|
1 | 1 | <dom-module id="mwc-layout"> |
2 | 2 |
|
| 3 | + <template> |
3 | 4 | <style> |
4 | | - :host { |
5 | | - display: none!important; |
6 | | - } |
7 | | - |
| 5 | +:host { |
| 6 | + display: none!important; |
| 7 | +} |
| 8 | + |
8 | 9 | :host([active]) { |
9 | | - display: block!important; |
| 10 | + display: block!important; |
10 | 11 | } |
11 | 12 | </style> |
12 | 13 |
|
13 | | - <template> |
14 | | - <content class="mwc-layout" select="*"></content> |
15 | | - </template> |
16 | | - |
17 | | - <script> |
18 | | - // HTMLImports.whenReady(function() { |
19 | | - Polymer({ |
20 | | - |
21 | | - activeChange: function(newValue, oldValue) { |
22 | | - if (newValue === false && oldValue === true) { |
23 | | - var region = Object.keys(this.opt); |
24 | | - |
25 | | - for (var A = 0; A < region.length; A++) { |
26 | | - var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
27 | | - |
28 | | - for (Z = 0; Z < element.length; Z++) { |
29 | | - element[Z].innerHTML = ""; |
30 | | - } |
31 | | - } |
32 | | - } |
33 | | - }, |
34 | | - |
35 | | - is: "mwc-layout", |
36 | | - |
37 | | - properties: { |
38 | | - active: { |
39 | | - notify: true, |
40 | | - observer: "activeChange", |
41 | | - reflectToAttribute: true, |
42 | | - type: Boolean, |
43 | | - value: false |
44 | | - }, |
45 | | - opt: { |
46 | | - type: Object |
47 | | - } |
48 | | - }, |
49 | | - |
50 | | - render: function(opt) { |
51 | | - var region = Object.keys(opt); |
52 | | - |
53 | | - for (var A = 0; A < region.length; A++) { |
54 | | - if (typeof(opt[region[A]]) === "object") { |
55 | | - var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
56 | | - |
57 | | - for (Z = 0; Z < element.length; Z++) { |
58 | | - element[Z].innerHTML = ""; |
59 | | - |
60 | | - Polymer.dom(element[Z]).appendChild(opt[region[A]]); |
61 | | - } |
62 | | - } else { |
63 | | - if (document.createElement(opt[region[A]]).constructor !== HTMLElement) { |
64 | | - var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
65 | | - |
66 | | - for (Z = 0; Z < element.length; Z++) { |
67 | | - element[Z].innerHTML = ""; |
68 | | - |
69 | | - Polymer.dom(element[Z]).appendChild(document.createElement(opt[region[A]])); |
70 | | - } |
71 | | - } else { |
72 | | - console.log(opt[region[A]] + " not registered"); |
73 | | - } |
74 | | - } |
75 | | - } |
76 | | - |
77 | | - this.opt = opt; |
| 14 | + |
| 15 | + <content class="mwc-layout" select="*"></content> |
| 16 | + </template> |
| 17 | + |
| 18 | + <script> |
| 19 | +// HTMLImports.whenReady(function() { |
| 20 | +Polymer({ |
| 21 | + |
| 22 | + activeChange: function(newValue, oldValue) { |
| 23 | + if (newValue === false && oldValue === true) { |
| 24 | + var region = Object.keys(this.opt); |
| 25 | + |
| 26 | + for (var A = 0; A < region.length; A++) { |
| 27 | + var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
| 28 | + |
| 29 | + for (Z = 0; Z < element.length; Z++) { |
| 30 | + element[Z].innerHTML = ""; |
| 31 | + } |
| 32 | + } |
| 33 | + } |
| 34 | + }, |
| 35 | + |
| 36 | + is: "mwc-layout", |
| 37 | + |
| 38 | + properties: { |
| 39 | + active: { |
| 40 | + notify: true, |
| 41 | + observer: "activeChange", |
| 42 | + reflectToAttribute: true, |
| 43 | + type: Boolean, |
| 44 | + value: false |
| 45 | + }, |
| 46 | + opt: { |
| 47 | + type: Object |
| 48 | + } |
| 49 | + }, |
| 50 | + |
| 51 | + render: function(opt) { |
| 52 | + var region = Object.keys(opt); |
| 53 | + |
| 54 | + for (var A = 0; A < region.length; A++) { |
| 55 | + if (typeof(opt[region[A]]) === "object") { |
| 56 | + var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
| 57 | + |
| 58 | + for (Z = 0; Z < element.length; Z++) { |
| 59 | + element[Z].innerHTML = ""; |
| 60 | + |
| 61 | + Polymer.dom(element[Z]).appendChild(opt[region[A]]); |
| 62 | + } |
| 63 | + } else { |
| 64 | + if (document.createElement(opt[region[A]]).constructor !== HTMLElement) { |
| 65 | + var element = this.querySelectorAll('*[region="' + region[A] + '"]'); |
| 66 | + |
| 67 | + for (Z = 0; Z < element.length; Z++) { |
| 68 | + element[Z].innerHTML = ""; |
| 69 | + |
| 70 | + Polymer.dom(element[Z]).appendChild(document.createElement(opt[region[A]])); |
| 71 | + } |
| 72 | + } else { |
| 73 | + console.log(opt[region[A]] + " not registered"); |
78 | 74 | } |
| 75 | + } |
| 76 | + } |
79 | 77 |
|
80 | | - }); |
81 | | - // }); |
82 | | - </script> |
| 78 | + this.opt = opt; |
| 79 | + } |
| 80 | + |
| 81 | +}); |
| 82 | +// }); |
| 83 | + </script> |
83 | 84 |
|
84 | 85 | </dom-module> |
85 | 86 |
|
86 | 87 | <script> |
87 | 88 | var PolymerLayout = function() { |
88 | | - this.currentLayout = null; |
| 89 | + this.currentLayout = null; |
89 | 90 | }; |
90 | 91 |
|
91 | 92 | // layout[String] |
92 | 93 | // opt[Object] one-level deep |
93 | 94 | // forceRender[Boolean] |
94 | 95 |
|
95 | 96 | PolymerLayout.prototype.render = function(layout, opt, forceRender) { |
96 | | - if (document.querySelector('mwc-layout[id="' + layout + '"]')) { |
97 | | - if (this.currentLayout != layout || forceRender) { |
98 | | - if (this.currentLayout) { |
99 | | - document.querySelector('mwc-layout[id="' + this.currentLayout + '"]').active = false |
100 | | - } |
| 97 | + if (document.querySelector('mwc-layout[id="' + layout + '"]')) { |
| 98 | + if (this.currentLayout != layout || forceRender) { |
| 99 | + if (this.currentLayout) { |
| 100 | + document.querySelector('mwc-layout[id="' + this.currentLayout + '"]').active = false |
| 101 | + } |
101 | 102 |
|
102 | | - document.querySelector('mwc-layout[id="' + layout + '"]').render(Object.prototype.toString.call(opt) == "[object Object]" ? opt : {}); |
| 103 | + document.querySelector('mwc-layout[id="' + layout + '"]').render(Object.prototype.toString.call(opt) == "[object Object]" ? opt : {}); |
103 | 104 |
|
104 | | - document.querySelector('mwc-layout[id="' + layout + '"]').active = true; |
| 105 | + document.querySelector('mwc-layout[id="' + layout + '"]').active = true; |
105 | 106 |
|
106 | | - this.currentLayout = layout; |
107 | | - } |
| 107 | + this.currentLayout = layout; |
108 | 108 | } |
| 109 | + } |
109 | 110 | }; |
110 | 111 |
|
111 | 112 | mwcLayout = new PolymerLayout(); |
|
0 commit comments