@spectrum-web-components/card 1.0.0 → 1.0.1-color-testing

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 (50) hide show
  1. package/README.md +95 -90
  2. package/package.json +54 -38
  3. package/sp-card.dev.js +5 -0
  4. package/sp-card.dev.js.map +7 -0
  5. package/sp-card.js +2 -14
  6. package/sp-card.js.map +7 -1
  7. package/src/Card.d.ts +27 -6
  8. package/src/Card.dev.js +303 -0
  9. package/src/Card.dev.js.map +7 -0
  10. package/src/Card.js +60 -206
  11. package/src/Card.js.map +7 -1
  12. package/src/card-overrides.css.d.ts +2 -0
  13. package/src/card-overrides.css.dev.js +7 -0
  14. package/src/card-overrides.css.dev.js.map +7 -0
  15. package/src/card-overrides.css.js +4 -0
  16. package/src/card-overrides.css.js.map +7 -0
  17. package/src/card.css.dev.js +7 -0
  18. package/src/card.css.dev.js.map +7 -0
  19. package/src/card.css.js +4 -21
  20. package/src/card.css.js.map +7 -1
  21. package/src/index.dev.js +3 -0
  22. package/src/index.dev.js.map +7 -0
  23. package/src/index.js +2 -13
  24. package/src/index.js.map +7 -1
  25. package/src/spectrum-card.css.dev.js +7 -0
  26. package/src/spectrum-card.css.dev.js.map +7 -0
  27. package/src/spectrum-card.css.js +4 -21
  28. package/src/spectrum-card.css.js.map +7 -1
  29. package/src/spectrum-config.js +54 -96
  30. package/stories/card.stories.js +385 -0
  31. package/stories/card.stories.js.map +7 -0
  32. package/stories/images.js +4 -0
  33. package/stories/images.js.map +7 -0
  34. package/test/benchmark/test-basic.js +16 -0
  35. package/test/benchmark/test-basic.js.map +7 -0
  36. package/test/card-memory.test.js +5 -0
  37. package/test/card-memory.test.js.map +7 -0
  38. package/test/card.test-vrt.js +5 -0
  39. package/test/card.test-vrt.js.map +7 -0
  40. package/test/card.test.js +353 -0
  41. package/test/card.test.js.map +7 -0
  42. package/CHANGELOG.md +0 -123
  43. package/custom-elements.json +0 -153
  44. package/src/Card.ts +0 -237
  45. package/src/card.css +0 -58
  46. package/src/card.css.ts +0 -20
  47. package/src/index.ts +0 -12
  48. package/src/spectrum-card.css +0 -812
  49. package/src/spectrum-card.css.ts +0 -20
  50. package/src/spectrum-vars.json +0 -52
