@opendesign-plus/components 0.0.1-rc.6 → 0.0.1-rc.8

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 (138) hide show
  1. package/dist/chunk-OElCookieNotice.cjs.js +1 -0
  2. package/dist/chunk-OElCookieNotice.es.js +281 -0
  3. package/dist/components/OFooter.vue.d.ts +25 -0
  4. package/dist/components/OHeader.vue.d.ts +23 -0
  5. package/dist/components/OHeaderMoblie.vue.d.ts +33 -0
  6. package/dist/components/OHeaderUser.vue.d.ts +40 -0
  7. package/dist/components/OSourceCode.vue.d.ts +20 -0
  8. package/dist/components/events/OEventsApply.vue.d.ts +16 -0
  9. package/dist/components/events/OEventsCalendar.vue.d.ts +5 -0
  10. package/dist/components/events/OEventsList.vue.d.ts +26 -0
  11. package/dist/components/events/config.d.ts +27 -0
  12. package/dist/components/events/index.d.ts +78 -0
  13. package/dist/components/events/types.d.ts +66 -0
  14. package/dist/components/events/utils.d.ts +7 -0
  15. package/dist/components.cjs.js +3 -1
  16. package/dist/components.css +1 -1
  17. package/dist/components.element.cjs.js +1 -1
  18. package/dist/components.element.es.js +2 -214
  19. package/dist/components.es.js +3001 -444
  20. package/dist/index.d.ts +8 -1
  21. package/docs/design.md +27 -27
  22. package/docs/design_banner.md +41 -41
  23. package/docs/design_section.md +27 -27
  24. package/package.json +2 -1
  25. package/scripts/generate-components-index.js +99 -80
  26. package/src/assets/events/city/beijing.jpg +0 -0
  27. package/src/assets/events/city/chengdu.jpg +0 -0
  28. package/src/assets/events/city/default-cover.jpg +0 -0
  29. package/src/assets/events/city/guangzhou.jpg +0 -0
  30. package/src/assets/events/city/hangzhou.jpg +0 -0
  31. package/src/assets/events/city/nanjing.jpg +0 -0
  32. package/src/assets/events/city/shanghai.jpg +0 -0
  33. package/src/assets/events/city/shenzhen1.jpg +0 -0
  34. package/src/assets/events/city/shenzhen2.jpg +0 -0
  35. package/src/assets/events/city/suzhou.jpg +0 -0
  36. package/src/assets/events/city/tianjin.jpg +0 -0
  37. package/src/assets/events/city/wuhan.jpg +0 -0
  38. package/src/assets/events/city/wuxi.jpg +0 -0
  39. package/src/assets/events/city/xian.jpg +0 -0
  40. package/src/assets/events/city/zhengzhou.jpg +0 -0
  41. package/src/assets/events/svg-icons/icon-checked.svg +3 -0
  42. package/src/assets/events/svg-icons/icon-competition.svg +7 -0
  43. package/src/assets/events/svg-icons/icon-events.svg +4 -0
  44. package/src/assets/events/svg-icons/icon-release.svg +4 -0
  45. package/src/assets/events/svg-icons/icon-summit.svg +4 -0
  46. package/src/assets/svg-icons/icon-arrow-left.svg +3 -0
  47. package/src/assets/svg-icons/icon-avatar-line.svg +3 -0
  48. package/src/assets/svg-icons/icon-caret-left.svg +3 -0
  49. package/src/assets/svg-icons/icon-caret-right.svg +3 -0
  50. package/src/assets/svg-icons/icon-chevron-down.svg +3 -0
  51. package/src/assets/svg-icons/icon-chevron-right.svg +3 -3
  52. package/src/assets/svg-icons/icon-close.svg +3 -3
  53. package/src/assets/svg-icons/icon-delete.svg +3 -3
  54. package/src/assets/svg-icons/icon-header-back.svg +3 -3
  55. package/src/assets/svg-icons/icon-header-delete.svg +3 -3
  56. package/src/assets/svg-icons/icon-header-menu.svg +3 -0
  57. package/src/assets/svg-icons/icon-header-person.svg +3 -0
  58. package/src/assets/svg-icons/icon-header-search.svg +4 -4
  59. package/src/assets/svg-icons/icon-locale.svg +3 -0
  60. package/src/assets/svg-icons/icon-log-off.svg +3 -0
  61. package/src/assets/svg-icons/icon-message.svg +3 -0
  62. package/src/assets/svg-icons/icon-moon.svg +3 -3
  63. package/src/assets/svg-icons/icon-outlink.svg +3 -0
  64. package/src/assets/svg-icons/icon-overview.svg +3 -0
  65. package/src/assets/svg-icons/icon-setting.svg +3 -0
  66. package/src/assets/svg-icons/icon-sun.svg +3 -3
  67. package/src/components/OBanner.vue +390 -390
  68. package/src/components/OCookieNotice.vue +423 -423
  69. package/src/components/OFooter.vue +566 -0
  70. package/src/components/OHeader.vue +97 -0
  71. package/src/components/OHeaderMoblie.vue +149 -0
  72. package/src/components/OHeaderSearch.vue +601 -601
  73. package/src/components/OHeaderUser.vue +304 -0
  74. package/src/components/OPlusConfigProvider.vue +32 -32
  75. package/src/components/OSection.vue +178 -178
  76. package/src/components/OSourceCode.vue +153 -0
  77. package/src/components/OThemeSwitcher.vue +108 -108
  78. package/src/components/common/AppAvatar.vue +83 -0
  79. package/src/components/common/ClientOnlyWrapper.ts +21 -21
  80. package/src/components/common/ContentWrapper.vue +85 -85
  81. package/src/components/common/HeaderEulerNav.vue +1118 -0
  82. package/src/components/common/HeaderNavMoblie.vue +344 -0
  83. package/src/components/common/HeaderUbmcNav.vue +597 -0
  84. package/src/components/element-plus/OElCookieNotice.vue +412 -412
  85. package/src/components/element-plus/index.ts +3 -3
  86. package/src/components/events/OEventsApply.vue +487 -0
  87. package/src/components/events/OEventsCalendar.vue +613 -0
  88. package/src/components/events/OEventsList.vue +402 -0
  89. package/src/components/events/config.ts +49 -0
  90. package/src/components/events/index.ts +23 -0
  91. package/src/components/events/types.ts +80 -0
  92. package/src/components/events/utils.ts +9 -0
  93. package/src/components/meeting/npmcachae/_cacache/content-v2/sha512/3e/17/1865217b9acb9f4921c53a09b5c76587cd2ab748beb2699ff6cfb1341d73b1aa56ed91ffc5ab2c9c9b3fbe626103b35d9a79ff29ff6b8cbb8d89755fe1a2 +1 -0
  94. package/src/components/meeting/npmcachae/_cacache/content-v2/sha512/a6/15/47bb7552ec9248079e839a5feecc1742d4de19524fdf041cf581701cf4760a5025106036145e279ba193b07c8fa5b07ae3d75f1b6032f0cb2219115b6167 +1 -0
  95. package/src/components/meeting/npmcachae/_cacache/content-v2/sha512/d1/4c/133b32e09c97101a27a07cc4432f94e470cff02d120d21babcea77c3f5cd436793516dc1a8e282ee1a568f923c148b1a48f4a43233462a530d35e8b41c67 +1 -0
  96. package/src/components/meeting/npmcachae/_cacache/index-v5/54/0d/a4909047714a0a7198bb9bd37020992464e47c79a791889919b84d90aab0 +3 -0
  97. package/src/components/meeting/npmcachae/_cacache/index-v5/8e/2b/21a79778e2ac08cf5663baf83cb35f951995a496007eb2e2f7fba54021a4 +3 -0
  98. package/src/components/meeting/npmcachae/_cacache/index-v5/eb/a0/b70c8132e5b57a0f1e129b8cc941796420a9c147c0baa680710083740898 +2 -0
  99. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_03_54_955Z-debug-0.log +277 -0
  100. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_03_57_842Z-debug-0.log +277 -0
  101. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_04_00_016Z-debug-0.log +277 -0
  102. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_04_02_191Z-debug-0.log +277 -0
  103. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_04_04_425Z-debug-0.log +277 -0
  104. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_04_06_642Z-debug-0.log +277 -0
  105. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_04_08_826Z-debug-0.log +277 -0
  106. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_25_36_140Z-debug-0.log +433 -0
  107. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_25_39_573Z-debug-0.log +433 -0
  108. package/src/components/meeting/npmcachae/_logs/2026-03-20T07_25_42_134Z-debug-0.log +212 -0
  109. package/src/components/meeting/npmcachae/_update-notifier-last-checked +0 -0
  110. package/src/draft/Banner.vue +265 -265
  111. package/src/draft/ButtonCards.vue +105 -105
  112. package/src/draft/Feature.vue +133 -133
  113. package/src/draft/Footer.vue +512 -512
  114. package/src/draft/HorizontalAnchor.vue +165 -165
  115. package/src/draft/ItemSwiper.vue +133 -133
  116. package/src/draft/Logo.vue +141 -141
  117. package/src/draft/LogoCard.vue +74 -74
  118. package/src/draft/LogoV2.vue +19 -19
  119. package/src/draft/MainCard.vue +38 -38
  120. package/src/draft/MultiCard.vue +94 -94
  121. package/src/draft/MultiIconCard.vue +73 -73
  122. package/src/draft/OInfoCard.vue +176 -176
  123. package/src/draft/Process.vue +81 -81
  124. package/src/draft/Section.vue +167 -167
  125. package/src/draft/SingleTabCard.vue +84 -84
  126. package/src/draft/SliderCard.vue +110 -110
  127. package/src/env.d.ts +1 -1
  128. package/src/i18n/en.ts +20 -20
  129. package/src/i18n/index.ts +42 -42
  130. package/src/i18n/zh.ts +14 -9
  131. package/src/index.ts +15 -1
  132. package/src/shared/provide.ts +6 -6
  133. package/src/shims-vue-dompurify-html.d.ts +17 -0
  134. package/src/vue.d.ts +9 -9
  135. package/tsconfig.json +33 -33
  136. package/vite.config.ts +102 -101
  137. package/dist/chunk-index.cjs.js +0 -1
  138. package/dist/chunk-index.es.js +0 -64
