lolita 3.3.4 → 3.3.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (105) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/stylesheets/lolita/PIE-custom.htc +87 -87
  3. data/app/assets/stylesheets/lolita/PIE.htc +81 -81
  4. data/app/assets/stylesheets/lolita/application.css +6 -6
  5. data/app/assets/stylesheets/lolita/default.css.erb +169 -169
  6. data/app/assets/stylesheets/lolita/jquery-ui-1.8.16.lolita.css.erb +567 -567
  7. data/app/controllers/lolita/field_data_controller.rb~ +45 -0
  8. data/app/helpers/components/lolita/configuration/list_component.rb +10 -10
  9. data/app/views/components/lolita/configuration/column/_first.html.haml +1 -1
  10. data/app/views/components/lolita/configuration/column/header/_first.html.haml +1 -1
  11. data/app/views/components/lolita/configuration/column/header/_sort.html.haml +6 -6
  12. data/app/views/components/lolita/configuration/columns/header/_display.html.haml +5 -5
  13. data/app/views/components/lolita/configuration/field/array/autocomplete/_display.html.haml~ +16 -0
  14. data/app/views/components/lolita/configuration/field/array/checkbox/_display.html.haml +7 -7
  15. data/app/views/components/lolita/configuration/filter/_display.html.haml +2 -2
  16. data/app/views/components/lolita/configuration/filter/_display.html.haml~ +9 -0
  17. data/app/views/components/lolita/configuration/search/_display.html.haml +2 -2
  18. data/app/views/kaminari/lolita/_first_page.html.erb +11 -11
  19. data/app/views/kaminari/lolita/_gap.html.erb +8 -8
  20. data/app/views/kaminari/lolita/_last_page.html.erb +11 -11
  21. data/app/views/kaminari/lolita/_next_page.html.erb +11 -11
  22. data/app/views/kaminari/lolita/_page.html.erb +12 -12
  23. data/app/views/kaminari/lolita/_paginator.html.erb +23 -23
  24. data/app/views/kaminari/lolita/_prev_page.html.erb +11 -11
  25. data/app/views/lolita/info/index.html.erb +232 -232
  26. data/lib/lolita/adapter/field_helper.rb +18 -18
  27. data/lib/lolita/configuration/field/big_decimal.rb +12 -12
  28. data/lib/lolita/configuration/field/boolean.rb +12 -12
  29. data/lib/lolita/configuration/field/date.rb +12 -12
  30. data/lib/lolita/configuration/field/hidden.rb +12 -12
  31. data/lib/lolita/configuration/field/integer.rb +11 -11
  32. data/lib/lolita/configuration/field/string.rb +16 -16
  33. data/lib/lolita/configuration/field/time.rb +13 -13
  34. data/lib/lolita/configuration/field_set.rb +25 -25
  35. data/lib/lolita/configuration/filter.rb +1 -7
  36. data/lib/lolita/configuration/filter.rb~ +122 -0
  37. data/lib/lolita/configuration/nested_form.rb +104 -104
  38. data/lib/lolita/configuration/search.rb +104 -104
  39. data/lib/lolita/dbi/base.rb +56 -56
  40. data/lib/lolita/hooks/named_hook.rb +125 -125
  41. data/lib/lolita/lazy_loader.rb +54 -54
  42. data/lib/lolita/navigation/tree.rb +132 -132
  43. data/lib/lolita/ruby_ext/accessors.rb +26 -26
  44. data/lib/lolita/search/simple.rb +75 -75
  45. data/lib/lolita/support/formatter.rb +62 -62
  46. data/lib/lolita/support/formatter/rails.rb +56 -56
  47. data/lib/lolita/test/matchers.rb +77 -77
  48. data/lib/lolita/version.rb +1 -1
  49. data/lib/lolita/version.rb~ +30 -0
  50. data/spec/builder_spec.rb +120 -120
  51. data/spec/configuration/filter_spec.rb +1 -30
  52. data/spec/configuration/filter_spec.rb~ +167 -0
  53. data/spec/rails_app/app/controllers/application_controller.rb +3 -3
  54. data/spec/rails_app/app/helpers/application_helper.rb +3 -3
  55. data/spec/rails_app/app/mongoid/address.rb +7 -7
  56. data/spec/rails_app/app/mongoid/comment.rb +5 -5
  57. data/spec/rails_app/app/mongoid/preference.rb +5 -5
  58. data/spec/rails_app/app/mongoid/profile.rb +13 -13
  59. data/spec/rails_app/app/mongoid/tag.rb +3 -3
  60. data/spec/rails_app/app/views/components/lolita/configuration/list/_body_cell.html.erb +1 -1
  61. data/spec/rails_app/config/environment.rb +5 -5
  62. data/spec/rails_app/config/environments/production.rb +37 -37
  63. data/spec/rails_app/config/environments/test.rb +37 -37
  64. data/spec/rails_app/config/initializers/backtrace_silencers.rb +7 -7
  65. data/spec/rails_app/config/initializers/inflections.rb +2 -2
  66. data/spec/rails_app/config/initializers/secret_token.rb +1 -1
  67. data/spec/rails_app/lib/lolita/configuration/field/my_custom_collection.rb +13 -13
  68. data/spec/rails_app/log/development.log +753 -14016
  69. data/spec/rails_app/public/javascripts/jquery-1.5.1.min.js +15 -15
  70. data/spec/rails_app/public/javascripts/lolita/main.js +6 -6
  71. data/spec/rails_app/public/javascripts/modernizr-1.7.min.js +1 -1
  72. data/spec/rails_app/public/javascripts/rails.js +137 -137
  73. data/spec/rails_app/public/javascripts/tinymce/langs/en.js +221 -221
  74. data/spec/rails_app/public/javascripts/tinymce/license.txt +504 -504
  75. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/about.htm +52 -52
  76. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/anchor.htm +26 -26
  77. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/charmap.htm +51 -51
  78. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/color_picker.htm +74 -74
  79. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/editor_template_src.js +1328 -1328
  80. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/image.htm +80 -80
  81. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/about.js +73 -73
  82. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/anchor.js +42 -42
  83. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/charmap.js +354 -354
  84. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/color_picker.js +329 -329
  85. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/image.js +247 -247
  86. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/link.js +153 -153
  87. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/js/source_editor.js +56 -56
  88. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en.js +68 -68
  89. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/langs/en_dlg.js +53 -53
  90. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/link.htm +57 -57
  91. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/shortcuts.htm +47 -47
  92. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  93. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  94. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  95. data/spec/rails_app/public/javascripts/tinymce/themes/advanced/source_editor.htm +25 -25
  96. data/spec/rails_app/public/javascripts/tinymce/tiny_mce_popup.js +4 -4
  97. data/spec/rails_app/public/stylesheets/lolita/default.css +169 -169
  98. data/spec/rails_app/public/stylesheets/lolita/style.css +214 -214
  99. data/vendor/assets/javascripts/jquery-numeric.js +279 -279
  100. data/vendor/assets/javascripts/modernizr_1_7_min.js +1 -1
  101. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/content.css +66 -66
  102. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/dialog.css +117 -117
  103. data/vendor/assets/javascripts/tinymce/themes/advanced/skins/cirkuit/ui.css +988 -988
  104. data/vendor/assets/stylesheets/jquery-ui-1.8.16.custom.css +567 -567
  105. metadata +347 -340
