123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
'use strict';
modulum('LabelWidget', ['TextWidgetBase', 'WidgetFactory'],
function(context, cls) {
cls.LabelWidget = context.oo.Class(cls.TextWidgetBase, function($super) {
return {
__name: 'LabelWidget',
__dataContentPlaceholderSelector: cls.WidgetBase.selfDataContent,
_textContainer: null,
_hasHTMLContent: false,
_htmlFilter: null,
_value: null,
_displayFormat: null,
_sanitize: null,
_initLayout: function() {
if (!this._ignoreLayout) {
this._layoutInformation = new cls.LayoutInformation(this);
this._layoutEngine = new cls.LeafLayoutEngine(this);
this._layoutInformation.forcedMinimalWidth = 16;
this._layoutInformation.forcedMinimalHeight = 16;
}
},
resetLayout: function() {
if (this._layoutInformation) {
this._layoutInformation._initialMeasure = false;
this._layoutInformation.invalidateInitialMeasure(false, this._value !== null && this._value !== '' && this._value !==
false && this._value !== 0);
}
},
_initElement: function() {
$super._initElement.call(this);
this._textContainer = this._element.getElementsByTagName('span')[0];
},
destroy: function() {
this._textContainer = null;
if (this._htmlFilter) {
this._htmlFilter.destroy();
this._htmlFilter = null;
}
$super.destroy.call(this);
},
manageMouseClick: function(domEvent) {
this._onRequestFocus(domEvent);
this.emit(context.constants.widgetEvents.click, domEvent);
return true;
},
getDisplayFormat: function() {
return this._displayFormat;
},
setDisplayFormat: function(format) {
this._displayFormat = format;
},
setValue: function(value) {
var formattedValue = value;
var hadValue = this._value !== null && this._value !== '' && this._value !== false && this._value !== 0;
var hasValue = formattedValue !== null && formattedValue !== '' && formattedValue !== false && formattedValue !== 0;
if (this._layoutInformation) {
this._layoutInformation.invalidateInitialMeasure(hadValue, hasValue);
}
this._value = formattedValue || null;
this.domAttributesMutator(function() {
if (this._hasHTMLContent === true) {
if (this._sanitize) {
if (!this._htmlFilter) {
this._htmlFilter = cls.WidgetFactory.createWidget('HtmlFilterWidget', this.getBuildParameters());
}
this._textContainer.innerHTML = this._htmlFilter.sanitize(formattedValue);
} else {
this._textContainer.innerHTML = formattedValue;
}
} else {
var newValue = (formattedValue || formattedValue === 0 || formattedValue === false) ? formattedValue : '';
if (this.isInTable()) {
newValue = newValue.replace(/\n/g, " ");
}
this._textContainer.textContent = newValue;
this._textContainer.toggleClass("is-empty-label", newValue === "");
}
}.bind(this));
if (this._layoutEngine) {
if (!hadValue && hasValue) {
this._layoutEngine.forceMeasurement();
}
this._layoutEngine.invalidateMeasure();
}
},
getValue: function() {
if (this._hasHTMLContent === true) {
return this._textContainer.innerHTML;
} else {
var content = this._textContainer.textContent;
if (content === '\u00a0') {
return '';
}
return content;
}
},
getClipboardValue: function() {
return this.getValue();
},
setFocus: function(fromMouse) {
this._element.domFocus();
},
setHtmlControl: function(jcontrol) {
jcontrol.innerHTML = this.getValue();
jcontrol.addClass('gbc-label-text-container');
this._textContainer.replaceWith(jcontrol);
this._textContainer = jcontrol;
this._hasHTMLContent = true;
},
setSanitize: function(sanitize) {
this._sanitize = sanitize;
}
};
});
cls.WidgetFactory.registerBuilder('Label', cls.LabelWidget);
});