nodegame-widgets
Version:
Collections of useful and reusable javascript / HTML snippets for nodeGame
104 lines (89 loc) • 2.9 kB
JavaScript
/**
* # ContentBox
* Copyright(c) 2019 Stefano Balietti
* MIT Licensed
*
* Displays some content.
*
* www.nodegame.org
*/
(function(node) {
"use strict";
node.widgets.register('ContentBox', ContentBox);
// ## Meta-data
ContentBox.version = '0.2.0';
ContentBox.description = 'Simply displays some content';
ContentBox.title = false;
ContentBox.panel = false;
ContentBox.className = 'contentbox';
// ## Dependencies
ContentBox.dependencies = {};
/**
* ## ContentBox constructor
*
*/
function ContentBox() {
// ### ContentBox.mainText
// The main text above the content.
this.mainText = null;
// ### ContentBox.content
// Some content to be displayed.
this.content = null;
// ### ContentBox.hint
// A hint text.
this.hint = null;
}
// ## ContentBox methods
ContentBox.prototype.init = function(opts) {
// Set the mainText, if any.
if ('string' === typeof opts.mainText) {
this.mainText = opts.mainText;
}
else if ('undefined' !== typeof opts.mainText) {
throw new TypeError('ContentBox.init: mainText must ' +
'be string or undefined. Found: ' +
opts.mainText);
}
// Set the content, if any.
if ('string' === typeof opts.content) {
this.content = opts.content;
}
else if ('undefined' !== typeof opts.content) {
throw new TypeError('ContentBox.init: content must ' +
'be string or undefined. Found: ' +
opts.content);
}
// Set the content, if any.
if ('string' === typeof opts.hint) {
this.hint = opts.hint;
}
else if ('undefined' !== typeof opts.hint) {
throw new TypeError('ContentBox.init: hint must ' +
'be string or undefined. Found: ' +
opts.hint);
}
};
ContentBox.prototype.append = function() {
// MainText.
if (this.mainText) {
W.append('span', this.bodyDiv, {
className: 'contentbox-maintext',
innerHTML: this.mainText
});
}
// Content.
if (this.content) {
W.append('div', this.bodyDiv, {
className: 'contentbox-content',
innerHTML: this.content
});
}
// Hint.
if (this.hint) {
W.append('span', this.bodyDiv, {
className: 'contentbox-hint',
innerHTML: this.hint
});
}
};
})(node);