@spectrum-web-components/card 0.37.0 → 0.39.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.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/card",
3
- "version": "0.37.0",
3
+ "version": "0.39.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -57,16 +57,16 @@
57
57
  "lit-html"
58
58
  ],
59
59
  "dependencies": {
60
- "@spectrum-web-components/asset": "^0.37.0",
61
- "@spectrum-web-components/base": "^0.37.0",
62
- "@spectrum-web-components/checkbox": "^0.37.0",
63
- "@spectrum-web-components/icons-workflow": "^0.37.0",
64
- "@spectrum-web-components/quick-actions": "^0.37.0",
65
- "@spectrum-web-components/shared": "^0.37.0",
66
- "@spectrum-web-components/styles": "^0.37.0"
60
+ "@spectrum-web-components/asset": "^0.39.0",
61
+ "@spectrum-web-components/base": "^0.39.0",
62
+ "@spectrum-web-components/checkbox": "^0.39.0",
63
+ "@spectrum-web-components/icons-workflow": "^0.39.0",
64
+ "@spectrum-web-components/quick-actions": "^0.39.0",
65
+ "@spectrum-web-components/shared": "^0.39.0",
66
+ "@spectrum-web-components/styles": "^0.39.0"
67
67
  },
68
68
  "devDependencies": {
69
- "@spectrum-css/card": "^6.0.9"
69
+ "@spectrum-css/card": "^6.0.18"
70
70
  },
71
71
  "types": "./src/index.d.ts",
72
72
  "customElements": "custom-elements.json",
@@ -74,5 +74,5 @@
74
74
  "./sp-*.js",
75
75
  "./**/*.dev.js"
76
76
  ],
77
- "gitHead": "d771f62f0d8063070af43283bb0fd5e3400bad06"
77
+ "gitHead": "2acc8390ef0ac6cc940958d4da705c9859155c0d"
78
78
  }
package/src/Card.dev.js CHANGED
@@ -12,6 +12,7 @@ var __decorateClass = (decorators, target, key, kind) => {
12
12
  };
13
13
  import {
14
14
  html,
15
+ nothing,
15
16
  SizedMixin,
16
17
  SpectrumElement
17
18
  } from "@spectrum-web-components/base";
@@ -37,7 +38,8 @@ export class Card extends LikeAnchor(
37
38
  '[slot="preview"]'
38
39
  ]),
39
40
  {
40
- validSizes: ["s", "m"]
41
+ validSizes: ["s", "m"],
42
+ noDefaultSize: true
41
43
  }
42
44
  )
43
45
  ) {
@@ -175,7 +177,7 @@ export class Card extends LikeAnchor(
175
177
  </sp-asset>
176
178
  ${this.variant !== "quiet" && !this.horizontal ? html`
177
179
  <sp-divider size="s"></sp-divider>
178
- ` : html``}
180
+ ` : nothing}
179
181
  `;
180
182
  }
181
183
  get renderCoverImage() {
@@ -185,7 +187,7 @@ export class Card extends LikeAnchor(
185
187
  </sp-asset>
186
188
  ${this.variant !== "quiet" && !this.horizontal ? html`
187
189
  <sp-divider size="s"></sp-divider>
188
- ` : html``}
190
+ ` : nothing}
189
191
  `;
190
192
  }
191
193
  get images() {
@@ -219,7 +221,7 @@ export class Card extends LikeAnchor(
219
221
  <div class="body">
220
222
  <div class="header">
221
223
  ${this.renderHeading}
222
- ${this.variant === "gallery" ? this.renderSubtitleAndDescription : html``}
224
+ ${this.variant === "gallery" ? this.renderSubtitleAndDescription : nothing}
223
225
  ${this.variant !== "quiet" || this.size !== "s" ? html`
224
226
  <div
225
227
  class="action-button"
@@ -227,21 +229,21 @@ export class Card extends LikeAnchor(
227
229
  >
228
230
  <slot name="actions"></slot>
229
231
  </div>
230
- ` : html``}
232
+ ` : nothing}
231
233
  </div>
232
234
  ${this.variant !== "gallery" ? html`
233
235
  <div class="content">
234
236
  ${this.renderSubtitleAndDescription}
235
237
  </div>
236
- ` : html``}
238
+ ` : nothing}
237
239
  </div>
238
240
  ${this.href ? this.renderAnchor({
239
241
  id: "like-anchor",
240
242
  labelledby: "heading"
241
- }) : html``}
243
+ }) : nothing}
242
244
  ${this.variant === "standard" ? html`
243
245
  <slot name="footer"></slot>
244
- ` : html``}
246
+ ` : nothing}
245
247
  ${this.toggles ? html`
