@design.estate/dees-wcctools 1.0.77

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,402 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { DeesElement, property, html, customElement, state } from '@design.estate/dees-element';
11
+ import { WccDashboard } from './wcc-dashboard.js';
12
+ let environment = 'native';
13
+ export const setEnvironment = (envArg) => {
14
+ environment = envArg;
15
+ };
16
+ export let WccProperties = class WccProperties extends DeesElement {
17
+ constructor() {
18
+ super(...arguments);
19
+ this.selectedViewport = 'native';
20
+ this.selectedTheme = 'dark';
21
+ this.warning = null;
22
+ this.propertyContent = [];
23
+ }
24
+ render() {
25
+ return html `
26
+ <style>
27
+ :host {
28
+ font-family: 'Roboto', sans-serif;
29
+ box-sizing: border-box;
30
+ position: absolute;
31
+ left: 200px;
32
+ height: 100px;
33
+ bottom: 0px;
34
+ right: 0px;
35
+ overflow: hidden;
36
+ background: #111;
37
+ color: #fff;
38
+ }
39
+ .grid {
40
+ display: grid;
41
+ grid-template-columns: auto 150px 300px 70px;
42
+ }
43
+ .properties {
44
+ border-right: 1px solid #999;
45
+ height: 100px;
46
+ overflow-y: auto;
47
+ display: grid;
48
+ grid-template-columns: 33% 33% 33%;
49
+ }
50
+
51
+ .material-symbols-outlined {
52
+ font-family: 'Material Symbols Outlined';
53
+ font-weight: normal;
54
+ font-style: normal;
55
+ font-size: 24px; /* Preferred icon size */
56
+ display: inline-block;
57
+ line-height: 1;
58
+ text-transform: none;
59
+ letter-spacing: normal;
60
+ word-wrap: normal;
61
+ white-space: nowrap;
62
+ direction: ltr;
63
+ font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48;
64
+ }
65
+
66
+ .properties .property {
67
+ padding: 5px;
68
+ background: #444;
69
+ border: 1px solid #000;
70
+ }
71
+
72
+ .properties input,
73
+ .properties select {
74
+ display: block;
75
+ width: 100%;
76
+ background: #333;
77
+ border: none;
78
+ color: #fff;
79
+ }
80
+
81
+ .viewportSelector,
82
+ .themeSelector {
83
+ user-select: none;
84
+ border-right: 1px solid #999;
85
+ }
86
+ .selectorButtons2 {
87
+ display: grid;
88
+ grid-template-columns: 50% 50%;
89
+ }
90
+ .selectorButtons4 {
91
+ display: grid;
92
+ grid-template-columns: 25% 25% 25% 25%;
93
+ }
94
+ .button {
95
+ padding: 10px;
96
+ text-align: center;
97
+ border: 1px solid #000;
98
+ transition: all 0.2s;
99
+ }
100
+ .button:hover {
101
+ cursor: pointer;
102
+ color: #333;
103
+ background: #fff;
104
+ }
105
+
106
+ .button.selected {
107
+ background: #455a64;
108
+ }
109
+
110
+ .button.selected:hover {
111
+ cursor: pointer;
112
+ color: #ffffff;
113
+ background: #455a64;
114
+ }
115
+
116
+ .panelheading {
117
+ padding: 5px;
118
+ font-weight: bold;
119
+ background: #444;
120
+ border: 1px solid #000;
121
+ }
122
+ .docs {
123
+ text-align: center;
124
+ line-height: 100px;
125
+ text-transform: uppercase;
126
+ }
127
+
128
+ .docs:hover {
129
+ cursor: pointer;
130
+ color: #333;
131
+ background: #fff;
132
+ }
133
+
134
+ .warning {
135
+ position: absolute;
136
+ background: #222;
137
+ color: #CCC;
138
+ top: 0px;
139
+ bottom: 0px;
140
+ left: 0px;
141
+ right: 520px;
142
+ text-align: center;
143
+ padding: 35px;
144
+ font-size: 25px;
145
+ }
146
+ </style>
147
+ <div class="grid">
148
+ <div class="properties">
149
+ <div class="panelheading">Properties</div>
150
+ ${this.propertyContent}
151
+ </div>
152
+ <div class="themeSelector">
153
+ <div class="panelheading">Theme</div>
154
+ <div class="selectorButtons2">
155
+ <div
156
+ class="button ${this.selectedTheme === 'dark' ? 'selected' : null}"
157
+ @click=${() => {
158
+ this.selectTheme('dark');
159
+ }}
160
+ >
161
+ Dark<br /><i class="material-symbols-outlined">brightness_3</i>
162
+ </div>
163
+ <div
164
+ class="button ${this.selectedTheme === 'bright' ? 'selected' : null}"
165
+ @click=${() => {
166
+ this.selectTheme('bright');
167
+ }}
168
+ >
169
+ Bright<br /><i class="material-symbols-outlined">flare</i>
170
+ </div>
171
+ </div>
172
+ </div>
173
+ <div class="viewportSelector">
174
+ <div class="panelheading">Viewport</div>
175
+ <div class="selectorButtons4">
176
+ <div
177
+ class="button ${this.selectedViewport === 'phone' ? 'selected' : null}"
178
+ @click=${() => {
179
+ this.selectViewport('phone');
180
+ }}
181
+ >
182
+ Phone<br /><i class="material-symbols-outlined">smartphone</i>
183
+ </div>
184
+ <div
185
+ class="button ${this.selectedViewport === 'phablet' ? 'selected' : null}"
186
+ @click=${() => {
187
+ this.selectViewport('phablet');
188
+ }}
189
+ >
190
+ Phablet<br /><i class="material-symbols-outlined">smartphone</i>
191
+ </div>
192
+ <div
193
+ class="button ${this.selectedViewport === 'tablet' ? 'selected' : null}"
194
+ @click=${() => {
195
+ this.selectViewport('tablet');
196
+ }}
197
+ >
198
+ Tablet<br /><i class="material-symbols-outlined">tablet</i>
199
+ </div>
200
+ <div
201
+ class="button ${this.selectedViewport === 'desktop' ||
202
+ this.selectedViewport === 'native'
203
+ ? 'selected'
204
+ : null}"
205
+ @click=${() => {
206
+ this.selectViewport('native');
207
+ }}
208
+ >
209
+ Desktop<br /><i class="material-symbols-outlined">desktop_windows</i>
210
+ </div>
211
+ </div>
212
+ </div>
213
+ <div class="docs">Docs</div>
214
+ </div>
215
+ ${this.warning ? html `<div class="warning">${this.warning}</div>` : null}
216
+ `;
217
+ }
218
+ async createProperties() {
219
+ console.log('creating properties for:');
220
+ console.log(this.selectedItem);
221
+ const isEnumeration = (propertyArg) => {
222
+ const keys = Object.keys(propertyArg.type);
223
+ const values = [];
224
+ for (const key of keys) {
225
+ let value = propertyArg.type[key];
226
+ if (typeof value === 'number') {
227
+ value = value.toString();
228
+ }
229
+ values.push(value);
230
+ }
231
+ for (const key of keys) {
232
+ if (values.indexOf(key) < 0) {
233
+ return false;
234
+ }
235
+ }
236
+ return true;
237
+ };
238
+ const getEnumValues = (propertyArg) => {
239
+ console.log(JSON.stringify(propertyArg));
240
+ const enumValues = [];
241
+ Object.keys(propertyArg.type).forEach((valueArg) => {
242
+ enumValues.push(valueArg);
243
+ });
244
+ return enumValues;
245
+ };
246
+ const determinePropertyType = async (propertyArg) => {
247
+ const typeName = propertyArg.type.name;
248
+ if (typeName) {
249
+ return typeName;
250
+ }
251
+ else {
252
+ return Array.isArray(propertyArg)
253
+ ? 'Array'
254
+ : isEnumeration(propertyArg)
255
+ ? 'Enum'
256
+ : 'Object';
257
+ }
258
+ };
259
+ if (this.selectedItem && this.selectedItem.demo) {
260
+ console.log(`Got Dees-Element for property evaluation.`);
261
+ const anonItem = this.selectedItem;
262
+ if (!anonItem) {
263
+ this.warning = 'no element selected';
264
+ return;
265
+ }
266
+ console.log(anonItem.elementProperties);
267
+ const wccFrame = await this.dashboardRef.wccFrame;
268
+ let firstFoundInstantiatedElement;
269
+ for (const element of Array.from((await wccFrame.getViewportElement()).children)) {
270
+ if (element instanceof this.selectedItem) {
271
+ firstFoundInstantiatedElement = element;
272
+ break;
273
+ }
274
+ }
275
+ if (!firstFoundInstantiatedElement) {
276
+ this.warning = `no first instantiated element found for >>${anonItem.name}<<`;
277
+ return;
278
+ }
279
+ const classProperties = anonItem.elementProperties;
280
+ if (!classProperties) {
281
+ this.warning = `selected element >>${anonItem.name}<< does not expose element properties`;
282
+ return;
283
+ }
284
+ this.warning = null;
285
+ const propertyArray = [];
286
+ for (const key of classProperties.keys()) {
287
+ if (key === 'goBright' || key === 'domtools') {
288
+ continue;
289
+ }
290
+ const property = classProperties.get(key);
291
+ const propertyTypeString = await determinePropertyType(property);
292
+ propertyArray.push(html `
293
+ <div class="property">
294
+ ${key} / ${propertyTypeString}<br />
295
+ ${(() => {
296
+ switch (propertyTypeString) {
297
+ case 'Boolean':
298
+ return html `<input
299
+ type="checkbox"
300
+ ?checked=${firstFoundInstantiatedElement[key]}
301
+ @input="${(eventArg) => {
302
+ firstFoundInstantiatedElement[key] = eventArg.target.checked;
303
+ }}"
304
+ />`;
305
+ case 'String':
306
+ return html `<input
307
+ type="text"
308
+ value=${firstFoundInstantiatedElement[key]}
309
+ @input="${(eventArg) => {
310
+ firstFoundInstantiatedElement[key] = eventArg.target.value;
311
+ }}"
312
+ />`;
313
+ case 'Number':
314
+ return html `<input
315
+ type="number"
316
+ value=${firstFoundInstantiatedElement[key]}
317
+ @input="${(eventArg) => {
318
+ firstFoundInstantiatedElement[key] = eventArg.target.value;
319
+ }}"
320
+ />`;
321
+ case 'Enum':
322
+ const enumValues = getEnumValues(property);
323
+ return html `<select
324
+ @change="${(eventArg) => {
325
+ firstFoundInstantiatedElement[key] = eventArg.target.value;
326
+ }}"
327
+ >
328
+ ${enumValues.map((valueArg) => {
329
+ return html `
330
+ <option
331
+ ?selected=${valueArg === firstFoundInstantiatedElement[key] ? true : false}
332
+ name="${valueArg}"
333
+ >
334
+ ${valueArg}
335
+ </option>
336
+ `;
337
+ })}
338
+ </select>`;
339
+ }
340
+ })()}
341
+ </div>
342
+ `);
343
+ }
344
+ this.propertyContent = propertyArray;
345
+ }
346
+ else {
347
+ console.log(`Cannot extract properties of ${this.selectedItem?.name}`);
348
+ this.warning = `You selected a page.`;
349
+ return null;
350
+ }
351
+ }
352
+ selectTheme(themeArg) {
353
+ this.selectedTheme = themeArg;
354
+ this.dispatchEvent(new CustomEvent('selectedTheme', {
355
+ detail: themeArg,
356
+ }));
357
+ console.log(this.dashboardRef.selectedType);
358
+ this.dashboardRef.buildUrl();
359
+ }
360
+ async scheduleUpdate() {
361
+ await this.createProperties();
362
+ super.scheduleUpdate();
363
+ }
364
+ selectViewport(viewport) {
365
+ this.selectedViewport = viewport;
366
+ setEnvironment(viewport);
367
+ this.dispatchEvent(new CustomEvent('selectedViewport', {
368
+ detail: viewport,
369
+ }));
370
+ this.dashboardRef.buildUrl();
371
+ }
372
+ };
373
+ __decorate([
374
+ property({
375
+ type: WccDashboard
376
+ }),
377
+ __metadata("design:type", WccDashboard)
378
+ ], WccProperties.prototype, "dashboardRef", void 0);
379
+ __decorate([
380
+ property(),
381
+ __metadata("design:type", Object)
382
+ ], WccProperties.prototype, "selectedItem", void 0);
383
+ __decorate([
384
+ property(),
385
+ __metadata("design:type", String)
386
+ ], WccProperties.prototype, "selectedViewport", void 0);
387
+ __decorate([
388
+ property(),
389
+ __metadata("design:type", String)
390
+ ], WccProperties.prototype, "selectedTheme", void 0);
391
+ __decorate([
392
+ property(),
393
+ __metadata("design:type", String)
394
+ ], WccProperties.prototype, "warning", void 0);
395
+ __decorate([
396
+ state(),
397
+ __metadata("design:type", Array)
398
+ ], WccProperties.prototype, "propertyContent", void 0);
399
+ WccProperties = __decorate([
400
+ customElement('wcc-properties')
401
+ ], WccProperties);
402
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wcc-properties.js","sourceRoot":"","sources":["../../ts_web/elements/wcc-properties.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { DeesElement, type TemplateResult } from '@design.estate/dees-element';
2
+ import { WccDashboard } from './wcc-dashboard.js';
3
+ export type TElementType = 'element' | 'page';
4
+ export declare class WccSidebar extends DeesElement {
5
+ websites: string[];
6
+ selectedItem: DeesElement | (() => TemplateResult);
7
+ selectedType: TElementType;
8
+ dashboardRef: WccDashboard;
9
+ render(): TemplateResult;
10
+ selectItem(typeArg: TElementType, itemNameArg: string, itemArg: (() => TemplateResult) | DeesElement): void;
11
+ }
@@ -0,0 +1,201 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import * as plugins from '../wcctools.plugins.js';
11
+ import { DeesElement, property, html, customElement } from '@design.estate/dees-element';
12
+ import { WccDashboard } from './wcc-dashboard.js';
13
+ export let WccSidebar = class WccSidebar extends DeesElement {
14
+ constructor() {
15
+ super(...arguments);
16
+ this.websites = [];
17
+ }
18
+ render() {
19
+ return html `
20
+ <link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet" />
21
+ <style>
22
+ :host {
23
+ display: block;
24
+ border-right: 1px solid #999;
25
+ font-family: 'Roboto', sans-serif;
26
+ box-sizing: border-box;
27
+ position: absolute;
28
+ left: 0px;
29
+ width: 200px;
30
+ top: 0px;
31
+ bottom: 0px;
32
+ overflow-y: scroll;
33
+ overflow-x: hidden;
34
+ background: #222;
35
+ color: #fff;
36
+ padding: 5px;
37
+ }
38
+
39
+ .material-symbols-outlined {
40
+ font-family: 'Material Symbols Outlined';
41
+ font-weight: normal;
42
+ font-style: normal;
43
+ font-size: 24px; /* Preferred icon size */
44
+ display: inline-block;
45
+ line-height: 1;
46
+ text-transform: none;
47
+ letter-spacing: normal;
48
+ word-wrap: normal;
49
+ white-space: nowrap;
50
+ direction: ltr;
51
+ font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48;
52
+ }
53
+
54
+ .heading {
55
+ font-size: 24px;
56
+ text-align: center;
57
+ margin: 20px 5px 5px 5px;
58
+ }
59
+
60
+ .heading a {
61
+ text-decoration: none;
62
+ color: #fff;
63
+ }
64
+
65
+ .subheading {
66
+ text-align: center;
67
+ }
68
+ .selectOption {
69
+ position: relative;
70
+ line-height: 24px;
71
+ padding: 5px;
72
+ transition: all 0.2s;
73
+ display: grid;
74
+ grid-template-columns: 28px auto;
75
+ }
76
+ .selectOption:hover {
77
+ cursor: pointer;
78
+ padding: 5px;
79
+ color: #333;
80
+ background: #fff;
81
+ }
82
+
83
+ .selectOption.selected {
84
+ background: #455A64;;
85
+ }
86
+
87
+ .selectOption.selected:hover {
88
+ cursor: pointer;
89
+ color: #ffffff;
90
+ background: #455A64;
91
+ }
92
+
93
+ .selectOption .material-symbols-outlined {
94
+ color: #666;
95
+ display: block;
96
+ transition: all 0.2s;
97
+ }
98
+
99
+ .selectOption.selected .material-symbols-outlined {
100
+ color: #000;
101
+ }
102
+
103
+ .selectOption .text {
104
+ display: block;
105
+ word-wrap: break-word;
106
+ word-break: break-all;
107
+ max-width: 100%;
108
+ }
109
+
110
+
111
+ </style>
112
+ <div class="heading">
113
+ <a href="https://gitlab.com/designestate/dees-wcctools" target="_blank">wcctools</a>
114
+ </div>
115
+ <div class="subheading">
116
+ by Lossless GmbH
117
+ </div>
118
+ <div class="menu">
119
+ <h3>Live Websites</h3>
120
+ ${this.websites.map(website => {
121
+ return html `<div class="selectOption"><i class="material-symbols-outlined">ondemand_video</i><div class="text">${website}</div></div>`;
122
+ })}
123
+ <h3>Pages</h3>
124
+ ${(() => {
125
+ const pages = Object.keys(this.dashboardRef.pages);
126
+ return pages.map(pageName => {
127
+ const item = this.dashboardRef.pages[pageName];
128
+ return html `
129
+ <div
130
+ class="selectOption ${this.selectedItem === item ? 'selected' : null}"
131
+ @click=${async () => {
132
+ const domtools = await plugins.deesDomtools.DomTools.setupDomTools();
133
+ this.selectItem('page', pageName, item);
134
+ }}
135
+ >
136
+ <i class="material-symbols-outlined">insert_drive_file</i>
137
+ <div class="text">${pageName}</div>
138
+ </div>
139
+ `;
140
+ });
141
+ })()}
142
+ <h3>Elements</h3>
143
+ ${(() => {
144
+ const elements = Object.keys(this.dashboardRef.elements);
145
+ return elements.map(elementName => {
146
+ const item = this.dashboardRef.elements[elementName];
147
+ return html `
148
+ <div
149
+ class="selectOption ${this.selectedItem === item ? 'selected' : null}"
150
+ @click=${async () => {
151
+ const domtools = await plugins.deesDomtools.DomTools.setupDomTools();
152
+ this.selectItem('element', elementName, item);
153
+ }}
154
+ >
155
+ <i class="material-symbols-outlined">featured_video</i>
156
+ <div class="text">${elementName}</div>
157
+ </div>
158
+ `;
159
+ });
160
+ })()}
161
+ </menu>
162
+ `;
163
+ }
164
+ selectItem(typeArg, itemNameArg, itemArg) {
165
+ console.log('selected item');
166
+ console.log(itemNameArg);
167
+ console.log(itemArg);
168
+ this.selectedItem = itemArg;
169
+ this.selectedType = typeArg;
170
+ this.dispatchEvent(new CustomEvent('selectedType', {
171
+ detail: typeArg
172
+ }));
173
+ this.dispatchEvent(new CustomEvent('selectedItemName', {
174
+ detail: itemNameArg
175
+ }));
176
+ this.dispatchEvent(new CustomEvent('selectedItem', {
177
+ detail: itemArg
178
+ }));
179
+ this.dashboardRef.buildUrl();
180
+ }
181
+ };
182
+ __decorate([
183
+ property({ type: Array }),
184
+ __metadata("design:type", Array)
185
+ ], WccSidebar.prototype, "websites", void 0);
186
+ __decorate([
187
+ property({ attribute: false }),
188
+ __metadata("design:type", Object)
189
+ ], WccSidebar.prototype, "selectedItem", void 0);
190
+ __decorate([
191
+ property({ attribute: false }),
192
+ __metadata("design:type", String)
193
+ ], WccSidebar.prototype, "selectedType", void 0);
194
+ __decorate([
195
+ property(),
196
+ __metadata("design:type", WccDashboard)
197
+ ], WccSidebar.prototype, "dashboardRef", void 0);
198
+ WccSidebar = __decorate([
199
+ customElement('wcc-sidebar')
200
+ ], WccSidebar);
201
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2NjLXNpZGViYXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90c193ZWIvZWxlbWVudHMvd2NjLXNpZGViYXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSx3QkFBd0IsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUF1QixNQUFNLDZCQUE2QixDQUFDO0FBQzlHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUszQyxXQUFNLFVBQVUsR0FBaEIsTUFBTSxVQUFXLFNBQVEsV0FBVztJQUFwQzs7UUFFRSxhQUFRLEdBQWEsRUFBRSxDQUFDO0lBc0xqQyxDQUFDO0lBM0tRLE1BQU07UUFDWCxPQUFPLElBQUksQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7VUFxR0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDNUIsT0FBTyxJQUFJLENBQUEsc0dBQXNHLE9BQU8sY0FBYyxDQUFDO1FBQ3pJLENBQUMsQ0FBQzs7VUFFQSxDQUFDLEdBQUcsRUFBRTtZQUNOLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNuRCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUU7Z0JBQzFCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUMvQyxPQUFPLElBQUksQ0FBQTs7c0NBRWUsSUFBSSxDQUFDLFlBQVksS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLFVBQVUs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
@@ -0,0 +1,7 @@
1
+ import { LitElement, type TemplateResult } from 'lit';
2
+ declare const setupWccTools: (elementsArg?: {
3
+ [key: string]: LitElement;
4
+ }, pagesArg?: {
5
+ [key: string]: () => TemplateResult;
6
+ }) => void;
7
+ export { setupWccTools };
@@ -0,0 +1,16 @@
1
+ import { WccDashboard } from './elements/wcc-dashboard.js';
2
+ import { LitElement } from 'lit';
3
+ const setupWccTools = (elementsArg, pagesArg) => {
4
+ let hasRun = false;
5
+ const runWccToolsSetup = async () => {
6
+ if (document.readyState === 'complete' && !hasRun) {
7
+ hasRun = true;
8
+ const wccTools = new WccDashboard(elementsArg, pagesArg);
9
+ document.querySelector('body').append(wccTools);
10
+ }
11
+ };
12
+ document.addEventListener('readystatechange', runWccToolsSetup);
13
+ runWccToolsSetup();
14
+ };
15
+ export { setupWccTools };
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90c193ZWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNELE9BQU8sRUFBRSxVQUFVLEVBQXVCLE1BQU0sS0FBSyxDQUFDO0FBRXRELE1BQU0sYUFBYSxHQUFHLENBQUMsV0FBMkMsRUFBRSxRQUFrRCxFQUFFLEVBQUU7SUFDeEgsSUFBSSxNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ25CLE1BQU0sZ0JBQWdCLEdBQUcsS0FBSyxJQUFJLEVBQUU7UUFDbEMsSUFBSSxRQUFRLENBQUMsVUFBVSxLQUFLLFVBQVUsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNqRCxNQUFNLEdBQUcsSUFBSSxDQUFDO1lBQ2QsTUFBTSxRQUFRLEdBQUcsSUFBSSxZQUFZLENBQUMsV0FBa0IsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUNoRSxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUNqRDtJQUNILENBQUMsQ0FBQztJQUNGLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ2hFLGdCQUFnQixFQUFFLENBQUM7QUFDckIsQ0FBQyxDQUFDO0FBRUYsT0FBTyxFQUNMLGFBQWEsRUFDZCxDQUFDIn0=
@@ -0,0 +1,4 @@
1
+ import * as smartdelay from '@push.rocks/smartdelay';
2
+ export { smartdelay };
3
+ import * as deesDomtools from '@design.estate/dees-domtools';
4
+ export { deesDomtools };
@@ -0,0 +1,5 @@
1
+ import * as smartdelay from '@push.rocks/smartdelay';
2
+ export { smartdelay };
3
+ import * as deesDomtools from '@design.estate/dees-domtools';
4
+ export { deesDomtools };
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2NjdG9vbHMucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzX3dlYi93Y2N0b29scy5wbHVnaW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxVQUFVLE1BQU0sd0JBQXdCLENBQUM7QUFFckQsT0FBTyxFQUNMLFVBQVUsRUFDWCxDQUFDO0FBRUYsT0FBTyxLQUFLLFlBQVksTUFBTSw4QkFBOEIsQ0FBQztBQUU3RCxPQUFPLEVBQ0wsWUFBWSxFQUNiLENBQUMifQ==