aboutsummaryrefslogtreecommitdiff
path: root/js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js')
-rw-r--r--js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js192
1 files changed, 192 insertions, 0 deletions
diff --git a/js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js b/js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js
new file mode 100644
index 00000000..0e1cf206
--- /dev/null
+++ b/js/panels/CSSPanel/ComputedStyleSubPanel.reel/ComputedStyleSubPanel.js
@@ -0,0 +1,192 @@
1/* <copyright>
2This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
3No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
4(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
5</copyright> */
6
7var Montage = require("montage/core/core").Montage,
8 Component = require("montage/ui/component").Component,
9 nj = require("js/lib/NJUtils.js").NJUtils;
10
11
12exports.ComputedStyleSubPanel = Montage.create(Component, {
13 groupDropDown: { value: null },
14 computedListEl: { value: null },
15 searchField: { value: null },
16
17 templateDidLoad : {
18 value : function() {
19 ///// Set current filter group
20 this._group = this.groupDropDown.value;
21 ///// Set up event listeners
22 this.groupDropDown.addEventListener('change', this);
23 this.searchField.addEventListener('input', this);
24 }
25 },
26 // prepareForDraw : {
27 // value: function() {
28 //
29 // }
30 // },
31 willDraw : {
32 value: function() {
33 if(this._declaration) {
34
35 var group = this.staticGroupingMap[this._group],
36 matchedInGroup, elementList;
37
38 if(this._group === 'all' && !group) {
39 group = this.staticGroupingMap['all'] = nj.toArray(this._declaration).sort();
40 }
41
42 ///// Filter group to show only the styles that match search filter
43 matchedInGroup = group.filter(function(item) {
44 return (item.indexOf(this._filter) > -1);
45 }, this);
46
47 this._elementList = matchedInGroup.map(function(propName) {
48 var propEl = nj.make('dt'),
49 valEl = nj.make('dd'),
50 contEl = nj.make('div');
51
52 propEl.appendChild(nj.textNode(propName));
53 propEl.title = propName;
54
55 valEl.appendChild(nj.textNode(this._declaration.getPropertyValue(propName)));
56 valEl.title = this._declaration.getPropertyValue(propName);
57
58 contEl.appendChild(propEl);
59 contEl.appendChild(valEl);
60
61 return contEl;
62 }, this);
63
64 /*if(matchedInGroup.length) {
65
66 } else {
67
68 }*/
69 }
70 }
71 },
72 // The draw function appends the element list to the dom
73 draw: {
74 value: function() {
75 if(this._elementList) {
76 this.clearList();
77 ///// Append style elements to the list container
78 this._elementList.forEach(function(el) {
79 this.computedListEl.appendChild(el);
80 }, this);
81 }
82 }
83 },
84 clearList : {
85 value: function() {
86 nj.empty(this.computedListEl);
87 }
88 },
89 ///// Drop down has changed values
90 handleChange : {
91 value: function(e) {
92 this._group = this.groupDropDown.value;
93 this.needsDraw = true;
94 }
95 },
96 ///// Text input has changed values
97 handleInput : {
98 value : function(e) {
99 this._filter = this.searchField.value.trim();
100 this.needsDraw = true;
101 }
102 },
103 // Publicly accessible list of computed styles
104 declaration : {
105 get: function() {
106 return this._declaration;
107 },
108 ////// Accepts a CSSStyleDeclaration object, or dom element
109 set: function(source) {
110 var declaration, styles;
111 if(source.constructor.name === 'CSSStyleDeclaration') {
112 declaration = this._declaration = source;
113 } else {
114 ///// Get computed style of passed in node
115 declaration = this._declaration = source.ownerDocument.defaultView.getComputedStyle(source);
116 }
117
118 this.needsDraw = true;
119 }
120 },
121 ///// Renders the styles for the current node
122 show : {
123 value : function() {
124 this.element.classList.remove(this._cssClasses.hide);
125 }
126 },
127 hide : {
128 value : function() {
129 this.element.classList.add(this._cssClasses.hide);
130 }
131 },
132 ///// Private
133 //// Stores the current CSSDeclaration object returned by getComputedStyle
134 //// which is needed to get property values
135 _declaration : {
136 enumerable: false,
137 value : null
138 },
139 ///// List of elements to append to style list
140 _elementList : {
141 value: null
142 },
143 ///// Group selected in drop down
144 _group : {
145 enumerable: false,
146 value : null
147 },
148 ///// Filter string entered in search input
149 _filter : {
150 enumerable: false,
151 value : ''
152 },
153 ///// CSS classes used in component
154 _cssClasses : {
155 value : {
156 hide : 'nj-css-panel-hide'
157 }
158 },
159 ///// List of css properties within specified catagories
160 staticGroupingMap : {
161 value : {
162 'all' : null,
163 'background' : [
164 'background-color', 'background-image', 'background-repeat', 'background-position',
165 'background-attachment'
166 ],
167 'summary' : [
168 'width', 'height', 'color', 'font-family', 'font-size', 'display'
169 ],
170 'dimensions' : [
171 'width', 'height', 'top', 'right', 'bottom', 'left',
172 'padding-top', 'padding-right', 'padding-bottom', 'padding-left',
173 'margin-top', 'margin-right', 'margin-bottom', 'margin-left',
174 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width'
175 ],
176 'border' : [
177 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width',
178 'border-top-color', 'border-right-color', 'border-bottom-color', 'border-left-color',
179 'border-top-style', 'border-right-style', 'border-bottom-style', 'border-left-style'
180 ],
181 'font' : [
182 'font-family', 'font-size', 'font-weight', 'font-style', 'color', 'text-transform',
183 'text-decoration', 'letter-spacing', 'word-spacing', 'line-height', 'text-align',
184 'vertical-align', 'direction'
185 ],
186 'layout' : [
187 'position', 'display', 'visibility', 'z-index', 'overflow-x', 'overflow-y',
188 'white-space', 'clip', 'float', 'clear'
189 ]
190 }
191 }
192}); \ No newline at end of file