@@ -1,247 +1,247 @@
1
- var ImageDialog = {
2
- preInit : function() {
3
- var url;
4
-
5
- tinyMCEPopup.requireLangPack();
6
-
7
- if (url = tinyMCEPopup.getParam("external_image_list_url"))
8
- document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>');
9
- },
10
-
11
- init : function() {
12
- var f = document.forms[0], ed = tinyMCEPopup.editor;
13
-
14
- // Setup browse button
15
- document.getElementById('srcbrowsercontainer').innerHTML = getBrowserHTML('srcbrowser','src','image','theme_advanced_image');
16
- if (isVisible('srcbrowser'))
17
- document.getElementById('src').style.width = '180px';
18
-
19
- e = ed.selection.getNode();
20
-
21
- this.fillFileList('image_list', 'tinyMCEImageList');
22
-
23
- if (e.nodeName == 'IMG') {
24
- f.src.value = ed.dom.getAttrib(e, 'src');
25
- f.alt.value = ed.dom.getAttrib(e, 'alt');
26
- f.border.value = this.getAttrib(e, 'border');
27
- f.vspace.value = this.getAttrib(e, 'vspace');
28
- f.hspace.value = this.getAttrib(e, 'hspace');
29
- f.width.value = ed.dom.getAttrib(e, 'width');
30
- f.height.value = ed.dom.getAttrib(e, 'height');
31
- f.insert.value = ed.getLang('update');
32
- this.styleVal = ed.dom.getAttrib(e, 'style');
33
- selectByValue(f, 'image_list', f.src.value);
34
- selectByValue(f, 'align', this.getAttrib(e, 'align'));
35
- this.updateStyle();
36
- }
37
- },
38
-
39
- fillFileList : function(id, l) {
40
- var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl;
41
-
42
- l = window[l];
43
-
44
- if (l && l.length > 0) {
45
- lst.options[lst.options.length] = new Option('', '');
46
-
47
- tinymce.each(l, function(o) {
48
- lst.options[lst.options.length] = new Option(o[0], o[1]);
49
- });
50
- } else
51
- dom.remove(dom.getParent(id, 'tr'));
52
- },
53
-
54
- update : function() {
55
- var f = document.forms[0], nl = f.elements, ed = tinyMCEPopup.editor, args = {}, el;
56
-
57
- tinyMCEPopup.restoreSelection();
58
-
59
- if (f.src.value === '') {
60
- if (ed.selection.getNode().nodeName == 'IMG') {
61
- ed.dom.remove(ed.selection.getNode());
62
- ed.execCommand('mceRepaint');
63
- }
64
-
65
- tinyMCEPopup.close();
66
- return;
67
- }
68
-
69
- if (!ed.settings.inline_styles) {
70
- args = tinymce.extend(args, {
71
- vspace : nl.vspace.value,
72
- hspace : nl.hspace.value,
73
- border : nl.border.value,
74
- align : getSelectValue(f, 'align')
75
- });
76
- } else
77
- args.style = this.styleVal;
78
-
79
- tinymce.extend(args, {
80
- src : f.src.value.replace(/ /g, '%20'),
81
- alt : f.alt.value,
82
- width : f.width.value,
83
- height : f.height.value
84
- });
85
-
86
- el = ed.selection.getNode();
87
-
88
- if (el && el.nodeName == 'IMG') {
89
- ed.dom.setAttribs(el, args);
90
- tinyMCEPopup.editor.execCommand('mceRepaint');
91
- tinyMCEPopup.editor.focus();
92
- } else {
93
- ed.execCommand('mceInsertContent', false, '<img id="__mce_tmp" />', {skip_undo : 1});
94
- ed.dom.setAttribs('__mce_tmp', args);
95
- ed.dom.setAttrib('__mce_tmp', 'id', '');
96
- ed.undoManager.add();
97
- }
98
-
99
- tinyMCEPopup.close();
100
- },
101
-
102
- updateStyle : function() {
103
- var dom = tinyMCEPopup.dom, st, v, f = document.forms[0];
104
-
105
- if (tinyMCEPopup.editor.settings.inline_styles) {
106
- st = tinyMCEPopup.dom.parseStyle(this.styleVal);
107
-
108
- // Handle align
109
- v = getSelectValue(f, 'align');
110
- if (v) {
111
- if (v == 'left' || v == 'right') {
112
- st['float'] = v;
113
- delete st['vertical-align'];
114
- } else {
115
- st['vertical-align'] = v;
116
- delete st['float'];
117
- }
118
- } else {
119
- delete st['float'];
120
- delete st['vertical-align'];
121
- }
122
-
123
- // Handle border
124
- v = f.border.value;
125
- if (v || v == '0') {
126
- if (v == '0')
127
- st['border'] = '0';
128
- else
129
- st['border'] = v + 'px solid black';
130
- } else
131
- delete st['border'];
132
-
133
- // Handle hspace
134
- v = f.hspace.value;
135
- if (v) {
136
- delete st['margin'];
137
- st['margin-left'] = v + 'px';
138
- st['margin-right'] = v + 'px';
139
- } else {
140
- delete st['margin-left'];
141
- delete st['margin-right'];
142
- }
143
-
144
- // Handle vspace
145
- v = f.vspace.value;
146
- if (v) {
147
- delete st['margin'];
148
- st['margin-top'] = v + 'px';
149
- st['margin-bottom'] = v + 'px';
150
- } else {
151
- delete st['margin-top'];
152
- delete st['margin-bottom'];
153
- }
154
-
155
- // Merge
156
- st = tinyMCEPopup.dom.parseStyle(dom.serializeStyle(st), 'img');
157
- this.styleVal = dom.serializeStyle(st, 'img');
158
- }
159
- },
160
-
161
- getAttrib : function(e, at) {
162
- var ed = tinyMCEPopup.editor, dom = ed.dom, v, v2;
163
-
164
- if (ed.settings.inline_styles) {
165
- switch (at) {
166
- case 'align':
167
- if (v = dom.getStyle(e, 'float'))
168
- return v;
169
-
170
- if (v = dom.getStyle(e, 'vertical-align'))
171
- return v;
172
-
173
- break;
174
-
175
- case 'hspace':
176
- v = dom.getStyle(e, 'margin-left')
177
- v2 = dom.getStyle(e, 'margin-right');
178
- if (v && v == v2)
179
- return parseInt(v.replace(/[^0-9]/g, ''));
180
-
181
- break;
182
-
183
- case 'vspace':
184
- v = dom.getStyle(e, 'margin-top')
185
- v2 = dom.getStyle(e, 'margin-bottom');
186
- if (v && v == v2)
187
- return parseInt(v.replace(/[^0-9]/g, ''));
188
-
189
- break;
190
-
191
- case 'border':
192
- v = 0;
193
-
194
- tinymce.each(['top', 'right', 'bottom', 'left'], function(sv) {
195
- sv = dom.getStyle(e, 'border-' + sv + '-width');
196
-
197
- // False or not the same as prev
198
- if (!sv || (sv != v && v !== 0)) {
199
- v = 0;
200
- return false;
201
- }
202
-
203
- if (sv)
204
- v = sv;
205
- });
206
-
207
- if (v)
208
- return parseInt(v.replace(/[^0-9]/g, ''));
209
-
210
- break;
211
- }
212
- }
213
-
214
- if (v = dom.getAttrib(e, at))
215
- return v;
216
-
217
- return '';
218
- },
219
-
220
- resetImageData : function() {
221
- var f = document.forms[0];
222
-
223
- f.width.value = f.height.value = "";
224
- },
225
-
226
- updateImageData : function() {
227
- var f = document.forms[0], t = ImageDialog;
228
-
229
- if (f.width.value == "")
230
- f.width.value = t.preloadImg.width;
231
-
232
- if (f.height.value == "")
233
- f.height.value = t.preloadImg.height;
234
- },
235
-
236
- getImageData : function() {
237
- var f = document.forms[0];
238
-
239
- this.preloadImg = new Image();
240
- this.preloadImg.onload = this.updateImageData;
241
- this.preloadImg.onerror = this.resetImageData;
242
- this.preloadImg.src = tinyMCEPopup.editor.documentBaseURI.toAbsolute(f.src.value);
243
- }
244
- };
245
-
246
- ImageDialog.preInit();
247
- tinyMCEPopup.onInit.add(ImageDialog.init, ImageDialog);
1
+ var ImageDialog = {
2
+ preInit : function() {
3
+ var url;
4
+
5
+ tinyMCEPopup.requireLangPack();
6
+
7
+ if (url = tinyMCEPopup.getParam("external_image_list_url"))
8
+ document.write('<script language="javascript" type="text/javascript" src="' + tinyMCEPopup.editor.documentBaseURI.toAbsolute(url) + '"></script>');
9
+ },
10
+
11
+ init : function() {
12
+ var f = document.forms[0], ed = tinyMCEPopup.editor;
13
+
14
+ // Setup browse button
15
+ document.getElementById('srcbrowsercontainer').innerHTML = getBrowserHTML('srcbrowser','src','image','theme_advanced_image');
16
+ if (isVisible('srcbrowser'))
17
+ document.getElementById('src').style.width = '180px';
18
+
19
+ e = ed.selection.getNode();
20
+
21
+ this.fillFileList('image_list', 'tinyMCEImageList');
22
+
23
+ if (e.nodeName == 'IMG') {
24
+ f.src.value = ed.dom.getAttrib(e, 'src');
25
+ f.alt.value = ed.dom.getAttrib(e, 'alt');
26
+ f.border.value = this.getAttrib(e, 'border');
27
+ f.vspace.value = this.getAttrib(e, 'vspace');
28
+ f.hspace.value = this.getAttrib(e, 'hspace');
29
+ f.width.value = ed.dom.getAttrib(e, 'width');
30
+ f.height.value = ed.dom.getAttrib(e, 'height');
31
+ f.insert.value = ed.getLang('update');
32
+ this.styleVal = ed.dom.getAttrib(e, 'style');
33
+ selectByValue(f, 'image_list', f.src.value);
34
+ selectByValue(f, 'align', this.getAttrib(e, 'align'));
35
+ this.updateStyle();
36
+ }
37
+ },
38
+
39
+ fillFileList : function(id, l) {
40
+ var dom = tinyMCEPopup.dom, lst = dom.get(id), v, cl;
41
+
42
+ l = window[l];
43
+
44
+ if (l && l.length > 0) {
45
+ lst.options[lst.options.length] = new Option('', '');
46
+
47
+ tinymce.each(l, function(o) {
48
+ lst.options[lst.options.length] = new Option(o[0], o[1]);
49
+ });
50
+ } else
51
+ dom.remove(dom.getParent(id, 'tr'));
52
+ },
53
+
54
+ update : function() {
55
+ var f = document.forms[0], nl = f.elements, ed = tinyMCEPopup.editor, args = {}, el;
56
+
57
+ tinyMCEPopup.restoreSelection();
58
+
59
+ if (f.src.value === '') {
60
+ if (ed.selection.getNode().nodeName == 'IMG') {
61
+ ed.dom.remove(ed.selection.getNode());
62
+ ed.execCommand('mceRepaint');
63
+ }
64
+
65
+ tinyMCEPopup.close();
66
+ return;
67
+ }
68
+
69
+ if (!ed.settings.inline_styles) {
70
+ args = tinymce.extend(args, {
71
+ vspace : nl.vspace.value,
72
+ hspace : nl.hspace.value,
73
+ border : nl.border.value,
74
+ align : getSelectValue(f, 'align')
75
+ });
76
+ } else
77
+ args.style = this.styleVal;
78
+
79
+ tinymce.extend(args, {
80
+ src : f.src.value.replace(/ /g, '%20'),
81
+ alt : f.alt.value,
82
+ width : f.width.value,
83
+ height : f.height.value
84
+ });
85
+
86
+ el = ed.selection.getNode();
87
+
88
+ if (el && el.nodeName == 'IMG') {
89
+ ed.dom.setAttribs(el, args);
90
+ tinyMCEPopup.editor.execCommand('mceRepaint');
91
+ tinyMCEPopup.editor.focus();
92
+ } else {
93
+ ed.execCommand('mceInsertContent', false, '<img id="__mce_tmp" />', {skip_undo : 1});
94
+ ed.dom.setAttribs('__mce_tmp', args);
95
+ ed.dom.setAttrib('__mce_tmp', 'id', '');
96
+ ed.undoManager.add();
97
+ }
98
+
99
+ tinyMCEPopup.close();
100
+ },
101
+
102
+ updateStyle : function() {
103
+ var dom = tinyMCEPopup.dom, st, v, f = document.forms[0];
104
+
105
+ if (tinyMCEPopup.editor.settings.inline_styles) {
106
+ st = tinyMCEPopup.dom.parseStyle(this.styleVal);
107
+
108
+ // Handle align
109
+ v = getSelectValue(f, 'align');
110
+ if (v) {
111
+ if (v == 'left' || v == 'right') {
112
+ st['float'] = v;
113
+ delete st['vertical-align'];
114
+ } else {
115
+ st['vertical-align'] = v;
116
+ delete st['float'];
117
+ }
118
+ } else {
119
+ delete st['float'];
120
+ delete st['vertical-align'];
121
+ }
122
+
123
+ // Handle border
124
+ v = f.border.value;
125
+ if (v || v == '0') {
126
+ if (v == '0')
127
+ st['border'] = '0';
128
+ else
129
+ st['border'] = v + 'px solid black';
130
+ } else
131
+ delete st['border'];
132
+
133
+ // Handle hspace
134
+ v = f.hspace.value;
135
+ if (v) {
136
+ delete st['margin'];
137
+ st['margin-left'] = v + 'px';
138
+ st['margin-right'] = v + 'px';
139
+ } else {
140
+ delete st['margin-left'];
141
+ delete st['margin-right'];
142
+ }
143
+
144
+ // Handle vspace
145
+ v = f.vspace.value;
146
+ if (v) {
147
+ delete st['margin'];
148
+ st['margin-top'] = v + 'px';
149
+ st['margin-bottom'] = v + 'px';
150
+ } else {
151
+ delete st['margin-top'];
152
+ delete st['margin-bottom'];
153
+ }
154
+
155
+ // Merge
156
+ st = tinyMCEPopup.dom.parseStyle(dom.serializeStyle(st), 'img');
157
+ this.styleVal = dom.serializeStyle(st, 'img');
158
+ }
159
+ },
160
+
161
+ getAttrib : function(e, at) {
162
+ var ed = tinyMCEPopup.editor, dom = ed.dom, v, v2;
163
+
164
+ if (ed.settings.inline_styles) {
165
+ switch (at) {
166
+ case 'align':
167
+ if (v = dom.getStyle(e, 'float'))
168
+ return v;
169
+
170
+ if (v = dom.getStyle(e, 'vertical-align'))
171
+ return v;
172
+
173
+ break;
174
+
175
+ case 'hspace':
176
+ v = dom.getStyle(e, 'margin-left')
177
+ v2 = dom.getStyle(e, 'margin-right');
178
+ if (v && v == v2)
179
+ return parseInt(v.replace(/[^0-9]/g, ''));
180
+
181
+ break;
182
+
183
+ case 'vspace':
184
+ v = dom.getStyle(e, 'margin-top')
185
+ v2 = dom.getStyle(e, 'margin-bottom');
186
+ if (v && v == v2)
187
+ return parseInt(v.replace(/[^0-9]/g, ''));
188
+
189
+ break;
190
+
191
+ case 'border':
192
+ v = 0;
193
+
194
+ tinymce.each(['top', 'right', 'bottom', 'left'], function(sv) {
195
+ sv = dom.getStyle(e, 'border-' + sv + '-width');
196
+
197
+ // False or not the same as prev
198
+ if (!sv || (sv != v && v !== 0)) {
199
+ v = 0;
200
+ return false;
201
+ }
202
+
203
+ if (sv)
204
+ v = sv;
205
+ });
206
+
207
+ if (v)
208
+ return parseInt(v.replace(/[^0-9]/g, ''));
209
+
210
+ break;
211
+ }
212
+ }
213
+
214
+ if (v = dom.getAttrib(e, at))
215
+ return v;
216
+
217
+ return '';
218
+ },
219
+
220
+ resetImageData : function() {
221
+ var f = document.forms[0];
222
+
223
+ f.width.value = f.height.value = "";
224
+ },
225
+
226
+ updateImageData : function() {
227
+ var f = document.forms[0], t = ImageDialog;
228
+
229
+ if (f.width.value == "")
230
+ f.width.value = t.preloadImg.width;
231
+
232
+ if (f.height.value == "")
233
+ f.height.value = t.preloadImg.height;
234
+ },
235
+
236
+ getImageData : function() {
237
+ var f = document.forms[0];
238
+
239
+ this.preloadImg = new Image();
240
+ this.preloadImg.onload = this.updateImageData;
241
+ this.preloadImg.onerror = this.resetImageData;
242
+ this.preloadImg.src = tinyMCEPopup.editor.documentBaseURI.toAbsolute(f.src.value);
243
+ }
244
+ };
245
+
246
+ ImageDialog.preInit();
247
+ tinyMCEPopup.onInit.add(ImageDialog.init, ImageDialog);