@saooti/octopus-sdk 0.28.16 → 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 (328) hide show
  1. package/README.md +188 -2
  2. package/index.ts +45 -11
  3. package/package.json +46 -48
  4. package/public/config.ts +4 -0
  5. package/public/css/fonts/icomoon.eot +0 -0
  6. package/public/css/fonts/icomoon.svg +129 -0
  7. package/public/css/fonts/icomoon.ttf +0 -0
  8. package/public/css/fonts/icomoon.woff +0 -0
  9. package/public/css/fonts/style.css +185 -1266
  10. package/public/img/403.jpeg +0 -0
  11. package/public/img/404.svg +242 -0
  12. package/public/img/ouest_france_logo.svg +12 -0
  13. package/src/App.vue +45 -24
  14. package/src/api/classicCrud.ts +34 -0
  15. package/src/api/initialize.ts +4 -2
  16. package/src/assets/bootstrap-diff.scss +197 -0
  17. package/src/assets/form.scss +77 -77
  18. package/src/assets/general.scss +287 -301
  19. package/src/assets/live.scss +39 -0
  20. package/src/assets/modal.scss +43 -50
  21. package/src/assets/multiselect.scss +522 -590
  22. package/src/assets/octopus-library.scss +17 -4
  23. package/src/assets/share.scss +150 -250
  24. package/src/assets/transition.scss +98 -2
  25. package/src/components/display/aggregator/RssSection.vue +4 -6
  26. package/src/components/display/categories/CategoryChooser.vue +100 -79
  27. package/src/components/display/categories/CategoryFilter.vue +117 -37
  28. package/src/components/display/categories/CategoryList.vue +121 -108
  29. package/src/components/display/comments/AddCommentModal.vue +98 -94
  30. package/src/components/display/comments/CommentBasicView.vue +95 -0
  31. package/src/components/display/comments/CommentInput.vue +175 -155
  32. package/src/components/display/comments/CommentItem.vue +152 -168
  33. package/src/components/display/comments/CommentList.vue +123 -229
  34. package/src/components/display/comments/CommentParentInfo.vue +26 -58
  35. package/src/components/display/comments/CommentPlayer.vue +51 -49
  36. package/src/components/display/comments/CommentSection.vue +44 -67
  37. package/src/components/display/edit/EditBox.vue +11 -5
  38. package/src/components/display/edit/EditCommentBox.vue +121 -29
  39. package/src/components/display/emission/EmissionChooser.vue +73 -81
  40. package/src/components/display/emission/EmissionInlineList.vue +130 -128
  41. package/src/components/display/emission/EmissionItem.vue +68 -109
  42. package/src/components/display/emission/EmissionList.vue +140 -146
  43. package/src/components/display/emission/EmissionPlayerItem.vue +186 -148
  44. package/src/components/display/filter/AdvancedSearch.vue +192 -273
  45. package/src/components/display/filter/CategoryFilter.vue +51 -59
  46. package/src/components/display/filter/MonetizableFilter.vue +17 -16
  47. package/src/components/display/filter/ProductorSearch.vue +149 -149
  48. package/src/components/display/filter/RubriqueChoice.vue +33 -37
  49. package/src/components/display/filter/RubriqueFilter.vue +132 -122
  50. package/src/components/display/list/ListPaginate.vue +145 -0
  51. package/src/components/display/list/Paginate.vue +218 -0
  52. package/src/components/display/live/CountDown.vue +19 -12
  53. package/src/components/display/live/LiveHorizontalList.vue +78 -55
  54. package/src/components/display/live/LiveItem.vue +136 -121
  55. package/src/components/display/live/LiveList.vue +172 -276
  56. package/src/components/display/organisation/OrganisationChooser.vue +104 -122
  57. package/src/components/display/organisation/OrganisationChooserLight.vue +46 -37
  58. package/src/components/display/participant/ParticipantItem.vue +91 -115
  59. package/src/components/display/participant/ParticipantList.vue +131 -117
  60. package/src/components/display/playlist/PlaylistItem.vue +54 -78
  61. package/src/components/display/playlist/PlaylistList.vue +91 -83
  62. package/src/components/display/playlist/PodcastList.vue +113 -128
  63. package/src/components/display/playlist/PodcastPlaylistInlineList.vue +191 -0
  64. package/src/components/display/podcasts/AnimatorsItem.vue +28 -39
  65. package/src/components/display/podcasts/ParticipantDescription.vue +62 -74
  66. package/src/components/display/podcasts/PodcastFilterList.vue +47 -89
  67. package/src/components/display/podcasts/PodcastImage.vue +195 -229
  68. package/src/components/display/podcasts/PodcastInlineList.vue +64 -282
  69. package/src/components/display/podcasts/PodcastInlineListClassic.vue +240 -0
  70. package/src/components/display/podcasts/PodcastInlineListTemplate.vue +167 -0
  71. package/src/components/display/podcasts/PodcastItem.vue +93 -227
  72. package/src/components/display/podcasts/PodcastItemInfo.vue +166 -0
  73. package/src/components/display/podcasts/PodcastList.vue +115 -134
  74. package/src/components/display/podcasts/PodcastModuleBox.vue +234 -0
  75. package/src/components/display/podcasts/PodcastPlayBar.vue +101 -0
  76. package/src/components/display/podcasts/PodcastSwiperList.vue +204 -0
  77. package/src/components/display/podcasts/TagList.vue +60 -39
  78. package/src/components/display/rubriques/RubriqueChooser.vue +114 -95
  79. package/src/components/display/rubriques/RubriqueList.vue +111 -106
  80. package/src/components/display/sharing/PlayerParameters.vue +90 -151
  81. package/src/components/display/sharing/QrCode.vue +40 -27
  82. package/src/components/display/sharing/ShareButtons.vue +64 -299
  83. package/src/components/display/sharing/ShareButtonsIntern.vue +225 -0
  84. package/src/components/display/sharing/ShareDistribution.vue +99 -140
  85. package/src/components/display/sharing/SharePlayer.vue +155 -370
  86. package/src/components/display/sharing/SharePlayerColors.vue +78 -0
  87. package/src/components/display/sharing/SharePlayerTypes.vue +112 -0
  88. package/src/components/display/sharing/SplitButton.vue +42 -0
  89. package/src/components/display/sharing/SubscribeButtons.vue +62 -179
  90. package/src/components/display/studio/RecordingItemButton.vue +4 -6
  91. package/src/components/form/ClassicCheckbox.vue +66 -0
  92. package/src/components/form/ClassicLoading.vue +28 -0
  93. package/src/components/form/ClassicRadio.vue +66 -0
  94. package/src/components/form/ClassicSearch.vue +86 -0
  95. package/src/components/form/ClassicSelect.vue +65 -0
  96. package/src/components/misc/ErrorMessage.vue +27 -14
  97. package/src/components/misc/Footer.vue +132 -127
  98. package/src/components/misc/HomeDropdown.vue +93 -150
  99. package/src/components/misc/LeftMenu.vue +121 -192
  100. package/src/components/misc/Popover.vue +118 -0
  101. package/src/components/misc/Snackbar.vue +70 -35
  102. package/src/components/misc/TopBar.vue +192 -308
  103. package/src/components/misc/modal/ClipboardModal.vue +35 -50
  104. package/src/components/misc/modal/MessageModal.vue +71 -48
  105. package/src/components/misc/modal/NewsletterModal.vue +260 -231
  106. package/src/components/misc/modal/QrCodeModal.vue +42 -60
  107. package/src/components/misc/modal/ShareModalPlayer.vue +136 -70
  108. package/src/components/misc/player/Player.vue +146 -0
  109. package/src/components/misc/player/PlayerCompact.vue +154 -0
  110. package/src/components/misc/player/PlayerLarge.vue +166 -0
  111. package/src/components/misc/player/PlayerProgressBar.vue +112 -0
  112. package/src/components/misc/player/PlayerTimeline.vue +61 -0
  113. package/src/components/mixins/functions.ts +11 -43
  114. package/src/components/mixins/handle403.ts +17 -0
  115. package/src/components/mixins/init.ts +8 -6
  116. package/src/components/mixins/orgaComputed.ts +15 -0
  117. package/src/components/mixins/organisationFilter.ts +35 -18
  118. package/src/components/mixins/player/playerComment.ts +98 -0
  119. package/src/components/mixins/player/playerDisplay.ts +113 -0
  120. package/src/components/mixins/player/playerLive.ts +111 -0
  121. package/src/components/mixins/player/playerLogic.ts +225 -0
  122. package/src/components/mixins/tagOfMixins.ts +19 -0
  123. package/src/components/pages/Category.vue +21 -26
  124. package/src/components/pages/Emission.vue +136 -162
  125. package/src/components/pages/Emissions.vue +60 -93
  126. package/src/components/pages/Error403Page.vue +60 -0
  127. package/src/components/pages/Home.vue +32 -39
  128. package/src/components/pages/Lives.vue +40 -46
  129. package/src/components/pages/PageNotFound.vue +55 -0
  130. package/src/components/pages/Participant.vue +110 -113
  131. package/src/components/pages/Participants.vue +21 -45
  132. package/src/components/pages/Playlist.vue +84 -75
  133. package/src/components/pages/Playlists.vue +29 -47
  134. package/src/components/pages/Podcast.vue +203 -434
  135. package/src/components/pages/Podcasts.vue +75 -134
  136. package/src/components/pages/Rubrique.vue +21 -29
  137. package/src/components/pages/Search.vue +33 -79
  138. package/src/helper/dom.ts +1 -1
  139. package/src/helper/duration.ts +1 -1
  140. package/src/helper/useEventListener.ts +18 -0
  141. package/src/i18n.ts +36 -0
  142. package/src/locale/de.ts +309 -0
  143. package/src/locale/educationen.ts +1 -1
  144. package/src/locale/educationfr.ts +1 -1
  145. package/src/locale/en.ts +45 -28
  146. package/src/locale/es.ts +309 -0
  147. package/src/locale/fr.ts +25 -8
  148. package/src/locale/it.ts +307 -0
  149. package/src/locale/messages.ts +9 -2
  150. package/src/locale/sl.ts +309 -0
  151. package/src/main.ts +59 -85
  152. package/src/router/router.ts +60 -39
  153. package/src/sass/_variables.scss +10 -8
  154. package/src/shims-tsx.d.ts +2 -0
  155. package/src/shims-vue-recaptcha-v3.d.ts +9 -0
  156. package/src/shims-vue.d.ts +5 -4
  157. package/src/store/AppStore.ts +8 -9
  158. package/src/store/class/adserver/adserverConfig.ts +9 -0
  159. package/src/store/class/adserver/adserverOtherEmission.ts +13 -0
  160. package/src/store/class/adserver/adserverTiming.ts +10 -0
  161. package/src/store/class/cartouchier/cartouche.ts +15 -0
  162. package/src/store/class/cartouchier/cartouchier.ts +9 -0
  163. package/src/store/class/conference/conference.ts +35 -0
  164. package/src/store/class/conference/conferenceMessage.ts +10 -0
  165. package/src/store/class/conference/conferenceParticipant.ts +18 -0
  166. package/src/store/class/conference/pad.ts +15 -0
  167. package/src/store/class/conference/studioCall.ts +7 -0
  168. package/src/store/class/contract/contract.ts +7 -0
  169. package/src/store/class/contract/contractOrganisation.ts +7 -0
  170. package/src/store/class/ftp/ftpEmission.ts +41 -0
  171. package/src/store/class/ftp/ftpParam.ts +12 -0
  172. package/src/store/class/ftp/testFtpEmission.ts +5 -0
  173. package/src/store/class/general/audioView.ts +21 -0
  174. package/src/store/class/general/category.ts +10 -0
  175. package/src/store/class/general/comment.ts +16 -0
  176. package/src/store/class/general/customPlayer.ts +9 -0
  177. package/src/store/class/general/emission.ts +23 -0
  178. package/src/store/class/general/fetchParam.ts +3 -0
  179. package/src/store/class/general/initState.ts +25 -0
  180. package/src/store/class/general/interfacePageable.ts +16 -0
  181. package/src/store/class/general/ituneCategory.ts +5 -0
  182. package/src/store/class/general/media.ts +14 -0
  183. package/src/store/class/general/organisation.ts +20 -0
  184. package/src/store/class/general/pageable.ts +13 -0
  185. package/src/store/class/general/participant.ts +12 -0
  186. package/src/store/class/{player.ts → general/player.ts} +5 -3
  187. package/src/store/class/general/playlist.ts +13 -0
  188. package/src/store/class/general/podcast.ts +43 -0
  189. package/src/store/class/general/sortPageable.ts +5 -0
  190. package/src/store/class/general/soundcastCategory.ts +8 -0
  191. package/src/store/class/ouestFrance/ofTag.ts +36 -0
  192. package/src/store/class/ouestFrance/ofTagInfo.ts +9 -0
  193. package/src/store/class/ouestFrance/ofTagPage.ts +7 -0
  194. package/src/store/class/ouestFrance/ofTagSeo.ts +7 -0
  195. package/src/store/class/ouestFrance/ofTagVente.ts +6 -0
  196. package/src/store/class/ouestFrance/ofTagWithParents.ts +26 -0
  197. package/src/store/class/rss/aggregator.ts +28 -0
  198. package/src/store/class/rss/rssEmission.ts +14 -0
  199. package/src/store/class/rss/rssInfo.ts +8 -0
  200. package/src/store/class/rubrique/rubriquage.ts +10 -0
  201. package/src/store/class/rubrique/rubriquageFilter.ts +6 -0
  202. package/src/store/class/rubrique/rubrique.ts +9 -0
  203. package/src/store/class/stat/statArrayIncome.ts +6 -0
  204. package/src/store/class/stat/statArrayObject.ts +34 -0
  205. package/src/store/class/stat/statGraph.ts +7 -0
  206. package/src/store/class/user/person.ts +15 -0
  207. package/src/store/class/user/profile.ts +12 -0
  208. package/src/store/class/user/userKeycloak.ts +24 -0
  209. package/src/store/paramStore.ts +221 -241
  210. package/src/store/typeAppStore.ts +45 -28
  211. package/src/vuex-shim.d.ts +8 -0
  212. package/tsconfig.json +2 -1
  213. package/vue.config.js +3 -1
  214. package/public/css/fonts/saooti-ui.eot +0 -0
  215. package/public/css/fonts/saooti-ui.svg +0 -840
  216. package/public/css/fonts/saooti-ui.ttf +0 -0
  217. package/public/css/fonts/saooti-ui.woff +0 -0
  218. package/public/css/fonts/stitcher-logo.svg +0 -83
  219. package/public/img/article.png +0 -0
  220. package/src/api/comments.ts +0 -7
  221. package/src/api/emissions.ts +0 -7
  222. package/src/api/podcasts.ts +0 -7
  223. package/src/api/profile.ts +0 -8
  224. package/src/api/studio.ts +0 -8
  225. package/src/assets/bootstrap_scss/_alert.scss +0 -51
  226. package/src/assets/bootstrap_scss/_badge.scss +0 -54
  227. package/src/assets/bootstrap_scss/_breadcrumb.scss +0 -42
  228. package/src/assets/bootstrap_scss/_button-group.scss +0 -164
  229. package/src/assets/bootstrap_scss/_buttons.scss +0 -298
  230. package/src/assets/bootstrap_scss/_card.scss +0 -278
  231. package/src/assets/bootstrap_scss/_carousel.scss +0 -197
  232. package/src/assets/bootstrap_scss/_close.scss +0 -41
  233. package/src/assets/bootstrap_scss/_code.scss +0 -48
  234. package/src/assets/bootstrap_scss/_custom-forms.scss +0 -522
  235. package/src/assets/bootstrap_scss/_dropdown.scss +0 -201
  236. package/src/assets/bootstrap_scss/_forms.scss +0 -352
  237. package/src/assets/bootstrap_scss/_functions.scss +0 -134
  238. package/src/assets/bootstrap_scss/_grid.scss +0 -69
  239. package/src/assets/bootstrap_scss/_images.scss +0 -42
  240. package/src/assets/bootstrap_scss/_input-group.scss +0 -191
  241. package/src/assets/bootstrap_scss/_jumbotron.scss +0 -17
  242. package/src/assets/bootstrap_scss/_list-group.scss +0 -158
  243. package/src/assets/bootstrap_scss/_media.scss +0 -8
  244. package/src/assets/bootstrap_scss/_mixins.scss +0 -47
  245. package/src/assets/bootstrap_scss/_modal.scss +0 -243
  246. package/src/assets/bootstrap_scss/_nav.scss +0 -120
  247. package/src/assets/bootstrap_scss/_navbar.scss +0 -324
  248. package/src/assets/bootstrap_scss/_pagination.scss +0 -74
  249. package/src/assets/bootstrap_scss/_popover.scss +0 -170
  250. package/src/assets/bootstrap_scss/_print.scss +0 -141
  251. package/src/assets/bootstrap_scss/_progress.scss +0 -46
  252. package/src/assets/bootstrap_scss/_reboot.scss +0 -482
  253. package/src/assets/bootstrap_scss/_root.scss +0 -20
  254. package/src/assets/bootstrap_scss/_spinners.scss +0 -55
  255. package/src/assets/bootstrap_scss/_tables.scss +0 -185
  256. package/src/assets/bootstrap_scss/_toasts.scss +0 -44
  257. package/src/assets/bootstrap_scss/_tooltip.scss +0 -115
  258. package/src/assets/bootstrap_scss/_transitions.scss +0 -20
  259. package/src/assets/bootstrap_scss/_type.scss +0 -125
  260. package/src/assets/bootstrap_scss/_utilities.scss +0 -17
  261. package/src/assets/bootstrap_scss/_variables.scss +0 -1145
  262. package/src/assets/bootstrap_scss/bootstrap-grid.scss +0 -29
  263. package/src/assets/bootstrap_scss/bootstrap-reboot.scss +0 -12
  264. package/src/assets/bootstrap_scss/bootstrap.scss +0 -44
  265. package/src/assets/bootstrap_scss/mixins/_alert.scss +0 -13
  266. package/src/assets/bootstrap_scss/mixins/_background-variant.scss +0 -22
  267. package/src/assets/bootstrap_scss/mixins/_badge.scss +0 -17
  268. package/src/assets/bootstrap_scss/mixins/_border-radius.scss +0 -63
  269. package/src/assets/bootstrap_scss/mixins/_box-shadow.scss +0 -20
  270. package/src/assets/bootstrap_scss/mixins/_breakpoints.scss +0 -123
  271. package/src/assets/bootstrap_scss/mixins/_buttons.scss +0 -110
  272. package/src/assets/bootstrap_scss/mixins/_caret.scss +0 -62
  273. package/src/assets/bootstrap_scss/mixins/_clearfix.scss +0 -7
  274. package/src/assets/bootstrap_scss/mixins/_deprecate.scss +0 -10
  275. package/src/assets/bootstrap_scss/mixins/_float.scss +0 -14
  276. package/src/assets/bootstrap_scss/mixins/_forms.scss +0 -177
  277. package/src/assets/bootstrap_scss/mixins/_gradients.scss +0 -45
  278. package/src/assets/bootstrap_scss/mixins/_grid-framework.scss +0 -71
  279. package/src/assets/bootstrap_scss/mixins/_grid.scss +0 -69
  280. package/src/assets/bootstrap_scss/mixins/_hover.scss +0 -37
  281. package/src/assets/bootstrap_scss/mixins/_image.scss +0 -36
  282. package/src/assets/bootstrap_scss/mixins/_list-group.scss +0 -21
  283. package/src/assets/bootstrap_scss/mixins/_lists.scss +0 -7
  284. package/src/assets/bootstrap_scss/mixins/_nav-divider.scss +0 -11
  285. package/src/assets/bootstrap_scss/mixins/_pagination.scss +0 -22
  286. package/src/assets/bootstrap_scss/mixins/_reset-text.scss +0 -17
  287. package/src/assets/bootstrap_scss/mixins/_resize.scss +0 -6
  288. package/src/assets/bootstrap_scss/mixins/_screen-reader.scss +0 -34
  289. package/src/assets/bootstrap_scss/mixins/_size.scss +0 -7
  290. package/src/assets/bootstrap_scss/mixins/_table-row.scss +0 -39
  291. package/src/assets/bootstrap_scss/mixins/_text-emphasis.scss +0 -17
  292. package/src/assets/bootstrap_scss/mixins/_text-hide.scss +0 -11
  293. package/src/assets/bootstrap_scss/mixins/_text-truncate.scss +0 -8
  294. package/src/assets/bootstrap_scss/mixins/_transition.scss +0 -16
  295. package/src/assets/bootstrap_scss/mixins/_visibility.scss +0 -8
  296. package/src/assets/bootstrap_scss/utilities/_align.scss +0 -8
  297. package/src/assets/bootstrap_scss/utilities/_background.scss +0 -19
  298. package/src/assets/bootstrap_scss/utilities/_borders.scss +0 -75
  299. package/src/assets/bootstrap_scss/utilities/_clearfix.scss +0 -3
  300. package/src/assets/bootstrap_scss/utilities/_display.scss +0 -26
  301. package/src/assets/bootstrap_scss/utilities/_embed.scss +0 -39
  302. package/src/assets/bootstrap_scss/utilities/_flex.scss +0 -51
  303. package/src/assets/bootstrap_scss/utilities/_float.scss +0 -11
  304. package/src/assets/bootstrap_scss/utilities/_overflow.scss +0 -5
  305. package/src/assets/bootstrap_scss/utilities/_position.scss +0 -32
  306. package/src/assets/bootstrap_scss/utilities/_screenreaders.scss +0 -11
  307. package/src/assets/bootstrap_scss/utilities/_shadows.scss +0 -6
  308. package/src/assets/bootstrap_scss/utilities/_sizing.scss +0 -20
  309. package/src/assets/bootstrap_scss/utilities/_spacing.scss +0 -73
  310. package/src/assets/bootstrap_scss/utilities/_stretched-link.scss +0 -19
  311. package/src/assets/bootstrap_scss/utilities/_text.scss +0 -72
  312. package/src/assets/bootstrap_scss/utilities/_visibility.scss +0 -13
  313. package/src/assets/bootstrap_scss/vendor/_rfs.scss +0 -204
  314. package/src/components/misc/Player.vue +0 -772
  315. package/src/store/class/category.ts +0 -8
  316. package/src/store/class/comment.ts +0 -17
  317. package/src/store/class/conference.ts +0 -27
  318. package/src/store/class/customPlayer.ts +0 -8
  319. package/src/store/class/emission.ts +0 -20
  320. package/src/store/class/media.ts +0 -13
  321. package/src/store/class/organisation.ts +0 -19
  322. package/src/store/class/participant.ts +0 -12
  323. package/src/store/class/person.ts +0 -13
  324. package/src/store/class/playlist.ts +0 -15
  325. package/src/store/class/podcast.ts +0 -37
  326. package/src/store/class/rubriquage.ts +0 -9
  327. package/src/store/class/rubriquageFilter.ts +0 -5
  328. package/src/store/class/rubrique.ts +0 -8
