@wscsports/blaze-web-sdk 0.22.0 → 0.24.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wscsports/blaze-web-sdk",
3
- "version": "0.22.0",
3
+ "version": "0.24.0",
4
4
  "main": "publish/index",
5
5
  "types": "publish/index",
6
6
  "files": [
@@ -238,6 +238,7 @@ export declare class MomentEvent {
238
238
  'cc_state': string;
239
239
  'content_extra_info': string;
240
240
  'custom_action_button_name': string;
241
+ 'follow_state': string | null;
241
242
  }
242
243
  export declare class WidgetEvent {
243
244
  'page_view_id': string;
@@ -460,6 +461,14 @@ export declare class EventsListener {
460
461
  removeAll(): void;
461
462
  }
462
463
 
464
+ export declare class FollowingsManager {
465
+ private static followedEntities;
466
+ static isFollowing(entityId: string): boolean;
467
+ static initialize(followedList: string[]): void;
468
+ static follow(entityId: string): void;
469
+ static unfollow(entityId: string): void;
470
+ }
471
+
463
472
  export declare class FullscreenManager {
464
473
  private isFullscreen;
465
474
  private isProgrammaticChange;
@@ -485,6 +494,7 @@ export * from './device-detector.class';
485
494
  export * from './events-listener';
486
495
  export * from './fullscreen-manager.class';
487
496
  export * from './label-builder.class';
497
+ export * from './url-rotator.class';
488
498
  export * from './logger/logger-manager.class';
489
499
  export * from './logger/logger-storage.class';
490
500
  export * from './logger/logger-transport.class';
@@ -495,6 +505,7 @@ export * from './throttle';
495
505
  export * from './url';
496
506
  export * from './visiblity-manager.class';
497
507
  export * from './accessibility';
508
+ export * from './followings-manager.class';
498
509
 
499
510
  export interface IBlazeWidgetLabel {
500
511
  readonly _type: 'BlazeWidgetLabel';
@@ -543,6 +554,16 @@ export declare function Singleton<T>(): {
543
554
  export type EventHandler<E extends Event> = (event: E) => void;
544
555
  export declare function throttle<F extends (...args: any[]) => void>(func: F, _delay: number): (...args: Parameters<F>) => Promise<void>;
545
556
 
557
+ export declare class UrlRotator {
558
+ private endpoints;
559
+ private currentIndex;
560
+ private fallbackUrl;
561
+ constructor(fallbackUrl?: string);
562
+ initialize(endpointUrls?: string): void;
563
+ getNext(): string;
564
+ private parseEndpoints;
565
+ }
566
+
546
567
  interface UpdateLocationContentHashParams {
547
568
  contentType?: ContentType;
548
569
  contentId?: string;
@@ -1062,10 +1083,53 @@ export declare class BlazeCtaButton extends BaseWidget {
1062
1083
  clearAllAnimations(): void;
1063
1084
  }
1064
1085
 
1086
+ export declare class BlazeFollowButton extends BaseWidget {
1087
+ private playerStyle;
1088
+ private containerEl;
1089
+ private avatarEl;
1090
+ private chipEl;
1091
+ private chipContentWrapperEl;
1092
+ private checkMarkIconEl;
1093
+ private plusIconEl;
1094
+ private textEl;
1095
+ private _isFollowing;
1096
+ private _entityId?;
1097
+ private _entityType?;
1098
+ private _avatarUrl?;
1099
+ private _sourceId?;
1100
+ private _sourceContentType?;
1101
+ onToggle?: (e: Event, data: FollowingSharedContext) => void;
1102
+ constructor(playerStyle: MomentPlayerStyle | undefined);
1103
+ connectedCallback(): void;
1104
+ disconnectedCallback(): void;
1105
+ setEntity(id: string | undefined, type?: BlazeFollowEntityType): void;
1106
+ setAvatar(url: string | undefined): void;
1107
+ setSource(sourceId: string, contentType: ContentType): void;
1108
+ get entityId(): string | undefined;
1109
+ get entityType(): BlazeFollowEntityType | undefined;
1110
+ get isFollowed(): boolean;
1111
+ private handleClick;
1112
+ private handleStateChange;
1113
+ private updateAriaLabel;
1114
+ private onMouseEnter;
1115
+ private onMouseLeave;
1116
+ private setupContainer;
1117
+ private handlePressKeyboard;
1118
+ private setupAvatar;
1119
+ private setupChip;
1120
+ private setupIcons;
1121
+ private updateIconVisibility;
1122
+ private updateIconColors;
1123
+ private applyStateToUi;
1124
+ setAriaLabel(label: string): void;
1125
+ private updateAvatarBackground;
1126
+ }
1127
+
1065
1128
  export * from './share-button';
1066
1129
  export * from './button';
1067
1130
  export * from './cta-button';
1068
1131
  export * from './call-to-action.button';
1132
+ export * from './follow-button';
1069
1133
 
1070
1134
  export type ShareButtonType = 'copy-link' | 'linked-in';
1071
1135
  type AttributeType = 'size' | 'button-type';
@@ -1140,7 +1204,9 @@ export declare enum MomentAction {
1140
1204
  PlaybackInitialStart = "playback_initial_start",
1141
1205
  ClosedCaptionsOff = "cc_off",
1142
1206
  ClosedCaptionsOn = "cc_on",
1143
- CustomActionButtonClick = "custom_action_button_click"
1207
+ CustomActionButtonClick = "custom_action_button_click",
1208
+ Follow = "follow",
1209
+ Unfollow = "unfollow"
1144
1210
  }
1145
1211
  export declare enum VideoAction {
1146
1212
  VideoStart = "video_start",
@@ -1225,6 +1291,8 @@ export declare const ASPECT_RATIO_16_9_STRING = "16 / 9";
1225
1291
  export declare const ASPECT_RATIO_9_16_STRING = "9 / 16";
1226
1292
  export declare const ASPECT_RATIO_4_3_STRING = "4 / 3";
1227
1293
 
1294
+ export declare const FOLLOW_BUTTON_STATE_CHANGE = "follow-button-state-change";
1295
+
1228
1296
  export * from './accessibility.constants';
1229
1297
  export * from './ads.constants';
1230
1298
  export * from './analytics.constants';
@@ -1341,6 +1409,7 @@ export interface AppConfiguration {
1341
1409
  analyticsAddEntitiesInfo?: string;
1342
1410
  configRefetchIntervalInMinutes?: number;
1343
1411
  enableClientPlaybackModification?: 'true' | 'false' | string;
1412
+ analyticsEndpointUrls?: string;
1344
1413
  };
1345
1414
  recommendationsConfigurations?: IRecommendationsConfigurations;
1346
1415
  sdkLoggerConfigurations?: ILoggerConfiguration;
@@ -1358,6 +1427,14 @@ export type ContentEntities = {
1358
1427
  teamId: string | null;
1359
1428
  playerId: string | null;
1360
1429
  };
1430
+ export type BlazeFollowEntity = {
1431
+ storageFile: {
1432
+ url: string;
1433
+ fileSize: number | null;
1434
+ };
1435
+ entityType: BlazeFollowEntityType;
1436
+ entityId: string;
1437
+ };
1361
1438
  export interface IContent {
1362
1439
  id: string;
1363
1440
  title: string;
@@ -1372,6 +1449,7 @@ export interface IContent {
1372
1449
  description?: string;
1373
1450
  closedCaptions?: IClosedCaption[];
1374
1451
  extraInfo: ExtraInfo;
1452
+ followEntities?: BlazeFollowEntity[];
1375
1453
  }
1376
1454
  export interface IBlazeContent {
1377
1455
  id: string;
@@ -1634,7 +1712,8 @@ export interface IBlazeVideo extends IBlazeContent {
1634
1712
  }
1635
1713
 
1636
1714
  export declare enum ActionHandlerId {
1637
- AddCustomActionButton = "addCustomActionButton"
1715
+ AddCustomActionButton = "addCustomActionButton",
1716
+ AddFollowButton = "addFollowButton"
1638
1717
  }
1639
1718
 
1640
1719
  export declare enum ButtonState {
@@ -1764,6 +1843,7 @@ export interface WidgetsTagNameMap {
1764
1843
  'blaze-button': BlazeButton;
1765
1844
  'blaze-button-cta': BlazeCtaButton;
1766
1845
  'blaze-call-to-action-button': BlazeCallToActionButton;
1846
+ 'blaze-follow-button': BlazeFollowButton;
1767
1847
  'blaze-typography': BlazeTypography;
1768
1848
  'blaze-timer': BlazeTimer;
1769
1849
  }
@@ -1810,6 +1890,7 @@ interface WidgetsTagNameOptionsMap {
1810
1890
  'blaze-button': {};
1811
1891
  'blaze-button-cta': {};
1812
1892
  'blaze-call-to-action-button': {};
1893
+ 'blaze-follow-button': {};
1813
1894
  'blaze-typography': {};
1814
1895
  }
1815
1896
  export declare abstract class WidgetsFactory {
@@ -1869,6 +1950,7 @@ export declare const closedCaptionsOffIconSvg = "
1869
1950
  export declare const shareVideosIconSvg = "";
1870
1951
  export declare const linkIconSvg = "";
1871
1952
  export declare const checkMarkSvg = "";
1953
+ export declare const plusSvg = "";
1872
1954
 
1873
1955
  export interface AccessibilityContext {
1874
1956
  trigger: 'user' | 'auto' | 'navigation' | 'modal';
@@ -1912,6 +1994,7 @@ export interface IContentWidgetButtons {
1912
1994
  prevStory?: HTMLElement;
1913
1995
  nextMoment?: HTMLElement;
1914
1996
  prevMoment?: HTMLElement;
1997
+ follow?: HTMLElement;
1915
1998
  }
1916
1999
  export interface IContentWidgetData {
1917
2000
  id: string;
@@ -1921,6 +2004,7 @@ export interface IContentWidgetData {
1921
2004
  isLiked?: boolean;
1922
2005
  hasClosedCaptions?: boolean;
1923
2006
  ctaText?: string;
2007
+ isFollowed?: boolean;
1924
2008
  }
1925
2009
  export interface IContentWidgetElements {
1926
2010
  widget: HTMLElement;
@@ -1992,6 +2076,7 @@ export interface IBlazeSDKOptions {
1992
2076
  layoutDirection?: LocaleDirectionType;
1993
2077
  shouldAllowClosedCaptions?: boolean;
1994
2078
  disableAutoLoadingContent?: boolean;
2079
+ followedEntities?: string[];
1995
2080
  }
1996
2081
 
1997
2082
  export interface IButtonPlayerNavigationConfig {
@@ -2063,6 +2148,10 @@ export interface IDrawable {
2063
2148
  render: () => void;
2064
2149
  }
2065
2150
 
2151
+ export interface IFollowingsManager {
2152
+ isFollowing(entityId: string): boolean;
2153
+ }
2154
+
2066
2155
  export interface IHttpResponse<T = any> extends IResponse<T> {
2067
2156
  httpStatus?: number;
2068
2157
  }
@@ -2122,6 +2211,7 @@ export * from './data-source.interface';
2122
2211
  export * from './database.interface';
2123
2212
  export * from './device.interface';
2124
2213
  export * from './drawable.interface';
2214
+ export * from './followings-manager.interface';
2125
2215
  export * from './http-response.interface';
2126
2216
  export * from './icons.interface';
2127
2217
  export * from './logger.interface';
@@ -2404,6 +2494,7 @@ declare const ApiServiceClass_base: {
2404
2494
  };
2405
2495
  declare abstract class ApiServiceClass extends ApiServiceClass_base implements IService {
2406
2496
  api: API;
2497
+ private analyticsUrlRotator?;
2407
2498
  init(): Promise<void>;
2408
2499
  private setAdsOnStories;
2409
2500
  getStoriesByIds(options: GetByIdsOptions & {
@@ -2464,6 +2555,8 @@ declare abstract class ApiServiceClass extends ApiServiceClass_base implements I
2464
2555
  private getContentParamsByLabels;
2465
2556
  private getContentParamsByIds;
2466
2557
  private getContentParamsByRecommendations;
2558
+ initializeAnalyticsEndpoints(endpointUrls?: string): void;
2559
+ private getAnalyticsEndpoint;
2467
2560
  }
2468
2561
  export declare const ApiService: ApiServiceClass;
2469
2562
 
@@ -3247,6 +3340,24 @@ export type BlazeMomentsPlayerCtaStyle = {
3247
3340
  fontFamily: string;
3248
3341
  backgroundColor?: string;
3249
3342
  borderColor?: string;
3343
+ isVisible: boolean;
3344
+ };
3345
+ type BlazeChipFollowStyle = {
3346
+ followedBackgroundColor: string;
3347
+ unfollowedBackgroundColor: string;
3348
+ color: string;
3349
+ };
3350
+ type BlazeAvatarFollowStyle = {
3351
+ borderWidth: string;
3352
+ followedBorderColor: string;
3353
+ unfollowedBorderColor: string;
3354
+ };
3355
+ export type BlazeMomentsPlayerFollowButtonStyle = {
3356
+ isVisible: boolean;
3357
+ variant: BlazeFollowButtonVariant;
3358
+ followEntityTypePriority?: BlazeSelectableEntityType[];
3359
+ avatar: BlazeAvatarFollowStyle;
3360
+ chip: BlazeChipFollowStyle;
3250
3361
  };
3251
3362
  type BlazeMomentsPlayerCTAPositioning = 'CTA_BELLOW_BOTTOM_BUTTONS_BOX' | 'CTA_NEXT_TO_BOTTOM_BUTTONS_BOX';
3252
3363
  type BlazeMomentsPlayerCTAHorizontalAlignment = 'START' | 'CENTER' | 'END' | 'FULL_AVAILABLE_WIDTH';
@@ -3286,6 +3397,7 @@ export interface MomentPlayerStyle {
3286
3397
  contentBoxHorizontalSpacing: string;
3287
3398
  seekBar: BlazeMomentsPlayerSeekBarStyle;
3288
3399
  ctaButton: BlazeMomentsPlayerCtaStyle;
3400
+ followButton: BlazeMomentsPlayerFollowButtonStyle;
3289
3401
  }
3290
3402
  export interface VideoPlayerStyle {
3291
3403
  headingText: BlazeVideosPlayerHeadingTextStyle;
@@ -3318,6 +3430,7 @@ export interface BlazeVideosPlayerCtaStyle {
3318
3430
  visibility: BlazeVideoPlayerVisibility;
3319
3431
  borderColor: string;
3320
3432
  horizontalAlignment: ButtonPositionType;
3433
+ isVisible: boolean;
3321
3434
  }
3322
3435
  export type BlazeVideosPlayerCtaIconStyle = {
3323
3436
  position: 'START';
@@ -3341,6 +3454,7 @@ export interface CtaButtonStyle {
3341
3454
  width: string;
3342
3455
  height: string;
3343
3456
  position: ButtonPositionType;
3457
+ isVisible: boolean;
3344
3458
  icon: IconStyle;
3345
3459
  }
3346
3460
  export interface IconStyle {
@@ -3385,9 +3499,12 @@ export type CustomActionButtonOptions = {
3385
3499
  buttonName: string;
3386
3500
  onClick: (e: MouseEvent | Event, data: ContentEntities | null) => void;
3387
3501
  };
3502
+ export type FollowButtonOptions = {
3503
+ onClick: (e: MouseEvent | Event, data: FollowingSharedContext) => void;
3504
+ };
3388
3505
  export type ActionHandler = {
3389
3506
  actionId: `${ActionHandlerId}`;
3390
- options: CustomActionButtonOptions;
3507
+ options: CustomActionButtonOptions | FollowButtonOptions;
3391
3508
  };
3392
3509
 
3393
3510
  export type AnimationType = 'Growing' | 'Shrinking' | 'BottomToTop';
@@ -3840,6 +3957,16 @@ export type ElementType = WidgetElementType | ComponentsElementType;
3840
3957
 
3841
3958
  export type EnvironmentType = 'prod' | 'uat' | 'local';
3842
3959
 
3960
+ export type BlazeFollowButtonVariant = 'icon' | 'text';
3961
+ export type FollowingSharedContext = {
3962
+ sourceId: string;
3963
+ sourceContentType: ContentType;
3964
+ newFollowingState: boolean;
3965
+ followEntity: Omit<BlazeFollowEntity, 'storageFile'>;
3966
+ };
3967
+ export type BlazeSelectableEntityType = 'Player' | 'Team' | 'Property' | 'FirstAvailable';
3968
+ export type BlazeFollowEntityType = Omit<BlazeSelectableEntityType, 'FirstAvailable'>;
3969
+
3843
3970
  export type StoryGestureType = 'Swipe Up' | 'CTA Click';
3844
3971
  export type MomentGestureType = 'CTA Click';
3845
3972
 
@@ -3890,6 +4017,7 @@ export * from './widget-view-options.type';
3890
4017
  export * from './content-item.type';
3891
4018
  export * from './play-content-options.type';
3892
4019
  export * from './recommendations.type';
4020
+ export * from './follow-button.type';
3893
4021
 
3894
4022
  export type EntitiesType = 'playerId' | 'teamId' | 'gameId' | 'roundId';
3895
4023
  export type PerItemStyleOverrides = Partial<Record<EntitiesType, Array<{
@@ -4053,6 +4181,9 @@ export declare function transformContentsArray(items: ContentItem[]): BlazeConte
4053
4181
  type CountryCode = typeof CountryCodes[number];
4054
4182
  export declare function isValidCountryCode(countryCode: string): countryCode is CountryCode;
4055
4183
 
4184
+ export declare const getFollowEntityByPriority: (followEntityTypePriority?: BlazeSelectableEntityType[], followEntities?: BlazeFollowEntity[]) => BlazeFollowEntity | null;
4185
+ export declare const generateFollowStateForAnalytics: (entityId?: string, entityType?: BlazeFollowEntityType, followingsManager?: IFollowingsManager) => string | null;
4186
+
4056
4187
  export declare function GuardNullOrEmpty(name: string, value: any): void;
4057
4188
  export declare function isStory(content: IContent): content is IStory;
4058
4189
 
@@ -6249,6 +6380,7 @@ export declare class BlazeWidgetMoment extends BlazeWidgetContent {
6249
6380
  headElement: BlazeDiv;
6250
6381
  bodyElement: BlazeDiv;
6251
6382
  ctaButtonElement: BlazeCtaButton;
6383
+ followButtonElement?: BlazeFollowButton;
6252
6384
  isInit: boolean;
6253
6385
  isActive: boolean;
6254
6386
  isMomentPausedByPlayPauseButton: boolean;
@@ -6289,6 +6421,7 @@ export declare class BlazeWidgetMoment extends BlazeWidgetContent {
6289
6421
  configureButtons(): Promise<void>;
6290
6422
  appendButtonsContainer(): void;
6291
6423
  handleMobileSpecificFeatures(): void;
6424
+ configureFollowButton(): void;
6292
6425
  configureContentBody(): void;
6293
6426
  appendBottomContainer(): void;
6294
6427
  private updateLayoutPositioning;
@@ -6326,6 +6459,7 @@ export declare class BlazeWidgetMoment extends BlazeWidgetContent {
6326
6459
  handleOnCustomActionButtonClick(e: MouseEvent, handlerOptions: CustomActionButtonOptions): void;
6327
6460
  handleOnClose(): void;
6328
6461
  handleOnLikeClick(): void;
6462
+ handleFollowAnalytics(data: FollowingSharedContext): void;
6329
6463
  pause(): void;
6330
6464
  resume(): void;
6331
6465
  removeResumeButtonFromScreen(): void;