@getflip/swirl-components 0.136.0 → 0.138.0

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.
Files changed (31) hide show
  1. package/components.json +61 -3
  2. package/dist/cjs/loader.cjs.js +1 -1
  3. package/dist/cjs/swirl-components.cjs.js +1 -1
  4. package/dist/cjs/swirl-image-grid-item.cjs.entry.js +36 -2
  5. package/dist/cjs/swirl-popover_2.cjs.entry.js +4 -2
  6. package/dist/collection/assets/pdfjs/pdf.worker.min.js +1 -1
  7. package/dist/collection/collection-manifest.json +1 -1
  8. package/dist/collection/components/swirl-image-grid/swirl-image-grid.spec.js +4 -1
  9. package/dist/collection/components/swirl-image-grid/swirl-image-grid.stories.js +5 -3
  10. package/dist/collection/components/swirl-image-grid-item/swirl-image-grid-item.css +10 -0
  11. package/dist/collection/components/swirl-image-grid-item/swirl-image-grid-item.js +63 -1
  12. package/dist/collection/components/swirl-image-grid-item/swirl-image-grid-item.spec.js +3 -0
  13. package/dist/collection/components/swirl-popover/swirl-popover.css +15 -0
  14. package/dist/collection/components/swirl-popover/swirl-popover.js +20 -1
  15. package/dist/components/assets/pdfjs/pdf.worker.min.js +1 -1
  16. package/dist/components/swirl-image-grid-item.js +53 -4
  17. package/dist/components/swirl-popover2.js +5 -2
  18. package/dist/esm/loader.js +1 -1
  19. package/dist/esm/swirl-components.js +1 -1
  20. package/dist/esm/swirl-image-grid-item.entry.js +37 -3
  21. package/dist/esm/swirl-popover_2.entry.js +4 -2
  22. package/dist/swirl-components/p-1d953d29.entry.js +1 -0
  23. package/dist/swirl-components/p-77dfa273.entry.js +1 -0
  24. package/dist/swirl-components/swirl-components.esm.js +1 -1
  25. package/dist/types/components/swirl-image-grid-item/swirl-image-grid-item.d.ts +11 -0
  26. package/dist/types/components/swirl-popover/swirl-popover.d.ts +1 -0
  27. package/dist/types/components.d.ts +6 -0
  28. package/package.json +1 -1
  29. package/vscode-data.json +22 -0
  30. package/dist/swirl-components/p-69b074a7.entry.js +0 -1
  31. package/dist/swirl-components/p-abc1d6e7.entry.js +0 -1
@@ -20,6 +20,7 @@
20
20
  "./components/swirl-file-viewer/viewers/swirl-file-viewer-pdf/swirl-file-viewer-pdf.js",
21
21
  "./components/swirl-form-control/swirl-form-control.js",
22
22
  "./components/swirl-form-group/swirl-form-group.js",
23
+ "./components/swirl-image-grid-item/swirl-image-grid-item.js",
23
24
  "./components/swirl-inline-error/swirl-inline-error.js",
24
25
  "./components/swirl-inline-notification/swirl-inline-notification.js",
25
26
  "./components/swirl-inline-status/swirl-inline-status.js",
@@ -221,7 +222,6 @@
221
222
  "./components/swirl-icon/icons/swirl-icon-voice.js",
222
223
  "./components/swirl-icon/icons/swirl-icon-warning.js",
223
224
  "./components/swirl-image-grid/swirl-image-grid.js",
224
- "./components/swirl-image-grid-item/swirl-image-grid-item.js",
225
225
  "./components/swirl-lightbox/swirl-lightbox.js",
226
226
  "./components/swirl-list/swirl-list.js",
227
227
  "./components/swirl-menu-item/swirl-menu-item.js",
@@ -1,6 +1,6 @@
1
1
  import { newSpecPage } from "@stencil/core/testing";
2
- import { SwirlImageGrid } from "./swirl-image-grid";
3
2
  import { SwirlImageGridItem } from "../swirl-image-grid-item/swirl-image-grid-item";
