From b89a7ee8b956c96a1dcee995ea840feddc5d4b27 Mon Sep 17 00:00:00 2001 From: Pierre Frisch Date: Thu, 22 Dec 2011 07:25:50 -0800 Subject: First commit of Ninja to ninja-internal Signed-off-by: Valerio Virgillito --- .../layout/tool-button.reel/tool-button.css | 24 +++++ .../layout/tool-button.reel/tool-button.html | 35 +++++++ .../layout/tool-button.reel/tool-button.js | 112 +++++++++++++++++++++ 3 files changed, 171 insertions(+) create mode 100644 js/components/layout/tool-button.reel/tool-button.css create mode 100644 js/components/layout/tool-button.reel/tool-button.html create mode 100644 js/components/layout/tool-button.reel/tool-button.js (limited to 'js/components/layout/tool-button.reel') diff --git a/js/components/layout/tool-button.reel/tool-button.css b/js/components/layout/tool-button.reel/tool-button.css new file mode 100644 index 00000000..46152424 --- /dev/null +++ b/js/components/layout/tool-button.reel/tool-button.css @@ -0,0 +1,24 @@ +/* + 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. +
*/ + +.buttonBackground { + height: 23px; + width: 26px; + margin: auto; +} + +.buttonSelected { + background: #B2B2B2; +} + +#toolBarButton { + border: 3px; + float: left; +} + +#toolBarButton:hover { + opacity: 1; +} diff --git a/js/components/layout/tool-button.reel/tool-button.html b/js/components/layout/tool-button.reel/tool-button.html new file mode 100644 index 00000000..81a9b927 --- /dev/null +++ b/js/components/layout/tool-button.reel/tool-button.html @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + +
+
+
+ + + diff --git a/js/components/layout/tool-button.reel/tool-button.js b/js/components/layout/tool-button.reel/tool-button.js new file mode 100644 index 00000000..509512d0 --- /dev/null +++ b/js/components/layout/tool-button.reel/tool-button.js @@ -0,0 +1,112 @@ +/* +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; +var defaultEventManager = require("montage/core/event/event-manager").defaultEventManager; + + +exports.ToolButton = Montage.create(Component, { + + button: { value: null }, + + data: { value: null }, + + _selected: { value: null }, + + selected: { + get: function() { return this._selected; }, + set: function(value) { + this._selected = value; + this.needsDraw = true; + } + }, + + _subselected: { value: 1 }, + + subselected: { + get: function() { return this._subselected; }, + set: function(value) { + + var len = value.length; + for(var i=0; i < len; i++) { + if(value[i]) { + this._subselected = i; + this.needsDraw = true; + } + } + } + }, + + _currentSubSelected: { value: 0}, + + prepareForDraw: { + enumerable: false, + value: function() { + this.element.title = this.data.toolTip; + this.element.addEventListener("mousedown", this, false); + this.element.addEventListener("dblclick", this, false); + + Object.defineBinding(this, "selected", { + boundObject: this.data, + boundObjectPropertyPath: "selected", + oneway: false + }); + + if(this.data.container) { + this.element.title = this.data.subtools[this._subselected].toolTip; + Object.defineBinding(this, "subselected", { + boundObject: this.data.subtools, + boundObjectPropertyPath: "selected", + oneway: true + }); + } + } + }, + + draw: { + enumerable: false, + value: function() { + var buttonid; + + if(this.data.container) { + buttonid = this.data.subtools[this._subselected].id; + this.element.title = this.data.subtools[this._subselected].toolTip; + this.button.classList.remove( this.data.subtools[this._currentSubSelected].id + "Unpressed" ); + this.button.classList.remove( this.data.subtools[this._currentSubSelected].id + "Pressed" ); + this._currentSubSelected = this._subselected; + } else { + buttonid = this.data.id; + } + + if(this._selected) { + this.element.classList.add( "buttonSelected" ); + this.button.classList.remove( buttonid + "Unpressed" ); + this.button.classList.add( buttonid + "Pressed" ); + } else { + this.element.classList.remove( "buttonSelected" ); + this.button.classList.remove( buttonid + "Pressed" ); + this.button.classList.add( buttonid + "Unpressed" ); + } + } + }, + + handleMousedown: { + value: function(event) { + if(!this._selected) { + NJevent("selectTool", this.data); + } + } + }, + + handleDblclick: { + value: function(event) { + NJevent("toolDoubleClick", this.data); + } + } + + +}); \ No newline at end of file -- cgit v1.2.3