Skip to content

Commit

Permalink
revert(player): "remove decorators"
Browse files Browse the repository at this point in the history
revert commit 1acaec2
  • Loading branch information
mihar-22 committed Aug 8, 2024
1 parent b647dd9 commit 0c0215d
Show file tree
Hide file tree
Showing 18 changed files with 97 additions and 116 deletions.
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
import { Component, computed, provideContext, signal } from 'maverick.js';
import { Component, computed, prop, provideContext, signal } from 'maverick.js';
import { isBoolean } from 'maverick.js/std';

import { useMediaContext, type MediaContext } from '../../../core/api/media-context';
import type { MediaPlayerQuery } from '../../../core/api/player-state';
import { watchColorScheme } from '../../../utils/dom';
import { declare_props } from '../../../utils/typed-decorators';
import { defaultLayoutContext } from './context';
import { defaultLayoutProps, type DefaultLayoutProps } from './props';

Expand All @@ -23,10 +22,12 @@ export class DefaultLayout extends Component<DefaultLayoutProps> {
return this.#matches(when);
});

@prop
get isMatch() {
return this.#when();
}

@prop
get isSmallLayout() {
return this.#smallWhen();
}
Expand Down Expand Up @@ -64,5 +65,3 @@ export class DefaultLayout extends Component<DefaultLayoutProps> {
);
}
}

declare_props(DefaultLayout, ['isMatch', 'isSmallLayout']);
65 changes: 30 additions & 35 deletions packages/vidstack/src/components/player.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,10 @@ import {
Component,
computed,
effect,
method,
onDispose,
peek,
prop,
provideContext,
signal,
type WriteSignalRecord,
Expand Down Expand Up @@ -59,7 +61,6 @@ import type { AnyMediaProvider, MediaProviderAdapter } from '../providers/types'
import { setAttributeIfEmpty } from '../utils/dom';
import { clampNumber } from '../utils/number';
import { IS_IPHONE } from '../utils/support';
import { declare_methods, declare_props } from '../utils/typed-decorators';

declare global {
interface HTMLElementEventMap {
Expand Down Expand Up @@ -127,8 +128,10 @@ export class MediaPlayer
readonly #stateMgr: MediaStateManager;
readonly #requestMgr: MediaRequestManager;

@prop
readonly canPlayQueue = new RequestQueue();

@prop
readonly remoteControl: MediaRemoteControl;

get #provider() {
Expand Down Expand Up @@ -377,13 +380,15 @@ export class MediaPlayer
/**
* The current media provider.
*/
@prop
get provider(): AnyMediaProvider | null {
return this.#provider;
}

/**
* Media controls settings.
*/
@prop
get controls(): MediaControls {
return this.#requestMgr.controls;
}
Expand All @@ -396,11 +401,13 @@ export class MediaPlayer
* Controls the screen orientation of the current browser window and dispatches orientation
* change events on the player.
*/
@prop
readonly orientation: ScreenOrientationController;

/**
* The title of the current media.
*/
@prop
get title() {
return peek(this.$state.providedTitle);
}
Expand All @@ -419,6 +426,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/video-quality}
*/
@prop
get qualities(): VideoQualityList {
return this.#media.qualities;
}
Expand All @@ -428,6 +436,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/audio-tracks}
*/
@prop
get audioTracks(): AudioTrackList {
return this.#media.audioTracks;
}
Expand All @@ -437,6 +446,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/text-tracks}
*/
@prop
get textTracks(): TextTrackList {
return this.#media.textTracks;
}
Expand All @@ -445,10 +455,12 @@ export class MediaPlayer
* Contains text renderers which are responsible for loading, parsing, and rendering text
* tracks.
*/
@prop
get textRenderers(): TextRenderers {
return this.#media.textRenderers;
}

@prop
get duration() {
return this.$state.duration();
}
Expand All @@ -457,6 +469,7 @@ export class MediaPlayer
this.#props.duration.set(duration);
}

@prop
get paused() {
return peek(this.$state.paused);
}
Expand All @@ -475,6 +488,7 @@ export class MediaPlayer
} else this.canPlayQueue.enqueue('paused', () => this.#requestMgr.play());
}

@prop
get muted() {
return peek(this.$state.muted);
}
Expand All @@ -493,6 +507,7 @@ export class MediaPlayer
});
}

@prop
get currentTime() {
return peek(this.$state.currentTime);
}
Expand Down Expand Up @@ -530,6 +545,7 @@ export class MediaPlayer
});
}

@prop
get volume() {
return peek(this.$state.volume);
}
Expand All @@ -549,6 +565,7 @@ export class MediaPlayer
});
}

@prop
get playbackRate() {
return peek(this.$state.playbackRate);
}
Expand Down Expand Up @@ -615,6 +632,7 @@ export class MediaPlayer
*
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/play}
*/
@method
async play(trigger?: Event) {
return this.#requestMgr.play(trigger);
}
Expand All @@ -625,6 +643,7 @@ export class MediaPlayer
*
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/pause}
*/
@method
async pause(trigger?: Event) {
return this.#requestMgr.pause(trigger);
}
Expand All @@ -635,6 +654,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/fullscreen}
*/
@method
async enterFullscreen(target?: MediaFullscreenRequestTarget, trigger?: Event) {
return this.#requestMgr.enterFullscreen(target, trigger);
}
Expand All @@ -645,6 +665,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/fullscreen}
*/
@method
async exitFullscreen(target?: MediaFullscreenRequestTarget, trigger?: Event) {
return this.#requestMgr.exitFullscreen(target, trigger);
}
Expand All @@ -656,6 +677,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/picture-in-picture}
*/
@method
enterPictureInPicture(trigger?: Event) {
return this.#requestMgr.enterPictureInPicture(trigger);
}
Expand All @@ -666,6 +688,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/picture-in-picture}
*/
@method
exitPictureInPicture(trigger?: Event) {
return this.#requestMgr.exitPictureInPicture(trigger);
}
Expand All @@ -676,6 +699,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/live}
*/
@method
seekToLiveEdge(trigger?: Event): void {
this.#requestMgr.seekToLiveEdge(trigger);
}
Expand All @@ -686,6 +710,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/core-concepts/loading#load-strategies}
*/
@method
startLoading(trigger?: Event): void {
this.#media.notify('can-load', undefined, trigger);
}
Expand All @@ -695,13 +720,15 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/core-concepts/loading#load-strategies}
*/
@method
startLoadingPoster(trigger?: Event) {
this.#media.notify('can-load-poster', undefined, trigger);
}

