mirror of
https://github.com/BorysLevytskyi/BitwiseCmd.git
synced 2025-12-18 02:42:24 +01:00
Extracted mode views and controllers into separate features.
This commit is contained in:
64
components/htmlBuilder.js
Normal file
64
components/htmlBuilder.js
Normal file
@@ -0,0 +1,64 @@
|
||||
(function(){
|
||||
|
||||
function HtmlBuilder() {
|
||||
this.sb = [];
|
||||
}
|
||||
|
||||
HtmlBuilder.prototype.element = function(tagName, arg1, arg2) {
|
||||
var attrs, elementContent;
|
||||
|
||||
if(typeof arg1 == "object") {
|
||||
attrs = arg1;
|
||||
}
|
||||
else if(typeof arg1 == "string") {
|
||||
attrs = { html: arg1 };
|
||||
}
|
||||
else {
|
||||
attrs = {};
|
||||
}
|
||||
|
||||
elementContent = attrs.html || arg2;
|
||||
|
||||
this.sb.push('<' + tagName + ' ' + getAttributesStr(attrs) + ">");
|
||||
|
||||
if(typeof elementContent == 'function') {
|
||||
elementContent();
|
||||
} else if (elementContent != null) {
|
||||
this.sb.push(elementContent.toString());
|
||||
}
|
||||
|
||||
this.sb.push('</' + tagName + '>');
|
||||
};
|
||||
|
||||
HtmlBuilder.prototype.toString = function () {
|
||||
return this.sb.join('\r\n');
|
||||
};
|
||||
|
||||
HtmlBuilder.prototype.toHtmlElement = function (){
|
||||
return HtmlBuilder.createElement(this.toString());
|
||||
};
|
||||
|
||||
HtmlBuilder.createElement = function(html) {
|
||||
var el = document.createElement('div');
|
||||
el.innerHTML = html;
|
||||
return el.children[0];
|
||||
};
|
||||
|
||||
function getAttributesStr(attr) {
|
||||
if(attr == null) {
|
||||
return '';
|
||||
}
|
||||
var str = [];
|
||||
|
||||
for(var key in attr) {
|
||||
if(key == 'html')
|
||||
continue;
|
||||
str.push(key + '="' + attr[key] + '"');
|
||||
}
|
||||
|
||||
return str.join(' ');
|
||||
}
|
||||
|
||||
window.HtmlBuilder = HtmlBuilder;
|
||||
|
||||
})();
|
||||
Reference in New Issue
Block a user