Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/ui/entity-editor/js/ |
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/js/ui/entity-editor/js/control.js |
/* eslint-disable */ BX.namespace("BX.UI"); if(typeof BX.UI.EntityEditorControl === "undefined") { BX.UI.EntityEditorControl = function() { this._id = ""; this._settings = {}; this._editor = null; this._parent = null; this._mode = BX.UI.EntityEditorMode.intermediate; this._modeOptions = BX.UI.EntityEditorModeOptions.none; this._model = null; this._schemeElement = null; this._container = null; this._wrapper = null; this._dragButton = null; this._dragItem = null; this._hasLayout = false; this._isValidLayout = false; this._isVisible = true; this._isActive = false; this._isChanged = false; this._isSchemeChanged = false; this._changeHandler = BX.delegate(this.onChange, this); this._contextMenuButton = null; this._isContextMenuOpened = false; this._modeChangeNotifier = null; this._configurationFieldManager = null; this._draggableContextId = ""; }; BX.UI.EntityEditorControl.prototype = { initialize: function(id, settings) { this._id = BX.type.isNotEmptyString(id) ? id : BX.util.getRandomString(4); this._settings = settings ? settings : {}; this._editor = BX.prop.get(this._settings, "editor", null); this._parent = BX.prop.get(this._settings, "parent", null); this._model = BX.prop.get(this._settings, "model", null); this._schemeElement = BX.prop.get(this._settings, "schemeElement", null); this._container = BX.prop.getElementNode(this._settings, "container", null); var mode = BX.prop.getInteger(this._settings, "mode", BX.UI.EntityEditorMode.view); if(mode === BX.UI.EntityEditorMode.edit && this._schemeElement && !this._schemeElement.isEditable()) { mode = BX.UI.EntityEditorMode.view; } this._mode = mode; this.doInitialize(); this.bindModel(); this.initializeManagers(); }, doInitialize: function() { }, bindModel: function() { }, unbindModel: function() { }, getMessage: function(name) { var m = BX.UI.EntityEditorControl.messages; return m.hasOwnProperty(name) ? m[name] : name; }, getId: function() { return this._id; }, getEditor: function() { return this._editor; }, setEditor: function(editor) { this._editor = editor; }, getParentPosition: function() { var parent = this.getParent(); return (parent ? parent.getPosition() : { top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 }); }, getParent: function() { return this._parent; }, setParent: function(parent) { this._parent = parent; }, getSiblingByIndex: function (index) { return this._editor ? this._editor.getControlByIndex(index) : null; }, getChildCount: function() { return 0; }, getChildById: function(childId) { return null; }, editChild: function(child) { }, removeChild: function(child) { }, getChildren: function() { return []; }, editChildConfiguration: function(child) { }, areAttributesEnabled: function() { return this._schemeElement && this._schemeElement.areAttributesEnabled(); }, getType: function() { return this._schemeElement ? this._schemeElement.getType() : ""; }, getName: function() { return this._schemeElement ? this._schemeElement.getName() : ""; }, getTitle: function() { if(!this._schemeElement) { return ""; } var title = this._schemeElement.getTitle(); if(title === "") { title = this._schemeElement.getName(); } return title; }, setTitle: function(title) { if(!this._schemeElement) { return; } this._schemeElement.setTitle(title); this.refreshTitleLayout(); }, getOptionFlags: function() { return(this._schemeElement ? this._schemeElement.getOptionFlags() : BX.UI.EntityEditorControlOptions.none ); }, setOptionFlags: function(flags) { if(this._schemeElement) { this._schemeElement.setOptionFlags(flags); } }, toggleOptionFlag: function(flag) { var flags = this.getOptionFlags(); if(BX.UI.EntityEditorControlOptions.check(flags, flag)) { flags &= ~flag; } else { flags |= flag; } this.setOptionFlags(flags); }, checkOptionFlag: function(flag) { return BX.UI.EntityEditorControlOptions.check(this.getOptionFlags(), flag); }, getData: function() { return this._schemeElement ? this._schemeElement.getData() : {}; }, getInnerConfig: function() { return this._schemeElement ? this._schemeElement.getInnerConfig() : {}; }, isVisible: function() { if(!this._isVisible) { return false; } if(this.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways)) { return true; } return BX.UI.EntityEditorVisibilityPolicy.checkVisibility(this); }, setVisible: function(visible) { visible = !!visible; if(this._isVisible === visible) { return; } this._isVisible = visible; if(this._hasLayout) { this._wrapper.style.display = this._isVisible ? "" : "none"; } }, isActive: function() { return this._isActive; }, setActive: function(active) { active = !!active; if(this._isActive === active) { return; } this._isActive = active; this.doSetActive(); }, doSetActive: function() { }, isEditable: function() { return this._schemeElement && this._schemeElement.isEditable(); }, isRequired: function() { return this._schemeElement && this._schemeElement.isRequired(); }, isRequiredConditionally: function() { return this._schemeElement && this._schemeElement.isRequiredConditionally(); }, isRequiredByAttribute: function() { return this._schemeElement && this._schemeElement.isRequiredByAttribute(); }, isHeading: function() { return this._schemeElement && this._schemeElement.isHeading(); }, getCreationPlaceholder: function() { return this._schemeElement ? this._schemeElement.getCreationPlaceholder() : ""; }, getChangePlaceholder: function() { return this._schemeElement ? this._schemeElement.getChangePlaceholder() : ""; }, isReadOnly: function() { return this._editor && this._editor.isReadOnly(); }, isEditInViewEnabled: function() { //"Edit in View" - control value may be changed in view mode return(this._editor && this._editor.isEditInViewEnabled() && this.getDataBooleanParam("enableEditInView", false) ); }, getVisibilityPolicy: function() { if(this._editor && !this._editor.isVisibilityPolicyEnabled()) { return BX.UI.EntityEditorVisibilityPolicy.always; } return this._schemeElement && this._schemeElement.getVisibilityPolicy(); }, getEditPriority: function() { return BX.UI.EntityEditorPriority.normal; }, getPosition: function() { return BX.pos(this._wrapper); }, focus: function() { }, save: function() { }, validate: function(result) { return true; }, rollback: function() { }, getMode: function() { return this._mode; }, setMode: function(mode, options) { if(!this.canChangeMode(mode)) { return; } var modeOptions = BX.prop.getInteger(options, "options", BX.UI.EntityEditorModeOptions.none); if(this._mode === mode && this._modeOptions === modeOptions) { return; } this.onBeforeModeChange(); this._mode = mode; this._modeOptions = modeOptions; this.doSetMode(this._mode); this.onAfterModeChange(); if(BX.prop.getBoolean(options, "notify", false)) { if(this._parent) { this._parent.processChildControlModeChange(this); } else if(this._editor) { this._editor.processControlModeChange(this); } } this._isSchemeChanged = false; this._isChanged = false; if(this._hasLayout) { this._isValidLayout = false; } }, onBeforeModeChange: function() { }, doSetMode: function(mode) { }, onAfterModeChange: function() { if(this._modeChangeNotifier) { this._modeChangeNotifier.notify(); } }, getModeChangeNotifier: function() { return this._modeChangeNotifier; }, canChangeMode: function(mode) { if(mode === BX.UI.EntityEditorMode.edit) { return this.isEditable(); } return true; }, isModeToggleEnabled: function() { return this._editor.isModeToggleEnabled(); }, toggleMode: function(notify, options) { if(!this.isModeToggleEnabled()) { return false; } this.setMode( this._mode === BX.UI.EntityEditorMode.view ? BX.UI.EntityEditorMode.edit : BX.UI.EntityEditorMode.view, { notify: notify } ); if(BX.prop.getBoolean(options, "refreshLayout", true)) { this.refreshLayout(); } return true; }, isSingleEditEnabled: function() { //"Single Edit" - control may be switched to edit mode independently of parent control (section) return( this.isModeToggleEnabled() && this.isEditable() && !this.getDataBooleanParam("enableEditInView", false) && this.getDataBooleanParam("enableSingleEdit", true) ); }, isEditInViewEnabled: function() { //"Edit in View" - control value may be changed in view mode return(this._editor && this._editor.isEditInViewEnabled() && this.getDataBooleanParam("enableEditInView", false) ); }, isInSingleEditMode: function() { if(!this.isInEditMode()) { return false; } return(this.checkModeOption(BX.UI.EntityEditorModeOptions.exclusive) || this.checkModeOption(BX.UI.EntityEditorModeOptions.individual) ); }, isInEditMode: function() { return this._mode === BX.UI.EntityEditorMode.edit; }, isInViewMode: function() { return this._mode === BX.UI.EntityEditorMode.view; }, checkModeOption: function(option) { return BX.UI.EntityEditorModeOptions.check(this._modeOptions, option); }, getContextId: function() { return this._editor ? this._editor.getContextId() : ''; }, getExternalContextId: function() { return this._editor ? this._editor.getExternalContextId() : ''; }, processSchemeChange: function() { }, processAvailableSchemeElementsChange: function() { }, processChildControlModeChange: function(control) { }, processChildControlChange: function(control, params) { }, isChanged: function() { return this._isChanged; }, markAsChanged: function(params) { if(typeof(params) === "undefined") { params = {}; } var control = BX.prop.get(params, "control", null); if(!(control && control instanceof BX.UI.EntityEditorControl)) { control = params["control"] = this; } if(!control.isInEditMode()) { return; } if(!this._isChanged) { this._isChanged = true; } this.notifyChanged(params); }, isSchemeChanged: function() { return this._isSchemeChanged; }, markSchemeAsChanged: function() { if(this._isSchemeChanged) { return; } var parent = this.getParent(); if(parent) { parent.markSchemeAsChanged(); } this._isSchemeChanged = true; }, saveScheme: function() { if(!this._isSchemeChanged) { return; } var parent = this.getParent(); if(parent && parent.isSchemeChanged()) { parent.saveScheme(); } this.commitSchemeChanges(); return this._editor.saveScheme(); }, commitSchemeChanges: function() { if(!this._isSchemeChanged) { return; } this._editor.updateSchemeElement(this._schemeElement); this._isSchemeChanged = false; }, getRootContainer: function() { return this._editor ? this._editor.getContainer() : null; }, getRootContainerPosition: function() { return BX.pos(this.getRootContainer()); }, getContainer: function() { return this._container; }, setContainer: function (container) { this._container = container; if(this._hasLayout) { this._hasLayout = false; } }, getWrapper: function() { return this._wrapper; }, enablePointerEvents: function(enable) { if(this._wrapper) { this._wrapper.style.pointerEvents = enable ? "" : "none"; } }, getModel: function() { return this._model; }, getSchemeElement: function() { return this._schemeElement; }, hasScheme: function() { return !!this._schemeElement; }, getDataBooleanParam: function(name, defaultval) { return(this._schemeElement ? this._schemeElement.getDataBooleanParam(name, defaultval) : defaultval ); }, hasLayout: function() { return this._hasLayout; }, layout: function(options) { }, registerLayout: function(options) { if(!this._wrapper) { return; } this._wrapper.setAttribute("data-cid", this.getId()); //HACK: Fix positions of context menu and drag button for readonly fields in editing section if(this.isInViewMode() && this._parent && this._parent.isInEditMode()) { BX.addClass(this._wrapper, "ui-entity-editor-content-block-field-readonly"); } else { BX.removeClass(this._wrapper, "ui-entity-editor-content-block-field-readonly"); } if(typeof options === "undefined") { options = {}; } if(!BX.prop.getBoolean(options, "preservePosition", false)) { var anchor = BX.prop.getElementNode(options, "anchor", null); if (anchor) { BX.addClass(this._wrapper, "ui-entity-card-content-hide"); this._container.insertBefore(this._wrapper, anchor); setTimeout(BX.delegate(function () { BX.removeClass(this._wrapper, "ui-entity-card-content-hide"); BX.addClass(this._wrapper, "ui-entity-card-content-show"); }, this), 1); setTimeout(BX.delegate(function () { BX.removeClass(this._wrapper, "ui-entity-card-content-show"); }, this), 310); } else { this._container.appendChild(this._wrapper); } } this._isValidLayout = true; this.doRegisterLayout(); }, doRegisterLayout: function() { }, needRefreshViewModeLayout: function(options) { if (this._mode === BX.UI.EntityEditorMode.edit) { return false; } if(!this._hasLayout) { return false; } return true; }, refreshViewModeLayout: function(options) { if (this.needRefreshViewModeLayout(options)) { this.refreshLayout(options); } }, refreshLayout: function(options) { if(!this._hasLayout) { return; } if(!BX.type.isPlainObject(options)) { options = {}; } options["preservePosition"] = true; this.clearLayout(options); if(BX.prop.getBoolean(options, "reset", false)) { this.reset(); } this.layout(options); }, clearLayout: function(options) { }, refreshTitleLayout: function() { }, releaseLayout: function () { this._wrapper = null; }, release: function() { }, reset: function() { }, onHideButtonClick: function(e) { this.hide(); }, createHideButton: function() { var enabled = !this.isRequired() && !this.isRequiredByAttribute() && !this.isRequiredConditionally(); var button = BX.create( "div", { props: { className: "ui-entity-widget-content-block-hide-btn", title: this.getHideButtonHint(enabled) } } ); if(enabled) { BX.bind(button, "click", BX.delegate(this.onHideButtonClick, this)); } return button; }, hide: function(options) { if(this.isRequired() || this.isRequiredByAttribute() || this.isRequiredConditionally()) { return; } if(this._parent) { BX.addClass(this._wrapper, "ui-entity-card-content-hide"); setTimeout(BX.delegate(function () { this._parent.removeChild(this, options); }, this), 350); } else { this.clearLayout(); } }, showMessageDialog: function(id, title, content) { if(this._editor) { this._editor.showMessageDialog(id, title, content); } }, prepareSaveData: function(data) { }, onBeforeSubmit: function() { }, onChange: function(e) { this.markAsChanged(); }, notifyChanged: function(params) { if(typeof(params) === "undefined") { params = {}; } if(this._parent) { this._parent.processChildControlChange(this, params); } else if(this._editor) { this._editor.processControlChange(this, params); } BX.onCustomEvent(this._editor, "onControlChanged", [ this, params ]); }, scrollIntoView: function() { var wrapper = this.getWrapper(); setTimeout(function() { var doc = BX.GetDocElement(document); var pos = BX.pos(wrapper); var finish = null; if (doc.scrollTop > pos.top - 10) { finish = pos.top - 10; } else if (doc.scrollTop + window.innerHeight < pos.bottom + 10) { finish = pos.bottom - window.innerHeight + 10; } if (BX.type.isNumber(finish)) { (new BX.easing({ duration: 150, start: {position: doc.scrollTop}, finish: {position: finish}, step: function(state) { doc.scrollTop = state.position; } })).animate(); } }, 300); }, //region D&D isDragEnabled: function() { if(!this._editor) { return false; } if(!this._editor.canChangeScheme()) { return false; } if(!this._schemeElement.isDragEnabled()) { return false; } return BX.prop.getBoolean( BX.prop.getObject( this._editor.getDragConfig(this.getDragObjectType()), "modes", {} ), BX.UI.EntityEditorMode.getName(this._mode), false ); }, getDragObjectType: function() { return BX.UI.EditorDragObjectType.intermediate; }, getChildDragObjectType: function() { return BX.UI.EditorDragObjectType.intermediate; }, getDragScope: function() { if(this._parent) { return this._parent.getChildDragScope(); } if(!this._editor) { return BX.UI.EditorDragScope.getDefault(); } return BX.prop.getInteger( this._editor.getDragConfig(this.getDragObjectType()), "scope", BX.UI.EditorDragScope.getDefault() ); }, getChildDragScope: function() { if(!this._editor) { return BX.UI.EditorDragScope.getDefault(); } return BX.prop.getInteger( this._editor.getDragConfig(this.getChildDragObjectType()), "scope", BX.UI.EditorDragScope.getDefault() ); }, getDraggableContextId: function() { return this._draggableContextId; }, setDraggableContextId: function(contextId) { this._draggableContextId = contextId; }, createDragButton: function() { return this._dragButton; }, //endregion //region Context Menu isContextMenuEnabled: function() { if(this._editor && !(this._editor.isFieldsContextMenuEnabled() && this._editor.canChangeScheme())) { return false; } return this._schemeElement ? this._schemeElement.isContextMenuEnabled() : false; }, onContextMenuShow: function() { this._isContextMenuOpened = true; }, onContextMenuClose: function() { BX.PopupMenu.destroy(this._id); }, onPopupDestroy: function() { this._isContextMenuOpened = false; }, createContextMenuButton: function() { this._contextMenuButton = BX.create("div", { props: { className: "ui-entity-editor-block-context-menu" }, events: { click: BX.delegate(this.onContextButtonClick, this) } }); return this._contextMenuButton; }, onContextButtonClick: function(e) { if(!this._isContextMenuOpened) { this.openContextMenu(); } else { this.closeContextMenu(); } }, openContextMenu: function() { if(this._isContextMenuOpened) { return; } var menu = this.prepareContextMenuItems(); if(BX.type.isArray(menu) && menu.length > 0) { var handler = BX.delegate( this.onContextMenuItemSelect, this); for(var i = 0, length = menu.length; i < length; i++) { if(typeof menu[i]["onclick"] === "undefined") { menu[i]["onclick"] = handler; } } BX.PopupMenu.show( this._id, this._contextMenuButton, menu, { angle: false, events: { onPopupShow: BX.delegate(this.onContextMenuShow, this), onPopupClose: BX.delegate(this.onContextMenuClose, this), onPopupDestroy: BX.delegate(this.onPopupDestroy, this) } } ); } }, closeContextMenu: function() { var menu = BX.PopupMenu.getMenuById(this._id); if(menu) { menu.popupWindow.close(); } }, onContextMenuItemSelect: function(e, item) { this.processContextMenuCommand(e, BX.prop.getString(item, "value")); }, prepareContextMenuItems: function() { return []; }, processContextMenuCommand: function(e, command) { }, //endregion isWaitingForInput: function() { return false; }, initializeManagers: function() { var eventArgs = { id: this.getId(), editor: this.getEditor(), type: this.getType(), configurationFieldManager: this._configurationFieldManager, }; BX.onCustomEvent(window, "BX.UI.EntityConfigurationManager:onInitialize", [ this, eventArgs ]); if (eventArgs.configurationFieldManager) { this._configurationFieldManager = eventArgs.configurationFieldManager; } }, getConfigurationFieldManager: function() { if (this._configurationFieldManager) { return this._configurationFieldManager; } return this.getEditor().getConfigurationFieldManager(); }, createGhostNode: function() { return null; }, getHideButtonHint: function(enabled) { return ""; } }; if (typeof (BX.UI.EntityEditorControl.messages) === "undefined") { BX.UI.EntityEditorControl.messages = {}; } } if(typeof BX.UI.EntityEditorField === "undefined") { /** * @extends BX.UI.EntityEditorControl * @constructor */ BX.UI.EntityEditorField = function() { BX.UI.EntityEditorField.superclass.constructor.apply(this); this._titleWrapper = null; this._singleEditButton = null; this._singleEditController = null; this._singleEditTimeoutHandle = 0; this._viewController = null; this._singleEditButtonHandler = BX.delegate(this.onSingleEditBtnClick, this); this._validators = null; this._hasError = false; this._errorContainer = null; this._layoutAttributes = null; this._spotlight = null; this._dragObjectType = BX.UI.EditorDragObjectType.field; this.eventsNamespace = 'BX.UI.EntityEditorField'; }; BX.extend(BX.UI.EntityEditorField, BX.UI.EntityEditorControl); BX.UI.EntityEditorField.prototype.isNewEntity = function() { return this._editor && this._editor.isNew(); }; BX.UI.EntityEditorField.prototype.configure = function() { if(this._parent) { this._parent.editChildConfiguration(this); } }; BX.UI.EntityEditorField.prototype.hasAttributeConfiguration = function(attributeTypeId) { return this._schemeElement.hasAttributeConfiguration(attributeTypeId); }; BX.UI.EntityEditorField.prototype.getAttributeConfiguration = function(attributeTypeId) { return this._schemeElement.getAttributeConfiguration(attributeTypeId); }; BX.UI.EntityEditorField.prototype.setAttributeConfiguration = function(configuration) { return this._schemeElement.setAttributeConfiguration(configuration); }; BX.UI.EntityEditorField.prototype.removeAttributeConfiguration = function(attributeTypeId) { return this._schemeElement.removeAttributeConfiguration(attributeTypeId); }; BX.UI.EntityEditorField.prototype.setVisibilityConfiguration = function(configuration) { return this._schemeElement.setVisibilityConfiguration(configuration); }; BX.UI.EntityEditorField.prototype.removeVisibilityConfiguration = function(attributeTypeId) { return this._schemeElement.removeVisibilityConfiguration(attributeTypeId); }; BX.UI.EntityEditorField.prototype.getDuplicateControlConfig = function() { return this._schemeElement ? this._schemeElement.getDataObjectParam("duplicateControl", null) : null; }; BX.UI.EntityEditorField.prototype.markAsChanged = function(params) { BX.UI.EntityEditorField.superclass.markAsChanged.apply(this, arguments); if(this.hasError()) { this.clearError(); } var validators = this.getValidators(); for(var i = 0, length = validators.length; i < length; i++) { validators[i].processFieldChange(this); } }; BX.UI.EntityEditorField.prototype.bindModel = function() { this._model.addChangeListener(BX.delegate(this.onModelChange, this)); this._model.addLockListener(BX.delegate(this.onModelLock, this)); }; BX.UI.EntityEditorField.prototype.onBeforeModeChange = function() { //Enable animation if it is going to view mode this._layoutAttributes = null; if(this.isInEditMode()) { this._layoutAttributes = { animate: "show" }; } }; BX.UI.EntityEditorField.prototype.needRefreshViewModeLayout = function(options) { if (!BX.UI.EntityEditorField.superclass.needRefreshViewModeLayout.call(this, options)) { return false; } var prevModel = BX.prop.get(options, 'previousModel', null); if (!prevModel) { return true; } var affectedFields = this._schemeElement ? this._schemeElement.getAffectedFields() : []; if (!affectedFields.length) { affectedFields.push(this.getDataKey()); } return affectedFields.reduce(function(result, fieldName) { return result || !this.areModelValuesEqual(prevModel, this._model, fieldName); }.bind(this), false); }; BX.UI.EntityEditorField.prototype.areModelValuesEqual = function(previousModel, currentModel, fieldName) { var prevModelHasField = previousModel.hasField(fieldName); var curModelHasField = currentModel.hasField(fieldName); if (!prevModelHasField && !curModelHasField) { return true; } if (!prevModelHasField || !curModelHasField) { return false; } var prevValue = previousModel.getField(fieldName); var curValue = currentModel.getField(fieldName); return this.areValuesEqual(prevValue, curValue); }; BX.UI.EntityEditorField.prototype.areValuesEqual = function(value1, value2) { return (JSON.stringify(value1) === JSON.stringify(value2)); }; BX.UI.EntityEditorField.prototype.onModelChange = function(sender, params) { this.processModelChange(params); }; BX.UI.EntityEditorField.prototype.onModelLock = function(sender, params) { this.processModelLock(params); }; BX.UI.EntityEditorField.prototype.processModelChange = function(params) { }; BX.UI.EntityEditorField.prototype.processModelLock = function(params) { }; BX.UI.EntityEditorField.prototype.getMessage = function(name) { var m = BX.UI.EntityEditorField.messages; return (m.hasOwnProperty(name) ? m[name] : BX.UI.EntityEditorField.superclass.getMessage.apply(this, arguments) ); }; BX.UI.EntityEditorField.prototype.hasContentWrapper = function() { return this.getContentWrapper() !== null; }; BX.UI.EntityEditorField.prototype.getHideButtonHint = function(enabled) { return this.getMessage( enabled ? "hideButtonHint" : "hideButtonDisabledHint" ); }; BX.UI.EntityEditorField.prototype.getEditButton = function() { return this._singleEditButton; }; BX.UI.EntityEditorField.prototype.getContentWrapper = function() { return null; }; BX.UI.EntityEditorField.prototype.ensureWrapperCreated = function(params) { if(!this._wrapper) { this._wrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" } }); } this.createAdditionalWrapperBlock(); var classNames = BX.prop.getArray(params, "classNames", []); for(var i = 0, length = classNames.length; i < length; i++) { BX.addClass(this._wrapper, classNames[i]); } return this._wrapper; }; BX.UI.EntityEditorField.prototype.createAdditionalWrapperBlock = function() { if(!this._wrapper) { return; } var additionalBlock = BX.create("div", { props: { className: "ui-entity-editor-block-before-action" }, attrs: { "data-field-tag": this.getId() } }); this._wrapper.appendChild(additionalBlock); }; BX.UI.EntityEditorField.prototype.adjustWrapper = function() { if(!this._wrapper) { return; } if(this.isInEditMode() && (this.checkModeOption(BX.UI.EntityEditorModeOptions.exclusive) || this.checkModeOption(BX.UI.EntityEditorModeOptions.individual) ) ) { BX.addClass(this._wrapper, "ui-entity-editor-content-block-edit"); } else { BX.removeClass(this._wrapper, "ui-entity-editor-content-block-edit"); } //region Applying layout attributes /* for(var i = this._wrapper.attributes.length - 1; i >= 0; i--) { this._wrapper.removeAttribute(this._wrapper.attributes[i].name); } */ if(this._layoutAttributes) { for(var key in this._layoutAttributes) { if(this._layoutAttributes.hasOwnProperty(key)) { this._wrapper.setAttribute("data-" + key, this._layoutAttributes[key]); } } this._layoutAttributes = null; } //endregion }; BX.UI.EntityEditorField.prototype.needShowTitle = function() { return this._schemeElement ? this._schemeElement.needShowTitle() : true; }; BX.UI.EntityEditorField.prototype.isVirtual = function() { return this._schemeElement ? this._schemeElement.isVirtual() : false; }; BX.UI.EntityEditorField.prototype.createTitleNode = function(title) { this._titleWrapper = BX.create("div", { attrs: { className: "ui-entity-editor-block-title" } } ); this.prepareTitleLayout(BX.type.isNotEmptyString(title) ? title : this.getTitle()); return this._titleWrapper; }; BX.UI.EntityEditorField.prototype.prepareTitleLayout = function(title) { if(!this._titleWrapper) { return; } var titleNode = BX.create("label", { attrs: { className: "ui-entity-editor-block-title-text" }, text: title } ); if (this._mode === BX.UI.EntityEditorMode.edit) { BX.addClass(this._titleWrapper, "ui-entity-widget-content-block-title-edit"); } var focusInputId = this.getFocusInputID(); if (focusInputId !== "") { BX.adjust(titleNode, { attrs: { "for": focusInputId} } ); } var marker = this.createTitleMarker(); if(marker) { titleNode.appendChild(marker); } var hint = this.createTitleHint(); if (hint) { titleNode.appendChild(hint); BX.UI.Hint.init(titleNode); } var lock = this.createTitleLock(); if (lock) { BX.Dom.prepend(lock, titleNode); BX.UI.Hint.init(titleNode); } this._titleWrapper.appendChild(titleNode); var actionControls = this.createTitleActionControls(); if(actionControls.length > 0) { var actionWrapper = BX.create("span", { attrs: { className: "ui-entity-editor-block-title-actions" } }); this._titleWrapper.appendChild(actionWrapper); for(var i = 0, length = actionControls.length; i < length; i++) { actionWrapper.appendChild(actionControls[i]); } } }; BX.UI.EntityEditorField.prototype.refreshTitleLayout = function() { if(!this._titleWrapper) { return; } BX.cleanNode(this._titleWrapper); this.prepareTitleLayout(this.getTitle()); }; BX.UI.EntityEditorField.prototype.createTitleMarker = function() { if(this._mode === BX.UI.EntityEditorMode.view) { return null; } if(this.isRequired() || this.isRequiredByAttribute()) { return BX.create("span", { style: { color: "#f00" }, text: "*" }); } else if(this.isRequiredConditionally()) { return BX.create("span", { text: "*" }); } return null; }; BX.UI.EntityEditorField.prototype.createTitleHint = function() { var hint = this._schemeElement ? this._schemeElement.getHint() : null; if(hint) { return BX.create("span", { dataset: { hint, hintHtml: true, hintInteractivity: true, } }); } return null; }; BX.UI.EntityEditorField.prototype.createTitleLock = function() { var lockText = this._schemeElement ? this._schemeElement.getLockText() : null; if (lockText && !this.isEditable()) { return BX.Tag.render` <span class="ui-btn ui-btn-link ui-btn-icon-lock ui-btn-icon-lock-entity-editor-title" data-hint="${BX.Text.encode(lockText)}" data-hint-no-icon="true" ></span> `; } return null; }; BX.UI.EntityEditorField.prototype.createTitleActionControls = function() { return []; }; BX.UI.EntityEditorField.prototype.clearLayout = function(options) { if(!this._hasLayout) { return; } this.releaseLightingAbilities(); BX.UI.EntityEditorField.superclass.clearLayout.apply(this, arguments); if(!BX.type.isPlainObject(options)) { options = {}; } this.releaseDragDropAbilities(); this.releaseSwitchingAbilities(); if(!BX.prop.getBoolean(options, "preservePosition", false)) { this._wrapper = BX.remove(this._wrapper); } else { BX.removeClass(this._wrapper, "ui-entity-editor-content-block-click-editable"); BX.removeClass(this._wrapper, "ui-entity-editor-content-block-click-empty"); this._wrapper = BX.cleanNode(this._wrapper); if(this.hasError()) { this.clearError(); } } if(this._singleEditButton) { this._singleEditButton = null; } this.doClearLayout(options); this._hasLayout = false; }; BX.UI.EntityEditorField.prototype.doClearLayout = function(options) { }; BX.UI.EntityEditorField.prototype.registerLayout = function(options) { var isVisible = this.isVisible(); var isNeedToDisplay = this.isNeedToDisplay(); this._wrapper.style.display = (isVisible && isNeedToDisplay) ? "" : "none"; this.initializeSwitchingAbilities(); if(this.isInEditMode() && this.checkModeOption(BX.UI.EntityEditorModeOptions.individual)) { window.setTimeout(BX.delegate(this.focus, this), 0); } BX.UI.EntityEditorField.superclass.registerLayout.apply(this, arguments); var lighting = BX.prop.getObject(options, "lighting", null); if(lighting) { window.setTimeout( function(){ this.initializeLightingAbilities(lighting); }.bind(this), 1000 ) } if(!isNeedToDisplay && BX.prop.getBoolean(options, "notifyIfNotDisplayed", false)) { const plainTitle = BX.util.htmlspecialchars(this.getTitle()); BX.UI.Notification.Center.notify( { content: BX.message("UI_ENTITY_EDITOR_FIELD_HIDDEN_IN_VIEW_MODE").replace(/#TITLE#/gi, plainTitle), position: "top-center", autoHideDelay: 5000 } ); } }; BX.UI.EntityEditorField.prototype.raiseLayoutEvent = function() { BX.onCustomEvent(window, this.eventsNamespace + ":onLayout", [ this ]); }; BX.UI.EntityEditorField.prototype.hasContentToDisplay = function() { return this.hasValue(); }; BX.UI.EntityEditorField.prototype.isNeedToDisplay = function(options) { if ( !(this._editor && this._editor.isExternalLayoutResolversEnabled()) && ( this._mode === BX.UI.EntityEditorMode.edit || this.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways) || this._schemeElement.isShownAlways() ) ) { return true; } if(this._editor && BX.prop.getBoolean(options, "enableLayoutResolvers", true)) { return BX.prop.getBoolean( this._editor.prepareFieldLayoutOptions(this), "isNeedToDisplay", true ); } return this.hasContentToDisplay(); }; BX.UI.EntityEditorField.prototype.isWaitingForInput = function() { return this.isInEditMode() && (this.isRequired() || this.isRequiredByAttribute()) && !this.hasValue(); }; BX.UI.EntityEditorField.prototype.hide = function(options) { if(!(this.isRequired() || this.isRequiredConditionally() || this.isRequiredByAttribute())) { BX.UI.EntityEditorField.superclass.hide.apply(this, arguments); BX.onCustomEvent(window, this.eventsNamespace + ":onChildMenuItemDeselect", [ this, arguments ]); } else { this.showMessageDialog( "operationDenied", BX.message("UI_ENTITY_EDITOR_HIDE_TITLE"), BX.message("UI_ENTITY_EDITOR_HIDE_DENIED") ); } }; //region Value BX.UI.EntityEditorField.prototype.getEditPriority = function() { var hasValue = this.hasValue(); if(!hasValue && (this.isRequired() || this.isRequiredByAttribute() || this.isRequiredConditionally())) { return BX.UI.EntityEditorPriority.high; } if(!this._editor.isNew()) { return BX.UI.EntityEditorPriority.normal; } return hasValue ? BX.UI.EntityEditorPriority.high : this.doGetEditPriority(); }; BX.UI.EntityEditorField.prototype.doGetEditPriority = function() { return BX.UI.EntityEditorPriority.normal; }; BX.UI.EntityEditorField.prototype.checkIfNotEmpty = function(value) { if(BX.type.isString(value)) { return value.trim() !== ""; } return (value !== null && value !== undefined); }; BX.UI.EntityEditorField.prototype.setupFromModel = function(model, options) { if(!model) { model = this._model; } if(!model) { return; } var data = this.getRelatedModelData(model); this._model.updateData(data, options); }; BX.UI.EntityEditorField.prototype.getRelatedModelData = function(model) { if(!model) { model = this._model; } if(!model) { return {}; } var data = {}; var keys = this.getRelatedDataKeys(); for(var i = 0, length = keys.length; i < length; i++) { var key = keys[i]; if(key !== "") { data[key] = model.getField(key, null); } } return data; }; BX.UI.EntityEditorField.prototype.getRelatedDataKeys = function() { return [this.getDataKey()]; }; BX.UI.EntityEditorField.prototype.hasValue = function() { return this.checkIfNotEmpty(this.getValue()); }; BX.UI.EntityEditorField.prototype.getValue = function(defaultValue) { if(!this._model) { return ""; } return( this._model.getField( this.getDataKey(), (defaultValue !== undefined ? defaultValue : "") ) ); }; BX.UI.EntityEditorField.prototype.getStringValue = function(defaultValue) { return this._model ? this._model.getStringField(this.getName(), defaultValue) : ""; }; BX.UI.EntityEditorField.prototype.getRuntimeValue = function() { return ""; }; BX.UI.EntityEditorField.prototype.getDataKey = function() { return this.getName(); }; BX.UI.EntityEditorField.prototype.prepareSaveData = function(data) { data[this.getDataKey()] = this.getValue(); }; //endregion //region Validators BX.UI.EntityEditorField.prototype.findValidatorIndex = function(validator) { if(!this._validators) { return -1; } for(var i = 0, length = this._validators.length; i < length; i++) { if(this._validators[i] === validator) { return i; } } return -1; }; BX.UI.EntityEditorField.prototype.addValidator = function(validator) { if(validator && this.findValidatorIndex(validator) < 0) { if(!this._validators) { this._validators = []; } this._validators.push(validator); } }; BX.UI.EntityEditorField.prototype.removeValidator = function(validator) { if(!this._validators || !validator) { return; } var index = this.findValidatorIndex(validator); if(index >= 0) { this._validators.splice(index, 1); } }; BX.UI.EntityEditorField.prototype.getValidators = function() { return this._validators ? this._validators : []; }; BX.UI.EntityEditorField.prototype.hasValidators = function() { return this._validators && this._validators.length > 0; }; BX.UI.EntityEditorField.prototype.executeValidators = function(result) { if(!this._validators) { return true; } var isValid = true; for(var i = 0, length = this._validators.length; i < length; i++) { if(!this._validators[i].validate(result)) { isValid = false; } } return isValid; }; //endregion BX.UI.EntityEditorField.prototype.hasError = function() { return this._hasError; }; BX.UI.EntityEditorField.prototype.showError = function(error, anchor) { if(!this._errorContainer) { this._errorContainer = BX.create( "div", { attrs: { className: "ui-entity-editor-field-error-text" } } ); } this._errorContainer.innerHTML = BX.util.htmlspecialchars(error); if (this._wrapper) { this._wrapper.appendChild(this._errorContainer); BX.addClass(this._wrapper, "ui-entity-editor-field-error"); } this._hasError = true; }; BX.UI.EntityEditorField.prototype.showRequiredFieldError = function(anchor) { this.showError(BX.message("UI_ENTITY_EDITOR_REQUIRED_FIELD_ERROR"), anchor); }; BX.UI.EntityEditorField.prototype.clearError = function() { if(!this._hasError) { return; } if(this._errorContainer && this._errorContainer.parentNode) { this._errorContainer.parentNode.removeChild(this._errorContainer); } BX.removeClass(this._wrapper, "ui-entity-editor-field-error"); this._hasError = false; }; BX.UI.EntityEditorField.prototype.isContentWrapperOnScreen = function() { if (this.hasContentWrapper()) { var doc = BX.GetDocElement(document); var pos = BX.pos(this.getContentWrapper()); if ( doc.scrollTop <= pos.top && doc.scrollTop + window.innerHeight >= pos.bottom ) { return true; } } return false; }; BX.UI.EntityEditorField.prototype.focus = function() { if (!this.isContentWrapperOnScreen()) { this.scrollAnimate(); } }; BX.UI.EntityEditorField.prototype.scrollAnimate = function() { var doc = BX.GetDocElement(document); var anchor = this._wrapper; window.setTimeout( function() { (new BX.easing( { duration : 300, start : { position: doc.scrollTop }, finish: { position: BX.pos(anchor).top - 10 }, step: function(state) { doc.scrollTop = state.position; } } ) ).animate(); }, 0 ); }; //region D&D BX.UI.EntityEditorField.prototype.createDragButton = function() { if(!this._dragButton) { this._dragButton = BX.create( "div", { props: { className: "ui-entity-editor-block-draggable-btn-container" }, children: [ BX.create( "div", { props: { className: "ui-entity-editor-draggable-btn" } } ) ] } ); } return this._dragButton; }; BX.UI.EntityEditorField.prototype.createGhostNode = function() { if(!this._wrapper) { return null; } var pos = BX.pos(this._wrapper); var node = BX.create('div', { props: { className: "ui-entity-field-grabbing"}, children: [ this._wrapper.cloneNode(true) ] }); node.style.width = pos.width + "px"; node.style.height = pos.height + "px"; return node; }; BX.UI.EntityEditorField.prototype.setDragObjectType = function(type) { this._dragObjectType = type; }; BX.UI.EntityEditorField.prototype.getDragObjectType = function() { return this._dragObjectType; }; BX.UI.EntityEditorField.prototype.initializeDragDropAbilities = function() { if(this._dragItem) { return; } this._dragItem = BX.UI.EditorDragItemController.create( "field_" + this.getId(), { charge: BX.UI.EditorFieldDragItem.create( { control: this, contextId: this._draggableContextId, scope: this.getDragScope() } ), node: this.createDragButton(), showControlInDragMode: false, ghostOffset: { x: 0, y: 0 } } ); }; BX.UI.EntityEditorField.prototype.releaseDragDropAbilities = function() { if(this._dragItem) { this._dragItem.release(); this._dragItem = null; } }; //endregion //region Context Menu BX.UI.EntityEditorField.prototype.prepareContextMenuItems = function() { var results = []; if (this.getEditor().canHideField()) { results.push({ value: "hide", text: BX.message("UI_ENTITY_EDITOR_HIDE") }); } results.push({ value: "configure", text: BX.message("UI_ENTITY_EDITOR_CONFIGURE") }); if (this._parent && this._parent.hasAdditionalMenu()) { var additionalMenu = this._parent.getAdditionalMenu(); for (var i=0; i<additionalMenu.length; i++) { results.push(additionalMenu[i]); } } if (this.getEditor().isShowAlwaysFeautureEnabled()) { results.push( { value: "showAlways", html: '<label class="ui-entity-card-context-menu-item-hide-empty-wrap">' + '<input type="checkbox"' + ( this.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways) ? ' checked = "true"' : '' ) + ' class="ui-entity-card-context-menu-item-hide-empty-input">' + '<span class="ui-entity-card-context-menu-item-hide-empty-text">' + BX.message("UI_ENTITY_EDITOR_SHOW_ALWAYS") + '</span></label>' } ); } this.doPrepareContextMenuItems(results); return results; }; BX.UI.EntityEditorField.prototype.doPrepareContextMenuItems = function(menuItems) { }; BX.UI.EntityEditorField.prototype.processContextMenuCommand = function(e, command) { if(command === "showAlways") { var target = BX.getEventTarget(e); if(target && target.tagName === "INPUT") { this.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); if(this._parent) { this._parent.processChildControlSchemeChange(this); } if(!this.isNeedToDisplay()) { window.setTimeout(BX.delegate(this.clearLayout, this), 500); var handledTitle = BX.util.htmlspecialchars(this.getTitle()); BX.UI.Notification.Center.notify( { content: BX.message("UI_ENTITY_EDITOR_FIELD_HIDDEN_DUE_TO_SHOW_ALWAYS_CHANGED").replace(/#TITLE#/gi, handledTitle), position: "top-center", autoHideDelay: 5000 } ); this.closeContextMenu(); } } return; } if(command === "hide") { window.setTimeout(BX.delegate(this.hide, this), 500); } else if(command === "configure") { this.configure(); } else if (this._parent && this._parent.hasAdditionalMenu()) { this._parent.processChildAdditionalMenuCommand(this, command); } this.closeContextMenu(); }; //endregion BX.UI.EntityEditorField.prototype.initializeSwitchingAbilities = function() { if(this.isInViewMode()) { if(this.isSingleEditEnabled()) { BX.addClass(this._wrapper, "ui-entity-editor-content-block-click-editable"); if(!this.hasContentToDisplay()) { BX.addClass(this._wrapper, "ui-entity-editor-content-block-click-empty"); } if(this._singleEditButton) { BX.bind(this._singleEditButton, "click", this._singleEditButtonHandler); } } if(this.hasContentWrapper() && BX.UI.EntityEditorModeSwitchType.check( this.getModeSwitchType(BX.UI.EntityEditorMode.edit), BX.UI.EntityEditorModeSwitchType.content ) ) { this._viewController = BX.UI.EditorFieldViewController.create( this._id, { field: this, wrapper: this.getContentWrapper() } ); } } else if(this.checkModeOption(BX.UI.EntityEditorModeOptions.exclusive)) { this._singleEditController = BX.UI.EditorFieldSingleEditController.create( this._id, { field: this } ); } }; BX.UI.EntityEditorField.prototype.releaseSwitchingAbilities = function() { if(this._singleEditButton) { BX.unbind(this._singleEditButton, "click", this._singleEditButtonHandler); } if(this._viewController) { this._viewController.release(); this._viewController = null; } if(this._singleEditController) { this._singleEditController.release(); this._singleEditController = null; } }; BX.UI.EntityEditorField.prototype.initializeLightingAbilities = function(params) { var text = BX.prop.getString(params, "text", ""); if(!BX.type.isNotEmptyString(text)) { return; } var wrapper = this.getContentWrapper(); if(!wrapper) { return; } this._spotlight = new BX.SpotLight( { id: BX.prop.getString(params, "id", ""), targetElement: wrapper, autoSave: true, content: text, targetVertex: "middle-left", zIndex: 200 } ); this._spotlight.show(); var events = BX.prop.getObject(params, "events", {}); for(var key in events) { if(events.hasOwnProperty(key)) { BX.addCustomEvent(this._spotlight, key, events[key]); } } }; BX.UI.EntityEditorField.prototype.releaseLightingAbilities = function() { if(this._spotlight) { this._spotlight.close(); this._spotlight = null; } }; BX.UI.EntityEditorField.prototype.getFocusInputID = function() { return ""; }; BX.UI.EntityEditorField.prototype.onSingleEditBtnClick = function(e) { if(!(this.isSingleEditEnabled() && this._editor)) { return; } if(this._singleEditTimeoutHandle > 0) { window.clearTimeout(this._singleEditTimeoutHandle); this._singleEditTimeoutHandle = 0; } this._singleEditTimeoutHandle = window.setTimeout( BX.delegate(this.switchToSingleEditMode, this), 250 ); BX.eventCancelBubble(e); }; BX.UI.EntityEditorField.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button; } return result; }; BX.UI.EntityEditorField.prototype.switchToSingleEditMode = function() { if(!(this.isSingleEditEnabled() && this._editor)) { return; } this._singleEditTimeoutHandle = 0; if(this._editor) { this._editor.switchControlMode( this, BX.UI.EntityEditorMode.edit, BX.UI.EntityEditorModeOptions.individual ); } }; if (typeof (BX.UI.EntityEditorField.messages) === "undefined") { BX.UI.EntityEditorField.messages = {}; } } if(typeof BX.UI.EntityEditorSectionContentStub === "undefined") { BX.UI.EntityEditorSectionContentStub = function() { this._settings = null; this._owner = null; this._container = null; this._wrapper = null; this._clickHandler = BX.delegate(this.onClick, this); }; BX.UI.EntityEditorSectionContentStub.prototype = { initialize: function(settings) { this._settings = settings ? settings : {}; this._owner = BX.prop.get(this._settings, "owner", null); this._container = BX.prop.getElementNode(this._settings, "container", null); }, layout: function() { this._wrapper = BX.create( "div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create( "div", { props: { className: "ui-entity-card-content-nothing-selected" }, children: [ BX.create( "div", { props: { className: "ui-entity-card-content-nothing-selected-text" }, text: BX.message("UI_ENTITY_EDITOR_NOTHING_SELECTED") } ) ] } ) ] } ); BX.bind(this._wrapper, "click", this._clickHandler); if(this._container.children.length > 0) { this._container.insertBefore(this._wrapper, this._container.children[0]); } else { this._container.appendChild(this._wrapper); } }, clearLayout: function() { BX.unbind(this._wrapper, "click", this._clickHandler); this._wrapper = BX.remove(this._wrapper); }, onStubClick: function(e) { if(this._owner && this._owner.isModeToggleEnabled()) { this._owner.toggle(); } } }; BX.UI.EntityEditorSectionContentStub.create = function(id, settings) { var self = new BX.UI.EntityEditorSectionContentStub(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorColumn === "undefined") { /** * @extends BX.UI.EntityEditorControl * @constructor */ BX.UI.EntityEditorColumn = function() { BX.UI.EntityEditorColumn.superclass.constructor.apply(this); this._sections = null; this._width = 0; this._draggableContextId = ""; this._dragContainerController = null; this._dragPlaceHolder = null; this._dropHandler = BX.delegate(this.onDrop, this); }; BX.extend(BX.UI.EntityEditorColumn, BX.UI.EntityEditorControl); BX.UI.EntityEditorColumn.prototype.doSetActive = function() { for(var i = 0, l = this._sections.length; i < l; i++) { this._sections[i].setActive(this._isActive); } }; //region Initialization BX.UI.EntityEditorColumn.prototype.initialize = function(id, settings) { BX.UI.EntityEditorColumn.superclass.initialize.call(this, id, settings); this.initializeFromModel(); this._width = this._schemeElement.getDataIntegerParam('width', 0); }; BX.UI.EntityEditorColumn.prototype.initializeFromModel = function() { var i, length; if(this._sections) { for(i = 0, length = this._sections.length; i < length; i++) { this._sections[i].release(); } } this._sections = []; var elements = this._schemeElement.getElements(); for(i = 0, length = elements.length; i < length; i++) { var element = elements[i]; var field = this._editor.createControl( element.getType(), element.getName(), { schemeElement: element, model: this._model, parent: this } ); if(!field) { continue; } element.setParent(this._schemeElement); field.setMode(this._mode, { notify: false }); this._sections.push(field); } }; //endregion //region Layout BX.UI.EntityEditorColumn.prototype.layout = function(options) { //Create wrapper this._wrapper = BX.create( "div", { props: {className: "ui-entity-editor-column-content"}, style: this._width ? {flex: this._width} : null } ); this._container.appendChild(this._wrapper); if (!BX.type.isPlainObject(options)) { options = {}; } var enableReset = BX.prop.getBoolean(options, "reset", false); var sectionOptions = options; if (sectionOptions.hasOwnProperty('anchor')) { delete sectionOptions.anchor; } for (var i = 0, l = this._sections.length; i < l; i++) { var section = this._sections[i]; section.setContainer(this._wrapper); //Force layout reset because of animation implementation section.releaseLayout(); if (enableReset) { section.reset(); } section.layout(sectionOptions); } if (this.isDragEnabled()) { this._dragContainerController = BX.UI.EditorDragContainerController.create( "column_" + this.getId(), { charge: BX.UI.EditorSectionDragContainer.create({ editor: this._editor, column: this }), node: this._wrapper } ); this._dragContainerController.addDragFinishListener(this._dropHandler); } this._hasLayout = true; }; BX.UI.EntityEditorColumn.prototype.clearLayout = function() { if(!this._hasLayout) { return; } for(var i = 0, length = this._sections.length; i < length; i++) { var section = this._sections[i]; section.clearLayout(); section.setContainer(null); } this._wrapper = BX.remove(this._wrapper); this._hasLayout = false; }; BX.UI.EntityEditorColumn.prototype.refreshLayout = function(options) { options = BX.type.isPlainObject(options) ? BX.mergeEx({}, options) : {}; //region CALLBACK var callback = BX.prop.getFunction(options, "callback", null); delete options["callback"]; //endregion //region ANCHOR delete options["anchor"]; if(this._wrapper && this._wrapper.nextSibling) { options["anchor"] = this._wrapper.nextSibling; } //endregion //region LAYOUT this.clearLayout(); this.layout(options); //endregion if(callback) { callback(); } }; BX.UI.EntityEditorColumn.prototype.refreshViewModeLayout = function(options) { if (this.needRefreshViewModeLayout(options)) { for (var i = 0, l = this._sections.length; i < l; i++) { var section = this._sections[i]; section.refreshViewModeLayout(options); } } }; BX.UI.EntityEditorColumn.prototype.onStubClick = function(e) { this.toggle(); }; BX.UI.EntityEditorColumn.prototype.processChildControlChange = function(child, params) { if(typeof(params) === "undefined") { params = {}; } if(!BX.prop.get(params, "control", null)) { params["control"] = child; } if(!child.isInEditMode() && !params["control"].isInEditMode()) { return; } this.markAsChanged(params); this.enableToggling(false); }; //region Toggling & Mode control BX.UI.EntityEditorColumn.prototype.enableToggling = function(enable) { enable = !!enable; if(this._enableToggling === enable) { return; } this._enableToggling = enable; }; BX.UI.EntityEditorColumn.prototype.toggle = function() { if(this._enableToggling && this._editor) { this._editor.switchControlMode( this, this._mode === BX.UI.EntityEditorMode.view ? BX.UI.EntityEditorMode.edit : BX.UI.EntityEditorMode.view ); } }; BX.UI.EntityEditorColumn.prototype.onToggleBtnClick = function(e) { this.toggle(); }; BX.UI.EntityEditorColumn.prototype.onBeforeModeChange = function() { }; BX.UI.EntityEditorColumn.prototype.doSetMode = function(mode) { for(var i = 0, l = this._sections.length; i < l; i++) { this._sections[i].setMode(mode, { notify: false }); } }; //endregion //region Tracking of Changes, Validation, Saving and Rolling back BX.UI.EntityEditorColumn.prototype.processAvailableSchemeElementsChange = function() { }; BX.UI.EntityEditorColumn.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { return true; } var validator = BX.UI.EntityAsyncValidator.create(); for(var i = 0, length = this._sections.length; i < length; i++) { var field = this._sections[i]; if(field.getMode() !== BX.UI.EntityEditorMode.edit) { continue; } validator.addResult(field.validate(result)); } return validator.validate(); }; BX.UI.EntityEditorColumn.prototype.commitSchemeChanges = function() { if(this._isSchemeChanged) { var schemeElements = []; for(var i = 0, length = this._sections.length; i < length; i++) { this._sections[i].commitSchemeChanges(); var schemeElement = this._sections[i].getSchemeElement(); if(schemeElement) { schemeElements.push(schemeElement); } } this._schemeElement.setElements(schemeElements); } return BX.UI.EntityEditorColumn.superclass.commitSchemeChanges.call(this); }; BX.UI.EntityEditorColumn.prototype.save = function() { for(var i = 0, length = this._sections.length; i < length; i++) { this._sections[i].save(); } }; BX.UI.EntityEditorColumn.prototype.rollback = function() { for(var i = 0, l = this._sections.length; i < l; i++) { this._sections[i].rollback(); } if(this._isChanged) { this.initializeFromModel(); this._isChanged = false; } }; BX.UI.EntityEditorColumn.prototype.onBeforeSubmit = function() { for(var i = 0, length = this._sections.length; i < length; i++) { this._sections[i].onBeforeSubmit(); } }; //endregion //region Children & User Fields BX.UI.EntityEditorColumn.prototype.getChildIndex = function(child) { for(var i = 0, l = this._sections.length; i < l; i++) { if(this._sections[i] === child) { return i; } } return -1; }; BX.UI.EntityEditorColumn.prototype.addChild = function(child, options) { if(!BX.type.isPlainObject(options)) { options = {}; } var related = null; var index = BX.prop.getInteger(options, "index", -1); if(index >= 0) { this._sections.splice(index, 0, child); if(index < (this._sections.length - 1)) { related = this._sections[index + 1]; } } else { this._sections.push(child); related = BX.prop.get(options, "related", null); } if(child.getParent() !== this) { child.setParent(this); } if(child.hasScheme()) { child.getSchemeElement().setParent(this._schemeElement); } child.setActive(this._isActive); if(this._hasLayout) { child.setContainer(this._wrapper); var layoutOpts = BX.prop.getObject(options, "layout", {}); if(related) { layoutOpts["anchor"] = related.getWrapper(); } child.layout(layoutOpts); } if(child.hasScheme()) { this._editor.processControlAdd(child); this.markSchemeAsChanged(); if(BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } } }; BX.UI.EntityEditorColumn.prototype.removeChild = function(child, options) { if(!BX.type.isPlainObject(options)) { options = {}; } var index = this.getChildIndex(child); if(index < 0) { return; } if(child.isActive()) { child.setActive(false); } this._sections.splice(index, 1); var processScheme = child.hasScheme(); if(processScheme) { child.getSchemeElement().setParent(null); } if(this._hasLayout) { child.clearLayout(); child.setContainer(null); } if(processScheme) { this._editor.processControlRemove(child); this.markSchemeAsChanged(); if(BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } } }; BX.UI.EntityEditorColumn.prototype.moveChild = function(child, index, options) { if (!BX.type.isPlainObject(options)) { options = {}; } var qty = this.getChildCount(); var lastIndex = qty - 1; if (index < 0 || index > qty) { index = lastIndex; } var currentIndex = this.getChildIndex(child); if (currentIndex < 0 || currentIndex === index) { return false; } if (this._hasLayout) { child.clearLayout(); } this._sections.splice(currentIndex, 1); qty--; var anchor = null; if (this._hasLayout) { anchor = index < qty ? this._sections[index].getWrapper() : null; } if (index < qty) { this._sections.splice(index, 0, child); } else { this._sections.push(child); } if (this._hasLayout) { if (anchor) { child.layout({anchor: anchor}); } else { child.layout(); } } this._editor.processControlMove(child); this.markSchemeAsChanged(); if (BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } return true; }; BX.UI.EntityEditorColumn.prototype.editChild = function(child) { if(this._mode === BX.UI.EntityEditorMode.edit) { child.focus(); } else if(!this.isReadOnly()) { var isHomogeneous = true; for(var i = 0, length = this._sections.length; i < length; i++) { if(this._sections[i].getMode() !== this._mode) { isHomogeneous = false; break; } } if(isHomogeneous) { this.setMode(BX.UI.EntityEditorMode.edit, { notify: true }); this.refreshLayout( { callback: function(){ child.focus(); } } ); } } }; BX.UI.EntityEditorColumn.prototype.getChildById = function(childId) { for(var i = 0, length = this._sections.length; i < length; i++) { var field = this._sections[i]; if(field.getId() === childId) { return field; } var child = field.getChildById(childId); if(child) { return child; } } return null; }; BX.UI.EntityEditorColumn.prototype.getChildCount = function() { return this._sections.length; }; BX.UI.EntityEditorColumn.prototype.getChildren = function() { return this._sections; }; BX.UI.EntityEditorColumn.prototype.processChildControlModeChange = function(child) { if(!this.isActive() && this._editor) { this._editor.processControlModeChange(child); } }; //region Context Menu BX.UI.EntityEditorColumn.prototype.hasAdditionalMenu = function() { return false; }; BX.UI.EntityEditorColumn.prototype.getAdditionalMenu = function() { return []; }; //endregion BX.UI.EntityEditorColumn.prototype.isWaitingForInput = function() { for(var i = 0, l = this._sections.length; i < l; i++) { if(this._sections[i].isWaitingForInput()) { return true; } } return false; }; BX.UI.EntityEditorColumn.prototype.isRequired = function() { for(var i = 0, l = this._sections.length; i < l; i++) { if(this._sections[i].isRequired()) { return true; } } return false; }; BX.UI.EntityEditorColumn.prototype.isRequiredConditionally = function() { for(var i = 0, l = this._sections.length; i < l; i++) { if(this._sections[i].isRequiredConditionally()) { return true; } } return false; }; BX.UI.EntityEditorColumn.prototype.getDragObjectType = function() { return BX.UI.EditorDragObjectType.section; }; BX.UI.EntityEditorColumn.prototype.getChildDragObjectType = function() { return BX.UI.EditorDragObjectType.field; }; BX.UI.EntityEditorColumn.prototype.hasPlaceHolder = function() { return !!this._dragPlaceHolder; }; BX.UI.EntityEditorColumn.prototype.createPlaceHolder = function(index) { var qty = this._sections.length; if (index < 0 || index > qty) { index = qty > 0 ? qty : 0; } if (this._dragPlaceHolder) { if (this._dragPlaceHolder.getIndex() === index) { return this._dragPlaceHolder; } this._dragPlaceHolder.clearLayout(); this._dragPlaceHolder = null; } this._dragPlaceHolder = BX.UI.EditorDragSectionPlaceholder.create( { container: this._wrapper, anchor: (index < qty) ? this._sections[index].getWrapper() : null, index: index } ); this._dragPlaceHolder.layout(); return this._dragPlaceHolder; }; BX.UI.EntityEditorColumn.prototype.getPlaceHolder = function() { return this._dragPlaceHolder; }; BX.UI.EntityEditorColumn.prototype.removePlaceHolder = function() { if(this._dragPlaceHolder) { this._dragPlaceHolder.clearLayout(); this._dragPlaceHolder = null; } }; BX.UI.EntityEditorColumn.prototype.processDraggedItemDrop = function(dropContainer, draggedItem) { var containerCharge = dropContainer.getCharge(); if(!((containerCharge instanceof BX.UI.EditorSectionDragContainer) && containerCharge.getColumn() === this)) { return; } var context = draggedItem.getContextData(); var contextId = BX.type.isNotEmptyString(context["contextId"]) ? context["contextId"] : ""; if(contextId !== BX.UI.EditorSectionDragItem.contextId) { return; } var placeholder = this.getPlaceHolder(); var placeholderIndex = placeholder ? placeholder.getIndex() : -1; if(placeholderIndex < 0) { return; } var itemCharge = typeof(context["charge"]) !== "undefined" ? context["charge"] : null; if(!(itemCharge instanceof BX.UI.EditorSectionDragItem)) { return; } var source = itemCharge.getControl(); if(!source) { return; } var sourceParent = source.getParent(); if(sourceParent === this) { var currentIndex = this.getChildIndex(source); if(currentIndex < 0) { return; } var index = placeholderIndex <= currentIndex ? placeholderIndex : (placeholderIndex - 1); if(index === currentIndex) { return; } this.moveChild(source, index, { enableSaving: false }); this._editor.saveSchemeChanges(); } else { var schemeElement = source.getSchemeElement(); if(source.getMode() === BX.UI.EntityEditorMode.edit) { this._editor.unregisterActiveControl(source); } sourceParent.removeChild(source, { enableSaving: false }); var target = this._editor.createControl( schemeElement.getType(), schemeElement.getName(), { schemeElement: schemeElement, model: this._model, parent: this, mode: source.getMode() } ); this.addChild(target, { index: placeholderIndex}); this._editor.processControlModeChange(target); this._editor.saveSchemeChanges(); } }; BX.UI.EntityEditorColumn.prototype.onDrop = function(event) { this.processDraggedItemDrop(event.data["dropContainer"], event.data["draggedItem"]); }; BX.UI.EntityEditorColumn.prototype.initializeDragDropAbilities = function() { if(this._dragItem) { return; } this._dragItem = BX.UI.EditorDragItemController.create( "section_" + this.getId(), { charge: BX.UI.EditorSectionDragItem.create({ control: this }), node: this.createDragButton(), showControlInDragMode: false, ghostOffset: { x: 0, y: 0 } } ); }; BX.UI.EntityEditorColumn.prototype.releaseDragDropAbilities = function() { if(this._dragItem) { this._dragItem.release(); this._dragItem = null; } }; BX.UI.EntityEditorColumn.create = function(id, settings) { var self = new BX.UI.EntityEditorColumn(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorSection === "undefined") { /** * @extends BX.UI.EntityEditorControl * @constructor */ BX.UI.EntityEditorSection = function() { BX.UI.EntityEditorSection.superclass.constructor.apply(this); this._fields = null; this._fieldConfigurator = null; this._mandatoryConfigurator = null; this._visibilityConfigurator = null; this._titleEditButton = null; this._titleEditHandler = BX.delegate(this.onTitleEditButtonClick, this); this._headerContainer = null; this._titleContainer = null; this._titleView = null; this._titleInput = null; this._titleActions = null; this._titleMode = BX.UI.EntityEditorMode.intermediate; this._titleInputKeyHandler = BX.delegate(this.onTitleInputKeyPress, this); this._documentClickHandler = BX.delegate(this.onExternalClick, this); this._detetionConfirmDlgId = "section_deletion_confirm"; this._enableToggling = true; this._toggleButton = null; this._addChildButton = null; this._buttonPanelBlockLeft = null; this._buttonPanelBlockRight = null; this._createChildButton = null; this._childSelectMenu = null; this._buttonPanelWrapper = null; this._deleteButton = null; this._deleteButtonHandler = BX.delegate(this.onDeleteSectionBtnClick, this); this._draggableContextId = ""; this._dragContainerController = null; this._dragPlaceHolder = null; this._dropHandler = BX.delegate(this.onDrop, this); this._fieldSelector = null; this._fieldTypeSelectMenu = null; this._stub = null; this._detailButton = null; this.eventsNamespace = 'BX.UI.EntityEditorSection'; }; BX.extend(BX.UI.EntityEditorSection, BX.UI.EntityEditorControl); BX.UI.EntityEditorSection.prototype.doSetActive = function() { for(var i = 0, l = this._fields.length; i < l; i++) { this._fields[i].setActive(this._isActive); } }; //region Initialization BX.UI.EntityEditorSection.prototype.initialize = function(id, settings) { BX.UI.EntityEditorSection.superclass.initialize.call(this, id, settings); this._draggableContextId = BX.UI.EditorFieldDragItem.contextId; if(this.getChildDragScope() === BX.UI.EditorDragScope.parent) { this._draggableContextId += "_" + this.getId(); } this.initializeFromModel(); }; BX.UI.EntityEditorSection.prototype.initializeFromModel = function() { this.release(); var elements = this._schemeElement.getElements(); for(var i = 0, length = elements.length; i < length; i++) { var element = elements[i]; var field = this._editor.createControl( element.getType(), element.getName(), { schemeElement: element, model: this._model, parent: this } ); if(!field) { continue; } element.setParent(this._schemeElement); field.setMode(this._mode, { notify: false }); this._fields.push(field); } }; //endregion //region Layout BX.UI.EntityEditorSection.prototype.registerLayout = function(options) { this._wrapper.style.display = this.isVisible() ? '' : 'none'; BX.UI.EntityEditorField.superclass.registerLayout.apply(this, arguments); }; BX.UI.EntityEditorSection.prototype.layout = function(options) { //Create wrapper var title = this._schemeElement.getTitle(); this._contentContainer = BX.create("div", {props: { className: "ui-entity-editor-section-content" } }); var isViewMode = this._mode === BX.UI.EntityEditorMode.view ; var wrapperClassName = isViewMode ? "ui-entity-editor-section" : "ui-entity-editor-section-edit"; this._enableToggling = this.isModeToggleEnabled() && this._schemeElement.getDataBooleanParam("enableToggling", true); this._toggleButton = BX.create("span", { attrs: { className: "ui-entity-editor-header-edit-lnk" }, events: { click: BX.delegate(this.onToggleBtnClick, this) }, text: BX.message(isViewMode ? "UI_ENTITY_EDITOR_CHANGE" : "UI_ENTITY_EDITOR_CANCEL") } ); if(!this._enableToggling) { this._toggleButton.style.display = "none"; } var firstColumn = this.getEditor().getControlByIndex(0); var url = BX.prop.getString(this.getEditor()._settings, "entityDetailsUrl", ""); if (this.getEditor().isEmbedded() && url.length) { var sectionIndex = null; if(firstColumn) { sectionIndex = firstColumn.getChildren().indexOf(this); } if (sectionIndex === 0) { this._detailButton = BX.create("a", { attrs: { className: "ui-entity-editor-detail-btn", href: url }, text: BX.message('UI_ENTITY_EDITOR_SECTION_OPEN_DETAILS') } ); } } this._titleMode = BX.UI.EntityEditorMode.view; this._wrapper = BX.create("div", { props: { className: wrapperClassName }}); if(this._schemeElement.isTitleEnabled()) { this._headerContainer = BX.create('div', { props: { className: 'ui-entity-editor-section-header' } }); if(this.isDragEnabled()) { this._headerContainer.appendChild(this.createDragButton()); } this._titleEditButton = BX.create("span", { props: { className: "ui-entity-editor-header-title-edit-icon" }, events: { click: this._titleEditHandler } }); if(!this._editor.isSectionEditEnabled() || !this._editor.canChangeScheme()) { this._titleEditButton.style.display = "none"; } this._titleView = BX.create("span", { props: { className: "ui-entity-editor-header-title-text" }, text: title }); var hint = this.createTitleHint(); if (hint) { this._titleView.appendChild(hint); BX.UI.Hint.init(this._titleView); } this._titleInput = BX.create("input", { props: { className: "ui-entity-editor-header-title-text" }, style: { display: "none" } }); this._titleActions = BX.create("div", { props: { className: "ui-entity-editor-header-actions" }, children : [ this._toggleButton ] }); if (this._detailButton) { this._titleActions.appendChild(this._detailButton); } this._titleContainer = BX.create("div", { props: { className: "ui-entity-editor-header-title" }, children : [ this._titleView, this._titleInput, this._titleEditButton ] }); this._headerContainer.appendChild(this._titleContainer); this._headerContainer.appendChild(this._titleActions); this._wrapper.appendChild(this._headerContainer); } this._wrapper.appendChild(this._contentContainer); if(!BX.type.isPlainObject(options)) { options = {}; } var anchor = BX.prop.getElementNode(options, "anchor", null); if (anchor) { this._container.insertBefore(this._wrapper, anchor); } else { this._container.appendChild(this._wrapper); } if(isViewMode && this._fields.length === 0) { this._stub = BX.UI.EntityEditorSectionContentStub.create( { owner: this, container: this._contentContainer } ); this._stub.layout(); } var enableReset = BX.prop.getBoolean(options, "reset", false); //Layout fields var userFieldLoader = BX.prop.get(options, "userFieldLoader", null); if(!userFieldLoader) { userFieldLoader = BX.UI.EntityUserFieldLayoutLoader.create( this._id, { mode: this._mode, enableBatchMode: true, owner: this } ); } var enableFocusGain = BX.prop.getBoolean(options, "enableFocusGain", true); var lighting = BX.prop.getObject(options, "lighting", null); var isLighted = false; var isFieldContextMenuEnabled = false; var focusedField = null; for(var i = 0, l = this._fields.length; i < l; i++) { var field = this._fields[i]; field.setContainer(this._contentContainer); field.setDraggableContextId(this._draggableContextId); //Force layout reset because of animation implementation field.releaseLayout(); if(enableReset) { field.reset(); } var layoutOptions = { userFieldLoader: userFieldLoader }; if(!isLighted && lighting && field.isVisible() && field.isNeedToDisplay()) { layoutOptions["lighting"] = lighting; isLighted = true; } field.layout(layoutOptions); if(enableFocusGain && !isViewMode && field.isHeading()) { focusedField = field; } if(!isFieldContextMenuEnabled && field.isContextMenuEnabled()) { isFieldContextMenuEnabled = true; } } if(isFieldContextMenuEnabled) { BX.addClass(this._contentContainer, "ui-entity-editor-section-content-padding-right"); } if(userFieldLoader.getOwner() === this) { userFieldLoader.runBatch(); } this._addChildButton = this._createChildButton = this._deleteButton = null; if(this._editor.canChangeScheme() && this._schemeElement.getDataBooleanParam("showButtonPanel", true)) { this.showButtonPanel(); } if(this.isDragEnabled()) { this._dragContainerController = BX.UI.EditorDragContainerController.create( "section_" + this.getId(), { charge: BX.UI.EditorFieldDragContainer.create( { section: this, context: this._draggableContextId } ), node: this._wrapper } ); this._dragContainerController.addDragFinishListener(this._dropHandler); this.initializeDragDropAbilities(); } //region Add custom Html var serialNumber = null; if(firstColumn) { serialNumber = firstColumn.getChildren().indexOf(this); } var eventArgs = { id: this._id, customNodes: [], visible: true, serialNumber: serialNumber }; BX.onCustomEvent(window, this.eventsNamespace + ":onLayout", [ this, eventArgs ]); if(this._titleActions && BX.type.isArray(eventArgs["customNodes"])) { for(var j = 0, length = eventArgs["customNodes"].length; j < length; j++) { var node = eventArgs["customNodes"][j]; if(BX.type.isElementNode(node)) { this._titleActions.appendChild(node); } } } if("visible" in eventArgs && BX.type.isBoolean(eventArgs["visible"])) { this.setVisible(eventArgs["visible"]); } //endregion this.registerLayout(options); this._hasLayout = true; if (focusedField) { focusedField.focus(focusedField.getDataBooleanParam('selected', false)); } }; BX.UI.EntityEditorSection.prototype.clearLayout = function() { if(!this._hasLayout) { return; } if(this._dragContainerController) { this._dragContainerController.removeDragFinishListener(this._dropHandler); this._dragContainerController.release(); this._dragContainerController = null; } this.releaseDragDropAbilities(); if(this._stub !== null) { this._stub.clearLayout(); this._stub = null; } for(var i = 0, length = this._fields.length; i < length; i++) { var field = this._fields[i]; field.clearLayout(); field.setContainer(null); } this._buttonPanelWrapper = BX.remove(this._buttonPanelWrapper); this._stub = null; this._wrapper = BX.remove(this._wrapper); this._hasLayout = false; }; BX.UI.EntityEditorSection.prototype.refreshLayout = function(options) { options = BX.type.isPlainObject(options) ? BX.mergeEx({}, options) : {}; //region CALLBACK var callback = BX.prop.getFunction(options, "callback", null); delete options["callback"]; //endregion //region ANCHOR delete options["anchor"]; if(this._wrapper && this._wrapper.nextSibling) { options["anchor"] = this._wrapper.nextSibling; } //endregion //region LAYOUT this.clearLayout(); this.layout(options); //endregion if(callback) { callback(); } }; BX.UI.EntityEditorSection.prototype.refreshViewModeLayout = function(options) { if (this.needRefreshViewModeLayout(options)) { for (var i = 0, l = this._fields.length; i < l; i++) { var field = this._fields[i]; field.refreshViewModeLayout(options); } } }; BX.UI.EntityEditorSection.prototype.release = function() { var i, length; if(this._fields) { for(i = 0, length = this._fields.length; i < length; i++) { this._fields[i].release(); } } this._fields = []; }; BX.UI.EntityEditorSection.prototype.onStubClick = function(e) { this.toggle(); }; BX.UI.EntityEditorSection.prototype.adjustButtons = function() { var hasAvailableFields = this._editor.hasAvailableSchemeElements(); var hasTransferableFields = this._editor.hasTransferableElements([ this.getName() ]); if(this._addChildButton) { this._addChildButton.style.display = (hasAvailableFields || hasTransferableFields) ? "" : "none"; } }; BX.UI.EntityEditorSection.prototype.processChildAdditionalMenuCommand = function(child, command) { }; BX.UI.EntityEditorSection.prototype.ensureButtonPanelCreated = function() { if(!this._buttonPanelWrapper) { this._buttonPanelWrapper = BX.create("div", { props: { className: "ui-entity-card-content-actions-container" } }); this._contentContainer.appendChild(this._buttonPanelWrapper); this._buttonPanelBlockLeft = BX.create("div", { props: { className: "ui-entity-card-content-actions-block" } }); this._buttonPanelWrapper.appendChild(this._buttonPanelBlockLeft); this._buttonPanelBlockRight = BX.create("div", { props: { className: "ui-entity-card-content-actions-block" } }); this._buttonPanelWrapper.appendChild(this._buttonPanelBlockRight); } }; BX.UI.EntityEditorSection.prototype.showButtonPanel = function() { this.ensureButtonPanelCreated(); if (this._schemeElement.getDataBooleanParam("isChangeable", true)) { if (this.getConfigurationFieldManager().isSelectionEnabled()) { this._addChildButton = BX.create("span", { props: {className: "ui-entity-editor-content-add-lnk"}, text: BX.message("UI_ENTITY_EDITOR_SELECT_FIELD"), events: {click: BX.delegate(this.onAddChildBtnClick, this)} }); this.addButtonElement(this._addChildButton, {position: "left"}); } if (this.getConfigurationFieldManager().isCreationEnabled()) { this._createChildButton = BX.create("span", { props: {className: "ui-entity-editor-content-create-lnk"}, text: BX.message("UI_ENTITY_EDITOR_CREATE_FIELD"), events: {click: BX.delegate(this.onCreateFieldBtnClick, this)} }); this.addButtonElement(this._createChildButton, {position: "left"}); } } if (this._schemeElement.getDataBooleanParam("isRemovable", true)) { var deleteClassName = "ui-entity-editor-content-remove-lnk"; if (this.isRequired() || this.isRequiredByAttribute() || this.isRequiredConditionally()) { deleteClassName = "ui-entity-editor-content-remove-lnk-disabled"; } this._deleteButton = BX.create("span", { props: {className: deleteClassName}, text: BX.message("UI_ENTITY_EDITOR_DELETE_SECTION") }); this.addButtonElement(this._deleteButton, {position: "right"}); BX.bind(this._deleteButton, "click", this._deleteButtonHandler); } this._contentContainer.appendChild(this._buttonPanelWrapper); this.adjustButtons(); }; BX.UI.EntityEditorSection.prototype.addButtonElement = function(element, options) { this.ensureButtonPanelCreated(); if(BX.prop.getString(options, "position", "") === "left") { this._buttonPanelBlockLeft.appendChild(element); } else { this._buttonPanelBlockRight.appendChild(element); } }; //endregion //region Title Edit BX.UI.EntityEditorSection.prototype.setTitleMode = function(mode) { if(this._titleMode === mode) { return; } this._titleMode = mode; if(!this._schemeElement.isTitleEnabled()) { return; } if(this._titleMode === BX.UI.EntityEditorMode.view) { this._titleView.style.display = ""; this._titleInput.style.display = "none"; this._titleEditButton.style.display = ""; var title = this._titleInput.value; this._titleView.innerHTML = BX.util.htmlspecialchars(title); this._schemeElement.setTitle(title); this.markSchemeAsChanged(); this.saveScheme(); BX.unbind(this._titleInput, "keyup", this._titleInputKeyHandler); BX.unbind(window.document, "click", this._documentClickHandler); } else { this._titleView.style.display = "none"; this._titleInput.style.display = ""; this._titleEditButton.style.display = "none"; this._titleInput.value = this._schemeElement.getTitle(); BX.bind(this._titleInput, "keyup", this._titleInputKeyHandler); this._titleInput.focus(); window.setTimeout( BX.delegate(function() { BX.bind(window.document, "click", this._documentClickHandler); }, this), 100 ); } }; BX.UI.EntityEditorSection.prototype.toggleTitleMode = function() { this.setTitleMode( this._titleMode === BX.UI.EntityEditorMode.view ? BX.UI.EntityEditorMode.edit : BX.UI.EntityEditorMode.view ); }; BX.UI.EntityEditorSection.prototype.onTitleEditButtonClick = function(e) { if(this._editor.isSectionEditEnabled()) { this.toggleTitleMode(); } }; BX.UI.EntityEditorSection.prototype.onTitleInputKeyPress = function(e) { if(!e) { e = window.event; } if(e.keyCode === 13) { this.toggleTitleMode(); } }; BX.UI.EntityEditorSection.prototype.onExternalClick = function(e) { if(!e) { e = window.event; } if(this._titleInput !== BX.getEventTarget(e)) { this.toggleTitleMode(); } }; //endregion //region Toggling & Mode control BX.UI.EntityEditorSection.prototype.enableToggling = function(enable) { enable = !!enable; if(this._enableToggling === enable) { return; } this._enableToggling = enable; if(this._hasLayout) { this._toggleButton.style.display = this._enableToggling ? "" : "none"; } }; BX.UI.EntityEditorSection.prototype.toggle = function() { if(this._enableToggling && this._editor) { this._editor.switchControlMode( this, this._mode === BX.UI.EntityEditorMode.view ? BX.UI.EntityEditorMode.edit : BX.UI.EntityEditorMode.view ); } }; BX.UI.EntityEditorSection.prototype.onToggleBtnClick = function(e) { this.toggle(); }; BX.UI.EntityEditorSection.prototype.onBeforeModeChange = function() { }; BX.UI.EntityEditorSection.prototype.doSetMode = function(mode) { this.removeFieldConfigurator(); if(this._titleMode === BX.UI.EntityEditorMode.edit) { this.toggleTitleMode(); } for(var i = 0, l = this._fields.length; i < l; i++) { this._fields[i].setMode(mode, { notify: false }); } }; //endregion //region Tracking of Changes, Validation, Saving and Rolling back BX.UI.EntityEditorSection.prototype.processAvailableSchemeElementsChange = function() { }; BX.UI.EntityEditorSection.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { return true; } var validator = BX.UI.EntityAsyncValidator.create(); for(var i = 0, length = this._fields.length; i < length; i++) { var field = this._fields[i]; if(field.getMode() !== BX.UI.EntityEditorMode.edit) { continue; } validator.addResult(field.validate(result)); } return validator.validate(); }; BX.UI.EntityEditorSection.prototype.commitSchemeChanges = function() { if(this._isSchemeChanged) { var schemeElements = []; for(var i = 0, length = this._fields.length; i < length; i++) { var schemeElement = this._fields[i].getSchemeElement(); if(schemeElement) { schemeElements.push(schemeElement); } } this._schemeElement.setElements(schemeElements); } return BX.UI.EntityEditorSection.superclass.commitSchemeChanges.call(this); }; BX.UI.EntityEditorSection.prototype.save = function() { for(var i = 0, length = this._fields.length; i < length; i++) { this._fields[i].save(); } }; BX.UI.EntityEditorSection.prototype.rollback = function() { for(var i = 0, l = this._fields.length; i < l; i++) { this._fields[i].rollback(); } if(this._isChanged) { this.initializeFromModel(); this._isChanged = false; } }; BX.UI.EntityEditorSection.prototype.onBeforeSubmit = function() { for(var i = 0, length = this._fields.length; i < length; i++) { this._fields[i].onBeforeSubmit(); } }; //endregion //region Children & User Fields BX.UI.EntityEditorSection.prototype.getChildIndex = function(child) { for(var i = 0, l = this._fields.length; i < l; i++) { if(this._fields[i] === child) { return i; } } return -1; }; BX.UI.EntityEditorSection.prototype.addChild = function(child, options) { if(!BX.type.isPlainObject(options)) { options = {}; } var related = null; var index = BX.prop.getInteger(options, "index", -1); if(index >= 0) { this._fields.splice(index, 0, child); if(index < (this._fields.length - 1)) { related = this._fields[index + 1]; } } else { this._fields.push(child); related = BX.prop.get(options, "related", null); } if(child.getParent() !== this) { child.setParent(this); } if(child.hasScheme()) { child.getSchemeElement().setParent(this._schemeElement); } child.setActive(this._isActive); if(this._hasLayout) { if(this._stub !== null) { this._stub.clearLayout(); this._stub = null; } child.setContainer(this._contentContainer); var layoutOpts = BX.prop.getObject(options, "layout", {}); if(related) { layoutOpts["anchor"] = related.getWrapper(); } else { layoutOpts["anchor"] = this._buttonPanelWrapper; } if(BX.prop.getBoolean(layoutOpts, "forceDisplay", false) && !child.isNeedToDisplay() && !child.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways) ) { //Ensure that field will be displayed. child.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); } child.layout(layoutOpts); if ( !BX.hasClass(this._contentContainer, "ui-entity-editor-section-content-padding-right") && child.isContextMenuEnabled() ) { BX.addClass(this._contentContainer, "ui-entity-editor-section-content-padding-right"); } } var scrollIntoView = BX.prop.getBoolean(options, "scrollIntoView", false); if (scrollIntoView) { child.scrollIntoView(); } if(child.hasScheme()) { this._editor.processControlAdd(child, options); this.markSchemeAsChanged(); if(BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } } }; BX.UI.EntityEditorSection.prototype.removeChild = function(child, options) { if(!BX.type.isPlainObject(options)) { options = {}; } var index = this.getChildIndex(child); if(index < 0) { return; } if(child.isActive()) { child.setActive(false); } this._fields.splice(index, 1); var processScheme = child.hasScheme(); if(processScheme) { child.getSchemeElement().setParent(null); } if(this._hasLayout) { child.clearLayout(); child.setContainer(null); if(this.isInViewMode()) { if(this._fields.length > 0) { if(this._stub !== null) { this._stub.clearLayout(); this._stub = null; } } else { if(this._stub === null) { this._stub = BX.UI.EntityEditorSectionContentStub.create( { owner: this, container: this._contentContainer } ); } this._stub.layout(); } } } if(processScheme) { this._editor.processControlRemove(child, options); this.markSchemeAsChanged(); if(BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } } }; BX.UI.EntityEditorSection.prototype.moveChild = function(child, index, options) { if(!BX.type.isPlainObject(options)) { options = {}; } var qty = this.getChildCount(); var lastIndex = qty - 1; if(index < 0 || index > qty) { index = lastIndex; } var currentIndex = this.getChildIndex(child); if(currentIndex < 0 || currentIndex === index) { return false; } if(this._hasLayout) { child.clearLayout(); } this._fields.splice(currentIndex, 1); qty--; var anchor = null; if(this._hasLayout) { anchor = index < qty ? this._fields[index].getWrapper() : this._buttonPanelWrapper; } if(index < qty) { this._fields.splice(index, 0, child); } else { this._fields.push(child); } if(this._hasLayout) { if(anchor) { child.layout({ anchor: anchor }); } else { child.layout(); } } options["index"] = index; this._editor.processControlMove(child, options); this.markSchemeAsChanged(); if(BX.prop.getBoolean(options, "enableSaving", true)) { this.saveScheme(); } return true; }; BX.UI.EntityEditorSection.prototype.editChild = function(child) { if(this._mode === BX.UI.EntityEditorMode.edit) { child.focus(); } else if(!this.isReadOnly()) { var isHomogeneous = true; for(var i = 0, length = this._fields.length; i < length; i++) { if(this._fields[i].getMode() !== this._mode) { isHomogeneous = false; break; } } if(isHomogeneous) { this.setMode(BX.UI.EntityEditorMode.edit, { notify: true }); this.refreshLayout( { callback: function(){ child.focus(); } } ); } } }; BX.UI.EntityEditorSection.prototype.getChildById = function(childId) { for(var i = 0, length = this._fields.length; i < length; i++) { let field = this._fields[i]; if(field.getId() === childId) { return field; } if ("getActiveControlById" in field && BX.Type.isFunction(field["getActiveControlById"])) { let child = field.getActiveControlById(childId); if (child) { return child; } } } return null; }; BX.UI.EntityEditorSection.prototype.getChildCount = function() { return this._fields.length; }; BX.UI.EntityEditorSection.prototype.getChildren = function() { return this._fields; }; BX.UI.EntityEditorSection.prototype.editChildConfiguration = function(child) { this.removeFieldConfigurator(); this.createFieldConfigurator( { field: child, enableMandatoryControl: this.getConfigurationFieldManager().isMandatoryControlEnabled() } ); }; BX.UI.EntityEditorSection.prototype.processChildControlModeChange = function(child) { if(!this.isActive() && this._editor) { this._editor.processControlModeChange(child); } }; BX.UI.EntityEditorSection.prototype.processChildControlSchemeChange = function(child) { this.markSchemeAsChanged(); this.saveScheme(); }; BX.UI.EntityEditorSection.prototype.processSchemeChange = function() { this.adjustButtons(); }; BX.UI.EntityEditorSection.prototype.onAddChildBtnClick = function(e) { if (this._settings.editor._useForceFieldsAdd && !this.getEditor().isEmbedded()) { this.openTransferDialog(); } else { this.openAddChildMenu(); } }; BX.UI.EntityEditorSection.prototype.openAddChildMenu = function() { var schemeElements = this._editor.getAvailableSchemeElements(); var length = schemeElements.length; var menuItems = []; for(var i = 0; i < length; i++) { var schemeElement = schemeElements[i]; if (schemeElement) { var data = schemeElement.getData(); if (data.doNotDisplayInShowFieldList) { continue; } } menuItems.push({ text: schemeElement.getTitle(), value: schemeElement.getName() }); } if(this._editor.hasTransferableElements([ this.getName() ])) { if(length > 0) { menuItems.push({ delimiter: true }); } menuItems.push({ text: BX.message("UI_ENTITY_EDITOR_SELECT_FIELD_FROM_OTHER_SECTION"), value: "ACTION.TRANSFER" }); } var eventArgs = { id: this._id, menuItems: menuItems, button: this._addChildButton, cancel: false }; BX.onCustomEvent(window, this.eventsNamespace + ":onOpenChildMenu", [ this, eventArgs ]); if(eventArgs["cancel"]) { return; } if(this._childSelectMenu) { this._childSelectMenu.setupItems(menuItems); } else { this._childSelectMenu = BX.UI.SelectorMenu.create(this._id, { items: menuItems }); this._childSelectMenu.addOnSelectListener(BX.delegate(this.onChildSelect, this)); } this._childSelectMenu.open(this._addChildButton); }; BX.UI.EntityEditorSection.prototype.processChildControlChange = function(child, params) { if(!child.isInEditMode()) { return; } if(typeof(params) === "undefined") { params = {}; } if(!BX.prop.get(params, "control", null)) { params["control"] = child; } this.markAsChanged(params); this.enableToggling(false); }; BX.UI.EntityEditorSection.prototype.onChildSelect = function(event) { var item = event.data["item"]; var eventArgs = { id: this._id, item: item, button: this._addChildButton, cancel: false }; BX.onCustomEvent(window, this.eventsNamespace + ":onChildMenuItemSelect", [ this, eventArgs ]); if(eventArgs["cancel"]) { return; } var v = item.getValue(); if(v === "ACTION.TRANSFER") { this.openTransferDialog(); return; } var element = this._editor.getAvailableSchemeElementByName(v); if(!element) { return; } var field = this._editor.createControl( element.getType(), element.getName(), { schemeElement: element, model: this._model, parent: this, mode: this._mode } ); if(field) { //Option "notifyIfNotDisplayed" to enable user notification if field will not be displayed because of settings. //Option "forceDisplay" to enable "showAlways" flag if required . this.addChild(field, { layout: { forceDisplay: true } }); } }; BX.UI.EntityEditorSection.prototype.openTransferDialog = function() { const excludedElementNames = this.getExcludedElementNames(); if (!this._fieldSelector) { this._fieldSelector = BX.UI.EntityEditorFieldSelector.create( this._id, { scheme: this._editor.getScheme(), excludedNames: excludedElementNames, title: BX.message("UI_ENTITY_EDITOR_FIELD_TRANSFER_DIALOG_TITLE"), buttonTitle: this._settings.editor._entityTypeTitle, useFieldsSearch: this._settings.editor._useFieldsSearch, hiddenElements: this._settings.editor._useForceFieldsAdd ? this._editor.getAvailableSchemeElements() : [], } ); this._fieldSelector.addClosingListener(BX.delegate(this.onTransferFieldSelect, this)); } this._fieldSelector.setExcludedNames(excludedElementNames); this._fieldSelector.setCurrentSchemeElementName(this.getSchemeElement().getName()); this._fieldSelector.open(); }; BX.UI.EntityEditorSection.prototype.getExcludedElementNames = function() { const result = {}; result[`${this.getSchemeElement().getName()}`] = this._fields .filter((field) => { if (typeof field.isNeedToDisplay === 'function' && field.isNeedToDisplay()) { return true; } return typeof field.hasValue === 'function' ? field.hasValue() : false ; }) .map((field) => field.getName()) ; return result; } BX.UI.EntityEditorSection.prototype.onTransferFieldSelect = function(event) { if (event.data['isCanceled']) { return; } const items = BX.prop.getArray(event.data, 'items'); if (items.length === 0) { return; } for (let i = 0, length = items.length; i < length; i++) { const item = items[i]; const sectionName = BX.prop.getString(item, 'sectionName', ''); const fieldName = BX.prop.getString(item, 'fieldName', ''); const sourceSection = this._editor.getControlById(sectionName); if (!sourceSection) { continue; } const hiddenSourceField = this._editor.getAvailableSchemeElementByName(fieldName); const sourceField = sourceSection.getChildById(fieldName); if (sourceField) { sourceSection.removeChild(sourceField, { enableSaving: false }); const transferField = this.createTransferField(sourceField.getSchemeElement()); //Option "notifyIfNotDisplayed" to enable user notification if field will not be displayed because of settings. //Option "forceDisplay" to enable "showAlways" flag if required . this.addChild(transferField, { layout: { forceDisplay: true }, enableSaving: false }); } else if (this._settings.editor._useForceFieldsAdd && hiddenSourceField) { hiddenSourceField.setParent(sourceSection); const transferField = this.createTransferField(hiddenSourceField); //Option "notifyIfNotDisplayed" to enable user notification if field will not be displayed because of settings. //Option "forceDisplay" to enable "showAlways" flag if required . sourceSection.addChild(transferField, { layout: { forceDisplay: true } }); } } this._editor.saveSchemeChanges(); }; BX.UI.EntityEditorSection.prototype.createTransferField = function(sourceField) { return this._editor.createControl( sourceField.getType(), sourceField.getName(), { schemeElement: sourceField, model: this._model, parent: this, mode: this._mode } ); }; BX.UI.EntityEditorSection.prototype.createFieldConfigurator = function(params) { if(!BX.type.isPlainObject(params)) { throw "EntityEditorSection: The 'params' argument must be object."; } params.mandatoryConfigurator = null; var child = BX.prop.get(params, "field", null); var attrManager = this._editor.getAttributeManager(); if(attrManager) { params.mandatoryConfigurator = attrManager.createFieldConfigurator( child, BX.UI.EntityFieldAttributeType.required ); } this._fieldConfigurator = this.getConfigurationFieldManager().createFieldConfigurator(params, this); this.addChild(this._fieldConfigurator, { related: child, scrollIntoView: true }); if (BX.Type.isObject(params.mandatoryConfigurator)) { this._mandatoryConfigurator = params.mandatoryConfigurator; } if (this._fieldConfigurator instanceof BX.UI.EntityEditorUserFieldConfigurator) { BX.addCustomEvent(this._fieldConfigurator, "onSave", BX.delegate(this.onUserFieldConfigurationSave, this)); BX.addCustomEvent(this._fieldConfigurator, "onCancel", BX.delegate(this.onFieldConfigurationCancel, this)); } else { BX.addCustomEvent(this._fieldConfigurator, "onSave", BX.delegate(this.onFieldConfigurationSave, this)); BX.addCustomEvent(this._fieldConfigurator, "onCancel", BX.delegate(this.onFieldConfigurationCancel, this)); } }; BX.UI.EntityEditorSection.prototype.removeFieldConfigurator = function() { if(this._fieldConfigurator) { var field = this._fieldConfigurator.getField(); if(field) { field.setVisible(true); } this.removeChild(this._fieldConfigurator); this._fieldConfigurator = null; } }; BX.UI.EntityEditorSection.prototype.onFieldConfigurationSave = function(sender, params) { if(sender !== this._fieldConfigurator) { return; } var field = BX.prop.get(params, "field", null); if(!field) { BX.onCustomEvent(this._editor, this._editor.eventsNamespace + ":onFieldCreate", [ this, params ]); this.removeFieldConfigurator(); return; } var label = BX.prop.getString(params, "label", ""); var showAlways = BX.prop.getBoolean(params, "showAlways", null); if(label === "" && showAlways === null) { this.removeFieldConfigurator(); this._mandatoryConfigurator = null; this._visibilityConfigurator = null; return; } this._fieldConfigurator.setLocked(true); field.getSchemeElement().setTitle(label); if(showAlways !== null && showAlways !== field.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways)) { field.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); } BX.onCustomEvent(this._editor, this._editor.eventsNamespace + ":onFieldModify", [ this, params ]); this.markSchemeAsChanged(); this.saveScheme().then( BX.delegate( function() { if(this._mandatoryConfigurator) { if(this._mandatoryConfigurator.isPermitted() && field.areAttributesEnabled() && !field.isRequired() ) { if(this._mandatoryConfigurator.isEnabled()) { if(this._mandatoryConfigurator.isChanged()) { this._mandatoryConfigurator.acceptChanges(); } var attributeConfig = this._mandatoryConfigurator.getConfiguration(); this._editor.getAttributeManager().saveConfiguration( attributeConfig, field.getName() ); field.setAttributeConfiguration(attributeConfig); } else { var attributeTypeId = this._mandatoryConfigurator.getTypeId(); this._editor.getAttributeManager().removeConfiguration( attributeTypeId, field.getName() ); field.removeAttributeConfiguration(attributeTypeId); } const attrConfigs = BX.Runtime.clone( field.getSchemeElement().getDataParam("attrConfigs", []) ); BX.onCustomEvent( this._editor, this._editor.eventsNamespace + ":onFieldModifyAttributeConfigs", [ this, { field: field, attrConfigs: attrConfigs } ] ); } this._mandatoryConfigurator = null; this._visibilityConfigurator = null; } this.removeFieldConfigurator(); field.setTitle(label); }, this ) ) var typeId = BX.prop.getString(params, "typeId"); if (typeId === "list") { var fieldData = { "typeId": typeId }; fieldData["innerConfig"] = BX.prop.getObject(params, "innerConfig", {}); fieldData["enumeration"] = BX.prop.getArray(params, "enumeration", []); if ( BX.Type.isPlainObject(fieldData["innerConfig"]) && fieldData["innerConfig"].hasOwnProperty("controller") && BX.Type.isStringFilled(fieldData["innerConfig"]["controller"]) ) { BX.ajax.runAction(fieldData["innerConfig"]["controller"], { data: { configData: fieldData } }).then( function(response) { if ( BX.Type.isObject(response) && response.hasOwnProperty("status") && response.status === "success" && response.hasOwnProperty("data") && BX.Type.isArray(response["data"]) ) { var field = BX.prop.get(params, "field", null); if (BX.Type.isObject(field)) { var enumeration = response["data"]; var items = []; for (var i = 0; i < enumeration.length; i++) { items.push({ "NAME": enumeration[i]["VALUE"], "VALUE": enumeration[i]["ID"] }); } field.getSchemeElement().setDataParam("items", items); field.setItems(); field.refreshLayout(); } } else { console.error("Invalid server response."); } }.bind(this), function(response) { if ( BX.Type.isObject(response) && response.hasOwnProperty("status") && response["status"] === "error" && response.hasOwnProperty("errors") && BX.Type.isArray(response["errors"]) && response["errors"].length > 0 && BX.Type.isPlainObject(response["errors"][0]) && response["errors"][0].hasOwnProperty("message") && BX.Type.isString(response["errors"][0]["message"]) ) { console.error(response["errors"][0]["message"]); } else { console.error("Invalid server response."); } }.bind(this) ); } } }; BX.UI.EntityEditorSection.prototype.onFieldConfigurationCancel = function(sender, params) { if(sender !== this._fieldConfigurator) { return; } this.removeFieldConfigurator(); this._mandatoryConfigurator = null; this._visibilityConfigurator = null; }; BX.UI.EntityEditorSection.prototype.enablePointerEvents = function(enable) { if(!this._fields) { return; } enable = !!enable; for(var i = 0, length = this._fields.length; i < length; i++) { this._fields[i].enablePointerEvents(enable); } }; BX.UI.EntityEditorSection.prototype.onCreateFieldBtnClick = function(e) { if(!this._fieldTypeSelectMenu) { var infos = this.getConfigurationFieldManager().getTypeInfos(); var items = []; for(var i = 0, length = infos.length; i < length; i++) { var info = infos[i]; items.push({ value: info.name, text: info.title, legend: info.legend, callback: !!info.callback ? info.callback : null }); } this._fieldTypeSelectMenu = BX.UI.UserFieldTypeMenu.create( this._id, { items: items, callback: BX.delegate(this.onFieldTypeSelect, this) } ); } this._fieldTypeSelectMenu.open(this._createChildButton); }; BX.UI.EntityEditorSection.prototype.getCreationConfigurator = function(typeId) { return this.createFieldConfigurator( { typeId: typeId, enableMandatoryControl: this.getConfigurationFieldManager().isMandatoryControlEnabled() } ); }; BX.UI.EntityEditorSection.prototype.onFieldTypeSelect = function(sender, item) { this._fieldTypeSelectMenu.close(); var typeId = item.getValue(); if(typeId === "") { return; } if(this.getConfigurationFieldManager().hasExternalForm(typeId)) { this.getConfigurationFieldManager().openCreationPageUrl(typeId); } else { this.removeFieldConfigurator(); this.getCreationConfigurator(typeId); } }; BX.UI.EntityEditorSection.prototype.onUserFieldConfigurationSave = function(sender, params) { if(sender !== this._fieldConfigurator) { return; } this._fieldConfigurator.setLocked(true); var typeId = BX.prop.getString(params, "typeId"); if(typeId === BX.UI.EntityUserFieldType.datetime && !BX.prop.getBoolean(params, "enableTime", false)) { typeId = BX.UI.EntityUserFieldType.date; } var fieldData = { "USER_TYPE_ID": typeId }; if(this._mandatoryConfigurator && this._mandatoryConfigurator.isPermitted() && this._mandatoryConfigurator.isEnabled() && this._mandatoryConfigurator.isCustomized() ) { if(this._mandatoryConfigurator.isChanged()) { this._mandatoryConfigurator.acceptChanges(); } fieldData["MANDATORY"] = "N"; } else { fieldData["MANDATORY"] = BX.prop.getBoolean(params, "mandatory", false) ? "Y" : "N"; } var settings = BX.prop.get(params, "settings", null); if (settings) { fieldData["SETTINGS"] = settings; } var showAlways = BX.prop.getBoolean(params, "showAlways", null); var label = BX.prop.getString(params, "label", ""); var field = BX.prop.get(params, "field", null); if(field) { var previousLabel = field.getTitle(); if(label !== "" || showAlways !== null) { field.setTitle(label); if(showAlways !== null && showAlways !== field.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways)) { field.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); } this.markSchemeAsChanged(); this.saveScheme(); } if (!this.getEditor().canChangeCommonConfiguration()) { if(showAlways !== null) { this._editor.setOption("show_always", showAlways ? "Y" : "N"); } BX.delegate(this.onUserFieldUpdate, this); this.removeFieldConfigurator(); return; } fieldData["FIELD"] = field.getName(); fieldData["ENTITY_VALUE_ID"] = field.getEntityValueId(); if(this._editor.getConfigScope() === BX.UI.EntityConfigScope.common && label !== '' && previousLabel !== label) { fieldData["EDIT_FORM_LABEL"] = fieldData["LIST_COLUMN_LABEL"] = fieldData["LIST_FILTER_LABEL"] = label; } fieldData["VALUE"] = field.getFieldValue(); if(typeId === BX.UI.EntityUserFieldType.enumeration) { fieldData["ENUM"] = BX.prop.getArray(params, "enumeration", []); fieldData['SETTINGS']['DISPLAY'] = BX.prop.getString(params, 'display', 'UI'); } if( typeId === BX.UI.EntityUserFieldType.enumeration || typeId === BX.UI.EntityUserFieldType.crmStatus ) { fieldData['SETTINGS']['DISPLAY'] = BX.prop.getString(params, 'display', 'UI'); } field.adjustFieldParams(fieldData, false); var updateField = function() { this._editor.getUserFieldManager().updateField( fieldData, field.getMode() ).then( BX.delegate(this.onUserFieldUpdate, this) ); }.bind(this); if (typeId === BX.UI.EntityUserFieldType.crmStatus) { var displaySettings = {}; displaySettings.DISPLAY= BX.prop.getString(params, 'display', 'UI'); var configData = { "typeId": typeId, "innerConfig": BX.prop.getObject(params, "innerConfig", {}), "enumeration": BX.prop.getArray(params, "enumeration", []), "SETTINGS": displaySettings, }; if ( BX.Type.isPlainObject(configData["innerConfig"]) && configData["innerConfig"].hasOwnProperty("controller") && BX.Type.isStringFilled(configData["innerConfig"]["controller"]) ) { BX.ajax.runAction( configData["innerConfig"]["controller"], { data: { configData: configData } } ).then( function(response) { if ( !( BX.Type.isObject(response) && response.hasOwnProperty("status") && response.status === "success" && response.hasOwnProperty("data") && BX.Type.isArray(response["data"]) ) ) { console.error("Invalid server response."); } updateField(); }.bind(this), function(response) { if ( BX.Type.isObject(response) && response.hasOwnProperty("status") && response["status"] === "error" && response.hasOwnProperty("errors") && BX.Type.isArray(response["errors"]) && response["errors"].length > 0 && BX.Type.isPlainObject(response["errors"][0]) && response["errors"][0].hasOwnProperty("message") && BX.Type.isString(response["errors"][0]["message"]) ) { console.error(response["errors"][0]["message"]); } else { console.error("Invalid server response."); } updateField(); }.bind(this) ); } else { updateField(); } } else { updateField(); } } else { if(showAlways !== null) { this._editor.setOption("show_always", showAlways ? "Y" : "N"); } fieldData["EDIT_FORM_LABEL"] = fieldData["LIST_COLUMN_LABEL"] = fieldData["LIST_FILTER_LABEL"] = BX.prop.getString(params, "label"); fieldData["MULTIPLE"] = BX.prop.getBoolean(params, "multiple", false) ? "Y" : "N"; if(typeId === BX.UI.EntityUserFieldType.enumeration) { fieldData["ENUM"] = BX.prop.getArray(params, "enumeration", []); fieldData['SETTINGS']['DISPLAY'] = BX.prop.getString(params, 'display', 'UI'); } if( typeId === BX.UI.EntityUserFieldType.enumeration || typeId === BX.UI.EntityUserFieldType.crmStatus ) { fieldData['SETTINGS']['DISPLAY'] = BX.prop.getString(params, 'display', 'UI'); } this._editor.getUserFieldManager().createField( fieldData, this._mode ).then(BX.delegate(this.onUserFieldCreate, this)); } }; BX.UI.EntityEditorSection.prototype.onUserFieldCreate = function(result) { if(!BX.type.isPlainObject(result)) { return; } this.removeFieldConfigurator(); var manager = this._editor.getUserFieldManager(); for(var key in result) { if(!result.hasOwnProperty(key)) { continue; } var data = result[key]; var info = BX.prop.getObject(data, "FIELD", null); if(!info) { continue; } var element = manager.createSchemeElement(info); if(!element) { continue; } this._model.registerNewField( element.getName(), { "VALUE": "", "SIGNATURE": BX.prop.getString(info, "SIGNATURE", "") } ); var field = this._editor.createControl( element.getType(), element.getName(), { schemeElement: element, model: this._model, parent: this, mode: this._mode } ); if(this._mandatoryConfigurator && this._mandatoryConfigurator.isPermitted() && this._mandatoryConfigurator.isEnabled() && this._mandatoryConfigurator.isCustomized() ) { var attributeConfig = this._mandatoryConfigurator.getConfiguration(); this._editor.getAttributeManager().saveConfiguration(attributeConfig, element.getName()); field.setAttributeConfiguration(attributeConfig); } if (this._visibilityConfigurator) { var visibilityConfig = { 'accessCodes': this._visibilityConfigurator.formatAccessCodesFromConfig( this._visibilityConfigurator.getItems() ) }; this._visibilityConfigurator.onUserFieldConfigurationSave( element.getName(), this._editor.getEntityTypeId() ); field.setVisibilityConfiguration(visibilityConfig); } var showAlways = this._editor.getOption("show_always", "Y") === "Y"; if(showAlways !== field.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways)) { field.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); } //Option "notifyIfNotDisplayed" to enable user notification if field will not be displayed because of settings. this.addChild(field, { layout: { notifyIfNotDisplayed: true, html: BX.prop.getString(data, "HTML", "") } }); break; } this._mandatoryConfigurator = null; this._visibilityConfigurator = null; }; BX.UI.EntityEditorSection.prototype.onUserFieldUpdate = function(result) { if(!BX.type.isPlainObject(result)) { return; } this.removeFieldConfigurator(); var manager = this._editor.getUserFieldManager(); for(var key in result) { if(!result.hasOwnProperty(key)) { continue; } var data = result[key]; var info = BX.prop.getObject(data, "FIELD", null); if(!info) { continue; } var field = this.getChildById(key); if(!field) { continue; } var element = field.getSchemeElement(); if(!element) { continue; } if(this._mandatoryConfigurator && this._mandatoryConfigurator.isPermitted()) { if(this._mandatoryConfigurator.isEnabled() && this._mandatoryConfigurator.isCustomized()) { var attributeConfig = this._mandatoryConfigurator.getConfiguration(); this._editor.getAttributeManager().saveConfiguration(attributeConfig, element.getName()); field.setAttributeConfiguration(attributeConfig); } else { var attributeTypeId = this._mandatoryConfigurator.getTypeId(); this._editor.getAttributeManager().removeConfiguration(attributeTypeId, element.getName()); field.removeAttributeConfiguration(attributeTypeId); } } if (this._visibilityConfigurator) { var visibilityConfig = { 'accessCodes': this._visibilityConfigurator.formatAccessCodesFromConfig( this._visibilityConfigurator.getItems() ) }; this._visibilityConfigurator.onUserFieldConfigurationSave( element.getName(), this._editor.getEntityTypeId() ); field.setVisibilityConfiguration(visibilityConfig); } manager.updateSchemeElement(element, info); var options = {}; var html = BX.prop.getString(data, "HTML", ""); if(html !== "") { options["html"] = html; } field.refreshLayout(options); break; } this._mandatoryConfigurator = null; this._visibilityConfigurator = null; }; //endregion //region Create|Delete Section BX.UI.EntityEditorSection.prototype.onDeleteConfirm = function(result) { if(BX.prop.getBoolean(result, "cancel", true)) { return; } if (this.getParent()) { this.getParent().removeChild(this); } else { this._editor.removeSchemeElement(this.getSchemeElement()); this._editor.removeControl(this); this._editor.saveScheme(); } }; BX.UI.EntityEditorSection.prototype.onDeleteSectionBtnClick = function(e) { if(this.isRequired() || this.isRequiredByAttribute() || this.isRequiredConditionally()) { this.showMessageDialog( "operationDenied", BX.message("UI_ENTITY_EDITOR_DELETE_SECTION"), BX.message("UI_ENTITY_EDITOR_DELETE_SECTION_DENIED") ); return; } var dlg = BX.UI.ConfirmationDialog.get(this._detetionConfirmDlgId); if(!dlg) { dlg = BX.UI.ConfirmationDialog.create( this._detetionConfirmDlgId, { title: BX.message("UI_ENTITY_EDITOR_DELETE_SECTION"), content: BX.message("UI_ENTITY_EDITOR_DELETE_SECTION_CONFIRM") } ); } dlg.open().then(BX.delegate(this.onDeleteConfirm, this)); }; //endregion //region D&D BX.UI.EntityEditorSection.prototype.createDragButton = function() { if(!this._dragButton) { this._dragButton = BX.create( "div", { props: { className: "ui-entity-editor-header-draggable-btn-container" }, children: [ BX.create( "div", { props: { className: "ui-entity-editor-draggable-btn" } } ) ] } ); } return this._dragButton; }; BX.UI.EntityEditorSection.prototype.createGhostNode = function() { if(!this._wrapper) { return null; } var pos = BX.pos(this._wrapper); var node = BX.create("div", { props: { className: "ui-entity-section-grabbing" }, children : [ BX.create("div", { props: { className: "ui-entity-editor-section-header" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-header-draggable-btn-container" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-draggable-btn" } }) ] }), BX.create("div", { props: { className: "ui-entity-editor-header-title" }, children : [ BX.create("span", { props: { className: "ui-entity-editor-header-title-text" }, text: this._schemeElement.getTitle() }) ] }) ] }) ] }); BX.addClass(node, "ui-entity-card-card-drag"); node.style.width = pos.width + "px"; return node; }; BX.UI.EntityEditorSection.prototype.getDragObjectType = function() { return BX.UI.EditorDragObjectType.section; }; BX.UI.EntityEditorSection.prototype.getChildDragObjectType = function() { return BX.UI.EditorDragObjectType.field; }; BX.UI.EntityEditorSection.prototype.hasPlaceHolder = function() { return !!this._dragPlaceHolder; }; BX.UI.EntityEditorSection.prototype.createPlaceHolder = function(index) { this.enablePointerEvents(false); if(this._stub !== null) { this._stub.clearLayout(); this._stub = null; } var qty = this.getChildCount(); if(index < 0 || index > qty) { index = qty > 0 ? qty : 0; } if(this._dragPlaceHolder) { if(this._dragPlaceHolder.getIndex() === index) { return this._dragPlaceHolder; } this._dragPlaceHolder.clearLayout(); this._dragPlaceHolder = null; } this._dragPlaceHolder = BX.UI.EditorDragFieldPlaceholder.create( { container: this._contentContainer, anchor: (index < qty) ? this._fields[index].getWrapper() : this._buttonPanelWrapper, index: index } ); this._dragPlaceHolder.layout(); return this._dragPlaceHolder; }; BX.UI.EntityEditorSection.prototype.getPlaceHolder = function() { return this._dragPlaceHolder; }; BX.UI.EntityEditorSection.prototype.removePlaceHolder = function() { this.enablePointerEvents(true); if(this.isInViewMode() && this.getChildCount() === 0 && this._stub == null) { this._stub = BX.UI.EntityEditorSectionContentStub.create( { owner: this, container: this._contentContainer } ); this._stub.layout(); } if(this._dragPlaceHolder) { this._dragPlaceHolder.clearLayout(); this._dragPlaceHolder = null; } }; BX.UI.EntityEditorSection.prototype.processDraggedItemDrop = function(dropContainer, draggedItem) { var containerCharge = dropContainer.getCharge(); if(!((containerCharge instanceof BX.UI.EditorFieldDragContainer) && containerCharge.getSection() === this)) { return; } var context = draggedItem.getContextData(); var contextId = BX.type.isNotEmptyString(context["contextId"]) ? context["contextId"] : ""; if(contextId !== this.getDraggableContextId()) { return; } var placeholder = this.getPlaceHolder(); var placeholderIndex = placeholder ? placeholder.getIndex() : -1; if(placeholderIndex < 0) { return; } var itemCharge = typeof(context["charge"]) !== "undefined" ? context["charge"] : null; if(!(itemCharge instanceof BX.UI.EditorFieldDragItem)) { return; } var source = itemCharge.getControl(); if(!source) { return; } var sourceParent = source.getParent(); if(sourceParent === this) { var currentIndex = this.getChildIndex(source); if(currentIndex < 0) { return; } var index = placeholderIndex <= currentIndex ? placeholderIndex : (placeholderIndex - 1); if(index === currentIndex) { return; } this.moveChild(source, index, { enableSaving: false }); this._editor.saveSchemeChanges(); } else { var schemeElement = source.getSchemeElement(); sourceParent.removeChild(source, { enableSaving: false }); var target = this._editor.createControl( schemeElement.getType(), schemeElement.getName(), { schemeElement: schemeElement, model: this._model, parent: this, mode: this._mode } ); if(this._mode === BX.UI.EntityEditorMode.view && !target.hasContentToDisplay() && !target.checkOptionFlag(BX.UI.EntityEditorControlOptions.showAlways) ) { //Activate 'showAlways' flag for display empty field in view mode. target.toggleOptionFlag(BX.UI.EntityEditorControlOptions.showAlways); } this.addChild(target, { index: placeholderIndex, enableSaving: false }); this._editor.saveSchemeChanges(); } }; BX.UI.EntityEditorSection.prototype.onDrop = function(event) { this.processDraggedItemDrop(event.data["dropContainer"], event.data["draggedItem"]); }; BX.UI.EntityEditorSection.prototype.initializeDragDropAbilities = function() { if(this._dragItem) { return; } this._dragItem = BX.UI.EditorDragItemController.create( "section_" + this.getId(), { charge: BX.UI.EditorSectionDragItem.create({ control: this }), node: this.createDragButton(), showControlInDragMode: false, ghostOffset: { x: 0, y: 0 } } ); }; BX.UI.EntityEditorSection.prototype.releaseDragDropAbilities = function() { if(this._dragItem) { this._dragItem.release(); this._dragItem = null; } }; //endregion //region Context Menu BX.UI.EntityEditorSection.prototype.hasAdditionalMenu = function() { return false; }; BX.UI.EntityEditorSection.prototype.getAdditionalMenu = function() { return []; }; //endregion BX.UI.EntityEditorSection.prototype.isWaitingForInput = function() { for(var i = 0, l = this._fields.length; i < l; i++) { if(this._fields[i].isWaitingForInput()) { return true; } } return false; }; BX.UI.EntityEditorSection.prototype.isRequired = function() { for(var i = 0, l = this._fields.length; i < l; i++) { if(this._fields[i].isRequired()) { return true; } } return false; }; BX.UI.EntityEditorSection.prototype.isRequiredConditionally = function() { for(var i = 0, l = this._fields.length; i < l; i++) { if(this._fields[i].isRequiredConditionally()) { return true; } } return false; }; BX.UI.EntityEditorSection.prototype.isRequiredByAttribute = function() { for(var i = 0, l = this._fields.length; i < l; i++) { if(this._fields[i].isRequiredByAttribute()) { return true; } } return false; }; BX.UI.EntityEditorSection.prototype.ensureButtonPanelWrapperCreated = function() { if(!this._hasLayout) { throw "EntityEditorSection: Control does not have layout."; } if(!this._buttonPanelWrapper) { this._buttonPanelWrapper = BX.create("div", { props: { className: "ui-entity-card-content-actions-container" } }); this._contentContainer.appendChild(this._buttonPanelWrapper); } return this._buttonPanelWrapper; }; BX.UI.EntityEditorSection.prototype.createTitleHint = function() { var hint = this._schemeElement ? this._schemeElement.getHint() : null; if(hint) { return BX.create("span", { dataset: { hint, hintHtml: true, hintInteractivity: true, } }); } return null; }; BX.UI.EntityEditorSection.create = function(id, settings) { var self = new BX.UI.EntityEditorSection(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorIncludedArea === "undefined") { BX.UI.EntityEditorIncludedArea = function() { this._settings = null; this._owner = null; this._container = null; this._wrapper = null; this._loadedHtml = null; this._hasLayout = false; }; BX.extend(BX.UI.EntityEditorIncludedArea, BX.UI.EntityEditorSection); BX.UI.EntityEditorIncludedArea.prototype.layout = function() { if (this._hasLayout) { return; } if (!this._wrapper) { this._wrapper = BX.create("div", { props: { className: "ui-entity-editor-included-area" }, attrs: { 'data-name': this.getName() } }); } this._includedAreaContainer = BX.create("div", { attrs: {className: "ui-entity-editor-included-area-container"}, children: [ BX.create("div", { attrs: { className: "ui-entity-editor-included-area-container-loader" } }) ] }); this._contentContainer = BX.create("div", { attrs: {className: "ui-entity-editor-included-area-content-block"}, children: [this._includedAreaContainer] }); this._wrapper.appendChild(this._contentContainer); this._container.appendChild(this._wrapper); this.loadArea(); if (this._editor.canChangeScheme() && this._schemeElement.getDataBooleanParam("showButtonPanel", true)) { this.showButtonPanel(); } this._hasLayout = true; }; BX.UI.EntityEditorIncludedArea.prototype.clearLayout = function() { this._buttonPanelWrapper = BX.remove(this._buttonPanelWrapper); this._wrapper = BX.remove(this._wrapper); this._hasLayout = false; }; BX.UI.EntityEditorIncludedArea.prototype.loadArea = function() { if (this._includedAreaContainer && this._loadedHtml) { BX.html(this._includedAreaContainer, this._loadedHtml); return; } var action = this._schemeElement.getDataStringParam("action"); if (!BX.type.isNotEmptyString(action)) { return; } var config = this.prepareConfigForAction(); BX.onCustomEvent(window, "BX.UI.EntityEditorIncludedArea:onBeforeLoad", [this, config]); if (this._schemeElement.getDataStringParam("type", "") === "component") { var componentName = this._schemeElement.getDataStringParam("componentName", ""); if (!BX.type.isNotEmptyString(componentName)) { return; } config.mode = this._schemeElement.getDataStringParam("mode", "ajax"); BX.ajax.runComponentAction(componentName, action, config) .then(this.onLoadAreaSuccess.bind(this)); } else { BX.ajax.runAction(action, config) .then(this.onLoadAreaSuccess.bind(this)); } }; BX.UI.EntityEditorIncludedArea.prototype.prepareConfigForAction = function() { var config = {}; var dataName = this._schemeElement.getDataStringParam("dataName", ""); if (BX.type.isNotEmptyString(dataName)) { var data = this._model.getField(dataName, {}); if (BX.type.isPlainObject(data)) { config.data = data; } } var signedParametersName = this._schemeElement.getDataStringParam("signedParametersName", ""); if (BX.type.isNotEmptyString(signedParametersName)) { var signedParameters = this._model.getField(signedParametersName, ""); if (BX.type.isNotEmptyString(signedParameters)) { config.signedParameters = signedParameters; } } return config; }; BX.UI.EntityEditorIncludedArea.prototype.onLoadAreaSuccess = function(result) { this._loadedHtml = BX.prop.getString(BX.prop.getObject(result, "data", {}), "html", null); BX.html(this._includedAreaContainer, this._loadedHtml); BX.onCustomEvent(window, "BX.UI.EntityEditorIncludedArea:onAfterLoad", [this]); }; BX.UI.EntityEditorIncludedArea.create = function(id, settings) { var self = new BX.UI.EntityEditorIncludedArea(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorText === "undefined") { BX.UI.EntityEditorText = function() { BX.UI.EntityEditorText.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorText, BX.UI.EntityEditorField); BX.UI.EntityEditorText.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorText.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorText.prototype.focus = function(isSelectedFocus) { if(!this._input) { return; } BX.focus(this._input); if (Boolean(isSelectedFocus)) { this._input.select(); } else { BX.UI.EditorTextHelper.getCurrent().setPositionAtEnd(this._input); } }; BX.UI.EntityEditorText.prototype.getLineCount = function() { return this._schemeElement.getDataIntegerParam("lineCount", 1); }; BX.UI.EntityEditorText.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-text" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var title = this.getTitle(); var value = this.getValue(); this._input = null; this._inputContainer = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: this.getEditModeHtmlNodes() }); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); if(this.hasContentToDisplay()) { if(this.getLineCount() > 1) { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-text" }, html: BX.util.nl2br(BX.util.htmlspecialchars(value)) }) ] }); } else { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-text" }, text: value }) ] }); } } else { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, text: BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY") }); } } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorText.prototype.getEditModeHtmlNodes = function() { var value = this.getValue(); var lineCount = this.getLineCount(); this._inputContainer = BX.create("div", { attrs: { className: "ui-ctl ui-ctl-textbox ui-ctl-w100" } } ); if(lineCount > 1) { this._input = BX.create("textarea", { props: { className: "ui-entity-editor-field-textarea", rows: lineCount, value: value } } ); } else { this._input = BX.create("input", { attrs: { className: "ui-ctl-element", type: "text", value: value, id: this._id.toLowerCase() + "_text" } } ); } if (!this.isVirtual()) { this._input.name = this.getName(); } this._inputContainer.appendChild(this._input); if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } BX.bind(this._input, "input", this._changeHandler); return [ this._input ]; }; BX.UI.EntityEditorText.prototype.doClearLayout = function(options) { this._input = null; //BX.unbind(this._innerWrapper, "click", this._viewClickHandler); this._innerWrapper = null; }; BX.UI.EntityEditorText.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorText.superclass.refreshLayout.apply(this, arguments); return; } if(this._mode === BX.UI.EntityEditorMode.edit && this._input) { this._input.value = this.getValue(); } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = BX.util.htmlspecialchars(this.getValue()); } }; BX.UI.EntityEditorText.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? BX.util.trim(this._input.value) : "" ); }; BX.UI.EntityEditorText.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorText. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorText.prototype.showError = function(error, anchor) { BX.UI.EntityEditorText.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorText.prototype.clearError = function() { BX.UI.EntityEditorText.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorText.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.value, { originator: this }); } }; BX.UI.EntityEditorText.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorText.prototype.getFocusInputID = function() { return this._id.toLowerCase() + "_text"; }; BX.UI.EntityEditorText.create = function(id, settings) { var self = new BX.UI.EntityEditorText(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorMultiText === "undefined") { BX.UI.EntityEditorMultiText = function() { BX.UI.EntityEditorMultiText.superclass.constructor.apply(this); this._items = null; this._input = null; this._select = null; this._inputValue = []; this._addInputHandler = BX.delegate(this.addInputField, this); this._innerWrapper = null; this._isOpened = false; }; BX.extend(BX.UI.EntityEditorMultiText, BX.UI.EntityEditorField); BX.UI.EntityEditorMultiText.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorMultiText.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorMultiText.prototype.hasContentToDisplay = function() { var values = this.getValue(); if (!BX.type.isArray(values) || values.length === 0) { return false; } var filteredItems = values.filter(function(value){ return BX.type.isNotEmptyString('' + value) }); return (filteredItems.length > 0); }; BX.UI.EntityEditorMultiText.prototype.getLineCount = function() { return this._schemeElement.getDataIntegerParam("lineCount", 1); }; BX.UI.EntityEditorMultiText.prototype.createSingleInput = function(value) { var inputContainer = BX.create("div", { attrs: { className: "ui-ctl ui-ctl-textbox ui-ctl-w100" } } ); if (this.getLineCount() > 1) { inputContainer.appendChild( BX.create("textarea", { props: { className: "ui-ctl-element ui-entity-editor-field-textarea", name: this.getName() + '[]', rows: this.getLineCount(), value: value || '' }, events: { input: this._changeHandler } }) ); } else { inputContainer.appendChild( BX.create("input", { attrs: { name: this.getName() + '[]', className: "ui-ctl-element", type: "text", value: value || '' }, events: { input: this._changeHandler } }) ); } return inputContainer; }; BX.UI.EntityEditorMultiText.prototype.getCloneButton = function() { return BX.create('input', { attrs: { type: "button", value: BX.message("UI_ENTITY_EDITOR_ADD"), }, events: { click: this._addInputHandler } }); }; BX.UI.EntityEditorMultiText.prototype.addInputField = function (e) { if (BX.type.isDomNode(this._inputContainer)) { var newInput = this.createSingleInput(); this._inputContainer.appendChild(newInput); newInput.querySelector('.ui-ctl-element').focus(); } }; BX.UI.EntityEditorMultiText.prototype.onChange = function (e) { this._inputValue = []; for (var i = 0; i < this._inputContainer.children.length; i++) { var innerInput = this._inputContainer.children[i].querySelector('input'); if (BX.type.isDomNode(innerInput) && innerInput.value !== '') { this._inputValue.push(innerInput.value); } } this.markAsChanged(); }; BX.UI.EntityEditorMultiText.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-multitext" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var title = this.getTitle(); var values = this.getValue(); this._inputValue = values; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._inputContainer = BX.create("div"); if (values.length > 0) { for (var i = 0, l = values.length; i < l; i++) { this._inputContainer.appendChild(this.createSingleInput(values[i])); } } else { var newInput = this.createSingleInput(); this._inputContainer.appendChild(newInput); if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } } this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputContainer, this.getCloneButton() ] }); } else { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this.getViewInnerLayout() ] } ); } this._wrapper.appendChild(this._innerWrapper); if (newInput) { var firstInput = newInput.querySelector('.ui-ctl-element'); if (firstInput) { firstInput.focus(); } } if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorMultiText.prototype.getViewInnerLayout = function() { var textValue = BX.create("div", { props: { className: "ui-entity-editor-content-block-text" } }); if(!this.hasContentToDisplay()) { textValue.innerHTML = BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY"); } else { var values = this.getValue(); for (var i=0; i<values.length; i++) { textValue.appendChild(this.getSingleViewItem(values[i])); } } return textValue; }; BX.UI.EntityEditorMultiText.prototype.getSingleViewItem = function(value) { return BX.create('p', {text: value}); }; BX.UI.EntityEditorMultiText.prototype.doClearLayout = function(options) { this._select = null; this._innerWrapper = null; }; BX.UI.EntityEditorMultiText.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorMultiText.superclass.refreshLayout.apply(this, arguments); return; } var values = this.getValue(); if(this._mode === BX.UI.EntityEditorMode.edit && this._inputContainer) { for (var i = 0, l = values.length; i < l; i++) { this._inputContainer.appendChild(this.createSingleInput(values[i])); } } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = ''; this._innerWrapper.appendChild(this.getViewInnerLayout()); } }; BX.UI.EntityEditorMultiText.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { throw "BX.UI.EntityEditorMultiText. Invalid validation context"; } if(!this.isEditable()) { return true; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isEmptyValue = true; if(this._inputContainer) { var inputs = this._inputContainer.querySelectorAll('input'); for (var i=0; i<inputs.length; i++) { if (BX.util.trim(inputs[i].value) !== '') { isEmptyValue = false } } } var isValid = !this.isRequired() || !isEmptyValue; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorMultiText.prototype.showError = function(error, anchor) { BX.UI.EntityEditorMultiText.superclass.showError.apply(this, arguments); if(this._inputContainer) { for (var i=0; this._inputContainer.children.length<i; i++) { BX.addClass(this._inputContainer.children[i], "ui-ctl-danger"); } } }; BX.UI.EntityEditorMultiText.prototype.clearError = function() { BX.UI.EntityEditorMultiText.superclass.clearError.apply(this); for (var i=0; this._inputContainer.children.length<i; i++) { BX.removeClass(this._inputContainer.children[i], "ui-ctl-danger"); } }; BX.UI.EntityEditorMultiText.prototype.save = function() { if(!this.isEditable()) { return; } this._model.setField(this.getName(), this._inputValue); }; BX.UI.EntityEditorMultiText.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorMultiText.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? this._inputValue : "" ); }; BX.UI.EntityEditorMultiText.prototype.getValue = function() { var value = BX.UI.EntityEditorBoolean.superclass.getValue.apply(this); if (!BX.type.isArray(value) && value !== '') { return [value]; } return value; }; BX.UI.EntityEditorMultiText.create = function(id, settings) { var self = new BX.UI.EntityEditorMultiText(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorMultiMoney === "undefined") { BX.UI.EntityEditorMultiMoney = function() { BX.UI.EntityEditorMultiMoney.superclass.constructor.apply(this); this._currencyEditor = []; this._amountInput = []; this._currencyInput = []; this._sumElement = []; this._select = []; this._selectContainer = []; this._selectIcon = []; this._inputValue = []; this._selectedCurrencyValue = []; this._addInputHandler = BX.delegate(this.addInputField, this); this._inputWrapper = null; this._innerWrapper = null; this._isCurrencyMenuOpened = false; BX.UI.EntityEditorMoney.superclass.constructor.apply(this); this.wrapperClassName = "ui-entity-editor-field-money"; }; BX.extend(BX.UI.EntityEditorMultiMoney, BX.UI.EntityEditorMultiText); BX.UI.EntityEditorMultiMoney.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorMultiMoney.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorMultiMoney.prototype.hasContentToDisplay = function() { var values = this.getValue(); if (!BX.type.isArray(values) || values.length === 0) { return false; } var filteredItems = values.filter(function(value){ return BX.type.isNotEmptyString('' + value) }); return (filteredItems.length > 0); }; BX.UI.EntityEditorMultiMoney.prototype.getLineCount = function() { return this._schemeElement.getDataIntegerParam("lineCount", 1); }; BX.UI.EntityEditorMultiMoney.prototype.createSingleInput = function(index) { var data = this.getData(); var amountInputName = BX.prop.getString(data, "amount"); var currencyInputName = BX.prop.getString(BX.prop.getObject(data, "currency"), "name"); var currencyValues = this._model.getField( BX.prop.getString(BX.prop.getObject(data, "currency"), "name", ""), [] ); if(!BX.type.isNotEmptyString(currencyValues[index])) { currencyValues[index] = BX.Currency.Editor.getBaseCurrencyId(); } var currencyName = this._editor.findOption( currencyValues[index], BX.prop.getArray(BX.prop.getObject(data, "currency"), "items") ); var amountFieldName = this.getAmountFieldName(); var currencyFieldName = this.getCurrencyFieldName(); var amountValues = this._model.getField(amountFieldName, ""); //SET CURRENT SUM VALUE var formattedValues = this._model.getField(BX.prop.getString(data, "formatted"), ""); //SET FORMATTED VALUE this._selectedCurrencyValue.push(currencyValues[index]); this._amountValue.push(BX.create("input", { attrs: { name: amountInputName + '[]', type: "hidden", value: amountValues[index] } } )); this._amountInput.push(BX.create("input", { attrs: { className: "ui-ctl-inline ui-ctl-element ui-ctl-w75", type: "text", value: formattedValues[index] } } )); BX.bind(this._amountInput[index], "input", this._changeHandler); if(this._model.isFieldLocked(amountFieldName)) { this._amountInput[index].disabled = true; } this._currencyInput.push(BX.create("input", { attrs: { name: currencyInputName + '[]', type: "hidden", value: currencyValues[index] } } )); var containerProps = { props: { className: "ui-ctl-element" }, text: currencyName, }; this._select.push(BX.create("div", containerProps)); this._selectIcon.push(BX.create("div", { attrs: { className: "ui-ctl-after ui-ctl-icon-angle" } } )); this._selectContainer.push(BX.create("div", { props: {className: "ui-ctl ui-ctl-inline ui-ctl-after-icon ui-ctl-dropdown ui-ctl-w33"}, children :[ this._select[index], this._selectIcon[index] ] } )); if(this._model.isFieldLocked(currencyFieldName)) { this._selectContainer[index].disabled = true; } else { BX.bind( this._selectContainer[index], "click", BX.delegate(function(e){this.onSelectorClick(e, index)}, this) ); } var inputWrapper = BX.create("div", { props: { className: "ui-ctl-inline ui-ctl-w100" }, children: [ this._amountValue[index], this._currencyInput[index], this._amountInput[index], this._selectContainer[index], ] } ); var inputContainer = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ inputWrapper ] } ); this._currencyEditor[index] = new BX.Currency.Editor( { input: this._amountInput[index], currency: currencyValues[index], callback: BX.delegate(function(value){ this.onAmountValueChange(value, index) }, this) } ); this._currencyEditor[index].changeValue(); return inputContainer; }; BX.UI.EntityEditorMultiMoney.prototype.getCloneButton = function() { return BX.create('input', { attrs: { type: "button", value: BX.message("UI_ENTITY_EDITOR_ADD"), }, events: { click: this._addInputHandler } }); }; BX.UI.EntityEditorMultiMoney.prototype.addInputField = function (e) { if (BX.type.isDomNode(this._inputContainer)) { var newInput = this.createSingleInput(this._amountInput.length); this._inputContainer.appendChild(newInput); newInput.querySelector('.ui-ctl-element').focus(); } }; BX.UI.EntityEditorMultiMoney.prototype.getAmountFieldName = function() { return this._schemeElement.getDataStringParam("amount", ""); }; BX.UI.EntityEditorMultiMoney.prototype.getCurrencyFieldName = function() { return BX.prop.getString( this._schemeElement.getDataObjectParam("currency", {}), "name", "" ); }; BX.UI.EntityEditorMultiMoney.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-multitext" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var title = this.getTitle(); var values = this.getValue(); this._amountValue = []; this._amountInput = []; this._currencyInput = []; this._selectContainer = []; this._innerWrapper = null; this._sumElement = []; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._inputContainer = BX.create("div"); if (values.length > 0) { for (var i = 0, l = values.length; i < l; i++) { this._inputContainer.appendChild(this.createSingleInput(i)); } } else { var newInput = this.createSingleInput(0); this._inputContainer.appendChild(newInput); if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } } this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputContainer, this.getCloneButton() ] }); } else { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this.getViewInnerLayout() ] } ); } this._wrapper.appendChild(this._innerWrapper); if (newInput) { var firstInput = newInput.querySelector('.ui-ctl-element'); if (firstInput) { firstInput.focus(); } } if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorMultiMoney.prototype.onSelectorClick = function (e, index) { this.openCurrencyMenu(index); }; BX.UI.EntityEditorMultiMoney.prototype.openCurrencyMenu = function(index) { if(this._isCurrencyMenuOpened) { return; } var data = this._schemeElement.getData(); var currencyList = BX.prop.getArray(BX.prop.getObject(data, "currency"), "items"); //{NAME, VALUE} var key = 0; var menu = []; while (key < currencyList.length) { menu.push( { text: BX.util.htmlspecialchars(currencyList[key]["NAME"]), value: BX.util.htmlspecialchars(currencyList[key]["VALUE"]), onclick: BX.delegate( this.onCurrencySelect, this) } ); key++ } BX.PopupMenu.show( this._id, this._selectContainer[index], menu, { angle: false, width: this._selectContainer[index].offsetWidth + 'px', index: index, events: { onPopupShow: BX.delegate( this.onCurrencyMenuOpen, this), onPopupClose: BX.delegate( this.onCurrencyMenuClose, this) } } ); }; BX.UI.EntityEditorMultiMoney.prototype.closeCurrencyMenu = function() { if(!this._isCurrencyMenuOpened) { return; } var menu = BX.PopupMenu.getMenuById(this._id); if(menu) { menu.popupWindow.close(); } }; BX.UI.EntityEditorMultiMoney.prototype.onCurrencyMenuOpen = function() { BX.addClass(this._selectContainer, "active"); this._isCurrencyMenuOpened = true; }; BX.UI.EntityEditorMultiMoney.prototype.onCurrencyMenuClose = function() { BX.PopupMenu.destroy(this._id); BX.removeClass(this._selectContainer, "active"); this._isCurrencyMenuOpened = false; }; BX.UI.EntityEditorMultiMoney.prototype.onCurrencySelect = function(e, item) { this.closeCurrencyMenu(); if ( !( item && item['menuWindow'] && item['menuWindow']['params'] && BX.type.isInteger(item['menuWindow']['params']['index']) ) ) { return; } var index = item['menuWindow']['params']['index']; this._selectedCurrencyValue[index] = this._currencyInput[index].value = item.value; this._select[index].innerHTML = BX.util.htmlspecialchars(item.text); if(this._currencyEditor[index]) { this._currencyEditor[index].setCurrency(this._selectedCurrencyValue[index]); } this.markAsChanged( { fieldName: this.getCurrencyFieldName(), fieldValue: this._selectedCurrencyValue[index] } ); }; BX.UI.EntityEditorMultiMoney.prototype.onAmountValueChange = function(value, index) { if(!this._amountValue[index]) { return; } var currencyFormat = BX.prop.getObject( BX.Currency.Editor.currencyList, this._selectedCurrencyValue[index], null ); if (currencyFormat) { value = BX.Currency.Editor.getFormattedValue( value, this._selectedCurrencyValue[index] ); value = value.replaceAll(currencyFormat['SEPARATOR'], ''); } this._amountValue[index].value = value; }; BX.UI.EntityEditorMultiMoney.prototype.getViewInnerLayout = function() { var textValue = BX.create("div", { props: { className: "ui-entity-editor-content-block-text" } }); if(!this.hasContentToDisplay()) { textValue.innerHTML = BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY"); } else { var values = this.getValue(); for (var i=0; i<values.length; i++) { textValue.appendChild(this.getSingleViewItem(i)); } } return textValue; }; BX.UI.EntityEditorMultiMoney.prototype.getSingleViewItem = function(index) { return BX.create( 'p', { html: this.renderMoney(index), props: {className: 'ui-entity-editor-content-block-wallet'}, } ); }; BX.UI.EntityEditorMultiMoney.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._amountInput && this._amountValue)) { throw "BX.UI.EntityEditorMultiMoney. Invalid validation context"; } if(!this.isEditable()) { return true; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isEmptyValue = true; if(this._inputContainer) { var inputs = this._inputContainer.querySelectorAll('input'); for (var i=0; i<inputs.length; i++) { if (BX.util.trim(inputs[i].value) !== '') { isEmptyValue = false } } } var isValid = !this.isRequired() || !isEmptyValue; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorMultiMoney.prototype.renderMoney = function(index) { var data = this._schemeElement.getData(); var currencyValues = this._model.getField( BX.prop.getString(BX.prop.getObject(data, "currency"), "name", ""), [] ); if(!BX.type.isNotEmptyString(currencyValues[index])) { currencyValues[index] = BX.Currency.Editor.getBaseCurrencyId(); } this._selectedCurrencyValue.push(currencyValues[index]); var formattedWithCurrencyArray = this._model.getField(BX.prop.getString(data, "formattedWithCurrency"), []); var formattedArray = this._model.getField(BX.prop.getString(data, "formatted"), []); var formattedWithCurrencyCurrent = formattedWithCurrencyArray[index]; var formattedCurrent = formattedArray[index]; var result = BX.Currency.Editor.trimTrailingZeros(formattedCurrent, this._selectedCurrencyValue[index]); return formattedWithCurrencyCurrent.replace( formattedCurrent, result ); }; BX.UI.EntityEditorMultiMoney.prototype.doClearLayout = function(options) { BX.PopupMenu.destroy(this._id); for (var index = 0; index < this._currencyEditor.length; index++) { this._currencyEditor[index].clean(); } this._currencyEditor = []; this._select = []; this._selectIcon = []; this._amountValue = []; this._amountInput = []; this._currencyInput = []; this._sumElement = []; this._selectContainer = []; this._inputWrapper = null; this._innerWrapper = null; }; BX.UI.EntityEditorMultiMoney.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorMultiMoney.superclass.refreshLayout.apply(this, arguments); return; } var values = this.getValue(); if(this._mode === BX.UI.EntityEditorMode.edit && this._inputContainer) { for (var i = 0, l = values.length; i < l; i++) { this._inputContainer.appendChild(this.createSingleInput(i)); } } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = ''; this._innerWrapper.appendChild(this.getViewInnerLayout()); } }; BX.UI.EntityEditorMultiMoney.prototype.save = function() { if(!this.isEditable()) { return; } var data = this._schemeElement.getData(); this._model.setField( BX.prop.getString(BX.prop.getObject(data, "currency"), "name"), this._selectedCurrencyValue, { originator: this } ); if(this._amountValue) { var amountValues = []; for (var index = 0; index < this._amountValue.length; index++) { amountValues.push(this._amountValue[index]); } this._model.setField( BX.prop.getString(data, "amount"), amountValues, { originator: this } ); this._model.setField( BX.prop.getString(data, "formatted"), [], { originator: this } ); } }; BX.UI.EntityEditorMultiMoney.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getAmountFieldName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorMultiMoney.prototype.getRuntimeValue = function() { var data = []; if (this._mode === BX.UI.EntityEditorMode.edit) { if(this._amountValue) { var amountValues = []; for (var index = 0; index < this._amountValue.length; index++) { amountValues.push(this._amountValue[index].value); } data[ BX.prop.getString(data, "amount")] = amountValues; } data[ BX.prop.getString(data, "currency")] = this._selectedCurrencyValue; return data; } return ""; }; BX.UI.EntityEditorMultiMoney.create = function(id, settings) { var self = new BX.UI.EntityEditorMultiMoney(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorMultiDatetime === "undefined") { BX.UI.EntityEditorMultiDatetime = function() { BX.UI.EntityEditorMultiDatetime.superclass.constructor.apply(this); this._input = null; this._inputClickHandler = BX.delegate(this.onInputClick, this); this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorMultiDatetime, BX.UI.EntityEditorMultiText); BX.UI.EntityEditorMultiDatetime.prototype.isTimeEnabled = function() { return BX.prop.get(this._schemeElement.getData(), "enableTime", true); }; BX.UI.EntityEditorMultiDatetime.prototype.onInputClick = function(e) { this.showCalendar(e.target); }; BX.UI.EntityEditorMultiDatetime.prototype.showCalendar = function(element) { if (BX.type.isDomNode(element)) { BX.calendar({ node: element, field: element, bTime: this.isTimeEnabled(), bSetFocus: false }); } }; BX.UI.EntityEditorMultiDatetime.prototype.getDateFormat = function() { var timeFormat = 'j F Y'; if (this.isTimeEnabled()) { timeFormat = 'j F Y H:i'; } return BX.prop.getString(this._schemeElement.getData(), "dateViewFormat", timeFormat); }; BX.UI.EntityEditorMultiDatetime.prototype.getSingleViewItem = function(value) { return BX.create('p', { text: BX.date.format(this.getDateFormat(), BX.parseDate(value)) }); }; BX.UI.EntityEditorMultiDatetime.prototype.createSingleInput = function(value) { return BX.create("div", { attrs: { className: "ui-ctl ui-ctl-after-icon ui-ctl-datetime field-wrap" }, children: [ BX.create("div", { attrs: { className: "ui-ctl-after ui-ctl-icon-calendar" } } ), BX.create("input", { attrs: { name: this.getName() + '[]', className: "ui-ctl-element", type: "text", value: value || '' }, events: { input: this._changeHandler, change: this._changeHandler, click: this._inputClickHandler, } }) ] } ); }; BX.UI.EntityEditorMultiDatetime.create = function(id, settings) { var self = new BX.UI.EntityEditorMultiDatetime(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorMultiNumber === "undefined") { BX.UI.EntityEditorMultiNumber = function() { BX.UI.EntityEditorMultiNumber.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorMultiNumber, BX.UI.EntityEditorMultiText); BX.UI.EntityEditorMultiNumber.prototype.createSingleInput = function(value) { return BX.create("div", { attrs: { className: "ui-ctl ui-ctl-number field-wrap" }, children: [ BX.create("input", { attrs: { name: this.getName() + '[]', className: "ui-ctl-element", type: "number", value: value || '' }, events: { input: this._changeHandler } }) ] } ); }; BX.UI.EntityEditorMultiNumber.create = function(id, settings) { var self = new BX.UI.EntityEditorMultiNumber(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorTextarea === "undefined") { BX.UI.EntityEditorTextarea = function() { BX.UI.EntityEditorText.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorTextarea, BX.UI.EntityEditorField); BX.UI.EntityEditorTextarea.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorTextarea.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorTextarea.prototype.focus = function() { if(!this._input) { return; } BX.focus(this._input); BX.UI.EditorTextHelper.getCurrent().setPositionAtEnd(this._input); }; BX.UI.EntityEditorTextarea.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-text" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); this._input = null; this._inputContainer = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._inputContainer = BX.create("div", { attrs: { className: "ui-ctl ui-ctl-textarea ui-ctl-no-resize ui-ctl-w100" } }); this._input = BX.create("textarea", { attrs: { name: name, className: "ui-ctl-element", id: this._id.toLowerCase() + "_text" }, children: value }); this._inputContainer.appendChild(this._input); if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } BX.bind(this._input, "input", this._changeHandler); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputContainer ] }); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); if(this.hasContentToDisplay()) { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-text" }, html: BX.util.nl2br(BX.util.htmlspecialchars(value)) }) ] }); } else { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, text: BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY") }); } } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorTextarea.prototype.doClearLayout = function(options) { this._input = null; //BX.unbind(this._innerWrapper, "click", this._viewClickHandler); this._innerWrapper = null; }; BX.UI.EntityEditorTextarea.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorTextarea.superclass.refreshLayout.apply(this, arguments); return; } if(this._mode === BX.UI.EntityEditorMode.edit && this._input) { this._input.value = this.getValue(); } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = BX.util.htmlspecialchars(this.getValue()); } }; BX.UI.EntityEditorTextarea.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? BX.util.trim(this._input.value) : "" ); }; BX.UI.EntityEditorTextarea.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorTextarea. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorTextarea.prototype.showError = function(error, anchor) { BX.UI.EntityEditorTextarea.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorTextarea.prototype.clearError = function() { BX.UI.EntityEditorTextarea.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorTextarea.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.value, { originator: this }); } }; BX.UI.EntityEditorTextarea.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorTextarea.prototype.getFocusInputID = function() { return this._id.toLowerCase() + "_text"; }; BX.UI.EntityEditorTextarea.create = function(id, settings) { var self = new BX.UI.EntityEditorTextarea(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorNumber === "undefined") { BX.UI.EntityEditorNumber = function() { BX.UI.EntityEditorNumber.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorNumber, BX.UI.EntityEditorField); BX.UI.EntityEditorNumber.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorNumber.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorNumber.prototype.focus = function() { if(!this._input) { return; } BX.focus(this._input); BX.UI.EditorTextHelper.getCurrent().selectAll(this._input); }; BX.UI.EntityEditorNumber.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-content-block-field-number" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } this._input = null; if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._inputContainer = BX.create("div", { attrs: { className: "ui-ctl ui-ctl-textbox" } } ); this._input = BX.create("input", { attrs: { name: name, className: "ui-ctl-element", type: "number", value: value, id: this._id.toLowerCase() + "_text" } } ); this._inputContainer.appendChild(this._input); if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } BX.bind(this._input, "input", this._changeHandler); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputContainer ] }); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); if(!this.hasContentToDisplay()) { value = BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY"); } this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-number" }, text: value }) ] }); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorNumber.prototype.doClearLayout = function(options) { this._input = null; this._innerWrapper = null; }; BX.UI.EntityEditorNumber.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? BX.util.trim(this._input.value) : "" ); }; BX.UI.EntityEditorNumber.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorNumber. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorNumber.prototype.showError = function(error, anchor) { BX.UI.EntityEditorNumber.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._input, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorNumber.prototype.clearError = function() { BX.UI.EntityEditorNumber.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._input, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorNumber.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.value); } }; BX.UI.EntityEditorNumber.create = function(id, settings) { var self = new BX.UI.EntityEditorNumber(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorDatetime === "undefined") { BX.UI.EntityEditorDatetime = function() { BX.UI.EntityEditorDatetime.superclass.constructor.apply(this); this._input = null; this._inputClickHandler = BX.delegate(this.onInputClick, this); this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorDatetime, BX.UI.EntityEditorField); BX.UI.EntityEditorDatetime.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorDatetime.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorDatetime.prototype.focus = function() { if(this._input) { BX.focus(this._input); BX.UI.EditorTextHelper.getCurrent().selectAll(this._input); } }; BX.UI.EntityEditorDatetime.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-date" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); this._input = null; this._inputIcon = null; this._innerContainer = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._input = BX.create("input", { attrs: { name: name, className: "ui-ctl-element", type: "text", value: value } } ); BX.bind(this._input, "click", this._inputClickHandler); BX.bind(this._input, "change", this._changeHandler); BX.bind(this._input, "input", this._changeHandler); this._inputIcon = BX.create("div", { attrs: { className: "ui-ctl-after ui-ctl-icon-calendar" } } ); this._wrapper.appendChild(this.createTitleNode(title)); this._innerContainer = BX.create("div", { props: { className: "ui-ctl ui-ctl-after-icon ui-ctl-datetime ui-ctl-w50" }, children: [ this._inputIcon, this._input ] } ); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._innerContainer ] } ); } else// if(this._mode === BX.UI.EntityEditorMode.view) { value = BX.date.format(this.getDateFormat(), BX.parseDate(value)); this._wrapper.appendChild(this.createTitleNode(title)); if(!this.hasContentToDisplay()) { value = BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY"); } this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: {className: "ui-entity-editor-content-block-text"}, text: value.replaceAll('\\', '') } ) ] } ); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorDatetime.prototype.doRegisterLayout = function() { }; BX.UI.EntityEditorDatetime.prototype.doClearLayout = function(options) { this._input = null; this._innerWrapper = null; }; BX.UI.EntityEditorDatetime.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? BX.util.trim(this._input.value) : "" ); }; BX.UI.EntityEditorDatetime.prototype.isTimeEnabled = function() { return BX.prop.get(this._schemeElement.getData(), "enableTime", true); }; BX.UI.EntityEditorDatetime.prototype.onInputClick = function(e) { this.showCalendar(); }; BX.UI.EntityEditorDatetime.prototype.showCalendar = function() { BX.calendar({ node: this._input, field: this._input, bTime: this.isTimeEnabled(), bSetFocus: false }); }; BX.UI.EntityEditorDatetime.prototype.getDateFormat = function() { var timeFormat = 'j F Y'; if (this.isTimeEnabled()) { timeFormat = 'j F Y H:i'; } return BX.prop.getString(this._schemeElement.getData(), "dateViewFormat", timeFormat); }; BX.UI.EntityEditorDatetime.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorDatetime. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorDatetime.prototype.showError = function(error, anchor) { BX.UI.EntityEditorDatetime.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorDatetime.prototype.clearError = function() { BX.UI.EntityEditorDatetime.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorDatetime.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.value); } }; BX.UI.EntityEditorDatetime.create = function(id, settings) { var self = new BX.UI.EntityEditorDatetime(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorBoolean === "undefined") { BX.UI.EntityEditorBoolean = function() { BX.UI.EntityEditorBoolean.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; }; BX.extend(BX.UI.EntityEditorBoolean, BX.UI.EntityEditorField); BX.UI.EntityEditorBoolean.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorBoolean.prototype.doInitialize = function() { BX.UI.EntityEditorBoolean.superclass.doInitialize.apply(this); this._selectedValue = this._model.getField(this._schemeElement.getName()); }; BX.UI.EntityEditorBoolean.prototype.areAttributesEnabled = function() { return false; }; BX.UI.EntityEditorBoolean.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorBoolean.prototype.hasValue = function() { return BX.util.trim(this.getValue()) !== ""; }; BX.UI.EntityEditorBoolean.prototype.getValue = function(defaultValue) { if(!this._model) { return ""; } if(defaultValue === undefined) { defaultValue = "N"; } var value = this._model.getStringField( this.getName(), defaultValue ); if(value !== this.getCheckedValue() && value !== "N") { value = "N"; } return value; }; BX.UI.EntityEditorBoolean.prototype.getRuntimeValue = function() { if (this._mode !== BX.UI.EntityEditorMode.edit || !this._input) return ""; var value = BX.util.trim(this._input.value); if(value !== "Y" && value !== "N") { value = "N"; } return value; }; BX.UI.EntityEditorBoolean.prototype.getCheckedValue = function() { return this._schemeElement.getDataParam('value', 'Y'); }; BX.UI.EntityEditorBoolean.prototype.isChecked = function() { return (this.getValue() === this.getCheckedValue()); }; BX.UI.EntityEditorBoolean.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-checkbox" ] }); this.adjustWrapper(); var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); this._input = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild( BX.create("input", { attrs: { name: name, type: "hidden", value: "N" } }) ); this._input = BX.create("input", { attrs: { className: "ui-ctl-element", name: name, type: "checkbox", value: this.getCheckedValue(), checked: this.isChecked(), } } ); BX.bind(this._input, "change", this._changeHandler); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("label", { props: {className: "ui-ctl ui-ctl-xs ui-ctl-w100 ui-ctl-checkbox"}, children: [ this._input, BX.create("div", { attrs: { className: "ui-ctl-label-text" }, text: title } ) ] } ) ] } ); } else//if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-text"}, text: BX.message(this.isChecked() ? "UI_ENTITY_EDITOR_YES" : "UI_ENTITY_EDITOR_NO") } ) ] } ); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorBoolean.prototype.doClearLayout = function(options) { this._input = null; this._innerWrapper = null; //this._select = null; }; BX.UI.EntityEditorBoolean.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorBoolean. Invalid validation context"; } if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); BX.addClass(this._inputContainer, "ui-ctl-danger"); this.showRequiredFieldError(this._input); } else { BX.removeClass(this._input, "ui-ctl-danger"); this.clearError(); } return isValid; }; BX.UI.EntityEditorBoolean.prototype.showError = function(error, anchor) { BX.UI.EntityEditorBoolean.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._inputContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorBoolean.prototype.clearError = function() { BX.UI.EntityEditorBoolean.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._input, "ui-ctl-danger"); } }; BX.UI.EntityEditorBoolean.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.checked ? "Y" : "N", { originator: this }); } }; BX.UI.EntityEditorBoolean.create = function(id, settings) { var self = new BX.UI.EntityEditorBoolean(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorList === "undefined") { BX.UI.EntityEditorList = function() { BX.UI.EntityEditorList.superclass.constructor.apply(this); this._items = null; this._input = null; this._select = null; this._selectContainer = null; this._selectedValue = ""; this._selectorClickHandler = BX.delegate(this.onSelectorClick, this); this._innerWrapper = null; this._isOpened = false; }; BX.extend(BX.UI.EntityEditorList, BX.UI.EntityEditorField); BX.UI.EntityEditorList.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorList.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorList.prototype.checkIfNotEmpty = function(value) { //0 is value for "Not Selected" item return value !== "" && value !== "0"; }; BX.UI.EntityEditorList.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-select" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); var item = this.getItemByValue(value); var isHtmlOption = this.getDataBooleanParam('isHtml', false); var containerProps = {}; if(!item) { item = this.getFirstItem(); if(item) { value = item["VALUE"]; } } this._selectedValue = value; this._select = null; this._selectIcon = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._input = BX.create("input", { attrs: { name: name, type: "hidden", value: value } }); this._wrapper.appendChild(this._input); containerProps = { props: { className: "ui-ctl-element" }}; if (isHtmlOption) { containerProps.html = (item ? item["NAME"] : value); } else { containerProps.text = (item ? item["NAME"] : value); } this._select = BX.create("div", containerProps); BX.bind(this._select, "click", this._selectorClickHandler); this._selectIcon = BX.create("div", { attrs: { className: "ui-ctl-after ui-ctl-icon-angle" } } ); this._selectContainer = BX.create("div", { props: {className: "ui-ctl ui-ctl-after-icon ui-ctl-dropdown ui-ctl-w100"}, children :[ this._select, this._selectIcon ] } ); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._selectContainer ] } ); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); var text = ""; if(!this.hasContentToDisplay()) { text = BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY"); } else if(item) { text = item["NAME"]; } else { text = value; } containerProps = {props: { className: "ui-entity-editor-content-block-text" }}; if (isHtmlOption) { containerProps.html = text; } else { containerProps.text = text; } this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", containerProps) ] } ); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorList.prototype.doRegisterLayout = function() { }; BX.UI.EntityEditorList.prototype.doClearLayout = function(options) { this.closeMenu(); this._input = null; this._select = null; this._innerWrapper = null; }; BX.UI.EntityEditorList.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorList.superclass.refreshLayout.apply(this, arguments); return; } var value = this.getValue(); var item = this.getItemByValue(value); var text = item ? BX.prop.getString(item, "NAME", value) : value; if(this._mode === BX.UI.EntityEditorMode.edit) { this._selectedValue = value; if(this._input) { this._input.value = value; } if(this._select) { this._select.innerHTML = this.getDataBooleanParam('isHtml', false) ? text : BX.util.htmlspecialchars(text); } } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = this.getDataBooleanParam('isHtml', false) ? text : BX.util.htmlspecialchars(text); } }; BX.UI.EntityEditorList.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { throw "BX.UI.EntityEditorList. Invalid validation context"; } if(!this.isEditable()) { return true; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || (this._input && BX.util.trim(this._input.value) !== ""); if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorList.prototype.showError = function(error, anchor) { BX.UI.EntityEditorList.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._selectContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorList.prototype.clearError = function() { BX.UI.EntityEditorList.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._selectContainer, "ui-ctl-danger"); } }; BX.UI.EntityEditorList.prototype.onSelectorClick = function (e) { if(!this._isOpened) { this.openMenu(); } else { this.closeMenu(); } }; BX.UI.EntityEditorList.prototype.openMenu = function() { if(this._isOpened) { return; } var menu = []; var items = this.getItems(); for(var i = 0, length = items.length; i < length; i++) { var item = items[i]; if(!BX.prop.getBoolean(item, "IS_EDITABLE", true)) { continue; } var value = BX.prop.getString(item, "VALUE", i); var name = BX.prop.getString(item, "NAME", value); var itemParams = { value: value, onclick: BX.delegate( this.onItemSelect, this) }; if (this.getDataBooleanParam('isHtml', false)) { itemParams['html'] = name; } else { itemParams['text'] = name; } menu.push(itemParams); } const selectBottomY = BX.Dom.getPosition(this._select).y; const distanceToTop = selectBottomY - window.pageYOffset; const distanceToBottom = document.documentElement.clientHeight + window.pageYOffset - selectBottomY; const popupMaxHeight = distanceToTop > distanceToBottom ? distanceToTop - 50 : distanceToBottom - 100; BX.PopupMenu.show( this._id, this._select, menu, { angle: false, width: this._select.offsetWidth + 'px', maxHeight: popupMaxHeight, events: { onPopupShow: BX.delegate( this.onMenuShow, this), onPopupClose: BX.delegate( this.onMenuClose, this) } } ); BX.PopupMenu.currentItem.popupWindow.setWidth(BX.pos(this._select)["width"]); }; BX.UI.EntityEditorList.prototype.closeMenu = function() { var menu = BX.PopupMenu.getMenuById(this._id); if(menu) { menu.popupWindow.close(); } }; BX.UI.EntityEditorList.prototype.onMenuShow = function() { BX.addClass(this._selectContainer, "ui-ctl-active"); this._isOpened = true; }; BX.UI.EntityEditorList.prototype.onMenuClose = function() { BX.PopupMenu.destroy(this._id); BX.removeClass(this._selectContainer, "ui-ctl-active"); this._isOpened = false; }; BX.UI.EntityEditorList.prototype.onItemSelect = function(e, item) { this.closeMenu(); var eventArgs = { field: this, item: item, cancel: false }; BX.onCustomEvent(window, "BX.UI.EntityEditorList:onItemSelect", [ this, eventArgs ]); if(eventArgs["cancel"]) { return; } this._selectedValue = this._input.value = item.value; var name = BX.prop.getString( this.getItemByValue(this._selectedValue), "NAME", this._selectedValue ); this._select.innerHTML = this.getDataBooleanParam('isHtml', false) ? name : BX.util.htmlspecialchars(name); this.markAsChanged(); BX.PopupMenu.destroy(this._id); }; BX.UI.EntityEditorList.prototype.setItems = function(items) { if (!BX.type.isArray(items)) { items = BX.prop.getArray(this._schemeElement.getData(), "items", []); } if (!this.isRequired() && BX.prop.get(this._schemeElement.getData(), "enableEmptyItem", false)) { var empties = items.filter(function(item){ return (item.VALUE === '') }); if (empties.length === 0) { items.unshift({ VALUE: '', NAME: BX.message("UI_ENTITY_EDITOR_NOT_SELECTED") }); } } this._items = items; }; BX.UI.EntityEditorList.prototype.getItems = function() { if(!this._items) { this.setItems(); } return this._items; }; BX.UI.EntityEditorList.prototype.getItemByValue = function(value) { value = value || ''; value = value.toString(); var items = this.getItems(); for(var i = 0, l = items.length; i < l; i++) { var item = items[i]; if(value === BX.prop.getString(item, "VALUE", "")) { return item; } } return null; }; BX.UI.EntityEditorList.prototype.getFirstItem = function() { var items = this.getItems(); return items.length > 0 ? items[0] : null; }; BX.UI.EntityEditorList.prototype.save = function() { if(!this.isEditable()) { return; } this._model.setField(this.getName(), this._selectedValue); }; BX.UI.EntityEditorList.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorList.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? this._selectedValue : "" ); }; BX.UI.EntityEditorList.create = function(id, settings) { var self = new BX.UI.EntityEditorList(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorMultiList === "undefined") { BX.UI.EntityEditorMultiList = function() { BX.UI.EntityEditorMultiList.superclass.constructor.apply(this); this._items = null; this._selector = null; this._selectedValues = []; this._hiddenNode = ""; this._selectorClickHandler = BX.delegate(this.onSelectorClick, this); this._innerWrapper = null; this._isOpened = false; }; BX.extend(BX.UI.EntityEditorMultiList, BX.UI.EntityEditorField); BX.UI.EntityEditorMultiList.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorMultiList.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorMultiList.prototype.hasContentToDisplay = function() { var values = this.getValue(); this.getItems(); if (!BX.type.isArray(values) || values.length === 0) { return false; } var filteredItems = this._items.filter(function(item){ return BX.util.in_array(item.VALUE, values) }); return (filteredItems.length > 0); }; BX.UI.EntityEditorMultiList.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-multiselect" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getId(); var title = this.getTitle(); var value = this.getValue(); this._selectedValues = this.getSelectedValues(value); if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); var params = { 'isMulti': true, 'fieldName': name }; if (!this._selector) { this._selector = BX.decl({ block: 'main-ui-multi-select', name: name, items: this._items, value: this._selectedValues, params: params, valueDelete: true }); } var selector = BX.create( "div", { props: { className: "fields enumeration field-item" }, children: [this._selector] } ); BX.addCustomEvent( window, 'UI::Select::change', BX.delegate(this.onChange, this) ); BX.bind(selector, 'click', BX.defer( function(){ this.onChange({ params: params, node: selector.firstChild }); }, this)); this._innerWrapper = BX.create( "div", { props: { className: "ui-entity-editor-content-block" } } ); this._innerWrapper.appendChild(selector); this.layoutHidden(); this._innerWrapper.appendChild(this._hiddenNode); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create( "div", { props: { className: "ui-entity-editor-content-block" } } ); if(!this.hasContentToDisplay()) { this._innerWrapper.appendChild(BX.create("div", { text: this.getMessage("isEmpty") } )); } else { var selectedNames = []; for (var i=0; i<this._selectedValues.length ;i++) { var item = this.getItemByValue(this._selectedValues[i].VALUE); var selectedName; if (BX.type.isNotEmptyString(item['HTML'])) { selectedName = item['HTML']; } else if (BX.type.isNotEmptyString(item['NAME'])) { selectedName = BX.util.htmlspecialchars(item['NAME']); } else { selectedName = BX.util.htmlspecialchars(item['VALUE']); } selectedNames.push(selectedName); } if (selectedNames.length > 0) { this._innerWrapper.appendChild(BX.create("div", { props: {className: "ui-entity-editor-content-block"}, html: selectedNames.join(', ') } )); } } } this._wrapper.appendChild(this._innerWrapper); // if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorMultiList.prototype.doClearLayout = function(options) { this._selector = null; this._innerWrapper = null; }; BX.UI.EntityEditorMultiList.prototype.layoutHidden = function() { if (!BX.type.isDomNode(this._hiddenNode)) { this._hiddenNode = BX.create("div"); } else { this._hiddenNode.innerHTML = ''; } var selectedLength = this._selectedValues.length; if (selectedLength > 0) { for (var i=0;i<selectedLength;i++) { this._hiddenNode.appendChild( BX.create('input',{ attrs:{ type: 'hidden', name: this.getName() + "[]", value: this._selectedValues[i].VALUE } }) ) } } else { this._hiddenNode.appendChild( BX.create('input',{ attrs:{ type: 'hidden', name: this.getName() + "[]" } }) ) } }; BX.UI.EntityEditorMultiList.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { throw "BX.UI.EntityEditorMultiList. Invalid validation context"; } if(!this.isEditable()) { return true; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !this.isRequired() || this._selectedValues.length > 0; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._selector); } return isValid; }; BX.UI.EntityEditorMultiList.prototype.showError = function(error, anchor) { BX.UI.EntityEditorMultiList.superclass.showError.apply(this, arguments); if(this._selector) { BX.addClass(this._selector, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorMultiList.prototype.clearError = function() { BX.UI.EntityEditorMultiList.superclass.clearError.apply(this); if(this._selector) { BX.removeClass(this._selector, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorMultiList.prototype.onChange = function(e) { if (e.params.fieldName === this.getName() && this._selector) { this._selectedValues = JSON.parse(this._selector.getAttribute('data-value')); this.layoutHidden(); this.markAsChanged(); } }; BX.UI.EntityEditorMultiList.prototype.getItems = function() { if(!this._items) { this._items = BX.prop.getArray(this._schemeElement.getData(), "items", []); } return this._items; }; BX.UI.EntityEditorMultiList.prototype.getItemByValue = function(value) { var items = this.getItems(); for(var i = 0, l = items.length; i < l; i++) { var item = items[i]; if(value === BX.prop.getString(item, "VALUE", "")) { return item; } } return null; }; BX.UI.EntityEditorMultiList.prototype.getSelectedValues = function(values) { var result = []; var items = this.getItems(); if (!BX.type.isArray(values)) { return []; } for(var j = 0; j < values.length; j++) { value = '' + values[j]; for(var i = 0, l = items.length; i < l; i++) { var item = items[i]; if(value === BX.prop.getString(item, "VALUE", "")) { result.push(item); } } } return result; }; BX.UI.EntityEditorMultiList.prototype.getFirstItem = function() { var items = this.getItems(); return items.length > 0 ? items[0] : null; }; BX.UI.EntityEditorMultiList.prototype.save = function() { if(!this.isEditable()) { return; } this._model.setField(this.getName(), this.getRuntimeValue()); }; BX.UI.EntityEditorMultiList.prototype.getRuntimeValue = function() { var value = []; if (this._mode === BX.UI.EntityEditorMode.edit && this._selector) { for (var i=0;i<this._selectedValues.length;i++) { value.push(this._selectedValues[i].VALUE); } } return value; }; BX.UI.EntityEditorMultiList.prototype.setItems = function(items) { if (!BX.type.isArray(items)) { items = BX.prop.getArray(this._schemeElement.getData(), "items", []); } this._items = items; }; BX.UI.EntityEditorMultiList.create = function(id, settings) { var self = new BX.UI.EntityEditorMultiList(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorHtml === "undefined") { BX.UI.EntityEditorHtml = function() { BX.UI.EntityEditorHtml.superclass.constructor.apply(this); this._htmlEditorContainer = null; this._htmlEditor = null; this._isEditorInitialized = false; this._focusOnLoad = false; this._input = null; this._innerWrapper = null; this._editorInitializationHandler = BX.delegate(this.onEditorInitialized, this); this._viewClickHandler = BX.delegate(this.onViewClick, this); }; BX.extend(BX.UI.EntityEditorHtml, BX.UI.EntityEditorField); BX.UI.EntityEditorHtml.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorHtml.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorHtml.prototype.checkIfNotEmpty = function(value) { return BX.UI.EntityEditorHtml.isNotEmptyValue(value); }; BX.UI.EntityEditorHtml.prototype.focus = function() { if(this._htmlEditor && this._isEditorInitialized) { this._htmlEditor.Focus(true); } else { this._focusOnLoad = true; } }; BX.UI.EntityEditorHtml.prototype.layout = function(options) { if(this._hasLayout) { return; } this.release(); this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-content-block-field-html" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); this._input = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { if(!this._editor) { throw "BX.UI.EntityEditorHtml: Editor instance is required for create layout."; } var htmlEditorConfig = this._editor.getHtmlEditorConfig(name); if(!htmlEditorConfig) { throw "BX.UI.EntityEditorHtml: Could not find HTML editor config."; } this._htmlEditorContainer = BX(BX.prop.getString(htmlEditorConfig, "containerId")); if(!BX.type.isElementNode(this._htmlEditorContainer)) { throw "BX.UI.EntityEditorHtml: Could not find HTML editor container."; } this._htmlEditor = BXHtmlEditor.Get(BX.prop.getString(htmlEditorConfig, "id")); if(!this._htmlEditor) { throw "BX.UI.EntityEditorHtml: Could not find HTML editor instance."; } this._wrapper.appendChild(this.createTitleNode(title)); this._input = BX.create("input", { attrs: { name: name, type: "hidden", value: value } }); this._wrapper.appendChild(this._input); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: {className: "ui-entity-editor-content-block-field-container"}, children: [this._htmlEditorContainer] } ) ] } ); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" } } ); if(this.hasContentToDisplay()) { var entityEditorContentBlockInner = BX.create("div", { props: { className: "ui-entity-editor-content-block-inner-html" }, html: value } ); this._innerWrapper.appendChild( BX.create("div", { props: { className: "ui-entity-editor-content-block-field-container" }, children: [ entityEditorContentBlockInner, ] } ) ); var contentLength = entityEditorContentBlockInner && entityEditorContentBlockInner.innerText && entityEditorContentBlockInner.innerText.length ; if (contentLength > 200) { BX.addClass(this._wrapper, "ui-entity-editor-content-block-field-html-collapsed"); this._innerWrapper.appendChild( BX.create("DIV", { attrs: { className: "ui-entity-editor-content-block-field-html-expand-btn-container" }, children: [ BX.create("A", { attrs: { className: "ui-entity-editor-content-block-field-html-expand-btn", href: "#" }, events: { click: BX.delegate(this.onExpandButtonClick, this) }, text: BX.message("UI_ENTITY_EDITOR_EXPAND_HTML") } ) ] } ) ); this._isCollapsed = true; } } else { this._innerWrapper.appendChild( document.createTextNode(BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY")) ); } this._wrapper.appendChild(this._innerWrapper); BX.bindDelegate( this._wrapper, "mousedown", BX.delegate(this.filterViewNode, this), this._viewClickHandler ); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); if(this._mode === BX.UI.EntityEditorMode.edit) { this._isEditorInitialized = !!this._htmlEditor.inited; if(this._isEditorInitialized) { this.prepareEditor(); } else { BX.addCustomEvent( this._htmlEditor, "OnCreateIframeAfter", this._editorInitializationHandler ); setTimeout(function() { this._htmlEditor.Init(); }.bind(this), 0); } window.top.setTimeout(BX.delegate(this.bindChangeEvent, this), 1000); this.initializeDragDropAbilities(); } else { const innerHtmlElements = this._innerWrapper.querySelectorAll('.ui-entity-editor-content-block-inner-html'); const fieldIcon = new BX.UI.EntityFieldIcon({ editor: this._editor, mode: this.getMode(), fieldId: this.getId(), fieldType: 'string', isFieldMultiple: false, fieldInnerWrapper: this._innerWrapper, target: innerHtmlElements[0], }); fieldIcon.renderFieldValueIcon(); } this._hasLayout = true; }; BX.UI.EntityEditorHtml.prototype.doClearLayout = function(options) { this.release(); this._input = null; this._innerWrapper = null; }; BX.UI.EntityEditorHtml.prototype.onExpandButtonClick = function(e) { if (!this._wrapper) { return BX.PreventDefault(e); } if (this._hasFiles && BX.type.isDomNode(this._commentWrapper) && !this._textLoaded) { this._textLoaded = true; this.loadContent(this._commentWrapper, "GET_TEXT") } var eventWrapper = this._wrapper.querySelector(".ui-entity-editor-content-block-inner-html"); if (this._isCollapsed) { BX.defer( function() { eventWrapper.style.height = eventWrapper.scrollHeight + 20 + "px"; eventWrapper.style.maxHeight = eventWrapper.scrollHeight + 130 + "px"; } )(); setTimeout( BX.delegate(function() { BX.removeClass(this._wrapper, "ui-entity-editor-content-block-field-html-collapsed"); BX.addClass(this._wrapper, "ui-entity-editor-content-block-field-html-expand"); eventWrapper.style.maxHeight = ""; }, this), 200 ); } else { BX.defer( function() { eventWrapper.style.maxHeight = eventWrapper.clientHeight + "px"; } )(); BX.defer( function() { BX.removeClass(this._wrapper, "ui-entity-editor-content-block-field-html-expand"); BX.addClass(this._wrapper, "ui-entity-editor-content-block-field-html-collapsed"); }, this )(); setTimeout( function() { eventWrapper.style.maxHeight = ""; }, 200 ); } this._isCollapsed = !this._isCollapsed; var button = this._wrapper.querySelector("a.ui-entity-editor-content-block-field-html-expand-btn"); if (button) { button.innerHTML = BX.message(this._isCollapsed ? "UI_ENTITY_EDITOR_EXPAND_HTML" : "UI_ENTITY_EDITOR_COLLAPSE_HTML"); } return BX.PreventDefault(e); }; BX.UI.EntityEditorHtml.prototype.filterViewNode = function(obj) { return true; }; BX.UI.EntityEditorHtml.prototype.onViewClick = function(e) { var link = null; var node = BX.getEventTarget(e); if(node.tagName === "A") { link = node; } else { link = BX.findParent(node, { tagName: "a" }, this._wrapper); } if(link && link.target !== "_blank") { link.target = "_blank"; } }; BX.UI.EntityEditorHtml.prototype.onEditorInitialized = function() { this._isEditorInitialized = true; BX.removeCustomEvent( this._htmlEditor, "OnCreateIframeAfter", this._editorInitializationHandler ); this.prepareEditor(); }; BX.UI.EntityEditorHtml.prototype.prepareEditor = function() { this._htmlEditorContainer.style.display = ""; setTimeout(function() { this._htmlEditor.CheckAndReInit(); this._htmlEditor.ResizeSceleton("100%", 200); this._htmlEditor.SetContent(this.getStringValue(""), true); if(this._focusOnLoad) { this._htmlEditor.Focus(true); this._focusOnLoad = false; } }.bind(this), 0); }; BX.UI.EntityEditorHtml.prototype.release = function() { if(this._htmlEditorContainer) { var stub = BX.create("DIV", { style: { height: this._htmlEditorContainer.offsetHeight + "px", border: "1px solid #bbc4cd", boxSizing: "border-box" } } ); this._htmlEditorContainer.parentNode.insertBefore(stub, this._htmlEditorContainer); document.body.appendChild(this._htmlEditorContainer); this._htmlEditorContainer.style.display = "none"; this._htmlEditorContainer = null; } if(this._htmlEditor) { this.unbindChangeEvent(); this._htmlEditor.SetContent(""); this._htmlEditor = null; this._isEditorInitialized = false; } this._focusOnLoad = false; }; BX.UI.EntityEditorHtml.prototype.bindChangeEvent = function() { if(this._htmlEditor) { BX.addCustomEvent(this._htmlEditor, "OnContentChanged", this._changeHandler); } }; BX.UI.EntityEditorHtml.prototype.unbindChangeEvent = function() { if(this._htmlEditor) { BX.removeCustomEvent(this._htmlEditor, "OnContentChanged", this._changeHandler); } }; BX.UI.EntityEditorHtml.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._htmlEditor)) { throw "BX.UI.EntityEditorHtml. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.UI.EntityEditorHtml.isNotEmptyValue(this._htmlEditor.GetContent()); if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._htmlEditorContainer); } return isValid; }; BX.UI.EntityEditorHtml.prototype.showError = function(error, anchor) { BX.UI.EntityEditorHtml.superclass.showError.apply(this, arguments); if(this._htmlEditorContainer) { BX.addClass(this._htmlEditorContainer, "ui-entity-editor-content-error"); } }; BX.UI.EntityEditorHtml.prototype.clearError = function() { BX.UI.EntityEditorHtml.superclass.clearError.apply(this); if(this._htmlEditorContainer) { BX.removeClass(this._htmlEditorContainer, "ui-entity-editor-content-error"); } }; BX.UI.EntityEditorHtml.prototype.save = function() { if(this._htmlEditor) { var value = this._input.value = this._htmlEditor.GetContent(); this._model.setField(this.getName(), value); } }; BX.UI.EntityEditorHtml.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? this._htmlEditor.GetContent() : "" ); }; BX.UI.EntityEditorHtml.isNotEmptyValue = function(value) { if (BX.type.isNotEmptyString(value)) { return BX.util.trim(value.replace(/<br\/?>| /ig, "")) !== ""; } return false; }; BX.UI.EntityEditorHtml.create = function(id, settings) { var self = new BX.UI.EntityEditorHtml(); self.initialize(id, settings); return self; }; } if (typeof BX.UI.EntityEditorBB === 'undefined') { BX.UI.EntityEditorBB = function() { BX.UI.EntityEditorBB.superclass.constructor.apply(this); }; BX.extend(BX.UI.EntityEditorBB, BX.UI.EntityEditorHtml); BX.UI.EntityEditorBB.prototype.layout = function(options) { if (this._hasLayout) { return; } BX.UI.EntityEditorBB.superclass.layout.apply(this, [options]); if (this._mode !== BX.UI.EntityEditorMode.edit) // view mode { let contentNode = null; if (this._innerWrapper) { contentNode = this._innerWrapper.querySelector('.ui-entity-editor-content-block-inner-html'); } if (contentNode) { let value = this._model.getField(this.getDataKey() + '_HTML', ''); if (!BX.Type.isStringFilled(value)) { value = BX.Text.encode(this.getValue()); } const fieldIcon = new BX.UI.EntityFieldIcon({ editor: this._editor, mode: this.getMode(), fieldId: this.getId(), fieldType: 'string', fieldInnerWrapper: this._innerWrapper, }); const iconNode = fieldIcon.getIconNode(); if (iconNode) { value = value.replace(new RegExp(/<br>$/), iconNode.outerHTML); } contentNode.innerHTML = value; } } }; BX.UI.EntityEditorBB.create = function(id, settings) { var self = new BX.UI.EntityEditorBB(); self.initialize(id, settings); return self; }; } if (typeof BX.UI.EntityEditorFile === "undefined") { BX.UI.EntityEditorFile = function() { BX.UI.EntityEditorFile.superclass.constructor.apply(this); this._innerWrapper = null; this._dialogShowHandler = BX.delegate(this.onDialogShow, this); this._dialogCloseHandler = BX.delegate(this.onDialogClose, this); this._fileChangeHandler = BX.delegate(this.onFileChange, this); this._fileAddHandler = BX.delegate(this.onFileAdd, this); this._fileDeleteHandler = BX.delegate(this.onFileDelete, this); }; BX.extend(BX.UI.EntityEditorFile, BX.UI.EntityEditorField); BX.UI.EntityEditorFile.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorFile.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorFile.prototype.hasContentToDisplay = function() { return (this._mode === BX.UI.EntityEditorMode.edit || this.getValue().length > 0); }; BX.UI.EntityEditorFile.prototype.loadInput = function() { this._editor.loadCustomHtml("RENDER_IMAGE_INPUT", { "FIELD_NAME": this.getDataKey(), "ALLOW_UPLOAD": this._mode === BX.UI.EntityEditorMode.edit ? 'Y' : 'N' }, BX.delegate(this.onEditorHtmlLoad, this)); }; BX.UI.EntityEditorFile.prototype.onEditorHtmlLoad = function(html) { if(this._innerWrapper) { this._innerWrapper.innerHTML = html; BX.addCustomEvent(window, "onAfterPopupShow", this._dialogShowHandler); BX.addCustomEvent(window, "onPopupClose", this._dialogCloseHandler); if (this._mode !== BX.UI.EntityEditorMode.edit) { this._innerWrapper.querySelectorAll("del").forEach(function(element) { element.remove(); }); } window.setTimeout(BX.delegate(this.bindFileEvents, this), 500) } }; BX.UI.EntityEditorFile.prototype.layoutViewMode = function() { var title = this.getTitle(); this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" } }); if (this.hasContentToDisplay()) { this.loadInput(); } else { this._innerWrapper.appendChild(document.createTextNode(this.getMessage("isEmpty"))); } }; BX.UI.EntityEditorFile.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-widget-content-block-field-file" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var title = this.getTitle(); this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "crm-entity-widget-content-block-inner" } } ); this.loadInput(); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this.layoutViewMode(); } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorFile.prototype.doClearLayout = function(options) { if(this._innerWrapper) { BX.removeCustomEvent(window, "onAfterPopupShow", this._dialogShowHandler); BX.removeCustomEvent(window, "onPopupClose", this._dialogCloseHandler); BX.cleanNode(this._innerWrapper); this._innerWrapper = null; } this.unbindFileEvents(); }; BX.UI.EntityEditorFile.prototype.validate = function(result) { var numberOfFiles = 0; var fileControl = BX.MFInput ? BX.MFInput.get(this.getName().toLowerCase() + "_uploader") : null; if(fileControl) { numberOfFiles = fileControl.agent.getItems().length; } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || numberOfFiles > 0; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorFile.prototype.bindFileEvents = function() { var fileControl = BX.MFInput ? BX.MFInput.get(this.getName().toLowerCase() + "_uploader") : null; if(fileControl) { BX.addCustomEvent(fileControl, "onAddFile", this._fileAddHandler); BX.addCustomEvent(fileControl, "onDeleteFile", this._fileDeleteHandler); } }; BX.UI.EntityEditorFile.prototype.unbindFileEvents = function() { var fileControl = BX.MFInput ? BX.MFInput.get(this.getName().toLowerCase() + "_uploader") : null; if(fileControl) { BX.removeCustomEvent(fileControl, "onAddFile", this._fileAddHandler); BX.removeCustomEvent(fileControl, "onDeleteFile", this._fileDeleteHandler); } }; BX.UI.EntityEditorFile.prototype.onDialogShow = function(popup) { if(popup.uniquePopupId.indexOf("popupavatarEditor") !== 0) { return; } BX.addCustomEvent(window, "onApply", this._fileChangeHandler); if(this._singleEditController) { this._singleEditController.setActiveDelayed(false); } BX.bind( popup.popupContainer, "click", function (e) { BX.eventCancelBubble(e); } ); }; BX.UI.EntityEditorFile.prototype.onDialogClose = function(popup) { if(BX.prop.getString(popup, "uniquePopupId", "").indexOf("popupavatarEditor") !== 0) { return; } BX.removeCustomEvent(window, "onApply", this._fileChangeHandler); if(this._singleEditController) { this._singleEditController.setActiveDelayed(true); } }; BX.UI.EntityEditorFile.prototype.getValueAsArray = function() { var value = this.getValue(); if (!Array.isArray(value)) { if (value) { value = [value]; } else { value = []; } } return value; }; BX.UI.EntityEditorFile.prototype.onFileChange = function(result) { this.markAsChanged(); }; BX.UI.EntityEditorFile.prototype.onFileAdd = function(result) { var value = this.getValueAsArray(); value.push(result); this._model.setField(this.getName(), value); this.markAsChanged(); }; BX.UI.EntityEditorFile.prototype.onFileDelete = function(result) { var value = this.getValueAsArray(); this._model.setField(this.getName(), value); this.markAsChanged(); }; BX.UI.EntityEditorFile.create = function(id, settings) { var self = new BX.UI.EntityEditorFile(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorImage === "undefined") { BX.UI.EntityEditorImage = function() { BX.UI.EntityEditorImage.superclass.constructor.apply(this); }; BX.extend(BX.UI.EntityEditorImage, BX.UI.EntityEditorFile); BX.UI.EntityEditorImage.prototype.bindFileEvents = function() { var fileControl = BX.MFInput ? BX.MFInput.get(this.getName().toLowerCase() + "_uploader") : null; if(fileControl) { BX.addCustomEvent(fileControl, "onAddFile", this._fileChangeHandler); BX.addCustomEvent(fileControl, "onDeleteFile", this._fileChangeHandler); } }; BX.UI.EntityEditorImage.prototype.unbindFileEvents = function() { var fileControl = BX.MFInput ? BX.MFInput.get(this.getName().toLowerCase() + "_uploader") : null; if(fileControl) { BX.removeCustomEvent(fileControl, "onAddFile", this._fileChangeHandler); BX.removeCustomEvent(fileControl, "onDeleteFile", this._fileChangeHandler); } }; BX.UI.EntityEditorImage.prototype.hasContentToDisplay = function() { return(this._mode === BX.UI.EntityEditorMode.edit || this._model.getSchemeField(this._schemeElement, "showUrl", "") !== "" ); }; BX.UI.EntityEditorImage.prototype.layoutViewMode = function() { var title = this.getTitle(); this._wrapper.appendChild(this.createTitleNode(title)); this._innerWrapper = BX.create("div", { props: { className: "crm-entity-widget-content-block-inner" } }); if(this.hasContentToDisplay()) { this._innerWrapper.appendChild( BX.create("div", { props: { className: "crm-entity-widget-content-block-inner-box" }, children: [ BX.create( "img", { props: { className: "crm-entity-widget-content-block-photo", src: encodeURI(this._model.getSchemeField(this._schemeElement, "showUrl", "")) } } ) ] } ) ); } else { this._innerWrapper.appendChild(document.createTextNode(this.getMessage("isEmpty"))); } }; BX.UI.EntityEditorImage.prototype.loadInput = function() { console.error('loadInput is not implemented'); // BX.ajax.runComponentAction( // "bitrix:ui.form", // "renderImageInput", // { mode: "ajax", data: { moduleId: "ui", name: this.getName(), value: this.getValue() } } // ).then( // function(result) // { // var data = BX.prop.getObject(result, "data", {}); // var assets = BX.prop.getObject(data, "assets", {}); // // BX.html(null, BX.prop.getString(assets, "css", "")).then( // function() { // BX.loadScript( // BX.prop.getArray(assets, "js", []), // function() { // BX.html(null, BX.prop.getArray(assets, "string", []).join("\n")).then( // function() { // BX.html(this._innerWrapper, BX.prop.getString(data, "html", "")).then( // function() { // BX.addCustomEvent(window, "onAfterPopupShow", this._dialogShowHandler); // BX.addCustomEvent(window, "onPopupClose", this._dialogCloseHandler); // // window.setTimeout(BX.delegate(this.bindFileEvents, this), 500) // }.bind(this) // ); // }.bind(this) // ); // }.bind(this) // ); // }.bind(this) // ); // }.bind(this));this.getName() }; BX.UI.EntityEditorImage.create = function(id, settings) { var self = new BX.UI.EntityEditorImage(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorLink === "undefined") { BX.UI.EntityEditorLink = function() { BX.UI.EntityEditorLink.superclass.constructor.apply(this); this._input = null; this._innerWrapper = null; this._link_template = ""; this._link_target = ""; }; BX.extend(BX.UI.EntityEditorLink, BX.UI.EntityEditorField); BX.UI.EntityEditorLink.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorLink.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorLink.prototype.focus = function() { if(!this._input) { return; } BX.focus(this._input); BX.UI.EditorTextHelper.getCurrent().setPositionAtEnd(this._input); }; BX.UI.EntityEditorLink.prototype.getLineCount = function() { return this._schemeElement.getDataIntegerParam("lineCount", 1); }; BX.UI.EntityEditorLink.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ "ui-entity-editor-field-text" ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this.getName(); var title = this.getTitle(); var value = this.getValue(); var link_template = this.getLinkTemplate(); var link_target = this.getLinkTarget(); this._input = null; this._inputContainer = null; this._innerWrapper = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); var lineCount = this.getLineCount(); if(lineCount > 1) { this._input = BX.create("textarea", { props: { className: "ui-entity-editor-field-textarea", name: name, rows: lineCount, value: value } } ); } else { this._inputContainer = BX.create("div", { attrs: { className: "ui-ctl ui-ctl-textbox ui-ctl-w100" } } ); this._input = BX.create("input", { attrs: { name: name, className: "ui-ctl-element", type: "text", value: value, id: this._id.toLowerCase() + "_text" } } ); this._inputContainer.appendChild(this._input); } if(this.isNewEntity()) { var placeholder = this.getCreationPlaceholder(); if(placeholder !== "") { this._input.setAttribute("placeholder", placeholder); } } BX.bind(this._input, "input", this._changeHandler); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputContainer, BX.create("div", { attrs: { className: "ui-entity-editor-block-help" }, html: '<span>' + BX.prop.get(this._schemeElement.getData(), "help", "") + '</span>' })] } ); } else// if(this._mode === BX.UI.EntityEditorMode.view) { this._wrapper.appendChild(this.createTitleNode(title)); if(this.hasContentToDisplay()) { this._innerWrapper = BX.create( "div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create( "a", { props: { className: "ui-entity-editor-content-block-text", href: link_template.replace("#LINK#", value), target: link_target }, text: value } ) ] } ); } else { this._innerWrapper = BX.create( "div", { props: { className: "ui-entity-editor-content-block" }, text: BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY") } ); } } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorLink.prototype.doClearLayout = function(options) { this._input = null; //BX.unbind(this._innerWrapper, "click", this._viewClickHandler); this._innerWrapper = null; }; BX.UI.EntityEditorLink.prototype.refreshLayout = function() { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorLink.superclass.refreshLayout.apply(this, arguments); return; } if(this._mode === BX.UI.EntityEditorMode.edit && this._input) { this._input.value = this.getValue(); } else if(this._mode === BX.UI.EntityEditorMode.view && this._innerWrapper) { this._innerWrapper.innerHTML = BX.util.htmlspecialchars(this.getValue()); } }; BX.UI.EntityEditorLink.prototype.getLinkTemplate = function() { if(!this._link_template) { this._link_template = BX.prop.get(this._schemeElement.getData(), "link_template", "#LINK#"); } return this._link_template; }; BX.UI.EntityEditorLink.prototype.getLinkTarget = function() { if(!this._link_target) { this._link_target = BX.prop.get(this._schemeElement.getData(), "target", ""); } return this._link_target; }; BX.UI.EntityEditorLink.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit && this._input ? BX.util.trim(this._input.value) : "" ); }; BX.UI.EntityEditorLink.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._input)) { throw "BX.UI.EntityEditorLink. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._input.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._input); } return isValid; }; BX.UI.EntityEditorLink.prototype.showError = function(error, anchor) { BX.UI.EntityEditorLink.superclass.showError.apply(this, arguments); if(this._input) { BX.addClass(this._input, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorLink.prototype.clearError = function() { BX.UI.EntityEditorLink.superclass.clearError.apply(this); if(this._input) { BX.removeClass(this._input, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorLink.prototype.save = function() { if(this._input) { this._model.setField(this.getName(), this._input.value, { originator: this }); } }; BX.UI.EntityEditorLink.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorLink.prototype.getFocusInputID = function() { return this._id.toLowerCase() + "_text"; }; BX.UI.EntityEditorLink.create = function(id, settings) { var self = new BX.UI.EntityEditorLink(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorCustom === "undefined") { BX.UI.EntityEditorCustom = function() { BX.UI.EntityEditorCustom.superclass.constructor.apply(this); this._innerWrapper = null; this._runtimeValue = null; }; BX.extend(BX.UI.EntityEditorCustom, BX.UI.EntityEditorField); BX.UI.EntityEditorCustom.prototype.initialize = function(id, settings) { BX.UI.EntityEditorCustom.superclass.initialize.call(this, id, settings); if (this._schemeElement && this._schemeElement.getDataParam('type') === 'LOCATION' && this._model && this._model.getField(id)) { this.setRuntimeValue(this._model.getField(id)); } } BX.UI.EntityEditorCustom.prototype.hasContentToDisplay = function() { return this.getHtmlContent() !== ""; }; BX.UI.EntityEditorCustom.prototype.doClearLayout = function(options) { this.setRuntimeValue(this.getValue()); }; BX.UI.EntityEditorCustom.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorCustom.prototype.areModelValuesEqual = function(previousModel, currentModel) { var prevValue = previousModel.getSchemeField( this._schemeElement, 'view', '' ); var curValue = currentModel.getSchemeField( this._schemeElement, 'view', '' ); return this.areValuesEqual(prevValue, curValue); }; BX.UI.EntityEditorCustom.prototype.layout = function(options) { if(this._hasLayout) { return; } var classNames = this._schemeElement.getDataArrayParam("classNames", []); classNames.push("ui-entity-editor-field-text"); this.ensureWrapperCreated({ classNames: classNames }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } this._wrapper.appendChild(this.createTitleNode(this.getTitle())); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" } } ); this._wrapper.appendChild(this._innerWrapper); if (this._mode === BX.UI.EntityEditorMode.edit) { BX.addClass(this._innerWrapper, "ui-ctl-custom"); } var html = this.getHtmlContent(); if (BX.type.isNotEmptyString(html)) { setTimeout( BX.delegate(function(){ BX.html(this._innerWrapper, html); if (this._mode === BX.UI.EntityEditorMode.edit) { BX.bindDelegate( this._innerWrapper, "bxchange", { tag: [ "input", "select", "textarea" ] }, this._changeHandler ); } }, this), 0 ); } else if (this._mode !== BX.UI.EntityEditorMode.edit) { this._innerWrapper.appendChild(BX.create("div", { props: { className: "ui-entity-editor-content-block-text" }, text: BX.message("UI_ENTITY_EDITOR_FIELD_EMPTY") })); } if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorCustom.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorCustom.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorCustom.prototype.getHtmlContent = function() { return( this._model.getSchemeField( this._schemeElement, this.isInEditMode() ? "edit" : "view", "" ) ); }; BX.UI.EntityEditorCustom.prototype.setRuntimeValue = function(value) { this._runtimeValue = value; }; BX.UI.EntityEditorCustom.prototype.getRuntimeValue = function() { return (this._mode === BX.UI.EntityEditorMode.edit ? this._runtimeValue : ""); }; BX.UI.EntityEditorCustom.prototype.validate = function(result) { if(this._mode !== BX.UI.EntityEditorMode.edit) { throw "BX.UI.EntityEditorCustom. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } return true; }; BX.UI.EntityEditorCustom.create = function(id, settings) { var self = new BX.UI.EntityEditorCustom(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorMoney === "undefined") { BX.UI.EntityEditorMoney = function() { BX.UI.EntityEditorMoney.superclass.constructor.apply(this); this._currencyEditor = null; this._amountWrapper = null; this._amountInput = null; this._currencyInput = null; this._sumElement = null; this._selectContainer = null; this._inputWrapper = null; this._innerWrapper = null; this._selectedCurrencyValue = ""; this._selectorClickHandler = BX.delegate(this.onSelectorClick, this); this._isCurrencyMenuOpened = false; this.wrapperClassName = "ui-entity-editor-field-money"; }; BX.extend(BX.UI.EntityEditorMoney, BX.UI.EntityEditorField); BX.UI.EntityEditorMoney.prototype.getModeSwitchType = function(mode) { var result = BX.UI.EntityEditorModeSwitchType.common; if(mode === BX.UI.EntityEditorMode.edit) { result |= BX.UI.EntityEditorModeSwitchType.button|BX.UI.EntityEditorModeSwitchType.content; } return result; }; BX.UI.EntityEditorMoney.prototype.getContentWrapper = function() { return this._innerWrapper; }; BX.UI.EntityEditorMoney.prototype.focus = function() { if(this._amountInput && !this.isInputDisabled()) { BX.focus(this._amountInput); BX.UI.EditorTextHelper.getCurrent().selectAll(this._amountInput); } }; BX.UI.EntityEditorMoney.prototype.getValue = function(defaultValue) { if(!this._model) { return ""; } return( this._model.getStringField( this.getAmountFieldName(), (defaultValue !== undefined ? defaultValue : "") ) ); }; BX.UI.EntityEditorMoney.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated({ classNames: [ this.wrapperClassName ] }); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } //var name = this.getName(); var title = this.getTitle(); var data = this.getData(); var amountInputName = BX.prop.getString(data, "amount"); var currencyInputName = BX.prop.getString(BX.prop.getObject(data, "currency"), "name"); var currencyValue = this._model.getField( BX.prop.getString(BX.prop.getObject(data, "currency"), "name", "") ); if(!BX.type.isNotEmptyString(currencyValue)) { currencyValue = BX.Currency.Editor.getBaseCurrencyId(); } this._selectedCurrencyValue = currencyValue; var currencyName = this._editor.findOption( currencyValue, BX.prop.getArray(BX.prop.getObject(data, "currency"), "items") ); var amountFieldName = this.getAmountFieldName(); var currencyFieldName = this.getCurrencyFieldName(); var amountValue = this._model.getField(amountFieldName, ""); //SET CURRENT SUM VALUE var formatted = this._model.getField(BX.prop.getString(data, "formatted"), ""); //SET FORMATTED VALUE this._amountWrapper = null; this._amountValue = null; this._amountInput = null; this._currencyInput = null; this._selectContainer = null; this._innerWrapper = null; this._sumElement = null; if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } if(this._mode === BX.UI.EntityEditorMode.edit) { this._wrapper.appendChild(this.createTitleNode(title)); this._amountValue = BX.create("input", { attrs: { name: amountInputName, type: "hidden", value: amountValue } } ); this._amountInput = BX.create("input", { attrs: { className: "ui-ctl-element", type: "text", value: formatted } } ); this._amountWrapper = BX.create('div', { props: { className: 'ui-ctl-inline ui-ctl-w75'}, children: [ this._amountInput, ] } ); BX.bind(this._amountInput, "input", this._changeHandler); if(this._model.isFieldLocked(amountFieldName)) { this.setInputDisabled(true); } this._currencyInput = BX.create("input", { attrs: { name: currencyInputName, type: "hidden", value: currencyValue } } ); containerProps = { props: { className: "ui-ctl-element" }, text: currencyName, }; this._select = BX.create("div", containerProps); this._selectIcon = BX.create("div", { attrs: { className: "ui-ctl-after ui-ctl-icon-angle" } } ); this._selectContainer = BX.create("div", { props: {className: "ui-ctl ui-ctl-inline ui-ctl-after-icon ui-ctl-dropdown ui-ctl-w33"}, children :[ this._select, this._selectIcon ] } ); if(this._model.isFieldLocked(currencyFieldName)) { this._select.disabled = true; this._selectContainer.disabled = true; this._selectContainer.classList.add('ui-ctl-disabled'); } else { BX.bind(this._selectContainer, "click", this._selectorClickHandler); } this._inputWrapper = BX.create("div", { props: { className: "ui-ctl-inline ui-ctl-w100" }, children: [ this._amountValue, this._currencyInput, this._amountWrapper, this._selectContainer, ] } ); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ this._inputWrapper ] } ); this._currencyEditor = new BX.Currency.Editor( { input: this._amountInput, currency: currencyValue, callback: BX.delegate(this.onAmountValueChange, this) } ); this._currencyEditor.changeValue(); } else //this._mode === BX.UI.EntityEditorMode.view { this._wrapper.appendChild(this.createTitleNode(title)); if(this.hasContentToDisplay()) { var className = "ui-entity-editor-content-block-wallet"; var isLargeFormat = BX.prop.getBoolean(data, "largeFormat", false); if (isLargeFormat) { className += " ui-entity-editor-content-block-wallet-large" } this._sumElement = BX.create("span", { props: { className: className } } ); this._sumElement.innerHTML = this.renderMoney(); this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, children: [ BX.create("div", { props: { className: "ui-entity-editor-content-block-text" }, children: [ this._sumElement ] } ) ] } ); } else { this._innerWrapper = BX.create("div", { props: { className: "ui-entity-editor-content-block" }, text: this.getMessage("isEmpty") } ); } } this._wrapper.appendChild(this._innerWrapper); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorMoney.prototype.doClearLayout = function(options) { BX.PopupMenu.destroy(this._id); if(this._currencyEditor) { this._currencyEditor.clean(); this._currencyEditor = null; } this._amountWrapper = null; this._amountValue = null; this._amountInput = null; this._currencyInput = null; this._sumElement = null; this._selectContainer = null; this._inputWrapper = null; this._innerWrapper = null; }; BX.UI.EntityEditorMoney.prototype.refreshLayout = function(options) { if(!this._hasLayout) { return; } if(!this._isValidLayout) { BX.UI.EntityEditorMoney.superclass.refreshLayout.apply(this, arguments); return; } if(this._mode === BX.UI.EntityEditorMode.edit && this._amountInput) { var currencyValue = this._currencyEditor ? this._currencyEditor.currency : this._model.getField(this.getCurrencyFieldName()); if(!BX.type.isNotEmptyString(currencyValue)) { currencyValue = BX.Currency.Editor.getBaseCurrencyId(); } var amountFieldName = this.getAmountFieldName(); this._amountValue.value = this._model.getField(amountFieldName); this._amountInput.value = BX.Currency.Editor.getFormattedValue( this._model.getField(amountFieldName, ""), currencyValue ); this.setInputDisabled(this._model.isFieldLocked(amountFieldName)); } else if(this._mode === BX.UI.EntityEditorMode.view && this._sumElement) { this._sumElement.innerHTML = this.renderMoney(); } }; BX.UI.EntityEditorMoney.prototype.onAmountValueChange = function(value) { if(!this._amountValue) { return; } var currencyFormat = BX.prop.getObject( BX.Currency.Editor.currencyList, this._selectedCurrencyValue, null ); if (currencyFormat) { value = BX.Currency.Editor.getUnFormattedValue(value, this._selectedCurrencyValue); } this._amountValue.value = value; }; BX.UI.EntityEditorMoney.prototype.getAmountFieldName = function() { return this._schemeElement.getDataStringParam("amount", ""); }; BX.UI.EntityEditorMoney.prototype.getCurrencyFieldName = function() { return BX.prop.getString( this._schemeElement.getDataObjectParam("currency", {}), "name", "" ); }; BX.UI.EntityEditorMoney.prototype.onSelectorClick = function (e) { this.openCurrencyMenu(); }; BX.UI.EntityEditorMoney.prototype.openCurrencyMenu = function() { if(this._isCurrencyMenuOpened) { return; } var data = this._schemeElement.getData(); var currencyList = BX.prop.getArray(BX.prop.getObject(data, "currency"), "items"); //{NAME, VALUE} var key = 0; var menu = []; while (key < currencyList.length) { menu.push( { text: BX.util.htmlspecialchars(currencyList[key]["NAME"]), value: BX.util.htmlspecialchars(currencyList[key]["VALUE"]), onclick: BX.delegate( this.onCurrencySelect, this) } ); key++ } BX.PopupMenu.show( this._id, this._selectContainer, menu, { angle: false, width: this._selectContainer.offsetWidth + 'px', events: { onPopupShow: BX.delegate( this.onCurrencyMenuOpen, this), onPopupClose: BX.delegate( this.onCurrencyMenuClose, this) } } ); }; BX.UI.EntityEditorMoney.prototype.closeCurrencyMenu = function() { if(!this._isCurrencyMenuOpened) { return; } var menu = BX.PopupMenu.getMenuById(this._id); if(menu) { menu.popupWindow.close(); } }; BX.UI.EntityEditorMoney.prototype.onCurrencyMenuOpen = function() { BX.addClass(this._selectContainer, "active"); this._isCurrencyMenuOpened = true; }; BX.UI.EntityEditorMoney.prototype.onCurrencyMenuClose = function() { BX.PopupMenu.destroy(this._id); BX.removeClass(this._selectContainer, "active"); this._isCurrencyMenuOpened = false; }; BX.UI.EntityEditorMoney.prototype.onCurrencySelect = function(e, item) { this.closeCurrencyMenu(); this._selectedCurrencyValue = this._currencyInput.value = item.value; this._select.innerHTML = BX.util.htmlspecialchars(item.text); if(this._currencyEditor) { this._currencyEditor.setCurrency(this._selectedCurrencyValue); } this.markAsChanged( { fieldName: this.getCurrencyFieldName(), fieldValue: this._selectedCurrencyValue } ); }; BX.UI.EntityEditorMoney.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getAmountFieldName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorMoney.prototype.processModelLock = function(params) { var name = BX.prop.getString(params, "name", ""); if(this.getAmountFieldName() === name) { this.refreshLayout(); } }; BX.UI.EntityEditorMoney.prototype.validate = function(result) { if(!(this._mode === BX.UI.EntityEditorMode.edit && this._amountInput && this._amountValue)) { throw "BX.UI.EntityEditorMoney. Invalid validation context"; } this.clearError(); if(this.hasValidators()) { return this.executeValidators(result); } var isValid = !(this.isRequired() || this.isRequiredByAttribute()) || BX.util.trim(this._amountValue.value) !== ""; if(!isValid) { result.addError(BX.UI.EntityValidationError.create({ field: this })); this.showRequiredFieldError(this._inputWrapper); } return isValid; }; BX.UI.EntityEditorMoney.prototype.showError = function(error, anchor) { BX.UI.EntityEditorMoney.superclass.showError.apply(this, arguments); if(this._amountInput) { BX.addClass(this._amountInput, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorMoney.prototype.clearError = function() { BX.UI.EntityEditorMoney.superclass.clearError.apply(this); if(this._amountInput) { BX.removeClass(this._amountInput, "ui-entity-editor-field-error"); } }; BX.UI.EntityEditorMoney.prototype.setInputDisabled = function(isDisabled) { if (!this._amountInput || !this._amountWrapper) { return; } this._amountInput.readOnly = isDisabled; if (isDisabled) { BX.Dom.addClass(this._amountWrapper, 'ui-ctl-disabled'); } else { BX.Dom.removeClass(this._amountWrapper, 'ui-ctl-disabled'); } }; BX.UI.EntityEditorMoney.prototype.isInputDisabled = function() { return this._amountInput.readOnly; }; BX.UI.EntityEditorMoney.prototype.getRuntimeValue = function() { var data = []; if (this._mode === BX.UI.EntityEditorMode.edit) { if(this._amountValue) { data[ BX.prop.getString(data, "amount")] = this._amountValue.value; } data[ BX.prop.getString(data, "currency")] = this._selectedCurrencyValue; return data; } return ""; }; BX.UI.EntityEditorMoney.prototype.save = function() { var data = this._schemeElement.getData(); this._model.setField( BX.prop.getString(BX.prop.getObject(data, "currency"), "name"), this._selectedCurrencyValue, { originator: this } ); if(this._amountValue) { this._model.setField( BX.prop.getString(data, "amount"), this._amountValue.value, { originator: this } ); this._model.setField( BX.prop.getString(data, "formatted"), "", { originator: this } ); this._editor.formatMoney( this._amountValue.value, this._selectedCurrencyValue, BX.delegate(this.onMoneyFormatRequestSuccess, this) ); } }; BX.UI.EntityEditorMoney.prototype.onMoneyFormatRequestSuccess = function(data) { var schemeData = this._schemeElement.getData(); var formattedWithCurrency = BX.type.isNotEmptyString(data["FORMATTED_SUM_WITH_CURRENCY"]) ? data["FORMATTED_SUM_WITH_CURRENCY"] : ""; this._model.setField(BX.prop.getString(schemeData, "formattedWithCurrency"), formattedWithCurrency); var formatted = BX.type.isNotEmptyString(data["FORMATTED_SUM"]) ? data["FORMATTED_SUM"] : ""; this._model.setField( BX.prop.getString(schemeData, "formatted"), formatted, { originator: this } ); if(this._sumElement) { while (this._sumElement.firstChild) { this._sumElement.removeChild(this._sumElement.firstChild); } this._sumElement.innerHTML = this.renderMoney(); } }; BX.UI.EntityEditorMoney.prototype.renderMoney = function() { var data = this._schemeElement.getData(); var formattedWithCurrency = this._model.getField(BX.prop.getString(data, "formattedWithCurrency"), ""); var formatted = this._model.getField(BX.prop.getString(data, "formatted"), ""); var result = BX.Currency.Editor.trimTrailingZeros(formatted, this._selectedCurrencyValue); var isLargeFormat = BX.prop.getBoolean(data, "largeFormat", false); if (isLargeFormat) { result = "<span class=\"ui-entity-widget-content-block-columns-right\">" + result + "</span>"; } return formattedWithCurrency.replace( formatted, result ); }; BX.UI.EntityEditorMoney.create = function(id, settings) { var self = new BX.UI.EntityEditorMoney(); self.initialize(id, settings); return self; } } if(typeof BX.UI.EntityEditorUser === "undefined") { BX.UI.EntityEditorUser = function() { BX.UI.EntityEditorUser.superclass.constructor.apply(this); this._input = null; this._editButton = null; this._photoElement = null; this._nameElement = null; this._positionElement = null; this._selectedData = {}; this._editButtonClickHandler = BX.delegate(this.onEditBtnClick, this); }; BX.extend(BX.UI.EntityEditorUser, BX.UI.EntityEditorField); BX.UI.EntityEditorUser.prototype.isSingleEditEnabled = function() { return true; }; BX.UI.EntityEditorUser.prototype.getRelatedDataKeys = function() { return ( [ this.getDataKey(), this._schemeElement.getDataStringParam("formated", ""), this._schemeElement.getDataStringParam("position", ""), this._schemeElement.getDataStringParam("showUrl", ""), this._schemeElement.getDataStringParam("photoUrl", "") ] ); }; BX.UI.EntityEditorUser.prototype.hasContentToDisplay = function() { return true; }; BX.UI.EntityEditorUser.prototype.layout = function(options) { if(this._hasLayout) { return; } this.ensureWrapperCreated(); this.adjustWrapper(); if(!this.isNeedToDisplay()) { this.registerLayout(options); this._hasLayout = true; return; } var name = this._schemeElement.getName(); var title = this._schemeElement.getTitle(); var value = this._model.getField(name); var formattedName = this._model.getSchemeField(this._schemeElement, "formated", ""); var position = this._model.getSchemeField(this._schemeElement, "position", ""); var showUrl = this._model.getSchemeField(this._schemeElement, "showUrl", "", ""); var photoUrl = this._model.getSchemeField(this._schemeElement, "photoUrl", ""); this._photoElement = BX.create("a", { props: { className: "ui-entity-editor-user-avatar-container", target: "_blank" }, style: { backgroundImage: BX.type.isNotEmptyString(photoUrl) ? "url('" + encodeURI(photoUrl) + "')" : "", backgroundSize: BX.type.isNotEmptyString(photoUrl) ? "30px" : "" } } ); this._nameElement = BX.create("a", { props: { className: "ui-entity-editor-user-name", target: "_blank" }, text: formattedName } ); if (showUrl !== "") { this._photoElement.href = showUrl; this._nameElement.href = showUrl; } this._positionElement = BX.create("SPAN", { props: { className: "ui-entity-editor-user-position" }, text: position } ); if(this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } this._wrapper.appendChild(this.createTitleNode(title)); var userElement = BX.create("div", { props: { className: "ui-entity-editor-user-container" } }); this._editButton = null; this._input = null; if(this._mode === BX.UI.EntityEditorMode.edit || (this.isEditInViewEnabled() && !this.isReadOnly())) { this._input = BX.create("input", { attrs: { name: name, type: "hidden", value: value } }); this._wrapper.appendChild(this._input); this._editButton = BX.create("span", { props: { className: "ui-entity-editor-user-change" }, text: BX.message("UI_ENTITY_EDITOR_CHANGE") }); BX.bind(this._editButton, "click", this._editButtonClickHandler); userElement.appendChild(this._editButton); } userElement.appendChild(this._photoElement); userElement.appendChild( BX.create("span", { props: { className: "ui-entity-editor-user-info" }, children: [ this._nameElement, this._positionElement ] } ) ); this._wrapper.appendChild( BX.create("div", { props: { className: "ui-entity-editor-user-content-block-inner" }, children: [ userElement ] } ) ); if(this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if(this.isDragEnabled()) { this.initializeDragDropAbilities(); } this.registerLayout(options); this._hasLayout = true; }; BX.UI.EntityEditorUser.prototype.doRegisterLayout = function() { if(this.isInEditMode() && this.checkModeOption(BX.UI.EntityEditorModeOptions.individual) ) { window.setTimeout(BX.delegate(this.openSelector, this), 0); } }; BX.UI.EntityEditorUser.prototype.doClearLayout = function(options) { this._input = null; this._editButton = null; this._photoElement = null; this._nameElement = null; this._positionElement = null; }; BX.UI.EntityEditorUser.prototype.onEditBtnClick = function(e) { //If any other control has changed try to switch to edit mode. if(this._mode === BX.UI.EntityEditorMode.view && this.isEditInViewEnabled() && this.getEditor().isChanged()) { this.switchToSingleEditMode(); } else { this.openSelector(); } }; BX.UI.EntityEditorUser.prototype.openSelector = function() { BX.onCustomEvent(this._editor, "BX.UI.EntityEditorUser:openSelector", [ this, { id: this._id, callback: BX.delegate(this.processItemSelect, this), anchor: this._editButton, }]); }; BX.UI.EntityEditorUser.prototype.processItemSelect = function(selector, item) { var isViewMode = this._mode === BX.UI.EntityEditorMode.view; var editInView = this.isEditInViewEnabled(); if(isViewMode && !editInView) { return; } this._selectedData = { id: BX.prop.getInteger(item, "entityId", 0), photoUrl: BX.prop.getString(item, "avatar", ""), formattedNameHtml: BX.prop.getString(item, "name", ""), positionHtml: BX.prop.getString(item, "desc", "") }; this._input.value = this._selectedData["id"]; this._photoElement.style.backgroundImage = this._selectedData["photoUrl"] !== "" ? "url('" + encodeURI(this._selectedData["photoUrl"]) + "')" : ""; this._photoElement.style.backgroundSize = this._selectedData["photoUrl"] !== "" ? "30px" : ""; this._nameElement.innerHTML = this._selectedData["formattedNameHtml"]; this._positionElement.innerHTML = this._selectedData["positionHtml"]; BX.onCustomEvent(this._editor, "BX.UI.EntityEditorUser:closeSelector", [ this, { id: this._id, }]); if(!isViewMode) { this.markAsChanged(); } else { this._editor.saveControl(this); } }; BX.UI.EntityEditorUser.prototype.save = function() { var data = this._schemeElement.getData(); if(this._selectedData["id"] > 0) { var itemId = this._selectedData["id"]; this._model.setField( BX.prop.getString(data, "formated"), BX.util.htmlspecialcharsback(this._selectedData["formattedNameHtml"]) ); this._model.setField( BX.prop.getString(data, "position"), this._selectedData["positionHtml"] !== " " ? BX.util.htmlspecialcharsback(this._selectedData["positionHtml"]) : "" ); this._model.setField( BX.prop.getString(data, "showUrl"), BX.prop.getString(data, "pathToProfile").replace(/#user_id#/ig, itemId) ); this._model.setField( BX.prop.getString(data, "photoUrl"), this._selectedData["photoUrl"] ); this._model.setField(this.getName(), itemId); } }; BX.UI.EntityEditorUser.prototype.processModelChange = function(params) { if(BX.prop.get(params, "originator", null) === this) { return; } if(!BX.prop.getBoolean(params, "forAll", false) && BX.prop.getString(params, "name", "") !== this.getName() ) { return; } this.refreshLayout(); }; BX.UI.EntityEditorUser.prototype.getRuntimeValue = function() { if (this._mode === BX.UI.EntityEditorMode.edit && this._selectedData["id"] > 0) { return this._selectedData["id"]; } return ""; }; BX.UI.EntityEditorUser.prototype.getMessage = function(name) { var m = BX.UI.EntityEditorUser.messages; return (m.hasOwnProperty(name) ? m[name] : BX.UI.EntityEditorUser.superclass.getMessage.apply(this, arguments) ); }; if(typeof(BX.UI.EntityEditorUser.messages) === "undefined") { BX.UI.EntityEditorUser.messages = {}; } BX.UI.EntityEditorUser.create = function(id, settings) { var self = new BX.UI.EntityEditorUser(); self.initialize(id, settings); return self; }; } if(typeof BX.UI.EntityEditorProductRowSummary === "undefined") { BX.UI.EntityEditorProductRowSummary = function() { BX.UI.EntityEditorProductRowSummary.superclass.constructor.apply(this); this._availableProducts = null; this._productListOffset = 0; this.productListLimit = 3; this.totalCount = 0; this._productSummaryContainer = null; this._productListContainer = null; this._moreButton = null; }; BX.extend(BX.UI.EntityEditorProductRowSummary, BX.UI.EntityEditorField); BX.UI.EntityEditorProductRowSummary.prototype.layout = function(options) { if (this._hasLayout) { return; } const wasLayoutCleared = this._isNeedClearLayout(options); if (wasLayoutCleared) { this.ensureWrapperCreated({}); this.adjustWrapper(); } if (wasLayoutCleared) { if (this.isDragEnabled()) { this._wrapper.appendChild(this.createDragButton()); } this._wrapper.appendChild(this.createTitleNode(this.getTitle())); } this.updateProductSummaryContainer(this.getValue()); if (wasLayoutCleared) { this._wrapper.appendChild(this._productSummaryContainer); if (this.isContextMenuEnabled()) { this._wrapper.appendChild(this.createContextMenuButton()); } if (this.isDragEnabled()) { this.initializeDragDropAbilities(); } } this._hasLayout = true; this.registerLayout(options); }; BX.UI.EntityEditorProductRowSummary.prototype.getProductListLength = function() { const data = this.getValue(); return BX.prop.getArray(data, 'items', []).length; }; BX.UI.EntityEditorProductRowSummary.prototype.clearLayout = function(options) { if(this._isNeedClearLayout(options)) // clear layout if animation not required or position not preserved { return BX.UI.EntityEditorProductRowSummary.superclass.clearLayout.apply(this, arguments); } this._hasLayout = false; }; BX.UI.EntityEditorProductRowSummary.prototype._isNeedClearLayout = function(options) { return ( !BX.prop.getBoolean(options, 'preservePosition', false) || !BX.prop.getBoolean(options, 'isRefreshViewModeLayout', false) ); }; BX.UI.EntityEditorProductRowSummary.prototype.doClearLayout = function() { this._clearProductListData(); this._productSummaryContainer = null; this._productListContainer = null; this._moreButton = null; }; BX.UI.EntityEditorProductRowSummary.prototype.getAvailableProductsToDisplay = function () { if (this._availableProducts === null) { this.initProductListData(); } return this._availableProducts; } BX.UI.EntityEditorProductRowSummary.prototype._clearProductListData = function() { this._productListOffset = 0; this.totalCount = 0; this._availableProducts = null; } BX.UI.EntityEditorProductRowSummary.prototype.initProductListData = function(products) { if (!(products instanceof Array)) { products = BX.prop.getArray(this.getValue(), 'items', []); } this._availableProducts = products.slice(0, this.productListLimit * 2); } BX.UI.EntityEditorProductRowSummary.prototype.updateProductSummaryContainer = function(summaryData) { const isContainerInited = !(this._productSummaryContainer === null); if (!isContainerInited) { this._productSummaryContainer = BX.create( 'div', { props: {className: 'ui-entity-editor-product-summary-container'} } ); this._currentData = summaryData; this._previousData = {}; } else { BX.cleanNode(this._productSummaryContainer); this._previousData = this._currentData; this._currentData = summaryData; this._productListContainer = null; this._clearProductListData(); } this.totalCount = BX.prop.getNumber(summaryData, 'count', 0); const totalInfo = BX.prop.getString(summaryData, 'total', ''); if (this.totalCount > 0) { const totalInfoBlock = BX.create( 'span', { props: {className: 'ui-enitity-editor-product-summary-total-info'}, html: this._getTotalInfoPhraseTemplate(this.totalCount) .replace(/#COUNT#/gi, this.totalCount) .replace(/#TOTAL#/gi, totalInfo), } ); this._productSummaryContainer.appendChild(totalInfoBlock); const isReadOnly = BX.prop.getBoolean(summaryData, 'isReadOnly', true); if (!isReadOnly) { const addProductLinkBlock = BX.create( 'span', { props: { className: 'ui-enitity-editor-product-summary-tab-link', onclick: () => { this.openDetailProductList(); } }, text: BX.message("UI_ENTITY_EDITOR_PRODUCT_SUMMARY_TAB_LINK_EDIT"), } ); this._productSummaryContainer.appendChild(addProductLinkBlock); } const products = this.getAvailableProductsToDisplay(); this.createProductListContainer(products); this._productSummaryContainer.appendChild(this._productListContainer); const limit = Math.min(products.length, this.productListLimit); if (limit < products.length) { this._moreButton = this._getMoreButton(); this._productSummaryContainer.appendChild(this._moreButton); } } else { const isReadOnly = BX.prop.getBoolean(summaryData, 'isReadOnly', true); this._productSummaryContainer.appendChild(this._createEmptyListContainer(isReadOnly, this.totalCount, totalInfo)); } }; BX.UI.EntityEditorProductRowSummary.prototype._getTotalInfoPhraseTemplate = function(totalValue) { const languageId = BX.message('LANGUAGE_ID'); const phraseTemplate = BX.message( 'UI_ENTITY_EDITOR_PRODUCT_SUMMARY_TOTAL_PLURAL_' + BX.Loc.getPluralForm(totalValue, languageId) ); if (phraseTemplate) { return phraseTemplate; } return BX.message('UI_ENTITY_EDITOR_PRODUCT_SUMMARY_TOTAL'); } BX.UI.EntityEditorProductRowSummary.prototype._createEmptyListContainer = function(isReadOnly, totalCount, totalInfo) { if (isReadOnly) { return BX.create( 'span', { props: {className: 'ui-enitity-editor-product-summary-total-info'}, html: BX.message("UI_ENTITY_EDITOR_PRODUCT_SUMMARY_TOTAL").replace(/#COUNT#/gi, totalCount).replace(/#TOTAL#/gi, totalInfo), } ); } return BX.create( 'div', { props: { className: 'ui-entity-editor-product-summary-empty-list-container', onclick: () => { this.addNewPositionInDetailProductList(); } }, children: [ BX.create( 'span', { props: { className: 'ui-entity-editor-product-summary-empty-list-title' }, text: BX.message("UI_ENTITY_EDITOR_PRODUCT_SUMMARY_TAB_LINK_ADD") } ) ] } ); }; BX.UI.EntityEditorProductRowSummary.prototype.createProductListContainer = function(products = []) { if (this._productListContainer !== null) { return; } this._productListContainer = BX.create( 'ul', { props: { className: 'ui-entity-editor-product-list-container' } } ); const limit = Math.min(products.length, this.productListLimit); for (let i = 0; i < limit; i++) { this.addProductRow(products[i]); } }; BX.UI.EntityEditorProductRowSummary.prototype.addProductRow = function(productData) { if (this._productListContainer === null) { return; } const formattedProductData = this._formatProductData(productData); const row = BX.create( 'li', { props: { className: 'ui-entity-editor-product-row-container' }, children: [ this._getProductPicture(formattedProductData), this._getProductDetails(formattedProductData) ], } ); this._productListContainer.appendChild(row); this._productListOffset++; }; BX.UI.EntityEditorProductRowSummary.prototype._formatProductData = function(product) { return { name: BX.prop.getString(product, 'PRODUCT_NAME', ''), url: BX.prop.getString(product, 'URL', ''), price: BX.prop.getString(product, 'SUM', ''), propertiesString: BX.prop.getString(product, 'VARIATION_INFO', ''), photo: BX.prop.getString(product, 'PHOTO_URL', ''), }; }; BX.UI.EntityEditorProductRowSummary.prototype._getProductPicture = function(productData) { const {photo: photoUrl} = productData; const photoSettings = { props: { className: 'ui-enitity-editor-product-photo' } } if (photoUrl !== '') { photoSettings.style = { backgroundImage: `url(${encodeURI(photoUrl)})` }; } return BX.create('div', photoSettings); }; BX.UI.EntityEditorProductRowSummary.prototype._getProductDetails = function(productData) { const { name: productName, url: productUrl, price: productPrice, propertiesString: productProperties } = productData; const productTitle = this._getProductTitle(productName, productUrl); const productDetailsNodes = []; if (productProperties !== '') { productDetailsNodes.push(BX.create( 'span', { props: {className: 'ui-entity-editor-product-details-properties'}, text: productProperties, } )); } productDetailsNodes.push(BX.create( 'span', { props: {className: 'ui-entity-editor-product-details-price'}, html: productPrice, } )); const productDetails = BX.create( 'div', { props: {className: 'ui-enitity-editor-product-details'}, children: productDetailsNodes } ); return BX.create( 'div', { props: {className: 'ui-enitity-editor-product-info'}, children: [productTitle, productDetails] } ); }; BX.UI.EntityEditorProductRowSummary.prototype._isShowProductLink = function() { const settings = this._schemeElement && this._schemeElement._settings && BX.Type.isObject(this._schemeElement._settings) ? this._schemeElement._settings : {} ; return BX.prop.getBoolean(settings, 'showProductLink', true); }; BX.UI.EntityEditorProductRowSummary.prototype._getProductTitle = function(title, url = '') { let titleBlock; if ((typeof url === 'string') && url !== '' && this._isShowProductLink()) { titleBlock = BX.create( 'a', { props: { className: 'ui-entity-editor-product-title-link', href: url }, text: title } ); } else { titleBlock = BX.create( 'span', { props: { className: 'ui-entity-editor-product-title' }, text: title } ); } return titleBlock; }; BX.UI.EntityEditorProductRowSummary.prototype._getMoreButton = function() { if (this._moreButton === null) { const listLength = Math.min(this.totalCount, this.productListLimit * 2); this._moreButton = BX.create( 'span', { props: { className: 'ui-entity-editor-product-list-more-button', onclick: () => { this._onMoreButtonClick(); } }, text: BX.message('UI_ENTITY_EDITOR_PRODUCT_SUMMARY_MORE_BUTTON') .replace('#COUNT#', listLength - this._productListOffset), } ); } return this._moreButton; }; BX.UI.EntityEditorProductRowSummary.prototype._onMoreButtonClick = function() { this._productListContainer.style.maxHeight = `${this._productListContainer.clientHeight}px`; const products = this.getAvailableProductsToDisplay(); for (let i = this._productListOffset; i < products.length; i++) { this.addProductRow(products[i]); } const height = parseInt(this._productListContainer.style.maxHeight); setTimeout(() => { this._productListContainer.style.maxHeight = `${2 * height}px`; }, 0); BX.remove(this._moreButton); if (products.length < this.getProductListLength()) { this._wrapper.appendChild(BX.create( 'span', { props: { className: 'ui-entity-editor-product-list-more-button', onclick: () => { this.openDetailProductList(); } }, text: BX.message('UI_ENTITY_EDITOR_PRODUCT_SUMMARY_FULL_BUTTON') .replace(/#COUNT#/gi, this.totalCount), } )) } }; BX.UI.EntityEditorProductRowSummary.prototype.openDetailProductList = function() { BX.onCustomEvent(window, "BX.UI.EntityEditorProductRowSummary:onDetailProductListLinkClick", [this]); }; BX.UI.EntityEditorProductRowSummary.prototype.addNewPositionInDetailProductList = function() { BX.onCustomEvent(window, "BX.UI.EntityEditorProductRowSummary:onAddNewRowInProductList", [this]); } BX.UI.EntityEditorProductRowSummary.prototype.hasContentToDisplay = function() { return true; }; BX.UI.EntityEditorProductRowSummary.create = function(id, settings) { let self = new BX.UI.EntityEditorProductRowSummary(); self.initialize(id, settings); return self; }; }