@@ -0,0 +1,86 @@
1
+ <template>
2
+ <div class="position-relative champs-searchPage static-height">
3
+ <input
4
+ :id="idSearch"
5
+ ref="search"
6
+ v-model="textValue"
7
+ type="text"
8
+ class="search-input w-100 p-2 "
9
+ :placeholder="label"
10
+ :autofocus="autofocus"
11
+ >
12
+ <label
13
+ :for="idSearch"
14
+ :title="label"
15
+ />
16
+ <div
17
+ v-if="!textValue"
18
+ class="saooti-search search-icon-container"
19
+ />
20
+ <div
21
+ v-else
22
+ class="saooti-remove search-icon-container c-hand"
23
+ @click="textValue = ''"
24
+ />
25
+ </div>
26
+ </template>
27
+
28
+ <script lang="ts">
29
+ import { defineComponent } from 'vue';
30
+ export default defineComponent({
31
+ name: 'ClassicSearch',
32
+ props: {
33
+ idSearch: { default: '', type: String },
34
+ label: { default: '', type: String },
35
+ textInit: { default: '', type: String },
36
+ autofocus: { default: false, type: Boolean },
37
+ },
38
+
39
+ emits: ['update:textInit'],
40
+
41
+ data() {
42
+ return {
43
+ textValue: '' as string,
44
+ };
45
+ },
46
+ watch: {
47
+ textValue(){
48
+ if(this.textInit !== this.textValue){
49
+ this.$emit('update:textInit', this.textValue)
50
+ }
51
+ },
52
+ textInit: {
53
+ immediate: true,
54
+ handler() {
55
+ if(this.textInit !== this.textValue){
56
+ this.textValue =this.textInit;
57
+ }
58
+ },
59
+ },
60
+ }
61
+ });
62
+ </script>
63
+ <style lang="scss">
64
+ .octopus-app{
65
+ .champs-searchPage{
66
+ input {
67
+ border: 2px solid #dee2e6;
68
+ border-radius: 10px;
69
+ margin: 0 !important;
70
+ }
71
+ .saooti-search,
72
+ .saooti-remove {
73
+ font-size: 1rem;
74
+ }
75
+ .search-icon-container {
76
+ position: absolute;
77
+ top: 0;
78
+ bottom: 0;
79
+ right: 0;
80
+ display: flex;
81
+ align-items: center;
82
+ margin: 1rem;
83
+ }
84
+ }
85
+ }
86
+ </style>
@@ -0,0 +1,65 @@
1
+ <template>
2
+ <div class="classic-select">
3
+ <label
4
+ :for="idSelect"
5
+ class="form-label mt-2"
6
+ :class="displayLabel?'':'d-none'"
7
+ >{{ label }}</label>
8
+ <select
9
+ :id="idSelect"
10
+ v-model="textValue"
11
+ :disabled="isDisabled"
12
+ class="c-hand"
13
+ >
14
+ <option
15
+ v-for="option in options"
16
+ :key="option.title"
17
+ :value="option.value"
18
+ >
19
+ {{ option.title }}
20
+ </option>
21
+ </select>
22
+ </div>
23
+ </template>
24
+ <script lang="ts">
25
+ import { defineComponent } from 'vue';
26
+ export default defineComponent({
27
+ name: 'ClassicSelect',
28
+ props: {
29
+ idSelect: { default: '', type: String },
30
+ label: { default: '', type: String },
31
+ displayLabel:{default: true, type: Boolean},
32
+ isDisabled: { default: false, type: Boolean },
33
+ options: { default: ()=>[], type: Array as () => Array<{title: string, value: string|undefined}> },
34
+ textInit: { default: undefined, type: String },
35
+ },
36
+ emits: ['update:textInit'],
37
+ data() {
38
+ return {
39
+ textValue: undefined as string|undefined,
40
+ };
41
+ },
42
+ watch: {
43
+ textValue(){
44
+ if(this.textInit !== this.textValue){
45
+ this.$emit('update:textInit', this.textValue)
46
+ }
47
+ },
48
+ textInit: {
49
+ immediate: true,
50
+ handler() {
51
+ if(this.textInit !== this.textValue){
52
+ this.textValue =this.textInit;
53
+ }
54
+ },
55
+ },
56
+ }
57
+ });
58
+ </script>
59
+ <style lang="scss">
60
+ .octopus-app{
61
+ .classic-select select{
62
+ width: inherit;
63
+ }
64
+ }
65
+ </style>
@@ -1,25 +1,38 @@
1
1
  <template>
