@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
@@ -1,365 +1,72 @@
1
1
  <template>
2
- <div
3
- class="d-flex flex-column p-3 list-episode"
4
- v-if="loading || (!loading && 0 !== allPodcasts.length)"
5
- >
6
- <h2>{{ title }}</h2>
7
- <div class="d-flex justify-content-between">
8
- <div class="d-flex" v-if="undefined === requirePopularSort">
9
- <button
10
- class="btn btn-underline"
11
- @click="sortPopular()"
12
- :class="{ active: popularSort }"
13
- >
14
- {{ $t('Most popular') }}
15
- </button>
16
- <button
17
- class="btn btn-underline"
18
- @click="sortChrono()"
19
- :class="{ active: !popularSort }"
20
- >
21
- {{ $t('Last added') }}
22
- </button>
23
- </div>
24
- <div v-else></div>
25
- <div class="hide-phone" v-if="!isArrow">
26
- <button
27
- class="btn btn-arrow"
28
- @click="displayPrevious()"
29
- :class="{ disabled: !previousAvailable }"
30
- :aria-label="$t('Display previous')"
31
- >
32
- <div class="saooti-arrow-left2"></div>
33
- </button>
34
- <button
35
- class="btn btn-arrow"
36
- @click="displayNext()"
37
- :class="{ disabled: !nextAvailable }"
38
- :aria-label="$t('Display next')"
39
- >
40
- <div class="saooti-arrow-right2"></div>
41
- </button>
42
- </div>
43
- </div>
44
- <div class="d-flex justify-content-center" v-if="loading">
45
- <div class="spinner-border mr-3"></div>
46
- <h3 class="mt-2">{{ $t('Loading podcasts ...') }}</h3>
47
- </div>
48
- <transition-group
49
- :name="transitionName"
50
- class="podcast-list-inline"
51
- tag="ul"
52
- v-show="loaded"
53
- :class="[alignLeft ? 'justify-content-start' : '']"
54
- >
55
- <PodcastItem
56
- class="flex-shrink item-phone-margin"
57
- v-bind:podcast="p"
58
- v-for="p in podcasts"
59
- v-bind:key="p.podcastId"
60
- :class="[alignLeft ? 'mr-3' : '']"
61
- />
62
- </transition-group>
63
- <router-link
64
- class="btn btn-link"
65
- :class="buttonPlus ? 'btn-linkPlus' : ''"
66
- :to="refTo"
67
- >{{ buttonText }}
68
- <div class="saooti-plus" v-if="buttonPlus"></div
69
- ></router-link>
70
- </div>
2
+ <PodcastInlineListClassic
3
+ v-if="listTypeClassic"
4
+ :organisation-id="organisationId"
5
+ :emission-id="emissionId"
6
+ :iab-id="iabId"
7
+ :title="title"
8
+ :href="href"
9
+ :button-text="buttonText"
10
+ :is-arrow="isArrow"
11
+ :require-popular-sort="requirePopularSort"
12
+ :button-plus="buttonPlus"
13
+ :rubrique-id="rubriqueId"
14
+ :rubriquage-id="rubriquageId"
15
+ :no-rubriquage-id="noRubriquageId"
16
+ :query="query"
17
+ @update:isArrow="$emit('update:isArrow',$event)"
18
+ />
19
+ <PodcastSwiperList
20
+ v-else
21
+ :organisation-id="organisationId"
22
+ :emission-id="emissionId"
23
+ :iab-id="iabId"
24
+ :title="title"
25
+ :href="href"
26
+ :button-text="buttonText"
27
+ :is-arrow="isArrow"
28
+ :require-popular-sort="requirePopularSort"
29
+ :button-plus="buttonPlus"
30
+ :rubrique-id="rubriqueId"
31
+ :rubriquage-id="rubriquageId"
32
+ :no-rubriquage-id="noRubriquageId"
33
+ :query="query"
34
+ @update:isArrow="$emit('update:isArrow',$event)"
35
+ />
71
36
  </template>
72
37
 
