@wscsports/blaze-web-sdk 0.2.1 → 0.2.3

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.
@@ -12,6 +12,7 @@ export declare function LabelBuilder(): IWidgetLabelBuilder;
12
12
  export declare function pauseCurrentPlayer(): void;
13
13
  export declare function resumeCurrentPlayer(): void;
14
14
  export declare function setGoogleCustomNativeAdsHandler(handler: CustomNativeAdHandler): void;
15
+ export declare function setImaHandler(handler: ImaAdHandler): void;
15
16
  declare const _default: {
16
17
  Initialize: typeof Initialize;
17
18
  WidgetGridView: typeof WidgetGridView;
@@ -24,6 +25,7 @@ declare const _default: {
24
25
  LabelBuilder: typeof LabelBuilder;
25
26
  Delegations: typeof Delegation;
26
27
  setGoogleCustomNativeAdsHandler: typeof setGoogleCustomNativeAdsHandler;
28
+ setImaHandler: typeof setImaHandler;
27
29
  pauseCurrentPlayer: typeof pauseCurrentPlayer;
28
30
  resumeCurrentPlayer: typeof resumeCurrentPlayer;
29
31
  setExternalUserId: typeof setExternalUserId;
@@ -52,13 +54,6 @@ export declare class API {
52
54
 
53
55
  export * from './api';
54
56
 
55
- export declare abstract class BaseDrawableElement extends BaseWidget implements IDrawable {
56
- protected abstract connectedCallback(): void;
57
- protected abstract disconnectedCallback(): void;
58
- protected abstract attributeChangedCallback(name: string, oldValue?: string, newValue?: string): void;
59
- abstract render(): void;
60
- }
61
-
62
57
  export declare abstract class BaseWidget extends HTMLElement {
63
58
  protected _animationDuration: number;
64
59
  constructor();
@@ -114,7 +109,6 @@ export declare class EventsListener {
114
109
  removeAll(): void;
115
110
  }
116
111
 
117
- export * from './base-drawable-element.class';
118
112
  export * from './base-element.class';
119
113
  export * from './debounce';
120
114
  export * from './device-detector.class';
@@ -124,6 +118,21 @@ export * from './singleton.class';
124
118
  export * from './throttle';
125
119
  export * from './url';
126
120
  export * from './device-detector.class';
121
+ export * from './label-builder.class';
122
+
123
+ export declare class BlazeWidgetLabel {
124
+ value: string;
125
+ constructor(value: string);
126
+ static singleLabel(label: string): BlazeWidgetLabel;
127
+ static mustInclude(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
128
+ static atLeastOneOf(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
129
+ mustInclude(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
130
+ atLeastOneOf(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
131
+ toString(): string;
132
+ private static createLabel;
133
+ private static validateAndProceed;
134
+ private static isValidLabelFormat;
135
+ }
127
136
 
128
137
  export interface ILongPressHandlerOptions {
129
138
  onStart: () => void;
@@ -155,7 +164,7 @@ export declare class URLManager {
155
164
  static isBackWasCalled: boolean;
156
165
  static resetLocationAfterStoryClose(): void;
157
166
  static resetLocation(): void;
158
- static updateLocationStoryHash(story?: IStory): void;
167
+ static updateLocationContentHash(content?: IStory | IMoment): void;
159
168
  static getHashMatch(): RegExpMatchArray | null;
160
169
  static getHash(): string;
161
170
  static updateStoryInHash(story: IStory): void;
@@ -278,7 +287,7 @@ export declare class BlazeTypography extends BaseWidget {
278
287
  get fontSize(): ".8rem" | "1rem" | ".5rem";
279
288
  }
280
289
 
281
- type AttributeType = 'disabled' | 'hidden' | 'height' | 'width' | 'icon-color' | 'order';
290
+ type AttributeType = 'disabled' | 'blaze-btn-hidden' | 'blaze-btn-visible' | 'height' | 'width' | 'icon-color' | 'order';
282
291
  export declare class BlazeButton extends BaseWidget {
283
292
  buttonElement: HTMLButtonElement;
284
293
  get refElement(): ShadowRoot | this;
@@ -291,6 +300,7 @@ export declare class BlazeButton extends BaseWidget {
291
300
  get width(): string | number | boolean;
292
301
  setIconUrl(value: string): void;
293
302
  private setIsHidden;
303
+ private setIsVisible;
294
304
  private setIsDisabled;
295
305
  private setHeight;
296
306
  private setWidth;
@@ -454,6 +464,13 @@ export interface IContent {
454
464
  createTime: string;
455
465
  thumbnails: IThumbnail[];
456
466
  hasViewed: boolean;
467
+ type?: string;
468
+ isAd: boolean;
469
+ entities?: {
470
+ gameId: string | null;
471
+ teamId: string | null;
472
+ playerId: string | null;
473
+ };
457
474
  }
458
475
 
459
476
  export interface ICTA {
@@ -522,6 +539,7 @@ export interface ILayer {
522
539
  }
523
540
 
524
541
  export interface IMoment extends IContent {
542
+ type: string;
525
543
  duration: string;
526
544
  thumbnails: IThumbnail[];
527
545
  likes: number;
@@ -530,6 +548,7 @@ export interface IMoment extends IContent {
530
548
  rendition: IRendition;
531
549
  type: string;
532
550
  };
551
+ cta: ICTA;
533
552
  }
534
553
 
535
554
  export interface IContentPage {
@@ -547,6 +566,7 @@ export interface IContentPage {
547
566
  shouldShowImaAd?: boolean;
548
567
  imaUrl?: string;
549
568
  interaction?: Interaction;
569
+ poster?: IThumbnail;
550
570
  }
551
571
  export interface IAdPage {
552
572
  id: string;
@@ -567,17 +587,11 @@ export interface IStory extends IContent {
567
587
  description: string;
568
588
  isLive: boolean;
569
589
  pages: IPage[];
570
- isAd: boolean;
571
590
  adInfo?: IAdInfo;
572
- entities?: {
573
- gameId: string | null;
574
- teamId: string | null;
575
- playerId: string | null;
576
- };
577
591
  }
578
592
 
579
593
  export interface IThumbnail {
580
- type: 'SquareIcon' | 'VerticalTwoByThree' | 'MainThumbnail';
594
+ type: 'SquareIcon' | 'VerticalTwoByThree' | 'MainThumbnail' | 'PosterPortrait';
581
595
  rendition: IRendition;
582
596
  }
583
597
 
@@ -641,18 +655,15 @@ export interface WidgetsTagNameMap {
641
655
  'blaze-widget-item': BlazeWidgetItem;
642
656
  'blaze-widget-layout': BlazeWidgetLayout;
643
657
  'blaze-widget-story': BlazeWidgetStory;
644
- 'blaze-widget-story-preview': BlazeWidgetStoryPreview;
645
658
  'blaze-widget-story-player': BlazeWidgetStoryPlayer;
646
659
  'blaze-widget-story-modal': BlazeWidgetStoryModal;
647
660
  'blaze-widget-moment': BlazeWidgetMoment;
648
- 'blaze-widget-moment-preview': BlazeWidgetMomentPreview;
649
661
  'blaze-widget-moment-player': BlazeWidgetMomentPlayer;
650
662
  'blaze-widget-moment-modal': BlazeWidgetMomentModal;
663
+ 'blaze-widget-moment-seek-bar': BlazeWidgetMomentSeekBar;
651
664
  'blaze-widget-share-modal': BlazeWidgetShareModal;
652
665
  'blaze-widget-cta-modal': BlazeWidgetCtaModal;
653
- 'blaze-widget-image': BlazeWidgetStoryImage;
654
- 'blaze-widget-video': BlazeWidgetStoryVideo;
655
- 'blaze-widget-moment-video': BlazeWidgetMomentVideo;
666
+ 'blaze-widget-video': BlazeWidgetVideo;
656
667
  'blaze-widget-interaction': BlazeWidgetInteraction;
657
668
  'blaze-loader': BlazeLoader;
658
669
  'blaze-chip': BlazeChip;
@@ -674,13 +685,12 @@ interface WidgetsTagNameOptionsMap {
674
685
  'blaze-widget-item': {};
675
686
  'blaze-widget-layout': {};
676
687
  'blaze-widget-story': {};
677
- 'blaze-widget-story-preview': {};
678
688
  'blaze-widget-story-player': {};
679
689
  'blaze-widget-story-modal': {};
680
690
  'blaze-widget-moment': {};
681
- 'blaze-widget-moment-preview': {};
682
691
  'blaze-widget-moment-player': {};
683
692
  'blaze-widget-moment-modal': {};
693
+ 'blaze-widget-moment-seek-bar': {};
684
694
  'blaze-widget-share-modal': {};
685
695
  'blaze-widget-cta-modal': {};
686
696
  'blaze-widget-image': {};
@@ -713,43 +723,29 @@ export declare function isWidgetTheme(theme: any): theme is IWidgetTheme;
713
723
 
714
724
  export * from './svgs';
715
725
 
716
- export declare const playSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"M17.74 30.34V18.53a1.8 1.8 0 0 1 2.77-1.52l9.23 5.92a1.8 1.8 0 0 1 0 3.03l-9.23 5.9a1.8 1.8 0 0 1-2.77-1.52z\"/></svg>";
717
- export declare const pauseSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"2.1\" d=\"M20.33 16.86v15.4m7.34-15.4v15.4\"/></svg>";
718
- export declare const unmuteSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path fill=\"%23fff\" fill-rule=\"evenodd\" d=\"M27.53 16.97a.95.95 0 0 1 1.1-.76c.75.13 2.28.7 3.63 1.9a7.71 7.71 0 0 1 2.62 5.95c0 1.86-.55 3.32-1.33 4.45l-1.38-1.37c.48-.8.8-1.81.8-3.08 0-2.16-.92-3.59-1.97-4.53a6.43 6.43 0 0 0-2.7-1.45.95.95 0 0 1-.77-1.1z\" clip-rule=\"evenodd\"/><path fill=\"%23fff\" fill-rule=\"evenodd\" d=\"M27.54 21.03a.95.95 0 0 1 1.14-.72c.7.16 2.5 1.19 2.5 3.71 0 .7-.15 1.28-.36 1.76l-1.56-1.52c.05-.6-.07-1.25-.48-1.71-.23-.26-.47-.36-.51-.38 0 0-.01 0 0 0a.95.95 0 0 1-.73-1.14z\" clip-rule=\"evenodd\"/><path fill=\"%23fff\" d=\"M23.4 16.79v1.56l1.9 1.9v-4.27c0-.3-.12-.6-.29-.84a1.59 1.59 0 0 0-.7-.57c-.29-.11-.61-.16-.9-.1-.3.06-.61.21-.82.42l-1.31 1.34 1.33 1.34.8-.78z\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"m20.12 18.73-1.76 1.81h-2.59c-.94 0-1.7.76-1.7 1.7v3.45c0 .93.75 1.68 1.67 1.7l2.6.04 4.9 4.9a.65.65 0 0 0 1.1-.46v-9.1\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"m17.13 15.36 17.2 17.19\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"M28.47 30.84A7.2 7.2 0 0 0 31 29.67\"/></svg>";
719
- export declare const muteSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"M28.47 17.14c1.15.2 5.46 1.98 5.46 6.92 0 4.95-4.39 6.63-5.46 6.83\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.8\" d=\"M28.47 21.24c.37.08 1.75.79 1.75 2.78 0 1.99-1.4 2.67-1.75 2.74\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"m18.36 27.48 4.88 4.9a.65.65 0 0 0 1.1-.46V16.09c0-.58-.7-.87-1.1-.45l-4.88 4.94h-2.59c-.94 0-1.7.77-1.7 1.7v3.45c0 .93.75 1.69 1.67 1.7l2.62.05z\"/></svg>";
720
- export declare const shareSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path fill=\"%23fff\" d=\"m21.1 25.4 9.87-9.86 1.42 1.42-9.86 9.87z\"/><path stroke=\"%23fff\" stroke-linecap=\"round\" stroke-width=\"1.9\" d=\"m16.85 19.82 15.33-4.14c.04 0 .07.03.06.06l-4.02 15.34a1.6 1.6 0 0 1-2.97.33l-2.93-5.73-5.77-2.88a1.6 1.6 0 0 1 .3-2.98z\"/></svg>";
721
- export declare const nextSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path stroke=\"%23000\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2.4\" d=\"m21.52 16.22 7.75 7.75m-7.75 7.78L29.27 24\"/></svg>";
722
- export declare const nextPageSvg = "data:image/svg+xml,%3Csvg%20fill%3D%22none%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cmask%20id%3D%22a%22%20style%3D%22mask-type%3Aalpha%22%20width%3D%2224%22%20height%3D%2224%22%20x%3D%220%22%20y%3D%220%22%20maskUnits%3D%22userSpaceOnUse%22%3E%3Cpath%20fill%3D%22%23D9D9D9%22%20d%3D%22M0%200h24v24H0z%22%2F%3E%3C%2Fmask%3E%3Cg%20mask%3D%22url(%23a)%22%3E%3Cpath%20fill%3D%22%23000%22%20fill-opacity%3D%22.92%22%20d%3D%22M9.4%2018L8%2016.6l4.6-4.6L8%207.4%209.4%206l6%206-6%206z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E";
723
- export declare const prevPageSvg = "data:image/svg+xml,%3Csvg%20fill%3D%22none%22%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cmask%20id%3D%22a%22%20style%3D%22mask-type%3Aalpha%22%20width%3D%2224%22%20height%3D%2224%22%20x%3D%220%22%20y%3D%220%22%20maskUnits%3D%22userSpaceOnUse%22%3E%3Cpath%20fill%3D%22%23D9D9D9%22%20d%3D%22M0%200h24v24H0z%22%2F%3E%3C%2Fmask%3E%3Cg%20mask%3D%22url(%23a)%22%3E%3Cpath%20fill%3D%22%23000%22%20fill-opacity%3D%22.92%22%20d%3D%22M14%2018l-6-6%206-6%201.4%201.4-4.6%204.6%204.6%204.6L14%2018z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E";
724
- export declare const prevSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" fill=\"none\"><path stroke=\"%23000\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2.4\" d=\"m21.52 16.22 7.75 7.75m-7.75 7.78L29.27 24\"/></svg>";
725
- export declare const closeSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\" data-testid=\"CloseIcon\"><path fill=\"%23fff\" d=\"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"></path></svg>";
726
- export declare const closeSvgBlack = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"48\" height=\"48\" focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\" data-testid=\"CloseIcon\"><path fill=\"%23000\" d=\"M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"></path></svg>";
727
- export declare const nextStory = "data:image/svg+xml;charset=utf-8,<svg viewBox=\"0 0 48 48\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"> <g> <circle cx=\"24\" cy=\"24\" r=\"20\" fill=\"rgba(1,1,1,0.2)\" fill-opacity=\"0.2\" shape-rendering=\"crispEdges\"/> </g> <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M 25.725 28.753 L 27.705 30.899 L 34.296 23.756 L 27.705 16.613 L 25.725 18.759 L 30.334 23.756 L 25.725 28.753 Z\" fill=\"white\"/> <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M 15.098 29.053 L 17.078 31.199 L 23.669 24.056 L 17.078 16.913 L 15.098 19.059 L 19.707 24.056 L 15.098 29.053 Z\" fill=\"white\"/> </svg>";
728
- export declare const fullScreenSvg = "";
729
- export declare const rightArrowSvg = "data:image/svg+xml;charset=utf-8,<svg width=\"6\" height=\"10\" viewBox=\"0 0 6 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"> <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M0 8.49779L1.38618 10L6 5L1.38618 0L0 1.50221L3.22686 5L0 8.49779Z\" fill=\"white\"/> </svg>";
730
- export declare const replaySvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\" data-testid=\"ReplayIcon\" aria-label=\"fontSize large\"><path d=\"M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z\"></path></svg>";
731
- export declare const replayWhiteSvg = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" focusable=\"false\" aria-hidden=\"true\" viewBox=\"0 0 24 24\" data-testid=\"ReplayIcon\" aria-label=\"fontSize large\"><path fill=\"white\" d=\"M12 5V1L7 6l5 5V7c3.31 0 6 2.69 6 6s-2.69 6-6 6-6-2.69-6-6H4c0 4.42 3.58 8 8 8s8-3.58 8-8-3.58-8-8-8z\"></path></svg>";
732
- export declare const likeSvg = "";
733
- export declare const newShareSvg = "";
726
+ export declare const likeIconSvg = "";
727
+ export declare const ShareIconSvg = "";
734
728
  export declare const IconLink = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"10\" viewBox=\"0 0 20 10\" fill=\"none\"><path d=\"M9 10H5C3.61667 10 2.4375 9.5125 1.4625 8.5375C0.4875 7.5625 0 6.38333 0 5C0 3.61667 0.4875 2.4375 1.4625 1.4625C2.4375 0.4875 3.61667 0 5 0H9V2H5C4.16667 2 3.45833 2.29167 2.875 2.875C2.29167 3.45833 2 4.16667 2 5C2 5.83333 2.29167 6.54167 2.875 7.125C3.45833 7.70833 4.16667 8 5 8H9V10ZM6 6V4H14V6H6ZM11 10V8H15C15.8333 8 16.5417 7.70833 17.125 7.125C17.7083 6.54167 18 5.83333 18 5C18 4.16667 17.7083 3.45833 17.125 2.875C16.5417 2.29167 15.8333 2 15 2H11V0H15C16.3833 0 17.5625 0.4875 18.5375 1.4625C19.5125 2.4375 20 3.61667 20 5C20 6.38333 19.5125 7.5625 18.5375 8.5375C17.5625 9.5125 16.3833 10 15 10H11Z\" fill=\"white\" fill-opacity=\"0.92\"/></svg>";
735
729
  export declare const IconGlobe = "data:image/svg+xml;charset=utf-8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\"><path d=\"M10 20C8.61667 20 7.31667 19.7375 6.1 19.2125C4.88333 18.6875 3.825 17.975 2.925 17.075C2.025 16.175 1.3125 15.1167 0.7875 13.9C0.2625 12.6833 0 11.3833 0 10C0 8.61667 0.2625 7.31667 0.7875 6.1C1.3125 4.88333 2.025 3.825 2.925 2.925C3.825 2.025 4.88333 1.3125 6.1 0.7875C7.31667 0.2625 8.61667 0 10 0C11.3833 0 12.6833 0.2625 13.9 0.7875C15.1167 1.3125 16.175 2.025 17.075 2.925C17.975 3.825 18.6875 4.88333 19.2125 6.1C19.7375 7.31667 20 8.61667 20 10C20 11.3833 19.7375 12.6833 19.2125 13.9C18.6875 15.1167 17.975 16.175 17.075 17.075C16.175 17.975 15.1167 18.6875 13.9 19.2125C12.6833 19.7375 11.3833 20 10 20ZM9 17.95V16C8.45 16 7.97917 15.8042 7.5875 15.4125C7.19583 15.0208 7 14.55 7 14V13L2.2 8.2C2.15 8.5 2.10417 8.8 2.0625 9.1C2.02083 9.4 2 9.7 2 10C2 12.0167 2.6625 13.7833 3.9875 15.3C5.3125 16.8167 6.98333 17.7 9 17.95ZM15.9 15.4C16.2333 15.0333 16.5333 14.6375 16.8 14.2125C17.0667 13.7875 17.2875 13.3458 17.4625 12.8875C17.6375 12.4292 17.7708 11.9583 17.8625 11.475C17.9542 10.9917 18 10.5 18 10C18 8.36667 17.5458 6.875 16.6375 5.525C15.7292 4.175 14.5167 3.2 13 2.6V3C13 3.55 12.8042 4.02083 12.4125 4.4125C12.0208 4.80417 11.55 5 11 5H9V7C9 7.28333 8.90417 7.52083 8.7125 7.7125C8.52083 7.90417 8.28333 8 8 8H6V10H12C12.2833 10 12.5208 10.0958 12.7125 10.2875C12.9042 10.4792 13 10.7167 13 11V14H14C14.4333 14 14.825 14.1292 15.175 14.3875C15.525 14.6458 15.7667 14.9833 15.9 15.4Z\" fill=\"%23131313\"/></svg>";
736
- export declare const newPlayIcon = "";
737
- export declare const newPauseIcon = "";
738
- export declare const newUnmuteIcon = "";
739
- export declare const newMuteIcon = "";
740
- export declare const newShareIcon = "";
741
- export declare const newCloseIcon = "";
742
- export declare const newNextStoryIcon = "";
743
- export declare const newPrevStoryIcon = "";
744
- export declare const newNextPageIcon = "";
745
- export declare const newPrevPageIcon = "";
746
- export declare const restartIcon = "";
747
- export declare const playIcon = "";
748
- export declare const pauseIcon = "";
749
- export declare const arrowUpCtaIcon = "";
730
+ export declare const playIconSvg = "";
731
+ export declare const pauseIconSvg = "";
732
+ export declare const unmuteIconSvg = "";
733
+ export declare const muteIconSvg = "";
734
+ export declare const shareIconSvg = "";
735
+ export declare const closeIconSvg = "";
736
+ export declare const nextStoryIconSvg = "";
737
+ export declare const prevStoryIconSvg = "";
738
+ export declare const nextPageIconSvg = "";
739
+ export declare const prevPageIconSvg = "";
740
+ export declare const restartIconSvg = "";
741
+ export declare const playResumeIconSvg = "";
742
+ export declare const pauseResumeIconSvg = "";
743
+ export declare const arrowUpCtaIconSvg = "";
744
+ export declare const externalLinkIconSvg = "";
745
+ export declare const fullscreenIconSvg = "";
746
+ export declare const arrowPageMomentIconSvg = "";
750
747
  export declare const externalLinkIcon = "";
751
748
  export declare const newPageIcon = "";
752
- export declare const fullscreenIcon = "";
753
749
 
754
750
  type CustomNativeTargeting = Record<string, string | string[]>;
755
751
  type CustomNativeArgs = {
@@ -758,6 +754,10 @@ type CustomNativeArgs = {
758
754
  export interface CustomNativeAdHandler {
759
755
  provideAdExtraParams?: (args: CustomNativeArgs) => CustomNativeTargeting;
760
756
  }
757
+ type ImaExtraParams = Record<string, string>;
758
+ export interface ImaAdHandler {
759
+ provideAdExtraParams?: () => ImaExtraParams;
760
+ }
761
761
 
762
762
  export interface ISmoothOpenCloseModal {
763
763
  storyId?: string;
@@ -792,6 +792,7 @@ export interface IButtonPlayerConfig {
792
792
  iconUrl: string;
793
793
  eventType: string;
794
794
  clickHandler: () => void;
795
+ dataTestId?: string;
795
796
  }
796
797
 
797
798
  export interface IDatabase {
@@ -897,7 +898,7 @@ export interface IWidgetLabelBuilder {
897
898
  atLeastOneOf(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
898
899
  }
899
900
 
900
- export type ContentType = 'story';
901
+ export type ContentType = 'story' | 'moment';
901
902
  export interface IWidgetViewOptionsBase {
902
903
  orderType?: OrderType;
903
904
  maxItemsCount?: number;
@@ -910,7 +911,7 @@ export interface IWidgetViewOptionsBase {
910
911
  shouldOrderWidgetByReadStatus?: boolean;
911
912
  }
912
913
  export interface IWidgetViewOptionsWithLabels extends IWidgetViewOptionsBase {
913
- labels: string | string[] | BlazeWidgetLabel;
914
+ labels: LabelsType;
914
915
  storyIds?: never;
915
916
  }
916
917
  export interface IWidgetViewOptionsWithStoryIds extends IWidgetViewOptionsBase {
@@ -922,7 +923,7 @@ export type IWidgetViewOptions = IWidgetViewOptionsWithLabels | IWidgetViewOptio
922
923
  export interface IWidgetView extends HTMLElement {
923
924
  setTheme: (theme: IWidgetTheme) => void;
924
925
  getTheme: () => IWidgetTheme;
925
- setLabels: (labels: string | string[] | BlazeWidgetLabel, options?: ISetWidgetOptions) => void;
926
+ setLabels: (labels: LabelsType, options?: ISetWidgetOptions) => void;
926
927
  setLabelsPriority: (labelsPriority: string, options?: ISetWidgetOptions) => void;
927
928
  setContentIds: (storyIds: string[], options?: ISetWidgetOptions) => void;
928
929
  reload: () => void;
@@ -1141,6 +1142,7 @@ export declare class ImaAdEvent {
1141
1142
  'advertiser_name': string;
1142
1143
  'failure_reason': string;
1143
1144
  'ad_type': string;
1145
+ 'ima_url': string;
1144
1146
  }
1145
1147
  export declare class InteractionEvent {
1146
1148
  'interaction_id': string;
@@ -1187,7 +1189,16 @@ declare abstract class ApiServiceClass extends ApiServiceClass_base implements I
1187
1189
  } | undefined;
1188
1190
  error?: Error | undefined;
1189
1191
  }>;
1190
- getShorts(labels: string, orderType: OrderType, maxItemsSize?: number): Promise<import("../interfaces").IHttpResponse<{
1192
+ getMomentByIds(momentIds: string[], orderType?: OrderType): Promise<{
1193
+ httpStatus?: number | undefined;
1194
+ data?: {
1195
+ assetsExpiryTime: string;
1196
+ totalItems: number;
1197
+ result: IMoment[];
1198
+ } | undefined;
1199
+ error?: Error | undefined;
1200
+ }>;
1201
+ getMoments(labels: string, orderType: OrderType, maxItemsSize?: number): Promise<import("../interfaces").IHttpResponse<{
1191
1202
  assetsExpiryTime: string;
1192
1203
  totalItems: number;
1193
1204
  result: IMoment[];
@@ -1228,6 +1239,7 @@ declare abstract class ConfigServiceClass extends ConfigServiceClass_base implem
1228
1239
  private _shouldModifyUrlWithStoryId;
1229
1240
  private _shouldDismissPlayer;
1230
1241
  private _googleCustomNativeAdHandler?;
1242
+ private _imaAdHandler?;
1231
1243
  private _playerStyleCustomization?;
1232
1244
  private _shouldCreateUser;
1233
1245
  private _externalUserId;
@@ -1260,6 +1272,8 @@ declare abstract class ConfigServiceClass extends ConfigServiceClass_base implem
1260
1272
  get shouldDismissPlayer(): boolean;
1261
1273
  get googleCustomNativeAdHandler(): CustomNativeAdHandler | undefined;
1262
1274
  set googleCustomNativeAdHandler(value: CustomNativeAdHandler | undefined);
1275
+ get imaAdHandler(): ImaAdHandler | undefined;
1276
+ set imaAdHandler(value: ImaAdHandler | undefined);
1263
1277
  }
1264
1278
  export declare const ConfigService: ConfigServiceClass;
1265
1279
 
@@ -1450,12 +1464,16 @@ declare abstract class VideoCacheServiceClass extends VideoCacheServiceClass_bas
1450
1464
  private cache;
1451
1465
  private cacheName;
1452
1466
  private downloadControllers;
1467
+ private cacheList;
1453
1468
  private cacheInitialized;
1469
+ private sizeLimit;
1454
1470
  constructor();
1455
1471
  init(): Promise<void>;
1456
1472
  private retryCacheInitialization;
1473
+ checkCacheSize(): Promise<void>;
1457
1474
  isVideoDownloading(url: string): boolean;
1458
1475
  isInitialized(): boolean;
1476
+ private handleError;
1459
1477
  private fetchAndCache;
1460
1478
  private cacheResponse;
1461
1479
  addCacheVideoByUrl(url: string): Promise<Response | void>;
@@ -1463,6 +1481,8 @@ declare abstract class VideoCacheServiceClass extends VideoCacheServiceClass_bas
1463
1481
  abortDownload(url: string): Promise<void>;
1464
1482
  deleteCacheVideoByUrl(url: string): Promise<boolean>;
1465
1483
  clearAllCache(): Promise<void>;
1484
+ downloadAndCacheVideo(url: string): Promise<void>;
1485
+ deleteVideoFromCache(url: string): Promise<void>;
1466
1486
  }
1467
1487
  export declare const VideoCacheService: VideoCacheServiceClass;
1468
1488
 
@@ -1476,6 +1496,7 @@ declare abstract class VideoPlayerServiceClass extends VideoPlayerServiceClass_b
1476
1496
  private _isPlaying;
1477
1497
  private _isNavigating;
1478
1498
  private _isModalOpen;
1499
+ private _isSeekBarDragging;
1479
1500
  private _playReference;
1480
1501
  muteStateBeforeAd: 'mute' | 'unmute' | 'no-ad';
1481
1502
  constructor();
@@ -1490,6 +1511,8 @@ declare abstract class VideoPlayerServiceClass extends VideoPlayerServiceClass_b
1490
1511
  set playReference(value: PlayType);
1491
1512
  get isModalOpen(): boolean;
1492
1513
  set isModalOpen(value: boolean);
1514
+ get isSeekBarDragging(): boolean;
1515
+ set isSeekBarDragging(value: boolean);
1493
1516
  }
1494
1517
  export declare const VideoPlayerService: VideoPlayerServiceClass;
1495
1518
 
@@ -1645,6 +1668,7 @@ export declare const Colors: {
1645
1668
  readonly TimeColor: "#B6B7B8";
1646
1669
  readonly White: "#FFFFFF";
1647
1670
  readonly Black: "#000000";
1671
+ readonly Gray: "#B6B7B8";
1648
1672
  };
1649
1673
 
1650
1674
  export type ThemeType = 'grid-2-columns' | 'grid-3-columns' | 'row-circle' | 'row-rectangle' | 'row-rectangle-horizontal' | 'grid-2-columns-horizontal' | 'grid-3-columns-horizontal' | 'default';
@@ -2031,8 +2055,6 @@ export type ElementType = WidgetElementType | ComponentsElementType;
2031
2055
 
2032
2056
  export type EnvironmentType = 'prod' | 'uat';
2033
2057
 
2034
- export type FetchPriorityType = 'low' | 'high' | 'auto';
2035
-
2036
2058
  export * from './attribute-parser';
2037
2059
  export * from './button.type';
2038
2060
  export * from './client-platform.type';
@@ -2040,7 +2062,6 @@ export * from './css.type';
2040
2062
  export * from './direction.type';
2041
2063
  export * from './element.type';
2042
2064
  export * from './environment.type';
2043
- export * from './fetch-priority.type';
2044
2065
  export * from './item.type';
2045
2066
  export * from './label.type';
2046
2067
  export * from './locale.type';
@@ -2060,7 +2081,7 @@ export type PerItemStyleOverrides = Record<EntitiesType, Array<{
2060
2081
  theme: IWidgetTheme;
2061
2082
  }>>;
2062
2083
 
2063
- export type labelType = string | string[] | BlazeWidgetLabel;
2084
+ export type LabelsType = string | string[] | BlazeWidgetLabel;
2064
2085
 
2065
2086
  export type LocaleDirectionType = 'LTR' | 'RTL';
2066
2087
 
@@ -2087,6 +2108,7 @@ export type SeverityType = 'error' | 'warning' | 'info' | 'success';
2087
2108
  export type SizeType = 'small' | 'medium' | 'large';
2088
2109
 
2089
2110
  export type StoryDirectionType = 'PREV_STORY' | 'NEXT_STORY' | 'PREV_PAGE' | 'NEXT_PAGE';
2111
+ export type ContentDirection = 'PREV' | 'NEXT';
2090
2112
 
2091
2113
  export type ThumbnailApiType = 'SquareIcon' | 'VerticalTwoByThree' | 'MainThumbnail';
2092
2114
  export type ThumbnailType = 'SQUARE_ICON' | 'VERTICAL_TWO_BY_THREE' | 'CUSTOM';
@@ -2176,7 +2198,8 @@ export declare function calculatePosition(statusIndicatorPosition: PositionType)
2176
2198
  isRight: boolean;
2177
2199
  };
2178
2200
 
2179
- export declare const RegexHash: RegExp;
2201
+ export declare const RegexStoryHash: RegExp;
2202
+ export declare const RegexMomentHash: RegExp;
2180
2203
 
2181
2204
  export declare class Stopwatch {
2182
2205
  isRunning: boolean;
@@ -2189,66 +2212,52 @@ export declare class Stopwatch {
2189
2212
  reset(): void;
2190
2213
  }
2191
2214
 
2192
- export * from './widget-ad';
2193
- export * from './widget-cta-modal';
2215
+ export * from './widget-video-base';
2216
+ export * from './widget-player';
2217
+ export * from './ad/widget-ad';
2194
2218
  export * from './widget-embedded-story';
2195
2219
  export * from './widget-interaction';
2196
2220
  export * from './widget-item';
2197
- export * from './widget-label';
2198
2221
  export * from './widget-layout';
2199
2222
  export * from './widget-modal';
2200
- export * from './widget-moment';
2201
- export * from './widget-moment-modal';
2202
- export * from './widget-moment-player';
2203
- export * from './widget-moment-preview';
2204
- export * from './widget-moment-video';
2223
+ export * from './moment/widget-moment';
2224
+ export * from './moment/widget-moment-modal';
2225
+ export * from './moment/widget-moment-player';
2205
2226
  export * from './widget-scrollable';
2206
2227
  export * from './widget-sdk';
2207
2228
  export * from './widget-share-modal';
2208
- export * from './widget-story';
2209
- export * from './widget-story-base';
2210
- export * from './widget-story-image';
2211
- export * from './widget-story-modal';
2212
- export * from './widget-story-player';
2213
- export * from './widget-story-preview';
2214
- export * from './widget-story-video';
2215
-
2216
- export declare class BlazeWidgetStoryAd extends BlazeWidgetStoryBase {
2217
- private storyParent;
2218
- data: IPage | undefined;
2219
- private isCurrentlyDisplay;
2220
- private adContainer;
2221
- private placeholderContainer;
2222
- private googletag;
2223
- private failToLoadTimeout?;
2224
- private onFail?;
2225
- private isAdFailed;
2226
- private isPlaying;
2227
- constructor(storyParent: BlazeWidgetStory);
2229
+ export * from './story/widget-story';
2230
+ export * from './story/widget-story-modal';
2231
+ export * from './story/widget-story-player';
2232
+ export * from './widget-video';
2233
+ export * from './moment/widget-moment-seek-bar';
2234
+
2235
+ export type ExitTriggerType = 'Swipe' | 'Swipe Down' | 'Swipe Up' | 'Skip' | 'Close Button' | 'CTA Click' | 'Escape Button' | '';
2236
+ export type StartTriggerType = 'Embedded Player in Viewport' | 'Widget' | 'Deeplink' | 'Swipe' | 'Skip' | 'SingleStory' | 'Share' | '';
2237
+ export type NavigationType = 'Automatic' | 'Manual' | '';
2238
+ export type NavigationDirectionType = 'Forwards' | 'Backwards' | '';
2239
+ export declare abstract class BlazeWidgetContent extends HTMLElement {
2240
+ container: HTMLElement;
2241
+ pageIndex: number;
2242
+ startTrigger: StartTriggerType;
2243
+ exitTrigger: ExitTriggerType;
2244
+ navigationType: NavigationType;
2245
+ navigationDirection: NavigationDirectionType;
2246
+ listeners: EventsListener;
2247
+ isLoadCompletedTriggered: boolean;
2248
+ isActive: boolean;
2249
+ isResumeOnFocusExecuted: boolean;
2250
+ isNavigationPending: boolean;
2251
+ resumeAfterfocus: boolean;
2252
+ boundOnFocusEvent: () => void;
2253
+ boundOnBlurEvent: () => void;
2254
+ boundOnVisibilityChangeEvent: () => void;
2255
+ widgetParent: BlazeWidgetItem;
2256
+ constructor();
2228
2257
  connectedCallback(): void;
2229
2258
  disconnectedCallback(): void;
2259
+ setWidgetParent(parent: BlazeWidgetItem): void;
2230
2260
  render(): void;
2231
- get currentTime(): number;
2232
- set currentTime(value: number);
2233
- get duration(): number;
2234
- get progress(): number;
2235
- set muted(isMuted: boolean);
2236
- getAdIframeRef(): HTMLIFrameElement | null;
2237
- changeAdMutedState(isMuted: boolean): void;
2238
- setData(data: IPage): void;
2239
- startEnter(): Promise<void>;
2240
- endExit(): void;
2241
- play(): void;
2242
- get paused(): boolean;
2243
- pause(): void;
2244
- removeLoader(): void;
2245
- loadPoster(): void;
2246
- hide(): void;
2247
- display(onFail?: () => void): Promise<void>;
2248
- mainElement(): CanvasImageSource;
2249
- private initStyles;
2250
- isAdContainerConncetedToDOM(): Promise<boolean>;
2251
- private destroyAd;
2252
2261
  }
2253
2262
 
2254
2263
  export declare class BlazeWidgetCtaModal extends BaseWidget {
@@ -2296,7 +2305,7 @@ export declare class BlazeWidgetEmbeddedStory extends BaseWidget implements IWid
2296
2305
  attributeChangedCallback(name: string, oldValue: string, _newValue: string): void;
2297
2306
  getTheme(): IWidgetTheme;
2298
2307
  setTheme(theme: IWidgetTheme | string): void;
2299
- setLabels(labels: labelType, options?: ISetWidgetOptions): void;
2308
+ setLabels(labels: LabelsType, options?: ISetWidgetOptions): void;
2300
2309
  setLabelsPriority(labelsPriority: string, options?: ISetWidgetOptions): void;
2301
2310
  setContentIds(storyIds: string[], options?: ISetWidgetOptions): void;
2302
2311
  reload(): void;
@@ -2319,6 +2328,7 @@ export declare class BlazeWidgetEmbeddedStory extends BaseWidget implements IWid
2319
2328
  private handleModalClose;
2320
2329
  private updatePlayerStyle;
2321
2330
  openFullscreen(): void;
2331
+ appendModalToBlazeSDK(modal: BlazeWidgetStoryModal): void;
2322
2332
  onFullScreenClickHandler(event: Event): void;
2323
2333
  pauseCurrentStoryPage(): void;
2324
2334
  playCurrentStoryPage(): void;
@@ -2352,7 +2362,7 @@ export declare class BlazeWidgetInteraction extends BaseWidget {
2352
2362
 
2353
2363
  export interface BlazeWidgetItemOptions {
2354
2364
  theme: IWidgetTheme;
2355
- content: IStory;
2365
+ content: IStory | IMoment;
2356
2366
  }
2357
2367
  export declare class BlazeWidgetItem extends BaseWidget {
2358
2368
  protected options: BlazeWidgetItemOptions;
@@ -2364,15 +2374,16 @@ export declare class BlazeWidgetItem extends BaseWidget {
2364
2374
  private label;
2365
2375
  private labelContainer;
2366
2376
  private labelBackground;
2367
- private theme;
2377
+ theme: IWidgetTheme;
2368
2378
  private chip;
2369
2379
  private badge;
2370
2380
  private isLive;
2371
2381
  private analyticsCalls;
2382
+ chipType: 'statusReadStyle' | 'statusUnreadStyle' | 'statusLiveUnreadStyle' | 'statusLiveStyle';
2372
2383
  get parentRef(): BlazeWidgetLayout;
2373
- private statusIndicatorSettings;
2384
+ statusIndicatorSettings: IndicatorStyle;
2374
2385
  paddingItem: PositionOffset;
2375
- content: IStory;
2386
+ content: IStory | IMoment;
2376
2387
  onClick: (() => void) | undefined;
2377
2388
  constructor(options: BlazeWidgetItemOptions);
2378
2389
  private initializeWidget;
@@ -2406,27 +2417,12 @@ export declare class BlazeWidgetItem extends BaseWidget {
2406
2417
  render(): void;
2407
2418
  }
2408
2419
 
2409
- export declare class BlazeWidgetLabel {
2410
- value: string;
2411
- constructor(value: string);
2412
- static singleLabel(label: string): BlazeWidgetLabel;
2413
- static mustInclude(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
2414
- static atLeastOneOf(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
2415
- mustInclude(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
2416
- atLeastOneOf(...labels: Array<string | BlazeWidgetLabel>): BlazeWidgetLabel;
2417
- toString(): string;
2418
- private static createLabel;
2419
- private static validateAndProceed;
2420
- private static isValidLabelFormat;
2421
- }
2422
-
2423
2420
  /// <reference types="node" />
2424
2421
  export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements Observable, IWidgetView {
2425
- modal: BlazeWidgetStoryModal | undefined;
2426
- modalMoments: BlazeWidgetMomentModal | undefined;
2422
+ storysModal: BlazeWidgetStoryModal | undefined;
2423
+ momentsModal: BlazeWidgetMomentModal | undefined;
2427
2424
  defaultAdsInfo: IAdInfo | undefined;
2428
- stories: IStory[];
2429
- moments: IMoment[];
2425
+ content: IStory[] | IMoment[];
2430
2426
  skeletonContainer: BlazeDiv | undefined;
2431
2427
  widgetItems: BlazeWidgetItem[];
2432
2428
  preset: IWidgetTheme | undefined;
@@ -2444,7 +2440,7 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
2444
2440
  onResizeEvent: (this: Window, ev: UIEvent) => void;
2445
2441
  shouldReloadWhenPlayerIsClosed: boolean;
2446
2442
  shouldReloadData: boolean;
2447
- get refElement(): ShadowRoot | this;
2443
+ get refElement(): ShadowRoot | BlazeWidgetLayout;
2448
2444
  constructor();
2449
2445
  onResizeEventDelay(): void;
2450
2446
  onResize(): void;
@@ -2454,8 +2450,9 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
2454
2450
  disconnectedCallback(): void;
2455
2451
  attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2456
2452
  onKeyDown(e: KeyboardEvent): void;
2457
- onStoryChange(mode: StoryDirectionType): void;
2453
+ onStoryChange(mode: ContentDirection): void;
2458
2454
  onPlayerClose(): void;
2455
+ onPlayerOpen(): void;
2459
2456
  getParentHeightWithoutPadding(): number | null;
2460
2457
  setId(id: string): void;
2461
2458
  handlePopState(): void;
@@ -2464,24 +2461,24 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
2464
2461
  set storyIds(value: string);
2465
2462
  setContentIds(storyIds: string[], options?: ISetWidgetOptions): void;
2466
2463
  setLabelsPriority(labelsPriority: string, options?: ISetWidgetOptions): void;
2467
- setLabels(labels: labelType, options?: ISetWidgetOptions): void;
2464
+ setLabels(labels: LabelsType, options?: ISetWidgetOptions): void;
2468
2465
  getTheme(): IWidgetTheme;
2469
2466
  setTheme(theme: IWidgetTheme | string): void;
2470
2467
  private get theme();
2471
2468
  updateOverrideStyles(perItemStyleOverrides: PerItemStyleOverrides): void;
2472
2469
  reload(): void;
2473
- updateActiveLayoutThemesPerItemWithEntity(key: EntitiesType, value: string, theme: IWidgetTheme): void;
2470
+ private updateActiveLayoutThemesPerItemWithEntity;
2474
2471
  updateWidgetUI(): void;
2475
2472
  setMaxPaddingOnWidgetItems(): void;
2476
2473
  setDelegations(delegates: Record<Delegation, EventListenerOrEventListenerObject>): void;
2477
2474
  setMaxItemsDisplaySize(maxSize: number): void;
2478
2475
  setMaxItemsSize(maxItemsSize: number): void;
2479
2476
  private updatePlayerStyle;
2480
- createModal(): void;
2481
- createMomentsModal(): void;
2477
+ createModal(type: string): void;
2478
+ appendModalToBlazeSDK(modal: BlazeWidgetMomentModal | BlazeWidgetStoryModal): void;
2482
2479
  static get observedAttributes(): string[];
2483
2480
  onItemClick(item: BlazeWidgetItem, i: number): void;
2484
- loadStories(): Promise<void>;
2481
+ loadContent(): Promise<void>;
2485
2482
  processStoriesInWidget(): void;
2486
2483
  calculateChipSizes(theme: IWidgetTheme): {
2487
2484
  badge: {
@@ -2527,176 +2524,93 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
2527
2524
  widgetType(): WidgetType;
2528
2525
  }
2529
2526
 
2527
+ /// <reference types="hammerjs" />
2530
2528
  export declare class BlazeWidgetModal extends BaseWidget {
2529
+ player: BlazeWidgetStoryPlayer | BlazeWidgetMomentPlayer;
2531
2530
  isOpen: boolean;
2532
- constructor();
2533
- connectedCallback(): void;
2534
- open(): void;
2535
- close(): void;
2536
- }
2537
-
2538
- export declare class BlazeWidgetMomentModal extends BlazeWidgetModal {
2539
- player: BlazeWidgetMomentPlayer;
2540
- exitPopup: HTMLElement;
2541
- exitButton: HTMLElement;
2542
- resizeCallback: any;
2543
- parentWidget: HTMLElement;
2544
- onClose: (() => void) | undefined;
2545
- constructor();
2546
- setMoments(data: IMoment[]): void;
2547
- seekMoment(id: string): void;
2548
- onKeyDown(ev: KeyboardEvent): void;
2549
- close(): void;
2550
- open(): void;
2551
- play(): void;
2531
+ exitButtonElement: BlazeButton;
2532
+ exitButtonWrapperElement: BlazeDiv;
2533
+ hammer: HammerManager | null;
2534
+ isMultiTouch: boolean;
2535
+ boundOnResizeEvent: (this: Window, ev: UIEvent) => void;
2536
+ constructor(type: 'story' | 'moment');
2552
2537
  connectedCallback(): void;
2553
2538
  disconnectedCallback(): void;
2554
- render(): void;
2539
+ onResize(): void;
2540
+ seek(id: string): void;
2541
+ setupHammer(): void;
2542
+ handlePanStart(ev: HammerInput): void;
2543
+ handlePan(ev: HammerInput): void;
2544
+ handleDoubleTap(ev: HammerInput): void;
2545
+ handlePinchOut(ev: HammerInput): void;
2546
+ cleanupHammer(): void;
2547
+ open(options?: ISmoothOpenCloseModal): void;
2548
+ close(): void;
2555
2549
  }
2556
2550
 
2557
- export declare class BlazeWidgetMomentPlayer extends HTMLElement {
2558
- data: any;
2559
- widgets: BlazeWidgetMoment[];
2560
- container: HTMLElement;
2551
+ export type BlazeWidgetContent = BlazeWidgetStory | BlazeWidgetMoment;
2552
+ export declare abstract class WidgetAbstractPlayer extends BaseWidget {
2561
2553
  index: number;
2554
+ numberOfContentInList: number;
2555
+ contentList: BlazeWidgetStory[] | BlazeWidgetMoment[];
2556
+ playerContentList: BlazeWidgetStory[] | BlazeWidgetMoment[];
2557
+ srcBackground: HTMLCanvasElement;
2558
+ destBackground: HTMLCanvasElement;
2559
+ backgroundAnimation?: Animation;
2560
+ hammer: HammerManager;
2561
+ container: BlazeDiv;
2562
+ playerFullscreenOverlay: BlazeDiv;
2563
+ gestureActionLimitThreshold: number;
2564
+ edgeScreenThreshold: number;
2565
+ isEdgeThreshold: Boolean;
2566
+ isNavigationBlocked: boolean;
2567
+ isCloseAnimationStarted: boolean;
2562
2568
  currentNextAnimation?: anime.AnimeInstance;
2563
2569
  currentPrevAnimation?: anime.AnimeInstance;
2564
- preload: number;
2565
- cached: number;
2566
- items: BlazeWidgetMoment[];
2567
- actionLock: boolean;
2568
- touchStartY: number;
2570
+ onClose?: () => void;
2569
2571
  listeners: EventsListener;
2572
+ boundHandlePanStart: (ev: HammerInput) => void;
2573
+ boundHandlePanMove: (ev: HammerInput) => void;
2574
+ boundHandlePanEnd: (ev: HammerInput) => void;
2570
2575
  constructor();
2571
- prefetchNeighbours(addIndex?: number): void;
2572
- setMoments(moments: BlazeWidgetMoment[]): void;
2573
- seekMoment(id: string): void;
2574
- populatePrev(): Promise<void>;
2575
- populateNext(): Promise<void>;
2576
- play(): void;
2577
- pause(): void;
2578
- clean(): void;
2579
- nextAnimation(): AnimeTimelineInstance;
2580
- prevAnimation(): AnimeTimelineInstance;
2581
- onAnimationUpdate(anime: AnimeInstance): void;
2582
- onAnimationEnd(anime: AnimeInstance): void;
2583
- goPrev(): void;
2584
- goNext(): void;
2585
- handleTouchStart(evt: TouchEvent): void;
2586
- handleTouchMove(evt: TouchEvent): void;
2587
- handleTouchEnd(evt: TouchEvent): void;
2588
- handleWheel(evt: WheelEvent): void;
2589
- onKeyDown(ev: KeyboardEvent): void;
2590
- connectedCallback(): void;
2591
- disconnectedCallback(): void;
2592
- attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2593
- render(): void;
2594
- }
2595
-
2596
- export declare class BlazeWidgetMomentPreview extends BlazeWidgetMoment {
2597
- constructor();
2598
- disconnectedCallback(): void;
2599
- loadMoments(): Promise<void>;
2600
- static get observedAttributes(): string[];
2601
- attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2602
- }
2603
-
2604
- export declare class BlazeWidgetMomentVideo extends HTMLElement {
2605
- data: IContentPage | undefined;
2606
- video: HTMLVideoElement | undefined;
2607
- loader: HTMLElement | undefined;
2608
- source: HTMLElement | undefined;
2609
- loaderTimeoutRefAppending: NodeJS.Timeout | undefined;
2610
- isVideoStartPlaying: boolean;
2611
- isError: boolean;
2612
- isLoaded: boolean;
2613
- isVideoRunning: boolean;
2614
- maxRetryTimes: number;
2615
- videoFrameCallback?: any;
2616
- eventRenderBackgroundPercentageTriggered: Array<boolean>;
2617
- mode: 'contain' | 'cover';
2618
- constructor();
2619
- get progress(): number;
2620
- setData(data: IContentPage): void;
2621
- loadPoster(): void;
2622
- load(): Promise<void>;
2623
- display(): void;
2624
- hide(): void;
2625
- unload(): Promise<void>;
2626
- removeLoader(): void;
2627
- startPlayVideo(video: HTMLVideoElement, maxRetryTimes: number): Promise<void>;
2628
- reloadVideo(retryTime: number): void;
2629
- tryToAddLoader(): void;
2630
- play(): void;
2631
- pause(): void;
2632
- set currentTime(value: number);
2633
- get currentTime(): number;
2634
- get duration(): number;
2635
- requestFrameCallback(callback: () => void): void;
2636
- mainElement(): CanvasImageSource;
2637
- get paused(): boolean;
2638
- get muted(): boolean;
2639
- set muted(value: boolean);
2640
- connectedCallback(): void;
2641
- disconnectedCallback(): void;
2642
- render(): void;
2643
- }
2644
-
2645
- export declare class BlazeWidgetMoment extends HTMLElement {
2646
- player?: BlazeWidgetMomentVideo;
2647
- data: IMoment | any;
2648
- pageIndex: number;
2649
- container: HTMLElement;
2650
- progress: HTMLElement;
2651
- progressContainer: HTMLElement;
2652
- onPageStart: (() => void) | undefined;
2653
- onPrevStory: (() => void) | undefined;
2654
- onNextStory: (() => void) | undefined;
2655
- onClose: (() => void) | undefined;
2656
- playbackParts: HTMLElement[];
2657
- playToggleBtn: HTMLElement;
2658
- closeButton: HTMLElement;
2659
- muteToggleBtn: HTMLElement;
2660
- storyTitle: HTMLElement;
2661
- storyThumbnail: HTMLElement;
2662
- storyChip: HTMLElement;
2663
- ctaButton: HTMLElement;
2664
- likesContainer: HTMLElement;
2665
- likesCounter: HTMLElement;
2666
- shareBtn: HTMLElement;
2667
- playCallback: string | number | NodeJS.Timeout | null | undefined;
2668
- modal: BlazeWidgetMomentModal;
2669
- fullscreenMode: boolean;
2670
- listener: EventsListener;
2671
- constructor();
2672
- onTitleClick(): void;
2673
- updateButtonsPositions(isInside: boolean): void;
2674
- onMouseSeek(ev: MouseEvent): void;
2675
- onTouchMove(ev: TouchEvent): void;
2676
- updateChip(): void;
2677
- updateButtonsState(): void;
2678
- static get observedAttributes(): string[];
2679
- attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2680
- loadMoments(): Promise<void>;
2681
- playToggle(): boolean;
2682
- load(): void;
2683
- unload(): void;
2684
- openFullscreen(play?: boolean): void;
2685
- closeFullscreen(): void;
2686
- fullscreenPress(): void;
2687
- muteToggle(): boolean;
2688
- setData(data: IMoment | null, modal: BlazeWidgetMomentModal): void;
2689
- play(): void;
2690
- connectedCallback(): void;
2576
+ seek(contentId: string): void;
2577
+ cleanPlayerContentList(): void;
2578
+ abstract setContent(content: BlazeWidgetStory[] | BlazeWidgetMoment[]): void;
2579
+ muteVideoOnIOSOrMacTablet(): void;
2580
+ setupHammer(direction?: number): void;
2581
+ cleanupHammer(): void;
2582
+ handlePanStart(ev: HammerInput): void;
2583
+ handlePanMove(ev: HammerInput): void;
2584
+ handlePanEnd(ev: HammerInput): void;
2585
+ abstract handleMoveSwipe(ev: HammerInput): void;
2586
+ abstract handleEndSwipe(ev: HammerInput): void;
2587
+ reverseAnimation(ev: HammerInput): void;
2588
+ setAnimationContent(): void;
2589
+ isTouchOnScreenEdges(touchX: number, elementWidth: number): boolean;
2590
+ blockInteractionWithUserInterface(): void;
2591
+ renderPlayerBackground(renderBlackBackground?: boolean): void;
2592
+ appendToDomBasedOnNavigation(direction: ContentDirection): void;
2593
+ abstract handlePrevDirection(): void;
2594
+ abstract handleNextDirection(): void;
2595
+ resetAnimation(): void;
2596
+ abstract play(options?: any): void;
2691
2597
  close(): void;
2692
- pause(): void;
2693
- unpause(): void;
2598
+ animateContent(direction: ContentDirection): AnimeTimelineInstance | undefined;
2599
+ abstract createAnimation(content: BlazeWidgetStory | BlazeWidgetMoment, direction: ContentDirection, targetIndex: number): AnimeTimelineInstance;
2600
+ abstract handleAnimationCompletion(content: BlazeWidgetStory | BlazeWidgetMoment, mode: ContentDirection): void;
2601
+ processAnimation(event: HammerInput, content: BlazeWidgetMoment | BlazeWidgetStory, currentAnimation?: AnimeInstance | null | undefined): void;
2602
+ unloadFromPlayerList(): void;
2603
+ handleAnimationEnd(direction: ContentDirection): void;
2604
+ abstract loadAndPlayContent(): void;
2605
+ navigateContent(direction: ContentDirection): void;
2606
+ abstract onKeyDown(event: KeyboardEvent): void;
2607
+ handleSmallGestures(animation: AnimeInstance, content: BlazeWidgetStory | BlazeWidgetMoment): void;
2608
+ abstract resetStyles(): void;
2694
2609
  resetPosition(): void;
2695
- replay(): void;
2696
- goReplay(): void;
2697
- disconnectedCallback(): void;
2698
- playInternal(): void;
2699
- render(): void;
2610
+ abstract render(): void;
2611
+ isContentDirectionInPlayerListValid(direction: ContentDirection | null): boolean;
2612
+ isBlazeWidgetStory(content: BlazeWidgetContent[]): content is BlazeWidgetStory[];
2613
+ isBlazeWidgetMoment(content: BlazeWidgetContent[]): content is BlazeWidgetMoment[];
2700
2614
  }
2701
2615
 
2702
2616
  export declare class BlazeWidgetScrollable extends BaseWidget {
@@ -2715,8 +2629,9 @@ export declare class BlazeWidgetScrollable extends BaseWidget {
2715
2629
  disconnectedCallback(): void;
2716
2630
  }
2717
2631
 
2632
+ export type playRefType = 'Share' | 'SingleStory';
2718
2633
  export declare class BlazeWidgetSDK extends BaseWidget {
2719
- modalStory?: BlazeWidgetStoryModal;
2634
+ modal: BlazeWidgetStoryModal | BlazeWidgetMomentModal;
2720
2635
  onResizeEvent: (this: Window, ev: UIEvent) => void;
2721
2636
  static get observedAttributes(): string[];
2722
2637
  constructor();
@@ -2724,11 +2639,17 @@ export declare class BlazeWidgetSDK extends BaseWidget {
2724
2639
  disconnectedCallback(): void;
2725
2640
  onResizeEventDelay(): void;
2726
2641
  onResize(): void;
2642
+ checkUrlForContent(): {
2643
+ isStoryMatch: boolean;
2644
+ storyIds: string | null;
2645
+ isMomentMatch: boolean;
2646
+ momentIds: string | null;
2647
+ };
2727
2648
  setPlayerStyleCustomization(playerStyleCustomization: Partial<StoryPlayerStyle>): void;
2728
- handleStoryLoad(playReference: 'Share' | 'SingleStory', storyIds: string): Promise<void>;
2649
+ handleContentLoad(contentType: 'Moment' | 'Story', playReference: 'Share' | 'SingleStory', contentIds: string): Promise<void>;
2729
2650
  handleStaticContentLoad(playReference: 'Share' | 'SingleStory'): Promise<void>;
2730
2651
  enrichContent(content: IStory[]): Promise<IStory[]>;
2731
- setupModalAndLoadStories(playReference: 'Share' | 'SingleStory', content: IStory): Promise<void>;
2652
+ setupModalAndLoadContent(contentType: 'Moment' | 'Story', playReference: 'Share' | 'SingleStory', content: IStory | IMoment): Promise<void>;
2732
2653
  attributeChangedCallback(name: string, oldValue: string, newValue: string): Promise<void>;
2733
2654
  private getConfigAttributes;
2734
2655
  private initialize;
@@ -2762,7 +2683,7 @@ export declare class BlazeWidgetShareModal extends BaseWidget {
2762
2683
  render(): void;
2763
2684
  }
2764
2685
 
2765
- export declare class BlazeWidgetStoryBase extends HTMLElement {
2686
+ export declare class BlazeWidgetVideoBase extends HTMLElement {
2766
2687
  data: IPage | undefined;
2767
2688
  shouldShowImaAd?: boolean;
2768
2689
  isCurrentlyTryingToRunImaAd?: boolean;
@@ -2799,184 +2720,7 @@ export declare class BlazeWidgetStoryBase extends HTMLElement {
2799
2720
  endExit(): void;
2800
2721
  }
2801
2722
 
2802
- export declare class BlazeWidgetStoryImage extends BlazeWidgetStoryBase {
2803
- data: IPage | undefined;
2804
- video: HTMLImageElement | undefined;
2805
- startTime: Date;
2806
- excessTime: number;
2807
- isPlaying: boolean;
2808
- mode: 'contain' | 'cover';
2809
- constructor();
2810
- setData(data: IPage): void;
2811
- play(): void;
2812
- pause(): void;
2813
- set currentTime(value: number);
2814
- get currentTime(): number;
2815
- get duration(): number;
2816
- requestFrameCallback(): void;
2817
- mainElement(): CanvasImageSource;
2818
- get paused(): boolean;
2819
- get muted(): boolean;
2820
- set muted(value: boolean);
2821
- connectedCallback(): void;
2822
- disconnectedCallback(): void;
2823
- render(): void;
2824
- }
2825
-
2826
- /// <reference types="hammerjs" />
2827
- export declare class BlazeWidgetStoryModal extends BlazeWidgetModal {
2828
- parentWidget: HTMLElement;
2829
- playerLayout: StoryPlayerStyle;
2830
- player: BlazeWidgetStoryPlayer;
2831
- exitButtonElement: BlazeButton;
2832
- exitButtonWrapperElement: BlazeDiv;
2833
- onOpen?: () => void;
2834
- onClose?: (options?: ISmoothOpenCloseModal) => void;
2835
- onStoryChange?: (mode: StoryDirectionType) => void;
2836
- hammer: HammerManager | null;
2837
- isMultiTouch: boolean;
2838
- onResizeEvent: (this: Window, ev: UIEvent) => void;
2839
- get refElement(): this;
2840
- constructor(parentWidget: HTMLElement, playerLayout: StoryPlayerStyle);
2841
- handleOnStoryChange(mode: StoryDirectionType): void;
2842
- setTheme(theme: IWidgetTheme): void;
2843
- setStories(stories: IStory[], defaultAdsInfo?: IAdInfo): void;
2844
- seek(id: string): void;
2845
- handleExit(): void;
2846
- onKeyDown(ev: KeyboardEvent): void;
2847
- close(): void;
2848
- open(options?: ISmoothOpenCloseModal): void;
2849
- play(): void;
2850
- connectedCallback(): void;
2851
- disconnectedCallback(): void;
2852
- private handlePanStart;
2853
- private handlePan;
2854
- private handleDoubleTap;
2855
- private setupHammer;
2856
- handlePinchOut(ev: HammerInput): void;
2857
- private cleanupHammer;
2858
- render(): void;
2859
- playToggleCurrentStory(): void;
2860
- private onResize;
2861
- private onResizeEventDelay;
2862
- }
2863
-
2864
- export declare class BlazeWidgetStoryPlayer extends BaseWidget {
2865
- data: any;
2866
- hammer: HammerManager;
2867
- widgets: BlazeWidgetStory[];
2868
- container: HTMLElement;
2869
- index: number;
2870
- currentNextAnimation?: anime.AnimeInstance | null;
2871
- currentPrevAnimation?: anime.AnimeInstance | null;
2872
- widgetStories: BlazeWidgetStory[];
2873
- gestureActionLimitThreshold: number;
2874
- edgeScreenThreshold: number;
2875
- isEdgeThreshold: Boolean;
2876
- isNavigationBlocked: boolean;
2877
- isCloseAnimationStarted: boolean;
2878
- srcBackground: HTMLCanvasElement;
2879
- destBackground: HTMLCanvasElement;
2880
- onClose?: () => void;
2881
- onStoryChange?: (mode: StoryDirectionType) => void;
2882
- listeners: EventsListener;
2883
- backgroundAnimation?: Animation;
2884
- overlay: any;
2885
- constructor();
2886
- connectedCallback(): void;
2887
- onFocus(): void;
2888
- disconnectedCallback(): void;
2889
- attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2890
- private setupHammer;
2891
- private isTouchOnScreenEdges;
2892
- private isCurrentlyDisplayingVastAd;
2893
- private handlePanStart;
2894
- private handlePanMove;
2895
- private handlePanEnd;
2896
- private reverseAnimation;
2897
- private cleanupHammer;
2898
- renderBackground(renderBlackBackground?: boolean): void;
2899
- setStories(stories: BlazeWidgetStory[]): void;
2900
- close(): void;
2901
- seek(storyId: string): void;
2902
- injectStoryToDomBasedOnUserNavigation(direction: StoryDirectionType): void;
2903
- resetPosition(): void;
2904
- play(options?: ISmoothOpenCloseModal): void;
2905
- clean(): void;
2906
- onCompleteAnimation(story: BlazeWidgetStory, mode: StoryDirectionType): void;
2907
- animateStory(direction: StoryDirectionType): AnimeTimelineInstance | undefined;
2908
- onAnimationEnd(direction: StoryDirectionType): void;
2909
- blockInteractionWithUserInterface(): void;
2910
- closeWithAnimation(direction: Direction): void;
2911
- navigateToStory(direction: StoryDirectionType): void;
2912
- handleAnimation(distance: number, story: BlazeWidgetStory, currentAnimation?: AnimeInstance | null): void;
2913
- onSmallGestures(animation: AnimeInstance, story: BlazeWidgetStory): void;
2914
- onKeyDown(ev: KeyboardEvent): false | undefined;
2915
- render(): void;
2916
- playToggleCurrentStory(): void;
2917
- }
2918
-
2919
- export declare class BlazeWidgetStoryPreview extends BlazeWidgetStory {
2920
- pages: BlazeWidgetStoryBase[];
2921
- data: IStory;
2922
- pageIndex: number;
2923
- container: HTMLElement;
2924
- progress: HTMLElement;
2925
- onPageStart: (() => void) | undefined;
2926
- onPrevStory: (() => void) | undefined;
2927
- onNextStory: (() => void) | undefined;
2928
- onClose: (() => void) | undefined;
2929
- playbackParts: HTMLElement[];
2930
- playToggleBtn: HTMLElement;
2931
- muteToggleBtn: HTMLElement;
2932
- storyTitle: BlazeDiv;
2933
- storyPublishedDate: BlazeDiv;
2934
- storyThumbnail: HTMLElement;
2935
- storyChip: HTMLElement;
2936
- ctaButton: HTMLElement;
2937
- prevButton: HTMLElement;
2938
- nextButton: HTMLElement;
2939
- prevButtonFS: HTMLElement;
2940
- nextButtonFS: HTMLElement;
2941
- replayButton: HTMLElement;
2942
- replayButtonFS: HTMLElement;
2943
- playCallback: string | number | NodeJS.Timeout | null | undefined;
2944
- modal: BlazeWidgetStoryModal;
2945
- fullscreenMode: boolean;
2946
- static isPlaying: boolean;
2947
- constructor(playerStyle: StoryPlayerStyle);
2948
- updateChip(): void;
2949
- updateButtonsState(): void;
2950
- static get observedAttributes(): string[];
2951
- attributeChangedCallback(name: string, oldValue: any, newValue: string): void;
2952
- setPageId(): void;
2953
- loadStory(): Promise<void>;
2954
- prefetchNeighbours(distance?: number): void;
2955
- playToggle(): boolean;
2956
- openFullscreen(): void;
2957
- closeFullscreen(): void;
2958
- fullscreenPress(): void;
2959
- muteToggle(): boolean;
2960
- setData(data: IStory | IStory[] | null | undefined): void;
2961
- setVisible(isVisible: boolean): boolean;
2962
- get currentPage(): BlazeWidgetStoryBase;
2963
- get nextPage(): BlazeWidgetStoryBase;
2964
- get prevPage(): BlazeWidgetStoryBase;
2965
- play(): Promise<void>;
2966
- connectedCallback(): void;
2967
- close(): Promise<void>;
2968
- pause(): void;
2969
- resetPosition(): void;
2970
- updateReplay(): void;
2971
- goNextPage(): void;
2972
- goReplay(): void;
2973
- goPrevPage(): void;
2974
- disconnectedCallback(): void;
2975
- playPage(index: number): Promise<void>;
2976
- render(): void;
2977
- }
2978
-
2979
- export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
2723
+ export declare class BlazeWidgetVideo extends BlazeWidgetVideoBase {
2980
2724
  data: IPage | undefined;
2981
2725
  video: HTMLVideoElement;
2982
2726
  loader: HTMLElement;
@@ -2992,30 +2736,30 @@ export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
2992
2736
  isLoaded: boolean;
2993
2737
  isVideoRunning: boolean;
2994
2738
  maxRetryTimes: number;
2995
- mode: 'contain' | 'cover';
2996
2739
  adContainer: HTMLElement;
2997
2740
  adLoaderContainer: BlazeLoader;
2998
2741
  adDisplayContainer: any;
2999
2742
  adsManager: any;
3000
2743
  shouldShowImaAd: boolean;
3001
- storyParent: BlazeWidgetStory;
2744
+ storyParent: BlazeWidgetStory | BlazeWidgetMoment;
3002
2745
  googleIMA: any;
3003
2746
  isCurrentlyTryingToRunImaAd: boolean;
3004
2747
  hasPoster: boolean;
3005
- constructor(storyParent: BlazeWidgetStory);
2748
+ constructor(storyParent: BlazeWidgetStory | BlazeWidgetMoment);
3006
2749
  connectedCallback(): void;
3007
2750
  disconnectedCallback(): void;
3008
2751
  setData(data: IPage): void;
3009
2752
  loadPoster(): void;
3010
2753
  display(): void;
3011
2754
  hide(): void;
3012
- load(): Promise<void>;
2755
+ load(loadingType?: 'cache' | 'direct'): Promise<void>;
3013
2756
  unload(): Promise<void>;
2757
+ resetVideoState(): void;
3014
2758
  removeLoader(): void;
3015
2759
  startPlayVideo(video: HTMLVideoElement, maxRetryTimes: number): Promise<void>;
3016
2760
  tryReloadVideo(retryTime: number): void;
3017
2761
  tryToAddLoader(): void;
3018
- play(): void;
2762
+ play(): Promise<void>;
3019
2763
  pause(): void;
3020
2764
  set currentTime(value: number);
3021
2765
  get currentTime(): number;
@@ -3029,6 +2773,7 @@ export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
3029
2773
  render(): void;
3030
2774
  restartVideo(): void;
3031
2775
  initializeIMA(): void;
2776
+ buildImaUrl(url: string): string;
3032
2777
  onAdsManagerLoaded(adsManagerLoadedEvent: any): void;
3033
2778
  onAdEvent(adEvent: any): void;
3034
2779
  onWindowResize(): void;
@@ -3044,21 +2789,315 @@ export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
3044
2789
  handleInteractionEvent(event: CustomEvent<InteractionAnalyticCustomEvent>): void;
3045
2790
  }
3046
2791
 
3047
- export declare class BlazeWidgetStory extends HTMLElement {
2792
+ export declare class BlazeWidgetStoryAd extends BlazeWidgetVideoBase {
2793
+ private storyParent;
2794
+ data: IPage | undefined;
2795
+ private isCurrentlyDisplay;
2796
+ private adContainer;
2797
+ private placeholderContainer;
2798
+ private googletag;
2799
+ private failToLoadTimeout?;
2800
+ private onFail?;
2801
+ private isAdFailed;
2802
+ private isPlaying;
2803
+ constructor(storyParent: BlazeWidgetStory);
2804
+ connectedCallback(): void;
2805
+ disconnectedCallback(): void;
2806
+ render(): void;
2807
+ get currentTime(): number;
2808
+ set currentTime(value: number);
2809
+ get duration(): number;
2810
+ get progress(): number;
2811
+ set muted(isMuted: boolean);
2812
+ getAdIframeRef(): HTMLIFrameElement | null;
2813
+ changeAdMutedState(isMuted: boolean): void;
2814
+ setData(data: IPage): void;
2815
+ startEnter(): Promise<void>;
2816
+ endExit(): void;
2817
+ play(): void;
2818
+ get paused(): boolean;
2819
+ pause(): void;
2820
+ removeLoader(): void;
2821
+ loadPoster(): void;
2822
+ hide(): void;
2823
+ display(onFail?: () => void): Promise<void>;
2824
+ mainElement(): CanvasImageSource;
2825
+ private initStyles;
2826
+ isAdContainerConnectedToDOM(): Promise<boolean>;
2827
+ private destroyAd;
2828
+ }
2829
+
2830
+ export type BlazeWidgetContentType = BlazeWidgetMoment[] & BlazeWidgetStory[];
2831
+ export declare class BlazeWidgetMomentModal extends BlazeWidgetModal {
2832
+ parentWidget: HTMLElement;
2833
+ data: IMoment[];
2834
+ navigationButtonsContainerElement: BlazeDiv;
2835
+ nextContentButtonElement: BlazeButton;
2836
+ prevContentButtonElement: BlazeButton;
2837
+ onClose: (() => void) | undefined;
2838
+ onOpen: (() => void) | undefined;
2839
+ boundOnKeyDown: (ev: KeyboardEvent) => void;
2840
+ boundOnNavigationChange: (ev: Event) => void;
2841
+ constructor();
2842
+ connectedCallback(): void;
2843
+ disconnectedCallback(): void;
2844
+ onNavigationChange(ev: Event): void;
2845
+ navigateContent(direction: ContentDirection): void;
2846
+ createNavigationButton(direction: ContentDirection): BlazeButton;
2847
+ setModalContent(data: IMoment[]): void;
2848
+ onKeyDown(ev: KeyboardEvent): void;
2849
+ close(): void;
2850
+ open(): void;
2851
+ play(): void;
2852
+ setExitButtonDisplay(): void;
2853
+ render(): void;
2854
+ }
2855
+
2856
+ export declare const MUTE_UNMUTE_EVENT = "muteButtonClicked";
2857
+ export declare const UPDATE_NAVIGATION_BUTTONS_EVENT = "updateNavigationButtons";
2858
+ export declare class BlazeWidgetMomentPlayer extends WidgetAbstractPlayer {
2859
+ isWheelEventHandling: boolean;
2860
+ boundHandleMuteClicked: () => void;
2861
+ constructor();
2862
+ connectedCallback(): void;
2863
+ disconnectedCallback(): void;
2864
+ setupEventListeners(): void;
2865
+ setupContainer(): void;
2866
+ updateNavigationButtons(): void;
2867
+ private adjustContainerStyle;
2868
+ private adjustPlayerContentStyle;
2869
+ applyStyles(): void;
2870
+ attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
2871
+ handleMoveSwipe(ev: HammerInput): void;
2872
+ handleEndSwipe(ev: HammerInput): void;
2873
+ handlePrevDirection(): void;
2874
+ handleNextDirection(): void;
2875
+ createAnimation(content: BlazeWidgetMoment, direction: ContentDirection, targetIndex: number): AnimeTimelineInstance;
2876
+ loadAndPlayContent(): Promise<void>;
2877
+ handleAnimationCompletion(content: BlazeWidgetMoment, mode: ContentDirection): Promise<void>;
2878
+ setContent(content: BlazeWidgetMoment[]): void;
2879
+ preloadAdjacentContent(direction: ContentDirection): Promise<void>;
2880
+ prefetchPosters(): Promise<void>;
2881
+ play(): void;
2882
+ pause(): void;
2883
+ onAnimationEnd(): void;
2884
+ handleWheel(evt: WheelEvent): void;
2885
+ onKeyDown(event: KeyboardEvent): void;
2886
+ changeContent(direction: ContentDirection): Promise<void>;
2887
+ handleMuteClicked(): void;
2888
+ loadContentBatch(): void;
2889
+ resetStyles(): void;
2890
+ render(): void;
2891
+ }
2892
+
2893
+ export declare class BlazeWidgetMomentSeekBar extends HTMLElement {
2894
+ video: BlazeWidgetVideo;
2895
+ private progress;
2896
+ private playbackParts;
2897
+ private listeners;
2898
+ onPause?: () => void;
2899
+ onResume?: () => void;
2900
+ private boundOnTouchMove;
2901
+ private boundOnMouseMove;
2902
+ private boundOnClick;
2903
+ private boundOnMouseOut;
2904
+ private boundOnMouseIn;
2905
+ private boundOnStartDrag;
2906
+ private boundOnEndDrag;
2907
+ private isActive;
2908
+ private isInit;
2909
+ private animationFrameId;
2910
+ private lastProgress;
2911
+ private progressBarFill;
2912
+ private progressBarKnob;
2913
+ constructor(video: BlazeWidgetVideo);
2914
+ static get observedAttributes(): string[];
2915
+ attributeChangedCallback(name: string, oldValue: string, _newValue: string): void;
2916
+ connectedCallback(): void;
2917
+ disconnectedCallback(): void;
2918
+ private initialize;
2919
+ setVideo(video: BlazeWidgetVideo): void;
2920
+ private setupProgressUpdate;
2921
+ private stopProgressUpdate;
2922
+ private setupEventListeners;
2923
+ private handleOnStartDrag;
2924
+ private handleOnEndDrag;
2925
+ private handleOnClick;
2926
+ private onMouseMove;
2927
+ private onTouchMove;
2928
+ private handleOnMouseOut;
2929
+ private handleOnMouseIn;
2930
+ private resetSeekBarStyle;
2931
+ private emphasizesSeekBarStyle;
2932
+ private handleSeek;
2933
+ private styleProgressContainer;
2934
+ private createPlaybackPart;
2935
+ render(): void;
2936
+ }
2937
+
2938
+ interface ButtonElementOptions {
2939
+ iconUrl: string;
2940
+ size: string;
2941
+ onClick?: (this: GlobalEventHandlers, ev: MouseEvent) => void;
2942
+ backgroundColor?: string;
2943
+ }
2944
+ export declare class BlazeWidgetMoment extends BlazeWidgetContent {
2945
+ video: BlazeWidgetVideo;
2946
+ modal: BlazeWidgetMomentModal;
2947
+ seekBar: BlazeWidgetMomentSeekBar;
2948
+ shareModal: BlazeWidgetShareModal | undefined;
2949
+ data: IMoment;
2950
+ type: string;
2951
+ onClose: (() => void);
2952
+ boundOnCtaClicked: (event: Event) => void;
2953
+ topContainer: BlazeDiv;
2954
+ bottomContainer: BlazeDiv;
2955
+ bottomContentContainer: BlazeDiv;
2956
+ shadowBottomElement: BlazeDiv;
2957
+ shadowTopElement: BlazeDiv;
2958
+ topButtonsContainer: BlazeDiv;
2959
+ bottomButtonsContainer: BlazeDiv;
2960
+ closeButtonElement: BlazeButton;
2961
+ muteButtonElement: BlazeButton;
2962
+ likeWrapperElement: BlazeDiv;
2963
+ likeButtonElement: BlazeButton;
2964
+ likeCountElement: BlazeDiv;
2965
+ shareButtonElement: BlazeButton;
2966
+ playPauseButtonElement: BlazeButton;
2967
+ contentTitleElement: BlazeDiv;
2968
+ ctaElement: BlazeCtaButton;
2969
+ isInit: boolean;
2970
+ isActive: boolean;
2971
+ constructor();
2972
+ connectedCallback(): void;
2973
+ disconnectedCallback(): void;
2974
+ initializeStyles(): void;
2975
+ styleBottomContentContainer(): void;
2976
+ styleMainContainer(): void;
2977
+ styleShadowElements(): void;
2978
+ styleShadowTopElement(): void;
2979
+ styleShadowBottomElement(): void;
2980
+ styleButtonsContainer(): void;
2981
+ styleTopContainer(): void;
2982
+ styleBottomContainer(): void;
2983
+ styleContentTitle(): void;
2984
+ styleLike(): void;
2985
+ styleShare(): void;
2986
+ styleCta(): void;
2987
+ initializeElements(): void;
2988
+ appendShadowElements(): void;
2989
+ createButtonElement(options: ButtonElementOptions): BlazeButton;
2990
+ configureShareModal(): void;
2991
+ configureButtons(): void;
2992
+ appendButtonsContainer(): void;
2993
+ handleMobileSpecificFeatures(): void;
2994
+ configureContentTitle(): void;
2995
+ appendBottomContainer(): void;
2996
+ createPlayPauseButton(): void;
2997
+ setModal(modal: BlazeWidgetMomentModal): void;
2998
+ onVisibilityChange(): void;
2999
+ onBlur(): void;
3000
+ onFocus(): void;
3001
+ onContentClick(): void;
3002
+ onMuteUnmuteChange(): void;
3003
+ updatePlayerButtonIcons(): void;
3004
+ handleOnShareClick(): Promise<void>;
3005
+ onShareModalButtonClick(shareButton: BlazeShareButton): Promise<void>;
3006
+ loadMoments(): Promise<void>;
3007
+ load(loadingType?: 'direct' | 'cache'): Promise<void>;
3008
+ unload(): Promise<void>;
3009
+ playToggle(): void;
3010
+ handleOnMuteUnmuteToggle(): void;
3011
+ setData(data: IMoment | null): void;
3012
+ updateData(data: IMoment): void;
3013
+ updateContentTitle(title: string): void;
3014
+ updateLikeCount(likes?: number): void;
3015
+ updateCta(cta: ICTA): void;
3016
+ onCtaClick(event: Event): void;
3017
+ play(): void;
3018
+ handleOnClose(): void;
3019
+ handleOnLikeClick(): void;
3020
+ pause(): void;
3021
+ resume(): void;
3022
+ resetPosition(): void;
3023
+ resetLayout(): void;
3024
+ restartVideo(): void;
3025
+ adjustAdView(): void;
3026
+ event(): void;
3027
+ getRefferingObject(): undefined;
3028
+ adjustStylesForDevice(): void;
3029
+ render(): void;
3030
+ }
3031
+
3032
+ export declare class BlazeWidgetStoryModal extends BlazeWidgetModal {
3033
+ parentWidget: HTMLElement;
3034
+ playerLayout: StoryPlayerStyle;
3035
+ onOpen?: () => void;
3036
+ onClose?: (options?: ISmoothOpenCloseModal) => void;
3037
+ onStoryChange?: (mode: ContentDirection) => void;
3038
+ boundOnResizeEventDelay: (this: Window, ev: UIEvent) => void;
3039
+ boundOnKeyDown: (ev: KeyboardEvent) => void;
3040
+ constructor(parentWidget: HTMLElement, playerLayout: StoryPlayerStyle);
3041
+ connectedCallback(): void;
3042
+ disconnectedCallback(): void;
3043
+ handleOnStoryChange(mode: ContentDirection): void;
3044
+ setTheme(theme: IWidgetTheme): void;
3045
+ setModalContent(stories: IStory[], defaultAdsInfo?: IAdInfo): void;
3046
+ onKeyDown(ev: KeyboardEvent): void;
3047
+ close(): void;
3048
+ open(options?: ISmoothOpenCloseModal): void;
3049
+ play(): void;
3050
+ render(): void;
3051
+ playToggleCurrentStory(): void;
3052
+ onResize(): void;
3053
+ onResizeEventDelay(): void;
3054
+ }
3055
+
3056
+ export declare class BlazeWidgetStoryPlayer extends WidgetAbstractPlayer {
3057
+ onStoryChange?: (mode: ContentDirection) => void;
3058
+ boundOnKeyDown: (event: KeyboardEvent) => Promise<void>;
3059
+ backgroundAnimation?: Animation;
3060
+ constructor();
3061
+ connectedCallback(): void;
3062
+ disconnectedCallback(): void;
3063
+ setupEventListeners(): void;
3064
+ applyStyles(): void;
3065
+ attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
3066
+ setContent(content: BlazeWidgetStory[]): void;
3067
+ onFocus(): void;
3068
+ handleMoveSwipe(ev: HammerInput): void;
3069
+ handleEndSwipe(ev: HammerInput): void;
3070
+ handlePrevDirection(): void;
3071
+ handleNextDirection(): void;
3072
+ resetStyles(): void;
3073
+ play(options?: ISmoothOpenCloseModal): void;
3074
+ loadAndPlayContent(): Promise<void>;
3075
+ handleAnimationCompletion(content: BlazeWidgetStory, mode: ContentDirection): void;
3076
+ createAnimation(content: BlazeWidgetStory, direction: ContentDirection, targetIndex: number): anime.AnimeTimelineInstance;
3077
+ handleAnimationStart(content: BlazeWidgetStory, targetContent: BlazeWidgetStory, direction: ContentDirection): void;
3078
+ closeWithAnimation(direction: Direction): void;
3079
+ onKeyDown(event: KeyboardEvent): false | undefined;
3080
+ render(): void;
3081
+ loadContentBatch(): void;
3082
+ playToggleCurrentStory(): void;
3083
+ }
3084
+
3085
+ export declare class BlazeWidgetStory extends BlazeWidgetContent {
3048
3086
  playerStyle: StoryPlayerStyle;
3049
3087
  mode: ScreenMode;
3050
- pages: BlazeWidgetStoryBase[];
3088
+ pages: BlazeWidgetVideoBase[];
3051
3089
  data: IStory;
3052
- shareModal?: BlazeWidgetShareModal;
3053
- ctaModal?: BlazeWidgetCtaModal;
3090
+ shareModal: BlazeWidgetShareModal | undefined;
3054
3091
  isStoryLoadCompletedTriggered: boolean;
3055
3092
  isStoryActive: boolean;
3056
3093
  isResumeOnFocusExecuted: boolean;
3094
+ refWidget: BlazeWidgetStory[] | undefined;
3095
+ ctaModal: BlazeWidgetCtaModal;
3057
3096
  isCtaWasClickedOrSwiped: boolean;
3058
- refWidget?: BlazeWidgetStory[];
3059
3097
  refPlayer?: BlazeWidgetStoryPlayer;
3060
3098
  refPlayerModal?: BlazeWidgetStoryModal;
3061
3099
  pageIndex: number;
3100
+ type: string;
3062
3101
  container: HTMLElement;
3063
3102
  progressElement: HTMLElement;
3064
3103
  onPageStart?: () => void;
@@ -3074,10 +3113,10 @@ export declare class BlazeWidgetStory extends HTMLElement {
3074
3113
  fullScreenElement?: BlazeButton;
3075
3114
  topContainer: BlazeDiv;
3076
3115
  bottomContainer: BlazeDiv;
3077
- storyContentWrapper: BlazeDiv;
3078
- storyTitle: BlazeDiv;
3079
- storyPublishedDate: BlazeDiv;
3080
- storyLiveChip: BlazeDiv;
3116
+ contentWrapper: BlazeDiv;
3117
+ contentTitle: BlazeDiv;
3118
+ contentPublishedDate: BlazeDiv;
3119
+ contentChip: BlazeDiv;
3081
3120
  bottomButtonsWrapper: BlazeDiv;
3082
3121
  ctaButtonElement: BlazeCtaButton;
3083
3122
  prevPageButton?: BlazeButton;
@@ -3085,18 +3124,11 @@ export declare class BlazeWidgetStory extends HTMLElement {
3085
3124
  prevStoryButton?: BlazeButton;
3086
3125
  nextStoryButton?: BlazeButton;
3087
3126
  resumeAfterBlurButton?: BlazeButton;
3088
- widgetParent: BlazeWidgetItem;
3089
3127
  playCallback: any;
3090
3128
  sessionId: string;
3091
- startTrigger: 'Embedded Player in Viewport' | 'Widget' | 'Deeplink' | 'Swipe' | 'Skip' | 'SingleStory' | 'Share' | '';
3092
- exitTrigger: 'Swipe' | 'Swipe Down' | 'Swipe Up' | 'Skip' | 'Close Button' | 'CTA Click' | 'Escape Button' | '';
3093
- navigationType: 'Automatic' | 'Manual' | undefined;
3094
- navigationDirection: 'Forwards' | 'Backwards' | undefined;
3095
3129
  resumeAfterfocus: boolean;
3096
3130
  totalPlayStopwatch: Stopwatch;
3097
- listeners: EventsListener;
3098
3131
  shadowTopElement: HTMLDivElement;
3099
- isNavigationPending: boolean;
3100
3132
  navigationTimeout: NodeJS.Timeout | null;
3101
3133
  lastPageIndexToResume: number;
3102
3134
  elementsToHideOnWebAds: (HTMLElement | undefined)[];
@@ -3104,33 +3136,32 @@ export declare class BlazeWidgetStory extends HTMLElement {
3104
3136
  longPressHandler?: LongPressHandler;
3105
3137
  originalNextPageDesktopClickListener: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null | undefined;
3106
3138
  restartStoryOnClickEvent: ((event: MouseEvent) => void) | undefined;
3139
+ requestAnimationId: number | null;
3107
3140
  constructor(playerStyle: StoryPlayerStyle, mode: ScreenMode);
3108
3141
  private isButtonVisible;
3109
3142
  private createPlayerButtonsAndAppendToButtonsContainer;
3110
3143
  private createNavigationButtonsAndAppendToWidgetStoryContainer;
3111
3144
  private applyIconStyle;
3112
3145
  onShareClick(): Promise<void>;
3113
- updateCtaButtonLayout(): void;
3114
- updateChip(): void;
3146
+ private updateCtaButtonLayout;
3147
+ private updateChip;
3115
3148
  setTheme(storyPlayerStyle: StoryPlayerStyle): void;
3116
- setButtonNavigationAsDisabled(buttonType: ButtonType): void;
3149
+ private setButtonNavigationAsDisabled;
3117
3150
  adjustAdView(): void;
3118
- setPlayerButtonPosition(state: 'AD' | 'NO_AD'): void;
3151
+ private setPlayerButtonPosition;
3119
3152
  updatePlayerButtonIcons(): void;
3120
- handleCtaAction(event: Event, gestureType: 'Swipe Up' | 'CTA Click'): boolean;
3153
+ private handleCtaAction;
3121
3154
  playToggle(options?: {
3122
3155
  customIsPlaying?: boolean;
3123
3156
  }): void;
3124
3157
  muteToggle(): boolean;
3125
- setWidgetParent(parent: BlazeWidgetItem): void;
3126
3158
  resetStoryLocationIndexToLastUnseen(): void;
3127
3159
  setData(data: any): void;
3128
- get currentPage(): BlazeWidgetStoryBase;
3129
- get nextPage(): BlazeWidgetStoryBase;
3130
- get prevPage(): BlazeWidgetStoryBase;
3160
+ get currentPage(): BlazeWidgetVideoBase;
3161
+ get nextPage(): BlazeWidgetVideoBase;
3162
+ get prevPage(): BlazeWidgetVideoBase;
3131
3163
  prefetchNeighbours(distance?: number): void;
3132
3164
  loadStoryPostersByDistance(distance: number): void;
3133
- loadFirstVideo(): void;
3134
3165
  revertNextPageButtonToPreviousAction(): void;
3135
3166
  displayRestartStoryButton(): void;
3136
3167
  playPage(pageIndexToPlayNext: number): void;
@@ -3146,6 +3177,7 @@ export declare class BlazeWidgetStory extends HTMLElement {
3146
3177
  updateContainerLayout(): void;
3147
3178
  connectedCallback(): void;
3148
3179
  onShareModalClose(): void;
3180
+ updateStoryProgress(): void;
3149
3181
  onShareModalButtonClick(shareButton: BlazeShareButton): Promise<void>;
3150
3182
  onVisibilityChange(): void;
3151
3183
  onBlur(): void;
@@ -3162,7 +3194,7 @@ export declare class BlazeWidgetStory extends HTMLElement {
3162
3194
  goPrevPage(): void;
3163
3195
  disconnectedCallback(): void;
3164
3196
  updateCTAButtonPosition(): void;
3165
- renderCtaButton(pageIndex: number): void;
3197
+ updateCta(pageIndex?: number): void;
3166
3198
  updatePlayerButtonsState(displayPageNavigationButtons?: boolean): void;
3167
3199
  updateButtonState(buttonType: ButtonNavigation, button: BlazeButton | undefined): void;
3168
3200
  isNavigationButtonActive(navigationType: ButtonNavigation): boolean;
@@ -3175,6 +3207,7 @@ export declare class BlazeWidgetStory extends HTMLElement {
3175
3207
  updatePlayerContentOrder(): void;
3176
3208
  updatePlayerLocaleDirection(): void;
3177
3209
  displayExitButtonOnMobileTablet(): void;
3210
+ resetLayout(): void;
3178
3211
  render(): void;
3179
3212
  onExpandClick(): void;
3180
3213
  }