@clickview/player 0.0.20-dev.0 → 0.0.20-rc.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.
Files changed (24) hide show
  1. package/dist/en.json +1 -1
  2. package/dist/libs/common/src/backbone/core/BaseError.d.ts +0 -2
  3. package/dist/libs/common/src/react/utils/TextHelper.d.ts +1 -1
  4. package/dist/libs/shared/src/components/popup/PopupButtons.d.ts +1 -2
  5. package/dist/libs/shared/src/enums/SupportArticle.d.ts +16 -0
  6. package/dist/libs/shared/src/interfaces/models/BaseShareObject.d.ts +0 -1
  7. package/dist/libs/shared/src/utils/ArticleHelper.d.ts +5 -0
  8. package/dist/libs/shared/src/utils/DialogHelper.d.ts +0 -1
  9. package/dist/player-app.css +0 -2
  10. package/dist/player-app.js +19 -19
  11. package/dist/projects/player/src/players/base-player.d.ts +2 -2
  12. package/dist/projects/player/src/players/interactive-player.d.ts +4 -3
  13. package/dist/projects/player/src/plugins/create-clip-plugin/components/clip-timepoint-selector/clip-timepoint-selector.d.ts +0 -2
  14. package/dist/projects/player/src/plugins/interactive-plugin/components/interactive-summary/InteractiveSummaryWrapper.d.ts +2 -2
  15. package/dist/projects/player/src/plugins/interactive-plugin/components/interactive-summary/interactive-summary.d.ts +2 -2
  16. package/dist/projects/player/src/plugins/interactive-plugin/components/interactive-summary/progress-summary/progress-summary.d.ts +2 -2
  17. package/dist/projects/player/src/plugins/interactive-plugin/components/question-list/question-list-empty-state.d.ts +6 -1
  18. package/dist/projects/player/src/plugins/interactive-plugin/components/question-list/question-list.d.ts +2 -1
  19. package/dist/projects/player/src/plugins/interactive-plugin/interactive-plugin.d.ts +4 -3
  20. package/dist/projects/player/src/plugins/progress-reporter-plugin/progress-reporter-plugin.d.ts +9 -5
  21. package/dist/projects/player/src/services/analytics-service.d.ts +2 -2
  22. package/package.json +3 -3
  23. package/dist/projects/player/src/plugins/progress-reporter-plugin/components/progress-reporter-display.d.ts +0 -57
  24. package/dist/projects/player/src/plugins/progress-reporter-plugin/interfaces/ProgressEvent.d.ts +0 -8
@@ -39,7 +39,7 @@ import '../components/text-track-display/text-track-display.scss';
39
39
  import { ExternalLinkOptions } from 'projects/player/plugins/open-externally-plugin/interfaces/ExternalLinkOptions';
40
40
  import { PlaybackObject } from 'projects/player/interfaces/models/PlaybackObject';
41
41
  import { AnalyticsPlayerType, AnalyticsService } from 'projects/player/services/analytics-service';
42
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
42
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
43
43
  import { PlayerWrapperOptions } from 'projects/player/components/player/player';
44
44
  import { HashObject } from 'libs/analytics/interfaces';