246
248
  <sp-quick-actions
247
249
  class="quick-actions"
@@ -254,7 +256,7 @@ export class Card extends LikeAnchor(
254
256
  tabindex="-1"
255
257
  ></sp-checkbox>
256
258
  </sp-quick-actions>
257
- ` : html``}
259
+ ` : nothing}
258
260
  ${this.variant === "quiet" && this.size === "s" ? html`
259
261
  <sp-quick-actions
260
262
  class="spectrum-QuickActions actions"
@@ -262,7 +264,7 @@ export class Card extends LikeAnchor(
262
264
  >
263
265
  <slot name="actions"></slot>
264
266
  </sp-quick-actions>
265
- ` : html``}
267
+ ` : nothing}
266
268
  `;
267
269
  }
268
270
  firstUpdated(changes) {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
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 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/quick-actions/sp-quick-actions.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 }\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 : html``}\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 : html``}\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 : html``}\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 : html``}\n </div>\n ${this.variant !== 'gallery'\n ? html`\n <div class=\"content\">\n ${this.renderSubtitleAndDescription}\n </div>\n `\n : html``}\n </div>\n ${this.href\n ? this.renderAnchor({\n id: 'like-anchor',\n labelledby: 'heading',\n })\n : html``}\n ${this.variant === 'standard'\n ? html`\n <slot name=\"footer\"></slot>\n `\n : html``}\n ${this.toggles\n ? html`\n <sp-quick-actions\n class=\"quick-actions\"\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-quick-actions>\n `\n : html``}\n ${this.variant === 'quiet' && this.size === 's'\n ? html`\n <sp-quick-actions\n class=\"spectrum-QuickActions actions\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </sp-quick-actions>\n `\n : html``}\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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",
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/quick-actions/sp-quick-actions.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-quick-actions\n class=\"quick-actions\"\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-quick-actions>\n `\n : nothing}\n ${this.variant === 'quiet' && this.size === 's'\n ? html`\n <sp-quick-actions\n class=\"spectrum-QuickActions actions\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </sp-quick-actions>\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
6
  "names": []
7
7
  }
