public
Description: use named routes in your JavaScript
Clone URL: git://github.com/bwyrosdick/less-js-routes.git
less-js-routes / README
100644 72 lines (46 sloc) 2.548 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
LessJsRoutes
============
 
Have you ever wanted to use named routes in your JavaScript? So have I. Now you can.
 
LessJsRoutes will generate a javascript file with functions that give you the path to the route
and functions that will call these routes using ajax (uses jQuery or Prototype).
 
 
 
 
 
Installation
============
1. ./script/plugin install http://lessjsroutes.googlecode.com/svn/trunk/less_js_routes
2. Add 'less_routes' to your javascript_include tag
3. Either:
 
  RAKE TASK:
    rake less:js:routes
    will create public/javascripts/less_routes.js
 
  AND/OR
    
  ENVIRONMENT:
    add
    Less::JsRoutes.generate!
    to your environment file. This will auto generate less_routes.js every time your rails app is started.
 
 
4. There is no number 4.
 
 
 
Usage
=====
In your routes file:
  map.resources :users do |user|
    user.resources :profiles
  end
 
In your layout:
  <%= javascript_include_tag :defaults, 'less_routes' %>
  
In your applicaiton.js (or any script block):
  users_path() => '/users'
  users_path({page: 1}) => '/users?page=1'
  users_ajax() => GET '/users'
  user_path(1) => '/users/1'
  user_ajax(1) => GET '/user/1'
  user_profile_path(1,5) => '/users/1/profiles/5'
  user_profile_ajax(1,5) => GET '/users/1/profiles/5'
  user_ajax('post', {name: 'fonzie', password: 'cool', password_confirmation: 'cool'}) => POST '/users'
  change_password_user_ajax('put', {password: 'cool', new_password: '2cool', password_confirmation: '2cool'}) => PUT '/users'
  
  _path functions return the path and take the proper variables, :id, :nested_id, :format, etc. A json object or pre-formatted string of querystring parameters can be passed as the last optional parameter.
  _ajax functions return the server response of the ajax call. The parameters are (1) the proper variable, :id, :nested_id, :format, :etc, (2) the http verb (get, post, put, delete) (get is default), an object or pre-formatted string of parameters, an object of any jQuery.ajax options that should be added to the ajax call.
  
 
 
 
Notes
=====
* Less Js Routes will use jQuery if available and Prototype if it is not.
* If a formatted ajax function is called with a json format, the json string will be converted and returned as a JavaScript object, not a string.
* This hasn't had a lot of testing in the wild, so please report any bugs you find to http://code.google.com/p/lessjsroutes/issues/entry.
 
 
Brought to you with love, from Less Everything (http://lesseverything.com)
  
Copyright (c) 2007 Less Everything, Inc., released under the MIT license