@spectrum-web-components/tooltip 0.11.14 → 0.11.16-overlay.7

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.14",
3
+ "version": "0.11.16-overlay.7+a493756c7",
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.2"
61
+ "@spectrum-web-components/overlay": "^0.19.4-overlay.7+a493756c7"
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": "5e11d828243bb3ff572c25b33a8d58844a89f524"
72
+ "gitHead": "a493756c787f12c6266ddeb11cba260cd66b6e41"
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,23 @@ 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
+ this.handleOpenOverlay = () => {
33
+ this.open = true;
59
34
  };
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;
35
+ this.handleCloseOverlay = () => {
36
+ this.open = false;
82
37
  };
83
- this.addEventListener("sp-overlay-query", this.onOverlayQuery);
84
38
  }
85
39
  static get styles() {
86
40
  return [tooltipStyles];
@@ -100,121 +54,42 @@ const _Tooltip = class extends SpectrumElement {
100
54
  this.removeAttribute("variant");
101
55
  this._variant = "";
102
56
  }
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
- }
57
+ handleTransitionend() {
58
+ this.dispatchEvent(
59
+ new Event("transitionend", {
60
+ bubbles: true,
61
+ composed: true
62
+ })
63
+ );
191
64
  }
192
65
  render() {
193
- return html`
194
- <slot name="icon"></slot>
195
- <span id="label"><slot></slot></span>
196
- <span id="tip"></span>
66
+ const tooltip = html`
67
+ <span id="tooltip" @transitionend=${this.handleTransitionend}>
68
+ <slot name="icon"></slot>
69
+ <span id="label"><slot></slot></span>
70
+ <span id="tip"></span>
71
+ </span>
197
72
  `;
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();
73
+ if (this.selfManaged) {
74
+ return html`
75
+ <sp-overlay
76
+ ?open=${this.open}
77
+ offset=${this.offset}
78
+ type="hint"
79
+ .placement=${this.placement}
80
+ .triggerElement=${this.parentElement}
81
+ .triggerInteraction=${"hover"}
82
+ @sp-opened=${this.handleOpenOverlay}
83
+ @sp-closed=${this.handleCloseOverlay}
84
+ >
85
+ ${tooltip}
86
+ </sp-overlay>
87
+ `;
88
+ } else {
89
+ return tooltip;
214
90
  }
215
91
  }
216
- };
217
- export let Tooltip = _Tooltip;
92
+ }
218
93
  /**
219
94
  * @private
220
95
  */
@@ -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 @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\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 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(\n new Event('transitionend', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n override render(): TemplateResult {\n const tooltip = html`\n <span id=\"tooltip\" @transitionend=${this.handleTransitionend}>\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;AAWH,SAAO,cAAc;AAGrB,SAAO,SAAS;AAGhB,SAAO,OAAO;AAOd,SAAO,YAAuB;AAM9B;AAAA,SAAQ,WAAW;AAmBnB,SAAQ,oBAAoB,MAAY;AACpC,WAAK,OAAO;AAAA,IAChB;AAEA,SAAU,qBAAqB,MAAY;AACvC,WAAK,OAAO;AAAA,IAChB;AAAA;AAAA,EAtDA,WAA2B,SAAyB;AAChD,WAAO,CAAC,aAAa;AAAA,EACzB;AAAA,EA8BA,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,EAUU,sBAA4B;AAClC,SAAK;AAAA,MACD,IAAI,MAAM,iBAAiB;AAAA,QACvB,SAAS;AAAA,QACT,UAAU;AAAA,MACd,CAAC;AAAA,IACL;AAAA,EACJ;AAAA,EAES,SAAyB;AAC9B,UAAM,UAAU;AAAA,gDACwB,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAM7C,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;AA7Fa,QAQF,gBAAgB;AAGhB;AAAA,EADN,SAAS,EAAE,MAAM,SAAS,WAAW,eAAe,CAAC;AAAA,GAV7C,QAWF;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,QAAQ,SAAS,KAAK,CAAC;AAAA,GAbhC,QAcF;AAGA;AAAA,EADN,SAAS,EAAE,MAAM,SAAS,SAAS,KAAK,CAAC;AAAA,GAhBjC,QAiBF;AAOA;AAAA,EADN,SAAS,EAAE,SAAS,KAAK,CAAC;AAAA,GAvBlB,QAwBF;AAGA;AAAA,EADN,MAAM,MAAM;AAAA,GA1BJ,QA2BF;AAMI;AAAA,EADV,SAAS,EAAE,MAAM,OAAO,CAAC;AAAA,GAhCjB,QAiCE;",
6
+ "names": []
7
7
  }