3
+ import { SwirlImageGrid } from "./swirl-image-grid";
4
4
  describe("swirl-image-grid", () => {
5
5
  it("renders a single item", async () => {
6
6
  const page = await newSpecPage({
@@ -23,6 +23,9 @@ describe("swirl-image-grid", () => {
23
23
  <button class="image-grid-item" type="button">
24
24
  <div class="image-grid-item__background" style="background-image: url(/sample.jpg);"></div>
25
25
  <img alt="Cute dog in a blanket" class="image-grid-item__image" src="/sample.jpg">
26
+ <div class="image-grid-item__spinner">
27
+ <swirl-spinner></swirl-spinner>
28
+ </div>
26
29
  </button>
27
30
  </mock:shadow-root>
28
31
  </swirl-image-grid-item>
@@ -18,7 +18,9 @@ const Template = (args) => {
18
18
  export const SwirlImageGrid = Template.bind({});
19
19
  SwirlImageGrid.args = {
20
20
  aspectRatio: "16 / 9",
21
- slot: `<swirl-image-grid-item alt="Cute dog in a blanket" interactive src="/sample.jpg"></swirl-image-grid-item>
22
- <swirl-image-grid-item alt="Another cute dog in a blanket" icon="<swirl-icon-play-arrow></swirl-icon-play-arrow>" interactive src="/sample-2.jpg"></swirl-image-grid-item>
23
- <swirl-image-grid-item alt="Third cute dog in a blanket" interactive src="/sample-3.jpg"></swirl-image-grid-item>`,
21
+ slot: `
22
+ <swirl-image-grid-item alt="Cute dog in a blanket" interactive src="/sample.jpg"></swirl-image-grid-item>
23
+ <swirl-image-grid-item alt="Cute dog in a blanket" interactive src="/sample-2.jpg"></swirl-image-grid-item>
24
+ <swirl-image-grid-item alt="Cute dog in a blanket" interactive src="/sample-3.jpg"></swirl-image-grid-item>
25
+ `,
24
26
  };
@@ -101,3 +101,13 @@ button.image-grid-item:focus-visible {
101
101
  font-size: var(--s-font-size-2xl);
102
102
  inset: 0;
103
103
  }
104
+
105
+ .image-grid-item__spinner {
106
+ position: absolute;
107
+ z-index: 3;
108
+ display: flex;
109
+ justify-content: center;
110
+ align-items: center;
111
+ background-color: rgba(0, 0, 0, 0.4);
112
+ inset: 0;
113
+ }
@@ -2,18 +2,51 @@ import { h, Host } from "@stencil/core";
2
2
  import classnames from "classnames";
3
3
  export class SwirlImageGridItem {
4
4
  constructor() {
5
+ this.onLoad = () => {
6
+ this.loaded = true;
7
+ console.log(this.loaded);
8
+ };
5
9
  this.alt = undefined;
6
10
  this.icon = undefined;
7
11
  this.interactive = undefined;
12
+ this.loading = undefined;
8
13
  this.overlay = undefined;
9
14
  this.src = undefined;
15
+ this.loaded = false;
16
+ this.inViewport = false;
17
+ }
18
+ componentDidLoad() {
19
+ this.setupIntersectionObserver();
20
+ }
21
+ disconnectedCallback() {
22
+ this.intersectionObserver?.disconnect();
23
+ }
24
+ setupIntersectionObserver() {
25
+ if (this.loading !== "intersecting") {
26
+ return;
27
+ }
28
+ this.intersectionObserver = new IntersectionObserver(this.onVisibilityChange.bind(this), {
29
+ threshold: 0,
30
+ });
31
+ this.intersectionObserver.observe(this.el);
32
+ }
33
+ onVisibilityChange(entries) {
34
+ if (entries[0].isIntersecting) {
35
+ this.inViewport = true;
36
+ }
10
37
  }
11
38
  render() {
12
39
  const Tag = this.interactive ? "button" : "div";
13
40
  const className = classnames("image-grid-item", {
14
41
  "image-grid-item--has-overlay": this.overlay,
15
42
  });
16
- return (h(Host, { role: "listitem" }, h(Tag, { class: className, type: this.interactive ? "button" : undefined }, h("div", { class: "image-grid-item__background", style: { backgroundImage: `url(${this.src})` } }), h("img", { alt: this.alt, class: "image-grid-item__image", src: this.src }), this.icon && !Boolean(this.overlay) && (h("div", { class: "image-grid-item__icon", innerHTML: this.icon })), this.overlay && (h("div", { class: "image-grid-item__overlay" }, this.overlay)))));
43
+ return (h(Host, { role: "listitem" }, h(Tag, { class: className, type: this.interactive ? "button" : undefined }, h("div", { class: "image-grid-item__background", style: {
44
+ backgroundImage: !Boolean(this.loading) ||
45
+ this.loading === "eager" ||
46
+ this.loaded
47
+ ? `url(${this.src})`
48
+ : undefined,
49
+ } }), (this.loading !== "intersecting" || this.inViewport) && (h("img", { alt: this.alt, class: "image-grid-item__image", loading: this.loading !== "intersecting" ? this.loading : undefined, onLoad: this.onLoad, src: this.src })), this.loaded && this.icon && !Boolean(this.overlay) && (h("div", { class: "image-grid-item__icon", innerHTML: this.icon })), this.overlay && (h("div", { class: "image-grid-item__overlay" }, this.overlay)), !this.loaded && (h("div", { class: "image-grid-item__spinner" }, h("swirl-spinner", null))))));
17
50
  }
18
51
  static get is() { return "swirl-image-grid-item"; }
19
52
  static get encapsulation() { return "shadow"; }
@@ -80,6 +113,28 @@ export class SwirlImageGridItem {
80
113
  "attribute": "interactive",
81
114
  "reflect": false
82
115
  },
116
+ "loading": {
117
+ "type": "string",
118
+ "mutable": false,
119
+ "complexType": {
120
+ "original": "SwirlImageGridItemLoading",
121
+ "resolved": "\"auto\" | \"eager\" | \"intersecting\" | \"lazy\"",
122
+ "references": {
123
+ "SwirlImageGridItemLoading": {
124
+ "location": "local",
125
+ "path": "/home/runner/work/swirl/swirl/packages/swirl-components/src/components/swirl-image-grid-item/swirl-image-grid-item.tsx"
126
+ }
127
+ }
128
+ },
129
+ "required": false,
130
+ "optional": true,
131
+ "docs": {
132
+ "tags": [],
133
+ "text": ""
134
+ },
135
+ "attribute": "loading",
136
+ "reflect": false
137
+ },
83
138
  "overlay": {
84
139
  "type": "string",
85
140
  "mutable": false,
@@ -116,4 +171,11 @@ export class SwirlImageGridItem {
116
171
  }
117
172
  };
118
173
  }
174
+ static get states() {
175
+ return {
176
+ "loaded": {},
177
+ "inViewport": {}
178
+ };
179
+ }
180
+ static get elementRef() { return "el"; }
119
181
  }
@@ -12,6 +12,9 @@ describe("swirl-image-grid-item", () => {
12
12
  <div class="image-grid-item">
13
13
  <div class="image-grid-item__background" style="background-image: url(/image.jpg);"></div>
14
14
  <img alt="Dog in a blanket" class="image-grid-item__image" src="/image.jpg">
15
+ <div class="image-grid-item__spinner">
16
+ <swirl-spinner></swirl-spinner>
17
+ </div>
15
18
  </div>
16
19
  </mock:shadow-root>
17
20
  </swirl-image-grid-item>
@@ -130,6 +130,21 @@
130
130
  }
131
131
  }
132
132
 
133
+ @media (min-width: 768px) {
134
+
135
+ .popover--transparent .popover__content {
136
+ background-color: transparent;
137
+ box-shadow: none
138
+ }
139
+ }
140
+
141
+ @media (min-width: 768px) {
142
+
143
+ .popover--transparent .popover__scroll-container {
144
+ padding: 0
145
+ }
146
+ }
147
+
133
148
  .popover__backdrop {
134
149
  position: fixed;
135
150
  z-index: 0;
@@ -57,6 +57,7 @@ export class SwirlPopover {
57
57
  this.popoverId = undefined;
58
58
  this.placement = "bottom-start";
59
59
  this.returnFocusToTrigger = true;
60
+ this.transparent = undefined;
60
61
  this.trigger = undefined;
61
62
  this.triggerContainer = undefined;
62
63
  this.useContainerWidth = undefined;
@@ -242,10 +243,11 @@ export class SwirlPopover {
242
243
  render() {
243
244
  const mobile = !window.matchMedia("(min-width: 768px)").matches;
244
245
  const className = classnames("popover", `popover--animation-${this.animation}`, `popover--placement-${this.position?.placement}`, {
245
- "popover--closing": this.closing,
246
246
  "popover--active": this.active,
247
+ "popover--closing": this.closing,
247
248
  "popover--fullscreen-bottom-sheet": this.fullscreenBottomSheet,
248
249
  "popover--inactive": !this.active,
250
+ "popover--transparent": this.transparent,
249
251
  });
250
252
  return (h(Host, null, h("div", { class: className, onKeyDown: this.onKeydown }, h("div", { "aria-hidden": !this.active ? "true" : "false", "aria-label": this.label, class: "popover__content", id: this.popoverId, part: "popover__content", role: "dialog", ref: (el) => (this.contentContainer = el), style: {
251
253
  top: Boolean(this.position) ? `${this.position?.y}px` : "",
@@ -456,6 +458,23 @@ export class SwirlPopover {
456
458
  "reflect": false,
457
459
  "defaultValue": "true"
458
460
  },
461
+ "transparent": {
462
+ "type": "boolean",
463
+ "mutable": false,
464
+ "complexType": {
465
+ "original": "boolean",
466
+ "resolved": "boolean",
467
+ "references": {}
468
+ },
469
+ "required": false,
470
+ "optional": true,
471
+ "docs": {
472
+ "tags": [],
473
+ "text": ""
474
+ },
475
+ "attribute": "transparent",
476
+ "reflect": false
477
+ },
459
478
  "trigger": {
460
479
  "type": "string",
461
480
  "mutable": false,