2
- <div class="d-flex" v-if="message && message.length">
2
+ <div
3
+ v-if="message && message.length"
4
+ class="d-flex"
5
+ >
3
6
  <div
4
- class="d-flex align-items-center bg-error-message p-2 rounded mt-1 mb-1"
7
+ class="d-flex align-items-center bg-error-message p-2 rounded my-1"
5
8
  >
6
- <img src="/img/caution.png" class="icon-caution" />
7
- <div class="alert-text">{{ message }}</div>
9
+ <img
10
+ src="/img/caution.png"
11
+ :alt="$t('Warning')"
12
+ class="icon-caution"
13
+ >
14
+ <div class="alert-text">
15
+ {{ message }}
16
+ </div>
8
17
  </div>
9
18
  </div>
10
19
  </template>
11
- <style lang="scss">
12
- .bg-error-message {
13
- background-color: #ffd84a9c;
14
- }
15
- </style>
16
-
17
20
  <script lang="ts">
18
- import Vue from 'vue';
19
- export default Vue.extend({
21
+ import { defineComponent } from 'vue'
22
+ export default defineComponent({
20
23
  name: 'ErrorMessage',
21
24
  props: {
22
- message: { default: undefined as string|undefined},
25
+ message: { default: undefined, type: String},
23
26
  },
24
- });
27
+ })
25
28
  </script>