73
- <style lang="scss">
74
- .list-episode {
75
- padding: 2rem 0rem 1rem !important;
76
- @media (max-width: 450px) {
77
- padding: 0.5rem 0rem 1rem !important;
78
- }
79
- h2 {
80
- margin-bottom: 1rem;
81
- }
82
- }
83
-
84
- .podcast-list-inline {
85
- align-self: stretch;
86
- flex-grow: 1;
87
- margin: 0;
88
- padding: 0;
89
- display: flex;
90
- flex-wrap: nowrap;
91
- justify-content: space-between;
92
- display: grid;
93
- grid-auto-flow: column;
94
- grid-gap: 1rem;
95
- grid-row: 1;
96
- }
97
- .out-left-enter-active,
98
- .out-left-leave-active,
99
- .out-right-enter-active,
100
- .out-right-leave-active {
101
- transition: all 0.3s ease;
102
- }
103
-
104
- .out-left-leave-to,
105
- .out-right-enter {
106
- transform: translateX(-110%);
107
- opacity: 0;
108
- }
109
-
110
- .out-left-enter,
111
- .out-right-leave-to {
112
- transform: translateX(110%);
113
- opacity: 0;
114
- }
115
-
116
- .out-left-leave-to,
117
- .out-right-leave-to {
118
- position: absolute;
119
- }
120
- .out-right-leave-to {
121
- right: 5rem;
122
- z-index: -1;
123
- }
124
- /** PHONES*/
125
- @media (max-width: 960px) {
126
- .podcast-list-inline {
127
- display: flex;
128
- flex-wrap: nowrap;
129
- overflow-y: scroll;
130
- -webkit-overflow-scrolling: touch;
131
- scroll-behavior: smooth;
132
- padding-bottom: 1rem;
133
- width: 100%;
134
- .item-phone-margin {
135
- margin: 0 0.5rem !important;
136
- }
137
- }
138
- }
139
- </style>
140
-
141
38
  <script lang="ts">