/**
* Request Apple AirPlay picker to open.
*/
@method
requestAirPlay(trigger?: Event) {
return this.#requestMgr.requestAirPlay(trigger);
}
Expand All @@ -710,6 +737,7 @@ export class MediaPlayer
* Request Google Cast device picker to open. The Google Cast framework will be loaded if it
* hasn't yet.
*/
@method
requestGoogleCast(trigger?: Event) {
return this.#requestMgr.requestGoogleCast(trigger);
}
Expand All @@ -719,6 +747,7 @@ export class MediaPlayer
*
* @see {@link https://vidstack.io/docs/player/api/audio-gain}
*/
@method
setAudioGain(gain: number, trigger?: Event) {
return this.#requestMgr.setAudioGain(gain, trigger);
}
Expand All @@ -729,37 +758,3 @@ export class MediaPlayer
this.dispatch('destroy');
}
}

declare_props(MediaPlayer, [
'canPlayQueue',
'remoteControl',
'provider',
'controls',
'orientation',
'title',
'qualities',
'audioTracks',
'textTracks',
'textRenderers',
'duration',
'paused',
'muted',
'currentTime',
'volume',
'playbackRate',
]);

declare_methods(MediaPlayer, [
'play',
'pause',
'enterFullscreen',
'exitFullscreen',
'enterPictureInPicture',
'exitPictureInPicture',
'seekToLiveEdge',
'startLoading',
'startLoadingPoster',
'requestAirPlay',
'requestGoogleCast',
'setAudioGain',
]);
6 changes: 2 additions & 4 deletions packages/vidstack/src/components/provider/provider.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,11 @@
import { Component, onDispose, peek, signal, State, tick } from 'maverick.js';
import { Component, method, onDispose, peek, signal, State, tick } from 'maverick.js';
import { animationFrameThrottle, isString, setStyle } from 'maverick.js/std';
import type { CaptionsFileFormat } from 'media-captions';

import { useMediaContext, type MediaContext } from '../../core/api/media-context';
import type { Src } from '../../core/api/src-types';
import { TextTrack, type TextTrackInit } from '../../core/tracks/text/text-track';
import type { MediaProviderLoader } from '../../providers/types';
import { declare_methods } from '../../utils/typed-decorators';
import { SourceSelection } from './source-select';
import { Tracks } from './tracks';

Expand Down Expand Up @@ -75,6 +74,7 @@ export class MediaProvider extends Component<MediaProviderProps, MediaProviderSt

#loadRafId = -1;

@method
load(target: HTMLElement | null | undefined) {
// Hide underlying provider element from screen readers.
target?.setAttribute('aria-hidden', 'true');
Expand Down Expand Up @@ -182,5 +182,3 @@ export class MediaProvider extends Component<MediaProviderProps, MediaProviderSt
tick();
}
}

declare_methods(MediaProvider, ['load']);
6 changes: 2 additions & 4 deletions packages/vidstack/src/components/ui/buttons/toggle-button.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { Component, signal } from 'maverick.js';
import { Component, prop, signal } from 'maverick.js';

import { declare_props } from '../../../utils/typed-decorators';
import { ToggleButtonController } from './toggle-button-controller';

export interface ToggleButtonProps {
Expand Down Expand Up @@ -36,6 +35,7 @@ export class ToggleButton<
/**
* Whether the toggle is currently in a `pressed` state.
*/
@prop
get pressed() {
return this.#pressed();
}
Expand All @@ -47,5 +47,3 @@ export class ToggleButton<
});
}
}

declare_props(ToggleButton, ['pressed']);
6 changes: 2 additions & 4 deletions packages/vidstack/src/components/ui/menu/menu-button.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
import { Component, effect, onDispose, signal, useContext } from 'maverick.js';
import { Component, effect, onDispose, prop, signal, useContext } from 'maverick.js';
import { DOMEvent } from 'maverick.js/std';

import { FocusVisibleController } from '../../../foundation/observers/focus-visible';
import { onPress, setAttributeIfEmpty } from '../../../utils/dom';
import { declare_props } from '../../../utils/typed-decorators';
import { menuContext, type MenuContext } from './menu-context';

/**
Expand All @@ -25,6 +24,7 @@ export class MenuButton extends Component<MenuButtonProps, {}, MenuButtonEvents>
#menu!: MenuContext;
#hintEl = signal<HTMLElement | null>(null);

@prop
get expanded() {
return this.#menu?.expanded() ?? false;
}
Expand Down Expand Up @@ -93,5 +93,3 @@ export interface MenuButtonEvents {
export interface MenuButtonSelectEvent extends DOMEvent<void> {
target: MenuButton;
}

declare_props(MenuButton, ['expanded']);
Loading

0 comments on commit 0c0215d

Please sign in to comment.