29
+ <style lang="scss">
30
+ .octopus-app{
31
+ .bg-error-message {
32
+ background-color: #ffd84a9c;
33
+ }
34
+ .alert-text{
35
+ color: darkred;
36
+ }
37
+ }
38
+ </style>
@@ -2,197 +2,177 @@
2
2
  <div class="bg-dark">
3
3
  <div
4
4
  id="footer"
5
- class="d-flex p-3 secondary-bg border-top footer-display-phone"
5
+ ref="footer"
6
+ class="d-flex-column p-3 secondary-bg border-top"
6
7
  >
7
- <div class="d-flex flex-grow align-items-end flex-column">
8
+ <div class="d-flex flex-column flex-grow-1 align-items-end">
8
9
  <div class="d-flex flex-column">
9
- <router-link
10
- :to="{
11
- name: 'home',
12
- query: { productor: $store.state.filter.organisationId,
13
- iabId: $store.state.filter.iab ? $store.state.filter.iab.id : undefined,
14
- rubriquesId: rubriqueQueryParam },
15
- }"
16
- class="linkHover"
17
- >{{ $t('Home') }}</router-link
18
- >
19
- <router-link
20
- :to="{
21
- name: 'podcasts',
22
- query: { productor: $store.state.filter.organisationId,
23
- iabId: $store.state.filter.iab ? $store.state.filter.iab.id : undefined,
24
- rubriquesId: rubriqueQueryParam},
25
- }"
26
- class="linkHover"
27
- >{{ $t('Podcasts') }}</router-link
28
- >
29
- <router-link
30
- :to="{
31
- name: 'emissions',
32
- query: { productor: $store.state.filter.organisationId,
33
- iabId: $store.state.filter.iab ? $store.state.filter.iab.id : undefined },
34
- }"
35
- class="linkHover"
36
- >{{ $t('Emissions') }}</router-link
37
- >
38
- <router-link
39
- :to="{
40
- name: 'productors',
41
- query: { productor: $store.state.filter.organisationId },
42
- }"
43
- class="linkHover"
44
- v-if="!isPodcastmaker"
45
- >{{ $t('Productors') }}</router-link
46
- >
47
- <router-link
48
- :to="{
49
- name: 'participants',
50
- query: { productor: $store.state.filter.organisationId },
51
- }"
52
- class="linkHover"
53
- >{{ $t('Speakers') }}</router-link
10
+ <template
11
+ v-for="link in routerLinkArray"
12
+ :key="link.routeName"
54
13
  >