142
- const octopusApi = require('@saooti/octopus-api');
143
- import domHelper from '../../../helper/dom';
144
- import PodcastItem from './PodcastItem.vue';
145
-
146
- const PHONE_WIDTH = 960;
147
-
148
- import { defineComponent } from 'vue'
39
+ import { state } from '../../../store/paramStore';
40
+ import { defineAsyncComponent, defineComponent } from 'vue';
41
+ const PodcastInlineListClassic = defineAsyncComponent(() => import('./PodcastInlineListClassic.vue'));
42
+ const PodcastSwiperList = defineAsyncComponent(() => import('./PodcastSwiperList.vue'));
149
43
  export default defineComponent({
150
44
  name: 'PodcastInlineList',
151
-
152
- props: [
153
- 'organisationId',
154
- 'emissionId',
155
- 'iabId',
156
- 'title',
157
- 'href',
158
- 'buttonText',
159
- 'requirePopularSort',
160
- 'isArrow',
161
- 'buttonPlus',
162
- 'rubriqueId',
163
- 'rubriquageId',
164
- ],
165
- emits: ['update:isArrow'],
166
-
45
+
167
46
  components: {
168
- PodcastItem,
169
- },
170
-
171
- created() {
172
- if (undefined !== this.requirePopularSort) {
173
- this.popularSort = this.requirePopularSort;
174
- }
175
- if (undefined !== this.isArrow) {
176
- this.$emit('update:isArrow', true)
177
- }
178
- window.addEventListener('resize', this.handleResize);
179
- },
180
-
181
- unmounted() {
182
- window.removeEventListener('resize', this.handleResize);
183
- },
184
-
185
- mounted() {
186
- this.handleResize();
187
- this.fetchNext();
188
- },
189
-
190
- data() {
191
- return {
192
- loading: true,
193
- loaded: true,
194
- index: 0,
195
- first: 0,
196
- size: 5,
197
- totalCount: 0,
198
- popularSort: true,
199
- allPodcasts: [] as any,
200
- direction: 1,
201
- alignLeft: false,
202
- };
203
- },
204
-
205
- computed: {
206
- podcasts():any {
207
- return this.allPodcasts.slice(this.index, this.index + this.size);
208
- },
209
- filterOrga():any {
210
- return this.$store.state.filter.organisationId;
211
- },
212
- organisation():any {
213
- if (this.organisationId) return this.organisationId;
214
- if (this.filterOrga) return this.filterOrga;
215
- return undefined;
216
- },
217
- refTo():any {
218
- if (this.href) return this.href;
219
- return {
220
- name: 'category',
221
- params: { iabId: this.iabId },
222
- query: { productor: this.$store.state.filter.organisationId },
223
- };
224
- },
225
- previousAvailable():boolean {
226
- return this.index > 0;
227
- },
228
- nextAvailable():boolean {
229
- return this.index + this.size < this.totalCount;
230
- },
231
- transitionName: ({ direction }:any) =>
232
- direction > 0 ? 'out-left' : 'out-right',
47
+ PodcastInlineListClassic,
48
+ PodcastSwiperList,
233
49
  },
234
-
235
- methods: {
236
- async fetchNext() {
237
- const data = await octopusApi.fetchPodcasts({
238
- first: this.first,
239
- size: this.size + 1,
240
- organisationId: this.organisation,
241
- emissionId: this.emissionId,
242
- iabId: this.iabId,
243
- rubriqueId: this.rubriqueId,
244
- rubriquageId: this.rubriquageId,
245
- sort: this.popularSort ? 'POPULARITY' : 'DATE',
246
- });
247
- this.loading = false;
248
- this.loaded = true;
249
- this.totalCount = data.count;
250
- if (this.allPodcasts.length + data.result.length < this.totalCount) {
251
- let nexEl = data.result.pop();
252
- this.preloadImage(nexEl.imageUrl);
253
- }
254
- this.allPodcasts = this.allPodcasts.concat(
255
- data.result.filter((pod:any) => null !== pod)
256
- );
257
- if (this.allPodcasts.length <= 3) {
258
- this.alignLeft = true;
259
- } else {
260
- this.alignLeft = false;
261
- }
262
- this.first += this.size;
263
- },
264
-
265
- displayPrevious() {
266
- this.direction = -1;
267
- if (this.previousAvailable) {
268
- this.index -= 1;
269
- }
270
- },
271
-
272
- displayNext() {
273
- this.direction = 1;
274
- if (!this.nextAvailable) return;
275
- if (
276
- this.first - (this.index + this.size) < 2 &&
277
- this.allPodcasts.length < this.totalCount
278
- ) {
279
- this.fetchNext();
280
- }
281
- this.index += 1;
282
- },
283
-
284
- handleResize() {
285
- if (!this.$el) return;
286
- if (window.innerWidth <= PHONE_WIDTH) {
287
- this.size = 10;
288
- return;
289
- }
290
- const width = this.$el.offsetWidth;
291
- const sixteen = domHelper.convertRemToPixels(13.7);
292
- this.size = Math.floor(width / sixteen);
293
- },
294
-
295
- sortPopular() {
296
- if (this.popularSort) return;
297
-
298
- this.popularSort = true;
299
- this.reset();
300
- this.fetchNext();
301
- },
302
-
303
- sortChrono() {
304
- if (!this.popularSort) return;
305
-
306
- this.popularSort = false;
307
- this.reset();
308
- this.fetchNext();
309
- },
310
-
311
- reset() {
312
- this.loading = true;
313
- this.loaded = true;
314
- this.index = 0;
315
- this.first = 0;
316
- this.totalCount = 0;
317
- this.allPodcasts.length = 0;
318
- },
319
-
320
- preloadImage(url:string) {
321
- let img = new Image();
322
- img.src = url;
323
- },
50
+ props: {
51
+ organisationId: { default: undefined, type: String},
52
+ emissionId: { default: undefined, type: Number},
53
+ iabId: { default: undefined, type: Number},
54
+ title: { default: '', type: String},
55
+ href: { default: undefined, type: String},
56
+ buttonText: { default: undefined, type: String},
57
+ isArrow: { default: false, type: Boolean},
58
+ requirePopularSort: { default:undefined, type: Boolean},
59
+ buttonPlus: { default:false, type: Boolean},
60
+ rubriqueId: { default: () => [], type: Array as ()=> Array<number> },
61
+ rubriquageId:{ default: () => [], type: Array as ()=> Array<number> },
62
+ noRubriquageId: { default: () => [], type: Array as ()=> Array<number> },
63
+ query: { default: undefined, type: String},
324
64
  },
325
-
326
- watch: {
327
- emissionId: {
328
- handler() {
329
- this.reset();
330
- this.fetchNext();
331
- },
332
- },
333
- organisationId: {
334
- handler() {
335
- this.reset();
336
- this.fetchNext();
337
- },
338
- },
339
- filterOrga: {
340
- handler() {
341
- this.reset();
342
- this.fetchNext();
343
- },
344
- },
345
- iabId: {
346
- handler() {
347
- this.reset();
348
- this.fetchNext();
349
- },
350
- },
351
- rubriqueId: {
352
- handler() {
353
- this.reset();
354
- this.fetchNext();
355
- },
356
- },
357
- rubriquageId: {
358
- handler() {
359
- this.reset();
360
- this.fetchNext();
361
- },
65
+ emits: ['update:isArrow'],
66
+ computed:{
67
+ listTypeClassic(): boolean {
68
+ return (state.podcastPage.listTypeClassic as boolean);
362
69
  },
363
- },
364
- });
365
- </script>
70
+ }
71
+ })
72
+ </script>
@@ -0,0 +1,240 @@
1
+ <template>
2
+ <PodcastInlineListTemplate
3
+ v-if="loading || (!loading && 0 !== allPodcasts.length)"
4
+ :display-arrow="true"
5
+ :popular-sort="popularSort"
6
+ :button-text="buttonText"
7
+ :button-plus="buttonPlus"
8
+ :title="title"
9
+ :href="href"
10
+ :iab-id="iabId"
11
+ :rubrique-id="rubriqueId"
12
+ :previous-available="previousAvailable"
13
+ :next-available="nextAvailable"
14
+ :no-rubriquage-id="noRubriquageId"
15
+ @sortChrono="sortChrono"
16
+ @sortPopular="sortPopular"
17
+ @displayPrevious="displayPrevious"
18
+ @displayNext="displayNext"
19
+ >
20
+ <template #list-inline>
21
+ <ClassicLoading
22
+ :loading-text="loading?$t('Loading podcasts ...'):undefined"
23
+ />
24
+ <transition-group
25
+ v-show="loaded"
26
+ :name="transitionName"
27
+ class="element-list-inline"
28
+ tag="ul"
29
+ :class="[
30
+ alignLeft ? 'justify-content-start' : '',
31
+ overflowScroll ? 'overflowScroll' : '',
32
+ ]"
33
+ :css="isInlineAnimation"
34
+ >
35
+ <PodcastItem
36
+ v-for="p in podcasts"
37
+ :key="p.podcastId"
38
+ class="flex-shrink-0 item-phone-margin"
39
+ :podcast="p"
40
+ :class="[alignLeft ? 'me-3' : '']"
41
+ />
42
+ </transition-group>
43
+ </template>
44
+ </PodcastInlineListTemplate>
45
+ </template>
46
+
47
+ <script lang="ts">
48
+ import PodcastInlineListTemplate from './PodcastInlineListTemplate.vue';
49
+ import octopusApi from '@saooti/octopus-api';
50
+ import domHelper from '../../../helper/dom';
51
+ import PodcastItem from './PodcastItem.vue';
52
+ import ClassicLoading from '../../form/ClassicLoading.vue';
53
+ const PHONE_WIDTH = 960;
54
+ import { state } from '../../../store/paramStore';
55
+ import { Podcast } from '@/store/class/general/podcast';
56
+ import { defineComponent } from 'vue'
57
+ export default defineComponent({
58
+ name: 'PodcastInlineListClassic',
59
+
60
+ components: {
61
+ PodcastItem,
62
+ ClassicLoading,
63
+ PodcastInlineListTemplate
64
+ },
65
+
66
+ props: {
67
+ organisationId: { default: undefined, type: String},
68
+ emissionId: { default: undefined, type: Number},
69
+ iabId: { default: undefined, type: Number},
70
+ title: { default: '', type: String},
71
+ href: { default: undefined, type: String},
72
+ buttonText: { default: undefined, type: String},
73
+ isArrow: { default: false, type: Boolean},
74
+ requirePopularSort: { default:undefined, type: Boolean},
75
+ buttonPlus: { default:false, type: Boolean},
76
+ rubriqueId: { default: () => [], type: Array as ()=> Array<number> },
77
+ rubriquageId:{ default: () => [], type: Array as ()=> Array<number> },
78
+ noRubriquageId: { default: () => [], type: Array as ()=> Array<number> },
79
+ query: { default: undefined, type: String},
80
+ },
81
+ emits: ['update:isArrow'],
82
+
83
+ data() {
84
+ return {
85
+ loading: true as boolean,
86
+ loaded: true as boolean,
87
+ index: 0 as number,
88
+ first: 0 as number,
89
+ size: 5 as number,
90
+ totalCount: 0 as number,
91
+ popularSort: false as boolean,
92
+ allPodcasts: [] as Array<Podcast>,
93
+ direction: 1 as number,
94
+ alignLeft: false as boolean,
95
+ };
96
+ },
97
+ computed: {
98
+ podcasts(): Array<Podcast> {
99
+ return this.allPodcasts.slice(this.index, this.index + this.size);
100
+ },
101
+ sizeItem(): number {
102
+ return state.generalParameters.podcastItem ? (state.generalParameters.podcastItem as number): 13;
103
+ },
104
+ overflowScroll(): boolean {
105
+ return (state.emissionPage.overflowScroll as boolean);
106
+ },
107
+ isInlineAnimation(): boolean {
108
+ return (state.generalParameters.isInlineAnimation as boolean);
109
+ },
110
+ filterOrga(): string {
111
+ return this.$store.state.filter.organisationId;
112
+ },
113
+ organisation(): string|undefined {
114
+ return this.organisationId ?? this.filterOrga;
115
+ },
116
+ previousAvailable(): boolean {
117
+ return this.index > 0;
118
+ },
119
+ nextAvailable(): boolean {
120
+ return this.index + this.size < this.totalCount;
121
+ },
122
+ transitionName(): string {
123
+ return this.direction > 0 ? 'out-left' : 'out-right';
124
+ },
125
+ watchVariable():string{
126
+ return `${this.emissionId}|${this.organisationId}|${this.filterOrga}|${this.iabId}|${this.rubriqueId}|${this.rubriquageId}|${this.query}`;
127
+ }
128
+ },
129
+ watch: {
130
+ watchVariable(): void {
131
+ this.reset();
132
+ this.fetchNext();
133
+ },
134
+ },
135
+
136
+ created() {
137
+ if (undefined !== this.requirePopularSort) {
138
+ this.popularSort = this.requirePopularSort;
139
+ }
140
+ if (undefined !== this.isArrow) {
141
+ this.$emit('update:isArrow', true);
142
+ }
143
+ window.addEventListener('resize', this.handleResize);
144
+ },
145
+
146
+ unmounted() {
147
+ window.removeEventListener('resize', this.handleResize);
148
+ },
149
+
150
+ mounted() {
151
+ this.handleResize();
152
+ this.fetchNext();
153
+ },
154
+ methods: {
155
+ async fetchNext(): Promise<void> {
156
+ const data = await octopusApi.fetchDataWithParams<{count: number;result:Array<Podcast>;sort: string;}>(0, 'podcast/search',{
157
+ first: this.first,
158
+ size: this.size + 1,
159
+ organisationId: this.organisation,
160
+ emissionId: this.emissionId,
161
+ iabId: this.iabId,
162
+ rubriqueId: this.rubriqueId.length ?this.rubriqueId:undefined,
163
+ rubriquageId: this.rubriquageId.length ?this.rubriquageId : undefined,
164
+ noRubriquageId: this.noRubriquageId.length ? this.noRubriquageId : undefined,
165
+ sort: this.popularSort ? 'POPULARITY' : 'DATE',
166
+ query: this.query,
167
+ }, true);
168
+ this.loading = false;
169
+ this.loaded = true;
170
+ this.totalCount = data.count;
171
+ if (this.allPodcasts.length + data.result.length < this.totalCount) {
172
+ const nexEl = data.result.pop() as Podcast;
173
+ if(nexEl){
174
+ this.preloadImage(nexEl.imageUrl?nexEl.imageUrl:'');
175
+ }
176
+ }
177
+ this.allPodcasts = this.allPodcasts.concat(
178
+ data.result.filter((pod: Podcast|null) => null !== pod)
179
+ );
180
+ this.alignLeft = this.allPodcasts.length <= 3;
181
+ this.first += this.size;
182
+ },
183
+ displayPrevious(): void {
184
+ this.direction = -1;
185
+ if (this.previousAvailable) {
186
+ this.index -= 1;
187
+ }
188
+ },
189
+ displayNext(): void {
190
+ this.direction = 1;
191
+ if (!this.nextAvailable) return;
192
+ if (
193
+ this.first - (this.index + this.size) < 2 &&
194
+ this.allPodcasts.length < this.totalCount
195
+ ) {
196
+ this.fetchNext();
197
+ }
198
+ this.index += 1;
199
+ },
200
+ handleResize(): void {
201
+ if (!this.$el) return;
202
+ if (this.overflowScroll) {
203
+ this.size = 20;
204
+ return;
205
+ }
206
+ if (window.innerWidth <= PHONE_WIDTH) {
207
+ this.size = 10;
208
+ return;
209
+ }
210
+ const width = (this.$el as HTMLElement).offsetWidth;
211
+ const sixteen = domHelper.convertRemToPixels(this.sizeItem + 0.7);
212
+ this.size = Math.floor(width / sixteen);
213
+ },
214
+ sortPopular(): void {
215
+ if (this.popularSort) return;
216
+ this.popularSort = true;
217
+ this.reset();
218
+ this.fetchNext();
219
+ },
220
+ sortChrono(): void {
221
+ if (!this.popularSort) return;
222
+ this.popularSort = false;
223
+ this.reset();
224
+ this.fetchNext();
225
+ },
226
+ reset(): void {
227
+ this.loading = true;
228
+ this.loaded = true;
229
+ this.index = 0;
230
+ this.first = 0;
231
+ this.totalCount = 0;
232
+ this.allPodcasts.length = 0;
233
+ },
234
+ preloadImage(url: string): void {
235
+ const img = new Image();
236
+ img.src = url;
237
+ },
238
+ },
239
+ })
240
+ </script>