@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,78 @@
1
+ <template>
2
+ <div class="d-flex justify-content-around mt-3 w-100">
3
+ <div class="d-flex flex-column align-items-center flex-shrink-0 me-3">
4
+ <div>{{ $t('Choose color') }}</div>
5
+ <VSwatches
6
+ v-model="internColor"
7
+ class="c-hand "
8
+ show-fallback
9
+ colors="text-advanced"
10
+ popover-to="right"
11
+ :data-color="internColor"
12
+ />
13
+ </div>
14
+ <div class="d-flex flex-column align-items-center">
15
+ <div>{{ $t('Choose theme') }}</div>
16
+ <VSwatches
17
+ v-model="internTheme"
18
+ class="c-hand "
19
+ show-fallback
20
+ colors="text-advanced"
21
+ popover-to="right"
22
+ :data-color="internTheme"
23
+ />
24
+ </div>
25
+ </div>
26
+ </template>
27
+
28
+ <script lang="ts">
29
+ // @ts-ignore
30
+ import VSwatches from 'vue3-swatches';
31
+ import { defineComponent } from 'vue';
32
+ export default defineComponent({
33
+ components: {
34
+ VSwatches
35
+ },
36
+
37
+ props: {
38
+ color: { default: '#40a372', type: String},
39
+ theme: { default: '#000000', type: String},
40
+ },
41
+ emits:['update:color', 'update:theme'],
42
+
43
+ data() {
44
+ return {
45
+ internColor:'#40a372' as string,
46
+ internTheme:'#000000' as string,
47
+ };
48
+ },
49
+ watch:{
50
+ internColor(){
51
+ if(this.color !== this.internColor){
52
+ this.$emit('update:color', this.internColor);
53
+ }
54
+ },
55
+ internTheme(){
56
+ if(this.theme !== this.internTheme ){
57
+ this.$emit('update:theme', this.internTheme);
58
+ }
59
+ },
60
+ theme: {
61
+ immediate: true,
62
+ handler() {
63
+ if(this.theme !== this.internTheme){
64
+ this.internTheme = this.theme;
65
+ }
66
+ },
67
+ },
68
+ color: {
69
+ immediate: true,
70
+ handler() {
71
+ if(this.color !== this.internColor){
72
+ this.internColor = this.color;
73
+ }
74
+ },
75
+ },
76
+ },
77
+ })
78
+ </script>
@@ -0,0 +1,112 @@
1
+ <template>
2
+ <div class="d-flex flex-column">
3
+ <label
4
+ for="iframe-select"
5
+ title="select miniplayer"
6
+ />
7
+ <select
8
+ id="iframe-select"
9
+ :value="iFrameModel"
10
+ class=""
11
+ @change="$emit('update:iFrameModel',$event.target.value)"
12
+ >
13
+ <template
14
+ v-for="option in optionsSelect"
15
+ :key="option.value"
16
+ >
17
+ <option
18
+ v-if="option.condition"
19
+ :value="option.value"
20
+ >
21
+ {{ option.name }}
22
+ </option>
23
+ </template>
24
+ <option
25
+ v-for="player in customPlayersDisplay"
26
+ :key="player.customId"
27
+ :value="player.customId"
28
+ >
29
+ {{ $t('Custom version') + " «" +player.name+"»" }}
30
+ </option>
31
+ </select>
32
+ </div>
33
+ </template>
34
+
35
+ <script lang="ts">
36
+ import { state } from '../../../store/paramStore';
37
+ import octopusApi from '@saooti/octopus-api';
38
+ import { Podcast } from '@/store/class/general/podcast';
39
+ import { CustomPlayer } from '@/store/class/general/customPlayer';
40
+ import { defineComponent } from 'vue';
41
+ import { Emission } from '@/store/class/general/emission';
42
+ import { Playlist } from '@/store/class/general/playlist';
43
+ import { InterfacePageable } from '@/store/class/general/interfacePageable';
44
+ export default defineComponent({
45
+ props: {
46
+ podcast: { default: undefined, type: Object as ()=> Podcast},
47
+ emission: { default: undefined, type: Object as ()=> Emission},
48
+ playlist: { default: undefined, type: Object as ()=> Playlist},
49
+ iFrameModel: { default: 'default', type: String},
50
+ organisationId: { default: undefined, type: String},
51
+ },
52
+ emits:['update:iFrameModel'],
53
+
54
+ data() {
55
+ return {
56
+ customPlayers: [] as Array<CustomPlayer>,
57
+ };
58
+ },
59
+ computed: {
60
+ optionsSelect(){
61
+ return [
62
+ {name: this.$t('Default version'), value: 'default', condition: true},
63
+ {name: this.$t('Large version'), value: 'large', condition: true},
64
+ {name: this.$t('Emission version'), value: 'emission', condition: this.podcast && this.podcast.podcastId},
65
+ {name: this.$t('Large emission version'), value: 'emissionLarge', condition: this.podcast && this.podcast.podcastId},
66
+ {name: this.$t('Large suggestion version'), value: 'largeSuggestion', condition: this.podcast && this.podcast.podcastId}
67
+ ]
68
+ },
69
+ customPlayersDisplay(): Array<CustomPlayer>{
70
+ return this.customPlayers.filter((player: CustomPlayer)=>{
71
+ return (('EPISODE' === player.typePlayer ||'SUGGESTION' === player.typePlayer) &&this.podcast?.podcastId) ||
72
+ ('EMISSION' === player.typePlayer && this.emission && !this.podcast)|| ('PLAYLIST' === player.typePlayer && this.playlist );
73
+ });
74
+ },
75
+ },
76
+ async created() {
77
+ await this.initCustomPlayers();
78
+ },
79
+ methods: {
80
+ async fetchCustomPlayers(type:string, trySelect: boolean): Promise<boolean>{
81
+ let players = await octopusApi.fetchDataPublic<InterfacePageable<CustomPlayer>>(6,'customPlayer/type/'+ this.organisationId+'/'+type);
82
+ let playersContent = players.content;
83
+ const totalCount = players.totalElements;
84
+ let index = 1;
85
+ while (totalCount > playersContent.length) {
86
+ players = await octopusApi.fetchDataPublic<InterfacePageable<CustomPlayer>>(6,'customPlayer/type/'+ this.organisationId+'/'+type+'?start='+index);
87
+ playersContent = playersContent.concat(players.content);
88
+ ++index;
89
+ }
90
+ this.customPlayers = this.customPlayers.concat(playersContent);
91
+ if(trySelect && this.customPlayers[0] && this.customPlayers[0].selected){
92
+ this.$emit('update:iFrameModel',this.customPlayers[0].customId.toString());
93
+ return false;
94
+ }
95
+ return true;
96
+ },
97
+ async initCustomPlayers(): Promise<void> {
98
+ if (!state.generalParameters.authenticated) return;
99
+ if(this.playlist){
100
+ this.fetchCustomPlayers('PLAYLIST', true);
101
+ }else if(this.emission && !this.podcast){
102
+ this.fetchCustomPlayers('EMISSION', true);
103
+ }else{
104
+ let playerTrySelect = true;
105
+ playerTrySelect = await this.fetchCustomPlayers('EPISODE', playerTrySelect);
106
+ playerTrySelect = await this.fetchCustomPlayers('EMISSION', playerTrySelect);
107
+ playerTrySelect = await this.fetchCustomPlayers('SUGGESTION', playerTrySelect);
108
+ }
109
+ },
110
+ }
111
+ })
112
+ </script>
@@ -0,0 +1,42 @@
1
+ <template>
2
+ <div
3
+ class="btn-split"
4
+ @mouseleave="mobileHoverEffect=false"
5
+ >
6
+ <div class="d-flex flex-wrap">
7
+ <slot name="inside-button" />
8
+ </div>
9
+ <div class="label">
10
+ {{ title }}
11
+ </div>
12
+ </div>
13
+ </template>
14
+
15
+ <script lang="ts">
16
+ import { defineComponent } from 'vue';
17
+ export default defineComponent({
18
+ props: {
19
+ title: { default: '', type:String},
20
+ },
21
+
22
+ data() {
23
+ return {
24
+ mobileHoverEffect:false as boolean,
25
+ };
26
+ },
27
+ computed:{
28
+ isMobile(): boolean {
29
+ return window.matchMedia('(hover: none)').matches;
30
+ },
31
+ },
32
+
33
+ methods: {
34
+ linkClick(event: { preventDefault: () => void; }){
35
+ if(this.isMobile && !this.mobileHoverEffect){
36
+ this.mobileHoverEffect = true;
37
+ event.preventDefault();
38
+ }
39
+ },
40
+ },
41
+ })
42
+ </script>
@@ -1,137 +1,84 @@
1
1
  <template>