@@ -0,0 +1,303 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __decorateClass = (decorators, target, key, kind) => {
5
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
6
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
7
+ if (decorator = decorators[i])
8
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
9
+ if (kind && result) __defProp(target, key, result);
10
+ return result;
11
+ };
12
+ import {
13
+ html,
14
+ nothing,
15
+ SizedMixin,
16
+ SpectrumElement
17
+ } from "@spectrum-web-components/base";
18
+ import { ifDefined } from "@spectrum-web-components/base/src/directives.js";
19
+ import {
20
+ property,
21
+ query
22
+ } from "@spectrum-web-components/base/src/decorators.js";
23
+ import { FocusVisiblePolyfillMixin } from "@spectrum-web-components/shared/src/focus-visible.js";
24
+ import { ObserveSlotPresence } from "@spectrum-web-components/shared/src/observe-slot-presence.js";
25
+ import { LikeAnchor } from "@spectrum-web-components/shared/src/like-anchor.js";
26
+ import "@spectrum-web-components/asset/sp-asset.js";
27
+ import "@spectrum-web-components/checkbox/sp-checkbox.js";
28
+ import "@spectrum-web-components/popover/sp-popover.js";
29
+ import "@spectrum-web-components/divider/sp-divider.js";
30
+ import cardStyles from "./card.css.js";
31
+ import headingStyles from "@spectrum-web-components/styles/heading.js";
32
+ import detailStyles from "@spectrum-web-components/styles/detail.js";
33
+ export class Card extends LikeAnchor(
34
+ SizedMixin(
35
+ ObserveSlotPresence(FocusVisiblePolyfillMixin(SpectrumElement), [
36
+ '[slot="cover-photo"]',
37
+ '[slot="preview"]'
38
+ ]),
39
+ {
40
+ validSizes: ["s", "m"],
41
+ noDefaultSize: true
42
+ }
43
+ )
44
+ ) {
45
+ constructor() {
46
+ super(...arguments);
47
+ this.variant = "standard";
48
+ this._selected = false;
49
+ this.heading = "";
50
+ this.horizontal = false;
51
+ this.focused = false;
52
+ this.toggles = false;
53
+ this.value = "";
54
+ this.subheading = "";
55
+ this.handleFocusin = (event) => {
56
+ this.focused = true;
57
+ const target = event.composedPath()[0];
58
+ if (target !== this) {
59
+ this.removeEventListener("keydown", this.handleKeydown);
60
+ return;
61
+ }
62
+ this.addEventListener("keydown", this.handleKeydown);
63
+ };
64
+ }
65
+ static get styles() {
66
+ return [headingStyles, detailStyles, cardStyles];
67
+ }
68
+ get selected() {
69
+ return this._selected;
70
+ }
71
+ set selected(selected) {
72
+ if (selected === this.selected) return;
73
+ this._selected = selected;
74
+ this.requestUpdate("selected", !this._selected);
75
+ }
76
+ get hasCoverPhoto() {
77
+ return this.getSlotContentPresence('[slot="cover-photo"]');
78
+ }
79
+ get hasPreview() {
80
+ return this.getSlotContentPresence('[slot="preview"]');
81
+ }
82
+ click() {
83
+ var _a;
84
+ (_a = this.likeAnchor) == null ? void 0 : _a.click();
85
+ }
86
+ handleFocusout(event) {
87
+ this.focused = false;
88
+ const target = event.composedPath()[0];
89
+ if (target === this) {
90
+ this.removeEventListener("keydown", this.handleKeydown);
91
+ }
92
+ }
93
+ handleKeydown(event) {
94
+ const { code } = event;
95
+ switch (code) {
96
+ case "Space":
97
+ this.toggleSelected();
98
+ if (this.toggles) {
99
+ event.preventDefault();
100
+ break;
101
+ }
102
+ case "Enter":
103
+ case "NumpadEnter":
104
+ this.click();
105
+ }
106
+ }
107
+ handleSelectedChange(event) {
108
+ event.stopPropagation();
109
+ this.selected = event.target.checked;
110
+ this.announceChange();
111
+ }
112
+ toggleSelected() {
113
+ if (!this.toggles) {
114
+ this.dispatchEvent(
115
+ new Event("click", {
116
+ bubbles: true,
117
+ composed: true
118
+ })
119
+ );
120
+ return;
121
+ }
122
+ this.selected = !this.selected;
123
+ this.announceChange();
124
+ }
125
+ announceChange() {
126
+ const applyDefault = this.dispatchEvent(
127
+ new Event("change", {
128
+ cancelable: true,
129
+ bubbles: true,
130
+ composed: true
131
+ })
132
+ );
133
+ if (!applyDefault) {
134
+ this.selected = !this.selected;
135
+ }
136
+ }
137
+ stopPropagationOnHref(event) {
138
+ if (this.href) {
139
+ event.stopPropagation();
140
+ }
141
+ }
142
+ handlePointerdown(event) {
143
+ const path = event.composedPath();
144
+ const hasAnchor = path.some(
145
+ (el) => el.localName === "a"
146
+ );
147
+ if (hasAnchor) return;
148
+ const start = +/* @__PURE__ */ new Date();
149
+ const handleEnd = () => {
150
+ const end = +/* @__PURE__ */ new Date();
151
+ if (end - start < 200) {
152
+ this.click();
153
+ }
154
+ this.removeEventListener("pointerup", handleEnd);
155
+ this.removeEventListener("pointercancel", handleEnd);
156
+ };
157
+ this.addEventListener("pointerup", handleEnd);
158
+ this.addEventListener("pointercancel", handleEnd);
159
+ }
160
+ get renderHeading() {
161
+ return html`
162
+ <div
163
+ class="title spectrum-Heading spectrum-Heading--sizeXS"
164
+ id="heading"
165
+ >
166
+ <slot name="heading">${this.heading}</slot>
167
+ </div>
168
+ `;
169
+ }
170
+ get renderPreviewImage() {
171
+ return html`
172
+ <sp-asset id="preview" variant=${ifDefined(this.asset)}>
173
+ <slot name="preview"></slot>
174
+ </sp-asset>
175
+ ${this.variant !== "quiet" && !this.horizontal ? html`
176
+ <sp-divider size="s"></sp-divider>
177
+ ` : nothing}
178
+ `;
179
+ }
180
+ get renderCoverImage() {
181
+ return html`
182
+ <sp-asset id="cover-photo" variant=${ifDefined(this.asset)}>
183
+ <slot name="cover-photo"></slot>
184
+ </sp-asset>
185
+ ${this.variant !== "quiet" && !this.horizontal ? html`
186
+ <sp-divider size="s"></sp-divider>
187
+ ` : nothing}
188
+ `;
189
+ }
190
+ get images() {
191
+ const images = [];
192
+ if (this.hasPreview) images.push(this.renderPreviewImage);
193
+ if (this.hasCoverPhoto) images.push(this.renderCoverImage);
194
+ return images;
195
+ }
196
+ renderImage() {
197
+ if (this.horizontal) {
198
+ return this.images;
199
+ }
200
+ if (this.variant !== "standard") {
201
+ return [this.renderPreviewImage];
202
+ }
203
+ return this.images;
204
+ }
205
+ get renderSubtitleAndDescription() {
206
+ return html`
207
+ <div class="subtitle spectrum-Detail spectrum-Detail--sizeS">
208
+ <slot name="subheading">${this.subheading}</slot>
209
+ </div>
210
+ <slot name="description"></slot>
211
+ `;
212
+ }
213
+ render() {
214
+ return html`
215
+ ${this.renderImage()}
216
+ <div class="body">
217
+ <div class="header">
218
+ ${this.renderHeading}
219
+ ${this.variant === "gallery" ? this.renderSubtitleAndDescription : nothing}
220
+ ${this.variant !== "quiet" || this.size !== "s" ? html`
221
+ <div
222
+ class="action-button"
223
+ @pointerdown=${this.stopPropagationOnHref}
224
+ >
225
+ <slot name="actions"></slot>
226
+ </div>
227
+ ` : nothing}
228
+ </div>
229
+ ${this.variant !== "gallery" ? html`
230
+ <div class="content">
231
+ ${this.renderSubtitleAndDescription}
232
+ </div>
233
+ ` : nothing}
234
+ </div>
235
+ ${this.href ? this.renderAnchor({
236
+ id: "like-anchor",
237
+ labelledby: "heading"
238
+ }) : nothing}
239
+ ${this.variant === "standard" ? html`
240
+ <slot name="footer"></slot>
241
+ ` : nothing}
242
+ ${this.toggles ? html`
243
+ <sp-popover
244
+ class="checkbox-toggle"
245
+ @pointerdown=${this.stopPropagationOnHref}
246
+ >
247
+ <sp-checkbox
248
+ class="checkbox"
249
+ @change=${this.handleSelectedChange}
250
+ ?checked=${this.selected}
251
+ tabindex="-1"
252
+ ></sp-checkbox>
253
+ </sp-popover>
254
+ ` : nothing}
255
+ ${this.variant === "quiet" && this.size === "s" ? html`
256
+ <div
257
+ class="spectrum-QuickActions actions"
258
+ @pointerdown=${this.stopPropagationOnHref}
259
+ >
260
+ <slot name="actions"></slot>
261
+ </div>
262
+ ` : nothing}
263
+ `;
264
+ }
265
+ firstUpdated(changes) {
266
+ super.firstUpdated(changes);
267
+ this.addEventListener("pointerdown", this.handlePointerdown);
268
+ this.addEventListener("focusin", this.handleFocusin);
269
+ this.shadowRoot.addEventListener("focusin", this.handleFocusin);
270
+ this.addEventListener("focusout", this.handleFocusout);
271
+ }
272
+ }
273
+ __decorateClass([
274
+ property()
275
+ ], Card.prototype, "asset", 2);
276
+ __decorateClass([
277
+ property({ reflect: true })
278
+ ], Card.prototype, "variant", 2);
279
+ __decorateClass([
280
+ property({ type: Boolean, reflect: true })
281
+ ], Card.prototype, "selected", 1);
282
+ __decorateClass([
283
+ property()
284
+ ], Card.prototype, "heading", 2);
285
+ __decorateClass([
286
+ property({ type: Boolean, reflect: true })
287
+ ], Card.prototype, "horizontal", 2);
288
+ __decorateClass([
289
+ query("#like-anchor")
290
+ ], Card.prototype, "likeAnchor", 2);
291
+ __decorateClass([
292
+ property({ type: Boolean, reflect: true })
293
+ ], Card.prototype, "focused", 2);
294
+ __decorateClass([
295
+ property({ type: Boolean, reflect: true })
296
+ ], Card.prototype, "toggles", 2);
297
+ __decorateClass([
298
+ property()
299
+ ], Card.prototype, "value", 2);
300
+ __decorateClass([
301
+ property()
302
+ ], Card.prototype, "subheading", 2);
303
+ //# sourceMappingURL=Card.dev.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["Card.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 CSSResultArray,\n html,\n nothing,\n PropertyValues,\n SizedMixin,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { FocusVisiblePolyfillMixin } from '@spectrum-web-components/shared/src/focus-visible.js';\nimport { ObserveSlotPresence } from '@spectrum-web-components/shared/src/observe-slot-presence.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport '@spectrum-web-components/asset/sp-asset.js';\n\nimport { Checkbox } from '@spectrum-web-components/checkbox/src/Checkbox';\nimport '@spectrum-web-components/checkbox/sp-checkbox.js';\nimport '@spectrum-web-components/popover/sp-popover.js';\nimport '@spectrum-web-components/divider/sp-divider.js';\nimport cardStyles from './card.css.js';\nimport headingStyles from '@spectrum-web-components/styles/heading.js';\nimport detailStyles from '@spectrum-web-components/styles/detail.js';\n\n/**\n * @element sp-card\n *\n * @fires change - Announces a change in the `selected` property of a card\n * @slot preview - This is the preview image for Gallery Cards\n * @slot cover-photo - This is the cover photo for Default and Quiet Cards\n * @slot heading - HTML content to be listed as the heading\n * @slot subheading - HTML content to be listed as the subheading\n * @slot description - A description of the card\n * @slot actions - an `sp-action-menu` element outlining actions to take on the represened object\n * @slot footer - Footer text\n */\nexport class Card extends LikeAnchor(\n SizedMixin(\n ObserveSlotPresence(FocusVisiblePolyfillMixin(SpectrumElement), [\n '[slot=\"cover-photo\"]',\n '[slot=\"preview\"]',\n ]),\n {\n validSizes: ['s', 'm'],\n noDefaultSize: true,\n }\n )\n) {\n public static override get styles(): CSSResultArray {\n return [headingStyles, detailStyles, cardStyles];\n }\n\n @property()\n public asset?: 'file' | 'folder';\n\n @property({ reflect: true })\n public variant: 'standard' | 'gallery' | 'quiet' = 'standard';\n\n @property({ type: Boolean, reflect: true })\n get selected(): boolean {\n return this._selected;\n }\n set selected(selected: boolean) {\n if (selected === this.selected) return;\n this._selected = selected;\n this.requestUpdate('selected', !this._selected);\n }\n\n private _selected = false;\n\n @property()\n public heading = '';\n\n @property({ type: Boolean, reflect: true })\n public horizontal = false;\n\n @query('#like-anchor')\n private likeAnchor?: HTMLAnchorElement;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: Boolean, reflect: true })\n public toggles = false;\n\n @property()\n public value = '';\n\n @property()\n public subheading = '';\n\n protected get hasCoverPhoto(): boolean {\n return this.getSlotContentPresence('[slot=\"cover-photo\"]');\n }\n\n protected get hasPreview(): boolean {\n return this.getSlotContentPresence('[slot=\"preview\"]');\n }\n\n public override click(): void {\n this.likeAnchor?.click();\n }\n\n private handleFocusin = (event: Event): void => {\n this.focused = true;\n const target = event.composedPath()[0];\n if (target !== this) {\n this.removeEventListener('keydown', this.handleKeydown);\n return;\n }\n this.addEventListener('keydown', this.handleKeydown);\n };\n\n private handleFocusout(event: Event): void {\n this.focused = false;\n const target = event.composedPath()[0];\n if (target === this) {\n this.removeEventListener('keydown', this.handleKeydown);\n }\n }\n\n private handleKeydown(event: KeyboardEvent): void {\n const { code } = event;\n switch (code) {\n case 'Space':\n this.toggleSelected();\n if (this.toggles) {\n event.preventDefault();\n break;\n }\n case 'Enter':\n case 'NumpadEnter':\n this.click();\n }\n }\n\n private handleSelectedChange(event: Event & { target: Checkbox }): void {\n event.stopPropagation();\n this.selected = event.target.checked;\n this.announceChange();\n }\n\n public toggleSelected(): void {\n if (!this.toggles) {\n this.dispatchEvent(\n new Event('click', {\n bubbles: true,\n composed: true,\n })\n );\n return;\n }\n this.selected = !this.selected;\n this.announceChange();\n }\n\n private announceChange(): void {\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n cancelable: true,\n bubbles: true,\n composed: true,\n })\n );\n if (!applyDefault) {\n this.selected = !this.selected;\n }\n }\n\n private stopPropagationOnHref(event: Event): void {\n if (this.href) {\n event.stopPropagation();\n }\n }\n\n private handlePointerdown(event: Event): void {\n const path = event.composedPath();\n const hasAnchor = path.some(\n (el) => (el as HTMLElement).localName === 'a'\n );\n if (hasAnchor) return;\n const start = +new Date();\n const handleEnd = (): void => {\n const end = +new Date();\n if (end - start < 200) {\n this.click();\n }\n this.removeEventListener('pointerup', handleEnd);\n this.removeEventListener('pointercancel', handleEnd);\n };\n this.addEventListener('pointerup', handleEnd);\n this.addEventListener('pointercancel', handleEnd);\n }\n\n protected get renderHeading(): TemplateResult {\n return html`\n <div\n class=\"title spectrum-Heading spectrum-Heading--sizeXS\"\n id=\"heading\"\n >\n <slot name=\"heading\">${this.heading}</slot>\n </div>\n `;\n }\n\n protected get renderPreviewImage(): TemplateResult {\n return html`\n <sp-asset id=\"preview\" variant=${ifDefined(this.asset)}>\n <slot name=\"preview\"></slot>\n </sp-asset>\n ${this.variant !== 'quiet' && !this.horizontal\n ? html`\n <sp-divider size=\"s\"></sp-divider>\n `\n : nothing}\n `;\n }\n\n protected get renderCoverImage(): TemplateResult {\n return html`\n <sp-asset id=\"cover-photo\" variant=${ifDefined(this.asset)}>\n <slot name=\"cover-photo\"></slot>\n </sp-asset>\n ${this.variant !== 'quiet' && !this.horizontal\n ? html`\n <sp-divider size=\"s\"></sp-divider>\n `\n : nothing}\n `;\n }\n\n protected get images(): TemplateResult[] {\n const images: TemplateResult[] = [];\n if (this.hasPreview) images.push(this.renderPreviewImage);\n if (this.hasCoverPhoto) images.push(this.renderCoverImage);\n return images;\n }\n\n private renderImage(): TemplateResult[] {\n if (this.horizontal) {\n return this.images;\n }\n if (this.variant !== 'standard') {\n return [this.renderPreviewImage];\n }\n return this.images;\n }\n\n private get renderSubtitleAndDescription(): TemplateResult {\n return html`\n <div class=\"subtitle spectrum-Detail spectrum-Detail--sizeS\">\n <slot name=\"subheading\">${this.subheading}</slot>\n </div>\n <slot name=\"description\"></slot>\n `;\n }\n\n protected override render(): TemplateResult {\n return html`\n ${this.renderImage()}\n <div class=\"body\">\n <div class=\"header\">\n ${this.renderHeading}\n ${this.variant === 'gallery'\n ? this.renderSubtitleAndDescription\n : nothing}\n ${this.variant !== 'quiet' || this.size !== 's'\n ? html`\n <div\n class=\"action-button\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </div>\n `\n : nothing}\n </div>\n ${this.variant !== 'gallery'\n ? html`\n <div class=\"content\">\n ${this.renderSubtitleAndDescription}\n </div>\n `\n : nothing}\n </div>\n ${this.href\n ? this.renderAnchor({\n id: 'like-anchor',\n labelledby: 'heading',\n })\n : nothing}\n ${this.variant === 'standard'\n ? html`\n <slot name=\"footer\"></slot>\n `\n : nothing}\n ${this.toggles\n ? html`\n <sp-popover\n class=\"checkbox-toggle\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <sp-checkbox\n class=\"checkbox\"\n @change=${this.handleSelectedChange}\n ?checked=${this.selected}\n tabindex=\"-1\"\n ></sp-checkbox>\n </sp-popover>\n `\n : nothing}\n ${this.variant === 'quiet' && this.size === 's'\n ? html`\n <div\n class=\"spectrum-QuickActions actions\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </div>\n `\n : nothing}\n `;\n }\n\n protected override firstUpdated(changes: PropertyValues): void {\n super.firstUpdated(changes);\n this.addEventListener('pointerdown', this.handlePointerdown);\n this.addEventListener('focusin', this.handleFocusin);\n this.shadowRoot.addEventListener('focusin', this.handleFocusin);\n this.addEventListener('focusout', this.handleFocusout);\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
package/src/Card.js CHANGED
@@ -1,220 +1,74 @@
1
- /*
2
- Copyright 2020 Adobe. All rights reserved.
3
- This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- you may not use this file except in compliance with the License. You may obtain a copy
5
- of the License at http://www.apache.org/licenses/LICENSE-2.0
6
-
7
- Unless required by applicable law or agreed to in writing, software distributed under
8
- the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- OF ANY KIND, either express or implied. See the License for the specific language
10
- governing permissions and limitations under the License.
11
- */
12
- import { __decorate } from "tslib";
13
- import { html, SpectrumElement, property, ifDefined, } from '@spectrum-web-components/base';
14
- import { FocusVisiblePolyfillMixin } from '@spectrum-web-components/shared/src/focus-visible.js';
15
- import '@spectrum-web-components/asset/sp-asset.js';
16
- // import { MoreIcon } from '@spectrum-web-components/icons-workflow';
17
- import '@spectrum-web-components/checkbox/sp-checkbox.js';
18
- import '@spectrum-web-components/quick-actions/sp-quick-actions.js';
19
- import cardStyles from './card.css.js';
20
- /**
21
- * @element sp-card
22
- *
23
- * @fires change - Announces a change in the `selected` property of a card
24
- * @slot preview - This is the preview image for Gallery Cards
25
- * @slot cover-photo - This is the cover photo for Default and Quiet Cards
26
- * @slot heading - HTML content to be listed as the heading
27
- * @slot subheading - HTML content to be listed as the subheading
28
- * @slot description - A description of the card
29
- * @slot actions - an `sp-action-menu` element outlining actions to take on the represened object
30
- * @slot footer - Footer text
31
- */
32
- export class Card extends FocusVisiblePolyfillMixin(SpectrumElement) {
33
- constructor() {
34
- super();
35
- this.variant = 'standard';
36
- this.selected = false;
37
- this.heading = '';
38
- this.horizontal = false;
39
- this.small = false;
40
- this.focused = false;
41
- this.toggles = false;
42
- this.subheading = '';
43
- this.handleFocusin = (event) => {
44
- this.focused = true;
45
- const target = event.composedPath()[0];
46
- if (target !== this) {
47
- this.removeEventListener('keydown', this.handleKeydown);
48
- return;
49
- }
50
- this.addEventListener('keydown', this.handleKeydown);
51
- };
52
- this.addEventListener('focusin', this.handleFocusin);
53
- this.shadowRoot.addEventListener('focusin', this.handleFocusin);
54
- this.addEventListener('focusout', this.handleFocusout);
55
- }
56
- static get styles() {
57
- return [cardStyles];
58
- }
59
- handleFocusout(event) {
60
- this.focused = false;
61
- const target = event.composedPath()[0];
62
- if (target === this) {
63
- this.removeEventListener('keydown', this.handleKeydown);
64
- }
65
- }
66
- handleKeydown(event) {
67
- const { code } = event;
68
- /* istanbul ignore else */
69
- if (code === 'Space') {
70
- this.toggleSelected();
71
- }
72
- }
73
- handleSelectedChange(event) {
74
- const { target } = event;
75
- this.selected = target.checked;
76
- }
77
- toggleSelected() {
78
- if (!this.toggles) {
79
- this.dispatchEvent(new Event('click', {
80
- bubbles: true,
81
- composed: true,
82
- }));
83
- return;
84
- }
85
- this.selected = !this.selected;
86
- const applyDefault = this.dispatchEvent(new Event('change', {
87
- cancelable: true,
88
- }));
89
- if (!applyDefault) {
90
- this.selected = !this.selected;
91
- }
92
- }
93
- get renderHeading() {
94
- return html `
95
- <div class="title">
96
- <slot name="heading">
97
- ${this.heading}
98
- </slot>
1
+ "use strict";var u=Object.defineProperty;var v=Object.getOwnPropertyDescriptor;var i=(h,l,e,s)=>{for(var n=s>1?void 0:s?v(l,e):l,d=h.length-1,a;d>=0;d--)(a=h[d])&&(n=(s?a(l,e,n):a(n))||n);return s&&n&&u(l,e,n),n};import{html as t,nothing as r,SizedMixin as m,SpectrumElement as g}from"@spectrum-web-components/base";import{ifDefined as p}from"@spectrum-web-components/base/src/directives.js";import{property as o,query as f}from"@spectrum-web-components/base/src/decorators.js";import{FocusVisiblePolyfillMixin as b}from"@spectrum-web-components/shared/src/focus-visible.js";import{ObserveSlotPresence as y}from"@spectrum-web-components/shared/src/observe-slot-presence.js";import{LikeAnchor as w}from"@spectrum-web-components/shared/src/like-anchor.js";import"@spectrum-web-components/asset/sp-asset.js";import"@spectrum-web-components/checkbox/sp-checkbox.js";import"@spectrum-web-components/popover/sp-popover.js";import"@spectrum-web-components/divider/sp-divider.js";import E from"./card.css.js";import P from"@spectrum-web-components/styles/heading.js";import S from"@spectrum-web-components/styles/detail.js";export class Card extends w(m(y(b(g),['[slot="cover-photo"]','[slot="preview"]']),{validSizes:["s","m"],noDefaultSize:!0})){constructor(){super(...arguments);this.variant="standard";this._selected=!1;this.heading="";this.horizontal=!1;this.focused=!1;this.toggles=!1;this.value="";this.subheading="";this.handleFocusin=e=>{if(this.focused=!0,e.composedPath()[0]!==this){this.removeEventListener("keydown",this.handleKeydown);return}this.addEventListener("keydown",this.handleKeydown)}}static get styles(){return[P,S,E]}get selected(){return this._selected}set selected(e){e!==this.selected&&(this._selected=e,this.requestUpdate("selected",!this._selected))}get hasCoverPhoto(){return this.getSlotContentPresence('[slot="cover-photo"]')}get hasPreview(){return this.getSlotContentPresence('[slot="preview"]')}click(){var e;(e=this.likeAnchor)==null||e.click()}handleFocusout(e){this.focused=!1,e.composedPath()[0]===this&&this.removeEventListener("keydown",this.handleKeydown)}handleKeydown(e){const{code:s}=e;switch(s){case"Space":if(this.toggleSelected(),this.toggles){e.preventDefault();break}case"Enter":case"NumpadEnter":this.click()}}handleSelectedChange(e){e.stopPropagation(),this.selected=e.target.checked,this.announceChange()}toggleSelected(){if(!this.toggles){this.dispatchEvent(new Event("click",{bubbles:!0,composed:!0}));return}this.selected=!this.selected,this.announceChange()}announceChange(){this.dispatchEvent(new Event("change",{cancelable:!0,bubbles:!0,composed:!0}))||(this.selected=!this.selected)}stopPropagationOnHref(e){this.href&&e.stopPropagation()}handlePointerdown(e){if(e.composedPath().some(c=>c.localName==="a"))return;const d=+new Date,a=()=>{+new Date-d<200&&this.click(),this.removeEventListener("pointerup",a),this.removeEventListener("pointercancel",a)};this.addEventListener("pointerup",a),this.addEventListener("pointercancel",a)}get renderHeading(){return t`
2
+ <div
3
+ class="title spectrum-Heading spectrum-Heading--sizeXS"
4
+ id="heading"
5
+ >
6
+ <slot name="heading">${this.heading}</slot>
99
7
  </div>
100
- `;
101
- }
102
- get renderPreviewImage() {
103
- return html `
104
- <sp-asset id="preview" variant=${ifDefined(this.asset)}>
8
+ `}get renderPreviewImage(){return t`
9
+ <sp-asset id="preview" variant=${p(this.asset)}>
105
10
  <slot name="preview"></slot>
106
11
  </sp-asset>
107
- `;
108
- }
109
- renderImage() {
110
- if (this.horizontal) {
111
- return this.renderPreviewImage;
112
- }
113
- if (this.variant === 'standard') {
114
- return html `
115
- <sp-asset id="cover-photo" variant=${ifDefined(this.asset)}>
116
- <slot name="cover-photo"></slot>
117
- </sp-asset>
118
- `;
119
- }
120
- return this.renderPreviewImage;
121
- }
122
- render() {
123
- return html `
124
- ${this.toggles
125
- ? html `
126
- <sp-quick-actions
127
- class="spectrum-QuickActions quickActions"
128
- >
129
- <sp-checkbox
130
- tabindex="-1"
131
- class="checkbox"
132
- @change=${this.handleSelectedChange}
133
- ?checked=${this.selected}
134
- ></sp-checkbox>
135
- </sp-quick-actions>
136
- `
137
- : html ``}
138
- ${this.variant === 'quiet' && this.small
139
- ? html `
140
- <sp-quick-actions class="spectrum-QuickActions actions">
141
- <slot name="actions"></slot>
142
- </sp-quick-actions>
143
- `
144
- : html ``}
12
+ ${this.variant!=="quiet"&&!this.horizontal?t`
13
+ <sp-divider size="s"></sp-divider>
14
+ `:r}
15
+ `}get renderCoverImage(){return t`
16
+ <sp-asset id="cover-photo" variant=${p(this.asset)}>
17
+ <slot name="cover-photo"></slot>
18
+ </sp-asset>
19
+ ${this.variant!=="quiet"&&!this.horizontal?t`
20
+ <sp-divider size="s"></sp-divider>
21
+ `:r}
22
+ `}get images(){const e=[];return this.hasPreview&&e.push(this.renderPreviewImage),this.hasCoverPhoto&&e.push(this.renderCoverImage),e}renderImage(){return this.horizontal?this.images:this.variant!=="standard"?[this.renderPreviewImage]:this.images}get renderSubtitleAndDescription(){return t`
23
+ <div class="subtitle spectrum-Detail spectrum-Detail--sizeS">
24
+ <slot name="subheading">${this.subheading}</slot>
25
+ </div>
26
+ <slot name="description"></slot>
27
+ `}render(){return t`
145
28
  ${this.renderImage()}
146
29
  <div class="body">
147
30
  <div class="header">
148
31
  ${this.renderHeading}
149
- ${this.variant === 'gallery'
150
- ? html `
151
- <div class="subtitle">
152
- <slot name="subheading">
153
- ${this.subheading}
154
- </slot>
155
- </div>
156
- <slot name="description"></slot>
157
- `
158
- : html ``}
159
- ${this.variant !== 'quiet' || !this.small
160
- ? html `
161
- <div class="actionButton">
32
+ ${this.variant==="gallery"?this.renderSubtitleAndDescription:r}
33
+ ${this.variant!=="quiet"||this.size!=="s"?t`
34
+ <div
35
+ class="action-button"
36
+ @pointerdown=${this.stopPropagationOnHref}
37
+ >
162
38
  <slot name="actions"></slot>
163
39
  </div>
164
- `
165
- : html ``}
40
+ `:r}
166
41
  </div>
167
- ${this.variant !== 'gallery'
168
- ? html `
42
+ ${this.variant!=="gallery"?t`
169
43
  <div class="content">
170
- <div class="subtitle">
171
- <slot name="subheading">
172
- ${this.subheading}
173
- </slot>
174
- </div>
175
- <slot name="description"></slot>
44
+ ${this.renderSubtitleAndDescription}
176
45
  </div>
177
- `
178
- : html ``}
46
+ `:r}
179
47
  </div>
180
- ${this.variant === 'standard'
181
- ? html `
48
+ ${this.href?this.renderAnchor({id:"like-anchor",labelledby:"heading"}):r}
49
+ ${this.variant==="standard"?t`
182
50
  <slot name="footer"></slot>
183
- `
184
- : html ``}
185
- `;
186
- }
187
- firstUpdated(changes) {
188
- super.firstUpdated(changes);
189
- this.setAttribute('role', 'figure');
190
- this.tabIndex = 0;
191
- }
192
- }
193
- __decorate([
194
- property()
195
- ], Card.prototype, "asset", void 0);
196
- __decorate([
197
- property({ reflect: true })
198
- ], Card.prototype, "variant", void 0);
199
- __decorate([
200
- property({ type: Boolean, reflect: true })
201
- ], Card.prototype, "selected", void 0);
202
- __decorate([
203
- property()
204
- ], Card.prototype, "heading", void 0);
205
- __decorate([
206
- property({ type: Boolean, reflect: true })
207
- ], Card.prototype, "horizontal", void 0);
208
- __decorate([
209
- property({ type: Boolean, reflect: true })
210
- ], Card.prototype, "small", void 0);
211
- __decorate([
212
- property({ type: Boolean, reflect: true })
213
- ], Card.prototype, "focused", void 0);
214
- __decorate([
215
- property({ type: Boolean, reflect: true })
216
- ], Card.prototype, "toggles", void 0);
217
- __decorate([
218
- property()
219
- ], Card.prototype, "subheading", void 0);
220
- //# sourceMappingURL=Card.js.map
51
+ `:r}
52
+ ${this.toggles?t`
53
+ <sp-popover
54
+ class="checkbox-toggle"
55
+ @pointerdown=${this.stopPropagationOnHref}
56
+ >
57
+ <sp-checkbox
58
+ class="checkbox"
59
+ @change=${this.handleSelectedChange}
60
+ ?checked=${this.selected}
61
+ tabindex="-1"
62
+ ></sp-checkbox>
63
+ </sp-popover>
64
+ `:r}
65
+ ${this.variant==="quiet"&&this.size==="s"?t`
66
+ <div
67
+ class="spectrum-QuickActions actions"
68
+ @pointerdown=${this.stopPropagationOnHref}
69
+ >
70
+ <slot name="actions"></slot>
71
+ </div>
72
+ `:r}
73
+ `}firstUpdated(e){super.firstUpdated(e),this.addEventListener("pointerdown",this.handlePointerdown),this.addEventListener("focusin",this.handleFocusin),this.shadowRoot.addEventListener("focusin",this.handleFocusin),this.addEventListener("focusout",this.handleFocusout)}}i([o()],Card.prototype,"asset",2),i([o({reflect:!0})],Card.prototype,"variant",2),i([o({type:Boolean,reflect:!0})],Card.prototype,"selected",1),i([o()],Card.prototype,"heading",2),i([o({type:Boolean,reflect:!0})],Card.prototype,"horizontal",2),i([f("#like-anchor")],Card.prototype,"likeAnchor",2),i([o({type:Boolean,reflect:!0})],Card.prototype,"focused",2),i([o({type:Boolean,reflect:!0})],Card.prototype,"toggles",2),i([o()],Card.prototype,"value",2),i([o()],Card.prototype,"subheading",2);
74
+ //# sourceMappingURL=Card.js.map