@saooti/octopus-sdk 1.0.0 → 1.1.1

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 (317) hide show
  1. package/README.md +261 -0
  2. package/index.d.ts +4 -0
  3. package/index.ts +55 -3
  4. package/package.json +53 -45
  5. package/public/config.ts +4 -0
  6. package/public/css/fonts/icomoon.eot +0 -0
  7. package/public/css/fonts/icomoon.svg +129 -0
  8. package/public/css/fonts/icomoon.ttf +0 -0
  9. package/public/css/fonts/icomoon.woff +0 -0
  10. package/public/css/fonts/style.css +186 -1224
  11. package/public/img/403.jpeg +0 -0
  12. package/public/img/404.svg +242 -0
  13. package/public/img/ACPM.png +0 -0
  14. package/public/img/ouest_france_logo.svg +12 -0
  15. package/src/App.vue +102 -31
  16. package/src/api/classicCrud.ts +34 -0
  17. package/src/api/initialize.ts +5 -2
  18. package/src/assets/bootstrap-diff.scss +197 -0
  19. package/src/assets/form.scss +77 -77
  20. package/src/assets/general.scss +284 -272
  21. package/src/assets/live.scss +39 -0
  22. package/src/assets/modal.scss +43 -50
  23. package/src/assets/multiselect.scss +522 -573
  24. package/src/assets/octopus-library.scss +18 -4
  25. package/src/assets/share.scss +243 -0
  26. package/src/assets/transition.scss +98 -2
  27. package/src/components/display/aggregator/RssSection.vue +3 -5
  28. package/src/components/display/categories/CategoryChooser.vue +151 -114
  29. package/src/components/display/categories/CategoryFilter.vue +162 -0
  30. package/src/components/display/categories/CategoryList.vue +149 -117
  31. package/src/components/display/comments/AddCommentModal.vue +103 -108
  32. package/src/components/display/comments/CommentBasicView.vue +95 -0
  33. package/src/components/display/comments/CommentInput.vue +195 -183
  34. package/src/components/display/comments/CommentItem.vue +170 -208
  35. package/src/components/display/comments/CommentList.vue +134 -228
  36. package/src/components/display/comments/CommentParentInfo.vue +28 -62
  37. package/src/components/display/comments/CommentPlayer.vue +53 -56
  38. package/src/components/display/comments/CommentSection.vue +52 -83
  39. package/src/components/display/edit/EditBox.vue +10 -4
  40. package/src/components/display/edit/EditCommentBox.vue +124 -38
  41. package/src/components/display/emission/EmissionChooser.vue +88 -108
  42. package/src/components/display/emission/EmissionInlineList.vue +156 -157
  43. package/src/components/display/emission/EmissionItem.vue +72 -226
  44. package/src/components/display/emission/EmissionList.vue +159 -201
  45. package/src/components/display/emission/EmissionPlayerItem.vue +203 -174
  46. package/src/components/display/filter/AdvancedSearch.vue +224 -432
  47. package/src/components/display/filter/CategoryFilter.vue +105 -0
  48. package/src/components/display/filter/MonetizableFilter.vue +18 -15
  49. package/src/components/display/filter/ProductorSearch.vue +153 -176
  50. package/src/components/display/filter/RubriqueChoice.vue +97 -0
  51. package/src/components/display/filter/RubriqueFilter.vue +232 -0
  52. package/src/components/display/list/ListPaginate.vue +145 -0
  53. package/src/components/display/list/Paginate.vue +218 -0
  54. package/src/components/display/live/CountDown.vue +31 -30
  55. package/src/components/display/live/LiveHorizontalList.vue +84 -62
  56. package/src/components/display/live/LiveItem.vue +161 -186
  57. package/src/components/display/live/LiveList.vue +184 -295
  58. package/src/components/display/organisation/OrganisationChooser.vue +124 -162
  59. package/src/components/display/organisation/OrganisationChooserLight.vue +53 -56
  60. package/src/components/display/participant/ParticipantItem.vue +91 -128
  61. package/src/components/display/participant/ParticipantList.vue +134 -121
  62. package/src/components/display/playlist/PlaylistItem.vue +60 -97
  63. package/src/components/display/playlist/PlaylistList.vue +99 -92
  64. package/src/components/display/playlist/PodcastList.vue +117 -132
  65. package/src/components/display/playlist/PodcastPlaylistInlineList.vue +191 -0
  66. package/src/components/display/podcasts/AnimatorsItem.vue +29 -37
  67. package/src/components/display/podcasts/ParticipantDescription.vue +82 -0
  68. package/src/components/display/podcasts/PodcastFilterList.vue +49 -102
  69. package/src/components/display/podcasts/PodcastImage.vue +208 -225
  70. package/src/components/display/podcasts/PodcastInlineList.vue +62 -355
  71. package/src/components/display/podcasts/PodcastInlineListClassic.vue +240 -0
  72. package/src/components/display/podcasts/PodcastInlineListTemplate.vue +167 -0
  73. package/src/components/display/podcasts/PodcastItem.vue +94 -218
  74. package/src/components/display/podcasts/PodcastItemInfo.vue +166 -0
  75. package/src/components/display/podcasts/PodcastList.vue +127 -178
  76. package/src/components/display/podcasts/PodcastModuleBox.vue +234 -0
  77. package/src/components/display/podcasts/PodcastPlayBar.vue +101 -0
  78. package/src/components/display/podcasts/PodcastSwiperList.vue +204 -0
  79. package/src/components/display/podcasts/TagList.vue +60 -38
  80. package/src/components/display/rubriques/RubriqueChooser.vue +144 -131
  81. package/src/components/display/rubriques/RubriqueList.vue +216 -0
  82. package/src/components/display/sharing/PlayerParameters.vue +111 -153
  83. package/src/components/display/sharing/QrCode.vue +96 -0
  84. package/src/components/display/sharing/ShareButtons.vue +63 -233
  85. package/src/components/display/sharing/ShareButtonsIntern.vue +225 -0
  86. package/src/components/display/sharing/ShareDistribution.vue +102 -166
  87. package/src/components/display/sharing/SharePlayer.vue +189 -353
  88. package/src/components/display/sharing/SharePlayerColors.vue +78 -0
  89. package/src/components/display/sharing/SharePlayerTypes.vue +112 -0
  90. package/src/components/display/sharing/SplitButton.vue +42 -0
  91. package/src/components/display/sharing/SubscribeButtons.vue +65 -118
  92. package/src/components/display/studio/RecordingItemButton.vue +3 -5
  93. package/src/components/form/ClassicCheckbox.vue +66 -0
  94. package/src/components/form/ClassicLoading.vue +28 -0
  95. package/src/components/form/ClassicRadio.vue +66 -0
  96. package/src/components/form/ClassicSearch.vue +86 -0
  97. package/src/components/form/ClassicSelect.vue +65 -0
  98. package/src/components/misc/ErrorMessage.vue +27 -18
  99. package/src/components/misc/Footer.vue +151 -108
  100. package/src/components/misc/HomeDropdown.vue +95 -154
  101. package/src/components/misc/LeftMenu.vue +137 -206
  102. package/src/components/misc/Popover.vue +118 -0
  103. package/src/components/misc/Snackbar.vue +73 -37
  104. package/src/components/misc/TopBar.vue +211 -314
  105. package/src/components/misc/modal/ClipboardModal.vue +34 -47
  106. package/src/components/misc/modal/MessageModal.vue +74 -53
  107. package/src/components/misc/modal/NewsletterModal.vue +272 -224
  108. package/src/components/misc/modal/QrCodeModal.vue +58 -0
  109. package/src/components/misc/modal/ShareModalPlayer.vue +140 -74
  110. package/src/components/misc/player/Player.vue +146 -0
  111. package/src/components/misc/player/PlayerCompact.vue +154 -0
  112. package/src/components/misc/player/PlayerLarge.vue +166 -0
  113. package/src/components/misc/player/PlayerProgressBar.vue +112 -0
  114. package/src/components/misc/player/PlayerTimeline.vue +61 -0
  115. package/src/components/mixins/functions.ts +21 -18
  116. package/src/components/mixins/handle403.ts +17 -0
  117. package/src/components/mixins/init.ts +24 -0
  118. package/src/components/mixins/orgaComputed.ts +15 -0
  119. package/src/components/mixins/organisationFilter.ts +41 -0
  120. package/src/components/mixins/player/playerComment.ts +98 -0
  121. package/src/components/mixins/player/playerDisplay.ts +113 -0
  122. package/src/components/mixins/player/playerLive.ts +111 -0
  123. package/src/components/mixins/player/playerLogic.ts +225 -0
  124. package/src/components/mixins/tagOfMixins.ts +19 -0
  125. package/src/components/pages/Category.vue +24 -28
  126. package/src/components/pages/Emission.vue +144 -177
  127. package/src/components/pages/Emissions.vue +94 -110
  128. package/src/components/pages/Error403Page.vue +60 -0
  129. package/src/components/pages/Home.vue +74 -21
  130. package/src/components/pages/Lives.vue +53 -58
  131. package/src/components/pages/PageNotFound.vue +55 -0
  132. package/src/components/pages/Participant.vue +113 -129
  133. package/src/components/pages/Participants.vue +25 -41
  134. package/src/components/pages/Playlist.vue +86 -86
  135. package/src/components/pages/Playlists.vue +33 -52
  136. package/src/components/pages/Podcast.vue +206 -478
  137. package/src/components/pages/Podcasts.vue +112 -156
  138. package/src/components/pages/Rubrique.vue +21 -27
  139. package/src/components/pages/Search.vue +37 -94
  140. package/src/helper/dom.ts +2 -2
  141. package/src/helper/duration.ts +18 -8
  142. package/src/helper/useEventListener.ts +18 -0
  143. package/src/i18n.ts +36 -0
  144. package/src/locale/de.ts +309 -0
  145. package/src/locale/educationen.ts +14 -0
  146. package/src/locale/en.ts +316 -1
  147. package/src/locale/es.ts +309 -0
  148. package/src/locale/fr.ts +47 -15
  149. package/src/locale/it.ts +307 -0
  150. package/src/locale/messages.ts +11 -2
  151. package/src/locale/sl.ts +309 -0
  152. package/src/main.ts +64 -55
  153. package/src/router/router.ts +192 -159
  154. package/src/sass/_variables.scss +10 -8
  155. package/src/shims-tsx.d.ts +15 -0
  156. package/src/shims-vue-recaptcha-v3.d.ts +9 -0
  157. package/src/shims-vue.d.ts +5 -6
  158. package/src/store/AppStore.ts +41 -173
  159. package/src/store/class/adserver/adserverConfig.ts +9 -0
  160. package/src/store/class/adserver/adserverOtherEmission.ts +13 -0
  161. package/src/store/class/adserver/adserverTiming.ts +10 -0
  162. package/src/store/class/cartouchier/cartouche.ts +15 -0
  163. package/src/store/class/cartouchier/cartouchier.ts +9 -0
  164. package/src/store/class/conference/conference.ts +35 -0
  165. package/src/store/class/conference/conferenceMessage.ts +10 -0
  166. package/src/store/class/conference/conferenceParticipant.ts +18 -0
  167. package/src/store/class/conference/pad.ts +15 -0
  168. package/src/store/class/conference/studioCall.ts +7 -0
  169. package/src/store/class/contract/contract.ts +7 -0
  170. package/src/store/class/contract/contractOrganisation.ts +7 -0
  171. package/src/store/class/ftp/ftpEmission.ts +41 -0
  172. package/src/store/class/ftp/ftpParam.ts +12 -0
  173. package/src/store/class/ftp/testFtpEmission.ts +5 -0
  174. package/src/store/class/general/audioView.ts +21 -0
  175. package/src/store/class/general/category.ts +10 -0
  176. package/src/store/class/general/comment.ts +16 -0
  177. package/src/store/class/general/customPlayer.ts +9 -0
  178. package/src/store/class/general/emission.ts +23 -0
  179. package/src/store/class/general/fetchParam.ts +3 -0
  180. package/src/store/class/general/initState.ts +25 -0
  181. package/src/store/class/general/interfacePageable.ts +16 -0
  182. package/src/store/class/general/ituneCategory.ts +5 -0
  183. package/src/store/class/general/media.ts +14 -0
  184. package/src/store/class/general/organisation.ts +20 -0
  185. package/src/store/class/general/pageable.ts +13 -0
  186. package/src/store/class/general/participant.ts +12 -0
  187. package/src/store/class/general/player.ts +14 -0
  188. package/src/store/class/general/playlist.ts +13 -0
  189. package/src/store/class/general/podcast.ts +43 -0
  190. package/src/store/class/general/sortPageable.ts +5 -0
  191. package/src/store/class/general/soundcastCategory.ts +8 -0
  192. package/src/store/class/ouestFrance/ofTag.ts +36 -0
  193. package/src/store/class/ouestFrance/ofTagInfo.ts +9 -0
  194. package/src/store/class/ouestFrance/ofTagPage.ts +7 -0
  195. package/src/store/class/ouestFrance/ofTagSeo.ts +7 -0
  196. package/src/store/class/ouestFrance/ofTagVente.ts +6 -0
  197. package/src/store/class/ouestFrance/ofTagWithParents.ts +26 -0
  198. package/src/store/class/rss/aggregator.ts +28 -0
  199. package/src/store/class/rss/rssEmission.ts +14 -0
  200. package/src/store/class/rss/rssInfo.ts +8 -0
  201. package/src/store/class/rubrique/rubriquage.ts +10 -0
  202. package/src/store/class/rubrique/rubriquageFilter.ts +6 -0
  203. package/src/store/class/rubrique/rubrique.ts +9 -0
  204. package/src/store/class/stat/statArrayIncome.ts +6 -0
  205. package/src/store/class/stat/statArrayObject.ts +34 -0
  206. package/src/store/class/stat/statGraph.ts +7 -0
  207. package/src/store/class/user/person.ts +15 -0
  208. package/src/store/class/user/profile.ts +12 -0
  209. package/src/store/class/user/userKeycloak.ts +24 -0
  210. package/src/store/paramStore.ts +222 -217
  211. package/src/store/typeAppStore.ts +186 -235
  212. package/src/vuex-shim.d.ts +8 -0
  213. package/tsconfig.json +4 -0
  214. package/vue.config.js +16 -0
  215. package/public/css/fonts/saooti-ui.eot +0 -0
  216. package/public/css/fonts/saooti-ui.svg +0 -829
  217. package/public/css/fonts/saooti-ui.ttf +0 -0
  218. package/public/css/fonts/saooti-ui.woff +0 -0
  219. package/public/css/fonts/stitcher-logo.svg +0 -83
  220. package/public/img/ACPM.PNG +0 -0
  221. package/src/api/comments.ts +0 -7
  222. package/src/api/emissions.ts +0 -7
  223. package/src/api/podcasts.ts +0 -7
  224. package/src/api/profile.ts +0 -8
  225. package/src/api/studio.ts +0 -1
  226. package/src/assets/bootstrap_scss/_alert.scss +0 -51
  227. package/src/assets/bootstrap_scss/_badge.scss +0 -54
  228. package/src/assets/bootstrap_scss/_breadcrumb.scss +0 -42
  229. package/src/assets/bootstrap_scss/_button-group.scss +0 -164
  230. package/src/assets/bootstrap_scss/_buttons.scss +0 -291
  231. package/src/assets/bootstrap_scss/_card.scss +0 -278
  232. package/src/assets/bootstrap_scss/_carousel.scss +0 -197
  233. package/src/assets/bootstrap_scss/_close.scss +0 -41
  234. package/src/assets/bootstrap_scss/_code.scss +0 -48
  235. package/src/assets/bootstrap_scss/_custom-forms.scss +0 -522
  236. package/src/assets/bootstrap_scss/_dropdown.scss +0 -201
  237. package/src/assets/bootstrap_scss/_forms.scss +0 -352
  238. package/src/assets/bootstrap_scss/_functions.scss +0 -134
  239. package/src/assets/bootstrap_scss/_grid.scss +0 -69
  240. package/src/assets/bootstrap_scss/_images.scss +0 -42
  241. package/src/assets/bootstrap_scss/_input-group.scss +0 -191
  242. package/src/assets/bootstrap_scss/_jumbotron.scss +0 -17
  243. package/src/assets/bootstrap_scss/_list-group.scss +0 -158
  244. package/src/assets/bootstrap_scss/_media.scss +0 -8
  245. package/src/assets/bootstrap_scss/_mixins.scss +0 -47
  246. package/src/assets/bootstrap_scss/_modal.scss +0 -243
  247. package/src/assets/bootstrap_scss/_nav.scss +0 -120
  248. package/src/assets/bootstrap_scss/_navbar.scss +0 -324
  249. package/src/assets/bootstrap_scss/_pagination.scss +0 -74
  250. package/src/assets/bootstrap_scss/_popover.scss +0 -170
  251. package/src/assets/bootstrap_scss/_print.scss +0 -141
  252. package/src/assets/bootstrap_scss/_progress.scss +0 -46
  253. package/src/assets/bootstrap_scss/_reboot.scss +0 -482
  254. package/src/assets/bootstrap_scss/_root.scss +0 -20
  255. package/src/assets/bootstrap_scss/_spinners.scss +0 -55
  256. package/src/assets/bootstrap_scss/_tables.scss +0 -185
  257. package/src/assets/bootstrap_scss/_toasts.scss +0 -44
  258. package/src/assets/bootstrap_scss/_tooltip.scss +0 -115
  259. package/src/assets/bootstrap_scss/_transitions.scss +0 -20
  260. package/src/assets/bootstrap_scss/_type.scss +0 -125
  261. package/src/assets/bootstrap_scss/_utilities.scss +0 -17
  262. package/src/assets/bootstrap_scss/_variables.scss +0 -1145
  263. package/src/assets/bootstrap_scss/bootstrap-grid.scss +0 -29
  264. package/src/assets/bootstrap_scss/bootstrap-reboot.scss +0 -12
  265. package/src/assets/bootstrap_scss/bootstrap.scss +0 -44
  266. package/src/assets/bootstrap_scss/mixins/_alert.scss +0 -13
  267. package/src/assets/bootstrap_scss/mixins/_background-variant.scss +0 -22
  268. package/src/assets/bootstrap_scss/mixins/_badge.scss +0 -17
  269. package/src/assets/bootstrap_scss/mixins/_border-radius.scss +0 -63
  270. package/src/assets/bootstrap_scss/mixins/_box-shadow.scss +0 -20
  271. package/src/assets/bootstrap_scss/mixins/_breakpoints.scss +0 -123
  272. package/src/assets/bootstrap_scss/mixins/_buttons.scss +0 -110
  273. package/src/assets/bootstrap_scss/mixins/_caret.scss +0 -62
  274. package/src/assets/bootstrap_scss/mixins/_clearfix.scss +0 -7
  275. package/src/assets/bootstrap_scss/mixins/_deprecate.scss +0 -10
  276. package/src/assets/bootstrap_scss/mixins/_float.scss +0 -14
  277. package/src/assets/bootstrap_scss/mixins/_forms.scss +0 -177
  278. package/src/assets/bootstrap_scss/mixins/_gradients.scss +0 -45
  279. package/src/assets/bootstrap_scss/mixins/_grid-framework.scss +0 -71
  280. package/src/assets/bootstrap_scss/mixins/_grid.scss +0 -69
  281. package/src/assets/bootstrap_scss/mixins/_hover.scss +0 -37
  282. package/src/assets/bootstrap_scss/mixins/_image.scss +0 -36
  283. package/src/assets/bootstrap_scss/mixins/_list-group.scss +0 -21
  284. package/src/assets/bootstrap_scss/mixins/_lists.scss +0 -7
  285. package/src/assets/bootstrap_scss/mixins/_nav-divider.scss +0 -11
  286. package/src/assets/bootstrap_scss/mixins/_pagination.scss +0 -22
  287. package/src/assets/bootstrap_scss/mixins/_reset-text.scss +0 -17
  288. package/src/assets/bootstrap_scss/mixins/_resize.scss +0 -6
  289. package/src/assets/bootstrap_scss/mixins/_screen-reader.scss +0 -34
  290. package/src/assets/bootstrap_scss/mixins/_size.scss +0 -7
  291. package/src/assets/bootstrap_scss/mixins/_table-row.scss +0 -39
  292. package/src/assets/bootstrap_scss/mixins/_text-emphasis.scss +0 -17
  293. package/src/assets/bootstrap_scss/mixins/_text-hide.scss +0 -11
  294. package/src/assets/bootstrap_scss/mixins/_text-truncate.scss +0 -8
  295. package/src/assets/bootstrap_scss/mixins/_transition.scss +0 -16
  296. package/src/assets/bootstrap_scss/mixins/_visibility.scss +0 -8
  297. package/src/assets/bootstrap_scss/utilities/_align.scss +0 -8
  298. package/src/assets/bootstrap_scss/utilities/_background.scss +0 -19
  299. package/src/assets/bootstrap_scss/utilities/_borders.scss +0 -75
  300. package/src/assets/bootstrap_scss/utilities/_clearfix.scss +0 -3
  301. package/src/assets/bootstrap_scss/utilities/_display.scss +0 -26
  302. package/src/assets/bootstrap_scss/utilities/_embed.scss +0 -39
  303. package/src/assets/bootstrap_scss/utilities/_flex.scss +0 -51
  304. package/src/assets/bootstrap_scss/utilities/_float.scss +0 -11
  305. package/src/assets/bootstrap_scss/utilities/_overflow.scss +0 -5
  306. package/src/assets/bootstrap_scss/utilities/_position.scss +0 -32
  307. package/src/assets/bootstrap_scss/utilities/_screenreaders.scss +0 -11
  308. package/src/assets/bootstrap_scss/utilities/_shadows.scss +0 -6
  309. package/src/assets/bootstrap_scss/utilities/_sizing.scss +0 -20
  310. package/src/assets/bootstrap_scss/utilities/_spacing.scss +0 -73
  311. package/src/assets/bootstrap_scss/utilities/_stretched-link.scss +0 -19
  312. package/src/assets/bootstrap_scss/utilities/_text.scss +0 -72
  313. package/src/assets/bootstrap_scss/utilities/_visibility.scss +0 -13
  314. package/src/assets/bootstrap_scss/vendor/_rfs.scss +0 -204
  315. package/src/components/misc/Player.vue +0 -792
  316. package/src/shims-vuex.d.ts +0 -7
  317. package/src/views/Home.vue +0 -18
