@wscsports/blaze-web-sdk 0.1.815 → 0.1.871

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.
@@ -63,7 +63,7 @@ export declare function debounce<T extends Event>(func: EventHandler<T>, _delay:
63
63
  type ScreenOrientation = 'landscape' | 'portrait';
64
64
  type Platform = 'console' | 'mobile' | 'tablet' | 'smarttv' | 'wearable' | 'embedded' | 'desktop';
65
65
  type OS = 'AIX' | 'Amiga OS' | 'Android' | 'Arch' | 'Bada' | 'BeOS' | 'BlackBerry' | 'CentOS' | 'Chromium OS' | 'Contiki' | 'Fedora' | 'Firefox OS' | 'FreeBSD' | 'Debian' | 'DragonFly' | 'Gentoo' | 'GNU' | 'Haiku' | 'Hurd' | 'iOS' | 'Joli' | 'Linpus' | 'Linux' | 'Mac OS' | 'Mageia' | 'Mandriva' | 'MeeGo' | 'Minix' | 'Mint' | 'Morph OS' | 'NetBSD' | 'Nintendo' | 'OpenBSD' | 'OpenVMS' | 'OS/2' | 'Palm' | 'PCLinuxOS' | 'Plan9' | 'Playstation' | 'QNX' | 'RedHat' | 'RIM Tablet OS' | 'RISC OS' | 'Sailfish' | 'Series40' | 'Slackware' | 'Solaris' | 'SUSE' | 'Symbian' | 'Tizen' | 'Ubuntu' | 'UNIX' | 'VectorLinux' | 'WebOS' | 'Windows Phone/Mobile' | 'Zenwalk';
66
- type Browser = 'Amaya' | 'Android Browser' | 'Arora' | 'Avant' | 'Baidu' | 'Blazer' | 'Bolt' | 'Camino' | 'Chimera' | 'Chrome' | 'Chromium' | 'Comodo Dragon' | 'Conkeror' | 'Dillo' | 'Dolphin' | 'Doris' | 'Edge' | 'Epiphany' | 'Fennec' | 'Firebird' | 'Firefox' | 'Flock' | 'GoBrowser' | 'iCab' | 'ICE Browser' | 'IceApe' | 'IceCat' | 'IceDragon' | 'Iceweasel' | 'IE' | 'Iron' | 'Jasmine' | 'K-Meleon' | 'Konqueror' | 'Kindle' | 'Links' | 'Lunascape' | 'Lynx' | 'Maemo' | 'Maxthon' | 'Midori' | 'Minimo' | 'MIUI Browser' | 'Safari' | 'Mosaic' | 'Mozilla' | 'Netfront' | 'Netscape' | 'NetSurf' | 'Nokia' | 'OmniWeb' | 'Opera' | 'Phoenix' | 'Polaris' | 'QQBrowser' | 'RockMelt' | 'Silk' | 'Skyfire' | 'SeaMonkey' | 'SlimBrowser' | 'Swiftfox' | 'Tizen' | 'UCBrowser' | 'Vivaldi' | 'w3m' | 'Yandex';
66
+ type Browser = 'Amaya' | 'Android Browser' | 'Arora' | 'Avant' | 'Baidu' | 'Blazer' | 'Bolt' | 'Camino' | 'Chimera' | 'Chrome' | 'Chromium' | 'Comodo Dragon' | 'Conkeror' | 'Dillo' | 'Dolphin' | 'Doris' | 'Edge' | 'Epiphany' | 'Fennec' | 'Firebird' | 'Firefox' | 'Flock' | 'GoBrowser' | 'iCab' | 'ICE Browser' | 'IceApe' | 'IceCat' | 'IceDragon' | 'Iceweasel' | 'IE' | 'Iron' | 'Jasmine' | 'K-Meleon' | 'Konqueror' | 'Kindle' | 'Links' | 'Lunascape' | 'Lynx' | 'Maemo' | 'Maxthon' | 'Midori' | 'Minimo' | 'MIUI Browser' | 'Safari' | 'Mosaic' | 'Mozilla' | 'Netfront' | 'Netscape' | 'NetSurf' | 'Nokia' | 'OmniWeb' | 'Opera' | 'Phoenix' | 'Polaris' | 'QQBrowser' | 'RockMelt' | 'Silk' | 'Skyfire' | 'SeaMonkey' | 'SlimBrowser' | 'Swiftfox' | 'Tizen' | 'UCBrowser' | 'Vivaldi' | 'w3m' | 'Yandex' | 'Mobile Safari';
67
67
  declare class DeviceDetector {
68
68
  private static instance;
69
69
  private parser;
@@ -98,11 +98,13 @@ export declare class EventsListener {
98
98
  export * from './base-drawable-element.class';
99
99
  export * from './base-element.class';
100
100
  export * from './debounce';
101
+ export * from './device-detector.class';
101
102
  export * from './events-listener';
102
103
  export * from './long-press.handler';
103
104
  export * from './singleton.class';
104
105
  export * from './throttle';
105
106
  export * from './url';
107
+ export * from './device-detector.class';
106
108
 
107
109
  export interface ILongPressHandlerOptions {
108
110
  onStart: () => void;
@@ -112,6 +114,7 @@ export declare class LongPressHandler {
112
114
  private readonly options;
113
115
  private pressTimer?;
114
116
  private isDuringPress;
117
+ private isAttached;
115
118
  constructor(options: ILongPressHandlerOptions);
116
119
  private startPress;
117
120
  private endPress;
@@ -190,7 +193,7 @@ export declare class BlazeDrawer extends BaseWidget {
190
193
  export declare class BlazeImage extends BaseWidget {
191
194
  thumbnailElement: HTMLImageElement;
192
195
  constructor();
193
- load(src: string, onComplete?: () => void): void;
196
+ load(src: string): void;
194
197
  setRatio(ratio: string): void;
195
198
  setBorderRadius(radius: string): void;
196
199
  }
@@ -211,9 +214,12 @@ export declare class BlazeLoader extends HTMLElement {
211
214
  connectedCallback(): void;
212
215
  }
213
216
 
214
- export declare class BlazeSkeleton extends BaseWidget {
215
- borderRadius: string;
216
- constructor(layoutStyle?: LayoutStyle);
217
+ export declare class BlazeWidgetItemSkeleton extends BaseWidget {
218
+ width: number;
219
+ thumbnailHeight: number | string;
220
+ layoutStyle: LayoutStyle;
221
+ labelHeight: number;
222
+ constructor(layoutStyle: LayoutStyle, width: number, thumbnailHeight: number, labelHeight: number);
217
223
  connectedCallback(): void;
218
224
  }
219
225
 
@@ -248,7 +254,25 @@ export declare class BlazeTypography extends BaseWidget {
248
254
  get fontSize(): ".8rem" | "1rem" | ".5rem";
249
255
  }
250
256
 
257
+ type AttributeType = 'disabled' | 'hidden' | 'height' | 'width';
258
+ export declare class BlazeButton extends BaseWidget {
259
+ buttonElement: HTMLButtonElement;
260
+ constructor();
261
+ static observedAttributes: string[];
262
+ connectedCallback(): void;
263
+ disconnectedCallback(): void;
264
+ attributeChangedCallback(name: AttributeType, oldValue: string, newValue: string): void;
265
+ get height(): string | number | boolean;
266
+ get width(): string | number | boolean;
267
+ setIconUrl(value: string): void;
268
+ private setIsHidden;
269
+ private setIsDisabled;
270
+ private setHeight;
271
+ private setWidth;
272
+ }
273
+
251
274
  export * from './share-button';
275
+ export * from './button';
252
276
 
253
277
  export type ShareButtonType = 'copy-link' | 'linked-in';
254
278
  type AttributeType = 'size' | 'button-type';
@@ -445,6 +469,11 @@ export interface IStory extends IContent {
445
469
  pages: IPage[];
446
470
  isAd: boolean;
447
471
  adInfo?: IAdInfo;
472
+ entities?: {
473
+ gameId: string | null;
474
+ teamId: string | null;
475
+ playerId: string | null;
476
+ };
448
477
  }
449
478
 
450
479
  export interface IThumbnail {
@@ -505,7 +534,6 @@ export interface WidgetsTagNameMap {
505
534
  'blaze-widget-moment-video': BlazeWidgetMomentVideo;
506
535
  'blaze-widget-interaction': BlazeWidgetInteraction;
507
536
  'blaze-loader': BlazeLoader;
508
- 'blaze-skeleton': BlazeSkeleton;
509
537
  'blaze-chip': BlazeChip;
510
538
  'blaze-image': BlazeImage;
511
539
  'blaze-toast': BlazeToast;
@@ -513,6 +541,7 @@ export interface WidgetsTagNameMap {
513
541
  'blaze-modal': BlazeDrawer;
514
542
  'blaze-div': BlazeDiv;
515
543
  'blaze-share-button': BlazeShareButton;
544
+ 'blaze-button': BlazeButton;
516
545
  'blaze-typography': BlazeTypography;
517
546
  }
518
547
  interface WidgetsTagNameOptionsMap {
@@ -535,7 +564,6 @@ interface WidgetsTagNameOptionsMap {
535
564
  'blaze-widget-moment-video': {};
536
565
  'blaze-widget-interaction': {};
537
566
  'blaze-loader': {};
538
- 'blaze-skeleton': {};
539
567
  'blaze-chip': {};
540
568
  'blaze-image': {};
541
569
  'blaze-toast': {};
@@ -543,6 +571,7 @@ interface WidgetsTagNameOptionsMap {
543
571
  'blaze-modal': {};
544
572
  'blaze-div': {};
545
573
  'blaze-share-button': {};
574
+ 'blaze-button': {};
546
575
  'blaze-typography': {};
547
576
  }
548
577
  export declare abstract class WidgetsFactory {
@@ -579,6 +608,19 @@ export declare const likeSvg = "
579
608
  export declare const newShareSvg = "";
580
609
  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>";
581
610
  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>";
611
+ export declare const newPlayIcon = "";
612
+ export declare const newPauseIcon = "";
613
+ export declare const newUnmuteIcon = "";
614
+ export declare const newMuteIcon = "";
615
+ export declare const newShareIcon = "";
616
+ export declare const newCloseIcon = "";
617
+ export declare const newNextStoryIcon = "";
618
+ export declare const newPrevStoryIcon = "";
619
+ export declare const newNextPageIcon = "";
620
+ export declare const newPrevPageIcon = "";
621
+ export declare const restartIcon = "";
622
+ export declare const playIcon = "";
623
+ export declare const pauseIcon = "";
582
624
 
583
625
  export type EnvironmentType = 'prod' | 'uat';
584
626
  export interface IBlazeSDKOptions {
@@ -639,6 +681,7 @@ export interface IDrawable {
639
681
 
640
682
  export * from './blaze-sdk.interface';
641
683
  export * from './database.interface';
684
+ export * from './device.interface';
642
685
  export * from './drawable.interface';
643
686
  export * from './response.interface';
644
687
  export * from './service.interface';
@@ -675,6 +718,7 @@ export interface IWidgetViewOptionsBase {
675
718
  theme?: IWidgetTheme | ThemeType;
676
719
  delegates?: Record<Delegation, EventListenerOrEventListenerObject>;
677
720
  labelsPriority?: string;
721
+ perItemStyleOverrides?: PerItemStyleOverrides;
678
722
  }
679
723
  export interface IWidgetViewOptionsWithLabels extends IWidgetViewOptionsBase {
680
724
  labels: string | string[] | BlazeWidgetLabel;
@@ -693,8 +737,10 @@ export interface IWidgetView {
693
737
  setLabelsPriority: (labelsPriority: string) => void;
694
738
  setContentIds: (storyIds: string[]) => void;
695
739
  reload: () => void;
740
+ updateWidgetUI: () => void;
696
741
  setMaxItemsDisplaySize: (size: number) => void;
697
742
  setDelegations: (delegates: Record<Delegation, EventListenerOrEventListenerObject>) => void;
743
+ updateOverrideStyles: (perItemStyleOverrides: PerItemStyleOverrides) => void;
698
744
  }
699
745
 
700
746
  declare const AdServiceClass_base: {
@@ -708,17 +754,6 @@ declare abstract class AdServiceClass extends AdServiceClass_base implements ISe
708
754
  }
709
755
  export declare const AdService: AdServiceClass;
710
756
 
711
- declare const AlertServiceClass_base: {
712
- new (): {};
713
- _instance: AlertServiceClass;
714
- getInstance(): AlertServiceClass;
715
- };
716
- declare abstract class AlertServiceClass extends AlertServiceClass_base implements IService {
717
- init(): Promise<void>;
718
- alert(): void;
719
- }
720
- export declare const AlertService: AlertServiceClass;
721
-
722
757
  declare const AnalyticsServiceClass_base: {
723
758
  new (): {};
724
759
  _instance: AnalyticsServiceClass;
@@ -1073,7 +1108,7 @@ declare abstract class EventServiceClass extends EventServiceClass_base implemen
1073
1108
  }
1074
1109
  export declare const EventService: EventServiceClass;
1075
1110
 
1076
- export * from './alert.ervice';
1111
+ export * from './ad.service';
1077
1112
  export * from './analytics.service';
1078
1113
  export * from './api.service';
1079
1114
  export * from './config.service';
@@ -1081,6 +1116,7 @@ export * from './database.service';
1081
1116
  export * from './error.service';
1082
1117
  export * from './event-bus.service';
1083
1118
  export * from './event.service';
1119
+ export * from './logger.service';
1084
1120
  export * from './startup.service';
1085
1121
  export * from './user.service';
1086
1122
  export * from './video-cache.service';
@@ -1213,6 +1249,7 @@ export declare class Presets {
1213
1249
  static StatusLiveUnreadStyle: IndicatorStyle;
1214
1250
  static StatusReadStyle: IndicatorStyle;
1215
1251
  static StatusUnreadStyle: IndicatorStyle;
1252
+ static BadgeStyle: IndicatorStyle;
1216
1253
  static LabelStyle: LabelStyle;
1217
1254
  static Grid2Column: LayoutStyle;
1218
1255
  static Grid3Column: LayoutStyle;
@@ -1228,15 +1265,19 @@ export declare class Presets {
1228
1265
  export interface IndicatorStyle {
1229
1266
  backgroundColor: string;
1230
1267
  backgroundImage: string;
1231
- textColor: string;
1232
- font: string;
1233
- textSize: string;
1234
- letterSpacing: string;
1235
1268
  borderRadius: string;
1236
1269
  borderColor: string;
1237
1270
  borderWidth: number;
1238
1271
  text: string;
1272
+ textColor: string;
1273
+ textSize: string;
1274
+ letterSpacing: string;
1275
+ font: string;
1239
1276
  isVisible: boolean;
1277
+ width?: number;
1278
+ height?: number;
1279
+ padding: string;
1280
+ positionOffset?: PartialPositionOffset;
1240
1281
  }
1241
1282
  export interface LayoutStyle {
1242
1283
  thumbnailShape: ThumbnailShape;
@@ -1256,7 +1297,9 @@ export interface LayoutStyle {
1256
1297
  statusLiveUnreadStyle: IndicatorStyle;
1257
1298
  statusReadStyle: IndicatorStyle;
1258
1299
  statusUnreadStyle: IndicatorStyle;
1300
+ badgeIndicatorStyle: IndicatorStyle;
1259
1301
  statusIndicatorPosition: PositionType;
1302
+ badgePosition: PositionType;
1260
1303
  }
1261
1304
  export interface LabelStyle {
1262
1305
  isVisible: boolean;
@@ -1296,7 +1339,7 @@ export declare const Colors: {
1296
1339
  readonly Accent: "#5AA3FF";
1297
1340
  readonly LiveChip: "#FF364E";
1298
1341
  readonly ReadGray: "#9C9C9C";
1299
- readonly TimeColor: "#7F7F7F";
1342
+ readonly TimeColor: "#B6B7B8";
1300
1343
  };
1301
1344
 
1302
1345
  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';
@@ -1333,11 +1376,15 @@ export declare function AttributeParser<TBase extends GHTMLElement>(Base: TBase)
1333
1376
  readonly offsetTop: number;
1334
1377
  readonly offsetWidth: number;
1335
1378
  outerText: string;
1379
+ popover: string | null;
1336
1380
  spellcheck: boolean;
1337
1381
  title: string;
1338
1382
  translate: boolean;
1339
1383
  attachInternals(): ElementInternals;
1340
1384
  click(): void;
1385
+ hidePopover(): void;
1386
+ showPopover(): void;
1387
+ togglePopover(force?: boolean | undefined): boolean;
1341
1388
  addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions | undefined): void;
1342
1389
  addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions | undefined): void;
1343
1390
  removeEventListener<K_1 extends keyof HTMLElementEventMap>(type: K_1, listener: (this: HTMLElement, ev: HTMLElementEventMap[K_1]) => any, options?: boolean | EventListenerOptions | undefined): void;
@@ -1472,6 +1519,7 @@ export declare function AttributeParser<TBase extends GHTMLElement>(Base: TBase)
1472
1519
  ariaColIndex: string | null;
1473
1520
  ariaColSpan: string | null;
1474
1521
  ariaCurrent: string | null;
1522
+ ariaDescription: string | null;
1475
1523
  ariaDisabled: string | null;
1476
1524
  ariaExpanded: string | null;
1477
1525
  ariaHasPopup: string | null;
@@ -1542,6 +1590,7 @@ export declare function AttributeParser<TBase extends GHTMLElement>(Base: TBase)
1542
1590
  onanimationstart: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
1543
1591
  onauxclick: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
1544
1592
  onbeforeinput: ((this: GlobalEventHandlers, ev: InputEvent) => any) | null;
1593
+ onbeforetoggle: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1545
1594
  onblur: ((this: GlobalEventHandlers, ev: FocusEvent) => any) | null;
1546
1595
  oncancel: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1547
1596
  oncanplay: ((this: GlobalEventHandlers, ev: Event) => any) | null;
@@ -1602,6 +1651,7 @@ export declare function AttributeParser<TBase extends GHTMLElement>(Base: TBase)
1602
1651
  onreset: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1603
1652
  onresize: ((this: GlobalEventHandlers, ev: UIEvent) => any) | null;
1604
1653
  onscroll: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1654
+ onscrollend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1605
1655
  onsecuritypolicyviolation: ((this: GlobalEventHandlers, ev: SecurityPolicyViolationEvent) => any) | null;
1606
1656
  onseeked: ((this: GlobalEventHandlers, ev: Event) => any) | null;
1607
1657
  onseeking: ((this: GlobalEventHandlers, ev: Event) => any) | null;
@@ -1638,6 +1688,16 @@ export declare function AttributeParser<TBase extends GHTMLElement>(Base: TBase)
1638
1688
  };
1639
1689
  } & TBase;
1640
1690
 
1691
+ export type ButtonType = 'ALL' | 'PAGE_NAVIGATION_ONLY' | 'STORY_NAVIGATION_ONLY';
1692
+ export type ButtonState = 'ACTIVE' | 'DISABLED';
1693
+ export type NavigationButtonType = 'PREV_STORY' | 'NEXT_STORY' | 'PREV_PAGE' | 'NEXT_PAGE';
1694
+ export declare enum ButtonNavigation {
1695
+ PREV_STORY = 0,
1696
+ NEXT_STORY = 1,
1697
+ PREV_PAGE = 2,
1698
+ NEXT_PAGE = 3
1699
+ }
1700
+
1641
1701
  export type ClientPlatform = 'Web';
1642
1702
 
1643
1703
  export type Direction = 'UP' | 'DOWN' | 'RIGHT' | 'LEFT';
@@ -1649,19 +1709,28 @@ export type ElementType = WidgetElementType | ComponentsElementType;
1649
1709
  export type FetchPriorityType = 'low' | 'high' | 'auto';
1650
1710
 
1651
1711
  export * from './attribute-parser';
1712
+ export * from './button.type';
1652
1713
  export * from './client-platform.type';
1653
- export * from './story-direction.type';
1654
1714
  export * from './direction.type';
1655
1715
  export * from './element.type';
1656
1716
  export * from './fetch-priority.type';
1717
+ export * from './item.type';
1657
1718
  export * from './label.type';
1658
1719
  export * from './order.type';
1659
1720
  export * from './play.type';
1721
+ export * from './position.type';
1660
1722
  export * from './severity.type';
1661
1723
  export * from './size.type';
1724
+ export * from './story-direction.type';
1662
1725
  export * from './thumbnail.type';
1663
1726
  export * from './widget.type';
1664
1727
 
1728
+ export type EntitiesType = 'playerId' | 'teamId' | 'gameId';
1729
+ export type PerItemStyleOverrides = Record<EntitiesType, Array<{
1730
+ name: string;
1731
+ theme: IWidgetTheme;
1732
+ }>>;
1733
+
1665
1734
  export type labelType = string | string[] | BlazeWidgetLabel;
1666
1735
 
1667
1736
  export type OrderType = 'Manual' | 'AtoZ' | 'ZtoA' | 'RecentlyUpdatedFirst' | 'RecentlyUpdatedLast' | 'RecentlyCreatedFirst' | 'RecentlyCreatedLast';
@@ -1670,14 +1739,21 @@ export declare const PlayTypeArray: readonly ["Widget", "Share", "SingleStory"];
1670
1739
  export type PlayType = typeof PlayTypeArray[number];
1671
1740
 
1672
1741
  export type PositionInsideType = 'insideTopLeft' | 'insideTopRight' | 'insideMiddleTop' | 'insideMiddle' | 'insideBottomRight' | 'insideBottomLeft' | 'insideBottomMiddle' | 'insideMiddleLeft' | 'insideMiddleRight';
1673
- export type PositionOutsideType = 'outsideUnder' | 'outsideBelow' | 'outsideAbove' | 'outsideTop' | 'outsideTopLeft' | 'outsideTopRight' | 'outsideBottomLeft' | 'outsideBottomRight' | 'outsideBottom' | 'outsideRight' | 'outsideLeft';
1742
+ export type PositionOutsideType = 'outsideTop' | 'outsideTopLeft' | 'outsideTopRight' | 'outsideBottomLeft' | 'outsideBottomRight' | 'outsideBottom' | 'outsideRight' | 'outsideLeft';
1674
1743
  export type PositionType = PositionInsideType | PositionOutsideType;
1744
+ export interface PositionOffset {
1745
+ top: string;
1746
+ left: string;
1747
+ right: string;
1748
+ bottom: string;
1749
+ }
1750
+ export type PartialPositionOffset = Partial<PositionOffset>;
1675
1751
 
1676
1752
  export type SeverityType = 'error' | 'warning' | 'info' | 'success';
1677
1753
 
1678
1754
  export type SizeType = 'small' | 'medium' | 'large';
1679
1755
 
1680
- export type StoryDirectionType = 'PREV_STORY' | 'NEXT_STORY';
1756
+ export type StoryDirectionType = 'PREV_STORY' | 'NEXT_STORY' | 'PREV_PAGE' | 'NEXT_PAGE';
1681
1757
 
1682
1758
  export type ThumbnailApiType = 'SquareIcon' | 'VerticalTwoByThree' | 'MainThumbnail';
1683
1759
  export type ThumbnailType = 'SQUARE_ICON' | 'VERTICAL_TWO_BY_THREE' | 'CUSTOM';
@@ -1693,8 +1769,9 @@ interface ChipSizeOptions {
1693
1769
  statusUnreadStyle: IndicatorStyle;
1694
1770
  }
1695
1771
  export declare function getChipSize(options: ChipSizeOptions): DOMRect;
1696
- export declare function getMaxChipSize(layout: LayoutStyle): DOMRect;
1697
- export declare function calculateChipSize(statusIndicatorPosition: PositionType, layoutStyle: LayoutStyle): {
1772
+ export declare function createChip(indicatorSettings: IndicatorStyle): DOMRect;
1773
+ export declare function getMaxChipSize(type: 'chip' | 'badge', layout: LayoutStyle): DOMRect;
1774
+ export declare function calculateChipSize(type: 'chip' | 'badge', statusIndicatorPosition: PositionType, layoutStyle: LayoutStyle): {
1698
1775
  chipHeight: number;
1699
1776
  chipWidth: number;
1700
1777
  };
@@ -1709,18 +1786,22 @@ export declare function GuardNullOrEmpty(name: string, value: any): void;
1709
1786
  export declare function formatDuration(startDate: Date): string;
1710
1787
  export declare function removeUndefined(value: any): object;
1711
1788
  export declare function isCssPropertySupported(property: string): boolean;
1789
+ export declare function pixelsToNumber(pxString: string): number;
1712
1790
  export declare function isObject(item: any): boolean;
1713
1791
  export declare function mergeDeep(target: any, ...sources: any[]): any;
1714
1792
  export declare function cloneDeep<T>(target: T): T;
1715
1793
  export declare function formatDate(date: Date): string;
1716
1794
  export declare function formatUTCDate(date: Date): string;
1795
+ export declare function calculatePercentage(value: number, element: BlazeDiv): string;
1717
1796
  export declare function getRandomId(): string;
1797
+ export declare function isEmpty(obj: Record<string, any>): boolean;
1718
1798
  export declare function setId(element: HTMLElement, prefix?: string, suffix?: string): void;
1719
1799
  export type DeepPartial<T> = T extends object ? {
1720
1800
  [P in keyof T]?: DeepPartial<T[P]>;
1721
1801
  } : T;
1722
1802
  export declare function flattenObject<T extends Record<string, any>>(obj: T): Record<string, any>;
1723
1803
  export declare function mergeStyles(element: HTMLElement, styles: Partial<CSSStyleDeclaration>): object;
1804
+ export declare function getMaxValue(currentMax: string, newValue: string): string;
1724
1805
 
1725
1806
  export * from './chip.utils';
1726
1807
  export * from './common.utils';
@@ -1737,8 +1818,6 @@ export declare function calculatePosition(statusIndicatorPosition: PositionType)
1737
1818
  isTop: boolean;
1738
1819
  isMiddle: boolean;
1739
1820
  isBottom: boolean;
1740
- isBelow: boolean;
1741
- isAbove: boolean;
1742
1821
  isLeft: boolean;
1743
1822
  isRight: boolean;
1744
1823
  };
@@ -1756,6 +1835,8 @@ export declare class Stopwatch {
1756
1835
  reset(): void;
1757
1836
  }
1758
1837
 
1838
+ export * from './widget-ad';
1839
+ export * from './widget-interaction';
1759
1840
  export * from './widget-item';
1760
1841
  export * from './widget-label';
1761
1842
  export * from './widget-layout';
@@ -1764,15 +1845,18 @@ export * from './widget-moment';
1764
1845
  export * from './widget-moment-modal';
1765
1846
  export * from './widget-moment-player';
1766
1847
  export * from './widget-moment-preview';
1848
+ export * from './widget-moment-video';
1767
1849
  export * from './widget-scrollable';
1768
1850
  export * from './widget-sdk';
1769
1851
  export * from './widget-share-modal';
1770
1852
  export * from './widget-story';
1853
+ export * from './widget-story-base';
1771
1854
  export * from './widget-story-image';
1772
1855
  export * from './widget-story-modal';
1773
1856
  export * from './widget-story-player';
1774
1857
  export * from './widget-story-preview';
1775
1858
  export * from './widget-story-video';
1859
+ export * from './widget-interaction';
1776
1860
 
1777
1861
  export declare class BlazeWidgetStoryAd extends BlazeWidgetStoryBase {
1778
1862
  data: IPage | undefined;
@@ -1828,12 +1912,11 @@ export declare class BlazeWidgetItem extends BaseWidget {
1828
1912
  private labelBackground;
1829
1913
  private theme;
1830
1914
  private chip;
1915
+ private badge;
1831
1916
  private isLive;
1832
- private shouldDisplaySkeleton;
1833
- private blazeSkeletonThumbnail;
1834
- private blazeSkeletonLabel;
1835
1917
  private analyticsCalls;
1836
1918
  private statusIndicatorSettings;
1919
+ paddingItem: PositionOffset;
1837
1920
  content: IStory;
1838
1921
  onClick: (() => void) | undefined;
1839
1922
  constructor(options: BlazeWidgetItemOptions);
@@ -1841,22 +1924,26 @@ export declare class BlazeWidgetItem extends BaseWidget {
1841
1924
  connectedCallback(): void;
1842
1925
  disconnectedCallback(): void;
1843
1926
  updateWidget(): void;
1927
+ updateWidgetItemStyle(theme: IWidgetTheme): void;
1844
1928
  private setupDOMElements;
1845
1929
  private setupEventListeners;
1846
1930
  private handleWidgetClick;
1847
1931
  private setData;
1848
1932
  getThumbnailUrl(): string;
1849
- private removeSkeleton;
1850
- handelOnCompleteLoadingThumbnail(): void;
1851
1933
  private updateLabel;
1852
- private loadThumbnail;
1934
+ private resetWidgetItemStyles;
1853
1935
  private updateContainerStyles;
1854
1936
  private updateLabelStyles;
1855
1937
  private updateInsideLabelStyles;
1856
1938
  private updateOutsideLabelStyles;
1857
1939
  private updateThumbnailStyles;
1858
- private updateChipStyles;
1940
+ private updateStatusIndicatorStyle;
1941
+ private handleOutsidePosition;
1942
+ private handleInsidePosition;
1943
+ private applyCommonStyles;
1859
1944
  setTheme(theme: IWidgetTheme): void;
1945
+ getPaddingOnContainer(): PositionOffset;
1946
+ setPaddingOnContainer(padding: PositionOffset): void;
1860
1947
  setChipStyle(): void;
1861
1948
  event(action: WidgetAction, data: Partial<WidgetEvent>, label?: string | undefined): void;
1862
1949
  render(): void;
@@ -1882,8 +1969,11 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
1882
1969
  modalMoments: BlazeWidgetMomentModal | undefined;
1883
1970
  stories: IStory[];
1884
1971
  moments: IMoment[];
1972
+ skeletonContainer: BlazeDiv | undefined;
1885
1973
  widgetItems: BlazeWidgetItem[];
1886
1974
  preset: IWidgetTheme | undefined;
1975
+ perItemStyleOverrides: PerItemStyleOverrides;
1976
+ activeOverridesLayoutThemes: PerItemStyleOverrides;
1887
1977
  thumbnailWidth: number | undefined;
1888
1978
  thumbnailHeight: number | undefined;
1889
1979
  widgetHeight: number;
@@ -1900,10 +1990,10 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
1900
1990
  handleIntersection(entries: IntersectionObserverEntry[]): void;
1901
1991
  connectedCallback(): void;
1902
1992
  disconnectedCallback(): void;
1993
+ attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
1903
1994
  onKeyDown(e: KeyboardEvent): void;
1904
1995
  onStoryChange(mode: StoryDirectionType): void;
1905
1996
  getParentHeightWithoutPadding(): number | null;
1906
- attributeChangedCallback(name: string, oldValue: string, newValue: string): void;
1907
1997
  setId(id: string): void;
1908
1998
  handlePopState(_event: Event): void;
1909
1999
  addDelegateListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions | undefined): void;
@@ -1914,7 +2004,10 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
1914
2004
  getTheme(): IWidgetTheme;
1915
2005
  setTheme(theme: IWidgetTheme | string): void;
1916
2006
  private get theme();
2007
+ updateOverrideStyles(perItemStyleOverrides: PerItemStyleOverrides): void;
1917
2008
  reload(): void;
2009
+ updateActiveLayoutThemesPerItemWithEntity(key: EntitiesType, value: string, theme: IWidgetTheme): void;
2010
+ updateWidgetUI(): void;
1918
2011
  setDelegations(delegates: Record<Delegation, EventListenerOrEventListenerObject>): void;
1919
2012
  setMaxItemsDisplaySize(maxSize: number): void;
1920
2013
  setMaxItemsSize(maxItemsSize: number): void;
@@ -1923,7 +2016,37 @@ export declare class BlazeWidgetLayout extends BlazeWidgetScrollable implements
1923
2016
  static get observedAttributes(): string[];
1924
2017
  onItemClick(item: BlazeWidgetItem, i: number): void;
1925
2018
  loadStories(): Promise<void>;
2019
+ processStoriesInWidget(): void;
2020
+ calculateChipSizes(theme: IWidgetTheme): {
2021
+ badge: {
2022
+ width: number;
2023
+ height: number;
2024
+ };
2025
+ chip: {
2026
+ width: number;
2027
+ height: number;
2028
+ };
2029
+ };
2030
+ getStatusIndicatorBadgeAndChipSizes(): {
2031
+ maxBadgeHeight: number;
2032
+ maxBadgeWidth: number;
2033
+ maxChipHeight: number;
2034
+ maxChipWidth: number;
2035
+ };
2036
+ getMaxSizes(badge: {
2037
+ height: number;
2038
+ width: number;
2039
+ }, chip: {
2040
+ height: number;
2041
+ width: number;
2042
+ }, badgePosition: string, statusIndicatorPosition: string): {
2043
+ maxBadgeHeight: number;
2044
+ maxBadgeWidth: number;
2045
+ maxChipHeight: number;
2046
+ maxChipWidth: number;
2047
+ };
1926
2048
  render(): void;
2049
+ calculateWidthForRow(height: number, itemRatio: number, maxWidth: number, labelAdditionalWidth: number): number;
1927
2050
  calculateLabelSizes(labelStyle: LabelStyle, lineNumber: number): {
1928
2051
  labelWidth: number | "auto";
1929
2052
  labelAdditionalWidth: number;
@@ -2138,8 +2261,10 @@ export declare class BlazeWidgetSDK extends BaseWidget {
2138
2261
  disconnectedCallback(): void;
2139
2262
  onResizeEventDelay(): void;
2140
2263
  onResize(): void;
2141
- loadStoriesByHash(storyIds: string): Promise<void>;
2142
- loadStoriesByStaticContent(): Promise<void>;
2264
+ handleStoryLoad(playReference: 'Share' | 'SingleStory', storyIds: string): Promise<void>;
2265
+ handleStaticContentLoad(playReference: 'Share' | 'SingleStory'): Promise<void>;
2266
+ enrichContent(content: IStory[]): Promise<IStory[]>;
2267
+ setupModalAndLoadStories(playReference: 'Share' | 'SingleStory', content: IStory): Promise<void>;
2143
2268
  attributeChangedCallback(name: string, oldValue: string, newValue: string): Promise<void>;
2144
2269
  private getConfigAttributes;
2145
2270
  private initialize;
@@ -2175,10 +2300,12 @@ export declare class BlazeWidgetShareModal extends BaseWidget {
2175
2300
  export declare class BlazeWidgetStoryBase extends HTMLElement {
2176
2301
  data: IPage | undefined;
2177
2302
  shouldShowImaAd?: boolean;
2303
+ isCurrentlyTryingToRunImaAd?: boolean;
2178
2304
  constructor();
2179
2305
  setData(data: IPage): void;
2180
2306
  loadPoster(): void;
2181
2307
  play(): void;
2308
+ restartVideo(): void;
2182
2309
  pause(): void;
2183
2310
  get paused(): boolean;
2184
2311
  get currentTime(): number;
@@ -2227,7 +2354,8 @@ export declare class BlazeWidgetStoryImage extends BlazeWidgetStoryBase {
2227
2354
  export declare class BlazeWidgetStoryModal extends BlazeWidgetModal {
2228
2355
  parentWidget: HTMLElement;
2229
2356
  player: BlazeWidgetStoryPlayer;
2230
- exitPopup: HTMLElement;
2357
+ exitButtonElement: BlazeButton;
2358
+ exitButtonWrapperElement: BlazeDiv;
2231
2359
  onOpen?: () => void;
2232
2360
  onClose?: () => void;
2233
2361
  onStoryChange?: (mode: StoryDirectionType) => void;
@@ -2288,7 +2416,7 @@ export declare class BlazeWidgetStoryPlayer extends BaseWidget {
2288
2416
  private handlePanEnd;
2289
2417
  private reverseAnimation;
2290
2418
  private cleanupHammer;
2291
- renderBackground(): void;
2419
+ renderBackground(renderBlackBackground?: boolean): void;
2292
2420
  setStories(stories: BlazeWidgetStory[]): void;
2293
2421
  close(): void;
2294
2422
  seek(storyId: string): void;
@@ -2322,7 +2450,7 @@ export declare class BlazeWidgetStoryPreview extends BlazeWidgetStory {
2322
2450
  playToggleBtn: HTMLElement;
2323
2451
  muteToggleBtn: HTMLElement;
2324
2452
  storyTitle: HTMLElement;
2325
- storySubtitle: HTMLElement;
2453
+ storyPublishedDate: HTMLElement;
2326
2454
  storyThumbnail: HTMLElement;
2327
2455
  storyChip: HTMLElement;
2328
2456
  ctaButton: HTMLElement;
@@ -2393,6 +2521,7 @@ export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
2393
2521
  shouldShowImaAd: boolean;
2394
2522
  storyParent: BlazeWidgetStory;
2395
2523
  googleIMA: any;
2524
+ isCurrentlyTryingToRunImaAd: boolean;
2396
2525
  constructor(storyParent: BlazeWidgetStory, disableInteraction?: boolean);
2397
2526
  connectedCallback(): void;
2398
2527
  disconnectedCallback(): void;
@@ -2417,6 +2546,7 @@ export declare class BlazeWidgetStoryVideo extends BlazeWidgetStoryBase {
2417
2546
  get muted(): boolean;
2418
2547
  set muted(value: boolean);
2419
2548
  render(): void;
2549
+ restartVideo(): void;
2420
2550
  initializeIMA(): void;
2421
2551
  onAdsManagerLoaded(adsManagerLoadedEvent: any): void;
2422
2552
  onAdEvent(adEvent: any): void;
@@ -2447,21 +2577,25 @@ export declare class BlazeWidgetStory extends HTMLElement {
2447
2577
  onPrevStory?: () => void;
2448
2578
  onNextStory?: () => void;
2449
2579
  onClose?: () => void;
2580
+ buttonsContainer: BlazeDiv;
2450
2581
  playbackParts: HTMLElement[];
2451
- playButtonElement: HTMLElement;
2452
- muteButtonElement: HTMLElement;
2582
+ playButtonElement?: BlazeButton;
2583
+ shareButtonElement: BlazeButton;
2584
+ muteButtonElement: BlazeButton;
2585
+ exitMobileTabletButtonElement: BlazeButton;
2453
2586
  storyTitle: HTMLElement;
2454
- storySubtitle: HTMLElement;
2455
- storyChip: HTMLElement;
2587
+ storyPublishedDate: HTMLElement;
2588
+ storyLiveChip: HTMLElement;
2456
2589
  ctaButton: HTMLElement;
2457
- prevButton: HTMLElement;
2458
- nextButton: HTMLElement;
2459
- prevStoryButton: HTMLElement;
2460
- nextStoryButton: HTMLElement;
2590
+ prevPageButton?: BlazeButton;
2591
+ nextPageButton?: BlazeButton;
2592
+ prevStoryButton?: BlazeButton;
2593
+ nextStoryButton?: BlazeButton;
2594
+ resumeAfterBlurButton?: BlazeButton;
2461
2595
  widgetParent: BlazeWidgetItem;
2462
2596
  playCallback: any;
2463
2597
  sessionId: string;
2464
- startTrigger: 'Widget' | 'Deeplink' | 'Swipe' | 'Skip' | 'Static Load' | '';
2598
+ startTrigger: 'Widget' | 'Deeplink' | 'Swipe' | 'Skip' | 'SingleStory' | 'Share' | '';
2465
2599
  exitTrigger: 'Swipe' | 'Swipe Down' | 'Skip' | 'Close Button' | 'CTA Click' | 'Escape Button' | '';
2466
2600
  navigationType: 'Automatic' | 'Manual' | undefined;
2467
2601
  navigationDirection: 'Forwards' | 'Backwards' | undefined;
@@ -2470,18 +2604,20 @@ export declare class BlazeWidgetStory extends HTMLElement {
2470
2604
  playerStyle: StoryPlayerStyle;
2471
2605
  listeners: EventsListener;
2472
2606
  shadowTopElement: HTMLDivElement;
2473
- topStoryShadow: BlazeDiv;
2474
2607
  isNavigationPending: boolean;
2475
2608
  navigationTimeout: NodeJS.Timeout | null;
2476
2609
  lastPageIndexToResume: number;
2477
- elementsToHideOnCustomNativeAds: HTMLElement[];
2610
+ elementsToHideOnWebAds: HTMLElement[];
2478
2611
  elementsToHideOnImaAds: (HTMLElement | undefined)[];
2479
2612
  muteStateBeforeAd: 'mute' | 'unmute' | 'no-ad';
2480
2613
  longPressHandler?: LongPressHandler;
2614
+ originalNextPageDesktopClickListener: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null | undefined;
2615
+ restartStoryOnClickEvent: ((event: MouseEvent) => void) | undefined;
2481
2616
  constructor();
2482
2617
  onShareClick(): Promise<void>;
2483
2618
  updateChip(): void;
2484
2619
  setTheme(storyPlayerStyle: StoryPlayerStyle): void;
2620
+ setButtonNavigationAsDisabled(buttonType: ButtonType): void;
2485
2621
  adjustAdView(): void;
2486
2622
  updatePlayerButtonIcons(): void;
2487
2623
  onCtaClick(event: Event): boolean;
@@ -2496,6 +2632,8 @@ export declare class BlazeWidgetStory extends HTMLElement {
2496
2632
  prefetchNeighbours(distance?: number): void;
2497
2633
  loadStoryPostersByDistance(distance: number): void;
2498
2634
  loadFirstVideo(): void;
2635
+ revertNextPageButtonToPreviousAction(): void;
2636
+ displayRestartStoryButton(): void;
2499
2637
  playPage(pageIndexToPlayNext: number): void;
2500
2638
  switchToPage(newPageIndex: number): void;
2501
2639
  startPage(indexToPlay: number): void;
@@ -2521,11 +2659,16 @@ export declare class BlazeWidgetStory extends HTMLElement {
2521
2659
  prevStory(): void;
2522
2660
  nextStory(): void;
2523
2661
  markAsRead(): Promise<any>;
2524
- goNextPage(): void;
2662
+ goNextPage(navigationType?: 'Automatic' | 'Manual'): void;
2525
2663
  goPrevPage(): void;
2526
2664
  disconnectedCallback(): void;
2527
2665
  renderCtaButton(pageIndex: number): void;
2666
+ updatePlayerButtonsState(displayPageNavigationButtons?: boolean): void;
2667
+ updateButtonState(buttonType: ButtonNavigation, button: BlazeButton | undefined): void;
2668
+ isNavigationButtonActive(navigationType: ButtonNavigation): boolean;
2669
+ updateNavButton(state: ButtonState, navButtonElement: BlazeButton): void;
2670
+ updatePlayerButtonsCSS(): void;
2671
+ displayExitButtonOnMobileTablet(): void;
2528
2672
  render(): void;
2529
- shouldDisplayButton(navType: string): string;
2530
2673
  }
2531
2674