14
+ <router-link
15
+ v-if="link.condition"
16
+ class="link-hover"
17
+ :to="{
18
+ name: link.routeName,
19
+ query: getQueriesRouter(link.routeName),
20
+ }"
21
+ >
22
+ {{ link.title }}
23
+ </router-link>
24
+ </template>
55
25
  </div>
56
26
  </div>
57
- <hr class="divided-line show-phone" />
27
+ <hr class="show-phone">
58
28
  <div
59
- class="d-flex flex-grow align-items-center flex-column"
60
29
  v-if="!isPodcastmaker"
30
+ class="d-flex flex-grow-1 align-items-center flex-column"
61
31
  >
62
32
  <div class="d-flex flex-column">
63
- <div class="text-dark">&copy; Saooti 2019</div>
64
- <router-link class="linkHover" to="/main/pub/contact">{{
65
- $t('Contact')
66
- }}</router-link>
67
- <router-link class="linkHover" to="/main/pub/cgu">{{
68
- $t('Term of use')
69
- }}</router-link>
70
- <router-link class="linkHover" to="/main/pub/libraries">{{
71
- $t('Used libraries')
72
- }}</router-link>
73
- <a class="linkHover c-hand" @click="changeLanguage">{{
74
- $t('Change locale')
75
- }}</a>
33
+ <div class="text-dark">
34
+ &copy; Saooti 2019
35
+ </div>
36
+ <router-link
37
+ v-for="link in routerLinkSecondArray"
38
+ :key="link.routeName"
39
+ class="link-hover"
40
+ :to="link.routeName"
41
+ >
42
+ {{ link.title }}
43
+ </router-link>
44
+ <ClassicSelect
45
+ v-model:textInit="language"
46
+ :display-label="false"
47
+ id-select="language-chooser-select"
48
+ :label="$t('Change locale')"
49
+ :options="[{title:'Deutsch', value:'de'},
50
+ {title:'English', value:'en'},
51
+ {title:'Español', value:'es'},
52
+ {title:'Français', value:'fr'},
53
+ {title:'Italiano', value:'it'},
54
+ {title:'Slovenščina', value:'sl'}]"
55
+ />
76
56
  </div>
