ActiveContent¶
-
class
webix.
ActiveContent
()¶ Activecontent mixin
References¶
- helpers
_event()
,bind()
,isUndefined()
,ui()
.
External references¶
Code¶
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 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 | webix.ActiveContent = {
$init:function(config){
if (config.activeContent){
this.$ready.push(this._init_active_content_list);
this._active_holders = {};
this._active_holders_item = {};
this._active_holders_values = {};
this._active_references = {};
for (var key in config.activeContent){
this[key] = this._bind_active_content(key);
if (config.activeContent[key].earlyInit){
var temp = webix._parent_cell; webix._parent_cell = null;
this[key].call(this,{},this, config.activeContent);
webix._parent_cell=temp;
}
}
}
},
_destructActiveContent: function(){
for(var key in this._active_references){
var elem = this._active_references[key];
if(elem.destructor)
elem.destructor();
}
},
_init_active_content_list:function(){
this.attachEvent("onDestruct",webix.bind(this._destructActiveContent,this));
webix._event(this.$view, "blur", function(ev){
var target = ev.target || ev.srcElement;
// for inputs only
if(target.tagName != "BUTTON"){
var el = webix.$$(ev);
if (el !== this && el.getValue && el.setValue){
el.getNode(ev);
var newvalue = el.getValue();
if (newvalue != el._settings.value)
el.setValue(newvalue);
}
}
}, {bind:this, capture: true});
if (this.filter){
for (var key in this._settings.activeContent){
this.type[key] = this[key];
this[key] = this._locate_active_content_by_id(key);
}
//really bad!
this.attachEvent("onBeforeRender", function(){
this.type.masterUI = this;
});
this.type.masterUI = this;
}
},
_locate_active_content_by_id:function(key){
return function(id){
var button = this._active_references[key];
var button_id = button._settings.id;
var html = this.getItemNode(id).getElementsByTagName("DIV");
for (var i=0; i < html.length; i++) {
if (html[i].getAttribute("view_id") == button_id){
button._viewobj = button._dataobj = html[i];
break;
}
}
return button;
};
},
_get_active_node:function(el, key, master){
return function(e){
if (e){
var trg=e.target||e.srcElement;
while (trg){
if (trg.getAttribute && trg.getAttribute("view_id")){
master._setActiveContentView(el,trg);
if (master.locate){
var id = master.locate(trg.parentNode);
var value = master._active_holders_values[key][id];
el._settings.value = value;
el._settings.$masterId = id;
}
return trg;
}
trg = trg.parentNode;
}
}
return el._viewobj;
};
},
_set_new_active_value:function(key, master){
return function(value){
var data = master.data;
if (master.filter){
var id = master.locate(this._viewobj.parentNode);
data = master.getItem(id);
//XMLSerializer - FF "feature"
this.refresh();
master._active_holders_item[key][id]=this._viewobj.outerHTML||(new XMLSerializer().serializeToString(this._viewobj));
master._active_holders_values[key][id] = value;
}
if(data)
data[key] = value;
};
},
_bind_active_content:function(key){
return function(obj, common, active){
var object = common._active_holders?common:common.masterUI;
if (!object._active_holders[key]){
var d = document.createElement("DIV");
active = active || object._settings.activeContent;
var el = webix.ui(active[key], d);
d.firstChild.setAttribute("onclick", "event.processed = true; if (webix.env.isIE8) event.srcElement.w_view = '"+el._settings.id+"';");
el.getNode = object._get_active_node(el, key, object);
el.attachEvent("onChange", object._set_new_active_value(key, object));
object._active_references[key] = el;
object._active_holders[key] = d.innerHTML;
object._active_holders_item[key] = {};
object._active_holders_values[key] = {};
el.$activeEl = el.$view;
}
if (object.filter && obj[key] != object._active_holders_values[key] && !webix.isUndefined(obj[key])){
var el = object._active_references[key];
el.blockEvent();
object._setActiveContentView(el,el.$activeEl);
//in IE we can lost content of active element during parent repainting
if (!el.$view.firstChild) el.refresh();
el.setValue(obj[key]);
el.refresh();
el.unblockEvent();
object._active_holders_values[key][obj.id] = obj[key];
object._active_holders_item[key][obj.id] = el._viewobj.outerHTML||(new XMLSerializer().serializeToString(el._viewobj));
}
return object._active_holders_item[key][obj.id]||object._active_holders[key];
};
},
_setActiveContentView: function(el,view){
el._dataobj = el._viewobj = el.$view = view;
}
};
|