@spectrum-web-components/coachmark 0.41.2 → 0.42.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/README.md CHANGED
@@ -29,8 +29,6 @@ import { Coachmark } from '@spectrum-web-components/coachmark';
29
29
 
30
30
  ## Default
31
31
 
32
- Coachmark can take a `placement` and an `offset` similar to the [Overlay](https://opensource.adobe.com/spectrum-web-components/components/overlay/).
33
-
34
32
  ```html
35
33
  <sp-coachmark open>
36
34
  <div slot="title">Coachmark with Text Only</div>
@@ -56,7 +54,12 @@ Coach marks can include an `<sp-action-menu>`, which appears at the top right of
56
54
  <div slot="content">
57
55
  This is a Coachmark with nothing but text in it. Kind of lonely in here.
58
56
  </div>
59
- <sp-action-menu placement="bottom-end" quiet slot="actions">
57
+ <sp-action-menu
58
+ label="More Actions"
59
+ placement="bottom-end"
60
+ quiet
61
+ slot="actions"
62
+ >
60
63
  <sp-menu-item>Skip tour</sp-menu-item>
61
64
  <sp-menu-item>Restart tour</sp-menu-item>
62
65
  </sp-action-menu>
@@ -86,7 +89,7 @@ The primary and secondary CTA buttons within the coachmark popover can be config
86
89
  <div slot="content">
87
90
  This is a Coachmark with nothing but text in it. Kind of lonely in here.
88
91
  </div>
89
- <sp-action-menu placement="bottom-end" quiet slot="actions">
92
+ <sp-action-menu label="More Actions" placement="bottom-end" quiet slot="actions">
90
93
  <sp-menu-item>Skip tour</sp-menu-item>
91
94
  <sp-menu-item>Restart tour</sp-menu-item>
92
95
  </sp-action-menu>
@@ -137,7 +140,12 @@ Media Types allowed: `Images & Gifs`
137
140
  >
138
141
  <div slot="title">Coachmark with 16:9 image</div>
139
142
  <div slot="content">This is a Coachmark with some description</div>
140
- <sp-action-menu placement="bottom-end" quiet slot="actions">
143
+ <sp-action-menu
144
+ label="More Actions"
145
+ placement="bottom-end"
146
+ quiet
147
+ slot="actions"
148
+ >
141
149
  <sp-menu-item>Skip tour</sp-menu-item>
142
150
  <sp-menu-item>Restart tour</sp-menu-item>
143
151
  </sp-action-menu>
@@ -159,7 +167,12 @@ A custom media can also be added via `<slot name="cover-photo"></slot>`
159
167
  <div slot="title">Coachmark with 16:9 image</div>
160
168
  <div slot="content">This is a Coachmark with some description</div>
161
169
  <img slot="asset" src="https://picsum.photos/id/237/200/300" alt="" />
162
- <sp-action-menu placement="bottom-end" quiet slot="actions">
170
+ <sp-action-menu
171
+ label="More Actions"
172
+ placement="bottom-end"
173
+ quiet
174
+ slot="actions"
175
+ >
163
176
  <sp-menu-item>Skip tour</sp-menu-item>
164
177
  <sp-menu-item>Restart tour</sp-menu-item>
165
178
  </sp-action-menu>
@@ -182,7 +195,7 @@ The `shortcutKey` is the primary key used to trigger an interaction and are typi
182
195
  secondary-cta="Previous"
183
196
  id="coachmark-keys"
184
197
  >
185
- <sp-action-menu placement="bottom-end" quiet slot="actions">
198
+ <sp-action-menu label="More Actions" placement="bottom-end" quiet slot="actions">
186
199
  <sp-menu-item>Skip tour</sp-menu-item>
187
200
  <sp-menu-item>Restart tour</sp-menu-item>
188
201
  </sp-action-menu>
@@ -326,24 +326,6 @@
326
326
  }
327
327
  }
328
328
  },
329
- {
330
- "kind": "method",
331
- "name": "stopPropagationOnHref",
332
- "privacy": "private",
333
- "return": {
334
- "type": {
335
- "text": "void"
336
- }
337
- },
338
- "parameters": [
339
- {
340
- "name": "event",
341
- "type": {
342
- "text": "Event"
343
- }
344
- }
345
- ]
346
- },
347
329
  {
348
330
  "kind": "method",
349
331
  "name": "handlePrimaryCTA",
@@ -510,12 +492,6 @@
510
492
  "fieldName": "secondaryCTA"
511
493
  }
512
494
  ],
513
- "mixins": [
514
- {
515
- "name": "LikeAnchor",
516
- "package": "@spectrum-web-components/shared/src/like-anchor.js"
517
- }
518
- ],
519
495
  "superclass": {
520
496
  "name": "Popover",
521
497
  "package": "@spectrum-web-components/popover"
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@spectrum-web-components/coachmark",
3
- "version": "0.41.2",
3
+ "version": "0.42.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -70,19 +70,19 @@
70
70
  "lit-html"
71
71
  ],
72
72
  "dependencies": {
73
- "@spectrum-web-components/asset": "^0.41.2",
74
- "@spectrum-web-components/base": "^0.41.2",
75
- "@spectrum-web-components/button": "^0.41.2",
76
- "@spectrum-web-components/button-group": "^0.41.2",
77
- "@spectrum-web-components/icon": "^0.41.2",
78
- "@spectrum-web-components/icons-ui": "^0.41.2",
79
- "@spectrum-web-components/quick-actions": "^0.41.2",
80
- "@spectrum-web-components/reactive-controllers": "^0.41.2",
81
- "@spectrum-web-components/shared": "^0.41.2"
73
+ "@spectrum-web-components/asset": "^0.42.0",
74
+ "@spectrum-web-components/base": "^0.42.0",
75
+ "@spectrum-web-components/button": "^0.42.0",
76
+ "@spectrum-web-components/button-group": "^0.42.0",
77
+ "@spectrum-web-components/icon": "^0.42.0",
78
+ "@spectrum-web-components/icons-ui": "^0.42.0",
79
+ "@spectrum-web-components/quick-actions": "^0.42.0",
80
+ "@spectrum-web-components/reactive-controllers": "^0.42.0",
81
+ "@spectrum-web-components/shared": "^0.42.0"
82
82
  },
83
83
  "devDependencies": {
84
- "@spectrum-css/coachindicator": "^1.1.3",
85
- "@spectrum-css/coachmark": "^6.1.3"
84
+ "@spectrum-css/coachindicator": "^1.1.4",
85
+ "@spectrum-css/coachmark": "^6.1.4"
86
86
  },
87
87
  "types": "./src/index.d.ts",
88
88
  "customElements": "custom-elements.json",
@@ -90,5 +90,5 @@
90
90
  "./sp-*.js",
91
91
  "./**/*.dev.js"
92
92
  ],
93
- "gitHead": "78c3f16b08c9133c9e5ca88d0c9fef5ea7d2ab87"
93
+ "gitHead": "9b3bd55ff8e8f9438817255976e77fd456b19d72"
94
94
  }
@@ -7,10 +7,6 @@ import '@spectrum-web-components/asset/sp-asset.js';
7
7
  import '@spectrum-web-components/button/sp-button.js';
8
8
  import '@spectrum-web-components/button-group/sp-button-group.js';
9
9
  import '@spectrum-web-components/quick-actions/sp-quick-actions.js';
10
- declare const Coachmark_base: typeof Popover & {
11
- new (...args: any[]): import("@spectrum-web-components/shared/src/like-anchor.js").LikeAnchorInterface;
12
- prototype: import("@spectrum-web-components/shared/src/like-anchor.js").LikeAnchorInterface;
13
- };
14
10
  /**
15
11
  * @element sp-coachmark
16
12
  * @fires primary - Announces that the "primary" button has been clicked.
@@ -20,7 +16,7 @@ declare const Coachmark_base: typeof Popover & {
20
16
  * @slot description - A description of the card
21
17
  * @slot actions - an `sp-action-menu` element outlining actions to take on the represened object
22
18
  */
23
- export declare class Coachmark extends Coachmark_base {
19
+ export declare class Coachmark extends Popover {
24
20
  static get styles(): CSSResultArray;
25
21
  item?: CoachmarkItem;
26
22
  placement: Placement;
@@ -40,7 +36,6 @@ export declare class Coachmark extends Coachmark_base {
40
36
  private renderJoiner;
41
37
  private renderHeader;
42
38
  private renderContent;
43
- private stopPropagationOnHref;
44
39
  private handlePrimaryCTA;
45
40
  private handleSecondaryCTA;
46
41
  private renderSecondaryButton;
@@ -52,4 +47,3 @@ export declare class Coachmark extends Coachmark_base {
52
47
  protected renderActionMenu: () => TemplateResult;
53
48
  protected render(): TemplateResult;
54
49
  }
55
- export {};
@@ -16,7 +16,6 @@ import {
16
16
  } from "@spectrum-web-components/base";
17
17
  import { property } from "@spectrum-web-components/base/src/decorators.js";
18
18
  import { when } from "@spectrum-web-components/base/src/directives.js";
19
- import { LikeAnchor } from "@spectrum-web-components/shared/src/like-anchor.js";
20
19
  import coachmarkStyles from "./coachmark.css.js";
21
20
  import chevronStyles from "@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";
22
21
  import "@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js";
@@ -28,7 +27,7 @@ import "@spectrum-web-components/asset/sp-asset.js";
28
27
  import "@spectrum-web-components/button/sp-button.js";
29
28
  import "@spectrum-web-components/button-group/sp-button-group.js";
30
29
  import "@spectrum-web-components/quick-actions/sp-quick-actions.js";
31
- export class Coachmark extends LikeAnchor(Popover) {
30
+ export class Coachmark extends Popover {
32
31
  constructor() {
33
32
  super(...arguments);
34
33
  this.placement = "right";
@@ -99,7 +98,7 @@ export class Coachmark extends LikeAnchor(Popover) {
99
98
  // render action menu
100
99
  this.renderActionMenu = () => {
101
100
  return html`
102
- <div class="action-menu" @pointerdown=${this.stopPropagationOnHref}>
101
+ <div class="action-menu">
103
102
  <slot name="actions"></slot>
104
103
  </div>
105
104
  `;
@@ -186,11 +185,6 @@ export class Coachmark extends LikeAnchor(Popover) {
186
185
  <div>${(_b = this.content) == null ? void 0 : _b.description}</div>
187
186
  `;
188
187
  }
