@spectrum-web-components/grid 0.1.6-react.54 → 0.1.7-overlay-warning.19

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.
@@ -4,7 +4,7 @@
4
4
  "modules": [
5
5
  {
6
6
  "kind": "javascript-module",
7
- "path": "sp-grid.ts",
7
+ "path": "sp-grid.js",
8
8
  "declarations": [],
9
9
  "exports": [
10
10
  {
@@ -19,7 +19,7 @@
19
19
  },
20
20
  {
21
21
  "kind": "javascript-module",
22
- "path": "src/Grid.ts",
22
+ "path": "src/Grid.js",
23
23
  "declarations": [
24
24
  {
25
25
  "kind": "class",
@@ -74,13 +74,6 @@
74
74
  "default": "{\n width: 200,\n height: 200,\n }",
75
75
  "attribute": "itemSize"
76
76
  },
77
- {
78
- "kind": "field",
79
- "name": "renderItem",
80
- "type": {
81
- "text": "(\n item: unknown,\n index: number\n ) => TemplateResult"
82
- }
83
- },
84
77
  {
85
78
  "kind": "field",
86
79
  "name": "selected",
@@ -193,14 +186,14 @@
193
186
  "name": "Grid",
194
187
  "declaration": {
195
188
  "name": "Grid",
196
- "module": "src/Grid.ts"
189
+ "module": "src/Grid.js"
197
190
  }
198
191
  }
199
192
  ]
200
193
  },
201
194
  {
202
195
  "kind": "javascript-module",
203
- "path": "src/GridController.ts",
196
+ "path": "src/GridController.js",
204
197
  "declarations": [
205
198
  {
206
199
  "kind": "class",
@@ -416,7 +409,7 @@
416
409
  "name": "GridController",
417
410
  "declaration": {
418
411
  "name": "GridController",
419
- "module": "src/GridController.ts"
412
+ "module": "src/GridController.js"
420
413
  }
421
414
  }
422
415
  ]
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/grid",
3
- "version": "0.1.6-react.54+c59ca07be",
3
+ "version": "0.1.7-overlay-warning.19+0c0cf0e30",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -9,10 +9,10 @@
9
9
  "repository": {
10
10
  "type": "git",
11
11
  "url": "https://github.com/adobe/spectrum-web-components.git",
12
- "directory": "packages/grid"
12
+ "directory": "tools/grid"
13
13
  },
14
14
  "author": "",
15
- "homepage": "https://adobe.github.io/spectrum-web-components/components/grid",
15
+ "homepage": "https://opensource.adobe.com/spectrum-web-components/tools/grid",
16
16
  "bugs": {
17
17
  "url": "https://github.com/adobe/spectrum-web-components/issues"
18
18
  },
@@ -63,9 +63,9 @@
63
63
  ],
64
64
  "dependencies": {
65
65
  "@lit-labs/observers": "^1.0.1",
66
- "@lit-labs/virtualizer": "0.7.2",
67
- "@spectrum-web-components/base": "^0.7.3-react.54+c59ca07be",
68
- "@spectrum-web-components/reactive-controllers": "^0.3.5-react.54+c59ca07be"
66
+ "@lit-labs/virtualizer": "^1.0.1",
67
+ "@spectrum-web-components/base": "^0.7.4-overlay-warning.19+0c0cf0e30",
68
+ "@spectrum-web-components/reactive-controllers": "^0.3.5"
69
69
  },
70
70
  "types": "./src/index.d.ts",
71
71
  "customElements": "custom-elements.json",
@@ -73,5 +73,5 @@
73
73
  "./sp-*.js",
74
74
  "./**/*.dev.js"
75
75
  ],
76
- "gitHead": "c59ca07bef1633dd16241d4be7d87b037ce7ddbf"
76
+ "gitHead": "0c0cf0e307adb5e67526edb57de4f51ddfedefe1"
77
77
  }
package/src/Grid.d.ts CHANGED
@@ -16,13 +16,11 @@ export declare class Grid extends LitVirtualizer {
16
16
  width: number;
17
17
  height: number;
18
18
  };
19
- get renderItem(): (item: unknown, index: number) => TemplateResult;
20
- set renderItem(fn: (item: unknown, index: number, selected: boolean) => TemplateResult);
21
19
  selected: Record<string, unknown>[];
22
20
  gridController: GridController<HTMLElement>;
23
21
  protected handleChange(event: Event): void;
24
22
  createRenderRoot(): this;
25
- render(): TemplateResult;
23
+ render(): TemplateResult<1>;
26
24
  protected update(changes: PropertyValues<this>): void;
27
25
  connectedCallback(): void;
28
26
  disconnectedCallback(): void;
package/src/Grid.dev.js CHANGED
@@ -33,6 +33,7 @@ export class Grid extends LitVirtualizer {
33
33
  this.gridController = new GridController(this, {
34
34
  elements: () => [],
35
35
  itemSize: () => this.itemSize,
36
+ /* c8 ignore next 2 */
36
37
  gap: () => this.gap,
37
38
  padding: () => this.padding || this.gap
38
39
  });
@@ -40,17 +41,6 @@ export class Grid extends LitVirtualizer {
40
41
  static get styles() {
41
42
  return [styles];
42
43
  }
43
- get renderItem() {
44
- return super.renderItem;
45
- }
46
- set renderItem(fn) {
47
- super.renderItem = (item, index) => {
48
- const selected = this.selected.includes(
49
- item
50
- );
51
- return fn(item, index, selected);
52
- };
53
- }
54
44
  handleChange(event) {
55
45
  const target = event.target;
56
46
  const value = this.items[parseFloat(target.getAttribute("key") || "")];
@@ -104,6 +94,15 @@ export class Grid extends LitVirtualizer {
104
94
  padding: this.padding || this.gap
105
95
  });
106
96
  }
97
+ if (changes.has("renderItem")) {
98
+ const fn = this.renderItem;
99
+ this.renderItem = (item, index) => {
100
+ const selected = this.selected.includes(
101
+ item
102
+ );
103
+ return fn(item, index, selected);
104
+ };
105
+ }
107
106
  if (this.isConnected) {
108
107
  render(super.render(), this);
109
108
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Grid.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n adoptStyles,\n CSSResultArray,\n html,\n PropertyValues,\n ReactiveElement,\n render,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { LitVirtualizer } from '@lit-labs/virtualizer/LitVirtualizer.js';\nimport { grid } from '@lit-labs/virtualizer/layouts/grid.js';\nimport styles from './grid.css.js';\nimport { GridController } from './GridController.dev.js'\n\n/**\n * @element sp-grid\n *\n * @fires change - Announces that the value of `selected` has changed\n */\nexport class Grid extends LitVirtualizer {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String })\n public focusableSelector!: string;\n\n @property({ type: String })\n public gap: `${'0' | `${number}px`}` = '0';\n\n @property({ type: String })\n public padding: `${'0' | `${number}px`}` | undefined;\n\n @property({ type: Array })\n public override items: Record<string, unknown>[] = [];\n\n @property({ type: Object })\n public itemSize: {\n width: number;\n height: number;\n } = {\n width: 200,\n height: 200,\n };\n\n /* c8 ignore next 3 */\n override get renderItem(): (\n item: unknown,\n index: number\n ) => TemplateResult {\n return super.renderItem;\n }\n\n override set renderItem(\n fn: (item: unknown, index: number, selected: boolean) => TemplateResult\n ) {\n super.renderItem = (item, index: number): TemplateResult => {\n const selected = this.selected.includes(\n item as Record<string, unknown>\n );\n return fn(item, index, selected);\n };\n }\n\n @property({ type: Array })\n public selected: Record<string, unknown>[] = [];\n\n gridController = new GridController<HTMLElement>(this, {\n elements: () => [],\n itemSize: () => this.itemSize,\n /* c8 ignore next 2 */\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n\n protected handleChange(event: Event): void {\n const target = event.target as HTMLElement;\n const value = this.items[\n parseFloat(target.getAttribute('key') || '')\n ] as Record<string, unknown>;\n const selected: Record<string, unknown>[] = [...this.selected];\n if (!selected.includes(value)) {\n selected.push(value);\n } else {\n const index = selected.indexOf(value);\n if (index > -1) {\n selected.splice(index, 1);\n }\n }\n this.selected = selected;\n }\n\n public override createRenderRoot(): this {\n const renderRoot =\n this.shadowRoot ??\n this.attachShadow(\n (this.constructor as typeof ReactiveElement).shadowRootOptions\n );\n adoptStyles(\n renderRoot,\n (this.constructor as typeof ReactiveElement).elementStyles\n );\n return renderRoot as unknown as this;\n }\n\n public override render(): TemplateResult {\n return html`\n <slot></slot>\n `;\n }\n\n protected override update(changes: PropertyValues<this>): void {\n if (\n changes.has('itemSize') ||\n changes.has('gap') ||\n changes.has('padding') ||\n changes.has('focusableSelector')\n ) {\n this.updateComplete.then(() => {\n this.gridController.update({\n elements: () => [\n ...this.querySelectorAll<HTMLElement>(\n this.focusableSelector\n ),\n ],\n itemSize: () => this.itemSize,\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n });\n\n this.layout = grid({\n itemSize: {\n width: `${this.itemSize.width}px`,\n height: `${this.itemSize.height}px`,\n },\n gap: this.gap,\n padding: this.padding || this.gap,\n });\n }\n\n if (this.isConnected) {\n render(super.render(), this);\n }\n super.update(changes);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('change', this.handleChange, { capture: true });\n }\n\n override disconnectedCallback(): void {\n this.removeEventListener('change', this.handleChange, {\n capture: true,\n });\n super.disconnectedCallback();\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;AAYA;AAAA,EACI;AAAA,EAEA;AAAA,EAGA;AAAA,OAEG;AACP,SAAS,gBAAgB;AACzB,SAAS,sBAAsB;AAC/B,SAAS,YAAY;AACrB,OAAO,YAAY;AACnB,SAAS,sBAAsB;AAOxB,aAAM,aAAa,eAAe;AAAA,EAAlC;AAAA;AASH,SAAO,MAAgC;AAMvC,SAAgB,QAAmC,CAAC;AAGpD,SAAO,WAGH;AAAA,MACA,OAAO;AAAA,MACP,QAAQ;AAAA,IACZ;AAsBA,SAAO,WAAsC,CAAC;AAE9C,0BAAiB,IAAI,eAA4B,MAAM;AAAA,MACnD,UAAU,MAAM,CAAC;AAAA,MACjB,UAAU,MAAM,KAAK;AAAA,MAErB,KAAK,MAAM,KAAK;AAAA,MAChB,SAAS,MAAM,KAAK,WAAW,KAAK;AAAA,IACxC,CAAC;AAAA;AAAA,EArDD,WAA2B,SAAyB;AAChD,WAAO,CAAC,MAAM;AAAA,EAClB;AAAA,EAwBA,IAAa,aAGO;AAChB,WAAO,MAAM;AAAA,EACjB;AAAA,EAEA,IAAa,WACT,IACF;AACE,UAAM,aAAa,CAAC,MAAM,UAAkC;AACxD,YAAM,WAAW,KAAK,SAAS;AAAA,QAC3B;AAAA,MACJ;AACA,aAAO,GAAG,MAAM,OAAO,QAAQ;AAAA,IACnC;AAAA,EACJ;AAAA,EAaU,aAAa,OAAoB;AACvC,UAAM,SAAS,MAAM;AACrB,UAAM,QAAQ,KAAK,MACf,WAAW,OAAO,aAAa,KAAK,KAAK,EAAE;AAE/C,UAAM,WAAsC,CAAC,GAAG,KAAK,QAAQ;AAC7D,QAAI,CAAC,SAAS,SAAS,KAAK,GAAG;AAC3B,eAAS,KAAK,KAAK;AAAA,IACvB,OAAO;AACH,YAAM,QAAQ,SAAS,QAAQ,KAAK;AACpC,UAAI,QAAQ,IAAI;AACZ,iBAAS,OAAO,OAAO,CAAC;AAAA,MAC5B;AAAA,IACJ;AACA,SAAK,WAAW;AAAA,EACpB;AAAA,EAEgB,mBAAyB;AAzG7C;AA0GQ,UAAM,cACF,UAAK,eAAL,YACA,KAAK;AAAA,MACA,KAAK,YAAuC;AAAA,IACjD;AACJ;AAAA,MACI;AAAA,MACC,KAAK,YAAuC;AAAA,IACjD;AACA,WAAO;AAAA,EACX;AAAA,EAEgB,SAAyB;AACrC,WAAO;AAAA;AAAA;AAAA,EAGX;AAAA,EAEmB,OAAO,SAAqC;AAC3D,QACI,QAAQ,IAAI,UAAU,KACtB,QAAQ,IAAI,KAAK,KACjB,QAAQ,IAAI,SAAS,KACrB,QAAQ,IAAI,mBAAmB,GACjC;AACE,WAAK,eAAe,KAAK,MAAM;AAC3B,aAAK,eAAe,OAAO;AAAA,UACvB,UAAU,MAAM;AAAA,YACZ,GAAG,KAAK;AAAA,cACJ,KAAK;AAAA,YACT;AAAA,UACJ;AAAA,UACA,UAAU,MAAM,KAAK;AAAA,UACrB,KAAK,MAAM,KAAK;AAAA,UAChB,SAAS,MAAM,KAAK,WAAW,KAAK;AAAA,QACxC,CAAC;AAAA,MACL,CAAC;AAED,WAAK,SAAS,KAAK;AAAA,QACf,UAAU;AAAA,UACN,OAAO,GAAG,KAAK,SAAS;AAAA,UACxB,QAAQ,GAAG,KAAK,SAAS;AAAA,QAC7B;AAAA,QACA,KAAK,KAAK;AAAA,QACV,SAAS,KAAK,WAAW,KAAK;AAAA,MAClC,CAAC;AAAA,IACL;AAEA,QAAI,KAAK,aAAa;AAClB,aAAO,MAAM,OAAO,GAAG,IAAI;AAAA,IAC/B;AACA,UAAM,OAAO,OAAO;AAAA,EACxB;AAAA,EAES,oBAA0B;AAC/B,UAAM,kBAAkB;AACxB,SAAK,iBAAiB,UAAU,KAAK,cAAc,EAAE,SAAS,KAAK,CAAC;AAAA,EACxE;AAAA,EAES,uBAA6B;AAClC,SAAK,oBAAoB,UAAU,KAAK,cAAc;AAAA,MAClD,SAAS;AAAA,IACb,CAAC;AACD,UAAM,qBAAqB;AAAA,EAC/B;AACJ;AArIW;AAAA,EADN,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GALjB,KAMF;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GARjB,KASF;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GAXjB,KAYF;AAGS;AAAA,EADf,SAAS,EAAE,MAAM,MAAM,CAAC;AAAA,GAdhB,KAeO;AAGT;AAAA,EADN,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GAjBjB,KAkBF;AA4BA;AAAA,EADN,SAAS,EAAE,MAAM,MAAM,CAAC;AAAA,GA7ChB,KA8CF;",
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n adoptStyles,\n CSSResultArray,\n html,\n PropertyValues,\n ReactiveElement,\n render,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { LitVirtualizer } from '@lit-labs/virtualizer/LitVirtualizer.js';\nimport { grid } from '@lit-labs/virtualizer/layouts/grid.js';\nimport styles from './grid.css.js';\nimport { GridController } from './GridController.dev.js'\n\n/**\n * @element sp-grid\n *\n * @fires change - Announces that the value of `selected` has changed\n */\nexport class Grid extends LitVirtualizer {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String })\n public focusableSelector!: string;\n\n @property({ type: String })\n public gap: `${'0' | `${number}px`}` = '0';\n\n @property({ type: String })\n public padding: `${'0' | `${number}px`}` | undefined;\n\n @property({ type: Array })\n public override items: Record<string, unknown>[] = [];\n\n @property({ type: Object })\n public itemSize: {\n width: number;\n height: number;\n } = {\n width: 200,\n height: 200,\n };\n\n @property({ type: Array })\n public selected: Record<string, unknown>[] = [];\n\n gridController = new GridController<HTMLElement>(this, {\n elements: () => [],\n itemSize: () => this.itemSize,\n /* c8 ignore next 2 */\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n\n protected handleChange(event: Event): void {\n const target = event.target as HTMLElement;\n const value = this.items[\n parseFloat(target.getAttribute('key') || '')\n ] as Record<string, unknown>;\n const selected: Record<string, unknown>[] = [...this.selected];\n if (!selected.includes(value)) {\n selected.push(value);\n } else {\n const index = selected.indexOf(value);\n if (index > -1) {\n selected.splice(index, 1);\n }\n }\n this.selected = selected;\n }\n\n public override createRenderRoot(): this {\n const renderRoot =\n this.shadowRoot ??\n this.attachShadow(\n (this.constructor as typeof ReactiveElement).shadowRootOptions\n );\n adoptStyles(\n renderRoot,\n (this.constructor as typeof ReactiveElement).elementStyles\n );\n return renderRoot as unknown as this;\n }\n\n public override render(): TemplateResult<1> {\n return html`\n <slot></slot>\n `;\n }\n\n protected override update(changes: PropertyValues<this>): void {\n if (\n changes.has('itemSize') ||\n changes.has('gap') ||\n changes.has('padding') ||\n changes.has('focusableSelector')\n ) {\n this.updateComplete.then(() => {\n this.gridController.update({\n elements: () => [\n ...this.querySelectorAll<HTMLElement>(\n this.focusableSelector\n ),\n ],\n itemSize: () => this.itemSize,\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n });\n\n this.layout = grid({\n itemSize: {\n width: `${this.itemSize.width}px`,\n height: `${this.itemSize.height}px`,\n },\n gap: this.gap,\n padding: this.padding || this.gap,\n });\n }\n if (changes.has('renderItem')) {\n const fn = this.renderItem as unknown as (\n item: unknown,\n index: number,\n selected: boolean\n ) => TemplateResult;\n this.renderItem = (item, index: number): TemplateResult => {\n const selected = this.selected.includes(\n item as Record<string, unknown>\n );\n return fn(item, index, selected);\n };\n }\n\n if (this.isConnected) {\n render(super.render(), this);\n }\n super.update(changes);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('change', this.handleChange, { capture: true });\n }\n\n override disconnectedCallback(): void {\n this.removeEventListener('change', this.handleChange, {\n capture: true,\n });\n super.disconnectedCallback();\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/src/Grid.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var l=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var n=(a,d,e,i)=>{for(var t=i>1?void 0:i?p(d,e):d,r=a.length-1,s;r>=0;r--)(s=a[r])&&(t=(i?s(d,e,t):s(t))||t);return i&&t&&l(d,e,t),t};import{adoptStyles as u,html as c,render as h}from"@spectrum-web-components/base";import{property as o}from"@spectrum-web-components/base/src/decorators.js";import{LitVirtualizer as m}from"@lit-labs/virtualizer/LitVirtualizer.js";import{grid as g}from"@lit-labs/virtualizer/layouts/grid.js";import b from"./grid.css.js";import{GridController as S}from"./GridController.js";export class Grid extends m{constructor(){super(...arguments);this.gap="0";this.items=[];this.itemSize={width:200,height:200};this.selected=[];this.gridController=new S(this,{elements:()=>[],itemSize:()=>this.itemSize,gap:()=>this.gap,padding:()=>this.padding||this.gap})}static get styles(){return[b]}get renderItem(){return super.renderItem}set renderItem(e){super.renderItem=(i,t)=>{const r=this.selected.includes(i);return e(i,t,r)}}handleChange(e){const i=e.target,t=this.items[parseFloat(i.getAttribute("key")||"")],r=[...this.selected];if(!r.includes(t))r.push(t);else{const s=r.indexOf(t);s>-1&&r.splice(s,1)}this.selected=r}createRenderRoot(){var i;const e=(i=this.shadowRoot)!=null?i:this.attachShadow(this.constructor.shadowRootOptions);return u(e,this.constructor.elementStyles),e}render(){return c`
1
+ "use strict";var d=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var n=(l,a,e,i)=>{for(var t=i>1?void 0:i?p(a,e):a,r=l.length-1,s;r>=0;r--)(s=l[r])&&(t=(i?s(a,e,t):s(t))||t);return i&&t&&d(a,e,t),t};import{adoptStyles as h,html as c,render as u}from"@spectrum-web-components/base";import{property as o}from"@spectrum-web-components/base/src/decorators.js";import{LitVirtualizer as m}from"@lit-labs/virtualizer/LitVirtualizer.js";import{grid as g}from"@lit-labs/virtualizer/layouts/grid.js";import b from"./grid.css.js";import{GridController as S}from"./GridController.js";export class Grid extends m{constructor(){super(...arguments);this.gap="0";this.items=[];this.itemSize={width:200,height:200};this.selected=[];this.gridController=new S(this,{elements:()=>[],itemSize:()=>this.itemSize,gap:()=>this.gap,padding:()=>this.padding||this.gap})}static get styles(){return[b]}handleChange(e){const i=e.target,t=this.items[parseFloat(i.getAttribute("key")||"")],r=[...this.selected];if(!r.includes(t))r.push(t);else{const s=r.indexOf(t);s>-1&&r.splice(s,1)}this.selected=r}createRenderRoot(){var i;const e=(i=this.shadowRoot)!=null?i:this.attachShadow(this.constructor.shadowRootOptions);return h(e,this.constructor.elementStyles),e}render(){return c`
2
2
  <slot></slot>
3
- `}update(e){(e.has("itemSize")||e.has("gap")||e.has("padding")||e.has("focusableSelector"))&&(this.updateComplete.then(()=>{this.gridController.update({elements:()=>[...this.querySelectorAll(this.focusableSelector)],itemSize:()=>this.itemSize,gap:()=>this.gap,padding:()=>this.padding||this.gap})}),this.layout=g({itemSize:{width:`${this.itemSize.width}px`,height:`${this.itemSize.height}px`},gap:this.gap,padding:this.padding||this.gap})),this.isConnected&&h(super.render(),this),super.update(e)}connectedCallback(){super.connectedCallback(),this.addEventListener("change",this.handleChange,{capture:!0})}disconnectedCallback(){this.removeEventListener("change",this.handleChange,{capture:!0}),super.disconnectedCallback()}}n([o({type:String})],Grid.prototype,"focusableSelector",2),n([o({type:String})],Grid.prototype,"gap",2),n([o({type:String})],Grid.prototype,"padding",2),n([o({type:Array})],Grid.prototype,"items",2),n([o({type:Object})],Grid.prototype,"itemSize",2),n([o({type:Array})],Grid.prototype,"selected",2);
3
+ `}update(e){if((e.has("itemSize")||e.has("gap")||e.has("padding")||e.has("focusableSelector"))&&(this.updateComplete.then(()=>{this.gridController.update({elements:()=>[...this.querySelectorAll(this.focusableSelector)],itemSize:()=>this.itemSize,gap:()=>this.gap,padding:()=>this.padding||this.gap})}),this.layout=g({itemSize:{width:`${this.itemSize.width}px`,height:`${this.itemSize.height}px`},gap:this.gap,padding:this.padding||this.gap})),e.has("renderItem")){const i=this.renderItem;this.renderItem=(t,r)=>{const s=this.selected.includes(t);return i(t,r,s)}}this.isConnected&&u(super.render(),this),super.update(e)}connectedCallback(){super.connectedCallback(),this.addEventListener("change",this.handleChange,{capture:!0})}disconnectedCallback(){this.removeEventListener("change",this.handleChange,{capture:!0}),super.disconnectedCallback()}}n([o({type:String})],Grid.prototype,"focusableSelector",2),n([o({type:String})],Grid.prototype,"gap",2),n([o({type:String})],Grid.prototype,"padding",2),n([o({type:Array})],Grid.prototype,"items",2),n([o({type:Object})],Grid.prototype,"itemSize",2),n([o({type:Array})],Grid.prototype,"selected",2);
4
4
  //# sourceMappingURL=Grid.js.map
package/src/Grid.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Grid.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n adoptStyles,\n CSSResultArray,\n html,\n PropertyValues,\n ReactiveElement,\n render,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { LitVirtualizer } from '@lit-labs/virtualizer/LitVirtualizer.js';\nimport { grid } from '@lit-labs/virtualizer/layouts/grid.js';\nimport styles from './grid.css.js';\nimport { GridController } from './GridController.js';\n\n/**\n * @element sp-grid\n *\n * @fires change - Announces that the value of `selected` has changed\n */\nexport class Grid extends LitVirtualizer {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String })\n public focusableSelector!: string;\n\n @property({ type: String })\n public gap: `${'0' | `${number}px`}` = '0';\n\n @property({ type: String })\n public padding: `${'0' | `${number}px`}` | undefined;\n\n @property({ type: Array })\n public override items: Record<string, unknown>[] = [];\n\n @property({ type: Object })\n public itemSize: {\n width: number;\n height: number;\n } = {\n width: 200,\n height: 200,\n };\n\n /* c8 ignore next 3 */\n override get renderItem(): (\n item: unknown,\n index: number\n ) => TemplateResult {\n return super.renderItem;\n }\n\n override set renderItem(\n fn: (item: unknown, index: number, selected: boolean) => TemplateResult\n ) {\n super.renderItem = (item, index: number): TemplateResult => {\n const selected = this.selected.includes(\n item as Record<string, unknown>\n );\n return fn(item, index, selected);\n };\n }\n\n @property({ type: Array })\n public selected: Record<string, unknown>[] = [];\n\n gridController = new GridController<HTMLElement>(this, {\n elements: () => [],\n itemSize: () => this.itemSize,\n /* c8 ignore next 2 */\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n\n protected handleChange(event: Event): void {\n const target = event.target as HTMLElement;\n const value = this.items[\n parseFloat(target.getAttribute('key') || '')\n ] as Record<string, unknown>;\n const selected: Record<string, unknown>[] = [...this.selected];\n if (!selected.includes(value)) {\n selected.push(value);\n } else {\n const index = selected.indexOf(value);\n if (index > -1) {\n selected.splice(index, 1);\n }\n }\n this.selected = selected;\n }\n\n public override createRenderRoot(): this {\n const renderRoot =\n this.shadowRoot ??\n this.attachShadow(\n (this.constructor as typeof ReactiveElement).shadowRootOptions\n );\n adoptStyles(\n renderRoot,\n (this.constructor as typeof ReactiveElement).elementStyles\n );\n return renderRoot as unknown as this;\n }\n\n public override render(): TemplateResult {\n return html`\n <slot></slot>\n `;\n }\n\n protected override update(changes: PropertyValues<this>): void {\n if (\n changes.has('itemSize') ||\n changes.has('gap') ||\n changes.has('padding') ||\n changes.has('focusableSelector')\n ) {\n this.updateComplete.then(() => {\n this.gridController.update({\n elements: () => [\n ...this.querySelectorAll<HTMLElement>(\n this.focusableSelector\n ),\n ],\n itemSize: () => this.itemSize,\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n });\n\n this.layout = grid({\n itemSize: {\n width: `${this.itemSize.width}px`,\n height: `${this.itemSize.height}px`,\n },\n gap: this.gap,\n padding: this.padding || this.gap,\n });\n }\n\n if (this.isConnected) {\n render(super.render(), this);\n }\n super.update(changes);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('change', this.handleChange, { capture: true });\n }\n\n override disconnectedCallback(): void {\n this.removeEventListener('change', this.handleChange, {\n capture: true,\n });\n super.disconnectedCallback();\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["adoptStyles", "html", "render", "property", "LitVirtualizer", "grid", "styles", "GridController", "fn", "item", "index", "selected", "event", "target", "value", "_a", "renderRoot", "changes", "__decorateClass"]
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n adoptStyles,\n CSSResultArray,\n html,\n PropertyValues,\n ReactiveElement,\n render,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { LitVirtualizer } from '@lit-labs/virtualizer/LitVirtualizer.js';\nimport { grid } from '@lit-labs/virtualizer/layouts/grid.js';\nimport styles from './grid.css.js';\nimport { GridController } from './GridController.js';\n\n/**\n * @element sp-grid\n *\n * @fires change - Announces that the value of `selected` has changed\n */\nexport class Grid extends LitVirtualizer {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String })\n public focusableSelector!: string;\n\n @property({ type: String })\n public gap: `${'0' | `${number}px`}` = '0';\n\n @property({ type: String })\n public padding: `${'0' | `${number}px`}` | undefined;\n\n @property({ type: Array })\n public override items: Record<string, unknown>[] = [];\n\n @property({ type: Object })\n public itemSize: {\n width: number;\n height: number;\n } = {\n width: 200,\n height: 200,\n };\n\n @property({ type: Array })\n public selected: Record<string, unknown>[] = [];\n\n gridController = new GridController<HTMLElement>(this, {\n elements: () => [],\n itemSize: () => this.itemSize,\n /* c8 ignore next 2 */\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n\n protected handleChange(event: Event): void {\n const target = event.target as HTMLElement;\n const value = this.items[\n parseFloat(target.getAttribute('key') || '')\n ] as Record<string, unknown>;\n const selected: Record<string, unknown>[] = [...this.selected];\n if (!selected.includes(value)) {\n selected.push(value);\n } else {\n const index = selected.indexOf(value);\n if (index > -1) {\n selected.splice(index, 1);\n }\n }\n this.selected = selected;\n }\n\n public override createRenderRoot(): this {\n const renderRoot =\n this.shadowRoot ??\n this.attachShadow(\n (this.constructor as typeof ReactiveElement).shadowRootOptions\n );\n adoptStyles(\n renderRoot,\n (this.constructor as typeof ReactiveElement).elementStyles\n );\n return renderRoot as unknown as this;\n }\n\n public override render(): TemplateResult<1> {\n return html`\n <slot></slot>\n `;\n }\n\n protected override update(changes: PropertyValues<this>): void {\n if (\n changes.has('itemSize') ||\n changes.has('gap') ||\n changes.has('padding') ||\n changes.has('focusableSelector')\n ) {\n this.updateComplete.then(() => {\n this.gridController.update({\n elements: () => [\n ...this.querySelectorAll<HTMLElement>(\n this.focusableSelector\n ),\n ],\n itemSize: () => this.itemSize,\n gap: () => this.gap,\n padding: () => this.padding || this.gap,\n });\n });\n\n this.layout = grid({\n itemSize: {\n width: `${this.itemSize.width}px`,\n height: `${this.itemSize.height}px`,\n },\n gap: this.gap,\n padding: this.padding || this.gap,\n });\n }\n if (changes.has('renderItem')) {\n const fn = this.renderItem as unknown as (\n item: unknown,\n index: number,\n selected: boolean\n ) => TemplateResult;\n this.renderItem = (item, index: number): TemplateResult => {\n const selected = this.selected.includes(\n item as Record<string, unknown>\n );\n return fn(item, index, selected);\n };\n }\n\n if (this.isConnected) {\n render(super.render(), this);\n }\n super.update(changes);\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.addEventListener('change', this.handleChange, { capture: true });\n }\n\n override disconnectedCallback(): void {\n this.removeEventListener('change', this.handleChange, {\n capture: true,\n });\n super.disconnectedCallback();\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["adoptStyles", "html", "render", "property", "LitVirtualizer", "grid", "styles", "GridController", "event", "target", "value", "selected", "index", "_a", "renderRoot", "changes", "fn", "item", "__decorateClass"]
7
7
  }
@@ -1,7 +1,7 @@
1
1
  import type { ReactiveController } from 'lit';
2
2
  import { ResizeController } from '@lit-labs/observers/resize_controller.js';
3
3
  import { RovingTabindexController } from '@spectrum-web-components/reactive-controllers/src/RovingTabindex.js';
4
- import { RangeChangedEvent, VisibilityChangedEvent } from '@lit-labs/virtualizer/Virtualizer.js';
4
+ import { RangeChangedEvent, VisibilityChangedEvent } from '@lit-labs/virtualizer/events.js';
5
5
  import { Grid } from './Grid.js';
6
6
  interface ItemSize {
7
7
  width: number;
@@ -8,7 +8,9 @@ export class GridController {
8
8
  gap,
9
9
  padding
10
10
  }) {
11
+ // First visible element
11
12
  this._first = 0;
13
+ // Last visible element
12
14
  this._last = 0;
13
15
  this.handleFocusin = (event) => {
14
16
  const doCallbackAfterPaint = (cb) => {
@@ -71,6 +73,7 @@ export class GridController {
71
73
  get itemSize() {
72
74
  return this._itemSize();
73
75
  }
76
+ /* c8 ignore next 6 */
74
77
  _itemSize() {
75
78
  return {
76
79
  width: 100,
@@ -80,12 +83,14 @@ export class GridController {
80
83
  get gap() {
81
84
  return this._gap();
82
85
  }
86
+ /* c8 ignore next 3 */
83
87
  _gap() {
84
88
  return void 0;
85
89
  }
86
90
  get padding() {
87
91
  return this._padding();
88
92
  }
93
+ /* c8 ignore next 3 */
89
94
  _padding() {
90
95
  return void 0;
91
96
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["GridController.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport type { ReactiveController } from 'lit';\n\nimport { ResizeController } from '@lit-labs/observers/resize_controller.js';\nimport { RovingTabindexController } from '@spectrum-web-components/reactive-controllers/src/RovingTabindex.js';\nimport {\n RangeChangedEvent,\n VisibilityChangedEvent,\n} from '@lit-labs/virtualizer/Virtualizer.js';\nimport { Grid } from './Grid.dev.js'\n\ninterface ItemSize {\n width: number;\n height: number;\n}\n\nexport class GridController<T extends HTMLElement>\n implements ReactiveController\n{\n host!: Grid;\n\n resizeController!: ResizeController;\n\n rovingTabindexController!: RovingTabindexController<T>;\n\n get itemSize(): ItemSize {\n return this._itemSize();\n }\n\n /* c8 ignore next 6 */\n private _itemSize(): ItemSize {\n return {\n width: 100,\n height: 100,\n };\n }\n\n // First visible element\n _first = 0;\n\n get gap(): string | undefined {\n return this._gap();\n }\n\n /* c8 ignore next 3 */\n private _gap(): string | undefined {\n return undefined;\n }\n\n get padding(): string | undefined {\n return this._padding();\n }\n\n /* c8 ignore next 3 */\n private _padding(): string | undefined {\n return undefined;\n }\n\n // Last visible element\n _last = 0;\n\n constructor(\n host: Grid,\n {\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }\n ) {\n this.host = host;\n this.host.addController(this);\n this.applyLayout(itemSize, gap, padding);\n this.resizeController = new ResizeController(this.host, {\n callback: (entries: ResizeObserverEntry[]): void => {\n entries.forEach((entry) => {\n this.measureDirectionLength(entry.contentRect);\n });\n },\n });\n this.rovingTabindexController = new RovingTabindexController<T>(\n this.host,\n {\n direction: 'grid',\n elements,\n focusInIndex: () => {\n const activeElement = (this.host.getRootNode() as Document)\n .activeElement as HTMLElement;\n return activeElement === this.host ? 0 : -1;\n },\n }\n );\n }\n\n public focus(options?: FocusOptions): void {\n this.rovingTabindexController.focus(options);\n }\n\n protected applyLayout(\n itemSize: ItemSize | (() => ItemSize),\n gap?: string | (() => string),\n padding?: string | (() => string)\n ): void {\n /* c8 ignore next 2 */\n if (typeof itemSize === 'object') {\n this._itemSize = () => itemSize;\n } else if (\n typeof itemSize === 'function' &&\n typeof itemSize() !== 'undefined'\n ) {\n this._itemSize = itemSize;\n }\n /* c8 ignore next 2 */\n if (typeof gap === 'string') {\n this._gap = () => gap;\n } else if (typeof gap === 'function') {\n this._gap = gap;\n }\n /* c8 ignore next 2 */\n if (typeof padding === 'string') {\n this._padding = () => padding;\n } else if (typeof padding === 'function') {\n this._padding = padding;\n }\n }\n\n public update({\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }): void {\n this.rovingTabindexController.update({ elements });\n this.applyLayout(itemSize, gap, padding);\n const contentRect = this.host.getBoundingClientRect();\n this.measureDirectionLength(contentRect);\n }\n\n protected measureDirectionLength(contentRect: DOMRect): void {\n const gap = this.gap ? parseFloat(this.gap) : 0;\n const padding = this.padding ? parseFloat(this.padding) : 0;\n const contentBoxWidth = contentRect.width - padding * 2;\n // There is always one less gap per row than items.\n const directionLength =\n Math.floor(\n (contentBoxWidth - this.itemSize.width) /\n (gap + this.itemSize.width)\n ) + 1;\n this.rovingTabindexController.directionLength =\n Math.floor(directionLength);\n }\n\n protected handleFocusin = (event: FocusEvent): void => {\n const doCallbackAfterPaint = (cb: () => void): void => {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n cb();\n });\n });\n };\n const scrollToFirst = (): void => this.host.scrollToIndex(0);\n const focusIntoGrid = (): void => {\n this.focus();\n this.host.tabIndex = -1;\n };\n if ((event.target as HTMLElement) === this.host) {\n if (this._first > 0) {\n doCallbackAfterPaint(() => {\n scrollToFirst();\n doCallbackAfterPaint(focusIntoGrid);\n });\n } else {\n doCallbackAfterPaint(focusIntoGrid);\n }\n }\n };\n\n protected handleFocusout = (event: FocusEvent): void => {\n if (\n !event.relatedTarget ||\n !this.host.contains(event.relatedTarget as HTMLElement)\n ) {\n this.host.tabIndex = 0;\n }\n };\n\n protected handleRangeChanged = (event: RangeChangedEvent): void => {\n this.rovingTabindexController.clearElementCache(event.first);\n };\n\n protected handleVisibleChanged = (event: VisibilityChangedEvent): void => {\n this._first = event.first;\n this._last = event.last;\n };\n\n public hostConnected(): void {\n this.host.addEventListener('rangeChanged', this.handleRangeChanged);\n this.host.addEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.addEventListener('focusin', this.handleFocusin);\n this.host.addEventListener('focusout', this.handleFocusout);\n this.host.tabIndex = 0;\n this.host.style.setProperty('outline', 'none', 'important');\n }\n\n public hostDisconnected(): void {\n this.host.removeEventListener('rangeChanged', this.handleRangeChanged);\n this.host.removeEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.removeEventListener('focusin', this.handleFocusin);\n this.host.removeEventListener('focusout', this.handleFocusout);\n }\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport type { ReactiveController } from 'lit';\n\nimport { ResizeController } from '@lit-labs/observers/resize_controller.js';\nimport { RovingTabindexController } from '@spectrum-web-components/reactive-controllers/src/RovingTabindex.js';\nimport {\n RangeChangedEvent,\n VisibilityChangedEvent,\n} from '@lit-labs/virtualizer/events.js';\nimport { Grid } from './Grid.dev.js'\n\ninterface ItemSize {\n width: number;\n height: number;\n}\n\nexport class GridController<T extends HTMLElement>\n implements ReactiveController\n{\n host!: Grid;\n\n resizeController!: ResizeController;\n\n rovingTabindexController!: RovingTabindexController<T>;\n\n get itemSize(): ItemSize {\n return this._itemSize();\n }\n\n /* c8 ignore next 6 */\n private _itemSize(): ItemSize {\n return {\n width: 100,\n height: 100,\n };\n }\n\n // First visible element\n _first = 0;\n\n get gap(): string | undefined {\n return this._gap();\n }\n\n /* c8 ignore next 3 */\n private _gap(): string | undefined {\n return undefined;\n }\n\n get padding(): string | undefined {\n return this._padding();\n }\n\n /* c8 ignore next 3 */\n private _padding(): string | undefined {\n return undefined;\n }\n\n // Last visible element\n _last = 0;\n\n constructor(\n host: Grid,\n {\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }\n ) {\n this.host = host;\n this.host.addController(this);\n this.applyLayout(itemSize, gap, padding);\n this.resizeController = new ResizeController(this.host, {\n callback: (entries: ResizeObserverEntry[]): void => {\n entries.forEach((entry) => {\n this.measureDirectionLength(entry.contentRect);\n });\n },\n });\n this.rovingTabindexController = new RovingTabindexController<T>(\n this.host,\n {\n direction: 'grid',\n elements,\n focusInIndex: () => {\n const activeElement = (this.host.getRootNode() as Document)\n .activeElement as HTMLElement;\n return activeElement === this.host ? 0 : -1;\n },\n }\n );\n }\n\n public focus(options?: FocusOptions): void {\n this.rovingTabindexController.focus(options);\n }\n\n protected applyLayout(\n itemSize: ItemSize | (() => ItemSize),\n gap?: string | (() => string),\n padding?: string | (() => string)\n ): void {\n /* c8 ignore next 2 */\n if (typeof itemSize === 'object') {\n this._itemSize = () => itemSize;\n } else if (\n typeof itemSize === 'function' &&\n typeof itemSize() !== 'undefined'\n ) {\n this._itemSize = itemSize;\n }\n /* c8 ignore next 2 */\n if (typeof gap === 'string') {\n this._gap = () => gap;\n } else if (typeof gap === 'function') {\n this._gap = gap;\n }\n /* c8 ignore next 2 */\n if (typeof padding === 'string') {\n this._padding = () => padding;\n } else if (typeof padding === 'function') {\n this._padding = padding;\n }\n }\n\n public update({\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }): void {\n this.rovingTabindexController.update({ elements });\n this.applyLayout(itemSize, gap, padding);\n const contentRect = this.host.getBoundingClientRect();\n this.measureDirectionLength(contentRect);\n }\n\n protected measureDirectionLength(contentRect: DOMRect): void {\n const gap = this.gap ? parseFloat(this.gap) : 0;\n const padding = this.padding ? parseFloat(this.padding) : 0;\n const contentBoxWidth = contentRect.width - padding * 2;\n // There is always one less gap per row than items.\n const directionLength =\n Math.floor(\n (contentBoxWidth - this.itemSize.width) /\n (gap + this.itemSize.width)\n ) + 1;\n this.rovingTabindexController.directionLength =\n Math.floor(directionLength);\n }\n\n protected handleFocusin = (event: FocusEvent): void => {\n const doCallbackAfterPaint = (cb: () => void): void => {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n cb();\n });\n });\n };\n const scrollToFirst = (): void => this.host.scrollToIndex(0);\n const focusIntoGrid = (): void => {\n this.focus();\n this.host.tabIndex = -1;\n };\n if ((event.target as HTMLElement) === this.host) {\n if (this._first > 0) {\n doCallbackAfterPaint(() => {\n scrollToFirst();\n doCallbackAfterPaint(focusIntoGrid);\n });\n } else {\n doCallbackAfterPaint(focusIntoGrid);\n }\n }\n };\n\n protected handleFocusout = (event: FocusEvent): void => {\n if (\n !event.relatedTarget ||\n !this.host.contains(event.relatedTarget as HTMLElement)\n ) {\n this.host.tabIndex = 0;\n }\n };\n\n protected handleRangeChanged = (event: RangeChangedEvent): void => {\n this.rovingTabindexController.clearElementCache(event.first);\n };\n\n protected handleVisibleChanged = (event: VisibilityChangedEvent): void => {\n this._first = event.first;\n this._last = event.last;\n };\n\n public hostConnected(): void {\n this.host.addEventListener('rangeChanged', this.handleRangeChanged);\n this.host.addEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.addEventListener('focusin', this.handleFocusin);\n this.host.addEventListener('focusout', this.handleFocusout);\n this.host.tabIndex = 0;\n this.host.style.setProperty('outline', 'none', 'important');\n }\n\n public hostDisconnected(): void {\n this.host.removeEventListener('rangeChanged', this.handleRangeChanged);\n this.host.removeEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.removeEventListener('focusin', this.handleFocusin);\n this.host.removeEventListener('focusout', this.handleFocusout);\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["GridController.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport type { ReactiveController } from 'lit';\n\nimport { ResizeController } from '@lit-labs/observers/resize_controller.js';\nimport { RovingTabindexController } from '@spectrum-web-components/reactive-controllers/src/RovingTabindex.js';\nimport {\n RangeChangedEvent,\n VisibilityChangedEvent,\n} from '@lit-labs/virtualizer/Virtualizer.js';\nimport { Grid } from './Grid.js';\n\ninterface ItemSize {\n width: number;\n height: number;\n}\n\nexport class GridController<T extends HTMLElement>\n implements ReactiveController\n{\n host!: Grid;\n\n resizeController!: ResizeController;\n\n rovingTabindexController!: RovingTabindexController<T>;\n\n get itemSize(): ItemSize {\n return this._itemSize();\n }\n\n /* c8 ignore next 6 */\n private _itemSize(): ItemSize {\n return {\n width: 100,\n height: 100,\n };\n }\n\n // First visible element\n _first = 0;\n\n get gap(): string | undefined {\n return this._gap();\n }\n\n /* c8 ignore next 3 */\n private _gap(): string | undefined {\n return undefined;\n }\n\n get padding(): string | undefined {\n return this._padding();\n }\n\n /* c8 ignore next 3 */\n private _padding(): string | undefined {\n return undefined;\n }\n\n // Last visible element\n _last = 0;\n\n constructor(\n host: Grid,\n {\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }\n ) {\n this.host = host;\n this.host.addController(this);\n this.applyLayout(itemSize, gap, padding);\n this.resizeController = new ResizeController(this.host, {\n callback: (entries: ResizeObserverEntry[]): void => {\n entries.forEach((entry) => {\n this.measureDirectionLength(entry.contentRect);\n });\n },\n });\n this.rovingTabindexController = new RovingTabindexController<T>(\n this.host,\n {\n direction: 'grid',\n elements,\n focusInIndex: () => {\n const activeElement = (this.host.getRootNode() as Document)\n .activeElement as HTMLElement;\n return activeElement === this.host ? 0 : -1;\n },\n }\n );\n }\n\n public focus(options?: FocusOptions): void {\n this.rovingTabindexController.focus(options);\n }\n\n protected applyLayout(\n itemSize: ItemSize | (() => ItemSize),\n gap?: string | (() => string),\n padding?: string | (() => string)\n ): void {\n /* c8 ignore next 2 */\n if (typeof itemSize === 'object') {\n this._itemSize = () => itemSize;\n } else if (\n typeof itemSize === 'function' &&\n typeof itemSize() !== 'undefined'\n ) {\n this._itemSize = itemSize;\n }\n /* c8 ignore next 2 */\n if (typeof gap === 'string') {\n this._gap = () => gap;\n } else if (typeof gap === 'function') {\n this._gap = gap;\n }\n /* c8 ignore next 2 */\n if (typeof padding === 'string') {\n this._padding = () => padding;\n } else if (typeof padding === 'function') {\n this._padding = padding;\n }\n }\n\n public update({\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }): void {\n this.rovingTabindexController.update({ elements });\n this.applyLayout(itemSize, gap, padding);\n const contentRect = this.host.getBoundingClientRect();\n this.measureDirectionLength(contentRect);\n }\n\n protected measureDirectionLength(contentRect: DOMRect): void {\n const gap = this.gap ? parseFloat(this.gap) : 0;\n const padding = this.padding ? parseFloat(this.padding) : 0;\n const contentBoxWidth = contentRect.width - padding * 2;\n // There is always one less gap per row than items.\n const directionLength =\n Math.floor(\n (contentBoxWidth - this.itemSize.width) /\n (gap + this.itemSize.width)\n ) + 1;\n this.rovingTabindexController.directionLength =\n Math.floor(directionLength);\n }\n\n protected handleFocusin = (event: FocusEvent): void => {\n const doCallbackAfterPaint = (cb: () => void): void => {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n cb();\n });\n });\n };\n const scrollToFirst = (): void => this.host.scrollToIndex(0);\n const focusIntoGrid = (): void => {\n this.focus();\n this.host.tabIndex = -1;\n };\n if ((event.target as HTMLElement) === this.host) {\n if (this._first > 0) {\n doCallbackAfterPaint(() => {\n scrollToFirst();\n doCallbackAfterPaint(focusIntoGrid);\n });\n } else {\n doCallbackAfterPaint(focusIntoGrid);\n }\n }\n };\n\n protected handleFocusout = (event: FocusEvent): void => {\n if (\n !event.relatedTarget ||\n !this.host.contains(event.relatedTarget as HTMLElement)\n ) {\n this.host.tabIndex = 0;\n }\n };\n\n protected handleRangeChanged = (event: RangeChangedEvent): void => {\n this.rovingTabindexController.clearElementCache(event.first);\n };\n\n protected handleVisibleChanged = (event: VisibilityChangedEvent): void => {\n this._first = event.first;\n this._last = event.last;\n };\n\n public hostConnected(): void {\n this.host.addEventListener('rangeChanged', this.handleRangeChanged);\n this.host.addEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.addEventListener('focusin', this.handleFocusin);\n this.host.addEventListener('focusout', this.handleFocusout);\n this.host.tabIndex = 0;\n this.host.style.setProperty('outline', 'none', 'important');\n }\n\n public hostDisconnected(): void {\n this.host.removeEventListener('rangeChanged', this.handleRangeChanged);\n this.host.removeEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.removeEventListener('focusin', this.handleFocusin);\n this.host.removeEventListener('focusout', this.handleFocusout);\n }\n}\n"],
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport type { ReactiveController } from 'lit';\n\nimport { ResizeController } from '@lit-labs/observers/resize_controller.js';\nimport { RovingTabindexController } from '@spectrum-web-components/reactive-controllers/src/RovingTabindex.js';\nimport {\n RangeChangedEvent,\n VisibilityChangedEvent,\n} from '@lit-labs/virtualizer/events.js';\nimport { Grid } from './Grid.js';\n\ninterface ItemSize {\n width: number;\n height: number;\n}\n\nexport class GridController<T extends HTMLElement>\n implements ReactiveController\n{\n host!: Grid;\n\n resizeController!: ResizeController;\n\n rovingTabindexController!: RovingTabindexController<T>;\n\n get itemSize(): ItemSize {\n return this._itemSize();\n }\n\n /* c8 ignore next 6 */\n private _itemSize(): ItemSize {\n return {\n width: 100,\n height: 100,\n };\n }\n\n // First visible element\n _first = 0;\n\n get gap(): string | undefined {\n return this._gap();\n }\n\n /* c8 ignore next 3 */\n private _gap(): string | undefined {\n return undefined;\n }\n\n get padding(): string | undefined {\n return this._padding();\n }\n\n /* c8 ignore next 3 */\n private _padding(): string | undefined {\n return undefined;\n }\n\n // Last visible element\n _last = 0;\n\n constructor(\n host: Grid,\n {\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }\n ) {\n this.host = host;\n this.host.addController(this);\n this.applyLayout(itemSize, gap, padding);\n this.resizeController = new ResizeController(this.host, {\n callback: (entries: ResizeObserverEntry[]): void => {\n entries.forEach((entry) => {\n this.measureDirectionLength(entry.contentRect);\n });\n },\n });\n this.rovingTabindexController = new RovingTabindexController<T>(\n this.host,\n {\n direction: 'grid',\n elements,\n focusInIndex: () => {\n const activeElement = (this.host.getRootNode() as Document)\n .activeElement as HTMLElement;\n return activeElement === this.host ? 0 : -1;\n },\n }\n );\n }\n\n public focus(options?: FocusOptions): void {\n this.rovingTabindexController.focus(options);\n }\n\n protected applyLayout(\n itemSize: ItemSize | (() => ItemSize),\n gap?: string | (() => string),\n padding?: string | (() => string)\n ): void {\n /* c8 ignore next 2 */\n if (typeof itemSize === 'object') {\n this._itemSize = () => itemSize;\n } else if (\n typeof itemSize === 'function' &&\n typeof itemSize() !== 'undefined'\n ) {\n this._itemSize = itemSize;\n }\n /* c8 ignore next 2 */\n if (typeof gap === 'string') {\n this._gap = () => gap;\n } else if (typeof gap === 'function') {\n this._gap = gap;\n }\n /* c8 ignore next 2 */\n if (typeof padding === 'string') {\n this._padding = () => padding;\n } else if (typeof padding === 'function') {\n this._padding = padding;\n }\n }\n\n public update({\n elements,\n itemSize,\n gap,\n padding,\n }: {\n elements: () => T[];\n itemSize: ItemSize | (() => ItemSize);\n gap?: string | (() => string);\n padding?: string | (() => string);\n }): void {\n this.rovingTabindexController.update({ elements });\n this.applyLayout(itemSize, gap, padding);\n const contentRect = this.host.getBoundingClientRect();\n this.measureDirectionLength(contentRect);\n }\n\n protected measureDirectionLength(contentRect: DOMRect): void {\n const gap = this.gap ? parseFloat(this.gap) : 0;\n const padding = this.padding ? parseFloat(this.padding) : 0;\n const contentBoxWidth = contentRect.width - padding * 2;\n // There is always one less gap per row than items.\n const directionLength =\n Math.floor(\n (contentBoxWidth - this.itemSize.width) /\n (gap + this.itemSize.width)\n ) + 1;\n this.rovingTabindexController.directionLength =\n Math.floor(directionLength);\n }\n\n protected handleFocusin = (event: FocusEvent): void => {\n const doCallbackAfterPaint = (cb: () => void): void => {\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n cb();\n });\n });\n };\n const scrollToFirst = (): void => this.host.scrollToIndex(0);\n const focusIntoGrid = (): void => {\n this.focus();\n this.host.tabIndex = -1;\n };\n if ((event.target as HTMLElement) === this.host) {\n if (this._first > 0) {\n doCallbackAfterPaint(() => {\n scrollToFirst();\n doCallbackAfterPaint(focusIntoGrid);\n });\n } else {\n doCallbackAfterPaint(focusIntoGrid);\n }\n }\n };\n\n protected handleFocusout = (event: FocusEvent): void => {\n if (\n !event.relatedTarget ||\n !this.host.contains(event.relatedTarget as HTMLElement)\n ) {\n this.host.tabIndex = 0;\n }\n };\n\n protected handleRangeChanged = (event: RangeChangedEvent): void => {\n this.rovingTabindexController.clearElementCache(event.first);\n };\n\n protected handleVisibleChanged = (event: VisibilityChangedEvent): void => {\n this._first = event.first;\n this._last = event.last;\n };\n\n public hostConnected(): void {\n this.host.addEventListener('rangeChanged', this.handleRangeChanged);\n this.host.addEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.addEventListener('focusin', this.handleFocusin);\n this.host.addEventListener('focusout', this.handleFocusout);\n this.host.tabIndex = 0;\n this.host.style.setProperty('outline', 'none', 'important');\n }\n\n public hostDisconnected(): void {\n this.host.removeEventListener('rangeChanged', this.handleRangeChanged);\n this.host.removeEventListener(\n 'visibilityChanged',\n this.handleVisibleChanged\n );\n this.host.removeEventListener('focusin', this.handleFocusin);\n this.host.removeEventListener('focusout', this.handleFocusout);\n }\n}\n"],
5
5
  "mappings": "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",
6
6
  "names": ["ResizeController", "RovingTabindexController", "host", "elements", "itemSize", "gap", "padding", "event", "doCallbackAfterPaint", "cb", "scrollToFirst", "focusIntoGrid", "entries", "entry", "options", "contentRect", "contentBoxWidth", "directionLength"]
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["grid.css.ts"],
4
- "sourcesContent": ["/*\nCopyright 2022 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{contain:strict;display:block;pointer-events:none;position:relative}::slotted(*){pointer-events:all}\n`;\nexport default styles;"],
4
+ "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{contain:strict;display:block;pointer-events:none;position:relative}::slotted(*){pointer-events:all}\n`;\nexport default styles;"],
5
5
  "mappings": ";AAWA,SAAS,WAAW;AACpB,MAAM,SAAS;AAAA;AAAA;AAGf,eAAe;",
6
6
  "names": []
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["grid.css.ts"],
4
- "sourcesContent": ["/*\nCopyright 2022 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{contain:strict;display:block;pointer-events:none;position:relative}::slotted(*){pointer-events:all}\n`;\nexport default styles;"],
4
+ "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport { css } from '@spectrum-web-components/base';\nconst styles = css`\n:host{contain:strict;display:block;pointer-events:none;position:relative}::slotted(*){pointer-events:all}\n`;\nexport default styles;"],
5
5
  "mappings": "aAWA,OAAS,OAAAA,MAAW,gCACpB,MAAMC,EAASD;AAAA;AAAA,EAGf,eAAeC",
6
6
  "names": ["css", "styles"]
7
7
  }
@@ -1,5 +1,9 @@
1
1
  "use strict";
2
- import { html } from "@spectrum-web-components/base";
2
+ import {
3
+ css,
4
+ html,
5
+ SpectrumElement
6
+ } from "@spectrum-web-components/base";
3
7
  import "@spectrum-web-components/grid/sp-grid.js";
4
8
  import "@spectrum-web-components/action-bar/sp-action-bar.js";
5
9
  import "@spectrum-web-components/card/sp-card.js";
@@ -20,50 +24,50 @@ function generateItems(count) {
20
24
  }
21
25
  return items;
22
26
  }
27
+ const renderItem = (item, index, selected) => {
28
+ return html`
29
+ <sp-card
30
+ toggles
31
+ variant="quiet"
32
+ heading="Card Heading ${item.id}"
33
+ subheading="JPG Photo"
34
+ style="contain: strict; padding: 1px;"
35
+ value="card-${item.id}"
36
+ .selected=${selected}
37
+ key=${index}
38
+ >
39
+ <img
40
+ alt=""
41
+ slot="preview"
42
+ src="https://picsum.photos/id/${item.id}/200/300"
43
+ decoding="async"
44
+ />
45
+ <div slot="description">10/15/18</div>
46
+ <div slot="footer">Footer</div>
47
+ </sp-card>
48
+ `;
49
+ };
50
+ const handleChange = (event) => {
51
+ const actionbar = document.querySelector("sp-action-bar");
52
+ const selected = document.querySelector(".selected");
53
+ const ids = document.querySelector(".ids");
54
+ actionbar.open = !!event.currentTarget.selected.length;
55
+ actionbar.style.setProperty(
56
+ "display",
57
+ !!event.currentTarget.selected.length ? "flex" : "none"
58
+ );
59
+ selected.textContent = "" + event.currentTarget.selected.length;
60
+ ids.textContent = "" + event.currentTarget.selected.map((selection) => selection.id).join(", ");
61
+ };
62
+ const handleActionBarChange = (event) => {
63
+ event.preventDefault();
64
+ const grid = document.querySelector("sp-grid");
65
+ const actionbar = document.querySelector("sp-action-bar");
66
+ actionbar.open = false;
67
+ grid.selected = [];
68
+ };
23
69
  export const Default = () => {
24
70
  const items = generateItems(1e3);
25
- const renderItem = (item, index, selected) => {
26
- return html`
27
- <sp-card
28
- toggles
29
- variant="quiet"
30
- heading="Card Heading ${item.id}"
31
- subheading="JPG Photo"
32
- style="contain: strict; padding: 1px;"
33
- value="card-${item.id}"
34
- .selected=${selected}
35
- key=${index}
36
- >
37
- <img
38
- alt=""
39
- slot="preview"
40
- src="https://picsum.photos/id/${item.id}/200/300"
41
- decoding="async"
42
- />
43
- <div slot="description">10/15/18</div>
44
- <div slot="footer">Footer</div>
45
- </sp-card>
46
- `;
47
- };
48
- const handleChange = (event) => {
49
- const actionbar = document.querySelector("sp-action-bar");
50
- const selected = document.querySelector(".selected");
51
- const ids = document.querySelector(".ids");
52
- actionbar.open = !!event.currentTarget.selected.length;
53
- actionbar.style.setProperty(
54
- "display",
55
- !!event.currentTarget.selected.length ? "flex" : "none"
56
- );
57
- selected.textContent = "" + event.currentTarget.selected.length;
58
- ids.textContent = "" + event.currentTarget.selected.map((selection) => selection.id).join(", ");
59
- };
60
- const handleActionBarChange = (event) => {
61
- event.preventDefault();
62
- const grid = document.querySelector("sp-grid");
63
- const actionbar = document.querySelector("sp-action-bar");
64
- actionbar.open = false;
65
- grid.selected = [];
66
- };
67
71
  return html`
68
72
  <h1>Random before content that is focusable</h1>
69
73
  <input id="first-input" />
@@ -97,48 +101,6 @@ Default.swc_vrt = {
97
101
  };
98
102
  export const sized = ({ gap, padding } = { gap: 10, padding: 10 }) => {
99
103
  const items = generateItems(1e3);
100
- const renderItem = (item, index, selected) => {
101
- return html`
102
- <sp-card
103
- toggles
104
- variant="quiet"
105
- heading="Card Heading ${item.id}"
106
- subheading="JPG Photo"
107
- style="contain: strict; padding: 1px;"
108
- value="card-${item.id}"
109
- .selected=${selected}
110
- key=${index}
111
- >
112
- <img
113
- alt=""
114
- slot="preview"
115
- src="https://picsum.photos/id/${item.id}/200/300"
116
- decoding="async"
117
- />
118
- <div slot="description">10/15/18</div>
119
- <div slot="footer">Footer</div>
120
- </sp-card>
121
- `;
122
- };
123
- const handleChange = (event) => {
124
- const actionbar = document.querySelector("sp-action-bar");
125
- const selected = document.querySelector(".selected");
126
- const ids = document.querySelector(".ids");
127
- actionbar.open = !!event.currentTarget.selected.length;
128
- actionbar.style.setProperty(
129
- "display",
130
- !!event.currentTarget.selected.length ? "flex" : "none"
131
- );
132
- selected.textContent = "" + event.currentTarget.selected.length;
133
- ids.textContent = "" + event.currentTarget.selected.map((selection) => selection.id).join(", ");
134
- };
135
- const handleActionBarChange = (event) => {
136
- event.preventDefault();
137
- const grid = document.querySelector("sp-grid");
138
- const actionbar = document.querySelector("sp-action-bar");
139
- actionbar.open = false;
140
- grid.selected = [];
141
- };
142
104
  return html`
143
105
  <h1>Random before content that is focusable</h1>
144
106
  <input id="first-input" />
@@ -204,4 +166,41 @@ sized.argTypes = {
204
166
  sized.swc_vrt = {
205
167
  skip: true
206
168
  };
169
+ class MyParent extends SpectrumElement {
170
+ render() {
171
+ return html`
172
+ <div class="child"><slot></slot></div>
173
+ `;
174
+ }
175
+ }
176
+ MyParent.styles = [
177
+ css`
178
+ :host {
179
+ display: block;
180
+ height: 100vh;
181
+ overflow: hidden;
182
+ }
183
+
184
+ .child {
185
+ height: 100%;
186
+ overflow: scroll;
187
+ }
188
+ `
189
+ ];
190
+ customElements.define("my-parent", MyParent);
191
+ export const scrollParentInAssignedSlot = () => {
192
+ const items = generateItems(1e3);
193
+ return html`
194
+ <my-parent>
195
+ <sp-grid
196
+ .items=${items}
197
+ .focusableSelector=${"sp-card"}
198
+ .renderItem=${renderItem}
199
+ ></sp-grid>
200
+ </my-parent>
201
+ `;
202
+ };
203
+ scrollParentInAssignedSlot.swc_vrt = {
204
+ skip: true
205
+ };
207
206
  //# sourceMappingURL=grid.stories.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["grid.stories.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport { html, TemplateResult } from '@spectrum-web-components/base';\n\nimport '@spectrum-web-components/grid/sp-grid.js';\nimport '@spectrum-web-components/action-bar/sp-action-bar.js';\nimport '@spectrum-web-components/card/sp-card.js';\nimport '@spectrum-web-components/checkbox/sp-checkbox.js';\nimport '@spectrum-web-components/action-button/sp-action-button.js';\nimport '@spectrum-web-components/action-group/sp-action-group.js';\nimport '@spectrum-web-components/icons-workflow/icons/sp-icon-edit.js';\nimport '@spectrum-web-components/icons-workflow/icons/sp-icon-more.js';\nimport type { ActionBar } from '@spectrum-web-components/action-bar';\nimport type { Grid } from '@spectrum-web-components/grid';\n\nexport default {\n title: 'Grid',\n component: 'sp-grid',\n};\n\ninterface Item extends Record<string, unknown> {\n id: number;\n}\n\nfunction generateItems(count: number): Item[] {\n const items: Item[] = [];\n while (count) {\n count -= 1;\n items.unshift({ id: count });\n }\n return items;\n}\n\nexport const Default = (): TemplateResult => {\n const items = generateItems(1000);\n\n const renderItem = (\n item: Item,\n index: number,\n selected: boolean\n ): TemplateResult => {\n return html`\n <sp-card\n toggles\n variant=\"quiet\"\n heading=\"Card Heading ${item.id}\"\n subheading=\"JPG Photo\"\n style=\"contain: strict; padding: 1px;\"\n value=\"card-${item.id}\"\n .selected=${selected}\n key=${index}\n >\n <img\n alt=\"\"\n slot=\"preview\"\n src=\"https://picsum.photos/id/${item.id}/200/300\"\n decoding=\"async\"\n />\n <div slot=\"description\">10/15/18</div>\n <div slot=\"footer\">Footer</div>\n </sp-card>\n `;\n };\n const handleChange = (event: Event & { currentTarget: Grid }): void => {\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n const selected = document.querySelector('.selected') as HTMLElement;\n const ids = document.querySelector('.ids') as HTMLElement;\n actionbar.open = !!event.currentTarget.selected.length;\n actionbar.style.setProperty(\n 'display',\n !!event.currentTarget.selected.length ? 'flex' : 'none'\n );\n selected.textContent = '' + event.currentTarget.selected.length;\n ids.textContent =\n '' +\n event.currentTarget.selected\n .map((selection) => selection.id)\n .join(', ');\n };\n const handleActionBarChange = (event: Event): void => {\n event.preventDefault();\n const grid = document.querySelector('sp-grid') as Grid;\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n actionbar.open = false;\n grid.selected = [];\n };\n return html`\n <h1>Random before content that is focusable</h1>\n <input id=\"first-input\" />\n <sp-grid\n @change=${handleChange}\n .items=${items}\n .focusableSelector=${'sp-card'}\n .renderItem=${renderItem}\n ></sp-grid>\n <sp-action-bar variant=\"fixed\" style=\"display: none\">\n <sp-checkbox @click=${handleActionBarChange} checked>\n <span class=\"selected\"></span>\n Selected\n <span class=\"ids\"></span>\n </sp-checkbox>\n <sp-action-group quiet>\n <sp-action-button>\n <sp-icon-edit slot=\"icon\" label=\"Edit\"></sp-icon-edit>\n </sp-action-button>\n <sp-action-button>\n <sp-icon-more slot=\"icon\" label=\"More\"></sp-icon-more>\n </sp-action-button>\n </sp-action-group>\n </sp-action-bar>\n <h2>Random after content that is focusable</h2>\n <input id=\"last-input\" />\n `;\n};\n\nDefault.swc_vrt = {\n skip: true,\n};\n\nexport const sized = (\n { gap, padding } = { gap: 10, padding: 10 }\n): TemplateResult => {\n const items = generateItems(1000);\n\n const renderItem = (\n item: Item,\n index: number,\n selected: boolean\n ): TemplateResult => {\n return html`\n <sp-card\n toggles\n variant=\"quiet\"\n heading=\"Card Heading ${item.id}\"\n subheading=\"JPG Photo\"\n style=\"contain: strict; padding: 1px;\"\n value=\"card-${item.id}\"\n .selected=${selected}\n key=${index}\n >\n <img\n alt=\"\"\n slot=\"preview\"\n src=\"https://picsum.photos/id/${item.id}/200/300\"\n decoding=\"async\"\n />\n <div slot=\"description\">10/15/18</div>\n <div slot=\"footer\">Footer</div>\n </sp-card>\n `;\n };\n const handleChange = (event: Event & { currentTarget: Grid }): void => {\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n const selected = document.querySelector('.selected') as HTMLElement;\n const ids = document.querySelector('.ids') as HTMLElement;\n actionbar.open = !!event.currentTarget.selected.length;\n actionbar.style.setProperty(\n 'display',\n !!event.currentTarget.selected.length ? 'flex' : 'none'\n );\n selected.textContent = '' + event.currentTarget.selected.length;\n ids.textContent =\n '' +\n event.currentTarget.selected\n .map((selection) => selection.id)\n .join(', ');\n };\n const handleActionBarChange = (event: Event): void => {\n event.preventDefault();\n const grid = document.querySelector('sp-grid') as Grid;\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n actionbar.open = false;\n grid.selected = [];\n };\n return html`\n <h1>Random before content that is focusable</h1>\n <input id=\"first-input\" />\n <sp-grid\n @change=${handleChange}\n .items=${items}\n .focusableSelector=${'sp-card'}\n .renderItem=${renderItem}\n .itemSize=${{\n width: 200,\n height: 300,\n }}\n .gap=${`${gap}px`}\n .padding=${`${padding}px`}\n ></sp-grid>\n <sp-action-bar variant=\"fixed\" style=\"display: none\">\n <sp-checkbox @click=${handleActionBarChange} checked>\n <span class=\"selected\"></span>\n Selected\n <span class=\"ids\"></span>\n </sp-checkbox>\n <sp-action-group quiet>\n <sp-action-button>\n <sp-icon-edit slot=\"icon\" label=\"Edit\"></sp-icon-edit>\n </sp-action-button>\n <sp-action-button>\n <sp-icon-more slot=\"icon\" label=\"More\"></sp-icon-more>\n </sp-action-button>\n </sp-action-group>\n </sp-action-bar>\n <h2>Random after content that is focusable</h2>\n <input id=\"last-input\" />\n `;\n};\n\nsized.args = {\n gap: 10,\n padding: 10,\n};\n\nsized.argTypes = {\n gap: {\n name: 'gap',\n type: { name: 'number', required: false },\n description: 'Spacing between items.',\n table: {\n type: { summary: 'number' },\n },\n control: {\n type: 'number',\n },\n },\n padding: {\n name: 'padding',\n type: { name: 'number', required: false },\n description: 'Spacing around all items.',\n table: {\n type: { summary: 'number' },\n },\n control: {\n type: 'number',\n },\n },\n};\n\nsized.swc_vrt = {\n skip: true,\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n css,\n html,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\n\nimport '@spectrum-web-components/grid/sp-grid.js';\nimport '@spectrum-web-components/action-bar/sp-action-bar.js';\nimport '@spectrum-web-components/card/sp-card.js';\nimport '@spectrum-web-components/checkbox/sp-checkbox.js';\nimport '@spectrum-web-components/action-button/sp-action-button.js';\nimport '@spectrum-web-components/action-group/sp-action-group.js';\nimport '@spectrum-web-components/icons-workflow/icons/sp-icon-edit.js';\nimport '@spectrum-web-components/icons-workflow/icons/sp-icon-more.js';\nimport type { ActionBar } from '@spectrum-web-components/action-bar';\nimport type { Grid } from '@spectrum-web-components/grid';\n\nexport default {\n title: 'Grid',\n component: 'sp-grid',\n};\n\ninterface Item extends Record<string, unknown> {\n id: number;\n}\n\nfunction generateItems(count: number): Item[] {\n const items: Item[] = [];\n while (count) {\n count -= 1;\n items.unshift({ id: count });\n }\n return items;\n}\n\nconst renderItem = (\n item: Item,\n index: number,\n selected: boolean\n): TemplateResult => {\n return html`\n <sp-card\n toggles\n variant=\"quiet\"\n heading=\"Card Heading ${item.id}\"\n subheading=\"JPG Photo\"\n style=\"contain: strict; padding: 1px;\"\n value=\"card-${item.id}\"\n .selected=${selected}\n key=${index}\n >\n <img\n alt=\"\"\n slot=\"preview\"\n src=\"https://picsum.photos/id/${item.id}/200/300\"\n decoding=\"async\"\n />\n <div slot=\"description\">10/15/18</div>\n <div slot=\"footer\">Footer</div>\n </sp-card>\n `;\n};\n\nconst handleChange = (event: Event & { currentTarget: Grid }): void => {\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n const selected = document.querySelector('.selected') as HTMLElement;\n const ids = document.querySelector('.ids') as HTMLElement;\n actionbar.open = !!event.currentTarget.selected.length;\n actionbar.style.setProperty(\n 'display',\n !!event.currentTarget.selected.length ? 'flex' : 'none'\n );\n selected.textContent = '' + event.currentTarget.selected.length;\n ids.textContent =\n '' +\n event.currentTarget.selected\n .map((selection) => selection.id)\n .join(', ');\n};\n\nconst handleActionBarChange = (event: Event): void => {\n event.preventDefault();\n const grid = document.querySelector('sp-grid') as Grid;\n const actionbar = document.querySelector('sp-action-bar') as ActionBar;\n actionbar.open = false;\n grid.selected = [];\n};\n\nexport const Default = (): TemplateResult => {\n const items = generateItems(1000);\n\n return html`\n <h1>Random before content that is focusable</h1>\n <input id=\"first-input\" />\n <sp-grid\n @change=${handleChange}\n .items=${items}\n .focusableSelector=${'sp-card'}\n .renderItem=${renderItem}\n ></sp-grid>\n <sp-action-bar variant=\"fixed\" style=\"display: none\">\n <sp-checkbox @click=${handleActionBarChange} checked>\n <span class=\"selected\"></span>\n Selected\n <span class=\"ids\"></span>\n </sp-checkbox>\n <sp-action-group quiet>\n <sp-action-button>\n <sp-icon-edit slot=\"icon\" label=\"Edit\"></sp-icon-edit>\n </sp-action-button>\n <sp-action-button>\n <sp-icon-more slot=\"icon\" label=\"More\"></sp-icon-more>\n </sp-action-button>\n </sp-action-group>\n </sp-action-bar>\n <h2>Random after content that is focusable</h2>\n <input id=\"last-input\" />\n `;\n};\n\nDefault.swc_vrt = {\n skip: true,\n};\n\nexport const sized = (\n { gap, padding } = { gap: 10, padding: 10 }\n): TemplateResult => {\n const items = generateItems(1000);\n\n return html`\n <h1>Random before content that is focusable</h1>\n <input id=\"first-input\" />\n <sp-grid\n @change=${handleChange}\n .items=${items}\n .focusableSelector=${'sp-card'}\n .renderItem=${renderItem}\n .itemSize=${{\n width: 200,\n height: 300,\n }}\n .gap=${`${gap}px`}\n .padding=${`${padding}px`}\n ></sp-grid>\n <sp-action-bar variant=\"fixed\" style=\"display: none\">\n <sp-checkbox @click=${handleActionBarChange} checked>\n <span class=\"selected\"></span>\n Selected\n <span class=\"ids\"></span>\n </sp-checkbox>\n <sp-action-group quiet>\n <sp-action-button>\n <sp-icon-edit slot=\"icon\" label=\"Edit\"></sp-icon-edit>\n </sp-action-button>\n <sp-action-button>\n <sp-icon-more slot=\"icon\" label=\"More\"></sp-icon-more>\n </sp-action-button>\n </sp-action-group>\n </sp-action-bar>\n <h2>Random after content that is focusable</h2>\n <input id=\"last-input\" />\n `;\n};\n\nsized.args = {\n gap: 10,\n padding: 10,\n};\n\nsized.argTypes = {\n gap: {\n name: 'gap',\n type: { name: 'number', required: false },\n description: 'Spacing between items.',\n table: {\n type: { summary: 'number' },\n },\n control: {\n type: 'number',\n },\n },\n padding: {\n name: 'padding',\n type: { name: 'number', required: false },\n description: 'Spacing around all items.',\n table: {\n type: { summary: 'number' },\n },\n control: {\n type: 'number',\n },\n },\n};\n\nsized.swc_vrt = {\n skip: true,\n};\n\nclass MyParent extends SpectrumElement {\n static override styles = [\n css`\n :host {\n display: block;\n height: 100vh;\n overflow: hidden;\n }\n\n .child {\n height: 100%;\n overflow: scroll;\n }\n `,\n ];\n\n override render(): TemplateResult {\n return html`\n <div class=\"child\"><slot></slot></div>\n `;\n }\n}\n\ncustomElements.define('my-parent', MyParent);\n\nexport const scrollParentInAssignedSlot = (): TemplateResult => {\n const items = generateItems(1000);\n\n return html`\n <my-parent>\n <sp-grid\n .items=${items}\n .focusableSelector=${'sp-card'}\n .renderItem=${renderItem}\n ></sp-grid>\n </my-parent>\n `;\n};\n\nscrollParentInAssignedSlot.swc_vrt = {\n skip: true,\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }