@opendesign-plus/components 0.0.1-rc.3 → 0.0.1-rc.30

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 (266) hide show
  1. package/dist/chunk-OElCookieNotice.cjs.js +1 -0
  2. package/dist/chunk-OElCookieNotice.es.js +862 -0
  3. package/dist/components/activity/OActivityApproval.vue.d.ts +273 -0
  4. package/dist/components/activity/OActivityForm.vue.d.ts +138 -0
  5. package/dist/components/activity/OActivityMyCalendar.vue.d.ts +636 -0
  6. package/dist/components/activity/composables/useActivityConfig.d.ts +17 -0
  7. package/dist/components/activity/config.d.ts +1 -0
  8. package/dist/components/activity/index.d.ts +648 -0
  9. package/dist/components/activity/types.d.ts +88 -0
  10. package/dist/components/banner/OBanner.vue.d.ts +13 -0
  11. package/dist/components/banner/OBannerContent.vue.d.ts +7 -0
  12. package/dist/components/banner/index.d.ts +68 -0
  13. package/dist/components/banner/types.d.ts +31 -0
  14. package/dist/components/config-provider/OPlusConfigProvider.vue.d.ts +24 -0
  15. package/dist/components/config-provider/index.d.ts +30 -0
  16. package/dist/components/cookie-notice/OCookieNotice.vue.d.ts +17 -0
  17. package/dist/components/cookie-notice/index.d.ts +53 -0
  18. package/dist/components/element-plus/OElCookieNotice.vue.d.ts +34 -0
  19. package/dist/components/element-plus/index.d.ts +2 -0
  20. package/dist/components/events/OEventsApply.vue.d.ts +16 -0
  21. package/dist/components/events/OEventsCalendar.vue.d.ts +5 -0
  22. package/dist/components/events/OEventsList.vue.d.ts +26 -0
  23. package/dist/components/events/config.d.ts +14 -0
  24. package/dist/components/events/index.d.ts +78 -0
  25. package/dist/components/events/types.d.ts +73 -0
  26. package/dist/components/events/utils.d.ts +7 -0
  27. package/dist/components/footer/OFooter.vue.d.ts +46 -0
  28. package/dist/components/footer/index.d.ts +89 -0
  29. package/dist/components/header/OHeader.vue.d.ts +30 -0
  30. package/dist/components/header/OHeaderMobile.vue.d.ts +178 -0
  31. package/dist/components/header/components/HeaderContent.vue.d.ts +13 -0
  32. package/dist/components/header/components/HeaderNav.vue.d.ts +19 -0
  33. package/dist/components/header/components/HeaderNavMobile.vue.d.ts +36 -0
  34. package/dist/components/header/index.d.ts +153 -0
  35. package/dist/components/header/types.d.ts +85 -0
  36. package/dist/components/header-language-switcher/OHeaderLanguageSwitcher.vue.d.ts +49 -0
  37. package/dist/components/header-language-switcher/index.d.ts +90 -0
  38. package/dist/components/header-search/OHeaderSearch.vue.d.ts +1032 -0
  39. package/dist/components/header-search/index.d.ts +607 -0
  40. package/dist/components/header-source-code/OHeaderSourceCode.vue.d.ts +18 -0
  41. package/dist/components/header-source-code/index.d.ts +23 -0
  42. package/dist/components/header-theme/OHeaderTheme.vue.d.ts +25 -0
  43. package/dist/components/header-theme/index.d.ts +50 -0
  44. package/dist/components/header-user/OHeaderUser.vue.d.ts +40 -0
  45. package/dist/components/header-user/index.d.ts +53 -0
  46. package/dist/components/meeting/OMeetingCalendar.vue.d.ts +297 -0
  47. package/dist/components/meeting/OMeetingForm.vue.d.ts +141 -0
  48. package/dist/components/meeting/OMeetingMyCalendar.vue.d.ts +644 -0
  49. package/dist/components/meeting/OMeetingPlayback.vue.d.ts +94 -0
  50. package/dist/components/meeting/OMeetingSigCalendar.vue.d.ts +24 -0
  51. package/dist/components/meeting/components/OMeetingCalendarList.vue.d.ts +29 -0
  52. package/dist/components/meeting/components/OMeetingDetail.vue.d.ts +13 -0
  53. package/dist/components/meeting/components/OMeetingPlaybackSubtitles.vue.d.ts +20 -0
  54. package/dist/components/meeting/components/OMeetingPlaybackVideo.vue.d.ts +17 -0
  55. package/dist/components/meeting/components/OMeetingSigAside.vue.d.ts +16 -0
  56. package/dist/components/meeting/composables/useMeetingConfig.d.ts +14 -0
  57. package/dist/components/meeting/config.d.ts +12 -0
  58. package/dist/components/meeting/index.d.ts +823 -0
  59. package/dist/components/meeting/types.d.ts +235 -0
  60. package/dist/components/meeting/utils.d.ts +9 -0
  61. package/dist/components/search/OSearchInput.vue.d.ts +1025 -0
  62. package/dist/components/search/composables/useImageSearch.d.ts +48 -0
  63. package/dist/components/search/composables/useKeywordHighlight.d.ts +2 -0
  64. package/dist/components/search/composables/useSearchHistory.d.ts +14 -0
  65. package/dist/components/search/index.d.ts +600 -0
  66. package/dist/components/search/internal/HighlightText.vue.d.ts +9 -0
  67. package/dist/components/{OHeaderSearch.vue.d.ts → search/internal/SearchImageInput.vue.d.ts} +210 -166
  68. package/dist/components/search/internal/SearchPanel.vue.d.ts +100 -0
  69. package/dist/components/search/types.d.ts +20 -0
  70. package/dist/components/{OSection.vue.d.ts → section/OSection.vue.d.ts} +4 -4
  71. package/dist/components/section/index.d.ts +47 -0
  72. package/dist/components.cjs.js +224 -1
  73. package/dist/components.css +1 -1
  74. package/dist/components.element.cjs.js +1 -0
  75. package/dist/components.element.es.js +4 -0
  76. package/dist/components.es.js +46234 -1078
  77. package/dist/index.d.ts +16 -12
  78. package/docs/design.md +27 -27
  79. package/docs/design_banner.md +41 -41
  80. package/docs/design_section.md +27 -27
  81. package/package.json +18 -9
  82. package/scripts/generate-components-index.js +61 -80
  83. package/src/assets/events/svg-icons/icon-checked.svg +3 -0
  84. package/src/assets/events/svg-icons/icon-competition.svg +7 -0
  85. package/src/assets/events/svg-icons/icon-events.svg +4 -0
  86. package/src/assets/events/svg-icons/icon-release.svg +4 -0
  87. package/src/assets/events/svg-icons/icon-summit.svg +4 -0
  88. package/src/assets/meeting/svg-icons/icon-all.svg +4 -0
  89. package/src/assets/meeting/svg-icons/icon-backward.svg +4 -0
  90. package/src/assets/meeting/svg-icons/icon-calendar.svg +3 -0
  91. package/src/assets/meeting/svg-icons/icon-cancel.svg +4 -0
  92. package/src/assets/meeting/svg-icons/icon-captions.svg +4 -0
  93. package/src/assets/meeting/svg-icons/icon-close-captions.svg +6 -0
  94. package/src/assets/meeting/svg-icons/icon-close-fullscreen.svg +6 -0
  95. package/src/assets/meeting/svg-icons/icon-copy.svg +3 -0
  96. package/src/assets/meeting/svg-icons/icon-create.svg +5 -0
  97. package/src/assets/meeting/svg-icons/icon-delete.svg +7 -0
  98. package/src/assets/meeting/svg-icons/icon-empty.svg +31 -0
  99. package/src/assets/meeting/svg-icons/icon-empty_dark.svg +49 -0
  100. package/src/assets/meeting/svg-icons/icon-event.svg +4 -0
  101. package/src/assets/meeting/svg-icons/icon-export.svg +3 -0
  102. package/src/assets/meeting/svg-icons/icon-forward.svg +4 -0
  103. package/src/assets/meeting/svg-icons/icon-fullscreen.svg +6 -0
  104. package/src/assets/meeting/svg-icons/icon-help.svg +3 -0
  105. package/src/assets/meeting/svg-icons/icon-important.svg +4 -0
  106. package/src/assets/meeting/svg-icons/icon-info.svg +3 -0
  107. package/src/assets/meeting/svg-icons/icon-meet.svg +4 -0
  108. package/src/assets/meeting/svg-icons/icon-meeting-message.svg +5 -0
  109. package/src/assets/meeting/svg-icons/icon-meeting.svg +4 -0
  110. package/src/assets/meeting/svg-icons/icon-play.svg +5 -0
  111. package/src/assets/meeting/svg-icons/icon-playing-tip.svg +7 -0
  112. package/src/assets/meeting/svg-icons/icon-playing.svg +5 -0
  113. package/src/assets/meeting/svg-icons/icon-question.svg +4 -0
  114. package/src/assets/meeting/svg-icons/icon-sound.svg +5 -0
  115. package/src/assets/meeting/svg-icons/icon-speaker.svg +3 -0
  116. package/src/assets/meeting/svg-icons/icon-summit.svg +4 -0
  117. package/src/assets/meeting/svg-icons/icon-telligent.svg +3 -0
  118. package/src/assets/meeting/svg-icons/icon-tip.svg +3 -0
  119. package/src/assets/meeting/svg-icons/icon-todo.svg +4 -0
  120. package/src/assets/meeting/transparent.png +0 -0
  121. package/src/assets/styles/element-plus.scss +235 -0
  122. package/src/assets/svg-icons/icon-arrow-left.svg +3 -0
  123. package/src/assets/svg-icons/icon-avatar-line.svg +3 -0
  124. package/src/assets/svg-icons/icon-caret-left.svg +3 -0
  125. package/src/assets/svg-icons/icon-caret-right.svg +3 -0
  126. package/src/assets/svg-icons/icon-chevron-down.svg +3 -0
  127. package/src/assets/svg-icons/icon-chevron-right.svg +3 -3
  128. package/src/assets/svg-icons/icon-chevron-up.svg +3 -0
  129. package/src/assets/svg-icons/icon-close.svg +3 -3
  130. package/src/assets/svg-icons/icon-delete-hover.svg +4 -0
  131. package/src/assets/svg-icons/icon-delete.svg +7 -3
  132. package/src/assets/svg-icons/icon-filter.svg +3 -0
  133. package/src/assets/svg-icons/icon-header-back.svg +3 -3
  134. package/src/assets/svg-icons/icon-header-delete.svg +3 -3
  135. package/src/assets/svg-icons/icon-header-menu.svg +3 -0
  136. package/src/assets/svg-icons/icon-header-person.svg +3 -0
  137. package/src/assets/svg-icons/icon-header-search.svg +4 -4
  138. package/src/assets/svg-icons/icon-image-close.svg +4 -0
  139. package/src/assets/svg-icons/icon-image-upload.svg +3 -0
  140. package/src/assets/svg-icons/icon-image-zoomin.svg +3 -0
  141. package/src/assets/svg-icons/icon-loading.svg +4 -0
  142. package/src/assets/svg-icons/icon-locale.svg +3 -0
  143. package/src/assets/svg-icons/icon-log-off.svg +3 -0
  144. package/src/assets/svg-icons/icon-message.svg +3 -0
  145. package/src/assets/svg-icons/icon-moon.svg +3 -3
  146. package/src/assets/svg-icons/icon-outlink.svg +3 -0
  147. package/src/assets/svg-icons/icon-overview.svg +3 -0
  148. package/src/assets/svg-icons/icon-refresh.svg +3 -0
  149. package/src/assets/svg-icons/icon-search.svg +3 -0
  150. package/src/assets/svg-icons/icon-setting.svg +3 -0
  151. package/src/assets/svg-icons/icon-sun.svg +3 -3
  152. package/src/assets/svg-icons/icon-tips.svg +3 -0
  153. package/src/components/activity/OActivityApproval.vue +868 -0
  154. package/src/components/activity/OActivityForm.vue +548 -0
  155. package/src/components/activity/OActivityMyCalendar.vue +1540 -0
  156. package/src/components/activity/composables/useActivityConfig.ts +141 -0
  157. package/src/components/activity/config.ts +1 -0
  158. package/src/components/activity/index.ts +24 -0
  159. package/src/components/activity/types.ts +95 -0
  160. package/src/components/banner/OBanner.vue +288 -0
  161. package/src/components/banner/OBannerContent.vue +175 -0
  162. package/src/components/banner/index.ts +18 -0
  163. package/src/components/banner/types.ts +39 -0
  164. package/src/components/common/AppAvatar.vue +83 -0
  165. package/src/components/common/ClientOnly.vue +13 -0
  166. package/src/components/common/ContentWrapper.vue +85 -85
  167. package/src/components/common/MoreText.vue +124 -0
  168. package/src/components/common/ThFilter.vue +330 -0
  169. package/src/components/{OPlusConfigProvider.vue → config-provider/OPlusConfigProvider.vue} +32 -32
  170. package/src/components/config-provider/index.ts +10 -0
  171. package/src/components/cookie-notice/OCookieNotice.vue +575 -0
  172. package/src/components/cookie-notice/index.ts +10 -0
  173. package/src/components/element-plus/OElCookieNotice.vue +603 -0
  174. package/src/components/element-plus/index.ts +3 -0
  175. package/src/components/events/OEventsApply.vue +503 -0
  176. package/src/components/events/OEventsCalendar.vue +600 -0
  177. package/src/components/events/OEventsList.vue +463 -0
  178. package/src/components/events/config.ts +35 -0
  179. package/src/components/events/index.ts +24 -0
  180. package/src/components/events/types.ts +84 -0
  181. package/src/components/events/utils.ts +9 -0
  182. package/src/components/footer/OFooter.vue +577 -0
  183. package/src/components/footer/index.ts +10 -0
  184. package/src/components/header/OHeader.vue +157 -0
  185. package/src/components/header/OHeaderMobile.vue +184 -0
  186. package/src/components/header/components/HeaderContent.vue +1125 -0
  187. package/src/components/header/components/HeaderNav.vue +278 -0
  188. package/src/components/header/components/HeaderNavMobile.vue +380 -0
  189. package/src/components/header/index.ts +18 -0
  190. package/src/components/header/types.ts +96 -0
  191. package/src/components/header-language-switcher/OHeaderLanguageSwitcher.vue +211 -0
  192. package/src/components/header-language-switcher/index.ts +10 -0
  193. package/src/components/header-search/OHeaderSearch.vue +628 -0
  194. package/src/components/header-search/index.ts +10 -0
  195. package/src/components/header-source-code/OHeaderSourceCode.vue +151 -0
  196. package/src/components/header-source-code/index.ts +10 -0
  197. package/src/components/header-theme/OHeaderTheme.vue +132 -0
  198. package/src/components/header-theme/index.ts +10 -0
  199. package/src/components/header-user/OHeaderUser.vue +238 -0
  200. package/src/components/header-user/index.ts +10 -0
  201. package/src/components/meeting/OMeetingCalendar.vue +909 -0
  202. package/src/components/meeting/OMeetingForm.vue +1131 -0
  203. package/src/components/meeting/OMeetingMyCalendar.vue +1536 -0
  204. package/src/components/meeting/OMeetingPlayback.vue +469 -0
  205. package/src/components/meeting/OMeetingSigCalendar.vue +439 -0
  206. package/src/components/meeting/components/OMeetingCalendarList.vue +609 -0
  207. package/src/components/meeting/components/OMeetingCalendarSelector.vue +213 -0
  208. package/src/components/meeting/components/OMeetingDetail.vue +263 -0
  209. package/src/components/meeting/components/OMeetingPlaybackSubtitles.vue +615 -0
  210. package/src/components/meeting/components/OMeetingPlaybackVideo.vue +741 -0
  211. package/src/components/meeting/components/OMeetingSigAside.vue +204 -0
  212. package/src/components/meeting/composables/useMeetingConfig.ts +108 -0
  213. package/src/components/meeting/config.ts +48 -0
  214. package/src/components/meeting/index.ts +45 -0
  215. package/src/components/meeting/types.ts +268 -0
  216. package/src/components/meeting/utils.ts +70 -0
  217. package/src/components/search/OSearchInput.vue +526 -0
  218. package/src/components/search/composables/useImageSearch.ts +157 -0
  219. package/src/components/search/composables/useKeywordHighlight.ts +30 -0
  220. package/src/components/search/composables/useSearchHistory.ts +75 -0
  221. package/src/components/search/index.ts +23 -0
  222. package/src/components/search/internal/HighlightText.vue +37 -0
  223. package/src/components/search/internal/SearchImageInput.vue +498 -0
  224. package/src/components/search/internal/SearchPanel.vue +431 -0
  225. package/src/components/search/types.ts +25 -0
  226. package/src/components/{OSection.vue → section/OSection.vue} +178 -178
  227. package/src/components/section/index.ts +10 -0
  228. package/src/draft/Banner.vue +265 -265
  229. package/src/draft/ButtonCards.vue +105 -105
  230. package/src/draft/Feature.vue +133 -133
  231. package/src/draft/Footer.vue +519 -512
  232. package/src/draft/HorizontalAnchor.vue +165 -165
  233. package/src/draft/ItemSwiper.vue +133 -133
  234. package/src/draft/Logo.vue +141 -141
  235. package/src/draft/LogoCard.vue +74 -74
  236. package/src/draft/LogoV2.vue +19 -19
  237. package/src/draft/MainCard.vue +38 -38
  238. package/src/draft/MultiCard.vue +94 -94
  239. package/src/draft/MultiIconCard.vue +73 -73
  240. package/src/draft/OInfoCard.vue +176 -176
  241. package/src/draft/Process.vue +81 -81
  242. package/src/draft/Section.vue +167 -167
  243. package/src/draft/SingleTabCard.vue +84 -84
  244. package/src/draft/SliderCard.vue +111 -110
  245. package/src/env.d.ts +16 -1
  246. package/src/i18n/en.ts +276 -20
  247. package/src/i18n/index.ts +56 -42
  248. package/src/i18n/zh.ts +266 -9
  249. package/src/index.ts +16 -32
  250. package/src/shared/provide.ts +6 -6
  251. package/src/shims-vue-dompurify-html.d.ts +17 -0
  252. package/src/vue.d.ts +9 -9
  253. package/tsconfig.json +37 -33
  254. package/vite.config.ts +123 -94
  255. package/dist/components/OBanner.vue.d.ts +0 -2
  256. package/dist/components/OCookieNotice.vue.d.ts +0 -16
  257. package/dist/components/OElCookieNotice.vue.d.ts +0 -31
  258. package/dist/components/OPlusConfigProvider.vue.d.ts +0 -23
  259. package/dist/components/OThemeSwitcher.vue.d.ts +0 -28
  260. package/dist/components.umd.js +0 -1
  261. package/src/components/OBanner.vue +0 -390
  262. package/src/components/OCookieNotice.vue +0 -424
  263. package/src/components/OElCookieNotice.vue +0 -413
  264. package/src/components/OHeaderSearch.vue +0 -601
  265. package/src/components/OThemeSwitcher.vue +0 -108
  266. package/src/components/common/ClientOnlyWrapper.ts +0 -21