@@ -0,0 +1,402 @@
1
+ <script setup lang="ts">
2
+ import {
3
+ OCard,
4
+ ODivider,
5
+ OIcon,
6
+ OIconSearch,
7
+ OInput, OPagination,
8
+ ORadio,
9
+ ORadioGroup,
10
+ OTag,
11
+ OToggle,
12
+ } from '@opensig/opendesign';
13
+ import { computed, ref } from 'vue';
14
+ import { type EventsCardItemT, EventsStatusT, type EventsListPropsT, SearchParamsT } from './types';
15
+ import { compareDate } from './utils.ts';
16
+ import { useI18n } from '@/i18n';
17
+ import defaultCover from '@/assets/events/city/default-cover.jpg';
18
+ import { CITY_MAP } from './config.ts';
19
+ import { useScreen } from '@opendesign-plus/composables';
20
+
21
+ const { t } = useI18n();
22
+ const { lePadV } = useScreen();
23
+
24
+ const props = withDefaults(
25
+ defineProps<EventsListPropsT>(),
26
+ {
27
+ data: () => [],
28
+ },
29
+ );
30
+
31
+ interface StatusOptionT {
32
+ label: string;
33
+ value: EventsStatusT;
34
+ }
35
+
36
+ const statusOptions: StatusOptionT[] = [
37
+ {
38
+ label: t('events.statusAll'),
39
+ value: EventsStatusT.ALL,
40
+ },
41
+ {
42
+ label: t('events.statusIng'),
43
+ value: EventsStatusT.ING,
44
+ },
45
+ {
46
+ label: t('events.statusFinish'),
47
+ value: EventsStatusT.FINISH,
48
+ },
49
+ ];
50
+
51
+ defineSlots<{
52
+ empty?: () => any;
53
+ }>();
54
+
55
+ const emits = defineEmits<{
56
+ (e: 'search', params: SearchParamsT): void;
57
+ }>();
58
+ const status = ref<EventsStatusT>(EventsStatusT.ALL);
59
+ const input = ref('');
60
+ const keyword = ref('');
61
+
62
+ const emitSearch = (params = {}) => {
63
+ emits(
64
+ 'search',
65
+ Object.assign(
66
+ {
67
+ page: props.page,
68
+ pageSize: props.pageSize,
69
+ status: status.value,
70
+ keyword: keyword.value,
71
+ },
72
+ params,
73
+ ),
74
+ );
75
+ };
76
+
77
+ const changeStatus = () => {
78
+ emitSearch();
79
+ };
80
+ const changeKeyword = () => {
81
+ keyword.value = input.value;
82
+ emitSearch();
83
+ };
84
+ const list = computed(() => {
85
+ return props.data
86
+ .map((v: EventsCardItemT) => {
87
+ return {
88
+ ...v,
89
+ status: !compareDate(new Date(), v.date as string) ? EventsStatusT.ING : EventsStatusT.FINISH,
90
+ };
91
+ })
92
+ .sort((a: EventsCardItemT, b: EventsCardItemT) => (compareDate(a.date as string, b.date as string) ? -1 : 1))
93
+ .map((v) => {
94
+ const city = v.city?.replace('市', '')?.replace('中国', '')?.replaceAll(' ', '');
95
+ let cover = null;
96
+
97
+ if (Array.isArray(CITY_MAP[city])) {
98
+ cover = CITY_MAP[city][v.name.length % CITY_MAP[city].length];
99
+ } else {
100
+ cover = CITY_MAP[city];
101
+ }
102
+ if (!cover) {
103
+ cover = defaultCover;
104
+ }
105
+ return {
106
+ ...v,
107
+ cover,
108
+ };
109
+ });
110
+ });
111
+ </script>
112
+
113
+ <template>
114
+ <div class="o-events-list">
115
+ <div class="filter-wrapper">
116
+ <div class="filter-left">
117
+ <span>{{ t('events.status') }}</span>
118
+ <ORadioGroup v-model="status" :style="{ '--radio-group-gap': '8px' }" @change="changeStatus">
119
+ <ORadio v-for="t in statusOptions" :key="t.value" :value="t.value">
120
+ <template #radio="{ checked }">
121
+ <OToggle :checked="checked">{{ t.label }}</OToggle>
122
+ </template>
123
+ </ORadio>
124
+ </ORadioGroup>
125
+ </div>
126
+ <OInput
127
+ v-model="input"
128
+ :placeholder="t('events.searchPlaceholder')"
129
+ @pressEnter="changeKeyword"
130
+ @clear="changeKeyword"
131
+ clearable>
132
+ <template #prefix>
133
+ <OIcon class="input-icon">
134
+ <OIconSearch />
135
+ </OIcon>
136
+ </template>
137
+ </OInput>
138
+ </div>
139
+ <div class="list-content">
140
+ <OCard v-for="item in list" :key="item.name" :cover="item.cover" :href="item.link">
141
+ <OTag class="event-status">
142
+ {{ item.status === EventsStatusT.ING ? t('events.statusIng') : t('events.statusFinish') }}
143
+ </OTag>
144
+ <div class="event-name">{{ item.name }}</div>
145
+ <div class="event-desc">
146
+ <div class="event-date">{{ item.date }}</div>
147
+ <ODivider direction="v" />
148
+ <div class="event-location" v-if="item.city">{{ item.city }}</div>
149
+ </div>
150
+ </OCard>
151
+ </div>
152
+ <template v-if="!list.length">
153
+ <slot name="empty"></slot>
154
+ </template>
155
+ <OPagination
156
+ v-if="total > 8"
157
+ :page="page"
158
+ :simple="lePadV"
159
+ :show-total="true"
160
+ :pageSize="pageSize"
161
+ :total="total"
162
+ @change="emitSearch"
163
+ :pageSizes="[4, 12, 24, 36, 48]"
164
+ />
165
+ </div>
166
+ </template>
167
+
168
+ <style lang="scss">
169
+ .o-events-list {
170
+ .filter-wrapper {
171
+ display: flex;
172
+ align-items: center;
173
+ flex-wrap: wrap;
174
+ justify-content: space-between;
175
+ background-color: var(--o-color-fill2);
176
+ border-radius: var(--o-radius-xs);
177
+ padding: var(--o-gap-5) var(--o-gap-6);
178
+ gap: var(--o-gap-3) var(--o-gap-2);
179
+ @include respond-to('laptop') {
180
+ padding: var(--o-gap-4) var(--o-gap-5);
181
+ }
182
+ @include respond-to('pad_h') {
183
+ padding: var(--o-gap-4) var(--o-gap-5);
184
+ }
185
+ @include respond-to('pad_v') {
186
+ padding: var(--o-gap-3) var(--o-gap-4);
187
+ }
188
+ @include respond-to('phone') {
189
+ padding: var(--o-gap-3) var(--o-gap-4);
190
+ }
191
+ @include text1;
192
+
193
+ .filter-left {
194
+ display: flex;
195
+ align-items: center;
196
+ gap: var(--o-gap-2);
197
+ flex-wrap: wrap;
198
+
199
+ span:first-child {
200
+ flex-shrink: 0;
201
+ margin-right: var(--o-gap-5);
202
+ font-weight: 500;
203
+ @include respond-to('laptop') {
204
+ margin-right: var(--o-gap-4);
205
+ }
206
+ @include respond-to('pad_h') {
207
+ margin-right: var(--o-gap-3);
208
+ }
209
+ @include respond-to('pad_v') {
210
+ margin-right: var(--o-gap-4);
211
+ }
212
+ @include respond-to('phone') {
213
+ margin-right: var(--o-gap-4);
214
+ }
215
+ }
216
+
217
+ .o-toggle {
218
+ --toggle-size: 32px;
219
+ --toggle-padding: 3px 15px;
220
+ --toggle-radius: 4px;
221
+ max-height: 32px;
222
+ --toggle-bg-color: var(--o-color-fill1);
223
+ --toggle-bg-color-hover: var(--o-color-control2-light);
224
+ --toggle-color: var(--o-color-info1);
225
+ --toggle-color-hover: var(--o-color-info1);
226
+ --toggle-color-active: var(--o-color-primary1);
227
+ --toggle-color-disabled: var(--o-color-info4);
228
+ @include text1;
229
+ }
230
+ }
231
+
232
+ .o-input {
233
+ .o-icon-search {
234
+ font-size: 24px;
235
+ @include respond-to('<=pad_v') {
236
+ font-size: 16px;
237
+ }
238
+ }
239
+ }
240
+ }
241
+ .list-content {
242
+ display: grid;
243
+ grid-template-columns: repeat(4, 1fr);
244
+ gap: var(--o-gap-6);
245
+ margin-top: var(--o-gap-6);
246
+ @include respond-to('<=pad_v') {
247
+ grid-template-columns: repeat(1, 1fr);
248
+ }
249
+ @include respond-to('laptop') {
250
+ margin-top: var(--o-gap-5);
251
+ gap: var(--o-gap-5);
252
+ }
253
+ @include respond-to('pad_h') {
254
+ margin-top: var(--o-gap-4);
255
+ gap: var(--o-gap-4);
256
+ }
257
+ @include respond-to('pad_v') {
258
+ margin-top: var(--o-gap-4);
259
+ gap: var(--o-gap-3);
260
+ }
261
+ @include respond-to('phone') {
262
+ margin-top: var(--o-gap-4);
263
+ gap: var(--o-gap-3);
264
+ }
265
+
266
+ .o-card {
267
+ aspect-ratio: 1 / 1;
268
+ position: relative;
269
+ @include respond-to('<=pad_v') {
270
+ aspect-ratio: 1 / 0.4;
271
+ }
272
+
273
+ .o-card-cover {
274
+ padding: 0;
275
+ }
276
+
277
+ .o-card-content {
278
+ display: flex;
279
+ flex-direction: column;
280
+ align-items: center;
281
+ justify-content: center;
282
+ position: absolute;
283
+ overflow: hidden; // 防止内容溢出
284
+ box-sizing: border-box; // 确保 padding 计入总尺寸
285
+ left: 0;
286
+ top: 0;
287
+ width: 100%;
288
+ height: 100%;
289
+ color: var(--o-color-white);
290
+ text-align: center;
291
+ cursor: pointer;
292
+ padding: var(--o-gap-6);
293
+ z-index: 10;
294
+
295
+ @include respond-to('laptop') {
296
+ margin-top: var(--o-gap-5);
297
+ }
298
+ @include respond-to('pad_h') {
299
+ margin-top: var(--o-gap-4);
300
+ }
301
+ @include respond-to('pad_v') {
302
+ margin-top: var(--o-gap-4);
303
+ }
304
+ @include respond-to('phone') {
305
+ margin-top: var(--o-gap-4);
306
+ }
307
+
308
+ .event-status {
309
+ --tag-color: rgb(var(--o-white));
310
+ --tag-bg-color: rgba(var(--o-black), 0.25);
311
+ --tag-padding: var(--o-gap-1) var(--o-gap-3);
312
+ border: none;
313
+ position: absolute;
314
+ top: var(--o-gap-3);
315
+ right: var(--o-gap-3);
316
+ @include respond-to('<=pad_v') {
317
+ --tag-padding: var(--o-gap-1);
318
+ }
319
+ }
320
+
321
+ .event-name {
322
+ font-weight: 500;
323
+ text-align: center;
324
+ height: 3lh; // 3倍行高
325
+ @include h2;
326
+ @include text-truncate(3);
327
+ @include respond-to('pad_v') {
328
+ @include h1;
329
+ }
330
+ @include respond-to('phone') {
331
+ height: 2lh;
332
+ @include text-truncate(2);
333
+ }
334
+ }
335
+
336
+ .event-desc {
337
+ text-align: center;
338
+ font-weight: 500;
339
+ margin-top: var(--o-gap-5);
340
+
341
+ .o-divider {
342
+ --o-divider-color: var(--o-color-info1-inverse);
343
+ --o-divider-bd-color: var(--o-color-info1-inverse);
344
+ display: none;
345
+ }
346
+
347
+ @include text1;
348
+ @include respond-to('laptop') {
349
+ margin-top: var(--o-gap-4);
350
+ }
351
+ @include respond-to('pad_h') {
352
+ margin-top: var(--o-gap-3);
353
+ }
354
+ @include respond-to('pad_v') {
355
+ margin-top: var(--o-gap-2);
356
+ }
357
+ @include respond-to('phone') {
358
+ margin-top: var(--o-gap-2);
359
+ }
360
+ @include respond-to('<=pad_v') {
361
+ display: flex;
362
+ align-items: center;
363
+ .o-divider {
364
+ display: block;
365
+ }
366
+ @include tip1;
367
+ }
368
+ }
369
+ }
370
+ }
371
+
372
+ .event-card {
373
+ border-radius: var(--o-radius-xs);
374
+ color: rgb(var(--o-white));
375
+ background-size: cover;
376
+ background-repeat: no-repeat;
377
+ }
378
+ }
379
+
380
+ .o-pagination {
381
+ margin-top: var(--o-gap-6);
382
+
383
+ @include respond-to('laptop') {
384
+ margin-top: var(--o-gap-5);
385
+ }
386
+ @include respond-to('pad_h') {
387
+ margin-top: var(--o-gap-4);
388
+ }
389
+ @include respond-to('pad_v') {
390
+ margin-top: var(--o-gap-4);
391
+ }
392
+ @include respond-to('phone') {
393
+ margin-top: var(--o-gap-4);
394
+ }
395
+
396
+ .o-pagination-wrap {
397
+ justify-content: flex-end;
398
+ }
399
+ }
400
+
401
+ }
402
+ </style>
@@ -0,0 +1,49 @@
1
+ import IconSummit from '~icons/events/icon-summit.svg';
2
+ import IconEvents from '~icons/events/icon-events.svg';
3
+ import IconCompetition from '~icons/events/icon-competition.svg';
4
+ import IconRelease from '~icons/events/icon-release.svg';
5
+
6
+ import 上海 from '@/assets/events/city/shanghai.jpg';
7
+ import 北京 from '@/assets/events/city/beijing.jpg';
8
+ import 南京 from '@/assets/events/city/nanjing.jpg';
9
+ import 天津 from '@/assets/events/city/tianjin.jpg';
10
+ import 成都 from '@/assets/events/city/chengdu.jpg';
11
+ import 无锡 from '@/assets/events/city/wuxi.jpg';
12
+ import 杭州 from '@/assets/events/city/hangzhou.jpg';
13
+ import 深圳1 from '@/assets/events/city/shenzhen1.jpg';
14
+ import 深圳2 from '@/assets/events/city/shenzhen2.jpg';
15
+ import 苏州 from '@/assets/events/city/suzhou.jpg';
16
+ import 西安 from '@/assets/events/city/xian.jpg';
17
+ import 郑州 from '@/assets/events/city/zhengzhou.jpg';
18
+ import 武汉 from '@/assets/events/city/wuhan.jpg';
19
+ import 广州 from '@/assets/events/city/guangzhou.jpg';
20
+
21
+ export const EVENTS_COLOR_MAP = {
22
+ summit: '--o-orange-6',
23
+ events: '--o-cyan-6',
24
+ competition: '--o-blue-6',
25
+ release: '--o-purple-6',
26
+ };
27
+
28
+ export const EVENTS_ICON_MAP = {
29
+ events: IconEvents,
30
+ competition: IconCompetition,
31
+ release: IconRelease,
32
+ summit: IconSummit,
33
+ };
34
+
35
+ export const CITY_MAP = {
36
+ 上海,
37
+ 北京,
38
+ 南京,
39
+ 天津,
40
+ 成都,
41
+ 无锡,
42
+ 杭州,
43
+ 深圳: [深圳1, 深圳2],
44
+ 苏州,
45
+ 西安,
46
+ 郑州,
47
+ 武汉,
48
+ 广州,
49
+ };
@@ -0,0 +1,23 @@
1
+ import _OEventsCalendar from './OEventsCalendar.vue';
2
+ import _OEventsList from './OEventsList.vue';
3
+ import _OEventsApply from './OEventsApply.vue';
4
+ import type { App } from 'vue';
5
+
6
+ const OEventsCalendar = Object.assign(_OEventsCalendar, {
7
+ install(app: App) {
8
+ app.component('OEventsCalendar', _OEventsCalendar);
9
+ },
10
+ });
11
+ const OEventsList = Object.assign(_OEventsList, {
12
+ install(app: App) {
13
+ app.component('OEventsList', _OEventsList);
14
+ },
15
+ });
16
+ const OEventsApply = Object.assign(_OEventsApply, {
17
+ install(app: App) {
18
+ app.component('OEventsApply', _OEventsApply);
19
+ },
20
+ });
21
+
22
+ export { OEventsCalendar, OEventsList, OEventsApply };
23
+ export * from './types';
@@ -0,0 +1,80 @@
1
+ type EventsTextAlignT = 'center' | 'left';
2
+
3
+ export enum EventsStatusT {
4
+ FINISH = 'finish',
5
+ ING = 'ing',
6
+ ALL = ''
7
+ }
8
+
9
+
10
+ export interface EventsItemT {
11
+ name: string; // 事件名称
12
+ date: string | [string, string]; // 事件日期, "YYYY/MM/DD" 或 ["YYYY/MM/DD", "YYYY/MM/DD"]
13
+ location?: string; // 事件地点
14
+ link?: string; // 跳转链接
15
+ linkProps?: {
16
+ [key: string]: string | boolean;
17
+ },
18
+ align?: EventsTextAlignT; // 文本居中方式
19
+ cover?: string; // 事件背景,作为列表卡片形式时使用
20
+ status?: EventsStatusT; // 事件状态,作为列表卡片形式时使用,不传递,组件内部通过date计算得出
21
+ }
22
+
23
+ export type EventsTypeT = 'summit' | 'events' | 'competition' | 'release';
24
+
25
+ export interface CalendarItemT {
26
+ name: string; // 分组标题
27
+ desc?: string; // 分组描述,可选,支持传递html片段
28
+ type: EventsTypeT; // 分组类型,决定颜色和图标
29
+ color?: string; // 分组颜色,可选,如果没有传递由type决定, RGB格式: "255, 0, 0",包括图标背景和事件背景
30
+ icon?: string; // 分组图标,可选,如果没有传递由type决定,白色线性,背景由颜色决定
31
+ data: EventsItemT[];
32
+ isSpanMonth?: boolean; // 是否包含跨月事件,为true时date需要是[string, string]
33
+ }
34
+
35
+ export interface StepItemT {
36
+ title: string; // 标题
37
+ desc?: string; // 描述,支持HTML片段
38
+ img?: string; // 插图
39
+ imgPhone?: string; // 移动端插图
40
+ listTitle?: string; // 列表标题
41
+ list: Array<{
42
+ title: string; // 列表项标题
43
+ desc?: string; // 列表项描述
44
+ }>;
45
+ }
46
+
47
+ // 活动列表
48
+ export interface EventsCardItemT {
49
+ name: string; // 事件名称
50
+ date: string; // 事件日期
51
+ city: string; // 事件城市
52
+ cover?: string; // 卡片封面,如果不传递,组件内部通过date计算得出
53
+ status?: EventsStatusT; // 事件状态,不传递,组件内部通过date计算得出
54
+ link: string; // 跳转链接
55
+ }
56
+
57
+
58
+ // 组件 Props 类型定义
59
+ export interface EventsApplyPropsT {
60
+ steps: StepItemT[];
61
+ }
62
+
63
+ export interface EventsListPropsT {
64
+ data: EventsCardItemT[]; // 活动列表数据
65
+ page: number; // 当前页码
66
+ pageSize: number; // 当前每页个数
67
+ total: number; // 活动总计个数
68
+ }
69
+
70
+ export interface EventsCalendarPropsT {
71
+ data: CalendarItemT[];
72
+ }
73
+
74
+ // OEventList 组件搜索事件参数
75
+ export interface SearchParamsT {
76
+ page: number; // 页码
77
+ pageSize: number; // 每页数量
78
+ status: EventsStatusT; // 状态
79
+ keyword: string; // 关键词
80
+ }
@@ -0,0 +1,9 @@
1
+ /**
2
+ * 比较两个日期字符串的先后顺序
3
+ * @param dateA - 第一个日期字符串
4
+ * @param dateB - 第二个日期字符串
5
+ * @returns 如果 dateA 晚于 dateB 返回 true,否则返回 false
6
+ */
7
+ export const compareDate = (dateA: string | Date, dateB: string | Date): boolean => {
8
+ return new Date(dateA).getTime() > new Date(dateB).getTime();
9
+ };