@@ -0,0 +1,60 @@
1
+ <template>
2
+ <div class="page-box page-box-absolute bg-white justify-content-evenly">
3
+ <div class="not-auth-content d-flex-column justify-content-between">
4
+ <div class="d-flex flex-column justify-content-around">
5
+ <img
6
+ class="logo-octopus"
7
+ src="/img/logo_octopus_final.svg"
8
+ :alt="$t('Logo of main page')"
9
+ >
10
+ <h2>{{ $t('You do not have the right to access this page' ) }}</h2>
11
+ </div>
12
+ <img
13
+ class="stop-octopus-img"
14
+ src="/img/403.jpeg"
15
+ :alt="$t('You do not have the right to access this page')"
16
+ >
17
+ </div>
18
+
19
+ <a
20
+ class="btn btn-primary"
21
+ :href="authenticated ?'/sso/logout':'/sso/login'"
22
+ >{{ authText }}</a>
23
+ </div>
24
+ </template>
25
+
26
+ <script lang="ts">
27
+ import { state } from '../../store/paramStore';
28
+ import { defineComponent } from 'vue';
29
+ export default defineComponent({
30
+ name: 'Error403Page',
31
+ computed: {
32
+ authenticated(): boolean {
33
+ return (state.generalParameters.authenticated as boolean);
34
+ },
35
+ authText():string{
36
+ return this.authenticated ? this.$t('Logout') : this.$t('Login');
37
+ }
38
+ },
39
+ mounted() {
40
+ document.title = this.$store.state.general.metaTitle;
41
+ },
42
+ });
43
+ </script>
44
+ <style lang="scss">
45
+ .octopus-app .not-auth-content{
46
+ @media (max-width: 960px) {
47
+ align-items: center;
48
+ }
49
+ .stop-octopus-img{
50
+ width: 600px;
51
+ height: auto;
52
+ @media (max-width: 1400px) {
53
+ width: 400px;
54
+ }
55
+ @media (max-width: 450px) {
56
+ width: 80%;
57
+ }
58
+ }
59
+ }
60
+ </style>
@@ -1,40 +1,93 @@
1
1
  <template>
