/* This file contains proprietary software owned by Motorola Mobility, Inc.
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
*/ var Montage = require("montage/core/core").Montage; var Component = require("montage/ui/component").Component; exports.Splitter = Montage.create(Component, { version: { value: "1.0" }, hasTemplate: { value: false }, _panel: { value: null }, panel: { get: function() { return this._panel; }, set: function(value) { this._panel = value; } }, _resizeBar: { value: null }, resizeBar: { get: function() { return this._resizeBar; }, set: function(val) { this._resizeBar = val; }, serializable: true }, _collapsed : { value: false, enumerable:true }, collapsed: { get: function() { return this._collapsed; }, set: function(value) { this._collapsed = value; this.application.localStorage.setItem(this.element.getAttribute("data-montage-id"), {"version": this.version, "value": value}); } }, prepareForDraw: { value: function() { //Get splitter initial value from SettingManager var storedData = this.application.localStorage.getItem(this.element.getAttribute("data-montage-id")); if(storedData && this.element.getAttribute("data-montage-id") !== null) { this._collapsed = storedData.value; } else { this._collapsed = false; } this.element.addEventListener("click", this, false); } }, draw: { value: function() { if(this.collapsed) { if(this.panel.element) this.panel.element.classList.add("collapsed"); else this.panel.classList.add("collapsed"); this.element.classList.add("collapsed"); if(this._resizeBar != null) this.resizeBar.classList.add("collapsed"); } else { if(this.panel.element) this.panel.element.classList.remove("collapsed"); else this.panel.classList.remove("collapsed"); this.element.classList.remove("collapsed"); if(this._resizeBar != null) this.resizeBar.classList.remove("collapsed"); } } }, handleClick : { value: function() { if (!this.disabled) { if(this.panel.element) { this.panel.element.addEventListener("webkitTransitionEnd", this, false); } else { this.panel.addEventListener("webkitTransitionEnd", this, false); } this.collapsed = !this.collapsed; this.needsDraw = true; } } }, handleWebkitTransitionEnd: { value: function() { if(this.panel.element) { this.panel.element.removeEventListener("webkitTransitionEnd", this, false); } else { this.panel.removeEventListener("webkitTransitionEnd", this, false); } if(this.application.ninja.currentDocument && this.application.ninja.currentDocument.currentView === "design"){ this.application.ninja.stage.resizeCanvases = true; } } }, _disabled: { value: null }, disabled: { get: function() { return this._disabled; }, set: function(val) { if (val && !this.element.classList.contains("disabled")) { this.element.classList.add("disabled"); } else { this.element.classList.remove("disabled"); } this._disabled = val; } }, toggle: { value: function() { this.handleClick(); } }, collapse:{ value: function() { if (this.collapsed === false) { if(this.panel.element) { this.panel.element.addEventListener("webkitTransitionEnd", this, false); } else { this.panel.addEventListener("webkitTransitionEnd", this, false); } this._collapsed = true; this.disabled = true; this.needsDraw = true; } } }, restore:{ value: function(onSwitchFromCodeDocument) { //Get splitter initial value from SettingManager var storedData = this.application.localStorage.getItem(this.element.getAttribute("data-montage-id")), temp = this.collapsed; if(storedData && this.element.getAttribute("data-montage-id") !== null) { this._collapsed = storedData.value; } else { this._collapsed = false; } if(temp != this._collapsed){ if(this.panel.element) { this.panel.element.addEventListener("webkitTransitionEnd", this, false); } else { this.panel.addEventListener("webkitTransitionEnd", this, false); } this.disabled = false; if(onSwitchFromCodeDocument) { this.draw(); // When switching from code document, draw immediately so stage size is correct } else { this.needsDraw = true; } } } } });