45
45
  export interface BasePlayerOptions {
@@ -75,7 +75,7 @@ export declare abstract class BasePlayer {
75
75
  protected initialize(): void;
76
76
  private _configurePlugins;
77
77
  protected configurePlugins(): void;
78
- protected onFlushProgress(events: ProgressEventPair[]): void;
78
+ protected onFlushProgress(events: ProgressEvent[]): void;
79
79
  protected buildVideoJs(): VideoJsPlayer;
80
80
  protected getPlayerOptions(): PlayerWrapperOptions;
81
81
  protected fetch(): Promise<void>;
@@ -1,6 +1,6 @@
1
1
  import { HtmlPortalNode } from 'react-reverse-portal';
2
2
  import { HashObject } from 'libs/analytics/interfaces';
3
- import { CurrentUser } from 'libs/shared/interfaces';
3
+ import { CurrentUser, Config } from 'libs/shared/interfaces';
4
4
  import { ShareActivityStatus } from 'libs/shared/enums/ShareActivityStatus';
5
5
  import 'projects/player/plugins/favourite-plugin/favourite-plugin';
6
6
  import 'projects/player/plugins/activity-status-plugin/activity-status-plugin';
@@ -8,7 +8,7 @@ import 'projects/player/plugins/interactive-plugin/interactive-plugin';
8
8
  import { InteractiveMode } from 'projects/player/plugins/interactive-plugin/interfaces';
9
9
  import { PlaybackObject } from 'projects/player/interfaces/models/PlaybackObject';
10
10
  import { AnalyticsPlayerType } from 'projects/player/services/analytics-service';
11
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
11
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
12
12
  import { PlayerWrapperOptions } from 'projects/player/components/player/player';
13
13
  import { BasePlayer, BasePlayerOptions } from './base-player';
14
14
  declare type CollectResultsOptionalOptions = {
@@ -31,6 +31,7 @@ export declare type InteractivePlayerOptions = {
31
31
  onShowSummary?: (showing: boolean) => void;
32
32
  onClickEditDetails?: () => void;
33
33
  onClickPublish?: () => void;
34
+ config?: Config;
34
35
  } & (CollectResultsOptionalOptions | CollectResultsRequiredOptions) & BasePlayerOptions;
35
36
  export declare class InteractivePlayer extends BasePlayer {
36
37
  protected options: InteractivePlayerOptions;
@@ -39,7 +40,7 @@ export declare class InteractivePlayer extends BasePlayer {
39
40
  private totalProgress;
40
41
  constructor(id: string | Element, options: InteractivePlayerOptions);
41
42
  protected getPlayerOptions(): PlayerWrapperOptions;
42
- protected onFlushProgress(events: ProgressEventPair[]): void;
43
+ protected onFlushProgress(events: ProgressEvent[]): void;
43
44
  protected additionalSetup(playbackObject: PlaybackObject): Promise<void>;
44
45
  private setupUpClipPlugin;
45
46
  private setupViewInteractivePlugin;
@@ -76,8 +76,6 @@ export declare class ClipTimepointSelector extends Component {
76
76
  private setStartTime;
77
77
  private setEndTime;
78
78
  private bindListeners;
79
- private hasStartTime;
80
- private hasEndTime;
81
79
  private onTimeupdate;
82
80
  private dragStart;
83
81
  private dragEnd;
@@ -3,14 +3,14 @@ import { VideoJsPlayer } from 'video.js';
3
3
  import { HtmlPortalNode } from 'react-reverse-portal';
4
4
  import { CurrentUser, Interactive } from 'libs/shared/interfaces';
5
5
  import { InteractiveState } from 'projects/player/plugins/interactive-plugin/interfaces';
6
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
6
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
7
7
  import { ResultsService } from 'projects/player/plugins/interactive-plugin/utils/ResultsService';
8
8
  interface InteractiveSummaryWrapperProps {
9
9
  title: string;
10
10
  currentUser: CurrentUser;
11
11
  player: VideoJsPlayer;
12
12
  state: InteractiveState;
13
- progress?: ProgressEventPair[];
13
+ progress?: ProgressEvent[];
14
14
  interactive: Interactive;
15
15
  portalNode: HtmlPortalNode;
16
16
  resultsService: ResultsService;
@@ -3,7 +3,7 @@ import { HtmlPortalNode } from 'react-reverse-portal';
3
3
  import { VideoJsPlayer } from 'video.js';
4
4
  import { ResultsService } from 'projects/player/plugins/interactive-plugin/utils/ResultsService';
5
5
  import { CurrentUser, Interactive } from 'libs/shared/interfaces';
6
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
6
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
7
7
  import { InteractiveState } from 'projects/player/plugins/interactive-plugin/interfaces';
8
8
  interface InteractiveSummaryProps {
9
9
  title: string;
@@ -13,7 +13,7 @@ interface InteractiveSummaryProps {
13
13
  currentUser: CurrentUser;
14
14
  player: VideoJsPlayer;
15
15
  state: InteractiveState;
16
- progress?: ProgressEventPair[];
16
+ progress?: ProgressEvent[];
17
17
  interactive: Interactive;
18
18
  portalNode: HtmlPortalNode;
19
19
  resultsService?: ResultsService;
@@ -1,11 +1,11 @@
1
1
  import { Interactive } from 'libs/shared/interfaces';
2
2
  import React from 'react';
3
3
  import { VideoJsPlayer } from 'video.js';
4
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
4
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
5
5
  interface ProgressSummaryProps {
6
6
  player: VideoJsPlayer;
7
7
  duration: number;
8
- progress?: ProgressEventPair[];
8
+ progress?: ProgressEvent[];
9
9
  interactive: Interactive;
10
10
  }
11
11
  export declare function ProgressSummary(props: ProgressSummaryProps): React.ReactElement;
@@ -1,2 +1,7 @@
1
1
  import React from 'react';
2
- export declare function QuestionListEmptyState(): React.ReactElement;
2
+ import { Config } from 'libs/shared/interfaces';
3
+ interface QuestionListEmptyStateProps {
4
+ config: Config;
5
+ }
6
+ export declare function QuestionListEmptyState(props: QuestionListEmptyStateProps): React.ReactElement;
7
+ export {};
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { HtmlPortalNode } from 'react-reverse-portal';
3
- import { Interaction, Interactive } from 'libs/shared/interfaces';
3
+ import { Interaction, Interactive, Config } from 'libs/shared/interfaces';
4
4
  interface QuestionListProps {
5
5
  isCreate: boolean;
6
6
  interactive: Interactive;
@@ -8,6 +8,7 @@ interface QuestionListProps {
8
8
  portalNode: HtmlPortalNode;
9
9
  goToTimepoint: (timepointId: string, interactionId: string) => void;
10
10
  promptDelete: (interactionId: string) => void;
11
+ config?: Config;
11
12
  }
12
13
  export declare function QuestionList(props: QuestionListProps): React.ReactElement;
13
14
  export {};
@@ -1,9 +1,9 @@
1
1
  import videojs, { VideoJsPlayer } from 'video.js';
2
2
  import { HtmlPortalNode } from 'react-reverse-portal';
3
- import { CurrentUser, Interactive } from 'libs/shared/interfaces';
3
+ import { CurrentUser, Interactive, Config } from 'libs/shared/interfaces';
4
4
  import { InteractiveMode, LatestSession } from 'projects/player/plugins/interactive-plugin/interfaces';
5
5
  import { ResultsService } from 'projects/player/plugins/interactive-plugin/utils/ResultsService';
6
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
6
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
7
7
  import { AnalyticsService } from 'projects/player/services/analytics-service';
8
8
  import 'projects/player/plugins/interactive-plugin/components/interactive/interactive-component';
9
9
  import 'projects/player/plugins/interactive-plugin/components/continue-session/continue-session';
@@ -26,6 +26,7 @@ declare const Plugin: {
26
26
  interface InteractivePluginOptions {
27
27
  title: string;
28
28
  currentUser?: CurrentUser;
29
+ config?: Config;
29
30
  interactive: Interactive;
30
31
  mode?: InteractiveMode;
31
32
  imageApi?: URL;
@@ -33,7 +34,7 @@ interface InteractivePluginOptions {
33
34
  actionsPortalNode?: HtmlPortalNode;
34
35
  questionListPortalNode?: HtmlPortalNode;
35
36
  summaryPortalNode?: HtmlPortalNode;
36
- progress?: ProgressEventPair[];
37
+ progress?: ProgressEvent[];
37
38
  latestSession?: LatestSession;
38
39
  clipOffset?: number;
39
40
  analyticsService: AnalyticsService;
@@ -1,5 +1,4 @@
1
1
  import videojs, { VideoJsPlayer } from 'video.js';
2
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
3
2
  declare const Plugin: {
4
3
  new (player: VideoJsPlayer, options?: any): videojs.Plugin;
5
4
  prototype: videojs.Plugin;
@@ -14,13 +13,20 @@ declare const Plugin: {
14
13
  registerPlugin<T, K>(name: string, plugin: (this: VideoJsPlayer, ...options: K[]) => T): (...options: K[]) => T;
15
14
  registerPlugin<T_1 extends any>(name: string, plugin: T_1): () => T_1;
16
15
  };
16
+ interface Event {
17
+ time: number;
18
+ type: string;
19
+ }
20
+ export interface ProgressEvent {
21
+ start: Event;
22
+ end: Event;
23
+ }
17
24
  interface ProgressReporterPluginOptions {
18
- onFlush: (events: ProgressEventPair[]) => void;
25
+ onFlush: (events: ProgressEvent[]) => void;
19
26
  interval?: number;
20
27
  }
21
28
  declare class ProgressReporterPlugin extends Plugin {
22
29
  private options;
23
- private progressReporterDisplay;
24
30
  private eventBuffer;
25
31
  private latestTime;
26
32
  /**
@@ -44,8 +50,6 @@ declare class ProgressReporterPlugin extends Plugin {
44
50
  private validateOptions;
45
51
  private bindListeners;
46
52
  private startInterval;
47
- private addEasterEgg;
48
- private addDisplay;
49
53
  private onPlay;
50
54
  private onPause;
51
55
  private onTimeUpdate;
@@ -1,6 +1,6 @@
1
1
  import { RegionName } from 'libs/analytics/enums/RegionName';
2
2
  import { RegionalUrl, AnalyticsOptions, HashObject } from 'libs/analytics/interfaces';
3
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
3
+ import { ProgressEvent } from 'projects/player/plugins/progress-reporter-plugin/progress-reporter-plugin';
4
4
  export declare type AnalyticsPlayerType = 'player' | 'interactive-player' | 'create-clip-player' | 'reports-player';
5
5
  interface AnalyticsServiceOptions {
6
6
  collectionApiUrls: RegionalUrl;
@@ -23,7 +23,7 @@ export declare class AnalyticsService {
23
23
  private collectionApiClient;
24
24
  constructor(options: AnalyticsServiceOptions);
25
25
  logStream(): void;
26
- logVideoProgress(events: ProgressEventPair[]): void;
26
+ logVideoProgress(events: ProgressEvent[]): void;
27
27
  logUserAction(analyticsData: HashObject | HashObject[], analyticsOptions: AnalyticsOptions): void;
28
28
  private getAnalyticsData;
29
29
  private initialize;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@clickview/player",
3
- "version": "0.0.20-dev.0",
3
+ "version": "0.0.20-rc.0",
4
4
  "description": "ClickView Player",
5
5
  "main": "dist/player-app.js",
6
6
  "scripts": {
@@ -28,7 +28,7 @@
28
28
  "@babel/core": "7.11.6",
29
29
  "@clickview/eslint-config": "1.0.1",
30
30
  "@clickview/player-font": "0.0.12",
31
- "@clickview/tooling": "0.0.34-dev.0",
31
+ "@clickview/tooling": "0.0.33",
32
32
  "@storybook/react": "6.0.26",
33
33
  "@types/chromecast-caf-sender": "1.0.3",
34
34
  "@types/cropperjs": "1.3.0",
@@ -42,7 +42,7 @@
42
42
  "webpack-dev-server": "3.11.0"
43
43
  },
44
44
  "dependencies": {
45
- "@clickview/styles": "1.0.29-dev.0",
45
+ "@clickview/styles": "1.0.28",
46
46
  "@microsoft/signalr": "5.0.2",
47
47
  "cropperjs": "1.5.6",
48
48
  "draft-convert": "2.1.10",
@@ -1,57 +0,0 @@
1
- import videojs, { VideoJsPlayer } from 'video.js';
2
- import { ProgressEventPair } from 'projects/player/plugins/progress-reporter-plugin/interfaces/ProgressEvent';
3
- import './progress-reporter-display.scss';
4
- declare const Component: {
5
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions, ready?: videojs.Component.ReadyCallback): videojs.Component;
6
- prototype: videojs.Component;
7
- getComponent(name: "Button" | "button"): {
8
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions): videojs.Button;
9
- prototype: videojs.Button;
10
- };
11
- getComponent(name: "ClickableComponent" | "clickablecomponent"): {
12
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions): videojs.ClickableComponent;
13
- prototype: videojs.ClickableComponent;
14
- };
15
- getComponent(name: "ModalDialog" | "modaldialog"): {
16
- new (player: VideoJsPlayer, options?: videojs.ModalDialogOptions): videojs.ModalDialog;
17
- prototype: videojs.ModalDialog;
18
- };
19
- getComponent(name: "Menu" | "menu"): {
20
- new (player: VideoJsPlayer, options?: videojs.MenuOptions): videojs.Menu;
21
- prototype: videojs.Menu;
22
- };
23
- getComponent(name: "MenuButton" | "menubutton"): {
24
- new (player: VideoJsPlayer, options?: videojs.MenuButtonOptions): videojs.MenuButton;
25
- prototype: videojs.MenuButton;
26
- };
27
- getComponent(name: "MenuItem" | "menuitem"): {
28
- new (player: VideoJsPlayer, options?: videojs.MenuItemOptions): videojs.MenuItem;
29
- prototype: videojs.MenuItem;
30
- };
31
- getComponent(name: "MouseTimeDisplay" | "mouseTimeDisplay"): {
32
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions): videojs.MouseTimeDisplay;
33
- prototype: videojs.MouseTimeDisplay;
34
- };
35
- getComponent(name: "Spacer" | "spacer"): {
36
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions, ready?: videojs.Component.ReadyCallback): videojs.Spacer;
37
- prototype: videojs.Spacer;
38
- };
39
- getComponent(name: "Player" | "player"): {
40
- new (player: VideoJsPlayer, options?: import("video.js").VideoJsPlayerOptions): VideoJsPlayer;
41
- prototype: VideoJsPlayer;
42
- getTagSettings(tag: Element): any;
43
- };
44
- getComponent(name: "timeTooltip" | "TimeTooltip"): {
45
- new (player: VideoJsPlayer, options?: videojs.ComponentOptions): videojs.TimeToolTip;
46
- prototype: videojs.TimeToolTip;
47
- };
48
- getComponent(name: string): any;
49
- registerComponent(name: string, ComponentToRegister: any): any;
50
- };
51
- export declare class ProgressReporterDisplay extends Component {
52
- private events_;
53
- update(): void;
54
- addEvents(events: ProgressEventPair[]): void;
55
- createEl(): HTMLDivElement;
56
- }
57
- export {};
@@ -1,8 +0,0 @@
1
- export interface ProgressEvent {
2
- time: number;
3
- type: string;
4
- }
5
- export interface ProgressEventPair {
6
- start: ProgressEvent;
7
- end: ProgressEvent;
8
- }