From ce5f5efc61fd17c7f6399a31cbc95caf2503c477 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 11:00:59 +0300 Subject: [PATCH 1/8] Fix play/pause button in HLS-I Player --- src/Player.ts | 2 +- src/interstitial/PlayerHlsi.ts | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/src/Player.ts b/src/Player.ts index b32a01e..68c9538 100644 --- a/src/Player.ts +++ b/src/Player.ts @@ -299,7 +299,7 @@ export class Player { /** * Indicate that the config was loaded */ - private _configLoaded = false + protected _configLoaded = false /** * UI control visibility manager */ diff --git a/src/interstitial/PlayerHlsi.ts b/src/interstitial/PlayerHlsi.ts index 79949bc..38e2a77 100644 --- a/src/interstitial/PlayerHlsi.ts +++ b/src/interstitial/PlayerHlsi.ts @@ -98,6 +98,8 @@ export class PlayerHlsi extends Player { async loadHlsi(config?: clpp.PlayerConfiguration) { if (!this._ip || !config) {return} await this._ip.loadPaused(config) + // To enabled play/pause button + this._configLoaded = true } /** From ee56c4b14c3f3f9c71ee211b67539ea1a60fd1ec Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 11:05:01 +0300 Subject: [PATCH 2/8] Option to hide top controls bar --- src/interstitial/InterstitialPlayer.tsx | 4 ++++ src/interstitial/components/OverlayHlsi.tsx | 5 +++++ 2 files changed, 9 insertions(+) diff --git a/src/interstitial/InterstitialPlayer.tsx b/src/interstitial/InterstitialPlayer.tsx index b366166..cfa1aa9 100644 --- a/src/interstitial/InterstitialPlayer.tsx +++ b/src/interstitial/InterstitialPlayer.tsx @@ -74,6 +74,10 @@ export type InterstitialPlayerProps = { * If true, track controls are displayed. Defaults to false. */ hasTrackControls?: boolean + /** + * If true, the top controls bar is displayed. Defaults to true. + */ + hasTopControlsBar?: boolean /** * Callback called when the player of multi-controller changes. */ diff --git a/src/interstitial/components/OverlayHlsi.tsx b/src/interstitial/components/OverlayHlsi.tsx index ae2322e..ab3884f 100644 --- a/src/interstitial/components/OverlayHlsi.tsx +++ b/src/interstitial/components/OverlayHlsi.tsx @@ -75,6 +75,10 @@ export type Props = { * If true, track controls are displayed. Defaults to false. */ hasTrackControls?: boolean + /** + * If true, the top controls bar is displayed. Defaults to true. + */ + hasTopControlsBar?: boolean /** * Custom class name for the player container. */ @@ -166,6 +170,7 @@ export const InterstitialOverlay = React.memo((props: Props) => { seekBarSliderClassName={interstitial ? 'pp-ui-color-gold' : undefined} showSeekBarCues={props.showInterstitialMarkers} renderBottomCompanion={renderInterstitialInfo} + hasTopControlsBar={props.hasTopControlsBar ?? true} /> }) From b36fae785ce67ffb344785c06c3c097ba5562087 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 11:07:01 +0300 Subject: [PATCH 3/8] Fix CSS of seek bar cues --- src/themes/pp-ui-base-theme.css | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/themes/pp-ui-base-theme.css b/src/themes/pp-ui-base-theme.css index 725ac08..f21b693 100644 --- a/src/themes/pp-ui-base-theme.css +++ b/src/themes/pp-ui-base-theme.css @@ -550,9 +550,9 @@ .pp-ui-seekbar-cue { background-color: rgba(7, 7, 7, 0.3); - height: 130%; + height: 100%; position: absolute; - top: 16px; + top: 14px; } From 925120b722ccc7789a7a98a4abfe9f7b629f2ed4 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 11:24:11 +0300 Subject: [PATCH 4/8] Add option for top companion component --- app/src/InterstitialPage.tsx | 8 +++++++- app/src/styles.css | 15 ++++++++++++++- src/components/BaseThemeOverlay.tsx | 18 +++++++++++++++--- src/components/FullscreenButton.tsx | 11 ++++++++++- src/interstitial/InterstitialPlayer.tsx | 4 ++++ src/interstitial/components/OverlayHlsi.tsx | 5 +++++ 6 files changed, 55 insertions(+), 6 deletions(-) diff --git a/app/src/InterstitialPage.tsx b/app/src/InterstitialPage.tsx index 1848f0e..67e714f 100644 --- a/app/src/InterstitialPage.tsx +++ b/app/src/InterstitialPage.tsx @@ -25,7 +25,8 @@ export const InterstitialPage = () => { asset={{ source: { // url: 'http://localhost:3000/vod-fixed.m3u8', - url: 'http://localhost:3000/vod-preroll.m3u8', + // url: 'http://localhost:3000/vod-preroll.m3u8', + url: 'https://9457688946fc45ac9a3b526e93b06bf7.us-west-2.alpha.mediatailor.aws.a2z.com/v1/master/5d22c610440c419b9290f9233dc99fe61adb77ab/mt-dev-vod/index.m3u8?aws.insertionMode=GUIDED', type: clpp.Type.HLS, }, }} @@ -34,11 +35,16 @@ export const InterstitialPage = () => { // continues playing for another cca 800ms. This would obviously cause a glitch // in the UI so configure the player to ignore all ended states changes patchIgnoreStateEnded={true} + hasTopControlsBar={false} interstitialOptions={{ // Start resolving X-ASSET-LIST 15 seconds or less before // the cue is scheduled resolutionOffsetSec: 15, }} + renderTopCompanion={(isFullScreen) => { + if (!isFullScreen) {return null} + return
+ }} // onPlayerChanged={p => { // // @ts-ignore // window.player = p diff --git a/app/src/styles.css b/app/src/styles.css index d3805c9..9ebb74e 100644 --- a/app/src/styles.css +++ b/app/src/styles.css @@ -123,5 +123,18 @@ nav button:hover { .in-video-container { width: 800px; - height: 580px; + height: 400px; +} + +.in-logo-container { + width: 100%; + display: flex; + justify-content: end; + padding: 10px; + position: relative; + top: 10px; +} + +.in-logo { + width: 200px; } diff --git a/src/components/BaseThemeOverlay.tsx b/src/components/BaseThemeOverlay.tsx index 0894ab7..4c07d26 100644 --- a/src/components/BaseThemeOverlay.tsx +++ b/src/components/BaseThemeOverlay.tsx @@ -6,7 +6,7 @@ import { BufferingIndicator } from './BufferingIndicator' import { CurrentTime } from './CurrentTime' import { Duration } from './Duration' import { ForSize } from './ForSize' -import { FullscreenButton } from './FullscreenButton' +import { FullscreenButton, useIsPlayerFullScreen } from './FullscreenButton' import { HorizontalBar } from './HorizontalBar' import { Label } from './Label' import { @@ -88,7 +88,11 @@ export interface BaseThemeOverlayProps extends BaseComponentProps { /** * Render a custom bottom companion component. */ - renderBottomCompanion?: () => (JSX.Element | null) + renderBottomCompanion?: (isFullScreen: boolean) => (JSX.Element | null) + /** + * Render a custom top companion component. + */ + renderTopCompanion?: (isFullScreen: boolean) => (JSX.Element | null) /** * If true, seek bar cues are shown. Default: true. */ @@ -109,6 +113,7 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { const hasFullScreenButton = props.hasFullScreenButton ?? true const hasTopControlsBar = props.hasTopControlsBar ?? true const showSeekBarCues = props.showSeekBarCues ?? true + const isFullScreen = useIsPlayerFullScreen() const renderOptionsMenu = () => { if (selectionOptions.length === 0) {return} @@ -139,6 +144,8 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { return } + const topCompanion = props.renderTopCompanion?.(isFullScreen) + return (
@@ -146,6 +153,11 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { {/* Top bar */} {renderTopBar()} + {topCompanion ? ( +
+ {topCompanion} +
+ ): null} @@ -154,7 +166,7 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { - {props.renderBottomCompanion?.()} + {props.renderBottomCompanion?.(isFullScreen)} {/* Bottom bar */} diff --git a/src/components/FullscreenButton.tsx b/src/components/FullscreenButton.tsx index 6f4dcfe..f5ce6d8 100644 --- a/src/components/FullscreenButton.tsx +++ b/src/components/FullscreenButton.tsx @@ -74,7 +74,7 @@ const getVideoChild = (element: HTMLElement) => { * This hook will return whether the element of its descendant video * element is currently in fullscreen mode. */ -const useIsFullscreen = (playerSurface: HTMLElement | null) => { +export const useIsFullscreen = (playerSurface: HTMLElement | null) => { const [is, setIs] = useState(fullscreen.isInFullscreen()) const listener = () => { @@ -100,6 +100,15 @@ const useIsFullscreen = (playerSurface: HTMLElement | null) => { return is } +/** + * This hooks returns true if the player is in fullscreen mode, false otherwise. + */ +export const useIsPlayerFullScreen = () => { + const { playerSurface } = useContext(PrestoContext) + const isFullscreen = useIsFullscreen(playerSurface) + return isFullscreen +} + /** * Fullscreen button. * A button that brings the player into fullscreen mode. diff --git a/src/interstitial/InterstitialPlayer.tsx b/src/interstitial/InterstitialPlayer.tsx index cfa1aa9..eabf61c 100644 --- a/src/interstitial/InterstitialPlayer.tsx +++ b/src/interstitial/InterstitialPlayer.tsx @@ -98,6 +98,10 @@ export type InterstitialPlayerProps = { * If true, the player will ignore all state changes to state "ended". */ patchIgnoreStateEnded?: boolean + /** + * Render a custom top companion component. + */ + renderTopCompanion?: (isFullScreen: boolean) => (JSX.Element | null) } /** diff --git a/src/interstitial/components/OverlayHlsi.tsx b/src/interstitial/components/OverlayHlsi.tsx index ab3884f..b37f5f2 100644 --- a/src/interstitial/components/OverlayHlsi.tsx +++ b/src/interstitial/components/OverlayHlsi.tsx @@ -79,6 +79,10 @@ export type Props = { * If true, the top controls bar is displayed. Defaults to true. */ hasTopControlsBar?: boolean + /** + * Render a custom top companion component. + */ + renderTopCompanion?: (isFullScreen: boolean) => (JSX.Element | null) /** * Custom class name for the player container. */ @@ -171,6 +175,7 @@ export const InterstitialOverlay = React.memo((props: Props) => { showSeekBarCues={props.showInterstitialMarkers} renderBottomCompanion={renderInterstitialInfo} hasTopControlsBar={props.hasTopControlsBar ?? true} + renderTopCompanion={props.renderTopCompanion} /> }) From 8822ea90e17bc94328057c3b6ae85e556d70a5d0 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 11:47:39 +0300 Subject: [PATCH 5/8] Option to change player controls during interstitial --- app/src/InterstitialPage.tsx | 13 +++++++--- src/components/BaseThemeOverlay.tsx | 25 +++++++++++++----- src/interstitial/InterstitialPlayer.tsx | 6 ++++- src/interstitial/components/OverlayHlsi.tsx | 28 ++++++++++++++++++--- src/interstitial/types.ts | 11 ++++++++ 5 files changed, 69 insertions(+), 14 deletions(-) diff --git a/app/src/InterstitialPage.tsx b/app/src/InterstitialPage.tsx index 67e714f..b7c39f1 100644 --- a/app/src/InterstitialPage.tsx +++ b/app/src/InterstitialPage.tsx @@ -24,9 +24,9 @@ export const InterstitialPage = () => { { if (!isFullScreen) {return null} return
}} + interstitialControls={{ + pause: true, + seekButtons: false, + time: false, + fullScreen: true, + audio: false, + }} // onPlayerChanged={p => { // // @ts-ignore // window.player = p diff --git a/src/components/BaseThemeOverlay.tsx b/src/components/BaseThemeOverlay.tsx index 4c07d26..fd1c870 100644 --- a/src/components/BaseThemeOverlay.tsx +++ b/src/components/BaseThemeOverlay.tsx @@ -81,10 +81,18 @@ export interface BaseThemeOverlayProps extends BaseComponentProps { * If true, track controls are displayed. Defaults to true. */ hasTrackControls?: boolean + /** + * If true, the play/pause button is displayed. Defaults to true. + */ + hasPauseButton?: boolean /** * If true, the top controls bar is displayed. Defaults to true. */ hasTopControlsBar?: boolean + /** + * If true, the time is displayed. Defaults to true. + */ + hasTime?: boolean /** * Render a custom bottom companion component. */ @@ -113,6 +121,9 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { const hasFullScreenButton = props.hasFullScreenButton ?? true const hasTopControlsBar = props.hasTopControlsBar ?? true const showSeekBarCues = props.showSeekBarCues ?? true + const hasPauseButton = props.hasPauseButton ?? true + const hasTime = props.hasTime ?? true + const isFullScreen = useIsPlayerFullScreen() const renderOptionsMenu = () => { @@ -171,7 +182,7 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { {/* Bottom bar */}
- + {hasPauseButton ? : null} @@ -188,11 +199,13 @@ export const BaseThemeOverlay = (props: BaseThemeOverlayProps) => { />}
- - - + {hasTime ? ( + + + + ): null} {hasAudioControls ? : null} diff --git a/src/interstitial/InterstitialPlayer.tsx b/src/interstitial/InterstitialPlayer.tsx index eabf61c..bb0cc43 100644 --- a/src/interstitial/InterstitialPlayer.tsx +++ b/src/interstitial/InterstitialPlayer.tsx @@ -8,7 +8,7 @@ import { ControlsVisibilityMode } from '../services/controls' import { InterstitialOverlay } from './components/OverlayHlsi' import { PlayerSurfaceHlsi } from './components/PlayerSurfaceHlsi' import { PlayerHlsi } from './PlayerHlsi' -import { HlsInterstitial } from './types' +import { HlsInterstitial, InterstitialControls } from './types' // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore @@ -102,6 +102,10 @@ export type InterstitialPlayerProps = { * Render a custom top companion component. */ renderTopCompanion?: (isFullScreen: boolean) => (JSX.Element | null) + /** + * Player controls to shown during interstitial playback. + */ + interstitialControls?: InterstitialControls } /** diff --git a/src/interstitial/components/OverlayHlsi.tsx b/src/interstitial/components/OverlayHlsi.tsx index b37f5f2..3b55e31 100644 --- a/src/interstitial/components/OverlayHlsi.tsx +++ b/src/interstitial/components/OverlayHlsi.tsx @@ -6,7 +6,7 @@ import { HorizontalBar } from '../../components/HorizontalBar' import { StartButton } from '../../components/StartButton' import { ControlsVisibilityMode } from '../../services/controls' import { useHlsInterstitial, usePrestoUiEventHlsi } from '../hooks' -import { HlsInterstitial } from '../types' +import { HlsInterstitial, InterstitialControls } from '../types' import { CountDown } from './Countdown' @@ -91,6 +91,10 @@ export type Props = { * Custom style for the player container. */ style?: React.CSSProperties + /** + * Player controls to shown during interstitial playback. + */ + interstitialControls?: InterstitialControls } /** @@ -101,7 +105,21 @@ export const InterstitialOverlay = React.memo((props: Props) => { const [intermission, setIntermission] = useState(true) const interstitial = useHlsInterstitial() const loop = props.loop ?? true - const seekStep = props.seekStep ?? 10 + + let seekStep = props.seekStep ?? 10 + let hasFullScreenButton = props.hasFullScreenButton ?? true + let hasAudioControls = props.hasAudioControls ?? false + let hasTime = true + let hasPauseButton = true + if (props.interstitialControls && interstitial) { + if (props.interstitialControls.seekButtons === false) { + seekStep = 0 + } + hasFullScreenButton = props.interstitialControls.fullScreen + hasAudioControls = props.interstitialControls.audio + hasTime = props.interstitialControls.time + hasPauseButton = props.interstitialControls.pause + } const endIntermission = useCallback(() => { setIntermission(false) @@ -167,11 +185,13 @@ export const InterstitialOverlay = React.memo((props: Props) => { startButton={false} seekForward={seekStep} seekBackward={-seekStep} - hasAudioControls={props.hasAudioControls ?? false} - hasFullScreenButton={props.hasFullScreenButton ?? true} + hasAudioControls={hasAudioControls} + hasFullScreenButton={hasFullScreenButton} hasTrackControls={props.hasTrackControls ?? false} controlsVisibility={props.controlsVisibility ?? 'always-visible'} seekBarSliderClassName={interstitial ? 'pp-ui-color-gold' : undefined} + hasPauseButton={hasPauseButton} + hasTime={hasTime} showSeekBarCues={props.showInterstitialMarkers} renderBottomCompanion={renderInterstitialInfo} hasTopControlsBar={props.hasTopControlsBar ?? true} diff --git a/src/interstitial/types.ts b/src/interstitial/types.ts index 931cfbe..170228d 100644 --- a/src/interstitial/types.ts +++ b/src/interstitial/types.ts @@ -8,3 +8,14 @@ export type HlsInterstitial = { */ podCount: number } + +/** + * Player Controls visible during playback of HLS interstitial assets. + */ +export type InterstitialControls = { + audio: boolean + fullScreen: boolean + pause: boolean + seekButtons: boolean + time: boolean +} From 84a95b28f72d13da06e99f2ab2743c6571bfe864 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 12:21:42 +0300 Subject: [PATCH 6/8] HLS-I Options to listen to events --- app/src/InterstitialPage.tsx | 28 +++++++++++++++++++++++++ src/interstitial/InterstitialPlayer.tsx | 11 +++++++++- src/interstitial/PlayerHlsi.ts | 7 +++++++ 3 files changed, 45 insertions(+), 1 deletion(-) diff --git a/app/src/InterstitialPage.tsx b/app/src/InterstitialPage.tsx index b7c39f1..75db823 100644 --- a/app/src/InterstitialPage.tsx +++ b/app/src/InterstitialPage.tsx @@ -52,6 +52,34 @@ export const InterstitialPage = () => { fullScreen: true, audio: false, }} + onIntermissionEnded={() => { + console.info('EEEEvent: intermission-ended playback or primary or preroll started') + }} + onHlsiPlayerReady={hp => { + hp.on('cues-changed', (event) => { + const cues = hp.getCues() + console.info('EEEEvent: cues-changed', event.detail, 'cues via api call', cues) + }) + + hp.on('interstitial-started', (event) => { + console.info('EEEEvent: interstitial-started', event.detail) + }) + + hp.on('interstitial-item-started', (event) => { + // There are multiple items in one interstitial + console.info('EEEEvent: interstitial-item-started', event.detail) + }) + + hp.on('interstitial-ended', (event) => { + console.info('EEEEvent: interstitial-ended', event.detail) + }) + + hp.on('primary-ended', (event) => { + console.info('EEEEvent: primary-ended', event.detail) + }) + + // Note: Unfortunately we do not have an event for "primary-started" + }} // onPlayerChanged={p => { // // @ts-ignore // window.player = p diff --git a/src/interstitial/InterstitialPlayer.tsx b/src/interstitial/InterstitialPlayer.tsx index bb0cc43..b6c925c 100644 --- a/src/interstitial/InterstitialPlayer.tsx +++ b/src/interstitial/InterstitialPlayer.tsx @@ -41,6 +41,10 @@ export type InterstitialPlayerProps = { * Callback called when one loop cycle ended (if loop is `true`) */ onLoopEnded?: () => any + /** + * Callback called when intermission ended + */ + onIntermissionEnded?: () => any /** * Interstitial label text renderer. Default: `Interstitial ${podOrder} of ${podCount}` */ @@ -106,6 +110,10 @@ export type InterstitialPlayerProps = { * Player controls to shown during interstitial playback. */ interstitialControls?: InterstitialControls + /** + * Callback to get the instance of the HLS interstitial player + */ + onHlsiPlayerReady?: (player: clpp.interstitial.Player) => void } /** @@ -115,7 +123,7 @@ export type InterstitialPlayerProps = { * intermission in between. */ export const InterstitialPlayer = React.memo((props: InterstitialPlayerProps) => { - const playerRef = useRef(new PlayerHlsi()) + const playerRef = useRef(new PlayerHlsi(props.onHlsiPlayerReady)) useEffect(() => { if (props.patchIgnoreStateEnded) { @@ -173,6 +181,7 @@ export const InterstitialPlayer = React.memo((props: InterstitialPlayerProps) => await load() }} onIntermissionEnded={async () => { + props.onIntermissionEnded?.() await playerRef.current.unpause() }} /> diff --git a/src/interstitial/PlayerHlsi.ts b/src/interstitial/PlayerHlsi.ts index 38e2a77..e7da401 100644 --- a/src/interstitial/PlayerHlsi.ts +++ b/src/interstitial/PlayerHlsi.ts @@ -43,6 +43,12 @@ export class PlayerHlsi extends Player { private _isPlayingInterstitial = false private _disposers: Disposer[] = [] + constructor( + private _onReady?: (p: clpp.interstitial.Player) => void, + ) { + super() + } + /** * Initialize the HLS Interstitial player */ @@ -53,6 +59,7 @@ export class PlayerHlsi extends Player { this._options = options this._ip = new clpp.interstitial.Player(options) + this._onReady?.(this._ip) this.on('interstitial-item-started', (event) => { this.emitUIEvent('hlsInterstitial', { From 29e46730201056cf459cc71700822d9e4b672f66 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 13:30:58 +0300 Subject: [PATCH 7/8] More listeners --- app/src/App.tsx | 2 +- app/src/InterstitialPage.tsx | 16 ++++++++++++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/app/src/App.tsx b/app/src/App.tsx index 139b5af..c8c122f 100644 --- a/app/src/App.tsx +++ b/app/src/App.tsx @@ -34,7 +34,7 @@ function setQueryParam(key: string, value: string) { export function App() { // We track the configuration here to make sure we can dynamically change it const [assetId, setAssetId] = useState(Number(getQueryVariable('asset') || 0)) - const [pageId, setPageId] = useState(getQueryVariable('page') ?? 'basic') + const [pageId, setPageId] = useState(getQueryVariable('page') ?? 'interstitial') const [asset, setAsset] = useState(TestAssets[assetId]) const [autoload, setAutoload] = useState(false) const [navVisible, setNavVisible] = useState(false) diff --git a/app/src/InterstitialPage.tsx b/app/src/InterstitialPage.tsx index 75db823..5efc2b8 100644 --- a/app/src/InterstitialPage.tsx +++ b/app/src/InterstitialPage.tsx @@ -40,6 +40,12 @@ export const InterstitialPage = () => { // Start resolving X-ASSET-LIST 15 seconds or less before // the cue is scheduled resolutionOffsetSec: 15, + interstitialAssetConverter: (asset: clpp.interstitial.PlayerItem) => { + asset.config.htmlcue = { + enableResizeObserver: false, + } + return asset + }, }} renderTopCompanion={(isFullScreen) => { if (!isFullScreen) {return null} @@ -74,11 +80,17 @@ export const InterstitialPage = () => { console.info('EEEEvent: interstitial-ended', event.detail) }) + hp.on('primary-started', (event) => { + console.info('EEEEvent: primary-started', event.detail) + }) + + hp.on('playback-started', (event) => { + console.info('EEEEvent: playback-started (primary or preroll)', event.detail) + }) + hp.on('primary-ended', (event) => { console.info('EEEEvent: primary-ended', event.detail) }) - - // Note: Unfortunately we do not have an event for "primary-started" }} // onPlayerChanged={p => { // // @ts-ignore From cc592a90cb65d81006db8941f05338217e33c2e6 Mon Sep 17 00:00:00 2001 From: Artur Finger Date: Tue, 9 Apr 2024 13:32:08 +0300 Subject: [PATCH 8/8] Upgrade to beta 2 --- package-lock.json | 16 ++++++++-------- package.json | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/package-lock.json b/package-lock.json index a7fead5..247033c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -16,7 +16,7 @@ "@babel/preset-env": "^7.22.4", "@babel/preset-react": "^7.22.3", "@babel/preset-typescript": "^7.21.5", - "@castlabs/prestoplay": "^6.11.1-beta.1", + "@castlabs/prestoplay": "^6.11.1-beta.2", "@finga/eslint-config": "^1.2.1", "@rollup/plugin-commonjs": "^23.0.2", "@rollup/plugin-image": "^3.0.2", @@ -75,7 +75,7 @@ "typescript": "^4.8.4" }, "peerDependencies": { - "@castlabs/prestoplay": "^6.6.0", + "@castlabs/prestoplay": "^6.11.1-beta.1", "react": "^18.0.0", "react-dom": "^18.0.0" } @@ -2347,9 +2347,9 @@ "license": "MIT" }, "node_modules/@castlabs/prestoplay": { - "version": "6.11.1-beta.1", - "resolved": "https://registry.npmjs.org/@castlabs/prestoplay/-/prestoplay-6.11.1-beta.1.tgz", - "integrity": "sha512-QUxzyxKaK1KEaC/fPKxFyn5BEqYHU5vXl/DngakgydHr3xHbjTCCL/e0uZ3f2RMyu8KmOiK18EjCjoFon+IhMQ==", + "version": "6.11.1-beta.2", + "resolved": "https://registry.npmjs.org/@castlabs/prestoplay/-/prestoplay-6.11.1-beta.2.tgz", + "integrity": "sha512-9UvrrtIkhaSAfX3eBokWyLHxrix5vTpWC6Gi8MxVvKuEegqVLKJCR65bXZIICMZAjkO2TUA2Z7uM9cTo7ZAxZg==", "dev": true, "peerDependencies": { "@broadpeak/smartlib": "4.5.1-328cb1e", @@ -23316,9 +23316,9 @@ "dev": true }, "@castlabs/prestoplay": { - "version": "6.11.1-beta.1", - "resolved": "https://registry.npmjs.org/@castlabs/prestoplay/-/prestoplay-6.11.1-beta.1.tgz", - "integrity": "sha512-QUxzyxKaK1KEaC/fPKxFyn5BEqYHU5vXl/DngakgydHr3xHbjTCCL/e0uZ3f2RMyu8KmOiK18EjCjoFon+IhMQ==", + "version": "6.11.1-beta.2", + "resolved": "https://registry.npmjs.org/@castlabs/prestoplay/-/prestoplay-6.11.1-beta.2.tgz", + "integrity": "sha512-9UvrrtIkhaSAfX3eBokWyLHxrix5vTpWC6Gi8MxVvKuEegqVLKJCR65bXZIICMZAjkO2TUA2Z7uM9cTo7ZAxZg==", "dev": true, "requires": {} }, diff --git a/package.json b/package.json index d94f03e..b9990c8 100644 --- a/package.json +++ b/package.json @@ -29,7 +29,7 @@ "@babel/preset-env": "^7.22.4", "@babel/preset-react": "^7.22.3", "@babel/preset-typescript": "^7.21.5", - "@castlabs/prestoplay": "^6.11.1-beta.1", + "@castlabs/prestoplay": "^6.11.1-beta.2", "@finga/eslint-config": "^1.2.1", "@rollup/plugin-commonjs": "^23.0.2", "@rollup/plugin-image": "^3.0.2",