aboutsummaryrefslogtreecommitdiff
path: root/js/components/menu/menu-entry.reel
diff options
context:
space:
mode:
authorAnanya Sen2012-06-19 11:00:49 -0700
committerAnanya Sen2012-06-19 11:00:49 -0700
commitf1d8401aeb84e0eb0680caf72878dae26fd78a37 (patch)
tree31771ccaf3d1e2ddf01fa9605438d20be0d155d7 /js/components/menu/menu-entry.reel
parent9ea2610cec6569e7b7d5268b6c65bbf94c4753e5 (diff)
parent483ad57efcd6475776f580c3af5b60e6deeaf781 (diff)
downloadninja-f1d8401aeb84e0eb0680caf72878dae26fd78a37.tar.gz
Merge branch 'refs/heads/ninja-internal-master' into cut-copy-paste
Diffstat (limited to 'js/components/menu/menu-entry.reel')
-rwxr-xr-xjs/components/menu/menu-entry.reel/menu-entry.html6
-rwxr-xr-xjs/components/menu/menu-entry.reel/menu-entry.js49
2 files changed, 48 insertions, 7 deletions
diff --git a/js/components/menu/menu-entry.reel/menu-entry.html b/js/components/menu/menu-entry.reel/menu-entry.html
index f64de3cb..7310545f 100755
--- a/js/components/menu/menu-entry.reel/menu-entry.html
+++ b/js/components/menu/menu-entry.reel/menu-entry.html
@@ -24,8 +24,10 @@
24 "repetition": { 24 "repetition": {
25 "prototype": "montage/ui/repetition.reel", 25 "prototype": "montage/ui/repetition.reel",
26 "properties": { 26 "properties": {
27 "element": { "#": "subEntries" }, 27 "element": { "#": "subEntries" }
28 "contentController": {"@": "entriesController"} 28 },
29 "bindings": {
30 "objects": {"<-": "@owner.data.entries"}
29 } 31 }
30 }, 32 },
31 33
diff --git a/js/components/menu/menu-entry.reel/menu-entry.js b/js/components/menu/menu-entry.reel/menu-entry.js
index 1cea19b3..ae3469c6 100755
--- a/js/components/menu/menu-entry.reel/menu-entry.js
+++ b/js/components/menu/menu-entry.reel/menu-entry.js
@@ -8,18 +8,54 @@ var Montage = require("montage/core/core").Montage;
8var Component = require("montage/ui/component").Component; 8var Component = require("montage/ui/component").Component;
9 9
10exports.MenuEntry = Montage.create(Component, { 10exports.MenuEntry = Montage.create(Component, {
11 topHeader: { value: null }, 11 topHeader: {
12 topHeaderText: { value: null }, 12 value: null,
13 serializable: true
14 },
15
16 topHeaderText: {
17 value: null,
18 serializable: true
19 },
20
21 subEntries: {
22 value: null,
23 serializable: true
24 },
13 25
14 // Reference to the parent Menu component 26 // Reference to the parent Menu component
15 _menu: { 27 _menu: {
16 value: null 28 value: null
17 }, 29 },
18 30
19 data: { 31 menu: {
32 get: function() {
33 return this._menu;
34 },
35 set: function(value) {
36 if(value !== this._menu) {
37 this._menu = value;
38 }
39 },
40 serializable: true
41 },
42
43 _data: {
20 value: null 44 value: null
21 }, 45 },
22 46
47 data: {
48 get: function() {
49 return this._data;
50 },
51 set: function(value) {
52 if(this._data !== value) {
53 this._data = value;
54 }
55 },
56 serializable: true
57 },
58
23 select: { 59 select: {
24 value: function() { 60 value: function() {
25 this.element.classList.add("selected"); 61 this.element.classList.add("selected");
@@ -49,13 +85,16 @@ exports.MenuEntry = Montage.create(Component, {
49 85
50 captureMousedown: { 86 captureMousedown: {
51 value: function(event) { 87 value: function(event) {
52 this._menu.toggleActivation(this); 88 // TODO: Hack! Rework this!
89 this.parentComponent.ownerComponent.toggleActivation(this);
90// this._menu.toggleActivation(this);
53 } 91 }
54 }, 92 },
55 93
56 handleMouseover: { 94 handleMouseover: {
57 value: function(event) { 95 value: function(event) {
58 this._menu.activeEntry = this; 96 this.parentComponent.ownerComponent.activeEntry = this;
97// this._menu.activeEntry = this;
59 } 98 }
60 }, 99 },
61 100