@videojs/html 10.0.0-alpha.7 → 10.0.0-alpha.9
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/dist/default/define/ui/alert-dialog-close.js +8 -0
- package/dist/default/define/ui/alert-dialog-close.js.map +1 -0
- package/dist/default/define/ui/alert-dialog-description.js +8 -0
- package/dist/default/define/ui/alert-dialog-description.js.map +1 -0
- package/dist/default/define/ui/alert-dialog-title.js +8 -0
- package/dist/default/define/ui/alert-dialog-title.js.map +1 -0
- package/dist/default/define/ui/alert-dialog.js +14 -0
- package/dist/default/define/ui/alert-dialog.js.map +1 -0
- package/dist/default/define/ui/captions-button.js +7 -0
- package/dist/default/define/ui/captions-button.js.map +1 -0
- package/dist/default/define/ui/slider-thumbnail.js +8 -0
- package/dist/default/define/ui/slider-thumbnail.js.map +1 -0
- package/dist/default/define/ui/slider.js +2 -0
- package/dist/default/define/ui/slider.js.map +1 -1
- package/dist/default/define/ui/time-slider.js +4 -0
- package/dist/default/define/ui/time-slider.js.map +1 -1
- package/dist/default/define/ui/tooltip-group.js +8 -0
- package/dist/default/define/ui/tooltip-group.js.map +1 -0
- package/dist/default/define/ui/tooltip.js +8 -0
- package/dist/default/define/ui/tooltip.js.map +1 -0
- package/dist/default/define/ui/volume-slider.js +2 -0
- package/dist/default/define/ui/volume-slider.js.map +1 -1
- package/dist/default/define/video/minimal-skin.css +18 -26
- package/dist/default/define/video/skin.css +18 -25
- package/dist/default/index.js +13 -3
- package/dist/default/media/hls-video/index.js +5 -1
- package/dist/default/media/hls-video/index.js.map +1 -1
- package/dist/default/skins/dist/default/video/default.tailwind.js +3 -3
- package/dist/default/skins/dist/default/video/default.tailwind.js.map +1 -1
- package/dist/default/skins/dist/default/video/minimal.tailwind.js +3 -3
- package/dist/default/skins/dist/default/video/minimal.tailwind.js.map +1 -1
- package/dist/default/store/provider-mixin.js +2 -2
- package/dist/default/store/provider-mixin.js.map +1 -1
- package/dist/default/ui/alert-dialog/alert-dialog-close-element.js +46 -0
- package/dist/default/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-description-element.js +26 -0
- package/dist/default/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-element.js +73 -0
- package/dist/default/ui/alert-dialog/alert-dialog-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/alert-dialog-title-element.js +26 -0
- package/dist/default/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
- package/dist/default/ui/alert-dialog/context.js +9 -0
- package/dist/default/ui/alert-dialog/context.js.map +1 -0
- package/dist/default/ui/captions-button/captions-button-element.js +25 -0
- package/dist/default/ui/captions-button/captions-button-element.js.map +1 -0
- package/dist/default/ui/controls/controls-group-element.js +1 -1
- package/dist/default/ui/media-element.js +3 -2
- package/dist/default/ui/media-element.js.map +1 -1
- package/dist/default/ui/popover/popover-element.js +6 -3
- package/dist/default/ui/popover/popover-element.js.map +1 -1
- package/dist/default/ui/slider/slider-element.js +10 -5
- package/dist/default/ui/slider/slider-element.js.map +1 -1
- package/dist/default/ui/slider/slider-preview-element.js +51 -0
- package/dist/default/ui/slider/slider-preview-element.js.map +1 -0
- package/dist/default/ui/slider/slider-thumbnail-element.js +23 -0
- package/dist/default/ui/slider/slider-thumbnail-element.js.map +1 -0
- package/dist/default/ui/thumbnail/thumbnail-element.js +4 -1
- package/dist/default/ui/thumbnail/thumbnail-element.js.map +1 -1
- package/dist/default/ui/time-slider/time-slider-element.js +10 -5
- package/dist/default/ui/time-slider/time-slider-element.js.map +1 -1
- package/dist/default/ui/tooltip/context.js +9 -0
- package/dist/default/ui/tooltip/context.js.map +1 -0
- package/dist/default/ui/tooltip/tooltip-element.js +152 -0
- package/dist/default/ui/tooltip/tooltip-element.js.map +1 -0
- package/dist/default/ui/tooltip/tooltip-group-element.js +38 -0
- package/dist/default/ui/tooltip/tooltip-group-element.js.map +1 -0
- package/dist/default/ui/volume-slider/volume-slider-element.js +11 -6
- package/dist/default/ui/volume-slider/volume-slider-element.js.map +1 -1
- package/dist/dev/define/ui/alert-dialog-close.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-close.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-close.js +8 -0
- package/dist/dev/define/ui/alert-dialog-close.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog-description.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-description.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-description.js +8 -0
- package/dist/dev/define/ui/alert-dialog-description.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog-title.d.ts +9 -0
- package/dist/dev/define/ui/alert-dialog-title.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog-title.js +8 -0
- package/dist/dev/define/ui/alert-dialog-title.js.map +1 -0
- package/dist/dev/define/ui/alert-dialog.d.ts +15 -0
- package/dist/dev/define/ui/alert-dialog.d.ts.map +1 -0
- package/dist/dev/define/ui/alert-dialog.js +14 -0
- package/dist/dev/define/ui/alert-dialog.js.map +1 -0
- package/dist/dev/define/ui/captions-button.d.ts +9 -0
- package/dist/dev/define/ui/captions-button.d.ts.map +1 -0
- package/dist/dev/define/ui/captions-button.js +7 -0
- package/dist/dev/define/ui/captions-button.js.map +1 -0
- package/dist/dev/define/ui/slider-thumbnail.d.ts +9 -0
- package/dist/dev/define/ui/slider-thumbnail.d.ts.map +1 -0
- package/dist/dev/define/ui/slider-thumbnail.js +8 -0
- package/dist/dev/define/ui/slider-thumbnail.js.map +1 -0
- package/dist/dev/define/ui/slider.d.ts.map +1 -1
- package/dist/dev/define/ui/slider.js +2 -0
- package/dist/dev/define/ui/slider.js.map +1 -1
- package/dist/dev/define/ui/time-slider.d.ts.map +1 -1
- package/dist/dev/define/ui/time-slider.js +4 -0
- package/dist/dev/define/ui/time-slider.js.map +1 -1
- package/dist/dev/define/ui/tooltip-group.d.ts +9 -0
- package/dist/dev/define/ui/tooltip-group.d.ts.map +1 -0
- package/dist/dev/define/ui/tooltip-group.js +8 -0
- package/dist/dev/define/ui/tooltip-group.js.map +1 -0
- package/dist/dev/define/ui/tooltip.d.ts +9 -0
- package/dist/dev/define/ui/tooltip.d.ts.map +1 -0
- package/dist/dev/define/ui/tooltip.js +8 -0
- package/dist/dev/define/ui/tooltip.js.map +1 -0
- package/dist/dev/define/ui/volume-slider.d.ts.map +1 -1
- package/dist/dev/define/ui/volume-slider.js +2 -0
- package/dist/dev/define/ui/volume-slider.js.map +1 -1
- package/dist/dev/define/video/minimal-skin.css +18 -26
- package/dist/dev/define/video/skin.css +18 -25
- package/dist/dev/index.d.ts +13 -3
- package/dist/dev/index.js +13 -3
- package/dist/dev/media/hls-video/index.d.ts +1 -0
- package/dist/dev/media/hls-video/index.d.ts.map +1 -1
- package/dist/dev/media/hls-video/index.js +5 -1
- package/dist/dev/media/hls-video/index.js.map +1 -1
- package/dist/dev/skins/dist/default/video/default.tailwind.js +3 -3
- package/dist/dev/skins/dist/default/video/default.tailwind.js.map +1 -1
- package/dist/dev/skins/dist/default/video/minimal.tailwind.js +3 -3
- package/dist/dev/skins/dist/default/video/minimal.tailwind.js.map +1 -1
- package/dist/dev/store/provider-mixin.js +2 -2
- package/dist/dev/store/provider-mixin.js.map +1 -1
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts +20 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js +46 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-close-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts +17 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js +26 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-description-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts +22 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.js +73 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts +17 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js +26 -0
- package/dist/dev/ui/alert-dialog/alert-dialog-title-element.js.map +1 -0
- package/dist/dev/ui/alert-dialog/context.d.ts +14 -0
- package/dist/dev/ui/alert-dialog/context.d.ts.map +1 -0
- package/dist/dev/ui/alert-dialog/context.js +9 -0
- package/dist/dev/ui/alert-dialog/context.js.map +1 -0
- package/dist/dev/ui/captions-button/captions-button-element.d.ts +19 -0
- package/dist/dev/ui/captions-button/captions-button-element.d.ts.map +1 -0
- package/dist/dev/ui/captions-button/captions-button-element.js +25 -0
- package/dist/dev/ui/captions-button/captions-button-element.js.map +1 -0
- package/dist/dev/ui/controls/controls-group-element.d.ts +1 -1
- package/dist/dev/ui/controls/controls-group-element.js +1 -1
- package/dist/dev/ui/media-element.d.ts +4 -1
- package/dist/dev/ui/media-element.d.ts.map +1 -1
- package/dist/dev/ui/media-element.js +3 -2
- package/dist/dev/ui/media-element.js.map +1 -1
- package/dist/dev/ui/popover/popover-element.d.ts +1 -0
- package/dist/dev/ui/popover/popover-element.d.ts.map +1 -1
- package/dist/dev/ui/popover/popover-element.js +6 -3
- package/dist/dev/ui/popover/popover-element.js.map +1 -1
- package/dist/dev/ui/slider/slider-element.d.ts +1 -0
- package/dist/dev/ui/slider/slider-element.d.ts.map +1 -1
- package/dist/dev/ui/slider/slider-element.js +10 -5
- package/dist/dev/ui/slider/slider-element.js.map +1 -1
- package/dist/dev/ui/slider/slider-preview-element.js +51 -0
- package/dist/dev/ui/slider/slider-preview-element.js.map +1 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.d.ts +12 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.d.ts.map +1 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.js +23 -0
- package/dist/dev/ui/slider/slider-thumbnail-element.js.map +1 -0
- package/dist/dev/ui/thumbnail/thumbnail-element.d.ts +1 -0
- package/dist/dev/ui/thumbnail/thumbnail-element.d.ts.map +1 -1
- package/dist/dev/ui/thumbnail/thumbnail-element.js +4 -1
- package/dist/dev/ui/thumbnail/thumbnail-element.js.map +1 -1
- package/dist/dev/ui/time-slider/time-slider-element.d.ts +1 -0
- package/dist/dev/ui/time-slider/time-slider-element.d.ts.map +1 -1
- package/dist/dev/ui/time-slider/time-slider-element.js +10 -5
- package/dist/dev/ui/time-slider/time-slider-element.js.map +1 -1
- package/dist/dev/ui/tooltip/context.d.ts +9 -0
- package/dist/dev/ui/tooltip/context.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/context.js +9 -0
- package/dist/dev/ui/tooltip/context.js.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-element.d.ts +54 -0
- package/dist/dev/ui/tooltip/tooltip-element.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-element.js +152 -0
- package/dist/dev/ui/tooltip/tooltip-element.js.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.d.ts +27 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.d.ts.map +1 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.js +38 -0
- package/dist/dev/ui/tooltip/tooltip-group-element.js.map +1 -0
- package/dist/dev/ui/volume-slider/volume-slider-element.d.ts +1 -0
- package/dist/dev/ui/volume-slider/volume-slider-element.d.ts.map +1 -1
- package/dist/dev/ui/volume-slider/volume-slider-element.js +11 -6
- package/dist/dev/ui/volume-slider/volume-slider-element.js.map +1 -1
- package/package.json +6 -6
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { sliderContext } from "./context.js";
|
|
2
|
+
import { ThumbnailElement } from "../thumbnail/thumbnail-element.js";
|
|
3
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
4
|
+
|
|
5
|
+
//#region src/ui/slider/slider-thumbnail-element.ts
|
|
6
|
+
var SliderThumbnailElement = class extends ThumbnailElement {
|
|
7
|
+
static {
|
|
8
|
+
this.tagName = "media-slider-thumbnail";
|
|
9
|
+
}
|
|
10
|
+
#ctx = new ContextConsumer(this, {
|
|
11
|
+
context: sliderContext,
|
|
12
|
+
subscribe: true
|
|
13
|
+
});
|
|
14
|
+
update(changed) {
|
|
15
|
+
const ctx = this.#ctx.value;
|
|
16
|
+
if (ctx) this.time = ctx.pointerValue;
|
|
17
|
+
super.update(changed);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
//#endregion
|
|
22
|
+
export { SliderThumbnailElement };
|
|
23
|
+
//# sourceMappingURL=slider-thumbnail-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slider-thumbnail-element.js","names":["#ctx"],"sources":["../../../../src/ui/slider/slider-thumbnail-element.ts"],"sourcesContent":["import type { PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\n\nimport { ThumbnailElement } from '../thumbnail/thumbnail-element';\nimport { sliderContext } from './context';\n\n// @ts-expect-error TS2417 — tagName narrows to a different literal for custom element registration.\nexport class SliderThumbnailElement extends ThumbnailElement {\n static override readonly tagName = 'media-slider-thumbnail';\n\n readonly #ctx = new ContextConsumer(this, {\n context: sliderContext,\n subscribe: true,\n });\n\n protected override update(changed: PropertyValues): void {\n const ctx = this.#ctx.value;\n if (ctx) this.time = ctx.pointerValue;\n super.update(changed);\n }\n}\n"],"mappings":";;;;;AAOA,IAAa,yBAAb,cAA4C,iBAAiB;;iBACxB;;CAEnC,CAASA,MAAO,IAAI,gBAAgB,MAAM;EACxC,SAAS;EACT,WAAW;EACZ,CAAC;CAEF,AAAmB,OAAO,SAA+B;EACvD,MAAM,MAAM,MAAKA,IAAK;AACtB,MAAI,IAAK,MAAK,OAAO,IAAI;AACzB,QAAM,OAAO,QAAQ"}
|
|
@@ -64,6 +64,7 @@ var ThumbnailElement = class extends MediaElement {
|
|
|
64
64
|
}
|
|
65
65
|
connectedCallback() {
|
|
66
66
|
super.connectedCallback();
|
|
67
|
+
if (this.destroyed) return;
|
|
67
68
|
this.#api = createThumbnail({
|
|
68
69
|
getContainer: () => this,
|
|
69
70
|
getImg: () => this.#img,
|
|
@@ -72,8 +73,10 @@ var ThumbnailElement = class extends MediaElement {
|
|
|
72
73
|
}
|
|
73
74
|
disconnectedCallback() {
|
|
74
75
|
super.disconnectedCallback();
|
|
76
|
+
}
|
|
77
|
+
destroyCallback() {
|
|
75
78
|
this.#api?.destroy();
|
|
76
|
-
|
|
79
|
+
super.destroyCallback();
|
|
77
80
|
}
|
|
78
81
|
update(changed) {
|
|
79
82
|
super.update(changed);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thumbnail-element.js","names":["#core","#img","#textTracks","#externalThumbnails","#api","#thumbnails","#lastTextTrack","#resetStyles","#applyResize"],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"sourcesContent":["import {\n type MediaTextTrackState,\n mapCuesToThumbnails,\n ThumbnailCore,\n ThumbnailDataAttrs,\n type ThumbnailImage,\n type ThumbnailResizeResult,\n} from '@videojs/core';\nimport type { ThumbnailApi } from '@videojs/core/dom';\nimport { applyElementProps, applyStateDataAttrs, createThumbnail, selectTextTrack } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\n\nconst SHADOW_CSS = `\\\n:host {\n display: inline-block;\n overflow: hidden;\n}\nimg {\n display: block;\n}`;\n\nexport class ThumbnailElement extends MediaElement {\n static readonly tagName = 'media-thumbnail';\n\n static override properties = {\n time: { type: Number },\n crossOrigin: { type: String, attribute: 'crossorigin' },\n loading: { type: String },\n fetchPriority: { type: String, attribute: 'fetchpriority' },\n } satisfies PropertyDeclarationMap<keyof ThumbnailCore.Props>;\n\n time = 0;\n crossOrigin: ThumbnailCore.Props['crossOrigin'];\n loading: ThumbnailCore.Props['loading'];\n fetchPriority: ThumbnailCore.Props['fetchPriority'];\n\n readonly #core = new ThumbnailCore();\n readonly #img = document.createElement('img');\n readonly #textTracks = new PlayerController(this, playerContext, selectTextTrack);\n\n #thumbnails: ThumbnailImage[] = [];\n #externalThumbnails: ThumbnailImage[] | undefined;\n #lastTextTrack: MediaTextTrackState | undefined;\n #api: ThumbnailApi | null = null;\n\n constructor() {\n super();\n\n const shadow = this.attachShadow({ mode: 'open' });\n\n const style = document.createElement('style');\n style.textContent = SHADOW_CSS;\n shadow.appendChild(style);\n\n this.#img.alt = '';\n this.#img.setAttribute('part', 'img');\n this.#img.setAttribute('aria-hidden', 'true');\n this.#img.setAttribute('decoding', 'async');\n shadow.appendChild(this.#img);\n }\n\n /**\n * Set thumbnail images directly, bypassing the automatic `<track>` detection.\n * When set, this takes priority over the text track path.\n */\n get thumbnails(): ThumbnailImage[] | undefined {\n return this.#externalThumbnails;\n }\n\n set thumbnails(value: ThumbnailImage[] | undefined) {\n this.#externalThumbnails = value;\n this.requestUpdate();\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#api = createThumbnail({\n getContainer: () => this,\n getImg: () => this.#img,\n onStateChange: () => this.requestUpdate(),\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#api?.destroy();\n
|
|
1
|
+
{"version":3,"file":"thumbnail-element.js","names":["#core","#img","#textTracks","#externalThumbnails","#api","#thumbnails","#lastTextTrack","#resetStyles","#applyResize"],"sources":["../../../../src/ui/thumbnail/thumbnail-element.ts"],"sourcesContent":["import {\n type MediaTextTrackState,\n mapCuesToThumbnails,\n ThumbnailCore,\n ThumbnailDataAttrs,\n type ThumbnailImage,\n type ThumbnailResizeResult,\n} from '@videojs/core';\nimport type { ThumbnailApi } from '@videojs/core/dom';\nimport { applyElementProps, applyStateDataAttrs, createThumbnail, selectTextTrack } from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\n\nconst SHADOW_CSS = `\\\n:host {\n display: inline-block;\n overflow: hidden;\n}\nimg {\n display: block;\n}`;\n\nexport class ThumbnailElement extends MediaElement {\n static readonly tagName = 'media-thumbnail';\n\n static override properties = {\n time: { type: Number },\n crossOrigin: { type: String, attribute: 'crossorigin' },\n loading: { type: String },\n fetchPriority: { type: String, attribute: 'fetchpriority' },\n } satisfies PropertyDeclarationMap<keyof ThumbnailCore.Props>;\n\n time = 0;\n crossOrigin: ThumbnailCore.Props['crossOrigin'];\n loading: ThumbnailCore.Props['loading'];\n fetchPriority: ThumbnailCore.Props['fetchPriority'];\n\n readonly #core = new ThumbnailCore();\n readonly #img = document.createElement('img');\n readonly #textTracks = new PlayerController(this, playerContext, selectTextTrack);\n\n #thumbnails: ThumbnailImage[] = [];\n #externalThumbnails: ThumbnailImage[] | undefined;\n #lastTextTrack: MediaTextTrackState | undefined;\n #api: ThumbnailApi | null = null;\n\n constructor() {\n super();\n\n const shadow = this.attachShadow({ mode: 'open' });\n\n const style = document.createElement('style');\n style.textContent = SHADOW_CSS;\n shadow.appendChild(style);\n\n this.#img.alt = '';\n this.#img.setAttribute('part', 'img');\n this.#img.setAttribute('aria-hidden', 'true');\n this.#img.setAttribute('decoding', 'async');\n shadow.appendChild(this.#img);\n }\n\n /**\n * Set thumbnail images directly, bypassing the automatic `<track>` detection.\n * When set, this takes priority over the text track path.\n */\n get thumbnails(): ThumbnailImage[] | undefined {\n return this.#externalThumbnails;\n }\n\n set thumbnails(value: ThumbnailImage[] | undefined) {\n this.#externalThumbnails = value;\n this.requestUpdate();\n }\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#api = createThumbnail({\n getContainer: () => this,\n getImg: () => this.#img,\n onStateChange: () => this.requestUpdate(),\n });\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n }\n\n override destroyCallback(): void {\n this.#api?.destroy();\n super.destroyCallback();\n }\n\n protected override update(changed: PropertyValues): void {\n super.update(changed);\n\n // Resolve thumbnails: external prop takes priority over auto <track> path.\n if (this.#externalThumbnails) {\n this.#thumbnails = this.#externalThumbnails;\n } else {\n const textTrack = this.#textTracks.value;\n\n if (textTrack !== this.#lastTextTrack) {\n this.#lastTextTrack = textTrack;\n this.#thumbnails =\n textTrack && textTrack.thumbnailCues.length > 0\n ? mapCuesToThumbnails(textTrack.thumbnailCues, textTrack.thumbnailTrackSrc ?? undefined)\n : [];\n }\n }\n\n const thumbnail = this.#core.findActiveThumbnail(this.#thumbnails, this.time);\n\n // Sync img attributes from element properties.\n applyElementProps(this.#img, {\n crossorigin: this.crossOrigin || undefined,\n loading: this.loading,\n fetchpriority: this.fetchPriority,\n });\n\n // Track src changes via the thumbnail API.\n this.#api?.updateSrc(thumbnail?.url);\n\n if (!thumbnail) {\n this.#img.removeAttribute('src');\n this.#resetStyles();\n\n const state = this.#core.getState(false, false, undefined);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n return;\n }\n\n // Set the img src directly (imperative DOM).\n if (this.#img.getAttribute('src') !== thumbnail.url) {\n this.#img.src = thumbnail.url;\n }\n\n const api = this.#api;\n const state = this.#core.getState(api?.loading ?? false, api?.error ?? false, thumbnail);\n applyElementProps(this, this.#core.getAttrs(state));\n applyStateDataAttrs(this, state, ThumbnailDataAttrs);\n\n if (api?.naturalWidth && api.naturalHeight) {\n const constraints = api.readConstraints();\n const result = this.#core.resize(thumbnail, api.naturalWidth, api.naturalHeight, constraints);\n\n if (result) {\n this.#applyResize(result);\n }\n }\n }\n\n #applyResize(result: ThumbnailResizeResult): void {\n this.style.width = `${result.containerWidth}px`;\n this.style.height = `${result.containerHeight}px`;\n\n const imgStyle = this.#img.style;\n imgStyle.width = `${result.imageWidth}px`;\n imgStyle.height = `${result.imageHeight}px`;\n imgStyle.maxWidth = 'none';\n imgStyle.transform =\n result.offsetX || result.offsetY ? `translate(-${result.offsetX}px, -${result.offsetY}px)` : '';\n }\n\n #resetStyles(): void {\n this.style.width = '';\n this.style.height = '';\n\n const imgStyle = this.#img.style;\n imgStyle.width = '';\n imgStyle.height = '';\n imgStyle.maxWidth = '';\n imgStyle.transform = '';\n }\n}\n"],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@ import { playerContext } from "../../player/context.js";
|
|
|
2
2
|
import { MediaElement } from "../media-element.js";
|
|
3
3
|
import { PlayerController } from "../../player/player-controller.js";
|
|
4
4
|
import { sliderContext } from "../slider/context.js";
|
|
5
|
-
import { applyStateDataAttrs, createSlider, getTimeSliderCSSVars, selectBuffer, selectTime } from "@videojs/core/dom";
|
|
5
|
+
import { applyElementProps, applyStateDataAttrs, createSlider, getTimeSliderCSSVars, selectBuffer, selectTime } from "@videojs/core/dom";
|
|
6
6
|
import { ContextProvider } from "@videojs/element/context";
|
|
7
7
|
import { TimeSliderCore, TimeSliderDataAttrs } from "@videojs/core";
|
|
8
8
|
import { applyStyles, isRTL } from "@videojs/utils/dom";
|
|
@@ -51,6 +51,7 @@ var TimeSliderElement = class extends MediaElement {
|
|
|
51
51
|
#disconnect = null;
|
|
52
52
|
connectedCallback() {
|
|
53
53
|
super.connectedCallback();
|
|
54
|
+
if (this.destroyed) return;
|
|
54
55
|
this.#disconnect = new AbortController();
|
|
55
56
|
const signal = this.#disconnect.signal;
|
|
56
57
|
this.#slider = createSlider({
|
|
@@ -76,19 +77,23 @@ var TimeSliderElement = class extends MediaElement {
|
|
|
76
77
|
},
|
|
77
78
|
onDragEnd: () => {
|
|
78
79
|
this.dispatchEvent(new CustomEvent("drag-end", { bubbles: true }));
|
|
79
|
-
}
|
|
80
|
+
},
|
|
81
|
+
adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize)
|
|
80
82
|
});
|
|
83
|
+
applyElementProps(this, this.#slider.rootProps, { signal });
|
|
81
84
|
this.#slider.input.subscribe(() => this.requestUpdate(), { signal });
|
|
82
85
|
this.style.touchAction = "none";
|
|
83
86
|
this.style.userSelect = "none";
|
|
84
87
|
}
|
|
85
88
|
disconnectedCallback() {
|
|
86
89
|
super.disconnectedCallback();
|
|
87
|
-
this.#slider?.destroy();
|
|
88
|
-
this.#slider = null;
|
|
89
90
|
this.#disconnect?.abort();
|
|
90
91
|
this.#disconnect = null;
|
|
91
92
|
}
|
|
93
|
+
destroyCallback() {
|
|
94
|
+
this.#slider?.destroy();
|
|
95
|
+
super.destroyCallback();
|
|
96
|
+
}
|
|
92
97
|
willUpdate(_changed) {
|
|
93
98
|
super.willUpdate(_changed);
|
|
94
99
|
this.#core.setProps(this);
|
|
@@ -109,7 +114,7 @@ var TimeSliderElement = class extends MediaElement {
|
|
|
109
114
|
};
|
|
110
115
|
this.#core.setMedia(media);
|
|
111
116
|
const state = this.#core.getState();
|
|
112
|
-
const cssVars = getTimeSliderCSSVars(state);
|
|
117
|
+
const cssVars = getTimeSliderCSSVars(this.#slider.adjustForAlignment(state));
|
|
113
118
|
applyStyles(this, cssVars);
|
|
114
119
|
applyStateDataAttrs(this, state, TimeSliderDataAttrs);
|
|
115
120
|
this.#provider.setValue({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"time-slider-element.js","names":["#core","#provider","#timeState","#bufferState","#disconnect","#slider"],"sources":["../../../../src/ui/time-slider/time-slider-element.ts"],"sourcesContent":["import { TimeSliderCore, TimeSliderDataAttrs } from '@videojs/core';\nimport {\n applyStateDataAttrs,\n createSlider,\n getTimeSliderCSSVars,\n logMissingFeature,\n type SliderApi,\n selectBuffer,\n selectTime,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\nimport { formatTime } from '@videojs/utils/time';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from '../slider/context';\n\nexport class TimeSliderElement extends MediaElement {\n static readonly tagName = 'media-time-slider';\n\n static override properties = {\n label: { type: String },\n commitThrottle: { type: Number, attribute: 'commit-throttle' },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<Exclude<keyof TimeSliderCore.Props, 'value' | 'min' | 'max'>>;\n\n label = TimeSliderCore.defaultProps.label;\n commitThrottle = TimeSliderCore.defaultProps.commitThrottle;\n step = TimeSliderCore.defaultProps.step;\n largeStep = TimeSliderCore.defaultProps.largeStep;\n orientation = TimeSliderCore.defaultProps.orientation;\n disabled = TimeSliderCore.defaultProps.disabled;\n thumbAlignment = TimeSliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new TimeSliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n readonly #timeState = new PlayerController(this, playerContext, selectTime);\n readonly #bufferState = new PlayerController(this, playerContext, selectBuffer);\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled || !this.#timeState.value,\n getPercent: () => {\n const media = this.#timeState.value;\n if (!media) return 0;\n return this.#core.percentFromValue(media.currentTime);\n },\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueCommit: (percent) => {\n const media = this.#timeState.value;\n if (media) media.seek(this.#core.valueFromPercent(percent));\n },\n commitThrottle: this.commitThrottle,\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n });\n\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n\n // Prevent default touch gestures and text selection during interaction.\n this.style.touchAction = 'none';\n this.style.userSelect = 'none';\n\n if (__DEV__ && !this.#timeState.value) {\n logMissingFeature(this.localName, this.#timeState.displayName!);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#
|
|
1
|
+
{"version":3,"file":"time-slider-element.js","names":["#core","#provider","#timeState","#bufferState","#disconnect","#slider"],"sources":["../../../../src/ui/time-slider/time-slider-element.ts"],"sourcesContent":["import { TimeSliderCore, TimeSliderDataAttrs } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createSlider,\n getTimeSliderCSSVars,\n logMissingFeature,\n type SliderApi,\n selectBuffer,\n selectTime,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\nimport { formatTime } from '@videojs/utils/time';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from '../slider/context';\n\nexport class TimeSliderElement extends MediaElement {\n static readonly tagName = 'media-time-slider';\n\n static override properties = {\n label: { type: String },\n commitThrottle: { type: Number, attribute: 'commit-throttle' },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<Exclude<keyof TimeSliderCore.Props, 'value' | 'min' | 'max'>>;\n\n label = TimeSliderCore.defaultProps.label;\n commitThrottle = TimeSliderCore.defaultProps.commitThrottle;\n step = TimeSliderCore.defaultProps.step;\n largeStep = TimeSliderCore.defaultProps.largeStep;\n orientation = TimeSliderCore.defaultProps.orientation;\n disabled = TimeSliderCore.defaultProps.disabled;\n thumbAlignment = TimeSliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new TimeSliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n readonly #timeState = new PlayerController(this, playerContext, selectTime);\n readonly #bufferState = new PlayerController(this, playerContext, selectBuffer);\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled || !this.#timeState.value,\n getPercent: () => {\n const media = this.#timeState.value;\n if (!media) return 0;\n return this.#core.percentFromValue(media.currentTime);\n },\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueCommit: (percent) => {\n const media = this.#timeState.value;\n if (media) media.seek(this.#core.valueFromPercent(percent));\n },\n commitThrottle: this.commitThrottle,\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),\n });\n\n applyElementProps(this, this.#slider.rootProps, { signal });\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n\n // Prevent default touch gestures and text selection during interaction.\n this.style.touchAction = 'none';\n this.style.userSelect = 'none';\n\n if (__DEV__ && !this.#timeState.value) {\n logMissingFeature(this.localName, this.#timeState.displayName!);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#slider?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(_changed: PropertyValues): void {\n super.willUpdate(_changed);\n this.#core.setProps(this);\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#slider) return;\n\n const time = this.#timeState.value;\n const buffer = this.#bufferState.value;\n if (!time) return;\n\n this.#core.setInput(this.#slider.input.current);\n const media = { ...time, ...(buffer ?? { buffered: [], seekable: [] }) };\n this.#core.setMedia(media);\n const state = this.#core.getState();\n\n const cssVars = getTimeSliderCSSVars(this.#slider.adjustForAlignment(state));\n\n applyStyles(this, cssVars);\n\n // Domain-specific data attributes on root (includes data-seeking).\n applyStateDataAttrs(this, state, TimeSliderDataAttrs);\n\n // Provide context to child elements with base slider data attrs.\n this.#provider.setValue({\n state,\n stateAttrMap: TimeSliderDataAttrs,\n pointerValue: this.#core.valueFromPercent(state.pointerPercent),\n thumbAttrs: this.#core.getAttrs(state),\n thumbProps: this.#slider.thumbProps,\n formatValue: (value) => formatTime(value, state.duration),\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { createContext } from "@videojs/element/context";
|
|
2
|
+
|
|
3
|
+
//#region src/ui/tooltip/context.ts
|
|
4
|
+
const TOOLTIP_GROUP_CONTEXT_KEY = Symbol("@videojs/tooltip-group");
|
|
5
|
+
const tooltipGroupContext = createContext(TOOLTIP_GROUP_CONTEXT_KEY);
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
export { tooltipGroupContext };
|
|
9
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","names":[],"sources":["../../../../src/ui/tooltip/context.ts"],"sourcesContent":["import type { TooltipGroupCore } from '@videojs/core';\nimport { createContext } from '@videojs/element/context';\n\nconst TOOLTIP_GROUP_CONTEXT_KEY = Symbol('@videojs/tooltip-group');\n\nexport const tooltipGroupContext = createContext<TooltipGroupCore>(TOOLTIP_GROUP_CONTEXT_KEY);\n"],"mappings":";;;AAGA,MAAM,4BAA4B,OAAO,yBAAyB;AAElE,MAAa,sBAAsB,cAAgC,0BAA0B"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { MediaElement } from "../media-element.js";
|
|
2
|
+
import { tooltipGroupContext } from "./context.js";
|
|
3
|
+
import { applyElementProps, applyStateDataAttrs, createTooltip, createTransition, getAnchorNameStyle, getAnchorPositionStyle, resolveOffsets } from "@videojs/core/dom";
|
|
4
|
+
import { ContextConsumer } from "@videojs/element/context";
|
|
5
|
+
import { SnapshotController } from "@videojs/store/html";
|
|
6
|
+
import { TooltipCSSVars, TooltipCore, TooltipDataAttrs } from "@videojs/core";
|
|
7
|
+
import { applyStyles, supportsAnchorPositioning } from "@videojs/utils/dom";
|
|
8
|
+
|
|
9
|
+
//#region src/ui/tooltip/tooltip-element.ts
|
|
10
|
+
var TooltipElement = class extends MediaElement {
|
|
11
|
+
constructor(..._args) {
|
|
12
|
+
super(..._args);
|
|
13
|
+
this.open = TooltipCore.defaultProps.open;
|
|
14
|
+
this.defaultOpen = TooltipCore.defaultProps.defaultOpen;
|
|
15
|
+
this.side = TooltipCore.defaultProps.side;
|
|
16
|
+
this.align = TooltipCore.defaultProps.align;
|
|
17
|
+
this.delay = TooltipCore.defaultProps.delay;
|
|
18
|
+
this.closeDelay = TooltipCore.defaultProps.closeDelay;
|
|
19
|
+
this.disableHoverablePopup = TooltipCore.defaultProps.disableHoverablePopup;
|
|
20
|
+
this.disabled = TooltipCore.defaultProps.disabled;
|
|
21
|
+
}
|
|
22
|
+
static {
|
|
23
|
+
this.tagName = "media-tooltip";
|
|
24
|
+
}
|
|
25
|
+
static {
|
|
26
|
+
this.properties = {
|
|
27
|
+
open: { type: Boolean },
|
|
28
|
+
defaultOpen: {
|
|
29
|
+
type: Boolean,
|
|
30
|
+
attribute: "default-open"
|
|
31
|
+
},
|
|
32
|
+
side: { type: String },
|
|
33
|
+
align: { type: String },
|
|
34
|
+
delay: { type: Number },
|
|
35
|
+
closeDelay: {
|
|
36
|
+
type: Number,
|
|
37
|
+
attribute: "close-delay"
|
|
38
|
+
},
|
|
39
|
+
disableHoverablePopup: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
attribute: "disable-hoverable-popup"
|
|
42
|
+
},
|
|
43
|
+
disabled: { type: Boolean }
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
#core = new TooltipCore();
|
|
47
|
+
#groupConsumer = new ContextConsumer(this, { context: tooltipGroupContext });
|
|
48
|
+
#tooltip = null;
|
|
49
|
+
#snapshot = null;
|
|
50
|
+
#disconnect = null;
|
|
51
|
+
#triggerAbort = null;
|
|
52
|
+
#currentTrigger = null;
|
|
53
|
+
connectedCallback() {
|
|
54
|
+
super.connectedCallback();
|
|
55
|
+
this.#disconnect = new AbortController();
|
|
56
|
+
this.#tooltip = createTooltip({
|
|
57
|
+
transition: createTransition(),
|
|
58
|
+
onOpenChange: (nextOpen, details) => {
|
|
59
|
+
this.open = nextOpen;
|
|
60
|
+
this.dispatchEvent(new CustomEvent("open-change", { detail: {
|
|
61
|
+
open: nextOpen,
|
|
62
|
+
...details
|
|
63
|
+
} }));
|
|
64
|
+
},
|
|
65
|
+
delay: () => this.delay,
|
|
66
|
+
closeDelay: () => this.closeDelay,
|
|
67
|
+
disableHoverablePopup: () => this.disableHoverablePopup,
|
|
68
|
+
disabled: () => this.disabled,
|
|
69
|
+
group: () => this.#groupConsumer.value
|
|
70
|
+
});
|
|
71
|
+
this.#tooltip.setPopupElement(this);
|
|
72
|
+
applyElementProps(this, this.#tooltip.popupProps, { signal: this.#disconnect.signal });
|
|
73
|
+
if (this.#snapshot) this.#snapshot.track(this.#tooltip.input);
|
|
74
|
+
else this.#snapshot = new SnapshotController(this, this.#tooltip.input);
|
|
75
|
+
}
|
|
76
|
+
firstUpdated(changed) {
|
|
77
|
+
super.firstUpdated(changed);
|
|
78
|
+
if (this.defaultOpen && !this.open) this.#tooltip?.open();
|
|
79
|
+
}
|
|
80
|
+
disconnectedCallback() {
|
|
81
|
+
super.disconnectedCallback();
|
|
82
|
+
this.#cleanupTrigger();
|
|
83
|
+
this.#tooltip?.destroy();
|
|
84
|
+
this.#tooltip = null;
|
|
85
|
+
this.#disconnect?.abort();
|
|
86
|
+
this.#disconnect = null;
|
|
87
|
+
}
|
|
88
|
+
willUpdate(changed) {
|
|
89
|
+
super.willUpdate(changed);
|
|
90
|
+
this.#core.setProps(this);
|
|
91
|
+
if (this.#tooltip && changed.has("open")) {
|
|
92
|
+
const { active: interactionOpen } = this.#tooltip.input.current;
|
|
93
|
+
if (this.open !== interactionOpen) if (this.open) this.#tooltip.open();
|
|
94
|
+
else this.#tooltip.close();
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
update(_changed) {
|
|
98
|
+
super.update(_changed);
|
|
99
|
+
if (!this.#tooltip) return;
|
|
100
|
+
const triggerEl = this.#findTrigger();
|
|
101
|
+
this.#syncTrigger(triggerEl);
|
|
102
|
+
const input = this.#tooltip.input.current;
|
|
103
|
+
this.#core.setInput(input);
|
|
104
|
+
const state = this.#core.getState();
|
|
105
|
+
applyElementProps(this, this.#core.getPopupAttrs(state));
|
|
106
|
+
applyStateDataAttrs(this, state, TooltipDataAttrs);
|
|
107
|
+
if (this.#currentTrigger) {
|
|
108
|
+
applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));
|
|
109
|
+
applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));
|
|
110
|
+
}
|
|
111
|
+
if (!state.open) return;
|
|
112
|
+
const posOpts = {
|
|
113
|
+
side: state.side,
|
|
114
|
+
align: state.align
|
|
115
|
+
};
|
|
116
|
+
if (supportsAnchorPositioning()) applyStyles(this, getAnchorPositionStyle(this.id, posOpts, void 0, void 0, void 0, void 0, TooltipCSSVars));
|
|
117
|
+
else {
|
|
118
|
+
const triggerRect = this.#currentTrigger?.getBoundingClientRect();
|
|
119
|
+
const selfRect = this.getBoundingClientRect();
|
|
120
|
+
const boundaryRect = document.documentElement.getBoundingClientRect();
|
|
121
|
+
const offsets = resolveOffsets(this, TooltipCSSVars);
|
|
122
|
+
applyStyles(this, getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets, TooltipCSSVars));
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
#findTrigger() {
|
|
126
|
+
if (!this.id) return null;
|
|
127
|
+
return this.getRootNode().querySelector(`[commandfor="${this.id}"]`);
|
|
128
|
+
}
|
|
129
|
+
#syncTrigger(triggerEl) {
|
|
130
|
+
if (triggerEl === this.#currentTrigger) return;
|
|
131
|
+
this.#cleanupTrigger();
|
|
132
|
+
this.#currentTrigger = triggerEl;
|
|
133
|
+
this.#tooltip?.setTriggerElement(triggerEl);
|
|
134
|
+
if (triggerEl && this.#tooltip) {
|
|
135
|
+
this.#triggerAbort = new AbortController();
|
|
136
|
+
applyElementProps(triggerEl, this.#tooltip.triggerProps, { signal: this.#triggerAbort.signal });
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
#cleanupTrigger() {
|
|
140
|
+
if (this.#currentTrigger) {
|
|
141
|
+
applyElementProps(this.#currentTrigger, { "aria-describedby": void 0 });
|
|
142
|
+
this.#currentTrigger.style.removeProperty("anchor-name");
|
|
143
|
+
}
|
|
144
|
+
this.#triggerAbort?.abort();
|
|
145
|
+
this.#triggerAbort = null;
|
|
146
|
+
this.#currentTrigger = null;
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
|
|
150
|
+
//#endregion
|
|
151
|
+
export { TooltipElement };
|
|
152
|
+
//# sourceMappingURL=tooltip-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip-element.js","names":["#core","#groupConsumer","#disconnect","#tooltip","#snapshot","#cleanupTrigger","#findTrigger","#syncTrigger","#currentTrigger","#triggerAbort"],"sources":["../../../../src/ui/tooltip/tooltip-element.ts"],"sourcesContent":["import { TooltipCore, TooltipCSSVars, TooltipDataAttrs, type TooltipInput } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createTooltip,\n createTransition,\n getAnchorNameStyle,\n getAnchorPositionStyle,\n resolveOffsets,\n type TooltipApi,\n type TooltipChangeDetails,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextConsumer } from '@videojs/element/context';\nimport { SnapshotController } from '@videojs/store/html';\nimport { applyStyles, supportsAnchorPositioning } from '@videojs/utils/dom';\n\nimport { MediaElement } from '../media-element';\nimport { tooltipGroupContext } from './context';\n\nexport class TooltipElement extends MediaElement {\n static readonly tagName = 'media-tooltip';\n\n static override properties = {\n open: { type: Boolean },\n defaultOpen: { type: Boolean, attribute: 'default-open' },\n side: { type: String },\n align: { type: String },\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n disableHoverablePopup: { type: Boolean, attribute: 'disable-hoverable-popup' },\n disabled: { type: Boolean },\n } satisfies PropertyDeclarationMap<keyof TooltipCore.Props>;\n\n open = TooltipCore.defaultProps.open;\n defaultOpen = TooltipCore.defaultProps.defaultOpen;\n side = TooltipCore.defaultProps.side;\n align = TooltipCore.defaultProps.align;\n delay = TooltipCore.defaultProps.delay;\n closeDelay = TooltipCore.defaultProps.closeDelay;\n disableHoverablePopup = TooltipCore.defaultProps.disableHoverablePopup;\n disabled = TooltipCore.defaultProps.disabled;\n\n readonly #core = new TooltipCore();\n readonly #groupConsumer = new ContextConsumer(this, { context: tooltipGroupContext });\n #tooltip: TooltipApi | null = null;\n #snapshot: SnapshotController<TooltipInput> | null = null;\n\n // Cleanup controllers\n #disconnect: AbortController | null = null;\n #triggerAbort: AbortController | null = null;\n #currentTrigger: HTMLElement | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n this.#disconnect = new AbortController();\n\n this.#tooltip = createTooltip({\n transition: createTransition(),\n onOpenChange: (nextOpen: boolean, details: TooltipChangeDetails) => {\n this.open = nextOpen;\n this.dispatchEvent(new CustomEvent('open-change', { detail: { open: nextOpen, ...details } }));\n },\n delay: () => this.delay,\n closeDelay: () => this.closeDelay,\n disableHoverablePopup: () => this.disableHoverablePopup,\n disabled: () => this.disabled,\n // Lazy getter — group may arrive after connect via context.\n group: () => this.#groupConsumer.value,\n });\n\n // Register self as the popup element — the element IS the popup.\n this.#tooltip.setPopupElement(this);\n\n // Apply popup event handlers (pointerenter/leave, focusout) to self.\n applyElementProps(this, this.#tooltip.popupProps, { signal: this.#disconnect.signal });\n\n // Subscribe to interaction state for reactive updates.\n if (this.#snapshot) {\n this.#snapshot.track(this.#tooltip.input);\n } else {\n this.#snapshot = new SnapshotController(this, this.#tooltip.input);\n }\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n\n // Uncontrolled mode: open if `defaultOpen` is set. Controlled `open`\n // is already synced by `willUpdate` on the first render cycle.\n if (this.defaultOpen && !this.open) {\n this.#tooltip?.open();\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#cleanupTrigger();\n this.#tooltip?.destroy();\n this.#tooltip = null;\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n protected override willUpdate(changed: PropertyValues): void {\n super.willUpdate(changed);\n this.#core.setProps(this);\n\n // Sync controlled open state\n if (this.#tooltip && changed.has('open')) {\n const { active: interactionOpen } = this.#tooltip.input.current;\n if (this.open !== interactionOpen) {\n if (this.open) {\n this.#tooltip.open();\n } else {\n this.#tooltip.close();\n }\n }\n }\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#tooltip) return;\n\n // Discover trigger via commandfor linkage.\n const triggerEl = this.#findTrigger();\n this.#syncTrigger(triggerEl);\n\n // Derive state from core + input.\n const input = this.#tooltip.input.current;\n this.#core.setInput(input);\n const state = this.#core.getState();\n\n // Apply popup ARIA and data attributes to self.\n applyElementProps(this, this.#core.getPopupAttrs(state));\n applyStateDataAttrs(this, state, TooltipDataAttrs);\n\n // Apply trigger ARIA and anchor-name to the discovered trigger.\n if (this.#currentTrigger) {\n applyElementProps(this.#currentTrigger, this.#core.getTriggerAttrs(state, this.id));\n applyStyles(this.#currentTrigger, getAnchorNameStyle(this.id));\n }\n\n // Skip positioning when closed — no rects to measure.\n if (!state.open) return;\n\n // Apply positioning styles to self.\n const posOpts = { side: state.side, align: state.align };\n\n if (supportsAnchorPositioning()) {\n // Native CSS Anchor Positioning — no JS rect measurements needed.\n applyStyles(\n this,\n getAnchorPositionStyle(this.id, posOpts, undefined, undefined, undefined, undefined, TooltipCSSVars)\n );\n } else {\n // JS fallback: measure rects and resolve CSS var offsets.\n const triggerRect = this.#currentTrigger?.getBoundingClientRect();\n const selfRect = this.getBoundingClientRect();\n const boundaryRect = document.documentElement.getBoundingClientRect();\n const offsets = resolveOffsets(this, TooltipCSSVars);\n applyStyles(\n this,\n getAnchorPositionStyle(this.id, posOpts, triggerRect, selfRect, boundaryRect, offsets, TooltipCSSVars)\n );\n }\n }\n\n // --- Trigger discovery ---\n\n #findTrigger(): HTMLElement | null {\n if (!this.id) return null;\n const root = this.getRootNode() as Document | ShadowRoot;\n return root.querySelector<HTMLElement>(`[commandfor=\"${this.id}\"]`);\n }\n\n #syncTrigger(triggerEl: HTMLElement | null): void {\n if (triggerEl === this.#currentTrigger) return;\n\n this.#cleanupTrigger();\n this.#currentTrigger = triggerEl;\n this.#tooltip?.setTriggerElement(triggerEl);\n\n if (triggerEl && this.#tooltip) {\n this.#triggerAbort = new AbortController();\n applyElementProps(triggerEl, this.#tooltip.triggerProps, { signal: this.#triggerAbort.signal });\n }\n }\n\n #cleanupTrigger(): void {\n if (this.#currentTrigger) {\n // Remove ARIA attributes and anchor-name style from the old trigger.\n applyElementProps(this.#currentTrigger, {\n 'aria-describedby': undefined,\n });\n this.#currentTrigger.style.removeProperty('anchor-name');\n }\n\n this.#triggerAbort?.abort();\n this.#triggerAbort = null;\n this.#currentTrigger = null;\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { MediaElement } from "../media-element.js";
|
|
2
|
+
import { tooltipGroupContext } from "./context.js";
|
|
3
|
+
import { ContextProvider } from "@videojs/element/context";
|
|
4
|
+
import { TooltipGroupCore } from "@videojs/core";
|
|
5
|
+
|
|
6
|
+
//#region src/ui/tooltip/tooltip-group-element.ts
|
|
7
|
+
var TooltipGroupElement = class extends MediaElement {
|
|
8
|
+
constructor(..._args) {
|
|
9
|
+
super(..._args);
|
|
10
|
+
this.delay = TooltipGroupCore.defaultProps.delay;
|
|
11
|
+
this.closeDelay = TooltipGroupCore.defaultProps.closeDelay;
|
|
12
|
+
this.timeout = TooltipGroupCore.defaultProps.timeout;
|
|
13
|
+
}
|
|
14
|
+
static {
|
|
15
|
+
this.tagName = "media-tooltip-group";
|
|
16
|
+
}
|
|
17
|
+
static {
|
|
18
|
+
this.properties = {
|
|
19
|
+
delay: { type: Number },
|
|
20
|
+
closeDelay: {
|
|
21
|
+
type: Number,
|
|
22
|
+
attribute: "close-delay"
|
|
23
|
+
},
|
|
24
|
+
timeout: { type: Number }
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
#core = new TooltipGroupCore();
|
|
28
|
+
#provider = new ContextProvider(this, { context: tooltipGroupContext });
|
|
29
|
+
update(_changed) {
|
|
30
|
+
super.update(_changed);
|
|
31
|
+
this.#core.setProps(this);
|
|
32
|
+
this.#provider.setValue(this.#core);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
//#endregion
|
|
37
|
+
export { TooltipGroupElement };
|
|
38
|
+
//# sourceMappingURL=tooltip-group-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tooltip-group-element.js","names":["#core","#provider"],"sources":["../../../../src/ui/tooltip/tooltip-group-element.ts"],"sourcesContent":["import { TooltipGroupCore } from '@videojs/core';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\n\nimport { MediaElement } from '../media-element';\nimport { tooltipGroupContext } from './context';\n\nexport class TooltipGroupElement extends MediaElement {\n static readonly tagName = 'media-tooltip-group';\n\n static override properties = {\n delay: { type: Number },\n closeDelay: { type: Number, attribute: 'close-delay' },\n timeout: { type: Number },\n } satisfies PropertyDeclarationMap<keyof TooltipGroupCore.Props>;\n\n delay = TooltipGroupCore.defaultProps.delay;\n closeDelay = TooltipGroupCore.defaultProps.closeDelay;\n timeout = TooltipGroupCore.defaultProps.timeout;\n\n readonly #core = new TooltipGroupCore();\n readonly #provider = new ContextProvider(this, { context: tooltipGroupContext });\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n this.#core.setProps(this);\n this.#provider.setValue(this.#core);\n }\n}\n"],"mappings":";;;;;;AAOA,IAAa,sBAAb,cAAyC,aAAa;;;eAS5C,iBAAiB,aAAa;oBACzB,iBAAiB,aAAa;iBACjC,iBAAiB,aAAa;;;iBAVd;;;oBAEG;GAC3B,OAAO,EAAE,MAAM,QAAQ;GACvB,YAAY;IAAE,MAAM;IAAQ,WAAW;IAAe;GACtD,SAAS,EAAE,MAAM,QAAQ;GAC1B;;CAMD,CAASA,OAAQ,IAAI,kBAAkB;CACvC,CAASC,WAAY,IAAI,gBAAgB,MAAM,EAAE,SAAS,qBAAqB,CAAC;CAEhF,AAAmB,OAAO,UAAgC;AACxD,QAAM,OAAO,SAAS;AACtB,QAAKD,KAAM,SAAS,KAAK;AACzB,QAAKC,SAAU,SAAS,MAAKD,KAAM"}
|
|
@@ -2,7 +2,7 @@ import { playerContext } from "../../player/context.js";
|
|
|
2
2
|
import { MediaElement } from "../media-element.js";
|
|
3
3
|
import { PlayerController } from "../../player/player-controller.js";
|
|
4
4
|
import { sliderContext } from "../slider/context.js";
|
|
5
|
-
import { applyStateDataAttrs, createSlider, getSliderCSSVars, selectVolume } from "@videojs/core/dom";
|
|
5
|
+
import { applyElementProps, applyStateDataAttrs, createSlider, getSliderCSSVars, selectVolume } from "@videojs/core/dom";
|
|
6
6
|
import { ContextProvider } from "@videojs/element/context";
|
|
7
7
|
import { SliderDataAttrs, VolumeSliderCore } from "@videojs/core";
|
|
8
8
|
import { applyStyles, isRTL } from "@videojs/utils/dom";
|
|
@@ -44,6 +44,7 @@ var VolumeSliderElement = class extends MediaElement {
|
|
|
44
44
|
#disconnect = null;
|
|
45
45
|
connectedCallback() {
|
|
46
46
|
super.connectedCallback();
|
|
47
|
+
if (this.destroyed) return;
|
|
47
48
|
this.#disconnect = new AbortController();
|
|
48
49
|
const signal = this.#disconnect.signal;
|
|
49
50
|
this.#slider = createSlider({
|
|
@@ -70,19 +71,23 @@ var VolumeSliderElement = class extends MediaElement {
|
|
|
70
71
|
},
|
|
71
72
|
onDragEnd: () => {
|
|
72
73
|
this.dispatchEvent(new CustomEvent("drag-end", { bubbles: true }));
|
|
73
|
-
}
|
|
74
|
+
},
|
|
75
|
+
adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize)
|
|
74
76
|
});
|
|
77
|
+
applyElementProps(this, this.#slider.rootProps, { signal });
|
|
75
78
|
this.#slider.input.subscribe(() => this.requestUpdate(), { signal });
|
|
76
79
|
this.style.touchAction = "none";
|
|
77
80
|
this.style.userSelect = "none";
|
|
78
81
|
}
|
|
79
82
|
disconnectedCallback() {
|
|
80
83
|
super.disconnectedCallback();
|
|
81
|
-
this.#slider?.destroy();
|
|
82
|
-
this.#slider = null;
|
|
83
84
|
this.#disconnect?.abort();
|
|
84
85
|
this.#disconnect = null;
|
|
85
86
|
}
|
|
87
|
+
destroyCallback() {
|
|
88
|
+
this.#slider?.destroy();
|
|
89
|
+
super.destroyCallback();
|
|
90
|
+
}
|
|
86
91
|
willUpdate(_changed) {
|
|
87
92
|
super.willUpdate(_changed);
|
|
88
93
|
this.#core.setProps(this);
|
|
@@ -95,7 +100,7 @@ var VolumeSliderElement = class extends MediaElement {
|
|
|
95
100
|
this.#core.setInput(this.#slider.input.current);
|
|
96
101
|
this.#core.setMedia(media);
|
|
97
102
|
const state = this.#core.getState();
|
|
98
|
-
const cssVars = getSliderCSSVars(state);
|
|
103
|
+
const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));
|
|
99
104
|
applyStyles(this, cssVars);
|
|
100
105
|
applyStateDataAttrs(this, state, SliderDataAttrs);
|
|
101
106
|
this.#provider.setValue({
|
|
@@ -108,7 +113,7 @@ var VolumeSliderElement = class extends MediaElement {
|
|
|
108
113
|
});
|
|
109
114
|
}
|
|
110
115
|
#setVolume(percent) {
|
|
111
|
-
this.#volumeState.value?.
|
|
116
|
+
this.#volumeState.value?.setVolume(this.#core.valueFromPercent(percent) / 100);
|
|
112
117
|
}
|
|
113
118
|
};
|
|
114
119
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"volume-slider-element.js","names":["#core","#provider","#volumeState","#disconnect","#slider","#setVolume"],"sources":["../../../../src/ui/volume-slider/volume-slider-element.ts"],"sourcesContent":["import { SliderDataAttrs, VolumeSliderCore } from '@videojs/core';\nimport {\n applyStateDataAttrs,\n createSlider,\n getSliderCSSVars,\n logMissingFeature,\n type SliderApi,\n selectVolume,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from '../slider/context';\n\nexport class VolumeSliderElement extends MediaElement {\n static readonly tagName = 'media-volume-slider';\n\n static override properties = {\n label: { type: String },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<Exclude<keyof VolumeSliderCore.Props, 'value' | 'min' | 'max'>>;\n\n label = VolumeSliderCore.defaultProps.label;\n step = VolumeSliderCore.defaultProps.step;\n largeStep = VolumeSliderCore.defaultProps.largeStep;\n orientation = VolumeSliderCore.defaultProps.orientation;\n disabled = VolumeSliderCore.defaultProps.disabled;\n thumbAlignment = VolumeSliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new VolumeSliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n readonly #volumeState = new PlayerController(this, playerContext, selectVolume);\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled || !this.#volumeState.value,\n getPercent: () => {\n const media = this.#volumeState.value;\n if (!media) return 0;\n return media.volume * 100;\n },\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueChange: (percent) => {\n this.#setVolume(percent);\n },\n onValueCommit: (percent) => {\n this.#setVolume(percent);\n },\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n });\n\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n\n // Prevent default touch gestures and text selection during interaction.\n this.style.touchAction = 'none';\n this.style.userSelect = 'none';\n\n if (__DEV__ && !this.#volumeState.value) {\n logMissingFeature(this.localName, this.#volumeState.displayName!);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#
|
|
1
|
+
{"version":3,"file":"volume-slider-element.js","names":["#core","#provider","#volumeState","#disconnect","#slider","#setVolume"],"sources":["../../../../src/ui/volume-slider/volume-slider-element.ts"],"sourcesContent":["import { SliderDataAttrs, VolumeSliderCore } from '@videojs/core';\nimport {\n applyElementProps,\n applyStateDataAttrs,\n createSlider,\n getSliderCSSVars,\n logMissingFeature,\n type SliderApi,\n selectVolume,\n} from '@videojs/core/dom';\nimport type { PropertyDeclarationMap, PropertyValues } from '@videojs/element';\nimport { ContextProvider } from '@videojs/element/context';\nimport { applyStyles, isRTL } from '@videojs/utils/dom';\n\nimport { playerContext } from '../../player/context';\nimport { PlayerController } from '../../player/player-controller';\nimport { MediaElement } from '../media-element';\nimport { sliderContext } from '../slider/context';\n\nexport class VolumeSliderElement extends MediaElement {\n static readonly tagName = 'media-volume-slider';\n\n static override properties = {\n label: { type: String },\n step: { type: Number },\n largeStep: { type: Number, attribute: 'large-step' },\n orientation: { type: String },\n disabled: { type: Boolean },\n thumbAlignment: { type: String, attribute: 'thumb-alignment' },\n } satisfies PropertyDeclarationMap<Exclude<keyof VolumeSliderCore.Props, 'value' | 'min' | 'max'>>;\n\n label = VolumeSliderCore.defaultProps.label;\n step = VolumeSliderCore.defaultProps.step;\n largeStep = VolumeSliderCore.defaultProps.largeStep;\n orientation = VolumeSliderCore.defaultProps.orientation;\n disabled = VolumeSliderCore.defaultProps.disabled;\n thumbAlignment = VolumeSliderCore.defaultProps.thumbAlignment;\n\n readonly #core = new VolumeSliderCore();\n readonly #provider = new ContextProvider(this, { context: sliderContext });\n readonly #volumeState = new PlayerController(this, playerContext, selectVolume);\n\n #slider: SliderApi | null = null;\n #disconnect: AbortController | null = null;\n\n override connectedCallback(): void {\n super.connectedCallback();\n if (this.destroyed) return;\n\n this.#disconnect = new AbortController();\n const signal = this.#disconnect.signal;\n\n this.#slider = createSlider({\n getElement: () => this,\n getThumbElement: () => this.querySelector<HTMLElement>('media-slider-thumb'),\n getOrientation: () => this.orientation,\n isRTL: () => isRTL(this),\n isDisabled: () => this.disabled || !this.#volumeState.value,\n getPercent: () => {\n const media = this.#volumeState.value;\n if (!media) return 0;\n return media.volume * 100;\n },\n getStepPercent: () => this.#core.getStepPercent(),\n getLargeStepPercent: () => this.#core.getLargeStepPercent(),\n onValueChange: (percent) => {\n this.#setVolume(percent);\n },\n onValueCommit: (percent) => {\n this.#setVolume(percent);\n },\n onDragStart: () => {\n this.dispatchEvent(new CustomEvent('drag-start', { bubbles: true }));\n },\n onDragEnd: () => {\n this.dispatchEvent(new CustomEvent('drag-end', { bubbles: true }));\n },\n adjustPercent: (raw, thumbSize, trackSize) => this.#core.adjustPercentForAlignment(raw, thumbSize, trackSize),\n });\n\n applyElementProps(this, this.#slider.rootProps, { signal });\n this.#slider.input.subscribe(() => this.requestUpdate(), { signal });\n\n // Prevent default touch gestures and text selection during interaction.\n this.style.touchAction = 'none';\n this.style.userSelect = 'none';\n\n if (__DEV__ && !this.#volumeState.value) {\n logMissingFeature(this.localName, this.#volumeState.displayName!);\n }\n }\n\n override disconnectedCallback(): void {\n super.disconnectedCallback();\n this.#disconnect?.abort();\n this.#disconnect = null;\n }\n\n override destroyCallback(): void {\n this.#slider?.destroy();\n super.destroyCallback();\n }\n\n protected override willUpdate(_changed: PropertyValues): void {\n super.willUpdate(_changed);\n this.#core.setProps(this);\n }\n\n protected override update(_changed: PropertyValues): void {\n super.update(_changed);\n if (!this.#slider) return;\n\n const media = this.#volumeState.value;\n if (!media) return;\n\n this.#core.setInput(this.#slider.input.current);\n this.#core.setMedia(media);\n const state = this.#core.getState();\n\n const cssVars = getSliderCSSVars(this.#slider.adjustForAlignment(state));\n\n applyStyles(this, cssVars);\n\n // Apply data attributes to root.\n applyStateDataAttrs(this, state, SliderDataAttrs);\n\n // Provide context to child elements.\n this.#provider.setValue({\n state,\n stateAttrMap: SliderDataAttrs,\n pointerValue: this.#core.valueFromPercent(state.pointerPercent),\n thumbAttrs: this.#core.getAttrs(state),\n thumbProps: this.#slider.thumbProps,\n formatValue: (value) => `${Math.round(value)}%`,\n });\n }\n\n #setVolume(percent: number): void {\n const media = this.#volumeState.value;\n media?.setVolume(this.#core.valueFromPercent(percent) / 100);\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AlertDialogCloseElement } from "../../ui/alert-dialog/alert-dialog-close-element.js";
|
|
2
|
+
|
|
3
|
+
//#region src/define/ui/alert-dialog-close.d.ts
|
|
4
|
+
declare global {
|
|
5
|
+
interface HTMLElementTagNameMap {
|
|
6
|
+
[AlertDialogCloseElement.tagName]: AlertDialogCloseElement;
|
|
7
|
+
}
|
|
8
|
+
} //# sourceMappingURL=alert-dialog-close.d.ts.map
|
|
9
|
+
//# sourceMappingURL=alert-dialog-close.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-close.d.ts","names":[],"sources":["../../../../src/define/ui/alert-dialog-close.ts"],"mappings":";;;QAKQ,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AlertDialogCloseElement } from "../../ui/alert-dialog/alert-dialog-close-element.js";
|
|
2
|
+
import { safeDefine } from "../safe-define.js";
|
|
3
|
+
|
|
4
|
+
//#region src/define/ui/alert-dialog-close.ts
|
|
5
|
+
safeDefine(AlertDialogCloseElement);
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
//# sourceMappingURL=alert-dialog-close.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-close.js","names":[],"sources":["../../../../src/define/ui/alert-dialog-close.ts"],"sourcesContent":["import { AlertDialogCloseElement } from '../../ui/alert-dialog/alert-dialog-close-element';\nimport { safeDefine } from '../safe-define';\n\nsafeDefine(AlertDialogCloseElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AlertDialogCloseElement.tagName]: AlertDialogCloseElement;\n }\n}\n"],"mappings":";;;;AAGA,WAAW,wBAAwB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AlertDialogDescriptionElement } from "../../ui/alert-dialog/alert-dialog-description-element.js";
|
|
2
|
+
|
|
3
|
+
//#region src/define/ui/alert-dialog-description.d.ts
|
|
4
|
+
declare global {
|
|
5
|
+
interface HTMLElementTagNameMap {
|
|
6
|
+
[AlertDialogDescriptionElement.tagName]: AlertDialogDescriptionElement;
|
|
7
|
+
}
|
|
8
|
+
} //# sourceMappingURL=alert-dialog-description.d.ts.map
|
|
9
|
+
//# sourceMappingURL=alert-dialog-description.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-description.d.ts","names":[],"sources":["../../../../src/define/ui/alert-dialog-description.ts"],"mappings":";;;QAKQ,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,6BAAA,CAA8B,OAAA,GAAU,6BAAA;EAAA;AAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AlertDialogDescriptionElement } from "../../ui/alert-dialog/alert-dialog-description-element.js";
|
|
2
|
+
import { safeDefine } from "../safe-define.js";
|
|
3
|
+
|
|
4
|
+
//#region src/define/ui/alert-dialog-description.ts
|
|
5
|
+
safeDefine(AlertDialogDescriptionElement);
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
//# sourceMappingURL=alert-dialog-description.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-description.js","names":[],"sources":["../../../../src/define/ui/alert-dialog-description.ts"],"sourcesContent":["import { AlertDialogDescriptionElement } from '../../ui/alert-dialog/alert-dialog-description-element';\nimport { safeDefine } from '../safe-define';\n\nsafeDefine(AlertDialogDescriptionElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AlertDialogDescriptionElement.tagName]: AlertDialogDescriptionElement;\n }\n}\n"],"mappings":";;;;AAGA,WAAW,8BAA8B"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AlertDialogTitleElement } from "../../ui/alert-dialog/alert-dialog-title-element.js";
|
|
2
|
+
|
|
3
|
+
//#region src/define/ui/alert-dialog-title.d.ts
|
|
4
|
+
declare global {
|
|
5
|
+
interface HTMLElementTagNameMap {
|
|
6
|
+
[AlertDialogTitleElement.tagName]: AlertDialogTitleElement;
|
|
7
|
+
}
|
|
8
|
+
} //# sourceMappingURL=alert-dialog-title.d.ts.map
|
|
9
|
+
//# sourceMappingURL=alert-dialog-title.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-title.d.ts","names":[],"sources":["../../../../src/define/ui/alert-dialog-title.ts"],"mappings":";;;QAKQ,MAAA;EAAA,UACI,qBAAA;IAAA,CACP,uBAAA,CAAwB,OAAA,GAAU,uBAAA;EAAA;AAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AlertDialogTitleElement } from "../../ui/alert-dialog/alert-dialog-title-element.js";
|
|
2
|
+
import { safeDefine } from "../safe-define.js";
|
|
3
|
+
|
|
4
|
+
//#region src/define/ui/alert-dialog-title.ts
|
|
5
|
+
safeDefine(AlertDialogTitleElement);
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
//# sourceMappingURL=alert-dialog-title.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-dialog-title.js","names":[],"sources":["../../../../src/define/ui/alert-dialog-title.ts"],"sourcesContent":["import { AlertDialogTitleElement } from '../../ui/alert-dialog/alert-dialog-title-element';\nimport { safeDefine } from '../safe-define';\n\nsafeDefine(AlertDialogTitleElement);\n\ndeclare global {\n interface HTMLElementTagNameMap {\n [AlertDialogTitleElement.tagName]: AlertDialogTitleElement;\n }\n}\n"],"mappings":";;;;AAGA,WAAW,wBAAwB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AlertDialogCloseElement } from "../../ui/alert-dialog/alert-dialog-close-element.js";
|
|
2
|
+
import { AlertDialogDescriptionElement } from "../../ui/alert-dialog/alert-dialog-description-element.js";
|
|
3
|
+
import { AlertDialogElement } from "../../ui/alert-dialog/alert-dialog-element.js";
|
|
4
|
+
import { AlertDialogTitleElement } from "../../ui/alert-dialog/alert-dialog-title-element.js";
|
|
5
|
+
|
|
6
|
+
//#region src/define/ui/alert-dialog.d.ts
|
|
7
|
+
declare global {
|
|
8
|
+
interface HTMLElementTagNameMap {
|
|
9
|
+
[AlertDialogElement.tagName]: AlertDialogElement;
|
|
10
|
+
[AlertDialogCloseElement.tagName]: AlertDialogCloseElement;
|
|
11
|
+
[AlertDialogDescriptionElement.tagName]: AlertDialogDescriptionElement;
|
|
12
|
+
[AlertDialogTitleElement.tagName]: AlertDialogTitleElement;
|
|
13
|
+
}
|
|
14
|
+
} //# sourceMappingURL=alert-dialog.d.ts.map
|
|
15
|
+
//# sourceMappingURL=alert-dialog.d.ts.map
|