2
- <div class="module-box flex-no-grow">
3
- <div class="d-flex align-items-center mb-3">
4
- <h3 class="mb-0 share-button-title">{{ $t('Subscribe emission') }}</h3>
5
- </div>
6
- <div class="d-flex">
2
+ <div class="module-box flex-grow-0">
3
+ <h3 class="mb-2 height-40">
4
+ {{ $t('Subscribe emission') }}
5
+ </h3>
6
+ <template
7
+ v-for="(sub, index) in subscriptionsDisplay"
8
+ :key="sub.name"
9
+ >
7
10
  <a
11
+ rel="noopener"
8
12
  target="_blank"
9
- class="btn mr-3 mb-2 share-btn"
10
- :href="applePodcast"
11
- v-if="applePodcast"
12
- aria-label="Apple"
13
+ :class="[
14
+ 0 === index? 'first': '',
15
+ subscriptionsDisplay.length-1 === index? 'last': '',
16
+ ]"
17
+ class="btn share-btn mb-2 mx-2"
18
+ :href="sub.url"
19
+ :title="sub.name"
13
20
  >
14
- <span class="saooti-apple"></span>
21
+ <span :class="sub.icon">
22
+ <div
23
+ v-for="indexPath in getPathNumber(sub.name)"
24
+ :key="indexPath"
25
+ :class="'path'+(indexPath+1)"
26
+ />
27
+ </span>
15
28
  </a>
