@spectrum-web-components/tooltip 0.11.13 → 0.11.14-overlay.33

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/tooltip",
3
- "version": "0.11.13",
3
+ "version": "0.11.14-overlay.33+499d5fe96",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -58,7 +58,7 @@
58
58
  ],
59
59
  "dependencies": {
60
60
  "@spectrum-web-components/base": "^0.7.4",
61
- "@spectrum-web-components/overlay": "^0.19.1"
61
+ "@spectrum-web-components/overlay": "^0.19.2-overlay.33+499d5fe96"
62
62
  },
63
63
  "devDependencies": {
64
64
  "@spectrum-css/tooltip": "^4.0.10"
@@ -69,5 +69,5 @@
69
69
  "./sp-*.js",
70
70
  "./**/*.dev.js"
71
71
  ],
72
- "gitHead": "15365e4ee7e9171108d5dc6694cf64cc11db3048"
72
+ "gitHead": "499d5fe966f35eb862c1983eb3a42641f213ac6a"
73
73
  }
package/src/Tooltip.d.ts CHANGED
@@ -1,8 +1,6 @@
1
- import { CSSResultArray, PropertyValues, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
2
- import type { OverlayDisplayQueryDetail, Placement } from '@spectrum-web-components/overlay';
3
- export declare class TooltipProxy extends HTMLElement {
4
- disconnectedCallback(): void;
5
- }
1
+ import { CSSResultArray, SpectrumElement, TemplateResult } from '@spectrum-web-components/base';
2
+ import type { Placement } from '@spectrum-web-components/overlay';
3
+ import '@spectrum-web-components/overlay/sp-overlay.js';
6
4
  /**
7
5
  * @element sp-tooltip
8
6
  *
@@ -15,41 +13,20 @@ export declare class Tooltip extends SpectrumElement {
15
13
  * @private
16
14
  */
17
15
  static instanceCount: number;
18
- private _tooltipId;
19
16
  selfManaged: boolean;
20
17
  offset: number;
21
- private hadTooltipId;
22
18
  open: boolean;
23
19
  /**
24
20
  * @type {"auto" | "auto-start" | "auto-end" | "top" | "bottom" | "right" | "left" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end" | "none"}
25
21
  * @attr
26
22
  */
27
23
  placement: Placement;
28
- private tipElement;
24
+ tipElement: HTMLSpanElement;
29
25
  private _variant;
30
26
  get variant(): string;
31
27
  set variant(variant: string);
32
- constructor();
33
- onOverlayQuery(event: CustomEvent<OverlayDisplayQueryDetail>): void;
34
- private _proxy;
35
- private generateProxy;
36
- overlayWillOpenCallback({ trigger, }: {
37
- trigger: HTMLElement;
38
- }): void;
39
- overlayOpenCancelledCallback({ trigger, }: {
40
- trigger: HTMLElement;
41
- }): void;
42
- overlayCloseCallback({ trigger }: {
43
- trigger: HTMLElement;
44
- }): void;
45
- private removeProxy;
46
- private closeOverlayCallback?;
47
- private abortOverlay;
48
- private openOverlay;
49
- private closeOverlay;
50
- private previousSlot?;
51
- private manageTooltip;
28
+ private handleOpenOverlay;
29
+ protected handleCloseOverlay: () => void;
30
+ protected handleTransitionend(): void;
52
31
  render(): TemplateResult;
53
- protected update(changed: PropertyValues<this>): Promise<void>;
54
- protected updated(changed: PropertyValues<this>): void;
55
32
  }
@@ -18,69 +18,56 @@ import {
18
18
  property,
19
19
  query
20
20
  } from "@spectrum-web-components/base/src/decorators.js";
21
- import { openOverlay } from "@spectrum-web-components/overlay/src/loader.js";
21
+ import "@spectrum-web-components/overlay/sp-overlay.js";
22
22
  import tooltipStyles from "./tooltip.css.js";