77
57
  </div>
78
- <hr class="divided-line show-phone" />
79
- <div class="flex-grow">
58
+ <hr class="show-phone">
59
+ <div class="flex-grow-1">
80
60
  <a
81
61
  href="https://www.acpm.fr/L-ACPM/Certifications-et-Labels/Les-Podcasts"
82
62
  rel="noopener"
83
63
  target="_blank"
84
- :aria-label="$t('Octopus is ACPM Podcast accredited')"
64
+ :title="$t('Octopus is ACPM Podcast accredited')"
85
65
  >
86
66
  <img
87
67
  class="acpm_image"
88
68
  src="/img/ACPM.png"
89
69
  :title="$t('Octopus is ACPM Podcast accredited')"
90
70
  :alt="$t('Octopus is ACPM Podcast accredited')"
91
- />
71
+ >
92
72
  </a>
93
73
  </div>
94
74
  <div
95
- class="d-flex flex-grow align-items-center flex-column"
96
75
  v-if="isPodcastmaker && isContactLink"
76
+ class="d-flex flex-column flex-grow-1 align-items-center"
97
77
  >
98
78
  <div class="d-flex flex-column">
99
79
  <a
100
- class="linkHover"
101
80
  id="footer-contact"
81
+ class="link-hover"
102
82
  :href="isContactLink"