16
- <a
17
- target="_blank"
18
- class="btn mr-3 mb-2 share-btn"
19
- :href="deezer"
20
- v-if="deezer"
21
- aria-label="Deezer"
22
- >
23
- <span class="saooti-deezer"></span>
24
- </a>
25
- <a
26
- target="_blank"
27
- class="btn mr-3 mb-2 share-btn"
28
- :href="spotify"
29
- v-if="spotify"
30
- aria-label="Spotify"
31
- >
32
- <span class="saooti-spotify"></span>
33
- </a>
34
- <a
35
- target="_blank"
36
- class="btn mr-3 mb-2 share-btn"
37
- :href="tunein"
38
- v-if="tunein"
39
- aria-label="Tunin"
40
- >
41
- <span class="saooti-tunin"></span>
42
- </a>
43
- <a
44
- target="_blank"
45
- class="btn mr-3 mb-2 btn-tootak share-btn"
46
- :href="tootak"
47
- v-if="tootak"
48
- aria-label="Tootak"
49
- >
50
- <span class="saooti-tootak"></span>
51
- </a>
52
- <a
53
- target="_blank"
54
- class="btn mr-3 mb-2 btn-radioline share-btn"
55
- :href="radioline"
56
- v-if="radioline"
57
- aria-label="Radioline"
58
- >
59
- <span class="saooti-radioline"></span>
60
- </a>
61
- </div>
29
+ </template>
62
30
  </div>
63
31
  </template>
64
32
 
65
- <style lang="scss">
66
- .saooti-tunin {
67
- color: #36b4a7;
68
- }
69
- .saooti-radioline {
70
- color: #2273b9;
71
- }
72
- .saooti-tootak {
73
- color: #ff4d53;
74
- }
75
- .flex-no-grow {
76
- flex-grow: 0 !important;
77
- }
78
- </style>
79
-
80
33
  <script lang="ts">
