aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/generators/rails/app/templates/public/javascripts/rails.js
diff options
context:
space:
mode:
authorPratik Naik <pratiknaik@gmail.com>2010-02-14 19:28:05 +0000
committerPratik Naik <pratiknaik@gmail.com>2010-02-14 19:28:05 +0000
commit6f3c5f67870a625b8be4de6e34e8d0d2f5d2b5e3 (patch)
tree3da8d75101aabe3c1d90d0582505ec1480c9d885 /railties/lib/generators/rails/app/templates/public/javascripts/rails.js
parent77bf78b3b78a41d4f2f6e733f5c9c00608c0adba (diff)
parenta1b60696e2b13cbe94d748444cc0da37b190fbb8 (diff)
downloadrails-6f3c5f67870a625b8be4de6e34e8d0d2f5d2b5e3.tar.gz
rails-6f3c5f67870a625b8be4de6e34e8d0d2f5d2b5e3.tar.bz2
rails-6f3c5f67870a625b8be4de6e34e8d0d2f5d2b5e3.zip
Merge remote branch 'mainstream/master'
Conflicts: railties/README railties/guides/source/active_support_core_extensions.textile railties/guides/source/getting_started.textile railties/lib/generators/rails/app/templates/README
Diffstat (limited to 'railties/lib/generators/rails/app/templates/public/javascripts/rails.js')
-rw-r--r--railties/lib/generators/rails/app/templates/public/javascripts/rails.js41
1 files changed, 37 insertions, 4 deletions
diff --git a/railties/lib/generators/rails/app/templates/public/javascripts/rails.js b/railties/lib/generators/rails/app/templates/public/javascripts/rails.js
index 2a0a05d25f..f7ddba390a 100644
--- a/railties/lib/generators/rails/app/templates/public/javascripts/rails.js
+++ b/railties/lib/generators/rails/app/templates/public/javascripts/rails.js
@@ -1,4 +1,11 @@
document.observe("dom:loaded", function() {
+ var authToken = $$('meta[name=csrf-token]').first().readAttribute('content'),
+ authParam = $$('meta[name=csrf-param]').first().readAttribute('content'),
+ formTemplate = '<form method="#{method}" action="#{action}">\
+ #{realmethod}<input name="#{param}" value="#{token}" type="hidden">\
+ </form>',
+ realmethodTemplate = '<input name="_method" value="#{method}" type="hidden">';
+
function handleRemote(element) {
var method, url, params;
@@ -34,20 +41,46 @@ document.observe("dom:loaded", function() {
}
$(document.body).observe("click", function(event) {
+ var message = event.element().readAttribute('data-confirm');
+ if (message && !confirm(message)) {
+ event.stop();
+ return false;
+ }
+
var element = event.findElement("a[data-remote=true]");
if (element) {
handleRemote(element);
event.stop();
}
- });
- $(document.body).observe("ajax:before", function(event) {
- var message = event.element().readAttribute('data-confirm');
- if (message && !confirm(message)) event.stop();
+ var element = event.findElement("a[data-method]");
+ if (element && element.readAttribute('data-remote') != 'true') {
+ var method = element.readAttribute('data-method'),
+ piggyback = method.toLowerCase() != 'post',
+ formHTML = formTemplate.interpolate({
+ method: 'POST',
+ realmethod: piggyback ? realmethodTemplate.interpolate({ method: method }) : '',
+ action: element.readAttribute('href'),
+ token: authToken,
+ param: authParam
+ });
+
+ var form = new Element('div').update(formHTML).down().hide();
+ this.insert({ bottom: form });
+
+ form.submit();
+ event.stop();
+ }
});
// TODO: I don't think submit bubbles in IE
$(document.body).observe("submit", function(event) {
+ var message = event.element().readAttribute('data-confirm');
+ if (message && !confirm(message)) {
+ event.stop();
+ return false;
+ }
+
var inputs = event.element().select("input[type=submit][data-disable-with]");
inputs.each(function(input) {
input.disabled = true;