103
83
  rel="noopener"
104
84
  target="_blank"
105
- >{{ $t('Contact') }}</a
106
- >
85
+ >{{ $t('Contact') }}</a>
107
86
  </div>
108
87
  </div>
109
88
  </div>
110
89
  <Player @hide="showBlackBorder" />
111
90
  </div>
112
91
  </template>
113
- <style lang="scss">
114
- #footer {
115
- font-size: 0.7rem;
116
- a {
117
- color: #666;
118
- }
119
- .acpm_image {
120
- width: 70px;
121
- height: 70px;
122
- }
123
- }
124
- .border-round {
125
- border-radius: 0 0 2rem 2rem;
126
- }
127
- /** PHONES*/
128
- @media (max-width: 960px) {
129
- .footer-display-phone {
130
- flex-direction: column;
131
- .align-items-center,
132
- .align-items-end {
133
- align-items: flex-start !important;
134
- }
135
- }
136
- .container {
137
- font-size: 0.6rem;
138
- .pages {
139
- margin-right: 3rem;
140
- }
141
- }
142
- }
143
- </style>
144
92
 
145
93
  <script lang="ts">
146
- import Player from './Player.vue';
94
+ import { cookies } from '../mixins/functions';
95
+ import ClassicSelect from '../form/ClassicSelect.vue';
96
+ import Player from './player/Player.vue';
147
97
  import { state } from '../../store/paramStore';
