@design.estate/dees-wcctools 1.0.98 → 1.0.100

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.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * autocreated commitinfo by @pushrocks/commitinfo
2
+ * autocreated commitinfo by @push.rocks/commitinfo
3
3
  */
4
4
  export declare const commitinfo: {
5
5
  name: string;
@@ -1,9 +1,9 @@
1
1
  /**
2
- * autocreated commitinfo by @pushrocks/commitinfo
2
+ * autocreated commitinfo by @push.rocks/commitinfo
3
3
  */
4
4
  export const commitinfo = {
5
5
  name: '@design.estate/dees-wcctools',
6
- version: '1.0.90',
6
+ version: '1.0.100',
7
7
  description: 'A set of web component tools for creating element catalogues, enabling the structured development and documentation of custom elements and pages.'
8
8
  };
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHNfd2ViLzAwX2NvbW1pdGluZm9fZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRztJQUN4QixJQUFJLEVBQUUsOEJBQThCO0lBQ3BDLE9BQU8sRUFBRSxRQUFRO0lBQ2pCLFdBQVcsRUFBRSxtSkFBbUo7Q0FDakssQ0FBQSJ9
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHNfd2ViLzAwX2NvbW1pdGluZm9fZGF0YS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRztJQUN4QixJQUFJLEVBQUUsOEJBQThCO0lBQ3BDLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLFdBQVcsRUFBRSxtSkFBbUo7Q0FDakssQ0FBQSJ9
@@ -19,6 +19,9 @@ export declare class WccDashboard extends DeesElement {
19
19
  [key: string]: DeesElement;
20
20
  };
21
21
  warning: string;
22
+ frameScrollY: number;
23
+ sidebarScrollY: number;
24
+ private scrollPositionsApplied;
22
25
  wccFrame: Promise<WccFrame>;
23
26
  constructor(elementsArg?: {
24
27
  [key: string]: DeesElement;
@@ -30,4 +33,9 @@ export declare class WccDashboard extends DeesElement {
30
33
  firstUpdated(): Promise<void>;
31
34
  updated(changedPropertiesArg: Map<string, any>): Promise<void>;
32
35
  buildUrl(): void;
36
+ private scrollUpdateTimeout;
37
+ setupScrollListeners(): Promise<void>;
38
+ private debouncedScrollUpdate;
39
+ private updateUrlWithScrollState;
40
+ applyScrollPositions(): Promise<void>;
33
41
  }
@@ -25,6 +25,9 @@ let WccDashboard = class WccDashboard extends DeesElement {
25
25
  this.pages = {};
26
26
  this.elements = {};
27
27
  this.warning = null;
28
+ this.frameScrollY = 0;
29
+ this.sidebarScrollY = 0;
30
+ this.scrollPositionsApplied = false;
28
31
  if (elementsArg) {
29
32
  this.elements = elementsArg;
30
33
  console.log('got elements:');
@@ -88,6 +91,10 @@ let WccDashboard = class WccDashboard extends DeesElement {
88
91
  }
89
92
  async firstUpdated() {
90
93
  this.domtools = await plugins.deesDomtools.DomTools.setupDomTools();
94
+ // Set up scroll listeners after DOM is ready
95
+ setTimeout(() => {
96
+ this.setupScrollListeners();
97
+ }, 500);
91
98
  this.domtools.router.on('/wcctools-route/:itemType/:itemName/:viewport/:theme', async (routeInfo) => {
92
99
  this.selectedType = routeInfo.params.itemType;
93
100
  this.selectedItemName = routeInfo.params.itemName;
@@ -99,6 +106,21 @@ let WccDashboard = class WccDashboard extends DeesElement {
99
106
  else if (routeInfo.params.itemType === 'page') {
100
107
  this.selectedItem = this.pages[routeInfo.params.itemName];
101
108
  }
109
+ // Restore scroll positions from query parameters
110
+ if (routeInfo.queryParams) {
111
+ const frameScrollY = routeInfo.queryParams.frameScrollY;
112
+ const sidebarScrollY = routeInfo.queryParams.sidebarScrollY;
113
+ if (frameScrollY) {
114
+ this.frameScrollY = parseInt(frameScrollY);
115
+ }
116
+ if (sidebarScrollY) {
117
+ this.sidebarScrollY = parseInt(sidebarScrollY);
118
+ }
119
+ // Apply scroll positions after a short delay to ensure DOM is ready
120
+ setTimeout(() => {
121
+ this.applyScrollPositions();
122
+ }, 100);
123
+ }
102
124
  const domtoolsInstance = await plugins.deesDomtools.elementBasic.setup();
103
125
  this.selectedTheme === 'bright'
104
126
  ? domtoolsInstance.themeManager.goBright()
@@ -108,7 +130,6 @@ let WccDashboard = class WccDashboard extends DeesElement {
108
130
  async updated(changedPropertiesArg) {
109
131
  this.domtools = await plugins.deesDomtools.DomTools.setupDomTools();
110
132
  await this.domtools.router._handleRouteState();
111
- const storeElement = this.selectedItem;
112
133
  const wccFrame = this.shadowRoot.querySelector('wcc-frame');
113
134
  if (changedPropertiesArg.has('selectedItemName')) {
114
135
  document.title = this.selectedItemName;
@@ -144,7 +165,72 @@ let WccDashboard = class WccDashboard extends DeesElement {
144
165
  }
145
166
  }
146
167
  buildUrl() {
147
- this.domtools.router.pushUrl(`/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`);
168
+ const baseUrl = `/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`;
169
+ const queryParams = new URLSearchParams();
170
+ if (this.frameScrollY > 0) {
171
+ queryParams.set('frameScrollY', this.frameScrollY.toString());
172
+ }
173
+ if (this.sidebarScrollY > 0) {
174
+ queryParams.set('sidebarScrollY', this.sidebarScrollY.toString());
175
+ }
176
+ const queryString = queryParams.toString();
177
+ const fullUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;
178
+ this.domtools.router.pushUrl(fullUrl);
179
+ }
180
+ async setupScrollListeners() {
181
+ const wccFrame = await this.wccFrame;
182
+ const wccSidebar = this.shadowRoot.querySelector('wcc-sidebar');
183
+ if (wccFrame) {
184
+ // The frame element itself is the scrollable container
185
+ wccFrame.addEventListener('scroll', () => {
186
+ this.frameScrollY = wccFrame.scrollTop;
187
+ this.debouncedScrollUpdate();
188
+ });
189
+ }
190
+ if (wccSidebar) {
191
+ // The sidebar element itself is the scrollable container
192
+ wccSidebar.addEventListener('scroll', () => {
193
+ this.sidebarScrollY = wccSidebar.scrollTop;
194
+ this.debouncedScrollUpdate();
195
+ });
196
+ }
197
+ }
198
+ debouncedScrollUpdate() {
199
+ clearTimeout(this.scrollUpdateTimeout);
200
+ this.scrollUpdateTimeout = setTimeout(() => {
201
+ this.updateUrlWithScrollState();
202
+ }, 300);
203
+ }
204
+ updateUrlWithScrollState() {
205
+ const baseUrl = `/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`;
206
+ const queryParams = new URLSearchParams();
207
+ if (this.frameScrollY > 0) {
208
+ queryParams.set('frameScrollY', this.frameScrollY.toString());
209
+ }
210
+ if (this.sidebarScrollY > 0) {
211
+ queryParams.set('sidebarScrollY', this.sidebarScrollY.toString());
212
+ }
213
+ const queryString = queryParams.toString();
214
+ const fullUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;
215
+ // Use replaceState to update URL without navigation
216
+ window.history.replaceState(null, '', fullUrl);
217
+ }
218
+ async applyScrollPositions() {
219
+ // Only apply scroll positions once to avoid interfering with user scrolling
220
+ if (this.scrollPositionsApplied) {
221
+ return;
222
+ }
223
+ const wccFrame = await this.wccFrame;
224
+ const wccSidebar = this.shadowRoot.querySelector('wcc-sidebar');
225
+ if (wccFrame && this.frameScrollY > 0) {
226
+ // The frame element itself is the scrollable container
227
+ wccFrame.scrollTop = this.frameScrollY;
228
+ }
229
+ if (wccSidebar && this.sidebarScrollY > 0) {
230
+ // The sidebar element itself is the scrollable container
231
+ wccSidebar.scrollTop = this.sidebarScrollY;
232
+ }
233
+ this.scrollPositionsApplied = true;
148
234
  }
149
235
  };
150
236
  __decorate([
@@ -179,6 +265,14 @@ __decorate([
179
265
  property(),
180
266
  __metadata("design:type", String)
181
267
  ], WccDashboard.prototype, "warning", void 0);
268
+ __decorate([
269
+ property(),
270
+ __metadata("design:type", Number)
271
+ ], WccDashboard.prototype, "frameScrollY", void 0);
272
+ __decorate([
273
+ property(),
274
+ __metadata("design:type", Number)
275
+ ], WccDashboard.prototype, "sidebarScrollY", void 0);
182
276
  __decorate([
183
277
  queryAsync('wcc-frame'),
184
278
  __metadata("design:type", Promise)
@@ -188,4 +282,4 @@ WccDashboard = __decorate([
188
282
  __metadata("design:paramtypes", [Object, Object])
189
283
  ], WccDashboard);
190
284
  export { WccDashboard };
191
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2NjLWRhc2hib2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RzX3dlYi9lbGVtZW50cy93Y2MtZGFzaGJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxhQUFhLEVBQXVCLFVBQVUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFFNUksT0FBTyxLQUFLLE9BQU8sTUFBTSx3QkFBd0IsQ0FBQztBQUVsRCxZQUFZO0FBQ1osT0FBTyxnQkFBZ0IsQ0FBQztBQUN4QixPQUFPLGtCQUFrQixDQUFDO0FBQzFCLE9BQU8scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUFlLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUFxQixNQUFNLGtCQUFrQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHbkMsSUFBTSxZQUFZLEdBQWxCLE1BQU0sWUFBYSxTQUFRLFdBQVc7SUE2QjNDLFlBQ0UsV0FBNEMsRUFDNUMsUUFBa0Q7UUFFbEQsS0FBSyxFQUFFLENBQUM7UUFyQkgscUJBQWdCLEdBQStDLFNBQVMsQ0FBQztRQUd6RSxrQkFBYSxHQUFXLE1BQU0sQ0FBQztRQUcvQixVQUFLLEdBQTRDLEVBQUUsQ0FBQztRQUdwRCxhQUFRLEdBQW1DLEVBQUUsQ0FBQztRQUc5QyxZQUFPLEdBQVcsSUFBSSxDQUFDO1FBVTVCLElBQUksV0FBVyxFQUFFLENBQUM7WUFDaEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxXQUFXLENBQUM7WUFDNUIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQztZQUM3QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM3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
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wcc-dashboard.js","sourceRoot":"","sources":["../../ts_web/elements/wcc-dashboard.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@design.estate/dees-wcctools",
3
- "version": "1.0.98",
3
+ "version": "1.0.100",
4
4
  "private": false,
5
5
  "description": "A set of web component tools for creating element catalogues, enabling the structured development and documentation of custom elements and pages.",
6
6
  "exports": {
@@ -1,8 +1,8 @@
1
1
  /**
2
- * autocreated commitinfo by @pushrocks/commitinfo
2
+ * autocreated commitinfo by @push.rocks/commitinfo
3
3
  */
4
4
  export const commitinfo = {
5
5
  name: '@design.estate/dees-wcctools',
6
- version: '1.0.90',
6
+ version: '1.0.100',
7
7
  description: 'A set of web component tools for creating element catalogues, enabling the structured development and documentation of custom elements and pages.'
8
8
  }
@@ -38,6 +38,14 @@ export class WccDashboard extends DeesElement {
38
38
  @property()
39
39
  public warning: string = null;
40
40
 
41
+ @property()
42
+ public frameScrollY: number = 0;
43
+
44
+ @property()
45
+ public sidebarScrollY: number = 0;
46
+
47
+ private scrollPositionsApplied: boolean = false;
48
+
41
49
  @queryAsync('wcc-frame')
42
50
  public wccFrame: Promise<WccFrame>;
43
51
 
@@ -113,6 +121,12 @@ export class WccDashboard extends DeesElement {
113
121
 
114
122
  public async firstUpdated() {
115
123
  this.domtools = await plugins.deesDomtools.DomTools.setupDomTools();
124
+
125
+ // Set up scroll listeners after DOM is ready
126
+ setTimeout(() => {
127
+ this.setupScrollListeners();
128
+ }, 500);
129
+
116
130
  this.domtools.router.on(
117
131
  '/wcctools-route/:itemType/:itemName/:viewport/:theme',
118
132
  async (routeInfo) => {
@@ -125,6 +139,25 @@ export class WccDashboard extends DeesElement {
125
139
  } else if (routeInfo.params.itemType === 'page') {
126
140
  this.selectedItem = this.pages[routeInfo.params.itemName];
127
141
  }
142
+
143
+ // Restore scroll positions from query parameters
144
+ if (routeInfo.queryParams) {
145
+ const frameScrollY = routeInfo.queryParams.frameScrollY;
146
+ const sidebarScrollY = routeInfo.queryParams.sidebarScrollY;
147
+
148
+ if (frameScrollY) {
149
+ this.frameScrollY = parseInt(frameScrollY);
150
+ }
151
+ if (sidebarScrollY) {
152
+ this.sidebarScrollY = parseInt(sidebarScrollY);
153
+ }
154
+
155
+ // Apply scroll positions after a short delay to ensure DOM is ready
156
+ setTimeout(() => {
157
+ this.applyScrollPositions();
158
+ }, 100);
159
+ }
160
+
128
161
  const domtoolsInstance = await plugins.deesDomtools.elementBasic.setup();
129
162
  this.selectedTheme === 'bright'
130
163
  ? domtoolsInstance.themeManager.goBright()
@@ -136,7 +169,6 @@ export class WccDashboard extends DeesElement {
136
169
  public async updated(changedPropertiesArg: Map<string, any>) {
137
170
  this.domtools = await plugins.deesDomtools.DomTools.setupDomTools();
138
171
  await this.domtools.router._handleRouteState();
139
- const storeElement = this.selectedItem;
140
172
  const wccFrame: WccFrame = this.shadowRoot.querySelector('wcc-frame');
141
173
 
142
174
  if (changedPropertiesArg.has('selectedItemName')) {
@@ -173,8 +205,89 @@ export class WccDashboard extends DeesElement {
173
205
  }
174
206
 
175
207
  public buildUrl() {
176
- this.domtools.router.pushUrl(
177
- `/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`
178
- );
208
+ const baseUrl = `/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`;
209
+ const queryParams = new URLSearchParams();
210
+
211
+ if (this.frameScrollY > 0) {
212
+ queryParams.set('frameScrollY', this.frameScrollY.toString());
213
+ }
214
+ if (this.sidebarScrollY > 0) {
215
+ queryParams.set('sidebarScrollY', this.sidebarScrollY.toString());
216
+ }
217
+
218
+ const queryString = queryParams.toString();
219
+ const fullUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;
220
+
221
+ this.domtools.router.pushUrl(fullUrl);
222
+ }
223
+
224
+ private scrollUpdateTimeout: NodeJS.Timeout;
225
+
226
+ public async setupScrollListeners() {
227
+ const wccFrame = await this.wccFrame;
228
+ const wccSidebar = this.shadowRoot.querySelector('wcc-sidebar');
229
+
230
+ if (wccFrame) {
231
+ // The frame element itself is the scrollable container
232
+ wccFrame.addEventListener('scroll', () => {
233
+ this.frameScrollY = wccFrame.scrollTop;
234
+ this.debouncedScrollUpdate();
235
+ });
236
+ }
237
+
238
+ if (wccSidebar) {
239
+ // The sidebar element itself is the scrollable container
240
+ wccSidebar.addEventListener('scroll', () => {
241
+ this.sidebarScrollY = wccSidebar.scrollTop;
242
+ this.debouncedScrollUpdate();
243
+ });
244
+ }
245
+ }
246
+
247
+ private debouncedScrollUpdate() {
248
+ clearTimeout(this.scrollUpdateTimeout);
249
+ this.scrollUpdateTimeout = setTimeout(() => {
250
+ this.updateUrlWithScrollState();
251
+ }, 300);
252
+ }
253
+
254
+ private updateUrlWithScrollState() {
255
+ const baseUrl = `/wcctools-route/${this.selectedType}/${this.selectedItemName}/${this.selectedViewport}/${this.selectedTheme}`;
256
+ const queryParams = new URLSearchParams();
257
+
258
+ if (this.frameScrollY > 0) {
259
+ queryParams.set('frameScrollY', this.frameScrollY.toString());
260
+ }
261
+ if (this.sidebarScrollY > 0) {
262
+ queryParams.set('sidebarScrollY', this.sidebarScrollY.toString());
263
+ }
264
+
265
+ const queryString = queryParams.toString();
266
+ const fullUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;
267
+
268
+ // Use replaceState to update URL without navigation
269
+ window.history.replaceState(null, '', fullUrl);
270
+ }
271
+
272
+ public async applyScrollPositions() {
273
+ // Only apply scroll positions once to avoid interfering with user scrolling
274
+ if (this.scrollPositionsApplied) {
275
+ return;
276
+ }
277
+
278
+ const wccFrame = await this.wccFrame;
279
+ const wccSidebar = this.shadowRoot.querySelector('wcc-sidebar');
280
+
281
+ if (wccFrame && this.frameScrollY > 0) {
282
+ // The frame element itself is the scrollable container
283
+ wccFrame.scrollTop = this.frameScrollY;
284
+ }
285
+
286
+ if (wccSidebar && this.sidebarScrollY > 0) {
287
+ // The sidebar element itself is the scrollable container
288
+ wccSidebar.scrollTop = this.sidebarScrollY;
289
+ }
290
+
291
+ this.scrollPositionsApplied = true;
179
292
  }
180
293
  }