@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,15 +1,23 @@
1
1
  <template>
2
- <div class="default-multiselect-width" :style="{ width: width }">
3
- <label :for="id" class="d-inline" aria-label="select rubrique"></label>
4
- <Multiselect
5
- v-model="rubrique"
2
+ <div
3
+ class="default-multiselect-width"
4
+ :style="{ width: width }"
5
+ >
6
+ <label
7
+ :for="id"
8
+ class="d-inline"
9
+ title="select rubrique"
10
+ />
11
+ <VueMultiselect
6
12
  :id="id"
13
+ ref="multiselectRef"
14
+ v-model="model"
7
15
  :disabled="isDisabled"
8
16
  class="rubriqueChooser"
9
17
  label="name"
10
18
  track-by="rubriqueId"
19
+ :aria-expanded="false"
11
20
  :placeholder="$t('Type string to filter by rubrics')"
12
- ref="multiselectRef"
13
21
  :options="rubriques"
14
22
  :multiple="multiple"
15
23
  :searchable="true"
@@ -22,87 +30,131 @@
22
30
  :show-no-results="true"
23
31
  :hide-selected="true"
24
32
  :show-labels="false"
25
- @open="clearAll"
33
+ @open="onOpen"
26
34
  @search-change="onSearchRubrique"
27
- @close="onClose"
28
35
  @select="onRubriqueSelected"
29
36
  >
30
- <template v-slot:singleLabel="props" >
37
+ <template #singleLabel="{ option }">
31
38
  <div class="multiselect-octopus-proposition">
32
39
  <span class="option__title">
33
- {{ props.option.name }}
40
+ {{ option.name }}
34
41
  </span>
35
42
  </div>
36
43
  </template>
37
- <template v-slot:option="props" >
44
+ <template
45
+ #option="{ option }"
46
+ >
38
47
  <div
48
+ v-if="undefined!==option"
39
49
  class="multiselect-octopus-proposition"
40
- :class="props.option.rubriqueId <= 0 ? 'primary-dark' : ''"
41
- :data-selenium="'rubric-chooser-' + seleniumFormat(props.option.name)"
50
+ :class="option.rubriqueId <= 0 ? 'primary-darker' : ''"
51
+ :data-selenium="'rubric-chooser-' + seleniumFormat(option.name)"
42
52
  >
43
- <span class="option__title">{{ props.option.name }}</span>
53
+ <span class="option__title">{{ option.name }}</span>
44
54
  </div>
45
55
  </template>
46
- <template v-slot:noOptions>{{ $t('List is empty') }}</template>
47
- <template v-slot:noResult>
48
- <span>
56
+ <template #noOptions>
57
+ {{ $t('List is empty') }}
58
+ </template>
59
+ <template #noResult>
49
60
  {{ $t('No elements found. Consider changing the search query.') }}
50
- </span></template>
51
- <template v-slot:caret>
52
- <span
53
- class="saooti-arrow_down octopus-arrow-down octopus-arrow-down-top"
54
- ></span></template>
55
- </Multiselect>
61
+ </template>
62
+ <template #caret>
63
+ <span class="saooti-down octopus-arrow-down" />
64
+ </template>
65
+ </VueMultiselect>
56
66
  </div>
57
67
  </template>
58
68
 
59
- <style lang="scss"></style>
60
69
  <script lang="ts">
61
70
  import { selenium } from '../../mixins/functions';