2
2
  <div class="page-box">
3
- <PodcastInlineList
4
- v-for="c in categories"
5
- :key="c.id"
6
- :iabId="c.id"
7
- :title="c.name"
8
- :buttonText="$t('All podcast button', { name: c.name })"
9
- />
3
+ <template v-if="0 === rubriquageFilter.length">
4
+ <PodcastInlineList
5
+ v-for="c in categories"
6
+ :key="c.id"
7
+ :iab-id="c.id"
8
+ :title="c.name"
9
+ :button-text="$t('All podcast button', { name: c.name })"
10
+ />
11
+ </template>
12
+ <template v-else>
13
+ <PodcastInlineList
14
+ v-for="r in rubriqueDisplay"
15
+ :key="r.rubriqueId"
16
+ :rubrique-id="rubriqueId.concat(r.rubriqueId)"
17
+ :title="r.name"
18
+ :button-text="$t('All podcast button', { name: r.name })"
19
+ />
20
+ <PodcastInlineList
21
+ v-if="rubriqueDisplay && rubriqueDisplay.length"
22
+ :no-rubriquage-id="[rubriqueDisplay[0].rubriquageId]"
23
+ :rubrique-id="rubriqueId"
24
+ :title="$t('Without rubric')"
25
+ :button-text="$t('All podcast button', { name: $t('Without rubric') })"
26
+ />
27
+ </template>
10
28
  </div>
