From 8f78cb1377009dabde95f4a81d5090b79b9de0da Mon Sep 17 00:00:00 2001 From: Valerio Virgillito Date: Tue, 17 Jul 2012 23:34:57 -0700 Subject: menu design update and bug fixes - Moved Preview to the document bar - Redesigned the menu and improved DOM structure. - Removed un-used entires - Fixed layout and snap entries - Moved the preview button to the document bar. - Fixes for bugs: #1750, #1867, #1876, #1895 Signed-off-by: Valerio Virgillito --- js/ui/menu/menu.reel/menu.css | 39 +++++++++ js/ui/menu/menu.reel/menu.html | 94 +++++++++++++++++++++ js/ui/menu/menu.reel/menu.js | 183 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 316 insertions(+) create mode 100755 js/ui/menu/menu.reel/menu.css create mode 100755 js/ui/menu/menu.reel/menu.html create mode 100755 js/ui/menu/menu.reel/menu.js (limited to 'js/ui/menu/menu.reel') diff --git a/js/ui/menu/menu.reel/menu.css b/js/ui/menu/menu.reel/menu.css new file mode 100755 index 00000000..a02d488d --- /dev/null +++ b/js/ui/menu/menu.reel/menu.css @@ -0,0 +1,39 @@ +/* +Copyright (c) 2012, Motorola Mobility LLC. +All Rights Reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + +* Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +* Neither the name of Motorola Mobility LLC nor the names of its + contributors may be used to endorse or promote products derived from this + software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. + */ + +.horizontal-menu { + list-style: none; + margin: 0; + padding: 0 5px 0 5px; + float: left; + cursor: default; + display: block; +} diff --git a/js/ui/menu/menu.reel/menu.html b/js/ui/menu/menu.reel/menu.html new file mode 100755 index 00000000..4708c2cb --- /dev/null +++ b/js/ui/menu/menu.reel/menu.html @@ -0,0 +1,94 @@ + + + + + + + + + + + + + + + + + diff --git a/js/ui/menu/menu.reel/menu.js b/js/ui/menu/menu.reel/menu.js new file mode 100755 index 00000000..aff60163 --- /dev/null +++ b/js/ui/menu/menu.reel/menu.js @@ -0,0 +1,183 @@ +/* +Copyright (c) 2012, Motorola Mobility LLC. +All Rights Reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +* Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + +* Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +* Neither the name of Motorola Mobility LLC nor the names of its + contributors may be used to endorse or promote products derived from this + software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. + */ + +var Montage = require("montage/core/core").Montage, + Component = require("montage/ui/component").Component; + +exports.Menu = Montage.create(Component, { + + _currentDocument: { + value : null + }, + + currentDocument : { + get : function() { + return this._currentDocument; + }, + set : function(value) { + if (value === this._currentDocument) { + return; + } + + this._currentDocument = value; + } + }, + + menudata: { + value: null + }, + + _active: { + value: false + }, + + active: { + get: function() { + return this._active; + }, + set: function(value) { + if(this._active !== value) { + this._active = value; + } + + if(this._active) { + document.addEventListener("mousedown", this, false); + document.addEventListener("keydown", this, true); + } else { + document.removeEventListener("mousedown", this, false); + document.removeEventListener("keydown", this, true); + this.activeEntry = null; + } + + } + }, + + _activeEntry: { + value: null + }, + + activeEntry: { + get: function() { + return this._activeEntry; + }, + set: function(value) { + if(this._activeEntry === value) return; + + if(this._activeEntry) { + this._activeEntry.element.classList.remove("selected"); + } + + this._activeEntry = value; + + if(this._activeEntry) { + this._activeEntry.element.classList.add("selected"); + } + } + }, + + prepareForDraw: { + value: function() { + this.addEventListener("headermousedown", this, false); + this.addEventListener("headermouseover", this, false); + + this.addEventListener("menuItemClick", this, false); + } + }, + + handleHeadermousedown: { + value: function(evt) { + if(!this.active) { + this.active = true; + } + + this.activeEntry = evt.detail; + } + }, + + handleHeadermouseover: { + value: function(evt) { + if(this.active) { + this.activeEntry = evt.detail; + } + } + }, + + handleMenuItemClick: { + value: function(evt) { + if(evt.detail.indexOf("-") > 0) { + this.menudata.toggleItem(evt.detail.slice(evt.detail.indexOf("-") + 1)) + } else { + NJevent(evt.detail); + } + this.active = false; + } + }, + + captureKeydown: { + value: function(evt) { + if(evt.keyCode === 27) { + this.active = false; + } + } + }, + + handleMousedown: { + value: function(evt) { + if(this.active && (this.getZIndex(evt.target) < 9000 || evt.target.id === "topMenu")) { + this.active = false; + } + } + }, + + getZIndex: { + value: function(elem) { + + var position, value, zIndex; + while (elem && elem !== document) { +// position = elem.style.position; + position = document.defaultView.getComputedStyle(elem, "").getPropertyValue("position"); + + if (position === "absolute" || position === "relative" || position === "fixed") { + // webkit returns a string for zindex value and "" if zindex is not available +// zIndex = elem.style['z-index']; + zIndex = document.defaultView.getComputedStyle(elem, "").getPropertyValue("z-index"); + value = parseInt(zIndex, 10); + if (!isNaN(value) && value !== 0) { + return value; + } + } + elem = elem.parentNode; + } + return 0; + } + } + +}); -- cgit v1.2.3