package/src/Card.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var p=Object.defineProperty;var u=Object.getOwnPropertyDescriptor;var i=(d,a,e,s)=>{for(var o=s>1?void 0:s?u(a,e):a,l=d.length-1,n;l>=0;l--)(n=d[l])&&(o=(s?n(a,e,o):n(o))||o);return s&&o&&p(a,e,o),o};import{html as t,SizedMixin as v,SpectrumElement as m}from"@spectrum-web-components/base";import{ifDefined as h}from"@spectrum-web-components/base/src/directives.js";import{property as r,query as g}from"@spectrum-web-components/base/src/decorators.js";import{FocusVisiblePolyfillMixin as f}from"@spectrum-web-components/shared/src/focus-visible.js";import{ObserveSlotPresence as b}from"@spectrum-web-components/shared/src/observe-slot-presence.js";import{LikeAnchor as y}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/quick-actions/sp-quick-actions.js";import"@spectrum-web-components/divider/sp-divider.js";import w from"./card.css.js";import k from"@spectrum-web-components/styles/heading.js";import E from"@spectrum-web-components/styles/detail.js";export class Card extends y(v(b(f(m),['[slot="cover-photo"]','[slot="preview"]']),{validSizes:["s","m"]})){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[k,E,w]}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 l=+new Date,n=()=>{+new Date-l<200&&this.click(),this.removeEventListener("pointerup",n),this.removeEventListener("pointercancel",n)};this.addEventListener("pointerup",n),this.addEventListener("pointercancel",n)}get renderHeading(){return t`
1
+ "use strict";var u=Object.defineProperty;var v=Object.getOwnPropertyDescriptor;var i=(c,l,e,s)=>{for(var n=s>1?void 0:s?v(l,e):l,d=c.length-1,a;d>=0;d--)(a=c[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/quick-actions/sp-quick-actions.js";import"@spectrum-web-components/divider/sp-divider.js";import k from"./card.css.js";import E from"@spectrum-web-components/styles/heading.js";import P 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[E,P,k]}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(h=>h.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
2
  <div
3
3
  class="title spectrum-Heading spectrum-Heading--sizeXS"
4
4
  id="heading"
@@ -6,19 +6,19 @@
6
6
  <slot name="heading">${this.heading}</slot>
7
7
  </div>
8
8
  `}get renderPreviewImage(){return t`
9
- <sp-asset id="preview" variant=${h(this.asset)}>
9
+ <sp-asset id="preview" variant=${p(this.asset)}>
10
10
  <slot name="preview"></slot>
11
11
  </sp-asset>
12
12
  ${this.variant!=="quiet"&&!this.horizontal?t`
13
13
  <sp-divider size="s"></sp-divider>
14
- `:t``}
14
+ `:r}
15
15
  `}get renderCoverImage(){return t`
16
- <sp-asset id="cover-photo" variant=${h(this.asset)}>
16
+ <sp-asset id="cover-photo" variant=${p(this.asset)}>
17
17
  <slot name="cover-photo"></slot>
18
18
  </sp-asset>
19
19
  ${this.variant!=="quiet"&&!this.horizontal?t`
20
20
  <sp-divider size="s"></sp-divider>
21
- `:t``}
21
+ `:r}
22
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
23
  <div class="subtitle spectrum-Detail spectrum-Detail--sizeS">
24
24
  <slot name="subheading">${this.subheading}</slot>
@@ -29,7 +29,7 @@
29
29
  <div class="body">
30
30
  <div class="header">
31
31
  ${this.renderHeading}
32
- ${this.variant==="gallery"?this.renderSubtitleAndDescription:t``}
32
+ ${this.variant==="gallery"?this.renderSubtitleAndDescription:r}
33
33
  ${this.variant!=="quiet"||this.size!=="s"?t`
34
34
  <div
35
35
  class="action-button"
@@ -37,18 +37,18 @@
37
37
  >
38
38
  <slot name="actions"></slot>
39
39
  </div>
40
- `:t``}
40
+ `:r}
41
41
  </div>
42
42
  ${this.variant!=="gallery"?t`
43
43
  <div class="content">
44
44
  ${this.renderSubtitleAndDescription}
45
45
  </div>
46
- `:t``}
46
+ `:r}
47
47
  </div>
48
- ${this.href?this.renderAnchor({id:"like-anchor",labelledby:"heading"}):t``}
48
+ ${this.href?this.renderAnchor({id:"like-anchor",labelledby:"heading"}):r}
49
49
  ${this.variant==="standard"?t`
50
50
  <slot name="footer"></slot>
51
- `:t``}
51
+ `:r}
52
52
  ${this.toggles?t`
53
53
  <sp-quick-actions
54
54
  class="quick-actions"
@@ -61,7 +61,7 @@
61
61
  tabindex="-1"
62
62
  ></sp-checkbox>
63
63
  </sp-quick-actions>
64
- `:t``}
64
+ `:r}
65
65
  ${this.variant==="quiet"&&this.size==="s"?t`
66
66
  <sp-quick-actions
67
67
  class="spectrum-QuickActions actions"
@@ -69,6 +69,6 @@
69
69
  >
70
70
  <slot name="actions"></slot>
71
71
  </sp-quick-actions>
72
- `:t``}
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([r()],Card.prototype,"asset",2),i([r({reflect:!0})],Card.prototype,"variant",2),i([r({type:Boolean,reflect:!0})],Card.prototype,"selected",1),i([r()],Card.prototype,"heading",2),i([r({type:Boolean,reflect:!0})],Card.prototype,"horizontal",2),i([g("#like-anchor")],Card.prototype,"likeAnchor",2),i([r({type:Boolean,reflect:!0})],Card.prototype,"focused",2),i([r({type:Boolean,reflect:!0})],Card.prototype,"toggles",2),i([r()],Card.prototype,"value",2),i([r()],Card.prototype,"subheading",2);
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
74
  //# sourceMappingURL=Card.js.map
