Feature #2910 ยป textsave.js
1 |
/*
|
---|---|
2 |
File: textsave.js
|
3 |
|
4 |
Description: Initialize an onbeforeunload-Event in Redmine, if changes in a form are made, but do not ask, if we submit a form
|
5 |
|
6 |
Author: mathias.fischer@berlinonline.de
|
7 |
|
8 |
*/
|
9 |
|
10 |
var TextSave = Class.create({ |
11 |
observedForms: false, |
12 |
observedElements: false, |
13 |
changedForms: false, |
14 |
|
15 |
initialize: function(){ |
16 |
this.observedForms = $$('form'); |
17 |
//Use #main to ignore the Search-Box
|
18 |
this.observedElements = $$('#main textarea','#main input','#main select'); |
19 |
|
20 |
this.observedElements.each(this.observeChange.bind(this)); |
21 |
this.observedForms.each(this.submitAction.bind(this)); |
22 |
|
23 |
//Event.stop returns "false", so we cannot use Prototypes Event.observe() here...
|
24 |
window.onbeforeunload = this.unload.bind(this); |
25 |
},
|
26 |
|
27 |
//Stuff to do before unload, confirm-box is display if a return-value is given
|
28 |
unload: function(){ |
29 |
if(this.changedForms) |
30 |
return "There are unsaved changes."; |
31 |
},
|
32 |
|
33 |
setChanged: function(){ |
34 |
this.changedForms = true; |
35 |
},
|
36 |
|
37 |
setUnchanged: function(){ |
38 |
this.changedForms = false; |
39 |
},
|
40 |
|
41 |
observeChange: function(element){ |
42 |
element.observe('change',this.setChanged.bindAsEventListener(this)); |
43 |
},
|
44 |
|
45 |
submitAction: function(element){ |
46 |
element.observe('submit',this.setUnchanged.bindAsEventListener(this)); |
47 |
}
|
48 |
|
49 |
});
|
50 |
|
51 |
|
52 |
document.observe("dom:loaded", function() { |
53 |
new TextSave(); |
54 |
});
|