148
- const octopusApi = require('@saooti/octopus-api');
149
- import Vue from 'vue';
150
- const moment = require('moment');
151
- import { Category } from '@/store/class/category';
152
- import { RubriquageFilter } from '@/store/class/rubriquageFilter';
153
- export default Vue.extend({
98
+ import {loadLocaleMessages} from '@/i18n';
99
+ import octopusApi from '@saooti/octopus-api';
100
+ import moment from 'moment';
101
+ import { Category } from '@/store/class/general/category';
102
+ import { RubriquageFilter } from '@/store/class/rubrique/rubriquageFilter';
103
+ import { defineComponent } from 'vue'
104
+ export default defineComponent({
154
105
  name: 'Footer',
155
106
  components: {
156
107
  Player,
108
+ ClassicSelect
109
+ },
110
+ mixins:[cookies],
111
+ data() {
112
+ return {
113
+ language: this.$i18n.locale as string,
114
+ };
157
115
  },
158
-
159
116
  computed: {
160
- isPodcastmaker(): boolean {
161
- return state.generalParameters.podcastmaker;
117
+ routerLinkArray(){
118
+ return [
119
+ {title : this.$t('Home'), routeName: 'home', condition : true},
120
+ {title : this.$t('Podcasts'), routeName: 'podcasts', condition : true},
121
+ {title : this.$t('Emissions'), routeName: 'emissions', condition : true},
122
+ {title : this.$t('Productors'), routeName: 'productors', condition : !this.isPodcastmaker && !this.$store.state.filter.organisationId},
123
+ {title : this.$t('Playlists'), routeName: 'playlists', condition : true},
124
+ {title : this.$t('Speakers'), routeName: 'participants', condition : true},]
162
125
  },
163
- isBarTop(): boolean {
164
- return state.player.barTop;
126
+ routerLinkSecondArray(){
127
+ return [
128
+ {title : this.$t('Contact'), routeName: '/main/pub/contact'},
129
+ {title : this.$t('Term of use'), routeName: '/main/pub/cgu'},
130
+ {title : this.$t('Used libraries'), routeName: "/main/pub/libraries"}]
165
131
  },
166
- isContactLink(): string {
132
+ isPodcastmaker(): boolean {
133
+ return (state.generalParameters.podcastmaker as boolean);
134
+ },
135
+ isContactLink(): string|undefined {
167
136
  return state.footer.contactLink;
168
137
  },
169
138
  rubriqueQueryParam(): string|undefined{
170
- if(this.$store.state.filter && this.$store.state.filter.rubriqueFilter && this.$store.state.filter.rubriqueFilter.length){
139
+ if(this.$store.state.filter?.rubriqueFilter?.length){
171
140
  return this.$store.state.filter.rubriqueFilter.map((value: RubriquageFilter) => value.rubriquageId+':'+value.rubriqueId).join();
172
141
  }
173
142
  return undefined;
174
143
  },
175
144
  },
176
-
145
+ watch:{
146
+ language(){
147
+ this.changeLanguage();
148
+ }
149
+ },
177
150
  methods: {
151
+ getQueriesRouter(routeName: string){
152
+ if('podcasts' !== routeName && 'emissions' !== routeName && 'home' !== routeName){
153
+ return { productor: this.$store.state.filter.organisationId};
154
+ }
155
+ return { productor: this.$store.state.filter.organisationId,
156
+ iabId: this.$store.state.filter.iab?.id,
157
+ rubriquesId: this.rubriqueQueryParam}
158
+ },
178
159
  showBlackBorder(hide: boolean): void {
160
+ const footerElement = (this.$refs.footer as HTMLElement);
161
+ if(null===footerElement){return;}
179
162
  if (hide) {
180
- document.getElementById('footer')!.classList.remove('border-round');
181
- } else if (!this.isBarTop) {
182
- document.getElementById('footer')!.className += ' border-round';
163
+ footerElement.classList.remove('border-round');
164
+ } else {
165
+ footerElement.className += ' border-round';
183
166
  }
184
167
  },
185
168
  changeLanguage(): void{
186
- if('fr'===this.$i18n.locale){
187
- this.$i18n.locale= "en";
188
- }else{
189
- this.$i18n.locale= "fr";
190
- }
169
+ this.setCookie('octopus-language', this.language);
170
+ loadLocaleMessages(this.$i18n, this.language, this.$store.state.general.isEducation);
191
171
  moment.locale(this.$i18n.locale);
192
- octopusApi.fetchCategories({ lang: this.$i18n.locale }).then((data: Array<Category>) => {
172
+ octopusApi.fetchDataWithParams<Array<Category>>(0, `iab/list${state.octopusApi.organisationId? '/'+state.octopusApi.organisationId : ''}`, { lang: this.$i18n.locale }).then((data: Array<Category>) => {
193
173
  this.$store.commit('categoriesSet', data);
194
174
  if(this.$store.state.filter.iab){
195
- const category = this.$store.state.categories.filter((c: any) => {
175
+ const category = this.$store.state.categories.filter((c: Category) => {
196
176
  return c.id === this.$store.state.filter.iab.id;
197
177
  });
198
178
  if(category.length){
@@ -202,5 +182,30 @@ export default Vue.extend({
202
182
  });
203
183
  }
204
184
  },
205
- });
185
+ })
206
186
  </script>
187
+
188
+ <style lang="scss">
189
+ .octopus-app{
190
+ #footer{
191
+ font-size: 0.7rem;
192
+ .acpm_image {
193
+ width: 70px;
194
+ height: 70px;
195
+ }
196
+ a{
197
+ color: #666;
198
+ }
199
+ .border-round {
200
+ border-radius: 0 0 2rem 2rem;
201
+ }
202
+ /** PHONES*/
203
+ @media (max-width: 960px) {
204
+ .align-items-center,
205
+ .align-items-end {
206
+ align-items: flex-start !important;
207
+ }
208
+ }
209
+ }
210
+ }
211
+ </style>