package/src/Card.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
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 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/quick-actions/sp-quick-actions.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 }\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 : html``}\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 : html``}\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 : html``}\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 : html``}\n </div>\n ${this.variant !== 'gallery'\n ? html`\n <div class=\"content\">\n ${this.renderSubtitleAndDescription}\n </div>\n `\n : html``}\n </div>\n ${this.href\n ? this.renderAnchor({\n id: 'like-anchor',\n labelledby: 'heading',\n })\n : html``}\n ${this.variant === 'standard'\n ? html`\n <slot name=\"footer\"></slot>\n `\n : html``}\n ${this.toggles\n ? html`\n <sp-quick-actions\n class=\"quick-actions\"\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-quick-actions>\n `\n : html``}\n ${this.variant === 'quiet' && this.size === 's'\n ? html`\n <sp-quick-actions\n class=\"spectrum-QuickActions actions\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </sp-quick-actions>\n `\n : html``}\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": ["html", "SizedMixin", "SpectrumElement", "ifDefined", "property", "query", "FocusVisiblePolyfillMixin", "ObserveSlotPresence", "LikeAnchor", "cardStyles", "headingStyles", "detailStyles", "event", "selected", "_a", "code", "el", "start", "handleEnd", "images", "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 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/quick-actions/sp-quick-actions.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-quick-actions\n class=\"quick-actions\"\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-quick-actions>\n `\n : nothing}\n ${this.variant === 'quiet' && this.size === 's'\n ? html`\n <sp-quick-actions\n class=\"spectrum-QuickActions actions\"\n @pointerdown=${this.stopPropagationOnHref}\n >\n <slot name=\"actions\"></slot>\n </sp-quick-actions>\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": ["html", "nothing", "SizedMixin", "SpectrumElement", "ifDefined", "property", "query", "FocusVisiblePolyfillMixin", "ObserveSlotPresence", "LikeAnchor", "cardStyles", "headingStyles", "detailStyles", "event", "selected", "_a", "code", "el", "start", "handleEnd", "images", "changes", "__decorateClass"]
7
7
  }
@@ -48,10 +48,11 @@ const config = {
48
48
  converter.classToAttribute('is-focused', 'focused'),
49
49
  converter.classToAttribute('is-selected', 'selected'),
50
50
  converter.classToAttribute('is-drop-target', 'drop-target'),
51
+ // Default to `size='m'` without needing the attribute
52
+ converter.classToHost('spectrum-Card--sizeM'),
51
53
  ...converter.enumerateAttributes(
52
54
  [
53
55
  ['spectrum-Card--sizeS', 's'],
54
- ['spectrum-Card--sizeM', 'm'],
55
56
  ['spectrum-Card--sizeL', 'l'],
56
57
  ['spectrum-Card--sizeXL', 'xl'],
57
58
  ],