11
29
  </template>
12
- <style lang="scss"></style>
13
30
 
14
31
  <script lang="ts">
15
32
  import PodcastInlineList from '../display/podcasts/PodcastInlineList.vue';
16
33
  import { state } from '../../store/paramStore';
17
-
34
+ import { RubriquageFilter } from '@/store/class/rubrique/rubriquageFilter';
35
+ import { Rubriquage } from '@/store/class/rubrique/rubriquage';
36
+ import { Rubrique } from '@/store/class/rubrique/rubrique';
18
37
  import { defineComponent } from 'vue'
38
+ import { Category } from '@/store/class/general/category';
19
39
  export default defineComponent({
20
- name: 'home',
21
-
40
+ name: 'Home',
22
41
  components: {
23
42
  PodcastInlineList,
24
43
  },
25
-
26
- mounted() {},
27
-
44
+ data() {
45
+ return {
46
+ rubriqueId: [] as Array<number>,
47
+ };
48
+ },
28
49
  computed: {
29
- isPodcastmaker() {
30
- return state.generalParameters.podcastmaker;
50
+ rubriqueDisplay(): Array<Rubrique>{
51
+ return this.$store.state.filter.rubriqueDisplay.filter((rubrique: Rubrique) => 0 !== rubrique.podcastCount );
31
52
  },
32
- categories() {
33
- return state.generalParameters.allCategories.filter((c:any) => {
34
- if (this.isPodcastmaker) return c.podcastOrganisationCount;
53
+ rubriquageFilter(): Array<Rubriquage>{
54
+ return this.$store.state.filter.organisationId ? this.$store.state.filter.rubriquageArray :[];
55
+ },
56
+ rubriqueFilter(): Array<RubriquageFilter>{
57
+ return this.$store.state.filter.rubriqueFilter;
58
+ },
59
+ categories(): Array<Category> {
60
+ if(this.$store.state.filter.iab){
61
+ return [this.$store.state.filter.iab];
62
+ }
63
+ return this.$store.state.categories.filter((c: Category) => {
64
+ if (state.generalParameters.podcastmaker) return c.podcastOrganisationCount;
35
65
  return c.podcastCount;
36
66
  });
37
67
  },
38
68
  },
39
- });
40
- </script>
69
+ watch:{
70
+ rubriqueFilter:{
71
+ deep: true,
72
+ immediate: true,
73
+ handler(){
74
+ if(this.rubriqueFilter.length){
75
+ this.updateRubriquageFilter();
76
+ }
77
+ }
78
+ }
79
+ },
80
+ methods:{
81
+ updateRubriquageFilter(){
82
+ const length = this.rubriqueFilter.length;
83
+ const rubriqueId: Array<number>= [];
84
+ for (let index = 0; index < length; index++) {
85
+ if(0 < this.rubriqueFilter[index].rubriqueId){
86
+ rubriqueId.push(this.rubriqueFilter[index].rubriqueId);
87
+ }
88
+ }
89
+ this.rubriqueId = rubriqueId;
90
+ },
91
+ }
92
+ })
93
+ </script>
@@ -2,92 +2,87 @@
2
2
  <div class="page-box">
3
3
  <div class="d-flex flex-column align-items-center mb-3">
4
4
  <h1>{{ $t('In live') }}</h1>
5
- <router-link to="/main/priv/edit/live" v-if="liveRight && filterOrga">
6
- <button class="btn btn-primary">{{ $t('Launch a new live') }}</button>
7
- </router-link>
8
- <template v-else>
9
- <div class="align-self-start font-weight-bold mb-2">
10
- {{ $t('Please chose a productor') }}
11
- </div>
12
- <OrganisationChooser
13
- :defaultanswer="$t('Please chose a productor')"
14
- :all="true"
15
- @selected="onOrganisationSelected"
16
- />
5
+ <template v-if="!isPodcastmaker">
6
+ <router-link
7
+ v-if="liveRight && filterOrga"
8
+ to="/main/priv/edit/live"
9
+ >
10
+ <button class="btn btn-primary">
11
+ {{ $t('Launch a new live') }}
12
+ </button>
13
+ </router-link>
14
+ <template v-else>
15
+ <div class="align-self-start fw-bold mb-2">
16
+ {{ $t('Please chose a productor') }}
17
+ </div>
18
+ <OrganisationChooser
19
+ :defaultanswer="$t('Please chose a productor')"
20
+ @selected="onOrganisationSelected"
21
+ />
22
+ </template>
17
23
  </template>
18
24
  </div>
19
25
  <LiveList
20
- @initConferenceIds="initConferenceIds"
21
- :conferenceWatched="conferenceWatched"
22
- :organisationId="organisationId"
23
26
  v-if="filterOrga || organisationId"
27
+ :conference-watched="conferenceWatched"
28
+ :organisation-id="organisationId"
29
+ @initConferenceIds="initConferenceIds"
24
30
  />
25
31
  </div>
26
32
  </template>
27
- <style lang="scss"></style>
33
+
28
34
  <script lang="ts">
29
- // @ is an alias to /src
30
35
  import { state } from '../../store/paramStore';
31
- import LiveList from '../display/live/LiveList.vue';
32
- import OrganisationChooser from '../display/organisation/OrganisationChooser.vue';
33
-
34
- import { defineComponent } from 'vue'
36
+ import { Organisation } from '@/store/class/general/organisation';
37
+ import { defineComponent, defineAsyncComponent } from 'vue';
38
+ import { Conference } from '@/store/class/conference/conference';
39
+ const LiveList = defineAsyncComponent(() => import('../display/live/LiveList.vue'));
40
+ const OrganisationChooser = defineAsyncComponent(() => import('../display/organisation/OrganisationChooser.vue'));
35
41
  export default defineComponent({
36
42
  components: {
37
43
  LiveList,
38
44
  OrganisationChooser,
39
45
  },
40
46
  props: {
41
- conferenceWatched: { default: [] },
42
- organisationId: { default: undefined as any },
47
+ conferenceWatched: { default: () => [], type: Array as ()=>Array<{conferenceId:number,interval:ReturnType<typeof setTimeout>|undefined, status:string}>},
48
+ organisationId: { default: undefined, type: String },
49
+ productor:{default:undefined, type: String}
43
50
  },
44
51
  emits: ['update:organisationId', 'initConferenceIds'],
45
-
46
- created() {
47
- if (this.$route.query.productor) {
48
- this.$emit('update:organisationId',this.$route.query.productor);
49
- } else if (this.$store.state.filter.organisationId) {
50
- this.$emit('update:organisationId',this.$store.state.filter.organisationId);
51
- }
52
- if (
53
- this.$store.state.organisation &&
54
- this.$store.state.organisation.attributes &&
55
- !this.$store.state.organisation.attributes['live.active']
56
- ) {
57
- this.live = false;
58
- }
59
- },
60
-
61
52
  data() {
62
53
  return {
63
- live: true,
54
+ live: true as boolean,
64
55
  };
65
56
  },
66
-
57
+
67
58
  computed: {
68
- liveRight() {
69
- if (this.isRoleLive && this.live) return true;
70
- return false;
71
- },
72
- isRoleLive() {
73
- return state.generalParameters.isRoleLive;
59
+ liveRight(): boolean {
60
+ return (state.generalParameters.isRoleLive as boolean)&& this.live;
74
61
  },
75
- filterOrga():any {
62
+ filterOrga(): string {
76
63
  return this.$store.state.filter.organisationId;
77
64
  },
65
+ isPodcastmaker(): boolean {
66
+ return (state.generalParameters.podcastmaker as boolean);
67
+ },
68
+ },
69
+ created() {
70
+ if (this.productor) {
71
+ this.$emit('update:organisationId',this.productor);
72
+ } else if (this.$store.state.filter.organisationId) {
73
+ this.$emit('update:organisationId',this.$store.state.filter.organisationId);
74
+ }
75
+ if (!this.$store.state.organisation?.attributes?.['live.active']) {
76
+ this.live = false;
77
+ }
78
78
  },
79
-
80
79
  methods: {
81
- initConferenceIds(listIds: any) {
80
+ initConferenceIds(listIds: Array<Conference>): void {
82
81
  this.$emit('initConferenceIds', listIds);
83
82
  },
84
- onOrganisationSelected(organisation: any) {
85
- if (organisation && organisation.id) {
86
- this.$emit('update:organisationId', organisation.id);
87
- } else {
88
- this.$emit('update:organisationId', undefined);
89
- }
83
+ onOrganisationSelected(organisation: Organisation|undefined): void {
84
+ this.$emit('update:organisationId', organisation?.id);
90
85
  },
91
86
  },
92
- });
93
- </script>
87
+ })
88
+ </script>
@@ -0,0 +1,55 @@
1
+ <template>
2
+ <div
3
+ class="page-box page-box-absolute page-not-found"
4
+ :style="backgroundStyle"
5
+ >
6
+ <div class="position-absolute module-box">
7
+ <h1>{{ $t('Oops') }}</h1>
8
+ <h2>{{ $t('The page you are looking for cannot be found') }}</h2>
9
+ <router-link
10
+ class="btn btn-primary"
11
+ :to="{
12
+ name: 'home',
13
+ query: { productor: $store.state.filter.organisationId,
14
+ iabId:$store.state.filter.iab?.id,
15
+ rubriquesId: rubriqueQueryParam},
16
+ }"
17
+ >
18
+ {{ $t('Back to home') }}
19
+ </router-link>
20
+ </div>
21
+ </div>
22
+ </template>
23
+
24
+ <script lang="ts">
25
+ import { RubriquageFilter } from '@/store/class/rubrique/rubriquageFilter';
26
+ import { defineComponent } from 'vue';
27
+ export default defineComponent({
28
+ name: 'PageNotFound',
29
+ computed:{
30
+ rubriqueQueryParam(): string|undefined{
31
+ if(this.$store.state.filter?.rubriqueFilter?.length){
32
+ return this.$store.state.filter.rubriqueFilter.map((value: RubriquageFilter) => value.rubriquageId+':'+value.rubriqueId).join();
33
+ }
34
+ return undefined;
35
+ },
36
+ backgroundStyle():string{
37
+ return "background-image: url('/img/404.svg');";
38
+ },
39
+ },
40
+ mounted() {
41
+ document.title = this.$store.state.general.metaTitle;
42
+ },
43
+ });
44
+ </script>
45
+ <style lang="scss">
46
+ .octopus-app .page-not-found{
47
+ background-size: cover;
48
+ background-position: center;
49
+ background-color: #ebebeb;
50
+ display: flex;
51
+ flex-direction: column;
52
+ align-items: center;
53
+ padding: 0;
54
+ }
55
+ </style>