package/src/Tooltip.js CHANGED
@@ -1,6 +1,21 @@
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 id="tooltip" @transitionend=${this.handleTransitionend}>
3
+ <slot name="icon"></slot>
4
+ <span id="label"><slot></slot></span>
5
+ <span id="tip"></span>
6
+ </span>
7
+ `;return this.selfManaged?o`
8
+ <sp-overlay
9
+ ?open=${this.open}
10
+ offset=${this.offset}
11
+ type="hint"
12
+ .placement=${this.placement}
13
+ .triggerElement=${this.parentElement}
14
+ .triggerInteraction=${"hover"}
15
+ @sp-opened=${this.handleOpenOverlay}
16
+ @sp-closed=${this.handleCloseOverlay}
17
+ >
18
+ ${e}
19
+ </sp-overlay>
20
+ `: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
21
  //# 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 @property({ type: Boolean, attribute: 'self-managed' })\n public selfManaged = false;\n\n @property({ type: Number, reflect: true })\n public offset = 6;\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 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(\n new Event('transitionend', {\n bubbles: true,\n composed: true,\n })\n );\n }\n\n override render(): TemplateResult {\n const tooltip = html`\n <span id=\"tooltip\" @transitionend=${this.handleTransitionend}>\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,kCAWH,KAAO,YAAc,GAGrB,KAAO,OAAS,EAGhB,KAAO,KAAO,GAOd,KAAO,UAAuB,MAM9B,KAAQ,SAAW,GAmBnB,KAAQ,kBAAoB,IAAY,CACpC,KAAK,KAAO,EAChB,EAEA,KAAU,mBAAqB,IAAY,CACvC,KAAK,KAAO,EAChB,EAtDA,WAA2B,QAAyB,CAChD,MAAO,CAACG,CAAa,CACzB,CA8BA,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,CAUU,qBAA4B,CAClC,KAAK,cACD,IAAI,MAAM,gBAAiB,CACvB,QAAS,GACT,SAAU,EACd,CAAC,CACL,CACJ,CAES,QAAyB,CAC9B,MAAMC,EAAUN;AAAA,gDACwB,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA,UAM7C,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,CA7Fa,QAQF,cAAgB,EAGhBC,EAAA,CADNL,EAAS,CAAE,KAAM,QAAS,UAAW,cAAe,CAAC,GAV7C,QAWF,2BAGAK,EAAA,CADNL,EAAS,CAAE,KAAM,OAAQ,QAAS,EAAK,CAAC,GAbhC,QAcF,sBAGAK,EAAA,CADNL,EAAS,CAAE,KAAM,QAAS,QAAS,EAAK,CAAC,GAhBjC,QAiBF,oBAOAK,EAAA,CADNL,EAAS,CAAE,QAAS,EAAK,CAAC,GAvBlB,QAwBF,yBAGAK,EAAA,CADNJ,EAAM,MAAM,GA1BJ,QA2BF,0BAMII,EAAA,CADVL,EAAS,CAAE,KAAM,MAAO,CAAC,GAhCjB,QAiCE",
6
+ "names": ["html", "SpectrumElement", "property", "query", "tooltipStyles", "variant", "tooltip", "__decorateClass"]
7
7
  }