23
- export class TooltipProxy extends HTMLElement {
24
- disconnectedCallback() {
25
- this.dispatchEvent(new Event("disconnected"));
26
- }
27
- }
28
- customElements.define("tooltip-proxy", TooltipProxy);
29
- const _Tooltip = class extends SpectrumElement {
23
+ export class Tooltip extends SpectrumElement {
30
24
  constructor() {
31
- super();
32
- this._tooltipId = `sp-tooltip-describedby-helper-${_Tooltip.instanceCount++}`;
25
+ super(...arguments);
33
26
  this.selfManaged = false;
34
27
  this.offset = 6;
35
- this.hadTooltipId = false;
36
28
  this.open = false;
37
29
  this.placement = "top";
38
30
  /* Ensure that a '' value for `variant` removes the attribute instead of a blank value */
39
31
  this._variant = "";
40
- this.abortOverlay = () => {
41
- return;
42
- };
43
- this.openOverlay = () => {
44
- const parentElement = this.parentElement;
45
- const abortPromise = new Promise((res) => {
46
- this.abortOverlay = res;
47
- });
48
- if (true) {
49
- window.__swc.ignoreWarningLevels.deprecation = true;
50
- }
51
- this.closeOverlayCallback = openOverlay(parentElement, "hover", this, {
52
- abortPromise,
53
- offset: this.offset,
54
- placement: this.placement
55
- });
56
- if (true) {
57
- window.__swc.ignoreWarningLevels.deprecation = false;
58
- }
32
+ // public overlayWillOpenCallback({
33
+ // trigger,
34
+ // }: {
35
+ // trigger: HTMLElement;
36
+ // }): void {
37
+ // this.setAttribute('aria-hidden', 'true');
38
+ // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';
39
+ // this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;
40
+ // if (this.hadTooltipId) return;
41
+ // if (ariaDescribedby) {
42
+ // trigger.setAttribute(
43
+ // 'aria-describedby',
44
+ // `${ariaDescribedby} ${this._tooltipId}`
45
+ // );
46
+ // } else {
47
+ // trigger.setAttribute('aria-describedby', `${this._tooltipId}`);
48
+ // }
49
+ // }
50
+ // public overlayCloseCallback({ trigger }: { trigger: HTMLElement }): void {
51
+ // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';
52
+ // let descriptors = ariaDescribedby.split(/\s+/);
53
+ // if (!this.hadTooltipId) {
54
+ // descriptors = descriptors.filter(
55
+ // (descriptor) => descriptor !== this._tooltipId
56
+ // );
57
+ // }
58
+ // if (descriptors.length) {
59
+ // trigger.setAttribute('aria-describedby', descriptors.join(' '));
60
+ // } else {
61
+ // trigger.removeAttribute('aria-describedby');
62
+ // }
63
+ // this.removeAttribute('aria-hidden');
64
+ // }
65
+ this.handleOpenOverlay = () => {
66
+ this.open = true;
59
67
  };
60
- this.closeOverlay = async (event) => {
61
- const pointerIsEnteringTooltip = event && event.type === "pointerleave" && event.relatedTarget === this;
62
- if (pointerIsEnteringTooltip) {
63
- this.addEventListener(
64
- "pointerleave",
65
- (event2) => {
66
- const pointerIsEnteringParnet = event2.relatedTarget === this.parentElement;
67
- if (pointerIsEnteringParnet) {
68
- return;
69
- }
70
- this.closeOverlay(event2);
71
- },
72
- { once: true }
73
- );
74
- return;
75
- }
76
- if (this.abortOverlay)
77
- this.abortOverlay(true);
78
- if (!this.closeOverlayCallback)
79
- return;
80
- (await this.closeOverlayCallback)();
81
- delete this.closeOverlayCallback;
68
+ this.handleCloseOverlay = () => {
69
+ this.open = false;
82
70
  };
83
- this.addEventListener("sp-overlay-query", this.onOverlayQuery);
84
71
  }
85
72
  static get styles() {
86
73
  return [tooltipStyles];
@@ -100,121 +87,43 @@ const _Tooltip = class extends SpectrumElement {
100
87
  this.removeAttribute("variant");
101
88
  this._variant = "";
102
89
  }
103
- onOverlayQuery(event) {
104
- if (!event.target)
105
- return;
106
- const target = event.target;
107
- if (target !== this)
108
- return;
109
- event.detail.overlayContentTipElement = this.tipElement;
110
- }
111
- generateProxy() {
112
- if (this._proxy) {
113
- return;
114
- }
115
- this._proxy = document.createElement("tooltip-proxy");
116
- this._proxy.id = this._tooltipId;
117
- this._proxy.hidden = true;
118
- this._proxy.slot = "hidden-tooltip-content";
119
- this._proxy.setAttribute("role", "tooltip");
120
- this._proxy.addEventListener("disconnected", this.closeOverlay);
121
- }
122
- overlayWillOpenCallback({
123
- trigger
124
- }) {
125
- this.setAttribute("aria-hidden", "true");
126
- this.generateProxy();
127
- this._proxy.textContent = this.textContent;
128
- const ariaDescribedby = trigger.getAttribute("aria-describedby") || "";
129
- this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;
130
- this.insertAdjacentElement("beforebegin", this._proxy);
131
- if (this.hadTooltipId)
132
- return;
133
- if (ariaDescribedby) {
134
- trigger.setAttribute(
135
- "aria-describedby",
136
- `${ariaDescribedby} ${this._tooltipId}`
137
- );
138
- } else {
139
- trigger.setAttribute("aria-describedby", `${this._tooltipId}`);
140
- }
141
- }
142
- overlayOpenCancelledCallback({
143
- trigger
144
- }) {
145
- this.overlayCloseCallback({ trigger });
146
- }
147
- overlayCloseCallback({ trigger }) {
148
- const ariaDescribedby = trigger.getAttribute("aria-describedby") || "";
149
- let descriptors = ariaDescribedby.split(/\s+/);
150
- if (!this.hadTooltipId) {
151
- descriptors = descriptors.filter(
152
- (descriptor) => descriptor !== this._tooltipId
153
- );
154
- }
155
- if (descriptors.length) {
156
- trigger.setAttribute("aria-describedby", descriptors.join(" "));
157
- } else {
158
- trigger.removeAttribute("aria-describedby");
159
- }
160
- this.removeAttribute("aria-hidden");
161
- this.removeProxy();
162
- }
163
- removeProxy() {
164
- this._proxy.remove();
165
- }
166
- manageTooltip() {
167
- const parentElement = this.parentElement;
168
- if (this.selfManaged) {
169
- if (this.slot) {
170
- this.previousSlot = this.slot;
171
- }
172
- this.slot = "self-managed-tooltip";
173
- parentElement.addEventListener("pointerenter", this.openOverlay);
174
- parentElement.addEventListener("focusin", this.openOverlay);
175
- parentElement.addEventListener("pointerleave", this.closeOverlay);
176
- parentElement.addEventListener("focusout", this.closeOverlay);
177
- } else {
178
- if (this.previousSlot) {
179
- this.slot = this.previousSlot;
180
- } else if (this.slot === "self-managed-tooltip") {
181
- this.removeAttribute("slot");
182
- }
183
- parentElement.removeEventListener("pointerenter", this.openOverlay);
184
- parentElement.removeEventListener("focusin", this.openOverlay);
185
- parentElement.removeEventListener(
186
- "pointerleave",
187
- this.closeOverlay
188
- );
189
- parentElement.removeEventListener("focusout", this.closeOverlay);
190
- }
90
+ handleTransitionend() {
91
+ this.dispatchEvent(new Event("transitionend", {
92
+ bubbles: true,
93
+ composed: true
94
+ }));
191
95
  }
192
96
  render() {
193
- return html`
194
- <slot name="icon"></slot>
195
- <span id="label"><slot></slot></span>
196
- <span id="tip"></span>
97
+ const tooltip = html`
98
+ <span
99
+ id="tooltip"
100
+ @transitionend=${this.handleTransitionend}
101
+ >
102
+ <slot name="icon"></slot>
103
+ <span id="label"><slot></slot></span>
104
+ <span id="tip"></span>
105
+ </span>
197
106
  `;
198
- }
199
- async update(changed) {
200
- if (changed.has("open") && this.selfManaged) {
201
- if (this.open) {
202
- this.openOverlay();
203
- } else {
204
- this.closeOverlay();
205
- }
206
- }
207
- this.generateProxy();
208
- super.update(changed);
209
- }
210
- updated(changed) {
211
- super.updated(changed);
212
- if (changed.has("selfManaged")) {
213
- this.manageTooltip();
107
+ if (this.selfManaged) {
108
+ return html`
109
+ <sp-overlay
110
+ ?open=${this.open}
111
+ offset=${this.offset}
112
+ type="hint"
113
+ .placement=${this.placement}
114
+ .triggerElement=${this.parentElement}
115
+ .triggerInteraction=${"hover"}
116
+ @sp-opened=${this.handleOpenOverlay}
117
+ @sp-closed=${this.handleCloseOverlay}
118
+ >
119
+ ${tooltip}
120
+ </sp-overlay>
121
+ `;
122
+ } else {
123
+ return tooltip;
214
124
  }
215
125
  }
216
- };
217
- export let Tooltip = _Tooltip;
126
+ }
218
127
  /**
219
128
  * @private
220
129
  */
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Tooltip.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 SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport type {\n OverlayDisplayQueryDetail,\n Placement,\n} from '@spectrum-web-components/overlay';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\n\nimport tooltipStyles from './tooltip.css.js';\n\nexport class TooltipProxy extends HTMLElement {\n disconnectedCallback(): void {\n this.dispatchEvent(new Event('disconnected'));\n }\n}\n\ncustomElements.define('tooltip-proxy', TooltipProxy);\n\n/**\n * @element sp-tooltip\n *\n * @slot icon - the icon element appearing at the start of the label\n * @slot - the text label of the Tooltip\n */\n\nexport class Tooltip extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [tooltipStyles];\n }\n\n /**\n * @private\n */\n static instanceCount = 0;\n\n private _tooltipId = `sp-tooltip-describedby-helper-${Tooltip.instanceCount++}`;\n\n @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\n private hadTooltipId = false;\n\n @property({ type: Boolean, reflect: true })\n public open = false;\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement: Placement = 'top';\n\n @query('#tip')\n private tipElement!: HTMLSpanElement;\n\n /* Ensure that a '' value for `variant` removes the attribute instead of a blank value */\n private _variant = '';\n\n @property({ type: String })\n public get variant(): string {\n return this._variant;\n }\n public set variant(variant: string) {\n if (variant === this.variant) {\n return;\n }\n if (['info', 'positive', 'negative'].includes(variant)) {\n this.setAttribute('variant', variant);\n this._variant = variant;\n return;\n }\n this.removeAttribute('variant');\n this._variant = '';\n }\n\n public constructor() {\n super();\n this.addEventListener('sp-overlay-query', this.onOverlayQuery);\n }\n\n public onOverlayQuery(event: CustomEvent<OverlayDisplayQueryDetail>): void {\n /* c8 ignore next */\n if (!event.target) return;\n\n const target = event.target as Node;\n /* c8 ignore next */\n if (target !== this) return;\n\n event.detail.overlayContentTipElement = this.tipElement;\n }\n\n private _proxy!: HTMLElement;\n\n private generateProxy(): void {\n if (this._proxy) {\n return;\n }\n this._proxy = document.createElement('tooltip-proxy');\n this._proxy.id = this._tooltipId;\n this._proxy.hidden = true;\n this._proxy.slot = 'hidden-tooltip-content';\n this._proxy.setAttribute('role', 'tooltip');\n this._proxy.addEventListener('disconnected', this.closeOverlay);\n }\n\n public overlayWillOpenCallback({\n trigger,\n }: {\n trigger: HTMLElement;\n }): void {\n this.setAttribute('aria-hidden', 'true');\n this.generateProxy();\n this._proxy.textContent = this.textContent;\n const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;\n\n this.insertAdjacentElement('beforebegin', this._proxy);\n\n if (this.hadTooltipId) return;\n\n if (ariaDescribedby) {\n trigger.setAttribute(\n 'aria-describedby',\n `${ariaDescribedby} ${this._tooltipId}`\n );\n } else {\n trigger.setAttribute('aria-describedby', `${this._tooltipId}`);\n }\n }\n\n public overlayOpenCancelledCallback({\n trigger,\n }: {\n trigger: HTMLElement;\n }): void {\n this.overlayCloseCallback({ trigger });\n }\n\n public overlayCloseCallback({ trigger }: { trigger: HTMLElement }): void {\n const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n let descriptors = ariaDescribedby.split(/\\s+/);\n\n if (!this.hadTooltipId) {\n descriptors = descriptors.filter(\n (descriptor) => descriptor !== this._tooltipId\n );\n }\n if (descriptors.length) {\n trigger.setAttribute('aria-describedby', descriptors.join(' '));\n } else {\n trigger.removeAttribute('aria-describedby');\n }\n\n this.removeAttribute('aria-hidden');\n this.removeProxy();\n }\n\n private removeProxy(): void {\n this._proxy.remove();\n }\n\n private closeOverlayCallback?: Promise<() => void>;\n private abortOverlay: (cancelled: boolean) => void = () => {\n return;\n };\n\n private openOverlay = (): void => {\n const parentElement = this.parentElement as HTMLElement;\n const abortPromise: Promise<boolean> = new Promise((res) => {\n this.abortOverlay = res;\n });\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = true;\n }\n this.closeOverlayCallback = openOverlay(parentElement, 'hover', this, {\n abortPromise,\n offset: this.offset,\n placement: this.placement,\n });\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = false;\n }\n };\n\n private closeOverlay = async (\n event?: PointerEvent | FocusEvent | Event\n ): Promise<void> => {\n const pointerIsEnteringTooltip =\n event &&\n event.type === 'pointerleave' &&\n (event as PointerEvent).relatedTarget === this;\n if (pointerIsEnteringTooltip) {\n this.addEventListener(\n 'pointerleave',\n (event: PointerEvent) => {\n const pointerIsEnteringParnet =\n event.relatedTarget === this.parentElement;\n if (pointerIsEnteringParnet) {\n return;\n }\n this.closeOverlay(event);\n },\n { once: true }\n );\n return;\n }\n if (this.abortOverlay) this.abortOverlay(true);\n if (!this.closeOverlayCallback) return;\n (await this.closeOverlayCallback)();\n delete this.closeOverlayCallback;\n };\n\n private previousSlot?: string;\n\n private manageTooltip(): void {\n const parentElement = this.parentElement as HTMLElement;\n if (this.selfManaged) {\n if (this.slot) {\n this.previousSlot = this.slot;\n }\n this.slot = 'self-managed-tooltip';\n parentElement.addEventListener('pointerenter', this.openOverlay);\n parentElement.addEventListener('focusin', this.openOverlay);\n parentElement.addEventListener('pointerleave', this.closeOverlay);\n parentElement.addEventListener('focusout', this.closeOverlay);\n } else {\n if (this.previousSlot) {\n this.slot = this.previousSlot;\n } else if (this.slot === 'self-managed-tooltip') {\n this.removeAttribute('slot');\n }\n parentElement.removeEventListener('pointerenter', this.openOverlay);\n parentElement.removeEventListener('focusin', this.openOverlay);\n parentElement.removeEventListener(\n 'pointerleave',\n this.closeOverlay\n );\n parentElement.removeEventListener('focusout', this.closeOverlay);\n }\n }\n\n override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <span id=\"label\"><slot></slot></span>\n <span id=\"tip\"></span>\n `;\n }\n\n protected override async update(\n changed: PropertyValues<this>\n ): Promise<void> {\n if (changed.has('open') && this.selfManaged) {\n if (this.open) {\n this.openOverlay();\n } else {\n this.closeOverlay();\n }\n }\n this.generateProxy();\n super.update(changed);\n }\n\n protected override updated(changed: PropertyValues<this>): void {\n super.updated(changed);\n if (changed.has('selfManaged')) {\n this.manageTooltip();\n }\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["event"]
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 SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/overlay/sp-overlay.js';\n\nimport tooltipStyles from './tooltip.css.js';\n\n/**\n * @element sp-tooltip\n *\n * @slot icon - the icon element appearing at the start of the label\n * @slot - the text label of the Tooltip\n */\n\nexport class Tooltip extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [tooltipStyles];\n }\n\n /**\n * @private\n */\n static instanceCount = 0;\n\n // private _tooltipId = `sp-tooltip-describedby-helper-${Tooltip.instanceCount++}`;\n\n @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\n // private hadTooltipId = false;\n\n @property({ type: Boolean, reflect: true })\n public open = false;\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement: Placement = 'top';\n\n @query('#tip')\n public tipElement!: HTMLSpanElement;\n\n /* Ensure that a '' value for `variant` removes the attribute instead of a blank value */\n private _variant = '';\n\n @property({ type: String })\n public get variant(): string {\n return this._variant;\n }\n public set variant(variant: string) {\n if (variant === this.variant) {\n return;\n }\n if (['info', 'positive', 'negative'].includes(variant)) {\n this.setAttribute('variant', variant);\n this._variant = variant;\n return;\n }\n this.removeAttribute('variant');\n this._variant = '';\n }\n\n // public overlayWillOpenCallback({\n // trigger,\n // }: {\n // trigger: HTMLElement;\n // }): void {\n // this.setAttribute('aria-hidden', 'true');\n // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n // this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;\n\n // if (this.hadTooltipId) return;\n\n // if (ariaDescribedby) {\n // trigger.setAttribute(\n // 'aria-describedby',\n // `${ariaDescribedby} ${this._tooltipId}`\n // );\n // } else {\n // trigger.setAttribute('aria-describedby', `${this._tooltipId}`);\n // }\n // }\n\n // public overlayCloseCallback({ trigger }: { trigger: HTMLElement }): void {\n // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n // let descriptors = ariaDescribedby.split(/\\s+/);\n\n // if (!this.hadTooltipId) {\n // descriptors = descriptors.filter(\n // (descriptor) => descriptor !== this._tooltipId\n // );\n // }\n // if (descriptors.length) {\n // trigger.setAttribute('aria-describedby', descriptors.join(' '));\n // } else {\n // trigger.removeAttribute('aria-describedby');\n // }\n\n // this.removeAttribute('aria-hidden');\n // }\n\n private handleOpenOverlay = (): void => {\n this.open = true;\n };\n\n protected handleCloseOverlay = (): void => {\n this.open = false;\n };\n\n protected handleTransitionend(): void {\n this.dispatchEvent(new Event('transitionend', {\n bubbles: true,\n composed: true,\n }));\n }\n\n override render(): TemplateResult {\n const tooltip = html`\n <span\n id=\"tooltip\"\n @transitionend=${this.handleTransitionend}\n >\n <slot name=\"icon\"></slot>\n <span id=\"label\"><slot></slot></span>\n <span id=\"tip\"></span>\n </span>\n `;\n if (this.selfManaged) {\n return html`\n <sp-overlay\n ?open=${this.open}\n offset=${this.offset}\n type=\"hint\"\n .placement=${this.placement}\n .triggerElement=${this.parentElement}\n .triggerInteraction=${'hover'}\n @sp-opened=${this.handleOpenOverlay}\n @sp-closed=${this.handleCloseOverlay}\n >\n ${tooltip}\n </sp-overlay>\n `;\n } else {\n return tooltip;\n }\n }\n}\n"],
5
+ "mappings": ";;;;;;;;;;;;AAYA;AAAA,EAEI;AAAA,EACA;AAAA,OAEG;AACP;AAAA,EACI;AAAA,EACA;AAAA,OACG;AAEP,OAAO;AAEP,OAAO,mBAAmB;AASnB,aAAM,gBAAgB,gBAAgB;AAAA,EAAtC;AAAA;AAaH,SAAO,cAAc;AAGrB,SAAO,SAAS;AAIhB,SAAO,OAAO;AAOd,SAAO,YAAuB;AAM9B;AAAA,SAAQ,WAAW;AA0DnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAQ,oBAAoB,MAAY;AACpC,WAAK,OAAO;AAAA,IAChB;AAEA,SAAU,qBAAqB,MAAY;AACvC,WAAK,OAAO;AAAA,IAChB;AAAA;AAAA,EAhGA,WAA2B,SAAyB;AAChD,WAAO,CAAC,aAAa;AAAA,EACzB;AAAA,EAiCA,IAAW,UAAkB;AACzB,WAAO,KAAK;AAAA,EAChB;AAAA,EACA,IAAW,QAAQ,SAAiB;AAChC,QAAI,YAAY,KAAK,SAAS;AAC1B;AAAA,IACJ;AACA,QAAI,CAAC,QAAQ,YAAY,UAAU,EAAE,SAAS,OAAO,GAAG;AACpD,WAAK,aAAa,WAAW,OAAO;AACpC,WAAK,WAAW;AAChB;AAAA,IACJ;AACA,SAAK,gBAAgB,SAAS;AAC9B,SAAK,WAAW;AAAA,EACpB;AAAA,EAiDU,sBAA4B;AAClC,SAAK,cAAc,IAAI,MAAM,iBAAiB;AAAA,MAC1C,SAAS;AAAA,MACT,UAAU;AAAA,IACd,CAAC,CAAC;AAAA,EACN;AAAA,EAES,SAAyB;AAC9B,UAAM,UAAU;AAAA;AAAA;AAAA,iCAGS,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAO9B,QAAI,KAAK,aAAa;AAClB,aAAO;AAAA;AAAA,4BAES,KAAK;AAAA,6BACJ,KAAK;AAAA;AAAA,iCAED,KAAK;AAAA,sCACA,KAAK;AAAA,0CACD;AAAA,iCACT,KAAK;AAAA,iCACL,KAAK;AAAA;AAAA,sBAEhB;AAAA;AAAA;AAAA,IAGd,OAAO;AACH,aAAO;AAAA,IACX;AAAA,EACJ;AACJ;AAAA;AAAA;AAAA;AAxIa,QAQF,gBAAgB;AAKhB;AAAA,EADN,SAAS,EAAE,MAAM,SAAS,WAAW,eAAe,CAAC;AAAA,GAZ7C,QAaF;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,QAAQ,SAAS,KAAK,CAAC;AAAA,GAfhC,QAgBF;AAIA;AAAA,EADN,SAAS,EAAE,MAAM,SAAS,SAAS,KAAK,CAAC;AAAA,GAnBjC,QAoBF;AAOA;AAAA,EADN,SAAS,EAAE,SAAS,KAAK,CAAC;AAAA,GA1BlB,QA2BF;AAGA;AAAA,EADN,MAAM,MAAM;AAAA,GA7BJ,QA8BF;AAMI;AAAA,EADV,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GAnCjB,QAoCE;",
6
+ "names": []
7
7
  }
package/src/Tooltip.js CHANGED
@@ -1,6 +1,24 @@
1
- "use strict";var d=Object.defineProperty;var v=Object.getOwnPropertyDescriptor;var r=(n,o,e,i)=>{for(var t=i>1?void 0:i?v(o,e):o,s=n.length-1,l;s>=0;s--)(l=n[s])&&(t=(i?l(o,e,t):l(t))||t);return i&&t&&d(o,e,t),t};import{html as c,SpectrumElement as h}from"@spectrum-web-components/base";import{property as a,query as y}from"@spectrum-web-components/base/src/decorators.js";import{openOverlay as u}from"@spectrum-web-components/overlay/src/loader.js";import m from"./tooltip.css.js";export class TooltipProxy extends HTMLElement{disconnectedCallback(){this.dispatchEvent(new Event("disconnected"))}}customElements.define("tooltip-proxy",TooltipProxy);const p=class extends h{constructor(){super();this._tooltipId=`sp-tooltip-describedby-helper-${p.instanceCount++}`;this.selfManaged=!1;this.offset=6;this.hadTooltipId=!1;this.open=!1;this.placement="top";this._variant="";this.abortOverlay=()=>{};this.openOverlay=()=>{const e=this.parentElement,i=new Promise(t=>{this.abortOverlay=t});this.closeOverlayCallback=u(e,"hover",this,{abortPromise:i,offset:this.offset,placement:this.placement})};this.closeOverlay=async e=>{if(e&&e.type==="pointerleave"&&e.relatedTarget===this){this.addEventListener("pointerleave",t=>{t.relatedTarget!==this.parentElement&&this.closeOverlay(t)},{once:!0});return}this.abortOverlay&&this.abortOverlay(!0),this.closeOverlayCallback&&((await this.closeOverlayCallback)(),delete this.closeOverlayCallback)};this.addEventListener("sp-overlay-query",this.onOverlayQuery)}static get styles(){return[m]}get variant(){return this._variant}set variant(e){if(e!==this.variant){if(["info","positive","negative"].includes(e)){this.setAttribute("variant",e),this._variant=e;return}this.removeAttribute("variant"),this._variant=""}}onOverlayQuery(e){!e.target||e.target!==this||(e.detail.overlayContentTipElement=this.tipElement)}generateProxy(){this._proxy||(this._proxy=document.createElement("tooltip-proxy"),this._proxy.id=this._tooltipId,this._proxy.hidden=!0,this._proxy.slot="hidden-tooltip-content",this._proxy.setAttribute("role","tooltip"),this._proxy.addEventListener("disconnected",this.closeOverlay))}overlayWillOpenCallback({trigger:e}){this.setAttribute("aria-hidden","true"),this.generateProxy(),this._proxy.textContent=this.textContent;const i=e.getAttribute("aria-describedby")||"";this.hadTooltipId=i.search(this._tooltipId)>-1,this.insertAdjacentElement("beforebegin",this._proxy),!this.hadTooltipId&&(i?e.setAttribute("aria-describedby",`${i} ${this._tooltipId}`):e.setAttribute("aria-describedby",`${this._tooltipId}`))}overlayOpenCancelledCallback({trigger:e}){this.overlayCloseCallback({trigger:e})}overlayCloseCallback({trigger:e}){let t=(e.getAttribute("aria-describedby")||"").split(/\s+/);this.hadTooltipId||(t=t.filter(s=>s!==this._tooltipId)),t.length?e.setAttribute("aria-describedby",t.join(" ")):e.removeAttribute("aria-describedby"),this.removeAttribute("aria-hidden"),this.removeProxy()}removeProxy(){this._proxy.remove()}manageTooltip(){const e=this.parentElement;this.selfManaged?(this.slot&&(this.previousSlot=this.slot),this.slot="self-managed-tooltip",e.addEventListener("pointerenter",this.openOverlay),e.addEventListener("focusin",this.openOverlay),e.addEventListener("pointerleave",this.closeOverlay),e.addEventListener("focusout",this.closeOverlay)):(this.previousSlot?this.slot=this.previousSlot:this.slot==="self-managed-tooltip"&&this.removeAttribute("slot"),e.removeEventListener("pointerenter",this.openOverlay),e.removeEventListener("focusin",this.openOverlay),e.removeEventListener("pointerleave",this.closeOverlay),e.removeEventListener("focusout",this.closeOverlay))}render(){return c`
2
- <slot name="icon"></slot>
3
- <span id="label"><slot></slot></span>
4
- <span id="tip"></span>
5
- `}async update(e){e.has("open")&&this.selfManaged&&(this.open?this.openOverlay():this.closeOverlay()),this.generateProxy(),super.update(e)}updated(e){super.updated(e),e.has("selfManaged")&&this.manageTooltip()}};export let Tooltip=p;Tooltip.instanceCount=0,r([a({type:Boolean,attribute:"self-managed"})],Tooltip.prototype,"selfManaged",2),r([a({type:Number,reflect:!0})],Tooltip.prototype,"offset",2),r([a({type:Boolean,reflect:!0})],Tooltip.prototype,"open",2),r([a({reflect:!0})],Tooltip.prototype,"placement",2),r([y("#tip")],Tooltip.prototype,"tipElement",2),r([a({type:String})],Tooltip.prototype,"variant",1);
1
+ "use strict";var u=Object.defineProperty;var c=Object.getOwnPropertyDescriptor;var n=(a,r,e,s)=>{for(var t=s>1?void 0:s?c(r,e):r,l=a.length-1,p;l>=0;l--)(p=a[l])&&(t=(s?p(r,e,t):p(t))||t);return s&&t&&u(r,e,t),t};import{html as o,SpectrumElement as d}from"@spectrum-web-components/base";import{property as i,query as m}from"@spectrum-web-components/base/src/decorators.js";import"@spectrum-web-components/overlay/sp-overlay.js";import h from"./tooltip.css.js";export class Tooltip extends d{constructor(){super(...arguments);this.selfManaged=!1;this.offset=6;this.open=!1;this.placement="top";this._variant="";this.handleOpenOverlay=()=>{this.open=!0};this.handleCloseOverlay=()=>{this.open=!1}}static get styles(){return[h]}get variant(){return this._variant}set variant(e){if(e!==this.variant){if(["info","positive","negative"].includes(e)){this.setAttribute("variant",e),this._variant=e;return}this.removeAttribute("variant"),this._variant=""}}handleTransitionend(){this.dispatchEvent(new Event("transitionend",{bubbles:!0,composed:!0}))}render(){const e=o`
2
+ <span
3
+ id="tooltip"
4
+ @transitionend=${this.handleTransitionend}
5
+ >
6
+ <slot name="icon"></slot>
7
+ <span id="label"><slot></slot></span>
8
+ <span id="tip"></span>
9
+ </span>
10
+ `;return this.selfManaged?o`
11
+ <sp-overlay
12
+ ?open=${this.open}
13
+ offset=${this.offset}
14
+ type="hint"
15
+ .placement=${this.placement}
16
+ .triggerElement=${this.parentElement}
17
+ .triggerInteraction=${"hover"}
18
+ @sp-opened=${this.handleOpenOverlay}
19
+ @sp-closed=${this.handleCloseOverlay}
20
+ >
21
+ ${e}
22
+ </sp-overlay>
23
+ `:e}}Tooltip.instanceCount=0,n([i({type:Boolean,attribute:"self-managed"})],Tooltip.prototype,"selfManaged",2),n([i({type:Number,reflect:!0})],Tooltip.prototype,"offset",2),n([i({type:Boolean,reflect:!0})],Tooltip.prototype,"open",2),n([i({reflect:!0})],Tooltip.prototype,"placement",2),n([m("#tip")],Tooltip.prototype,"tipElement",2),n([i({type:String})],Tooltip.prototype,"variant",1);
6
24
  //# sourceMappingURL=Tooltip.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["Tooltip.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 SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport type {\n OverlayDisplayQueryDetail,\n Placement,\n} from '@spectrum-web-components/overlay';\nimport { openOverlay } from '@spectrum-web-components/overlay/src/loader.js';\n\nimport tooltipStyles from './tooltip.css.js';\n\nexport class TooltipProxy extends HTMLElement {\n disconnectedCallback(): void {\n this.dispatchEvent(new Event('disconnected'));\n }\n}\n\ncustomElements.define('tooltip-proxy', TooltipProxy);\n\n/**\n * @element sp-tooltip\n *\n * @slot icon - the icon element appearing at the start of the label\n * @slot - the text label of the Tooltip\n */\n\nexport class Tooltip extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [tooltipStyles];\n }\n\n /**\n * @private\n */\n static instanceCount = 0;\n\n private _tooltipId = `sp-tooltip-describedby-helper-${Tooltip.instanceCount++}`;\n\n @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\n private hadTooltipId = false;\n\n @property({ type: Boolean, reflect: true })\n public open = false;\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement: Placement = 'top';\n\n @query('#tip')\n private tipElement!: HTMLSpanElement;\n\n /* Ensure that a '' value for `variant` removes the attribute instead of a blank value */\n private _variant = '';\n\n @property({ type: String })\n public get variant(): string {\n return this._variant;\n }\n public set variant(variant: string) {\n if (variant === this.variant) {\n return;\n }\n if (['info', 'positive', 'negative'].includes(variant)) {\n this.setAttribute('variant', variant);\n this._variant = variant;\n return;\n }\n this.removeAttribute('variant');\n this._variant = '';\n }\n\n public constructor() {\n super();\n this.addEventListener('sp-overlay-query', this.onOverlayQuery);\n }\n\n public onOverlayQuery(event: CustomEvent<OverlayDisplayQueryDetail>): void {\n /* c8 ignore next */\n if (!event.target) return;\n\n const target = event.target as Node;\n /* c8 ignore next */\n if (target !== this) return;\n\n event.detail.overlayContentTipElement = this.tipElement;\n }\n\n private _proxy!: HTMLElement;\n\n private generateProxy(): void {\n if (this._proxy) {\n return;\n }\n this._proxy = document.createElement('tooltip-proxy');\n this._proxy.id = this._tooltipId;\n this._proxy.hidden = true;\n this._proxy.slot = 'hidden-tooltip-content';\n this._proxy.setAttribute('role', 'tooltip');\n this._proxy.addEventListener('disconnected', this.closeOverlay);\n }\n\n public overlayWillOpenCallback({\n trigger,\n }: {\n trigger: HTMLElement;\n }): void {\n this.setAttribute('aria-hidden', 'true');\n this.generateProxy();\n this._proxy.textContent = this.textContent;\n const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;\n\n this.insertAdjacentElement('beforebegin', this._proxy);\n\n if (this.hadTooltipId) return;\n\n if (ariaDescribedby) {\n trigger.setAttribute(\n 'aria-describedby',\n `${ariaDescribedby} ${this._tooltipId}`\n );\n } else {\n trigger.setAttribute('aria-describedby', `${this._tooltipId}`);\n }\n }\n\n public overlayOpenCancelledCallback({\n trigger,\n }: {\n trigger: HTMLElement;\n }): void {\n this.overlayCloseCallback({ trigger });\n }\n\n public overlayCloseCallback({ trigger }: { trigger: HTMLElement }): void {\n const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n let descriptors = ariaDescribedby.split(/\\s+/);\n\n if (!this.hadTooltipId) {\n descriptors = descriptors.filter(\n (descriptor) => descriptor !== this._tooltipId\n );\n }\n if (descriptors.length) {\n trigger.setAttribute('aria-describedby', descriptors.join(' '));\n } else {\n trigger.removeAttribute('aria-describedby');\n }\n\n this.removeAttribute('aria-hidden');\n this.removeProxy();\n }\n\n private removeProxy(): void {\n this._proxy.remove();\n }\n\n private closeOverlayCallback?: Promise<() => void>;\n private abortOverlay: (cancelled: boolean) => void = () => {\n return;\n };\n\n private openOverlay = (): void => {\n const parentElement = this.parentElement as HTMLElement;\n const abortPromise: Promise<boolean> = new Promise((res) => {\n this.abortOverlay = res;\n });\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = true;\n }\n this.closeOverlayCallback = openOverlay(parentElement, 'hover', this, {\n abortPromise,\n offset: this.offset,\n placement: this.placement,\n });\n if (window.__swc.DEBUG) {\n window.__swc.ignoreWarningLevels.deprecation = false;\n }\n };\n\n private closeOverlay = async (\n event?: PointerEvent | FocusEvent | Event\n ): Promise<void> => {\n const pointerIsEnteringTooltip =\n event &&\n event.type === 'pointerleave' &&\n (event as PointerEvent).relatedTarget === this;\n if (pointerIsEnteringTooltip) {\n this.addEventListener(\n 'pointerleave',\n (event: PointerEvent) => {\n const pointerIsEnteringParnet =\n event.relatedTarget === this.parentElement;\n if (pointerIsEnteringParnet) {\n return;\n }\n this.closeOverlay(event);\n },\n { once: true }\n );\n return;\n }\n if (this.abortOverlay) this.abortOverlay(true);\n if (!this.closeOverlayCallback) return;\n (await this.closeOverlayCallback)();\n delete this.closeOverlayCallback;\n };\n\n private previousSlot?: string;\n\n private manageTooltip(): void {\n const parentElement = this.parentElement as HTMLElement;\n if (this.selfManaged) {\n if (this.slot) {\n this.previousSlot = this.slot;\n }\n this.slot = 'self-managed-tooltip';\n parentElement.addEventListener('pointerenter', this.openOverlay);\n parentElement.addEventListener('focusin', this.openOverlay);\n parentElement.addEventListener('pointerleave', this.closeOverlay);\n parentElement.addEventListener('focusout', this.closeOverlay);\n } else {\n if (this.previousSlot) {\n this.slot = this.previousSlot;\n } else if (this.slot === 'self-managed-tooltip') {\n this.removeAttribute('slot');\n }\n parentElement.removeEventListener('pointerenter', this.openOverlay);\n parentElement.removeEventListener('focusin', this.openOverlay);\n parentElement.removeEventListener(\n 'pointerleave',\n this.closeOverlay\n );\n parentElement.removeEventListener('focusout', this.closeOverlay);\n }\n }\n\n override render(): TemplateResult {\n return html`\n <slot name=\"icon\"></slot>\n <span id=\"label\"><slot></slot></span>\n <span id=\"tip\"></span>\n `;\n }\n\n protected override async update(\n changed: PropertyValues<this>\n ): Promise<void> {\n if (changed.has('open') && this.selfManaged) {\n if (this.open) {\n this.openOverlay();\n } else {\n this.closeOverlay();\n }\n }\n this.generateProxy();\n super.update(changed);\n }\n\n protected override updated(changed: PropertyValues<this>): void {\n super.updated(changed);\n if (changed.has('selfManaged')) {\n this.manageTooltip();\n }\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["html", "SpectrumElement", "property", "query", "openOverlay", "tooltipStyles", "_Tooltip", "parentElement", "abortPromise", "res", "event", "variant", "trigger", "ariaDescribedby", "descriptors", "descriptor", "changed", "__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 SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport type { Placement } from '@spectrum-web-components/overlay';\nimport '@spectrum-web-components/overlay/sp-overlay.js';\n\nimport tooltipStyles from './tooltip.css.js';\n\n/**\n * @element sp-tooltip\n *\n * @slot icon - the icon element appearing at the start of the label\n * @slot - the text label of the Tooltip\n */\n\nexport class Tooltip extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [tooltipStyles];\n }\n\n /**\n * @private\n */\n static instanceCount = 0;\n\n // private _tooltipId = `sp-tooltip-describedby-helper-${Tooltip.instanceCount++}`;\n\n @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\n // private hadTooltipId = false;\n\n @property({ type: Boolean, reflect: true })\n public open = false;\n\n /**\n * @type {\"auto\" | \"auto-start\" | \"auto-end\" | \"top\" | \"bottom\" | \"right\" | \"left\" | \"top-start\" | \"top-end\" | \"bottom-start\" | \"bottom-end\" | \"right-start\" | \"right-end\" | \"left-start\" | \"left-end\" | \"none\"}\n * @attr\n */\n @property({ reflect: true })\n public placement: Placement = 'top';\n\n @query('#tip')\n public tipElement!: HTMLSpanElement;\n\n /* Ensure that a '' value for `variant` removes the attribute instead of a blank value */\n private _variant = '';\n\n @property({ type: String })\n public get variant(): string {\n return this._variant;\n }\n public set variant(variant: string) {\n if (variant === this.variant) {\n return;\n }\n if (['info', 'positive', 'negative'].includes(variant)) {\n this.setAttribute('variant', variant);\n this._variant = variant;\n return;\n }\n this.removeAttribute('variant');\n this._variant = '';\n }\n\n // public overlayWillOpenCallback({\n // trigger,\n // }: {\n // trigger: HTMLElement;\n // }): void {\n // this.setAttribute('aria-hidden', 'true');\n // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n // this.hadTooltipId = ariaDescribedby.search(this._tooltipId) > -1;\n\n // if (this.hadTooltipId) return;\n\n // if (ariaDescribedby) {\n // trigger.setAttribute(\n // 'aria-describedby',\n // `${ariaDescribedby} ${this._tooltipId}`\n // );\n // } else {\n // trigger.setAttribute('aria-describedby', `${this._tooltipId}`);\n // }\n // }\n\n // public overlayCloseCallback({ trigger }: { trigger: HTMLElement }): void {\n // const ariaDescribedby = trigger.getAttribute('aria-describedby') || '';\n // let descriptors = ariaDescribedby.split(/\\s+/);\n\n // if (!this.hadTooltipId) {\n // descriptors = descriptors.filter(\n // (descriptor) => descriptor !== this._tooltipId\n // );\n // }\n // if (descriptors.length) {\n // trigger.setAttribute('aria-describedby', descriptors.join(' '));\n // } else {\n // trigger.removeAttribute('aria-describedby');\n // }\n\n // this.removeAttribute('aria-hidden');\n // }\n\n private handleOpenOverlay = (): void => {\n this.open = true;\n };\n\n protected handleCloseOverlay = (): void => {\n this.open = false;\n };\n\n protected handleTransitionend(): void {\n this.dispatchEvent(new Event('transitionend', {\n bubbles: true,\n composed: true,\n }));\n }\n\n override render(): TemplateResult {\n const tooltip = html`\n <span\n id=\"tooltip\"\n @transitionend=${this.handleTransitionend}\n >\n <slot name=\"icon\"></slot>\n <span id=\"label\"><slot></slot></span>\n <span id=\"tip\"></span>\n </span>\n `;\n if (this.selfManaged) {\n return html`\n <sp-overlay\n ?open=${this.open}\n offset=${this.offset}\n type=\"hint\"\n .placement=${this.placement}\n .triggerElement=${this.parentElement}\n .triggerInteraction=${'hover'}\n @sp-opened=${this.handleOpenOverlay}\n @sp-closed=${this.handleCloseOverlay}\n >\n ${tooltip}\n </sp-overlay>\n `;\n } else {\n return tooltip;\n }\n }\n}\n"],
5
+ "mappings": "qNAYA,OAEI,QAAAA,EACA,mBAAAC,MAEG,gCACP,OACI,YAAAC,EACA,SAAAC,MACG,kDAEP,MAAO,iDAEP,OAAOC,MAAmB,mBASnB,aAAM,gBAAgBH,CAAgB,CAAtC,kCAaH,KAAO,YAAc,GAGrB,KAAO,OAAS,EAIhB,KAAO,KAAO,GAOd,KAAO,UAAuB,MAM9B,KAAQ,SAAW,GA0DnB,KAAQ,kBAAoB,IAAY,CACpC,KAAK,KAAO,EAChB,EAEA,KAAU,mBAAqB,IAAY,CACvC,KAAK,KAAO,EAChB,EAhGA,WAA2B,QAAyB,CAChD,MAAO,CAACG,CAAa,CACzB,CAiCA,IAAW,SAAkB,CACzB,OAAO,KAAK,QAChB,CACA,IAAW,QAAQC,EAAiB,CAChC,GAAIA,IAAY,KAAK,QAGrB,IAAI,CAAC,OAAQ,WAAY,UAAU,EAAE,SAASA,CAAO,EAAG,CACpD,KAAK,aAAa,UAAWA,CAAO,EACpC,KAAK,SAAWA,EAChB,MACJ,CACA,KAAK,gBAAgB,SAAS,EAC9B,KAAK,SAAW,GACpB,CAiDU,qBAA4B,CAClC,KAAK,cAAc,IAAI,MAAM,gBAAiB,CAC1C,QAAS,GACT,SAAU,EACd,CAAC,CAAC,CACN,CAES,QAAyB,CAC9B,MAAMC,EAAUN;AAAA;AAAA;AAAA,iCAGS,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAO9B,OAAI,KAAK,YACEA;AAAA;AAAA,4BAES,KAAK;AAAA,6BACJ,KAAK;AAAA;AAAA,iCAED,KAAK;AAAA,sCACA,KAAK;AAAA,0CACD;AAAA,iCACT,KAAK;AAAA,iCACL,KAAK;AAAA;AAAA,sBAEhBM;AAAA;AAAA,cAIHA,CAEf,CACJ,CAxIa,QAQF,cAAgB,EAKhBC,EAAA,CADNL,EAAS,CAAE,KAAM,QAAS,UAAW,cAAe,CAAC,GAZ7C,QAaF,2BAGAK,EAAA,CADNL,EAAS,CAAE,KAAM,OAAQ,QAAS,EAAK,CAAC,GAfhC,QAgBF,sBAIAK,EAAA,CADNL,EAAS,CAAE,KAAM,QAAS,QAAS,EAAK,CAAC,GAnBjC,QAoBF,oBAOAK,EAAA,CADNL,EAAS,CAAE,QAAS,EAAK,CAAC,GA1BlB,QA2BF,yBAGAK,EAAA,CADNJ,EAAM,MAAM,GA7BJ,QA8BF,0BAMII,EAAA,CADVL,EAAS,CAAE,KAAM,MAAO,CAAC,GAnCjB,QAoCE",
6
+ "names": ["html", "SpectrumElement", "property", "query", "tooltipStyles", "variant", "tooltip", "__decorateClass"]
7
7
  }
@@ -17,6 +17,7 @@ const config = {
17
17
  name: 'tooltip',
18
18
  host: {
19
19
  selector: '.spectrum-Tooltip',
20
+ shadowSelector: '#tooltip',
20
21
  },
21
22
  attributes: [
22
23
  {
@@ -3,7 +3,7 @@ import { css } from "@spectrum-web-components/base";
3
3
  const styles = css`
4
4
  :host{--spectrum-overlay-animation-distance:6px;--spectrum-overlay-animation-duration:var(
5
5
  --spectrum-animation-duration-100
6
- );opacity:0;pointer-events:none;transition:transform var(--spectrum-overlay-animation-duration) ease-in-out,opacity var(--spectrum-overlay-animation-duration) ease-in-out,visibility 0ms linear var(--spectrum-overlay-animation-duration);visibility:hidden}:host([open]){opacity:1;pointer-events:auto;transition-delay:0ms;visibility:visible}:host([open]) .spectrum-Tooltip--bottom-end,:host([open]) .spectrum-Tooltip--bottom-left,:host([open]) .spectrum-Tooltip--bottom-right,:host([open]) .spectrum-Tooltip--bottom-start,:host([placement*=bottom][open]){--spectrum-overlay-animation-distance:6px;transform:translateY(var(--spectrum-overlay-animation-distance))}:host([open]),:host([open]) .spectrum-Tooltip--top-end,:host([open]) .spectrum-Tooltip--top-left,:host([open]) .spectrum-Tooltip--top-right,:host([open]) .spectrum-Tooltip--top-start,:host([placement*=top][open]){--spectrum-overlay-animation-distance:6px;transform:translateY(calc(var(--spectrum-overlay-animation-distance)*-1))}:host([dir=rtl][open]) .spectrum-Tooltip--start,:host([dir=rtl][open]) .spectrum-Tooltip--start-bottom,:host([dir=rtl][open]) .spectrum-Tooltip--start-top,:host([open]) .spectrum-Tooltip--end,:host([open]) .spectrum-Tooltip--end-bottom,:host([open]) .spectrum-Tooltip--end-top,:host([open]) .spectrum-Tooltip--right-bottom,:host([open]) .spectrum-Tooltip--right-top,:host([placement*=right][open]){--spectrum-overlay-animation-distance:6px;transform:translateX(var(--spectrum-overlay-animation-distance))}:host([dir=rtl][open]) .spectrum-Tooltip--end,:host([dir=rtl][open]) .spectrum-Tooltip--end-bottom,:host([dir=rtl][open]) .spectrum-Tooltip--end-top,:host([open]) .spectrum-Tooltip--left-bottom,:host([open]) .spectrum-Tooltip--left-top,:host([open]) .spectrum-Tooltip--start,:host([open]) .spectrum-Tooltip--start-bottom,:host([open]) .spectrum-Tooltip--start-top,:host([placement*=left][open]){--spectrum-overlay-animation-distance:6px;transform:translateX(calc(var(--spectrum-overlay-animation-distance)*-1))}:host{--spectrum-tooltip-animation-duration:var(
6
+ )}#tooltip{opacity:0;pointer-events:none;transition:transform var(--spectrum-overlay-animation-duration) ease-in-out,opacity var(--spectrum-overlay-animation-duration) ease-in-out,visibility 0ms linear var(--spectrum-overlay-animation-duration);visibility:hidden}:host([open]) #tooltip{opacity:1;pointer-events:auto;transition-delay:0ms;visibility:visible}:host([open]) .spectrum-Tooltip--bottom-end,:host([open]) .spectrum-Tooltip--bottom-left,:host([open]) .spectrum-Tooltip--bottom-right,:host([open]) .spectrum-Tooltip--bottom-start,:host([placement*=bottom][open]) #tooltip{--spectrum-overlay-animation-distance:6px;transform:translateY(var(--spectrum-overlay-animation-distance))}:host([open]) #tooltip,:host([open]) .spectrum-Tooltip--top-end,:host([open]) .spectrum-Tooltip--top-left,:host([open]) .spectrum-Tooltip--top-right,:host([open]) .spectrum-Tooltip--top-start,:host([placement*=top][open]) #tooltip{--spectrum-overlay-animation-distance:6px;transform:translateY(calc(var(--spectrum-overlay-animation-distance)*-1))}:host([dir=rtl][open]) .spectrum-Tooltip--start,:host([dir=rtl][open]) .spectrum-Tooltip--start-bottom,:host([dir=rtl][open]) .spectrum-Tooltip--start-top,:host([open]) .spectrum-Tooltip--end,:host([open]) .spectrum-Tooltip--end-bottom,:host([open]) .spectrum-Tooltip--end-top,:host([open]) .spectrum-Tooltip--right-bottom,:host([open]) .spectrum-Tooltip--right-top,:host([placement*=right][open]) #tooltip{--spectrum-overlay-animation-distance:6px;transform:translateX(var(--spectrum-overlay-animation-distance))}:host([dir=rtl][open]) .spectrum-Tooltip--end,:host([dir=rtl][open]) .spectrum-Tooltip--end-bottom,:host([dir=rtl][open]) .spectrum-Tooltip--end-top,:host([open]) .spectrum-Tooltip--left-bottom,:host([open]) .spectrum-Tooltip--left-top,:host([open]) .spectrum-Tooltip--start,:host([open]) .spectrum-Tooltip--start-bottom,:host([open]) .spectrum-Tooltip--start-top,:host([placement*=left][open]) #tooltip{--spectrum-overlay-animation-distance:6px;transform:translateX(calc(var(--spectrum-overlay-animation-distance)*-1))}:host{--spectrum-tooltip-animation-duration:var(
7
7
  --spectrum-animation-duration-100
8
8
  );--spectrum-tooltip-animation-distance:var(--spectrum-spacing-75);--spectrum-tooltip-margin:0px;--spectrum-tooltip-height:var(--spectrum-component-height-75);--spectrum-tooltip-max-inline-size:var(--spectrum-tooltip-maximum-width);--spectrum-tooltip-border-radius:var(--spectrum-corner-radius-100);--spectrum-tooltip-icon-width:var(--spectrum-workflow-icon-size-50);--spectrum-tooltip-icon-height:var(--spectrum-workflow-icon-size-50);--spectrum-tooltip-font-size:var(--spectrum-font-size-75);--spectrum-tooltip-line-height:var(--spectrum-line-height-100);--spectrum-tooltip-cjk-line-height:var(--spectrum-line-height-cjk-100);--spectrum-tooltip-font-weight:var(--spectrum-font-weight-regular);--spectrum-tooltip-spacing-inline:var(
9
9
  --spectrum-component-edge-to-text-75
@@ -27,7 +27,7 @@ const styles = css`
27
27
  --spectrum-corner-radius-100
28
28
  );--spectrum-tooltip-background-color-default:var(
29
29
  --spectrum-tooltip-backgound-color-default-neutral
30
- )}@media (forced-colors:active){:host{border:1px solid transparent}#tip{--highcontrast-tooltip-background-color-default:CanvasText;--highcontrast-tooltip-background-color-informative:CanvasText;--highcontrast-tooltip-background-color-positive:CanvasText;--highcontrast-tooltip-background-color-negative:CanvasText;forced-color-adjust:none}}:host{-webkit-font-smoothing:antialiased;align-items:center;background-color:var(
30
+ )}@media (forced-colors:active){#tooltip{border:1px solid transparent}#tip{--highcontrast-tooltip-background-color-default:CanvasText;--highcontrast-tooltip-background-color-informative:CanvasText;--highcontrast-tooltip-background-color-positive:CanvasText;--highcontrast-tooltip-background-color-negative:CanvasText;forced-color-adjust:none}}#tooltip{-webkit-font-smoothing:antialiased;align-items:center;background-color:var(
31
31
  --highcontrast-tooltip-background-color-default,var(
32
32
  --mod-tooltip-background-color-default,var(--spectrum-tooltip-background-color-default)
33
33
  )
@@ -43,17 +43,17 @@ const styles = css`
43
43
  --mod-tooltip-max-inline-size,var(--spectrum-tooltip-max-inline-size)
44
44
  );min-block-size:var(--mod-tooltip-height,var(--spectrum-tooltip-height));padding-inline:var(
45
45
  --mod-tooltip-spacing-inline,var(--spectrum-tooltip-spacing-inline)
46
- );position:relative;vertical-align:top;width:auto;word-break:break-word}:host(:lang(ja)),:host(:lang(ko)),:host(:lang(zh)){line-height:var(
46
+ );position:relative;vertical-align:top;width:auto;word-break:break-word}#tooltip:lang(ja),#tooltip:lang(ko),#tooltip:lang(zh){line-height:var(
47
47
  --mod-tooltip-cjk-line-height,var(--spectrum-tooltip-cjk-line-height)
48
- )}:host{cursor:default;-webkit-user-select:none;user-select:none}p{margin:0}:host([variant=info]){background-color:var(
48
+ )}#tooltip{cursor:default;-webkit-user-select:none;user-select:none}p{margin:0}:host([variant=info]) #tooltip{background-color:var(
49
49
  --highcontrast-tooltip-background-color-informative,var(
50
50
  --mod-tooltip-background-color-informative,var(--spectrum-tooltip-background-color-informative)
51
51
  )
52
- )}:host([variant=positive]){background-color:var(
52
+ )}:host([variant=positive]) #tooltip{background-color:var(
53
53
  --highcontrast-tooltip-background-color-positive,var(
54
54
  --mod-tooltip-background-color-positive,var(--spectrum-tooltip-background-color-positive)
55
55
  )
56
- )}:host([variant=negative]){background-color:var(
56
+ )}:host([variant=negative]) #tooltip{background-color:var(
57
57
  --highcontrast-tooltip-background-color-negative,var(
58
58
  --mod-tooltip-background-color-negative,var(--spectrum-tooltip-background-color-negative)
59
59
  )
@@ -122,16 +122,16 @@ var(--spectrum-tooltip-spacing-inline)
122
122
  --mod-tooltip-spacing-block-end,var(--spectrum-tooltip-spacing-block-end)
123
123
  );margin-block-start:var(
124
124
  --mod-tooltip-spacing-block-start,var(--spectrum-tooltip-spacing-block-start)
125
- )}.spectrum-Tooltip--top-end,.spectrum-Tooltip--top-left,.spectrum-Tooltip--top-right,.spectrum-Tooltip--top-start,:host,:host([placement*=top]){margin-bottom:calc(var(
125
+ )}#tooltip,.spectrum-Tooltip--top-end,.spectrum-Tooltip--top-left,.spectrum-Tooltip--top-right,.spectrum-Tooltip--top-start,:host([placement*=top]) #tooltip{margin-bottom:calc(var(
126
126
  --mod-tooltip-tip-block-size,
127
127
  var(--spectrum-tooltip-tip-block-size)
128
- ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--bottom-end,.spectrum-Tooltip--bottom-left,.spectrum-Tooltip--bottom-right,.spectrum-Tooltip--bottom-start,:host([placement*=bottom]){margin-top:calc(var(
128
+ ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--bottom-end,.spectrum-Tooltip--bottom-left,.spectrum-Tooltip--bottom-right,.spectrum-Tooltip--bottom-start,:host([placement*=bottom]) #tooltip{margin-top:calc(var(
129
129
  --mod-tooltip-tip-block-size,
130
130
  var(--spectrum-tooltip-tip-block-size)
131
- ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--right-bottom,.spectrum-Tooltip--right-top,:host([placement*=right]){margin-left:calc(var(
131
+ ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--right-bottom,.spectrum-Tooltip--right-top,:host([placement*=right]) #tooltip{margin-left:calc(var(
132
132
  --mod-tooltip-tip-block-size,
133
133
  var(--spectrum-tooltip-tip-block-size)
134
- ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--left-bottom,.spectrum-Tooltip--left-top,:host([placement*=left]){margin-right:calc(var(
134
+ ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--left-bottom,.spectrum-Tooltip--left-top,:host([placement*=left]) #tooltip{margin-right:calc(var(
135
135
  --mod-tooltip-tip-block-size,
136
136
  var(--spectrum-tooltip-tip-block-size)
137
137
  ) + var(--mod-tooltip-margin, var(--spectrum-tooltip-margin)))}.spectrum-Tooltip--start,.spectrum-Tooltip--start-bottom,.spectrum-Tooltip--start-top{margin-inline-end:calc(var(