@@ -0,0 +1,204 @@
1
+ <script setup lang="ts">
2
+ import { OIcon, OIconArrowLeft, OIconArrowRight } from '@opensig/opendesign';
3
+ import { useMeetingConfig } from '@/components/meeting/composables/useMeetingConfig';
4
+ import { CalendarDataType } from '@/components/meeting';
5
+
6
+ const { getConfig } = useMeetingConfig();
7
+
8
+ const props = defineProps<{
9
+ data: any[];
10
+ current: number;
11
+ total: number;
12
+ active: string;
13
+ meetingDates: string[];// 会议日期列表
14
+ eventsDates: string[];// 活动日期列表
15
+ }>();
16
+
17
+ const STEP = 1;
18
+
19
+ const emits = defineEmits(['click-date', 'change-month']);
20
+ const clickDate = (date: string) => {
21
+ emits('click-date', date);
22
+ };
23
+
24
+ const changeMonth = (step: number) => {
25
+ if (props.current + step >= props.total || props.current + step < 0) return;
26
+ emits('change-month', step);
27
+ };
28
+ </script>
29
+
30
+ <template>
31
+ <div class="o-sig-meeting-aside">
32
+ <template v-for="(d, dIdx) in data" :key="dIdx">
33
+ <div v-for="m in d" :key="m.month" class="month-item">
34
+ <div class="month">{{ m.month.replace(/-/g, '/') }}</div>
35
+ <div class="days">
36
+ <div
37
+ class="day-item"
38
+ v-for="d in m.days"
39
+ :key="d"
40
+ @click="clickDate(`${m.month}-${d}`)"
41
+ :class="active === `${m.month}-${d}` && 'active'"
42
+ >
43
+ <div class="day-d">{{ d }}</div>
44
+ <div class="day-c">
45
+ <OIcon
46
+ v-if="meetingDates.includes(`${m.month}-${d}`)"
47
+ :style="{
48
+ zIndex: getConfig(CalendarDataType.MEETING, 'zIndex'),
49
+ backgroundColor: getConfig(CalendarDataType.MEETING, 'color'),
50
+ }"
51
+ >
52
+ <component :is="getConfig(CalendarDataType.MEETING, 'icon')" />
53
+ </OIcon>
54
+ <OIcon
55
+ v-if="eventsDates.includes(`${m.month}-${d}`)"
56
+ :style="{
57
+ zIndex: getConfig(CalendarDataType.EVENTS, 'zIndex'),
58
+ backgroundColor: getConfig(CalendarDataType.EVENTS, 'color'),
59
+ }"
60
+ >
61
+ <component :is="getConfig(CalendarDataType.EVENTS, 'icon')" />
62
+ </OIcon>
63
+ </div>
64
+ </div>
65
+ </div>
66
+ </div>
67
+ </template>
68
+ <div class="arrow-wrapper">
69
+ <OIcon @click="changeMonth(0 - STEP)" :class="current - STEP < 0 && 'disabled'">
70
+ <OIconArrowLeft />
71
+ </OIcon>
72
+ <OIcon @click="changeMonth(STEP)" :class="current + STEP >= total && 'disabled'">
73
+ <OIconArrowRight />
74
+ </OIcon>
75
+ </div>
76
+ </div>
77
+ </template>
78
+
79
+ <style lang="scss">
80
+ .o-sig-meeting-aside {
81
+ width: 35%;
82
+ flex-shrink: 0;
83
+ padding: var(--o-gap-4);
84
+ display: flex;
85
+ flex-direction: column;
86
+ border-right: 1px solid var(--o-color-control4);
87
+ @include respond('<=pad') {
88
+ padding: var(--o-gap-4);
89
+ }
90
+ @include respond('<=pad_v') {
91
+ border-right: none;
92
+ }
93
+ @include respond('phone') {
94
+ padding: 16px;
95
+ .title {
96
+ margin-bottom: var(--o-gap-2);
97
+ }
98
+ }
99
+ @include respond('<=pad_v') {
100
+ width: 100%;
101
+ }
102
+
103
+ .month-item {
104
+ margin-bottom: var(--o-gap-3);
105
+
106
+ .month {
107
+ color: var(--o-color-info3);
108
+ margin-bottom: var(--o-gap-2);
109
+ font-weight: bold;
110
+ @include text1;
111
+ }
112
+
113
+ .days {
114
+ gap: var(--o-gap-2);
115
+ display: grid;
116
+ grid-template-columns: repeat(2, 1fr);
117
+
118
+ @include respond('<=pad_v') {
119
+ display: flex;
120
+ }
121
+
122
+ .day-item {
123
+ height: 64px;
124
+ border-radius: var(--meeting-cell-radius);
125
+ background-color: var(--o-color-control2-light);
126
+ padding: 8px 12px;
127
+ cursor: pointer;
128
+ border: 1px solid transparent;
129
+
130
+ &:hover {
131
+ background-color: var(--o-color-control3-light);
132
+ }
133
+
134
+ &.active {
135
+ border-color: var(--o-color-primary1);
136
+ }
137
+
138
+ .day-d {
139
+ font-weight: 500;
140
+ margin-bottom: var(--o-gap-1);
141
+ color: var(--o-color-info1);
142
+ }
143
+
144
+ .day-c {
145
+ color: rgb(var(--o-white));
146
+ display: flex;
147
+ flex-wrap: nowrap;
148
+
149
+ .o-icon {
150
+ width: 20px;
151
+ height: 20px;
152
+ font-size: 18px;
153
+ padding: 1px;
154
+ line-height: 1em;
155
+ position: relative;
156
+ border-radius: 50%;
157
+ margin-left: -6px;
158
+
159
+ &:first-child {
160
+ margin-left: 0;
161
+ }
162
+
163
+ svg path {
164
+ fill: currentColor;
165
+ }
166
+ }
167
+ }
168
+ }
169
+ }
170
+ }
171
+
172
+ .arrow-wrapper {
173
+ display: flex;
174
+ align-items: center;
175
+ justify-content: space-between;
176
+ color: var(--o-color-primary1);
177
+
178
+ .o-icon {
179
+ font-size: 24px;
180
+ cursor: pointer;
181
+
182
+ &.disabled {
183
+ cursor: not-allowed;
184
+ color: var(--o-color-primary4);
185
+ }
186
+
187
+ &:not(.disabled):hover {
188
+ color: var(--o-color-primary2);
189
+ }
190
+ }
191
+ }
192
+
193
+ @include respond('<=pad_v') {
194
+ .day-item {
195
+ }
196
+ }
197
+ @include respond('<=pad_v') {
198
+ .day-item {
199
+ width: min(128px, calc((100% - var(--o-gap-2)) / 2));
200
+ }
201
+ }
202
+ }
203
+
204
+ </style>
@@ -0,0 +1,108 @@
1
+ import { computed } from 'vue';
2
+ import dayjs from 'dayjs';
3
+ import { useI18n } from '@/i18n';
4
+ import IconAll from '~icons/meeting/icon-all.svg';
5
+ import IconEvent from '~icons/meeting/icon-event.svg';
6
+ import IconMeeting from '~icons/meeting/icon-meet.svg';
7
+ import IconSummit from '~icons/meeting/icon-summit.svg';
8
+ import { CalendarDataType, meetingTabT, OptionItemT } from '../types';
9
+ import { INTERVAL_DAY, INTERVAL_MONTH, INTERVAL_WEEK, TYPE_COLOR_MAP } from '../config';
10
+
11
+ export const useMeetingConfig = () => {
12
+ const { t, locale } = useI18n();
13
+
14
+ const meetingTabs = computed<meetingTabT[]>(() => [
15
+ { label: t('meeting.meetingTypeAll'), value: CalendarDataType.ALL, icon: IconAll },
16
+ { label: t('meeting.meetingTypeMeet'), value: CalendarDataType.MEETING, icon: IconMeeting, color: TYPE_COLOR_MAP.meeting, zIndex: 3 },
17
+ { label: t('meeting.meetingTypeEvents'), value: CalendarDataType.EVENTS, icon: IconEvent, color: TYPE_COLOR_MAP.events, zIndex: 2 },
18
+ { label: t('meeting.meetingTypeSummit'), value: CalendarDataType.SUMMIT, icon: IconSummit, color: TYPE_COLOR_MAP.summit, zIndex: 1 },
19
+ ]);
20
+
21
+ const cycleTypeOptions0 = computed<OptionItemT[]>(() => [
22
+ { label: t('meeting.day0'), value: INTERVAL_DAY, max: 7 },
23
+ { label: t('meeting.week0'), value: INTERVAL_WEEK, max: 2 },
24
+ { label: t('meeting.month0'), value: INTERVAL_MONTH, max: 1 },
25
+ ]);
26
+
27
+ const cycleTypeOptions = computed<OptionItemT[]>(() => [
28
+ { label: t('meeting.day'), value: INTERVAL_DAY, max: 7 },
29
+ { label: t('meeting.week'), value: INTERVAL_WEEK, max: 2 },
30
+ { label: t('meeting.month'), value: INTERVAL_MONTH, max: 1 },
31
+ ]);
32
+
33
+ const weekDay = computed(() => [
34
+ t('meeting.sunday'),
35
+ t('meeting.monday'),
36
+ t('meeting.tuesday'),
37
+ t('meeting.wednesday'),
38
+ t('meeting.thursday'),
39
+ t('meeting.friday'),
40
+ t('meeting.saturday'),
41
+ ]);
42
+
43
+ const intervalWeekOptions = computed(() => {
44
+ const list: OptionItemT[] = [];
45
+ for (let i = 1; i <= 7; i++) {
46
+ const idx = i % 7;
47
+ list.push({ value: idx, label: weekDay.value[idx] });
48
+ }
49
+ return list;
50
+ });
51
+
52
+ const getPointStr = (cycleType: number, points: (number | string)[]) => {
53
+ if (cycleType === INTERVAL_WEEK) {
54
+ return points
55
+ .sort((a, b) => {
56
+ const aIdx = intervalWeekOptions.value.findIndex((v) => v.value === a || v.value.toString() === a);
57
+ const bIdx = intervalWeekOptions.value.findIndex((v) => v.value === b || v.value.toString() === b);
58
+ return aIdx - bIdx;
59
+ })
60
+ .map((point: number | string) => {
61
+ const opt = intervalWeekOptions.value.find((v) => v.value === point || v.value.toString() === point);
62
+ return opt?.label || String(point);
63
+ })
64
+ .join(t('meeting.cycleSplit'));
65
+ }
66
+ if (cycleType === INTERVAL_MONTH) {
67
+ return points.join(t('meeting.cycleSplit'));
68
+ }
69
+ return '';
70
+ };
71
+
72
+ const getConfig = (val: CalendarDataType, key: keyof meetingTabT): string => {
73
+ let value = val;
74
+ const find: meetingTabT | undefined = meetingTabs.value.find(v => v.value === value);
75
+ return find?.[key] || '';
76
+ };
77
+
78
+ const getPlatformLabel = (platform: string) => {
79
+ switch (platform) {
80
+ case 'WELINK':
81
+ return 'WeLink';
82
+ case 'ZOOM':
83
+ return 'Zoom';
84
+ case 'TENCENT':
85
+ return locale.value === 'zh' ? '腾讯会议' : 'Tencent';
86
+ default:
87
+ return platform;
88
+ }
89
+ };
90
+
91
+ const getWeekFromDate = (date: string | Date) => {
92
+ return weekDay.value[dayjs(date).day()];
93
+ };
94
+
95
+ return {
96
+ t,
97
+ locale,
98
+ meetingTabs,
99
+ cycleTypeOptions0,
100
+ cycleTypeOptions,
101
+ weekDay,
102
+ intervalWeekOptions,
103
+ getPointStr,
104
+ getConfig,
105
+ getPlatformLabel,
106
+ getWeekFromDate,
107
+ };
108
+ };
@@ -0,0 +1,48 @@
1
+ import { CalendarDataType, meetingTabT } from './types.ts';
2
+ import IconAll from '~icons/meeting/icon-all.svg';
3
+ import IconEvent from '~icons/meeting/icon-event.svg';
4
+ import IconMeeting from '~icons/meeting/icon-meet.svg';
5
+ import IconSummit from '~icons/meeting/icon-summit.svg';
6
+
7
+ export const TYPE_COLOR_MAP = {
8
+ summit: 'rgba(var(--o-orange-6))',
9
+ events: 'rgba(var(--o-cyan-6))',
10
+ meeting: 'rgba(var(--o-deepblue-6))',
11
+ };
12
+
13
+ export const INTERVAL_DAY = 0;
14
+ export const INTERVAL_WEEK = 1;
15
+ export const INTERVAL_MONTH = 2;
16
+
17
+ export const EMAIL_REGEX = /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;
18
+
19
+ export const PROGRESS_COLORS = ['var(--o-color-primary1)', 'var(--o-color-warning1)', 'var(--o-color-success1)'];
20
+
21
+ export const getMeetingTabs = (t: (key: string) => string): meetingTabT[] => [
22
+ {
23
+ label: t('meeting.meetingTypeAll'),
24
+ value: CalendarDataType.ALL,
25
+ icon: IconAll,
26
+ },
27
+ {
28
+ label: t('meeting.meetingTypeMeet'),
29
+ value: CalendarDataType.MEETING,
30
+ icon: IconMeeting,
31
+ color: TYPE_COLOR_MAP.meeting,
32
+ zIndex: 3,
33
+ },
34
+ {
35
+ label: t('meeting.meetingTypeEvents'),
36
+ value: CalendarDataType.EVENTS,
37
+ icon: IconEvent,
38
+ color: TYPE_COLOR_MAP.events,
39
+ zIndex: 2,
40
+ },
41
+ {
42
+ label: t('meeting.meetingTypeSummit'),
43
+ value: CalendarDataType.SUMMIT,
44
+ icon: IconSummit,
45
+ color: TYPE_COLOR_MAP.summit,
46
+ zIndex: 1,
47
+ },
48
+ ];
@@ -0,0 +1,45 @@
1
+ import type { App } from 'vue';
2
+ import _OMeetingCalendar from './OMeetingCalendar.vue';
3
+ import _OMeetingForm from './OMeetingForm.vue';
4
+ import _OMeetingPlayback from './OMeetingPlayback.vue';
5
+ import _OMeetingSigCalendar from './OMeetingSigCalendar.vue';
6
+ import _OMeetingMyCalendar from './OMeetingMyCalendar.vue';
7
+
8
+ const OMeetingCalendar = Object.assign(_OMeetingCalendar, {
9
+ install(app: App) {
10
+ app.component('OMeetingCalendar', _OMeetingCalendar);
11
+ },
12
+ });
13
+ const OMeetingForm = Object.assign(_OMeetingForm, {
14
+ install(app: App) {
15
+ app.component('OMeetingForm', _OMeetingForm);
16
+ },
17
+ });
18
+
19
+ const OMeetingPlayback = Object.assign(_OMeetingPlayback, {
20
+ install(app: App) {
21
+ app.component('OMeetingPlayback', _OMeetingPlayback);
22
+ },
23
+ });
24
+
25
+ const OMeetingSigCalendar = Object.assign(_OMeetingSigCalendar, {
26
+ install(app: App) {
27
+ app.component('OMeetingSigCalendar', _OMeetingSigCalendar);
28
+ },
29
+ });
30
+
31
+ const OMeetingMyCalendar = Object.assign(_OMeetingMyCalendar, {
32
+ install(app: App) {
33
+ app.component('OMeetingMyCalendar', _OMeetingMyCalendar);
34
+ },
35
+ });
36
+
37
+ export {
38
+ OMeetingCalendar,
39
+ OMeetingForm,
40
+ OMeetingPlayback,
41
+ OMeetingSigCalendar,
42
+ OMeetingMyCalendar,
43
+ };
44
+
45
+ export * from './types';
@@ -0,0 +1,268 @@
1
+ // sig组列表
2
+ import { INTERVAL_DAY, INTERVAL_MONTH, INTERVAL_WEEK } from '@/components/meeting/config.ts';
3
+
4
+ export interface GroupItemT {
5
+ id?: number;
6
+ group_name: string;
7
+ maillist?: string;
8
+ }
9
+
10
+ // 会议日历上额外的数据,活动或者峰会
11
+ export enum CalendarDataType {
12
+ ALL = 'all',
13
+ MEETING = 'meeting',
14
+ EVENTS = 'events',
15
+ SUMMIT = 'summit',
16
+ APPROVAL = 'approval'
17
+ }
18
+
19
+ export interface CalendarOtherDataT {
20
+ id: string;
21
+ name: string;
22
+ url: string;
23
+ dates: string[];
24
+ location?: string;
25
+ address?: string;
26
+ start_date: string;
27
+ end_date: string;
28
+ activity_type: string;
29
+ type: CalendarDataType.EVENTS | CalendarDataType.SUMMIT;
30
+ }
31
+
32
+ export interface OptionItemT {
33
+ label: string;
34
+ value: string | number;
35
+
36
+ [key: string]: any;
37
+ }
38
+
39
+
40
+ export type PlatformT = 'welink' | 'tencent' | 'zoom' | 'WELINK' | 'TENCENT' | 'ZOOM' | 'WeLink' | 'Tencent';
41
+
42
+ export enum MeetingGroupType {
43
+ SIG = 'sig',
44
+ GROUP = 'group',
45
+ }
46
+
47
+ export interface MeetingCalendarPropsT {
48
+ getDateListRequest: any;
49
+ getMeetingListRequest: any;
50
+ getSummitListRequest: any;
51
+ getSummitDatesRequest: any;
52
+ getEventsListRequest: any;
53
+ getEventsDatesRequest: any;
54
+ hiddenEvents?: boolean;
55
+ hiddenSummit?: boolean;
56
+ groupType: MeetingGroupType;
57
+ groups: string[];
58
+ disableFormat?: boolean; //是否禁用日期格式化
59
+ }
60
+
61
+ // 会议新增、修改
62
+ export interface MeetingPostT {
63
+ id?: number; // 会议id
64
+ topic: string; // 会议主题 128
65
+ name?: string; // 会议主题 128
66
+ title?: string; // 会议主题 128
67
+ sponsor?: string; // 会议发起人 20
68
+ group_name: string; // 所属SIG 64
69
+ platform: PlatformT | string; // 会议平台
70
+ date: string; // 会议日期
71
+ date_range?: string[]; // 日期返回
72
+ time: string; // 会议时间
73
+ start: string; // 会议开始时间
74
+ end: string; // 会议结束时间
75
+ etherpad: string; // etherpad链接
76
+ agenda: string; // 会议议程
77
+ email_list: string; // 通知邮件列表 1020
78
+ is_record: boolean; // 会议录制
79
+ is_cycle: boolean; // 是否重复
80
+ cycle_start_date?: string;
81
+ cycle_end_date?: string;
82
+ cycle_start?: string;
83
+ cycle_end?: string;
84
+ cycle_interval: number; // 重复周期, 当intervalType为month时固定为1
85
+ cycle_type: typeof INTERVAL_DAY | typeof INTERVAL_WEEK | typeof INTERVAL_MONTH; // 重复类型,默认为INTERVAL_DAY
86
+ cycle_point: number[]; // 重复节点,当intervalType为week|month时存在值
87
+ is_notify?: boolean;
88
+ mid?: string;
89
+ sub_id?: string;
90
+ }
91
+
92
+ export interface MeetingFormPropsT {
93
+ data?: MeetingItemT;
94
+ subId?: string;
95
+ createMeetingRequest: any,
96
+ editMeetingRequest: any;
97
+ editSubMeetingRequest: any;
98
+ getPlatformsRequest: any;
99
+ getGroupsRequest: any;
100
+ showBtns?: boolean;
101
+ groupType: MeetingGroupType;
102
+ confirmText?: string;
103
+ labelMap?: Record<string, string>;
104
+ }
105
+
106
+ export interface ObsDataItemT {
107
+ id: number;
108
+ mid: string;
109
+ sub_id: string;
110
+ status: number;
111
+ text_vtt_url: string;
112
+ text_json_url: string;
113
+ text_video_url: string;
114
+ text_picture_url: string;
115
+ topic_url: string;
116
+ meeting_id: number;
117
+ }
118
+
119
+ export interface CycleSubItemT {
120
+ id: number;
121
+ mid: string;
122
+ sub_id: string;
123
+ date: string;
124
+ start: string;
125
+ end: string;
126
+ meeting_id: number;
127
+ }
128
+
129
+ // 会议详情
130
+ export interface MeetingItemT extends MeetingPostT {
131
+ id: number;
132
+ community: string;
133
+ mid: string;
134
+ m_mid: string;
135
+ join_url: string; // 会议链接
136
+ create_time: string; // 创建时间
137
+ isEnd: boolean; // 是否结束
138
+ is_delete: boolean; // 是否取消
139
+ update_time: string;
140
+ time: string; // 处理一下时间范围
141
+ cycle_sub: CycleSubItemT[];
142
+ live_url?: string;
143
+ type: CalendarDataType;
144
+ obs_data?: ObsDataItemT[]; // 回放数据
145
+ isExpired?: boolean; // 处理数据,是否过期
146
+ sub_id: string; // 处理数据,周期会议平铺之后的id
147
+ dateRange?: string; // 计算属性
148
+ hasObsData?: boolean; // 计算属性
149
+ }
150
+
151
+ export interface MeetingEventsItemT {
152
+ id: number;
153
+ title: string;
154
+ start_date: string;
155
+ end_date: string;
156
+ activity_type: number;
157
+ synopsis: string;
158
+ create_time: string;
159
+ address: string;
160
+ status: number;
161
+ sponsor: string;
162
+ is_delete: number;
163
+ start: string;
164
+ end: string;
165
+ register_url: string;
166
+ content_url: string;
167
+ live_url: null;
168
+ register_end_date: string;
169
+ update_activity_id: null;
170
+ approver: string;
171
+ organizer: string;
172
+ email_list: string;
173
+ dates?: string[]; // 处理数据,如果时跨天活动,有多个元素
174
+ type: CalendarDataType;
175
+ }
176
+
177
+ export interface SummitItemT {
178
+ id: string;
179
+ name: string;
180
+ url: string;
181
+ dates: string[];
182
+ location: string;
183
+ address: string;
184
+ start_date: string;
185
+ end_date: string;
186
+ start: string;
187
+ end: string;
188
+ activity_type: number;
189
+ type: CalendarDataType;
190
+ }
191
+
192
+ export interface PageParamsT {
193
+ page: number;
194
+ size: number;
195
+ }
196
+
197
+ export interface meetingTabT {
198
+ label: string;
199
+ value: CalendarDataType;
200
+ icon: any;
201
+ color?: string;
202
+ zIndex?: number;
203
+ }
204
+
205
+
206
+ // -------------------- 会议回放 --------------------
207
+ export interface MeetingPlaybackPropsDetailT {
208
+ topic: string; // 会议主题
209
+ date: string; // 会议日期
210
+ start: string; // 会议开始时间
211
+ end: string; // 会议结束时间
212
+ agenda: string; // 会议详情
213
+ sponsor: string; // 会议创建人
214
+ groupName: string; // 会议所属sig组
215
+ }
216
+
217
+ export interface MeetingPlaybackPropsDataT {
218
+ mid: string; // 会议ID
219
+ subId?: string; //子会议ID
220
+ textJson: string; // 字幕json文件
221
+ poster: string; // 封面
222
+ video: string; // 录屏
223
+ textVtt: string; // 字幕文件
224
+ topicJson: string; // 议题分段
225
+ }
226
+
227
+ export interface MeetingPlaybackPropsT {
228
+ dates: string[]; // 如果是周期会议,传入可选的日期
229
+ detail: MeetingPlaybackPropsDetailT; // 会议信息
230
+ data: MeetingPlaybackPropsDataT; // 回放信息
231
+ }
232
+
233
+ export interface SubjectItemT {
234
+ title: string; // 议题
235
+ startTime: string; // 议题开始时间 【时:分:秒】格式
236
+ endTime: string; // 议题结束时间 【时:分:秒】格式
237
+ startTimeNumber: number;
238
+ endTimeNumber: number;
239
+ }
240
+
241
+
242
+ export interface CaptionItemT {
243
+ ID: number; // 字幕id
244
+ start_time: string; // 字幕开始时间
245
+ end_time: string; // 字幕结束时间
246
+ speaker: string; // 发言人
247
+ content: string; // 发言内容
248
+ contentHtml: string; // 发言内容转html
249
+ speakerIdx: number; // 当前发言人索引
250
+ speakerLabel: string; // 发言人文案
251
+ }
252
+
253
+
254
+ export interface MeetingPlaybackVideoPropsT {
255
+ src: string; // 视频资源
256
+ vtt?: string; // 字幕资源
257
+ captions?: CaptionItemT[]; // 语言转文字json
258
+ poster?: string | null; // 封面图片
259
+ posterTitle?: string | null; // 封面文案
260
+ instance?: any; // 播放器实例
261
+ trackIdx: number; // 当前字幕索引
262
+ }
263
+
264
+ export interface MeetingPlaybackSubtitlesPropsT {
265
+ captions?: CaptionItemT[]; // 语言转文字json
266
+ instance?: any; // 播放器实例
267
+ trackIdx: number; // 当前字幕索引
268
+ }