/* * Copyright [2015] [wisemapping] * * Licensed under WiseMapping Public License, Version 1.0 (the "License"). * It is basically the Apache License, Version 2.0 (the "License") plus the * "powered by wisemapping" text requirement on every single page; * you may not use this file except in compliance with the License. * You may obtain a copy of the license at * * http://www.wisemapping.org/license * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ const ToolbarItem = require('./ToolbarItem').default; const FloatingTip = require('./FloatingTip').default; const ToolbarPaneItem = new Class({ Extends:ToolbarItem, initialize : function(buttonId, model) { $assert(buttonId, "buttonId can not be null"); $assert(model, "model can not be null"); this._model = model; var me = this; var fn = function() { // Is the panel being displayed ? me.isVisible() ? me.hide() : me.show(); }; this.parent(buttonId, fn, {topicAction:true,relAction:false}); this._panelElem = this._init(); this._visible = false; }, _init:function () { // Load the context of the panel ... var panelElem = this.buildPanel(); panelElem.css('cursor', 'default'); var buttonElem = this.getButtonElem(); var me = this; this._tip = new FloatingTip(buttonElem, { html: true, placement: 'bottom', content: function() { return me._updateSelectedItem(); }, className: 'toolbarPaneTip', trigger: 'manual', template: '' }); this._tip.addEvent('hide', function() { me._visible = false }); this._tip.addEvent('show', function() { me._visible = true }); return panelElem; }, getModel : function() { return this._model; }, getPanelElem : function() { return this._panelElem; }.protect(), show : function() { if (!this.isVisible()) { this.parent(); this._tip.show(); this.getButtonElem().className = 'buttonExtActive'; } }, hide : function() { if (this.isVisible()) { this.parent(); this._tip.hide(); this.getButtonElem().className = 'buttonExtOn'; } }, isVisible : function() { return this._visible; }, disable : function() { this.hide(); var elem = this.getButtonElem(); if (this._enable) { elem.unbind('click', this._fn); elem.removeClass('buttonExtOn'); // Todo: Hack... elem.removeClass('buttonOn'); elem.addClass('buttonExtOff'); this._enable = false; } }, enable : function() { var elem = this.getButtonElem(); if (!this._enable) { elem.bind('click', this._fn); elem.removeClass('buttonExtOff'); elem.addClass('buttonExtOn'); this._enable = true; } }, buildPanel : function() { throw "Method must be implemented"; }.protect() }); export default ToolbarPaneItem;