81
- import { defineComponent } from 'vue'
34
+ import { Emission } from '@/store/class/general/emission';
35
+ import { defineComponent } from 'vue';
82
36
  export default defineComponent({
83
- props: ['podcastId', 'emission'],
84
-
85
- components: {},
86
-
87
- mounted() {
88
- this.applePodcast = this.externaliseLinks(this.applePodcast);
89
- this.deezer = this.externaliseLinks(this.deezer);
90
- this.spotify = this.externaliseLinks(this.spotify);
91
- this.tunein = this.externaliseLinks(this.tunein);
92
- this.tootak = this.externaliseLinks(this.tootak);
93
- this.radioline = this.externaliseLinks(this.radioline);
37
+ props: {
38
+ emission: { default: undefined, type: Object as ()=> Emission},
39
+ podcastId: { default: undefined, type: Number},
94
40
  },
95
-
96
- data() {
97
- return {
98
- applePodcast:
99
- this.emission && this.emission.annotations
100
- ? this.emission.annotations.applePodcast
101
- : undefined as any,
102
- deezer:
103
- this.emission && this.emission.annotations
104
- ? this.emission.annotations.deezer
105
- : undefined as any,
106
- spotify:
107
- this.emission && this.emission.annotations
108
- ? this.emission.annotations.spotify
109
- : undefined as any,
110
- tunein:
111
- this.emission && this.emission.annotations
112
- ? this.emission.annotations.tunein
113
- : undefined as any,
114
- tootak:
115
- this.emission && this.emission.annotations
116
- ? this.emission.annotations.tootak
117
- : undefined as any,
118
- radioline:
119
- this.emission && this.emission.annotations
120
- ? this.emission.annotations.radioline
121
- : undefined as any,
122
- };
41
+ computed:{
42
+ subscriptionsDisplay(){
43
+ const sub = [
44
+ {name : 'amazon', icon : 'saooti-amazon', url : this.getUrl('amazon')},
45
+ {name:'applePodcast', icon:'saooti-apple', url : this.getUrl('applePodcast')},
46
+ {name:'deezer', icon:'saooti-deezer', url : this.getUrl('deezer')},
47
+ {name:'googlePodcasts', icon:"saooti-google-podcasts", url : this.getUrl('googlePodcasts')},
48
+ {name:'playerFm', icon: 'saooti-playerfm', url : this.getUrl('playerFm')},
49
+ {name:'pocketCasts', icon:'saooti-pocket-casts', url : this.getUrl('pocketCasts')},
50
+ {name:'podcastAddict', icon: 'saooti-podcast-addict', url : this.getUrl('podcastAddict')},
51
+ {name:'radioline', icon:'saooti-radioline', url : this.getUrl('radioline')},
52
+ {name:'spotify', icon:'saooti-spotify', url : this.getUrl('spotify')},
53
+ {name:'stitcher', icon:'saooti-stitcher-logo', url : this.getUrl('stitcher')},
54
+ {name:'tunein', icon:'saooti-tunin', url : this.getUrl('tunein')}
55
+ ];
56
+ return sub.filter(item=> item.url);
57
+ }
123
58
  },
124
59
 
125
- computed: {},
126
-
127
60
  methods: {
128
- externaliseLinks(link?: string) {
61
+ getPathNumber(sub: string): number{
62
+ switch (sub) {
63
+ case 'amazon': return 3;
64
+ case 'googlePodcasts': return 7;
65
+ case 'stitcher': return 18;
66
+ default: return 0;
67
+ }
68
+ },
69
+ getUrl(sub: string): string | undefined{
70
+ return this.externaliseLinks(this.emission?.annotations?.[sub] as string|undefined);
71
+ },
72
+ externaliseLinks(link?: string): string|undefined {
129
73
  if (!link) return link;
130
74
  link = link.trim();
131
- if (!link.startsWith('http') && !link.startsWith('//'))
132
- return '//' + link;
133
- return link;
75
+ return !link.startsWith('http') && !link.startsWith('//') ? '//' + link:link;
134
76
  },
135
77
  },
136
- });
78
+ })
137
79
  </script>
80
+ <style lang="scss">
81
+ .height-40{
82
+ height: 40px;
83
+ }
84
+ </style>
@@ -1,10 +1,8 @@
1
1
  <template>
2
- <div></div>
2
+ <div />
3
3
  </template>
4
4
 
5
- <style lang="scss"></style>
6
-
7
5
  <script lang="ts">
8
6
  import { defineComponent } from 'vue'
9
- export default defineComponent({});
10
- </script>
7
+ export default defineComponent({})
8
+ </script>
@@ -0,0 +1,66 @@
1
+ <template>
2
+ <div
3
+ class="form-check"
4
+ :class="isSwitch?'form-switch':''"
5
+ >
6
+ <input
7
+ :id="idCheckbox"
8
+ v-model="textValue"
9
+ type="checkbox"
10
+ class="form-check-input"
11
+ :disabled="isDisabled"
12
+ :title="displayLabel?'':label"
13
+ :data-selenium="selenium"
14
+ @click="emitClickAction"
15
+ >
16
+ <label
17
+ class="form-check-label"
18
+ :class="displayLabel? '': 'd-none'"
19
+ :for="idCheckbox"
20
+ >{{ label }}</label>
21
+ </div>
22
+ </template>
23
+
24
+ <script lang="ts">
25
+ import { defineComponent } from 'vue';
26
+ export default defineComponent({
27
+ name: 'ClassicCheckbox',
28
+
29
+ props: {
30
+ idCheckbox: { default: '', type: String },
31
+ label: { default: '', type: String },
32
+ isDisabled: { default: false, type: Boolean },
33
+ textInit: { default: false, type: Boolean },
34
+ isSwitch:{default:false, type:Boolean},
35
+ displayLabel: {default:true, type: Boolean},
36
+ selenium: { default: '', type: String },
37
+ },
38
+ emits: ['update:textInit', 'clickAction'],
39
+
40
+ data() {
41
+ return {
42
+ textValue: false as boolean,
43
+ };
44
+ },
45
+ watch: {
46
+ textValue(){
47
+ if(this.textInit !== this.textValue){
48
+ this.$emit('update:textInit', this.textValue)
49
+ }
50
+ },
51
+ textInit: {
52
+ immediate: true,
53
+ handler() {
54
+ if(this.textInit !== this.textValue){
55
+ this.textValue =this.textInit;
56
+ }
57
+ },
58
+ },
59
+ },
60
+ methods:{
61
+ emitClickAction():void{
62
+ this.$emit('clickAction');
63
+ }
64
+ }
65
+ });
66
+ </script>
@@ -0,0 +1,28 @@
1
+ <template>
2
+ <div
3
+ v-if="loadingText"
4
+ class="d-flex justify-content-center"
5
+ >
6
+ <div class="spinner-border me-3" />
7
+ <div class="h3 mt-2">
8
+ {{ loadingText }}
9
+ </div>
10
+ </div>
11
+ <div
12
+ v-else-if="errorText"
13
+ class="text-center text-danger"
14
+ >
15
+ <h3>{{ errorText }}</h3>
16
+ </div>
17
+ </template>
18
+
19
+ <script lang="ts">
20
+ import { defineComponent } from 'vue';
21
+ export default defineComponent({
22
+ name: "ClassicLoading",
23
+ props: {
24
+ loadingText: { default: undefined, type: String},
25
+ errorText: { default: undefined, type: String},
26
+ }
27
+ })
28
+ </script>
@@ -0,0 +1,66 @@
1
+ <template>
2
+ <div
3
+ class="d-flex"
4
+ :class="isColumn? 'flex-column':''"
5
+ >
6
+ <div
7
+ v-for="option in options"
8
+ :key="option.title"
9
+ class="form-check"
10
+ :class="isColumn? '':'me-2'"
11
+ >
12
+ <input
13
+ :id="idRadio + option.value"
14
+ v-model="textValue"
15
+ class="form-check-input"
16
+ type="radio"
17
+ :name="idRadio"
18
+ :value="option.value"
19
+ :disabled="isDisabled"
20
+ >
21
+ <label
22
+ class="form-check-label"
23
+ :for="idRadio + option.value"
24
+ >{{
25
+ option.title
26
+ }}</label>
27
+ </div>
28
+ </div>
29
+ </template>
30
+
31
+ <script lang="ts">
32
+ import { defineComponent } from 'vue';
33
+ export default defineComponent({
34
+ name: 'ClassicRadio',
35
+
36
+ props: {
37
+ idRadio: { default: '', type: String },
38
+ isDisabled: { default: false, type: Boolean },
39
+ options: { default: ()=>[], type: Array as () => Array<{title: string, value: string|undefined}> },
40
+ textInit: { default: undefined, type: String },
41
+ isColumn: {default:true, type:Boolean}
42
+ },
43
+ emits: ['update:textInit'],
44
+
45
+ data() {
46
+ return {
47
+ textValue: undefined as string|undefined,
48
+ };
49
+ },
50
+ watch: {
51
+ textValue(){
52
+ if(this.textInit !== this.textValue){
53
+ this.$emit('update:textInit', this.textValue)
54
+ }
55
+ },
56
+ textInit: {
57
+ immediate: true,
58
+ handler() {
59
+ if(this.textInit !== this.textValue){
60
+ this.textValue =this.textInit;
61
+ }
62
+ },
63
+ },
64
+ }
65
+ });
66
+ </script>