2019-07-22 16:31:47 +02:00
|
|
|
// Data from API hooks: {hookType}:api.{location}.{elementType}.{actionType}.{target}
|
2019-12-05 17:06:18 +01:00
|
|
|
// Data in internal functions: {hookType}:{location}.{elementType}.{actionType}.{target}
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-22 16:31:47 +02:00
|
|
|
export const clientFilterHookObject = {
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch videos of the trending page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.trending-videos.videos.list.params': true,
|
|
|
|
'filter:api.trending-videos.videos.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-10-01 23:11:53 +02:00
|
|
|
// Filter params/result of the function that fetch videos of the trending page
|
|
|
|
'filter:api.most-liked-videos.videos.list.params': true,
|
|
|
|
'filter:api.most-liked-videos.videos.list.result': true,
|
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch videos of the local page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.local-videos.videos.list.params': true,
|
|
|
|
'filter:api.local-videos.videos.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch videos of the recently-added page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.recently-added-videos.videos.list.params': true,
|
|
|
|
'filter:api.recently-added-videos.videos.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch videos of the user subscription page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.user-subscriptions-videos.videos.list.params': true,
|
|
|
|
'filter:api.user-subscriptions-videos.videos.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch the video of the video-watch page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.video-watch.video.get.params': true,
|
|
|
|
'filter:api.video-watch.video.get.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch the threads of the video-watch page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.video-watch.video-threads.list.params': true,
|
|
|
|
'filter:api.video-watch.video-threads.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch the replies of a thread in the video-watch page
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.video-watch.video-thread-replies.list.params': true,
|
|
|
|
'filter:api.video-watch.video-thread-replies.list.result': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch videos according to the user search
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.search.videos.list.params': true,
|
|
|
|
'filter:api.search.videos.list.result': true,
|
2019-07-24 10:21:22 +02:00
|
|
|
// Filter params/result of the function that fetch video-channels according to the user search
|
2019-07-22 16:31:47 +02:00
|
|
|
'filter:api.search.video-channels.list.params': true,
|
2019-11-25 11:16:12 +01:00
|
|
|
'filter:api.search.video-channels.list.result': true,
|
|
|
|
|
|
|
|
// Filter form
|
2019-12-05 17:06:18 +01:00
|
|
|
'filter:api.signup.registration.create.params': true,
|
|
|
|
|
|
|
|
// Filter the options to create our player
|
2019-12-05 17:26:58 +01:00
|
|
|
'filter:internal.video-watch.player.build-options.params': true,
|
|
|
|
'filter:internal.video-watch.player.build-options.result': true,
|
|
|
|
|
|
|
|
// Filter our SVG icons content
|
|
|
|
'filter:internal.common.svg-icons.get-content.params': true,
|
|
|
|
'filter:internal.common.svg-icons.get-content.result': true
|
2019-07-22 16:31:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export type ClientFilterHookName = keyof typeof clientFilterHookObject
|
|
|
|
|
|
|
|
export const clientActionHookObject = {
|
2019-07-24 10:21:22 +02:00
|
|
|
// Fired when the application is being initialized
|
2019-07-22 16:31:47 +02:00
|
|
|
'action:application.init': true,
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Fired when the video watch page is being initialized
|
2019-07-22 16:31:47 +02:00
|
|
|
'action:video-watch.init': true,
|
2019-07-24 10:21:22 +02:00
|
|
|
// Fired when the video watch page loaded the video
|
2019-07-22 16:31:47 +02:00
|
|
|
'action:video-watch.video.loaded': true,
|
2019-11-18 09:55:23 +01:00
|
|
|
// Fired when the player finished loading
|
|
|
|
'action:video-watch.player.loaded': true,
|
2020-03-05 13:14:26 +01:00
|
|
|
// Fired when the video watch page comments(threads) are loaded and load more comments on scroll
|
|
|
|
'action:video-watch.video-threads.loaded': true,
|
2020-03-11 09:59:41 +01:00
|
|
|
// Fired when a user click on 'View x replies' and they're loaded
|
|
|
|
'action:video-watch.video-thread-replies.loaded': true,
|
2019-07-22 16:31:47 +02:00
|
|
|
|
2020-05-06 14:01:30 +02:00
|
|
|
// Fired when the login page is being initialized
|
|
|
|
'action:login.init': true,
|
|
|
|
|
2019-07-24 10:21:22 +02:00
|
|
|
// Fired when the search page is being initialized
|
2019-07-25 19:02:54 +02:00
|
|
|
'action:search.init': true,
|
|
|
|
|
|
|
|
// Fired every time Angular URL changes
|
2019-11-25 11:16:12 +01:00
|
|
|
'action:router.navigation-end': true,
|
|
|
|
|
|
|
|
// Fired when the registration page is being initialized
|
|
|
|
'action:signup.register.init': true
|
2019-07-22 16:31:47 +02:00
|
|
|
}
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-22 16:31:47 +02:00
|
|
|
export type ClientActionHookName = keyof typeof clientActionHookObject
|
2019-07-22 15:40:13 +02:00
|
|
|
|
2019-07-22 16:31:47 +02:00
|
|
|
export const clientHookObject = Object.assign({}, clientFilterHookObject, clientActionHookObject)
|
|
|
|
export type ClientHookName = keyof typeof clientHookObject
|
2019-07-22 15:40:13 +02:00
|
|
|
|
|
|
|
export interface ClientHook {
|
|
|
|
runHook <T> (hookName: ClientHookName, result?: T, params?: any): Promise<T>
|
|
|
|
}
|