aboutsummaryrefslogtreecommitdiff
path: root/js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js')
-rw-r--r--js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js127
1 files changed, 96 insertions, 31 deletions
diff --git a/js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js b/js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js
index 51822150..338e7e0d 100644
--- a/js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js
+++ b/js/panels/Components/ComponentsPanelBase.reel/ComponentsPanelBase.js
@@ -11,12 +11,74 @@ var Montage = require("montage/core/core").Montage,
11var treeControlModule = require("js/components/tree.reel"); 11var treeControlModule = require("js/components/tree.reel");
12var PIData = require("js/data/pi/pi-data").PiData; 12var PIData = require("js/data/pi/pi-data").PiData;
13 13
14String.prototype.capitalizeFirstChar = function() {
15 return this.charAt(0).toUpperCase() + this.slice(1);
16};
17
18
14var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component, { 19var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component, {
15 20
16 components: { 21 components: {
17 value: null 22 value: null
18 }, 23 },
19 24
25 componentsToLoad: {
26 value: null
27 },
28
29 componentsLoaded: {
30 value: 0
31 },
32
33 data2: {
34 value: {
35 "text": "styles",
36 "children": [{
37 "text": "Box Styles",
38 "children": [
39 {
40 "text": "Border-Radius",
41 "classNameBase" : "border-radius",
42 "styles" : {
43 "border-radius": "100px",
44 "border" : "1px solid #333"
45 }
46 },
47 {
48 "text": "Drop Shadow",
49 "classNameBase" : "drop-shadow",
50 "styles" : {
51 "box-shadow": "2px 2px 50px rgba(0,0,0,0.5)",
52 "border" : "1px solid #CCC"
53 }
54 },
55 {
56 "text": "Fancy Box",
57 "classNameBase" : "fancy-box",
58 "styles" : {
59 "box-shadow": "inset 0 0 0 1px #666, inset 0 0 0 2px rgba(225, 225, 225, 0.4), 0 0 20px -10px #333",
60 "border" : "1px solid #FFF",
61 "border-radius": "30px",
62 "background-color": "#7db9e8",
63 "background-image": "-webkit-linear-gradient(top, rgba(255,255,255,0.74) 0%,rgba(255,255,255,0) 100%)"
64 }
65 }]
66 }, {
67 "text": "Text Styles",
68 "children": [
69 { "text": "Italic" },
70 { "text": "Text Shadow" },
71 { "text": "Text Color" } ]
72 }, {
73 "text": "Color Styles",
74 "children": [
75 { "text": "Background Gradient" },
76 { "text": "Background Color" },
77 { "text": "Text Highlight" } ]
78 }]
79 }
80 },
81
20 _testButtonJson: { 82 _testButtonJson: {
21 value: { 83 value: {
22 "component": "button", 84 "component": "button",
@@ -42,14 +104,8 @@ var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component
42 104
43 didCreate: { 105 didCreate: {
44 value: function() { 106 value: function() {
45 this._loadComponents();
46 107
47// var req = new XMLHttpRequest(); 108 this._loadComponents();
48// req.identifier = "searchRequest";
49// req.open("GET", url);
50// req.addEventListener("load", this, false);
51// req.addEventListener("error", this, false);
52// req.send();
53 109
54 } 110 }
55 }, 111 },
@@ -61,6 +117,8 @@ var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component
61 {name: "Textfield", data: "node_modules/components-data/textfield.json"} 117 {name: "Textfield", data: "node_modules/components-data/textfield.json"}
62 ]; 118 ];
63 119
120 this.componentsToLoad = this.components.length;
121
64 // Build the PI objects for each component 122 // Build the PI objects for each component
65 for(var i = 0, component; component = this.components[i]; i++) { 123 for(var i = 0, component; component = this.components[i]; i++) {
66 var req = new XMLHttpRequest(); 124 var req = new XMLHttpRequest();
@@ -70,39 +128,44 @@ var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component
70 req.addEventListener("error", this, false); 128 req.addEventListener("error", this, false);
71 req.send(); 129 req.send();
72 130
73/* 131 }
74 var piIdentifier = component.name + "Pi"; 132
75 var piObj = []; 133 }
76 var section = {}; 134 },
135
136 handleLoad: {
137 value: function(evt) {
138 var response = JSON.parse(evt.target.responseText);
77 139
140 var component = response.component.capitalizeFirstChar();
78 141
79 section.label = component.name + " Properties"; 142 var piIdentifier = component + "Pi";
80 section.Section = []; 143 var piObj = [];
144 var section = {};
81 145
82 for(var j = 0, props; props = this._testButtonJson.properties[j]; j++) {
83 var row = {};
84 row.type = this.getControlType(props.type);
85 row.id = props.name;
86 row.prop = props.name;
87 row.defaultValue = props["default"];
88 row.label = props.name;
89 146
90 section.Section.push([row]); 147 section.label = component + " Properties";
91 } 148 section.Section = [];
92 149
93 PIData[piIdentifier] = []; 150 for(var j = 0, props; props = response.properties[j]; j++) {
94 PIData[piIdentifier].push(section); 151 var row = {};
95 */ 152 row.type = this.getControlType(props.type);
153 row.id = props.name;
154 row.prop = props.name;
155 row.defaultValue = props["default"];
156 row.label = props.name;
96 157
158 section.Section.push([row]);
97 } 159 }
98 160
99 } 161 PIData[piIdentifier] = [];
100 }, 162 PIData[piIdentifier].push(section);
101 163
102 handleLoad: { 164 this.componentsLoaded++;
103 value: function(evt) { 165
104 var response = JSON.parse(evt.target.responseText); 166 if(this.componentsLoaded === this.componentsToLoad) {
105 console.log(response); 167 console.log("all loaded");
168 }
106 169
107 } 170 }
108 }, 171 },
@@ -123,6 +186,7 @@ var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component
123 prepareForDraw: { 186 prepareForDraw: {
124 enumerable: false, 187 enumerable: false,
125 value: function() { 188 value: function() {
189
126 var treeHolderDiv = document.getElementById("comp_tree"); 190 var treeHolderDiv = document.getElementById("comp_tree");
127 var componentsTree = treeControlModule.Tree.create(); 191 var componentsTree = treeControlModule.Tree.create();
128 componentsTree.element = treeHolderDiv; 192 componentsTree.element = treeHolderDiv;
@@ -130,6 +194,7 @@ var ComponentsPanelBase = exports.ComponentsPanelBase = Montage.create(Component
130 componentsTree.needsDraw = true; 194 componentsTree.needsDraw = true;
131 195
132 this.eventManager.addEventListener( "executeAddComponent", this, false); 196 this.eventManager.addEventListener( "executeAddComponent", this, false);
197
133 } 198 }