62
- import Multiselect from 'vue-multiselect';
63
-
64
- const getDefaultRubrique = (defaultName: any) => {
65
- if (undefined !== defaultName) return { name: defaultName, rubriqueId: 0 };
66
- return '';
71
+ //@ts-ignore
72
+ import VueMultiselect from 'vue-multiselect';
73
+ import { Rubrique } from '@/store/class/rubrique/rubrique';
74
+ const getDefaultRubrique = (defaultName: string) => {
75
+ if ('' === defaultName){
76
+ return undefined;
77
+ }
78
+ return { name: defaultName, rubriqueId: 0 } as Rubrique;
67
79
  };
68
80
 
69
- import { defineComponent, ref } from 'vue'
81
+ import { defineComponent } from 'vue'
70
82
  export default defineComponent({
71
83
  components: {
72
- Multiselect,
84
+ VueMultiselect,
73
85
  },
74
-
86
+ mixins:[selenium],
75
87
  props: {
76
- width: { default: '100%' },
77
- defaultanswer: { default: undefined as any },
78
- rubriqueSelected: { default: undefined as any },
79
- multiple: { default: false },
80
- rubriqueArray: { default: undefined as any },
81
- rubriquageId: { default: undefined as any },
82
- allRubriques: { default: [] },
83
- reset: { default: false },
84
- withoutRubrique: { default: false },
85
- isDisabled: { default: false },
88
+ width: { default: '100%', type: String },
89
+ defaultanswer: { default: '', type: String },
90
+ rubriqueSelected: { default: undefined, type: Number },
91
+ multiple: { default: false, type: Boolean },
92
+ rubriqueArray: { default: undefined, type: Object as ()=>Array<number> },
93
+ rubriquageId: { default: undefined, type: Number },
94
+ allRubriques: { default: () => [], type: Array as ()=> Array<Rubrique> },
95
+ reset: { default: false, type: Boolean },
96
+ withoutRubrique: { default: false, type: Boolean },
97
+ isDisabled: { default: false, type: Boolean },
98
+ cannotBeUndefined: {default: false, type: Boolean}
86
99
  },
87
- emits: ['update:rubrique', 'selected'],
88
- mixins: [selenium],
100
+ emits: ['update:rubriqueSelected', 'selected'],
89
101
 
90
102
  data() {
91
103
  return {
92
- rubriques: [] as any,
93
- rubrique: getDefaultRubrique(this.defaultanswer) as any,
94
- isLoading: false,
95
- withoutItem: { name: this.$t('Without rubric'), rubriqueId: -1 },
104
+ rubriques: [] as Array<Rubrique>,
105
+ rubrique: getDefaultRubrique(this.defaultanswer) as Rubrique|undefined,
106
+ rubriqueForArray: [] as Array<Rubrique>,
107
+ isLoading: false as boolean,
108
+ withoutItem: { name: this.$t('Without rubric'), rubriqueId: -1 } as {name: string, rubriqueId:number},
96
109
  };
97
110
  },
111
+ computed: {
112
+ id(): string {
113
+ return this.rubriquageId? 'rubriqueChooser' + this.rubriquageId : 'rubriqueChooser';
114
+ },
115
+ model: {
116
+ get(): Rubrique| Array<Rubrique>|undefined{
117
+ return false===this.multiple ? this.rubrique:this.rubriqueForArray;
118
+ },
119
+ set(value: Rubrique| Array<Rubrique>|undefined): void{
120
+ if(false===this.multiple){
121
+ this.rubrique = (value as Rubrique|undefined);
122
+ return
123
+ }
124
+ this.rubriqueForArray = (value as Array<Rubrique>);
125
+ }
98
126
 
99
- setup() {
100
- const multiselect : any = ref(null);
101
- return {
102
- multiselect,
103
- };
127
+ }
128
+ },
129
+ watch: {
130
+ model:{
131
+ deep: true,
132
+ handler(){
133
+ if(false===this.multiple){
134
+ return;
135
+ }
136
+ const selected: Array<Rubrique> = JSON.parse(JSON.stringify(this.model));
137
+ const idsArray: Array<number> = [];
138
+ selected.forEach((el: Rubrique) => {
139
+ if(el.rubriqueId){
140
+ idsArray.push(el.rubriqueId);
141
+ }
142
+ });
143
+ this.$emit('selected', idsArray);
144
+ }
145
+ },
146
+ rubriqueSelected: {
147
+ deep: true,
148
+ handler(){
149
+ if (undefined !== this.rubriqueSelected) {
150
+ this.initRubriqueSelected(this.rubriqueSelected);
151
+ }
152
+ }
153
+ },
154
+ reset(): void {
155
+ this.rubrique = getDefaultRubrique(this.defaultanswer);
156
+ }
104
157
  },
105
-
106
158
  mounted() {
107
159
  if (undefined !== this.rubriqueSelected) {
108
160
  this.initRubriqueSelected(this.rubriqueSelected);
@@ -111,109 +163,70 @@ export default defineComponent({
111
163
  this.initRubriqueArray(this.rubriqueArray);
112
164
  }
113
165
  },
114
- computed: {
115
- id():string {
116
- if (this.rubriquageId) return 'rubriqueChooser' + this.rubriquageId;
117
- return 'rubriqueChooser';
118
- },
119
- },
120
-
121
166
  methods: {
122
- clearAll() {
123
- this.multiselect.$refs.search.setAttribute(
124
- 'autocomplete',
125
- 'off'
126
- );
127
- if (undefined === this.rubriqueArray) {
128
- this.rubrique = '';
167
+ initRubriquesArray(): Array<Rubrique>{
168
+ if ('' === this.defaultanswer) {
169
+ return this.allRubriques;
129
170
  }
130
- if (undefined === this.defaultanswer) {
131
- this.rubriques = this.allRubriques;
132
- return;
171
+ const rubriqueDefault = getDefaultRubrique(this.defaultanswer);
172
+ if(!rubriqueDefault){
173
+ return this.allRubriques;
133
174
  }
134
175
  if (this.withoutRubrique) {
135
- this.rubriques = [
136
- getDefaultRubrique(this.defaultanswer),
176
+ return [
177
+ rubriqueDefault,
137
178
  this.withoutItem,
138
179
  ].concat(this.allRubriques);
139
- } else {
140
- this.rubriques = [getDefaultRubrique(this.defaultanswer)].concat(
141
- this.allRubriques
142
- );
143
180
  }
181
+ return [rubriqueDefault].concat(this.allRubriques);
144
182
  },
145
-
146
- onClose() {
183
+ onOpen(): void {
184
+ (this.$refs.multiselectRef as VueMultiselect).$refs.search.setAttribute(
185
+ 'autocomplete',
186
+ 'off'
187
+ );
188
+ this.rubriques = this.initRubriquesArray();
189
+ },
190
+ onClose(): void {
147
191
  if (this.rubrique || undefined !== this.rubriqueArray) return;
148
- if (undefined !== this.defaultanswer) {
149
- this.rubrique = getDefaultRubrique(this.defaultanswer);
150
- } else {
151
- this.rubrique = '';
192
+ if(this.cannotBeUndefined && undefined !== this.rubriqueSelected){
193
+ this.initRubriqueSelected(this.rubriqueSelected);
194
+ return;
152
195
  }
196
+ this.rubrique ='' !== this.defaultanswer? getDefaultRubrique(this.defaultanswer): undefined;
153
197
  this.onRubriqueSelected(this.rubrique);
154
198
  },
155
-
156
- onSearchRubrique(query: string) {
199
+ onSearchRubrique(query: string): void {
157
200
  this.isLoading = true;
158
- let list;
159
- if (undefined !== this.defaultanswer) {
160
- if (this.withoutRubrique) {
161
- list = [
162
- getDefaultRubrique(this.defaultanswer),
163
- this.withoutItem,
164
- ].concat(this.allRubriques);
165
- } else {
166
- list = [getDefaultRubrique(this.defaultanswer)].concat(
167
- this.allRubriques
168
- );
169
- }
170
- } else {
171
- list = this.allRubriques;
172
- }
173
- this.rubriques = list.filter((item:any) => {
201
+ this.rubriques = this.initRubriquesArray().filter((item: Rubrique) => {
174
202
  return item.name.toUpperCase().includes(query.toUpperCase());
175
203
  });
176
204
  this.isLoading = false;
177
205
  },
178
-
179
- onRubriqueSelected(rubrique:any) {
180
- if (undefined !== this.rubriqueSelected) {
181
- this.$emit('update:rubrique', rubrique.rubriqueId);
182
- } else if (undefined === this.rubriqueArray) {
206
+ onRubriqueSelected(rubrique: Rubrique|undefined): void {
207
+ if (undefined !== this.rubriqueSelected && rubrique) {
208
+ this.$emit('update:rubriqueSelected', rubrique.rubriqueId);
209
+ }
210
+ if (false === this.multiple) {
183
211
  this.$emit('selected', rubrique);
184
212
  }
185
213
  },
186
- initRubriqueSelected(val: any) {
187
- this.rubrique = this.allRubriques.find((el:any) => {
214
+ initRubriqueSelected(val: number): void {
215
+ this.rubrique = this.initRubriquesArray().find((el: Rubrique) => {
188
216
  return el.rubriqueId === val;
189
217
  });
190
218
  },
191
- initRubriqueArray(val: any[]) {
192
- this.rubrique.length = 0;
193
- val.forEach((element: any) => {
194
- let item = this.allRubriques.find((el:any) => {
219
+ initRubriqueArray(val: number[]): void {
220
+ this.rubriqueForArray = [];
221
+ val.forEach((element: number) => {
222
+ const item = this.initRubriquesArray().find((el: Rubrique) => {
195
223
  return el.rubriqueId === element;
196
224
  });
197
- this.rubrique.push(item);
198
- });
199
- },
200
- },
201
- watch: {
202
- rubriqueSelected(newVal) {
203
- this.initRubriqueSelected(newVal);
204
- },
205
- rubrique(newVal) {
206
- if (undefined === this.rubriqueArray) return;
207
-
208
- let idsArray: any[] = [];
209
- newVal.forEach((el: { rubriqueId: any; }) => {
210
- idsArray.push(el.rubriqueId);
225
+ if(undefined!==item){
226
+ this.rubriqueForArray.push(item);
227
+ }
211
228
  });
212
- this.$emit('selected', idsArray);
213
- },
214
- reset() {
215
- this.rubrique = getDefaultRubrique(this.defaultanswer);
216
229
  },
217
230
  },
218
- });
219
- </script>
231
+ })
232
+ </script>
@@ -0,0 +1,216 @@
1
+ <template>
2
+ <div class="d-inline-flex w-100 mb-3 px-3 hide-phone">
3
+ <div
4
+ ref="rubriqueListContainer"
5
+ class="rubrique-list-container"
6
+ >
7
+ <select
8
+ v-model="rubriquage"
9
+ class="c-hand"
10
+ @change="onRubriquageSelected"
11
+ >
12
+ <option
13
+ v-for="myRubriquage in rubriquageDisplay"
14
+ :key="myRubriquage.rubriquageId"
15
+ :value="myRubriquage"
16
+ >
17
+ {{ myRubriquage.title }}
18
+ </option>
19
+ </select>
20
+ <button
21
+ v-for="rubrique in rubriqueDisplay"
22
+ :ref="'rubrique' + rubrique.rubriqueId"
23
+ :key="rubrique.rubriqueId"
24
+ class="rubrique-item bg-white"
25
+ @click="addFilter(rubrique)"
26
+ >
27
+ {{ rubrique.name }}
28
+ </button>
29
+ </div>
30
+ <div
31
+ v-show="hidenRubriques.length"
32
+ class="dropdown btn-group"
33
+ >
34
+ <button
35
+ class="btn dropdown-toggle admin-button dropdown-toggle-no-caret saooti-more"
36
+ data-bs-toggle="dropdown"
37
+ aria-expanded="false"
38
+ :title="$t('See more')"
39
+ />
40
+ <ul class="dropdown-menu dropdown-menu-right px-4">
41
+ <div
42
+ v-for="rubrique in hidenRubriques"
43
+ :key="rubrique.rubriqueId"
44
+ class="me-3 dropdown-item"
45
+ @click="addFilter(rubrique)"
46
+ >
47
+ {{ rubrique.name }}
48
+ </div>
49
+ </ul>
50
+ </div>
51
+ </div>
52
+ </template>
53
+
54
+ <script lang="ts">
55
+ import { Rubrique } from '@/store/class/rubrique/rubrique';
56
+ import { Rubriquage } from '@/store/class/rubrique/rubriquage';
57
+ import { RubriquageFilter } from '@/store/class/rubrique/rubriquageFilter';
58
+ import { defineComponent } from 'vue'
59
+ export default defineComponent({
60
+ name: 'RubriqueList',
61
+
62
+ props: {
63
+ rubriquages: { default: () => [], type: Array as ()=>Array<Rubriquage>},
64
+ },
65
+
66
+ data() {
67
+ return {
68
+ hidenRubriques: [] as Array<Rubrique>,
69
+ rubriques: [] as Array<Rubrique>,
70
+ rubriquage: undefined as Rubriquage|undefined,
71
+ };
72
+ },
73
+
74
+ computed: {
75
+ filterOrga(): string {
76
+ return this.$store.state.filter.organisationId;
77
+ },
78
+ rubriqueFilter(): Array<RubriquageFilter>{
79
+ return this.$store.state.filter.rubriqueFilter;
80
+ },
81
+ rubriqueDisplay(): Array<Rubrique>{
82
+ return this.$store.state.filter.rubriqueDisplay.filter((rubrique: Rubrique) => 0 !== rubrique.podcastCount );
83
+ },
84
+ rubriquageDisplay(): Array<Rubriquage>{
85
+ const elementToNotShow = Array.from(this.rubriqueFilter);
86
+ if(elementToNotShow.length){
87
+ const rubriquageIdToNotShow = elementToNotShow.map(a => a.rubriquageId);
88
+ return this.rubriquages.filter((element)=>{
89
+ if(!element.rubriquageId){return;}
90
+ return !rubriquageIdToNotShow.includes(element.rubriquageId);
91
+ });
92
+ }
93
+ return this.rubriquages;
94
+ },
95
+ },
96
+ watch:{
97
+ rubriqueFilter:{
98
+ deep: true,
99
+ handler(){
100
+ this.selectNewRubriquage();
101
+ }
102
+ }
103
+ },
104
+
105
+ mounted() {
106
+ this.selectNewRubriquage();
107
+ },
108
+ beforeUnmount(): void {
109
+ window.removeEventListener('resize', this.resizeWindow);
110
+ },
111
+ methods: {
112
+
113
+ initRubriques(): void{
114
+ if(!this.rubriquage){ return ;}
115
+ this.$store.commit('filterRubriqueDisplay', this.rubriquage.rubriques);
116
+ window.addEventListener('resize', this.resizeWindow);
117
+ this.$nextTick(() => {
118
+ this.resizeWindow();
119
+ });
120
+ },
121
+ addFilter(rubrique: Rubrique): void{
122
+ if(!this.rubriquage){ return ;}
123
+ const filterToAdd = {
124
+ rubriquageId: this.rubriquage.rubriquageId??0,
125
+ rubriqueId: rubrique.rubriqueId??0,
126
+ nameRubriquage: this.rubriquage.title,
127
+ nameRubrique: rubrique.name
128
+ };
129
+ const newFilter: Array<RubriquageFilter> = Array.from(this.$store.state.filter.rubriqueFilter);
130
+ newFilter.push(filterToAdd);
131
+ this.$store.commit('filterRubrique', newFilter);
132
+ const queries = this.$route.query;
133
+ const queryString = newFilter.map(value => value.rubriquageId+':'+value.rubriqueId).join();
134
+ this.$router.replace({ query: { ...queries, ...{ rubriquesId: queryString }} });
135
+ this.selectNewRubriquage();
136
+ },
137
+ selectNewRubriquage(){
138
+ const rubriquageLength = this.rubriquages.length;
139
+ if(rubriquageLength === this.rubriqueFilter.length){
140
+ return;
141
+ }
142
+ let index = 0;
143
+ const rubriquageAlreadyFilter = this.rubriqueFilter.map(a => a.rubriquageId);
144
+ for (index; index < rubriquageLength; index++) {
145
+ const rubriquageIdIndex = this.rubriquages[index].rubriquageId;
146
+ if(rubriquageIdIndex && !rubriquageAlreadyFilter.includes(rubriquageIdIndex)){
147
+ break;
148
+ }
149
+ }
150
+ this.rubriquage = this.rubriquages[index];
151
+ this.initRubriques();
152
+ },
153
+ resizeWindow(): void {
154
+ const rubriqueList = (this.$refs.rubriqueListContainer as HTMLElement);
155
+ if(null === rubriqueList){return}
156
+ rubriqueList.style.justifyContent = 'flex-start';
157
+ this.hidenRubriques.length = 0;
158
+ this.rubriqueDisplay.forEach((element: Rubrique) => {
159
+ const el = (this.$refs['rubrique' + element.rubriqueId] as Array<HTMLElement>)[0];
160
+ if (!el) return;
161
+ const parent = el.parentElement;
162
+ if (null !== parent && el.offsetLeft + el.clientWidth <= parent.clientWidth - 20) {
163
+ el.classList.remove('hid');
164
+ return;
165
+ }
166
+ this.hidenRubriques.push(element);
167
+ if (!el.classList.contains('hid')) {
168
+ el.className += ' hid';
169
+ }
170
+ });
171
+ if (!this.hidenRubriques.length) {
172
+ rubriqueList.style.justifyContent = 'center';
173
+ }
174
+ },
175
+ onRubriquageSelected(){
176
+ this.initRubriques();
177
+ }
178
+ }
179
+ })
180
+ </script>
181
+
182
+ <style lang="scss">
183
+ .octopus-app{
184
+ .rubrique-list-container {
185
+ display: flex;
186
+ justify-content: flex-start;
187
+ align-items: center;
188
+ overflow: hidden;
189
+ flex-grow: 1;
190
+ width: 0;
191
+ padding: 0 4rem;
192
+ select{
193
+ width: auto;
194
+ border-radius: 1.5rem;
195
+ margin: 0.2rem;
196
+ font-size: 0.6rem;
197
+ padding: 0.5rem;
198
+ }
199
+ }
200
+ .rubrique-item {
201
+ font-size: 0.6rem;
202
+ margin: 0.2rem;
203
+ padding: 0.5rem;
204
+ border-radius: 1.5rem;
205
+ border: 0;
206
+ display: flex;
207
+ align-items: center;
208
+ justify-content: center;
209
+ white-space: nowrap;
210
+ flex-shrink: 0;
211
+ &:hover {
212
+ background: #eee !important;
213
+ }
214
+ }
215
+ }
216
+ </style>