dataType: 'html',
success: function(data, textStatus) {
$(target).html(data);
- $(document).trigger('panel:unload', target);
$(document).trigger('panel:load', target);
// panel(target);
},
error: function(request, textStatus, errorThrown) {
- $(document).trigger('panel:unload', target);
console.log('ajax', url, target, 'error:', textStatus, errorThrown);
}
});
}
+// Funkcja do tworzenia nowych paneli
+function panel(load, unload) {
+ var self = null;
+ var eventId = Math.ceil(Math.random() * 1000000000);
+
+ unloadHandler = function(event, panel) {
+ if (self && self == panel) {
+ $(document).unbind('panel:unload.' + eventId, unloadHandler);
+ unload(event, panel);
+ }
+ };
+
+ $(document).one('panel:load', function(event, panel) {
+ self = panel;
+ $(document).bind('panel:unload.' + eventId, unloadHandler);
+ load(event, panel);
+ });
+}
+
$(function() {
// ========================
// = Resizable panels =
<textarea name="text" width="480px"><ala><ma></ma></ala></textarea>
</div>
<script type="text/javascript" charset="utf-8">
- (function() {
- var self = null;
- var id = Math.ceil(Math.random() * 1000000000);
-
- var load = function(event, panel) {
- console.log('loading panel', panel);
- self = panel;
- var textareaId = 'xmleditor-' + Math.ceil(Math.random() * 1000000000);
- $('textarea', panel).attr('id', textareaId);
- var editor = CodeMirror.fromTextArea(textareaId, {
- parserfile: 'parsexml.js',
- path: "/static/js/codemirror/",
- stylesheet: "/static/css/xmlcolors.css",
- parserConfig: {useHTMLKludges: false},
- initCallback: function() {}
- })
- $(document).unbind('panel:load.' + id, load);
- }
-
- var unload = function(event, panel) {
- console.log('unload event!', panel, self);
- if (panel == self) {
- console.log('unloading panel', self);
- $(document).unbind('panel:unload.' + id, unload);
- }
- };
-
- $(document).bind('panel:load.' + id, load);
- $(document).bind('panel:unload.' + id, unload);
- })();
+ panel(function(event, panel) {
+ console.log('loading panel', panel);
+ var textareaId = 'xmleditor-' + Math.ceil(Math.random() * 1000000000);
+ $('textarea', panel).attr('id', textareaId);
+ var editor = CodeMirror.fromTextArea(textareaId, {
+ parserfile: 'parsexml.js',
+ path: "/static/js/codemirror/",
+ stylesheet: "/static/css/xmlcolors.css",
+ parserConfig: {useHTMLKludges: false},
+ initCallback: function() {}
+ })
+ }, function(event, panel) {
+ console.log('unloaded panel', panel);
+ })
</script>