189
- stopPropagationOnHref(event) {
190
- if (this.href) {
191
- event.stopPropagation();
192
- }
193
- }
194
188
  // event on primary button
195
189
  handlePrimaryCTA() {
196
190
  this.dispatchEvent(
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Coachmark.ts"],
4
- "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { when } from '@spectrum-web-components/base/src/directives.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport coachmarkStyles from './coachmark.css.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { join } from 'lit/directives/join.js';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport { MediaType } from './CoachmarkItem.dev.js'\nimport type { CoachmarkItem } from './CoachmarkItem.dev.js'\nimport '@spectrum-web-components/asset/sp-asset.js';\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/button-group/sp-button-group.js';\nimport '@spectrum-web-components/quick-actions/sp-quick-actions.js';\n\n/**\n * @element sp-coachmark\n * @fires primary - Announces that the \"primary\" button has been clicked.\n * @fires secondary - Announces that the \"secondary\" button has been clicked.\n * @slot cover-photo - This is the cover photo for Default and Quiet Coachmark\n * @slot heading - HTML content to be listed as the heading\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 */\nexport class Coachmark extends LikeAnchor(Popover) {\n public static override get styles(): CSSResultArray {\n return [...super.styles, coachmarkStyles, chevronStyles];\n }\n @property({ type: Object })\n public item?: CoachmarkItem;\n\n @property({ type: String })\n public override placement: Placement = 'right';\n\n @property({ type: Object, attribute: false })\n private content?: {\n title?: string;\n description?: string;\n imageAlt?: string;\n };\n\n @property({ attribute: 'shortcut-key' })\n private shortcutKey?: string;\n\n @property({ type: Array })\n public modifierKeys?: string[] = [];\n\n @property({ attribute: 'src' })\n private source?: string;\n\n @property({ attribute: 'media-type' })\n private mediaType?: MediaType;\n\n @property({ type: Boolean, attribute: 'has-asset', reflect: true })\n public hasAsset = false;\n\n @property()\n public asset?: 'file' | 'folder';\n\n @property({ type: Number, attribute: 'current-step' })\n public currentStep?: number;\n\n @property({ type: Number, attribute: 'total-steps' })\n public totalSteps?: number;\n\n @property({ type: String, attribute: 'primary-cta' })\n primaryCTA?: string;\n\n @property({ type: String, attribute: 'secondary-cta' })\n secondaryCTA?: string;\n\n // render video and images\n private renderMedia(): TemplateResult {\n const isImage = this.mediaType === MediaType.IMAGE;\n if (!isImage) {\n return html`\n <slot name=\"asset\"></slot>\n `;\n }\n return html`\n <sp-asset id=\"cover-photo\">\n <div class=\"image-wrapper\">\n <img\n class=\"image\"\n loading=\"lazy\"\n slot=\"cover-photo\"\n src=\"${ifDefined(this.source)}\"\n alt=\"${ifDefined(this?.content?.imageAlt)}\"\n />\n </div>\n </sp-asset>\n `;\n }\n // method to render modifier\n private renderModifier(\n modifierKey: string,\n type: 'modifier' | 'shortcut' = 'modifier'\n ): TemplateResult {\n return html`\n <span type=\"${type}\" class=\"keyboard-shortcut\">${modifierKey}</span>\n `;\n }\n\n private renderJoiner(): TemplateResult {\n return html`\n <span class=\"plus\">&plus;</span>\n `;\n }\n // render heading title and modifier\n private renderHeader(): TemplateResult {\n const hasModifier = this.modifierKeys && this.modifierKeys?.length > 0;\n const hasShortcut = Boolean(this.shortcutKey);\n const hasTitle = Boolean(this.content?.title);\n if (!hasTitle && !hasModifier && !hasShortcut) {\n return html`\n <div class=\"title\"><slot name=\"title\"></slot></div>\n `;\n }\n return html`\n ${hasTitle\n ? html`\n <div class=\"title\">${this.content?.title}</div>\n `\n : nothing}\n ${hasModifier || hasShortcut\n ? html`\n <kbd class=\"keys spectrum-Body spectrum-Body--sizeS\">\n ${hasModifier\n ? join(\n this.modifierKeys?.map((k) =>\n this.renderModifier(k)\n ),\n this.renderJoiner()\n )\n : nothing}\n ${hasShortcut && hasModifier\n ? this.renderJoiner()\n : nothing}\n ${hasShortcut\n ? this.renderModifier(\n this.shortcutKey!,\n 'shortcut'\n )\n : nothing}\n </kbd>\n `\n : nothing}\n `;\n }\n // render description\n private renderContent(): TemplateResult {\n const hasDescription = Boolean(this.content?.description);\n if (!hasDescription)\n return html`\n <slot name=\"content\"></slot>\n `;\n return html`\n <div>${this.content?.description}</div>\n `;\n }\n\n private stopPropagationOnHref(event: Event): void {\n if (this.href) {\n event.stopPropagation();\n }\n }\n\n // event on primary button\n private handlePrimaryCTA(): void {\n this.dispatchEvent(\n new Event('primary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n // event on secondary button\n private handleSecondaryCTA(): void {\n this.dispatchEvent(\n new Event('secondary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private renderSecondaryButton = (): TemplateResult => {\n return html`\n <sp-button\n treatment=\"outline\"\n variant=\"secondary\"\n @click=${this.handleSecondaryCTA}\n >\n ${this.secondaryCTA}\n </sp-button>\n `;\n };\n\n private renderPrimaryButton = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n private renderSecondaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n variant=\"secondary\"\n treatment=\"outline\"\n icon-only\n aria-label=\"previous\"\n @click=${this.handleSecondaryCTA}\n >\n <sp-icon-chevron200\n size=\"s\"\n class=\"spectrum-UIIcon-ChevronLeft75\"\n slot=\"icon\"\n ></sp-icon-chevron200>\n </sp-button>\n `;\n };\n\n private renderPrimaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n protected renderButtons(): TemplateResult {\n return html`\n <sp-button-group class=\"spectrum-ButtonGroup buttongroup\">\n ${when(this.secondaryCTA, this.renderSecondaryButton)}\n ${when(this.primaryCTA, this.renderPrimaryButton)}\n </sp-button-group>\n <sp-button-group\n class=\"spectrum-ButtonGroup buttongroup-mobile\"\n size=\"s\"\n >\n ${when(this.secondaryCTA, this.renderSecondaryButtonMobile)}\n ${when(this.primaryCTA, this.renderPrimaryButtonMobile)}\n </sp-button-group>\n `;\n }\n\n // render steps\n protected renderSteps = (): TemplateResult => {\n return html`\n <div class=\"step\" role=\"status\">\n <span aria-live=\"polite\">\n ${this.currentStep} of ${this.totalSteps}\n </span>\n </div>\n `;\n };\n // render action menu\n protected renderActionMenu = (): TemplateResult => {\n return html`\n <div class=\"action-menu\" @pointerdown=${this.stopPropagationOnHref}>\n <slot name=\"actions\"></slot>\n </div>\n `;\n };\n\n protected override render(): TemplateResult {\n return html`\n ${this.renderMedia()}\n <div class=\"header\">\n <div class=\"flex-container\">${this.renderHeader()}</div>\n <div class=\"static-item\">\n ${when(\n this.secondaryCTA && this.primaryCTA,\n this.renderActionMenu\n )}\n </div>\n </div>\n\n <div class=\"content\">${this.renderContent()}</div>\n <div class=\"footer\">\n ${when(\n this.totalSteps && this.totalSteps > 1,\n this.renderSteps\n )}\n ${this.renderButtons()}\n </div>\n `;\n }\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { when } from '@spectrum-web-components/base/src/directives.js';\nimport coachmarkStyles from './coachmark.css.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { join } from 'lit/directives/join.js';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport { MediaType } from './CoachmarkItem.dev.js'\nimport type { CoachmarkItem } from './CoachmarkItem.dev.js'\nimport '@spectrum-web-components/asset/sp-asset.js';\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/button-group/sp-button-group.js';\nimport '@spectrum-web-components/quick-actions/sp-quick-actions.js';\n\n/**\n * @element sp-coachmark\n * @fires primary - Announces that the \"primary\" button has been clicked.\n * @fires secondary - Announces that the \"secondary\" button has been clicked.\n * @slot cover-photo - This is the cover photo for Default and Quiet Coachmark\n * @slot heading - HTML content to be listed as the heading\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 */\nexport class Coachmark extends Popover {\n public static override get styles(): CSSResultArray {\n return [...super.styles, coachmarkStyles, chevronStyles];\n }\n @property({ type: Object })\n public item?: CoachmarkItem;\n\n @property({ type: String })\n public override placement: Placement = 'right';\n\n @property({ type: Object, attribute: false })\n private content?: {\n title?: string;\n description?: string;\n imageAlt?: string;\n };\n\n @property({ attribute: 'shortcut-key' })\n private shortcutKey?: string;\n\n @property({ type: Array })\n public modifierKeys?: string[] = [];\n\n @property({ attribute: 'src' })\n private source?: string;\n\n @property({ attribute: 'media-type' })\n private mediaType?: MediaType;\n\n @property({ type: Boolean, attribute: 'has-asset', reflect: true })\n public hasAsset = false;\n\n @property()\n public asset?: 'file' | 'folder';\n\n @property({ type: Number, attribute: 'current-step' })\n public currentStep?: number;\n\n @property({ type: Number, attribute: 'total-steps' })\n public totalSteps?: number;\n\n @property({ type: String, attribute: 'primary-cta' })\n primaryCTA?: string;\n\n @property({ type: String, attribute: 'secondary-cta' })\n secondaryCTA?: string;\n\n // render video and images\n private renderMedia(): TemplateResult {\n const isImage = this.mediaType === MediaType.IMAGE;\n if (!isImage) {\n return html`\n <slot name=\"asset\"></slot>\n `;\n }\n return html`\n <sp-asset id=\"cover-photo\">\n <div class=\"image-wrapper\">\n <img\n class=\"image\"\n loading=\"lazy\"\n slot=\"cover-photo\"\n src=\"${ifDefined(this.source)}\"\n alt=\"${ifDefined(this?.content?.imageAlt)}\"\n />\n </div>\n </sp-asset>\n `;\n }\n // method to render modifier\n private renderModifier(\n modifierKey: string,\n type: 'modifier' | 'shortcut' = 'modifier'\n ): TemplateResult {\n return html`\n <span type=\"${type}\" class=\"keyboard-shortcut\">${modifierKey}</span>\n `;\n }\n\n private renderJoiner(): TemplateResult {\n return html`\n <span class=\"plus\">&plus;</span>\n `;\n }\n // render heading title and modifier\n private renderHeader(): TemplateResult {\n const hasModifier = this.modifierKeys && this.modifierKeys?.length > 0;\n const hasShortcut = Boolean(this.shortcutKey);\n const hasTitle = Boolean(this.content?.title);\n if (!hasTitle && !hasModifier && !hasShortcut) {\n return html`\n <div class=\"title\"><slot name=\"title\"></slot></div>\n `;\n }\n return html`\n ${hasTitle\n ? html`\n <div class=\"title\">${this.content?.title}</div>\n `\n : nothing}\n ${hasModifier || hasShortcut\n ? html`\n <kbd class=\"keys spectrum-Body spectrum-Body--sizeS\">\n ${hasModifier\n ? join(\n this.modifierKeys?.map((k) =>\n this.renderModifier(k)\n ),\n this.renderJoiner()\n )\n : nothing}\n ${hasShortcut && hasModifier\n ? this.renderJoiner()\n : nothing}\n ${hasShortcut\n ? this.renderModifier(\n this.shortcutKey!,\n 'shortcut'\n )\n : nothing}\n </kbd>\n `\n : nothing}\n `;\n }\n // render description\n private renderContent(): TemplateResult {\n const hasDescription = Boolean(this.content?.description);\n if (!hasDescription)\n return html`\n <slot name=\"content\"></slot>\n `;\n return html`\n <div>${this.content?.description}</div>\n `;\n }\n\n // event on primary button\n private handlePrimaryCTA(): void {\n this.dispatchEvent(\n new Event('primary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n // event on secondary button\n private handleSecondaryCTA(): void {\n this.dispatchEvent(\n new Event('secondary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private renderSecondaryButton = (): TemplateResult => {\n return html`\n <sp-button\n treatment=\"outline\"\n variant=\"secondary\"\n @click=${this.handleSecondaryCTA}\n >\n ${this.secondaryCTA}\n </sp-button>\n `;\n };\n\n private renderPrimaryButton = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n private renderSecondaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n variant=\"secondary\"\n treatment=\"outline\"\n icon-only\n aria-label=\"previous\"\n @click=${this.handleSecondaryCTA}\n >\n <sp-icon-chevron200\n size=\"s\"\n class=\"spectrum-UIIcon-ChevronLeft75\"\n slot=\"icon\"\n ></sp-icon-chevron200>\n </sp-button>\n `;\n };\n\n private renderPrimaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n protected renderButtons(): TemplateResult {\n return html`\n <sp-button-group class=\"spectrum-ButtonGroup buttongroup\">\n ${when(this.secondaryCTA, this.renderSecondaryButton)}\n ${when(this.primaryCTA, this.renderPrimaryButton)}\n </sp-button-group>\n <sp-button-group\n class=\"spectrum-ButtonGroup buttongroup-mobile\"\n size=\"s\"\n >\n ${when(this.secondaryCTA, this.renderSecondaryButtonMobile)}\n ${when(this.primaryCTA, this.renderPrimaryButtonMobile)}\n </sp-button-group>\n `;\n }\n\n // render steps\n protected renderSteps = (): TemplateResult => {\n return html`\n <div class=\"step\" role=\"status\">\n <span aria-live=\"polite\">\n ${this.currentStep} of ${this.totalSteps}\n </span>\n </div>\n `;\n };\n // render action menu\n protected renderActionMenu = (): TemplateResult => {\n return html`\n <div class=\"action-menu\">\n <slot name=\"actions\"></slot>\n </div>\n `;\n };\n\n protected override render(): TemplateResult {\n return html`\n ${this.renderMedia()}\n <div class=\"header\">\n <div class=\"flex-container\">${this.renderHeader()}</div>\n <div class=\"static-item\">\n ${when(\n this.secondaryCTA && this.primaryCTA,\n this.renderActionMenu\n )}\n </div>\n </div>\n\n <div class=\"content\">${this.renderContent()}</div>\n <div class=\"footer\">\n ${when(\n this.totalSteps && this.totalSteps > 1,\n this.renderSteps\n )}\n ${this.renderButtons()}\n </div>\n `;\n }\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/src/Coachmark.js CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";var v=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var i=(d,l,r,e)=>{for(var s=e>1?void 0:e?b(l,r):l,o=d.length-1,a;o>=0;o--)(a=d[o])&&(s=(e?a(l,r,s):a(s))||s);return e&&s&&v(l,r,s),s};import{html as t,nothing as u}from"@spectrum-web-components/base";import{property as n}from"@spectrum-web-components/base/src/decorators.js";import{when as p}from"@spectrum-web-components/base/src/directives.js";import{LikeAnchor as f}from"@spectrum-web-components/shared/src/like-anchor.js";import T from"./coachmark.css.js";import g from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js";import{Popover as $}from"@spectrum-web-components/popover";import{join as A}from"lit/directives/join.js";import{ifDefined as h}from"@spectrum-web-components/base/src/directives.js";import{MediaType as S}from"./CoachmarkItem.js";import"@spectrum-web-components/asset/sp-asset.js";import"@spectrum-web-components/button/sp-button.js";import"@spectrum-web-components/button-group/sp-button-group.js";import"@spectrum-web-components/quick-actions/sp-quick-actions.js";export class Coachmark extends f($){constructor(){super(...arguments);this.placement="right";this.modifierKeys=[];this.hasAsset=!1;this.renderSecondaryButton=()=>t`
1
+ "use strict";var v=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var r=(d,l,n,e)=>{for(var i=e>1?void 0:e?b(l,n):l,o=d.length-1,a;o>=0;o--)(a=d[o])&&(i=(e?a(l,n,i):a(i))||i);return e&&i&&v(l,n,i),i};import{html as t,nothing as u}from"@spectrum-web-components/base";import{property as s}from"@spectrum-web-components/base/src/decorators.js";import{when as p}from"@spectrum-web-components/base/src/directives.js";import T from"./coachmark.css.js";import f from"@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js";import"@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js";import{Popover as g}from"@spectrum-web-components/popover";import{join as $}from"lit/directives/join.js";import{ifDefined as y}from"@spectrum-web-components/base/src/directives.js";import{MediaType as A}from"./CoachmarkItem.js";import"@spectrum-web-components/asset/sp-asset.js";import"@spectrum-web-components/button/sp-button.js";import"@spectrum-web-components/button-group/sp-button-group.js";import"@spectrum-web-components/quick-actions/sp-quick-actions.js";export class Coachmark extends g{constructor(){super(...arguments);this.placement="right";this.modifierKeys=[];this.hasAsset=!1;this.renderSecondaryButton=()=>t`
2
2
  <sp-button
3
3
  treatment="outline"
4
4
  variant="secondary"
@@ -45,45 +45,45 @@
45
45
  </span>
46
46
  </div>
47
47
  `;this.renderActionMenu=()=>t`
48
- <div class="action-menu" @pointerdown=${this.stopPropagationOnHref}>
48
+ <div class="action-menu">
49
49
  <slot name="actions"></slot>
50
50
  </div>
51
- `}static get styles(){return[...super.styles,T,g]}renderMedia(){var e;return this.mediaType===S.IMAGE?t`
51
+ `}static get styles(){return[...super.styles,T,f]}renderMedia(){var e;return this.mediaType===A.IMAGE?t`
52
52
  <sp-asset id="cover-photo">
53
53
  <div class="image-wrapper">
54
54
  <img
55
55
  class="image"
56
56
  loading="lazy"
57
57
  slot="cover-photo"
58
- src="${h(this.source)}"
59
- alt="${h((e=this==null?void 0:this.content)==null?void 0:e.imageAlt)}"
58
+ src="${y(this.source)}"
59
+ alt="${y((e=this==null?void 0:this.content)==null?void 0:e.imageAlt)}"
60
60
  />
61
61
  </div>
62
62
  </sp-asset>
63
63
  `:t`
64
64
  <slot name="asset"></slot>
65
- `}renderModifier(r,e="modifier"){return t`
66
- <span type="${e}" class="keyboard-shortcut">${r}</span>
65
+ `}renderModifier(n,e="modifier"){return t`
66
+ <span type="${e}" class="keyboard-shortcut">${n}</span>
67
67
  `}renderJoiner(){return t`
68
68
  <span class="plus">&plus;</span>
69
- `}renderHeader(){var o,a,c,m;const r=this.modifierKeys&&((o=this.modifierKeys)==null?void 0:o.length)>0,e=!!this.shortcutKey,s=!!((a=this.content)!=null&&a.title);return!s&&!r&&!e?t`
69
+ `}renderHeader(){var o,a,c,m;const n=this.modifierKeys&&((o=this.modifierKeys)==null?void 0:o.length)>0,e=!!this.shortcutKey,i=!!((a=this.content)!=null&&a.title);return!i&&!n&&!e?t`
70
70
  <div class="title"><slot name="title"></slot></div>
71
71
  `:t`
72
- ${s?t`
72
+ ${i?t`
73
73
  <div class="title">${(c=this.content)==null?void 0:c.title}</div>
74
74
  `:u}
75
- ${r||e?t`
75
+ ${n||e?t`
76
76
  <kbd class="keys spectrum-Body spectrum-Body--sizeS">
77
- ${r?A((m=this.modifierKeys)==null?void 0:m.map(y=>this.renderModifier(y)),this.renderJoiner()):u}
78
- ${e&&r?this.renderJoiner():u}
77
+ ${n?$((m=this.modifierKeys)==null?void 0:m.map(h=>this.renderModifier(h)),this.renderJoiner()):u}
78
+ ${e&&n?this.renderJoiner():u}
79
79
  ${e?this.renderModifier(this.shortcutKey,"shortcut"):u}
80
80
  </kbd>
81
81
  `:u}
82
- `}renderContent(){var e,s;return!((e=this.content)!=null&&e.description)?t`
82
+ `}renderContent(){var e,i;return!((e=this.content)!=null&&e.description)?t`
83
83
  <slot name="content"></slot>
84
84
  `:t`
85
- <div>${(s=this.content)==null?void 0:s.description}</div>
86
- `}stopPropagationOnHref(r){this.href&&r.stopPropagation()}handlePrimaryCTA(){this.dispatchEvent(new Event("primary",{bubbles:!0,composed:!0}))}handleSecondaryCTA(){this.dispatchEvent(new Event("secondary",{bubbles:!0,composed:!0}))}renderButtons(){return t`
85
+ <div>${(i=this.content)==null?void 0:i.description}</div>
86
+ `}handlePrimaryCTA(){this.dispatchEvent(new Event("primary",{bubbles:!0,composed:!0}))}handleSecondaryCTA(){this.dispatchEvent(new Event("secondary",{bubbles:!0,composed:!0}))}renderButtons(){return t`
87
87
  <sp-button-group class="spectrum-ButtonGroup buttongroup">
88
88
  ${p(this.secondaryCTA,this.renderSecondaryButton)}
89
89
  ${p(this.primaryCTA,this.renderPrimaryButton)}
@@ -109,5 +109,5 @@
109
109
  ${p(this.totalSteps&&this.totalSteps>1,this.renderSteps)}
110
110
  ${this.renderButtons()}
111
111
  </div>
112
- `}}i([n({type:Object})],Coachmark.prototype,"item",2),i([n({type:String})],Coachmark.prototype,"placement",2),i([n({type:Object,attribute:!1})],Coachmark.prototype,"content",2),i([n({attribute:"shortcut-key"})],Coachmark.prototype,"shortcutKey",2),i([n({type:Array})],Coachmark.prototype,"modifierKeys",2),i([n({attribute:"src"})],Coachmark.prototype,"source",2),i([n({attribute:"media-type"})],Coachmark.prototype,"mediaType",2),i([n({type:Boolean,attribute:"has-asset",reflect:!0})],Coachmark.prototype,"hasAsset",2),i([n()],Coachmark.prototype,"asset",2),i([n({type:Number,attribute:"current-step"})],Coachmark.prototype,"currentStep",2),i([n({type:Number,attribute:"total-steps"})],Coachmark.prototype,"totalSteps",2),i([n({type:String,attribute:"primary-cta"})],Coachmark.prototype,"primaryCTA",2),i([n({type:String,attribute:"secondary-cta"})],Coachmark.prototype,"secondaryCTA",2);
112
+ `}}r([s({type:Object})],Coachmark.prototype,"item",2),r([s({type:String})],Coachmark.prototype,"placement",2),r([s({type:Object,attribute:!1})],Coachmark.prototype,"content",2),r([s({attribute:"shortcut-key"})],Coachmark.prototype,"shortcutKey",2),r([s({type:Array})],Coachmark.prototype,"modifierKeys",2),r([s({attribute:"src"})],Coachmark.prototype,"source",2),r([s({attribute:"media-type"})],Coachmark.prototype,"mediaType",2),r([s({type:Boolean,attribute:"has-asset",reflect:!0})],Coachmark.prototype,"hasAsset",2),r([s()],Coachmark.prototype,"asset",2),r([s({type:Number,attribute:"current-step"})],Coachmark.prototype,"currentStep",2),r([s({type:Number,attribute:"total-steps"})],Coachmark.prototype,"totalSteps",2),r([s({type:String,attribute:"primary-cta"})],Coachmark.prototype,"primaryCTA",2),r([s({type:String,attribute:"secondary-cta"})],Coachmark.prototype,"secondaryCTA",2);
113
113
  //# sourceMappingURL=Coachmark.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Coachmark.ts"],
4
- "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { when } from '@spectrum-web-components/base/src/directives.js';\nimport { LikeAnchor } from '@spectrum-web-components/shared/src/like-anchor.js';\nimport coachmarkStyles from './coachmark.css.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { join } from 'lit/directives/join.js';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport { MediaType } from './CoachmarkItem.js';\nimport type { CoachmarkItem } from './CoachmarkItem.js';\nimport '@spectrum-web-components/asset/sp-asset.js';\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/button-group/sp-button-group.js';\nimport '@spectrum-web-components/quick-actions/sp-quick-actions.js';\n\n/**\n * @element sp-coachmark\n * @fires primary - Announces that the \"primary\" button has been clicked.\n * @fires secondary - Announces that the \"secondary\" button has been clicked.\n * @slot cover-photo - This is the cover photo for Default and Quiet Coachmark\n * @slot heading - HTML content to be listed as the heading\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 */\nexport class Coachmark extends LikeAnchor(Popover) {\n public static override get styles(): CSSResultArray {\n return [...super.styles, coachmarkStyles, chevronStyles];\n }\n @property({ type: Object })\n public item?: CoachmarkItem;\n\n @property({ type: String })\n public override placement: Placement = 'right';\n\n @property({ type: Object, attribute: false })\n private content?: {\n title?: string;\n description?: string;\n imageAlt?: string;\n };\n\n @property({ attribute: 'shortcut-key' })\n private shortcutKey?: string;\n\n @property({ type: Array })\n public modifierKeys?: string[] = [];\n\n @property({ attribute: 'src' })\n private source?: string;\n\n @property({ attribute: 'media-type' })\n private mediaType?: MediaType;\n\n @property({ type: Boolean, attribute: 'has-asset', reflect: true })\n public hasAsset = false;\n\n @property()\n public asset?: 'file' | 'folder';\n\n @property({ type: Number, attribute: 'current-step' })\n public currentStep?: number;\n\n @property({ type: Number, attribute: 'total-steps' })\n public totalSteps?: number;\n\n @property({ type: String, attribute: 'primary-cta' })\n primaryCTA?: string;\n\n @property({ type: String, attribute: 'secondary-cta' })\n secondaryCTA?: string;\n\n // render video and images\n private renderMedia(): TemplateResult {\n const isImage = this.mediaType === MediaType.IMAGE;\n if (!isImage) {\n return html`\n <slot name=\"asset\"></slot>\n `;\n }\n return html`\n <sp-asset id=\"cover-photo\">\n <div class=\"image-wrapper\">\n <img\n class=\"image\"\n loading=\"lazy\"\n slot=\"cover-photo\"\n src=\"${ifDefined(this.source)}\"\n alt=\"${ifDefined(this?.content?.imageAlt)}\"\n />\n </div>\n </sp-asset>\n `;\n }\n // method to render modifier\n private renderModifier(\n modifierKey: string,\n type: 'modifier' | 'shortcut' = 'modifier'\n ): TemplateResult {\n return html`\n <span type=\"${type}\" class=\"keyboard-shortcut\">${modifierKey}</span>\n `;\n }\n\n private renderJoiner(): TemplateResult {\n return html`\n <span class=\"plus\">&plus;</span>\n `;\n }\n // render heading title and modifier\n private renderHeader(): TemplateResult {\n const hasModifier = this.modifierKeys && this.modifierKeys?.length > 0;\n const hasShortcut = Boolean(this.shortcutKey);\n const hasTitle = Boolean(this.content?.title);\n if (!hasTitle && !hasModifier && !hasShortcut) {\n return html`\n <div class=\"title\"><slot name=\"title\"></slot></div>\n `;\n }\n return html`\n ${hasTitle\n ? html`\n <div class=\"title\">${this.content?.title}</div>\n `\n : nothing}\n ${hasModifier || hasShortcut\n ? html`\n <kbd class=\"keys spectrum-Body spectrum-Body--sizeS\">\n ${hasModifier\n ? join(\n this.modifierKeys?.map((k) =>\n this.renderModifier(k)\n ),\n this.renderJoiner()\n )\n : nothing}\n ${hasShortcut && hasModifier\n ? this.renderJoiner()\n : nothing}\n ${hasShortcut\n ? this.renderModifier(\n this.shortcutKey!,\n 'shortcut'\n )\n : nothing}\n </kbd>\n `\n : nothing}\n `;\n }\n // render description\n private renderContent(): TemplateResult {\n const hasDescription = Boolean(this.content?.description);\n if (!hasDescription)\n return html`\n <slot name=\"content\"></slot>\n `;\n return html`\n <div>${this.content?.description}</div>\n `;\n }\n\n private stopPropagationOnHref(event: Event): void {\n if (this.href) {\n event.stopPropagation();\n }\n }\n\n // event on primary button\n private handlePrimaryCTA(): void {\n this.dispatchEvent(\n new Event('primary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n // event on secondary button\n private handleSecondaryCTA(): void {\n this.dispatchEvent(\n new Event('secondary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private renderSecondaryButton = (): TemplateResult => {\n return html`\n <sp-button\n treatment=\"outline\"\n variant=\"secondary\"\n @click=${this.handleSecondaryCTA}\n >\n ${this.secondaryCTA}\n </sp-button>\n `;\n };\n\n private renderPrimaryButton = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n private renderSecondaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n variant=\"secondary\"\n treatment=\"outline\"\n icon-only\n aria-label=\"previous\"\n @click=${this.handleSecondaryCTA}\n >\n <sp-icon-chevron200\n size=\"s\"\n class=\"spectrum-UIIcon-ChevronLeft75\"\n slot=\"icon\"\n ></sp-icon-chevron200>\n </sp-button>\n `;\n };\n\n private renderPrimaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n protected renderButtons(): TemplateResult {\n return html`\n <sp-button-group class=\"spectrum-ButtonGroup buttongroup\">\n ${when(this.secondaryCTA, this.renderSecondaryButton)}\n ${when(this.primaryCTA, this.renderPrimaryButton)}\n </sp-button-group>\n <sp-button-group\n class=\"spectrum-ButtonGroup buttongroup-mobile\"\n size=\"s\"\n >\n ${when(this.secondaryCTA, this.renderSecondaryButtonMobile)}\n ${when(this.primaryCTA, this.renderPrimaryButtonMobile)}\n </sp-button-group>\n `;\n }\n\n // render steps\n protected renderSteps = (): TemplateResult => {\n return html`\n <div class=\"step\" role=\"status\">\n <span aria-live=\"polite\">\n ${this.currentStep} of ${this.totalSteps}\n </span>\n </div>\n `;\n };\n // render action menu\n protected renderActionMenu = (): TemplateResult => {\n return html`\n <div class=\"action-menu\" @pointerdown=${this.stopPropagationOnHref}>\n <slot name=\"actions\"></slot>\n </div>\n `;\n };\n\n protected override render(): TemplateResult {\n return html`\n ${this.renderMedia()}\n <div class=\"header\">\n <div class=\"flex-container\">${this.renderHeader()}</div>\n <div class=\"static-item\">\n ${when(\n this.secondaryCTA && this.primaryCTA,\n this.renderActionMenu\n )}\n </div>\n </div>\n\n <div class=\"content\">${this.renderContent()}</div>\n <div class=\"footer\">\n ${when(\n this.totalSteps && this.totalSteps > 1,\n this.renderSteps\n )}\n ${this.renderButtons()}\n </div>\n `;\n }\n}\n"],
5
- "mappings": "qNAWA,OAEI,QAAAA,EACA,WAAAC,MAEG,gCACP,OAAS,YAAAC,MAAgB,kDACzB,OAAS,QAAAC,MAAY,kDACrB,OAAS,cAAAC,MAAkB,qDAC3B,OAAOC,MAAqB,qBAC5B,OAAOC,MAAmB,iEAC1B,MAAO,gEACP,OAAS,WAAAC,MAAe,mCACxB,OAAS,QAAAC,MAAY,yBACrB,OAAS,aAAAC,MAAiB,kDAE1B,OAAS,aAAAC,MAAiB,qBAE1B,MAAO,6CACP,MAAO,+CACP,MAAO,2DACP,MAAO,6DAWA,aAAM,kBAAkBN,EAAWG,CAAO,CAAE,CAA5C,kCAQH,KAAgB,UAAuB,QAavC,KAAO,aAA0B,CAAC,EASlC,KAAO,SAAW,GAoIlB,KAAQ,sBAAwB,IACrBP;AAAA;AAAA;AAAA;AAAA,yBAIU,KAAK,kBAAkB;AAAA;AAAA,kBAE9B,KAAK,YAAY;AAAA;AAAA,UAK/B,KAAQ,oBAAsB,IACnBA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAKU,KAAK,gBAAgB;AAAA;AAAA,kBAE5B,KAAK,UAAU;AAAA;AAAA,UAK7B,KAAQ,4BAA8B,IAC3BA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAMU,KAAK,kBAAkB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAW5C,KAAQ,0BAA4B,IACzBA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAKU,KAAK,gBAAgB;AAAA;AAAA,kBAE5B,KAAK,UAAU;AAAA;AAAA,UAsB7B,KAAU,YAAc,IACbA;AAAA;AAAA;AAAA,sBAGO,KAAK,WAAW,OAAO,KAAK,UAAU;AAAA;AAAA;AAAA,UAMxD,KAAU,iBAAmB,IAClBA;AAAA,oDACqC,KAAK,qBAAqB;AAAA;AAAA;AAAA,UAtP1E,WAA2B,QAAyB,CAChD,MAAO,CAAC,GAAG,MAAM,OAAQK,EAAiBC,CAAa,CAC3D,CA6CQ,aAA8B,CA3F1C,IAAAK,EA6FQ,OADgB,KAAK,YAAcD,EAAU,MAMtCV;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,+BAOgBS,EAAU,KAAK,MAAM,CAAC;AAAA,+BACtBA,GAAUE,EAAA,uBAAM,UAAN,YAAAA,EAAe,QAAQ,CAAC;AAAA;AAAA;AAAA;AAAA,UAZ9CX;AAAA;AAAA,aAiBf,CAEQ,eACJY,EACAC,EAAgC,WAClB,CACd,OAAOb;AAAA,0BACWa,CAAI,+BAA+BD,CAAW;AAAA,SAEpE,CAEQ,cAA+B,CACnC,OAAOZ;AAAA;AAAA,SAGX,CAEQ,cAA+B,CAhI3C,IAAAW,EAAAG,EAAAC,EAAAC,EAiIQ,MAAMC,EAAc,KAAK,gBAAgBN,EAAA,KAAK,eAAL,YAAAA,EAAmB,QAAS,EAC/DO,EAAc,EAAQ,KAAK,YAC3BC,EAAW,IAAQL,EAAA,KAAK,UAAL,MAAAA,EAAc,OACvC,MAAI,CAACK,GAAY,CAACF,GAAe,CAACC,EACvBlB;AAAA;AAAA,cAIJA;AAAA,cACDmB,EACInB;AAAA,4CACyBe,EAAA,KAAK,UAAL,YAAAA,EAAc,KAAK;AAAA,oBAE5Cd,CAAO;AAAA,cACXgB,GAAeC,EACXlB;AAAA;AAAA,4BAEUiB,EACIT,GACIQ,EAAA,KAAK,eAAL,YAAAA,EAAmB,IAAKI,GACpB,KAAK,eAAeA,CAAC,GAEzB,KAAK,aAAa,CACtB,EACAnB,CAAO;AAAA,4BACXiB,GAAeD,EACX,KAAK,aAAa,EAClBhB,CAAO;AAAA,4BACXiB,EACI,KAAK,eACD,KAAK,YACL,UACJ,EACAjB,CAAO;AAAA;AAAA,oBAGrBA,CAAO;AAAA,SAErB,CAEQ,eAAgC,CAzK5C,IAAAU,EAAAG,EA2KQ,MADuB,GAAQH,EAAA,KAAK,UAAL,MAAAA,EAAc,aAElCX;AAAA;AAAA,cAGJA;AAAA,oBACIc,EAAA,KAAK,UAAL,YAAAA,EAAc,WAAW;AAAA,SAExC,CAEQ,sBAAsBO,EAAoB,CAC1C,KAAK,MACLA,EAAM,gBAAgB,CAE9B,CAGQ,kBAAyB,CAC7B,KAAK,cACD,IAAI,MAAM,UAAW,CACjB,QAAS,GACT,SAAU,EACd,CAAC,CACL,CACJ,CAEQ,oBAA2B,CAC/B,KAAK,cACD,IAAI,MAAM,YAAa,CACnB,QAAS,GACT,SAAU,EACd,CAAC,CACL,CACJ,CA0DU,eAAgC,CACtC,OAAOrB;AAAA;AAAA,kBAEGG,EAAK,KAAK,aAAc,KAAK,qBAAqB,CAAC;AAAA,kBACnDA,EAAK,KAAK,WAAY,KAAK,mBAAmB,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kBAM/CA,EAAK,KAAK,aAAc,KAAK,2BAA2B,CAAC;AAAA,kBACzDA,EAAK,KAAK,WAAY,KAAK,yBAAyB,CAAC;AAAA;AAAA,SAGnE,CAqBmB,QAAyB,CACxC,OAAOH;AAAA,cACD,KAAK,YAAY,CAAC;AAAA;AAAA,8CAEc,KAAK,aAAa,CAAC;AAAA;AAAA,sBAE3CG,EACE,KAAK,cAAgB,KAAK,WAC1B,KAAK,gBACT,CAAC;AAAA;AAAA;AAAA;AAAA,mCAIc,KAAK,cAAc,CAAC;AAAA;AAAA,kBAErCA,EACE,KAAK,YAAc,KAAK,WAAa,EACrC,KAAK,WACT,CAAC;AAAA,kBACC,KAAK,cAAc,CAAC;AAAA;AAAA,SAGlC,CACJ,CA/QWmB,EAAA,CADNpB,EAAS,CAAE,KAAM,MAAO,CAAC,GAJjB,UAKF,oBAGSoB,EAAA,CADfpB,EAAS,CAAE,KAAM,MAAO,CAAC,GAPjB,UAQO,yBAGRoB,EAAA,CADPpB,EAAS,CAAE,KAAM,OAAQ,UAAW,EAAM,CAAC,GAVnC,UAWD,uBAOAoB,EAAA,CADPpB,EAAS,CAAE,UAAW,cAAe,CAAC,GAjB9B,UAkBD,2BAGDoB,EAAA,CADNpB,EAAS,CAAE,KAAM,KAAM,CAAC,GApBhB,UAqBF,4BAGCoB,EAAA,CADPpB,EAAS,CAAE,UAAW,KAAM,CAAC,GAvBrB,UAwBD,sBAGAoB,EAAA,CADPpB,EAAS,CAAE,UAAW,YAAa,CAAC,GA1B5B,UA2BD,yBAGDoB,EAAA,CADNpB,EAAS,CAAE,KAAM,QAAS,UAAW,YAAa,QAAS,EAAK,CAAC,GA7BzD,UA8BF,wBAGAoB,EAAA,CADNpB,EAAS,GAhCD,UAiCF,qBAGAoB,EAAA,CADNpB,EAAS,CAAE,KAAM,OAAQ,UAAW,cAAe,CAAC,GAnC5C,UAoCF,2BAGAoB,EAAA,CADNpB,EAAS,CAAE,KAAM,OAAQ,UAAW,aAAc,CAAC,GAtC3C,UAuCF,0BAGPoB,EAAA,CADCpB,EAAS,CAAE,KAAM,OAAQ,UAAW,aAAc,CAAC,GAzC3C,UA0CT,0BAGAoB,EAAA,CADCpB,EAAS,CAAE,KAAM,OAAQ,UAAW,eAAgB,CAAC,GA5C7C,UA6CT",
6
- "names": ["html", "nothing", "property", "when", "LikeAnchor", "coachmarkStyles", "chevronStyles", "Popover", "join", "ifDefined", "MediaType", "_a", "modifierKey", "type", "_b", "_c", "_d", "hasModifier", "hasShortcut", "hasTitle", "k", "event", "__decorateClass"]
4
+ "sourcesContent": ["/*\nCopyright 2023 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\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 TemplateResult,\n} from '@spectrum-web-components/base';\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport { when } from '@spectrum-web-components/base/src/directives.js';\nimport coachmarkStyles from './coachmark.css.js';\nimport chevronStyles from '@spectrum-web-components/icon/src/spectrum-icon-chevron.css.js';\nimport '@spectrum-web-components/icons-ui/icons/sp-icon-chevron200.js';\nimport { Popover } from '@spectrum-web-components/popover';\nimport { join } from 'lit/directives/join.js';\nimport { ifDefined } from '@spectrum-web-components/base/src/directives.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport { MediaType } from './CoachmarkItem.js';\nimport type { CoachmarkItem } from './CoachmarkItem.js';\nimport '@spectrum-web-components/asset/sp-asset.js';\nimport '@spectrum-web-components/button/sp-button.js';\nimport '@spectrum-web-components/button-group/sp-button-group.js';\nimport '@spectrum-web-components/quick-actions/sp-quick-actions.js';\n\n/**\n * @element sp-coachmark\n * @fires primary - Announces that the \"primary\" button has been clicked.\n * @fires secondary - Announces that the \"secondary\" button has been clicked.\n * @slot cover-photo - This is the cover photo for Default and Quiet Coachmark\n * @slot heading - HTML content to be listed as the heading\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 */\nexport class Coachmark extends Popover {\n public static override get styles(): CSSResultArray {\n return [...super.styles, coachmarkStyles, chevronStyles];\n }\n @property({ type: Object })\n public item?: CoachmarkItem;\n\n @property({ type: String })\n public override placement: Placement = 'right';\n\n @property({ type: Object, attribute: false })\n private content?: {\n title?: string;\n description?: string;\n imageAlt?: string;\n };\n\n @property({ attribute: 'shortcut-key' })\n private shortcutKey?: string;\n\n @property({ type: Array })\n public modifierKeys?: string[] = [];\n\n @property({ attribute: 'src' })\n private source?: string;\n\n @property({ attribute: 'media-type' })\n private mediaType?: MediaType;\n\n @property({ type: Boolean, attribute: 'has-asset', reflect: true })\n public hasAsset = false;\n\n @property()\n public asset?: 'file' | 'folder';\n\n @property({ type: Number, attribute: 'current-step' })\n public currentStep?: number;\n\n @property({ type: Number, attribute: 'total-steps' })\n public totalSteps?: number;\n\n @property({ type: String, attribute: 'primary-cta' })\n primaryCTA?: string;\n\n @property({ type: String, attribute: 'secondary-cta' })\n secondaryCTA?: string;\n\n // render video and images\n private renderMedia(): TemplateResult {\n const isImage = this.mediaType === MediaType.IMAGE;\n if (!isImage) {\n return html`\n <slot name=\"asset\"></slot>\n `;\n }\n return html`\n <sp-asset id=\"cover-photo\">\n <div class=\"image-wrapper\">\n <img\n class=\"image\"\n loading=\"lazy\"\n slot=\"cover-photo\"\n src=\"${ifDefined(this.source)}\"\n alt=\"${ifDefined(this?.content?.imageAlt)}\"\n />\n </div>\n </sp-asset>\n `;\n }\n // method to render modifier\n private renderModifier(\n modifierKey: string,\n type: 'modifier' | 'shortcut' = 'modifier'\n ): TemplateResult {\n return html`\n <span type=\"${type}\" class=\"keyboard-shortcut\">${modifierKey}</span>\n `;\n }\n\n private renderJoiner(): TemplateResult {\n return html`\n <span class=\"plus\">&plus;</span>\n `;\n }\n // render heading title and modifier\n private renderHeader(): TemplateResult {\n const hasModifier = this.modifierKeys && this.modifierKeys?.length > 0;\n const hasShortcut = Boolean(this.shortcutKey);\n const hasTitle = Boolean(this.content?.title);\n if (!hasTitle && !hasModifier && !hasShortcut) {\n return html`\n <div class=\"title\"><slot name=\"title\"></slot></div>\n `;\n }\n return html`\n ${hasTitle\n ? html`\n <div class=\"title\">${this.content?.title}</div>\n `\n : nothing}\n ${hasModifier || hasShortcut\n ? html`\n <kbd class=\"keys spectrum-Body spectrum-Body--sizeS\">\n ${hasModifier\n ? join(\n this.modifierKeys?.map((k) =>\n this.renderModifier(k)\n ),\n this.renderJoiner()\n )\n : nothing}\n ${hasShortcut && hasModifier\n ? this.renderJoiner()\n : nothing}\n ${hasShortcut\n ? this.renderModifier(\n this.shortcutKey!,\n 'shortcut'\n )\n : nothing}\n </kbd>\n `\n : nothing}\n `;\n }\n // render description\n private renderContent(): TemplateResult {\n const hasDescription = Boolean(this.content?.description);\n if (!hasDescription)\n return html`\n <slot name=\"content\"></slot>\n `;\n return html`\n <div>${this.content?.description}</div>\n `;\n }\n\n // event on primary button\n private handlePrimaryCTA(): void {\n this.dispatchEvent(\n new Event('primary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n // event on secondary button\n private handleSecondaryCTA(): void {\n this.dispatchEvent(\n new Event('secondary', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n private renderSecondaryButton = (): TemplateResult => {\n return html`\n <sp-button\n treatment=\"outline\"\n variant=\"secondary\"\n @click=${this.handleSecondaryCTA}\n >\n ${this.secondaryCTA}\n </sp-button>\n `;\n };\n\n private renderPrimaryButton = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n private renderSecondaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n variant=\"secondary\"\n treatment=\"outline\"\n icon-only\n aria-label=\"previous\"\n @click=${this.handleSecondaryCTA}\n >\n <sp-icon-chevron200\n size=\"s\"\n class=\"spectrum-UIIcon-ChevronLeft75\"\n slot=\"icon\"\n ></sp-icon-chevron200>\n </sp-button>\n `;\n };\n\n private renderPrimaryButtonMobile = (): TemplateResult => {\n return html`\n <sp-button\n size=\"s\"\n treatment=\"outline\"\n variant=\"primary\"\n @click=${this.handlePrimaryCTA}\n >\n ${this.primaryCTA}\n </sp-button>\n `;\n };\n\n protected renderButtons(): TemplateResult {\n return html`\n <sp-button-group class=\"spectrum-ButtonGroup buttongroup\">\n ${when(this.secondaryCTA, this.renderSecondaryButton)}\n ${when(this.primaryCTA, this.renderPrimaryButton)}\n </sp-button-group>\n <sp-button-group\n class=\"spectrum-ButtonGroup buttongroup-mobile\"\n size=\"s\"\n >\n ${when(this.secondaryCTA, this.renderSecondaryButtonMobile)}\n ${when(this.primaryCTA, this.renderPrimaryButtonMobile)}\n </sp-button-group>\n `;\n }\n\n // render steps\n protected renderSteps = (): TemplateResult => {\n return html`\n <div class=\"step\" role=\"status\">\n <span aria-live=\"polite\">\n ${this.currentStep} of ${this.totalSteps}\n </span>\n </div>\n `;\n };\n // render action menu\n protected renderActionMenu = (): TemplateResult => {\n return html`\n <div class=\"action-menu\">\n <slot name=\"actions\"></slot>\n </div>\n `;\n };\n\n protected override render(): TemplateResult {\n return html`\n ${this.renderMedia()}\n <div class=\"header\">\n <div class=\"flex-container\">${this.renderHeader()}</div>\n <div class=\"static-item\">\n ${when(\n this.secondaryCTA && this.primaryCTA,\n this.renderActionMenu\n )}\n </div>\n </div>\n\n <div class=\"content\">${this.renderContent()}</div>\n <div class=\"footer\">\n ${when(\n this.totalSteps && this.totalSteps > 1,\n this.renderSteps\n )}\n ${this.renderButtons()}\n </div>\n `;\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["html", "nothing", "property", "when", "coachmarkStyles", "chevronStyles", "Popover", "join", "ifDefined", "MediaType", "_a", "modifierKey", "type", "_b", "_c", "_d", "hasModifier", "hasShortcut", "hasTitle", "k", "__decorateClass"]
7
7
  }