mall-components 1.0.0

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 (122) hide show
  1. package/README.md +128 -0
  2. package/build/_components-raw.css +791 -0
  3. package/build/_shims/antd.js +1 -0
  4. package/build/_shims/icons.js +1 -0
  5. package/build/_shims/moment.js +1 -0
  6. package/build/_shims/react-dom.js +1 -0
  7. package/build/_shims/react.js +1 -0
  8. package/build/adapters/DataSourceAdapter.d.ts +46 -0
  9. package/build/components/AdminLayout/AdminLayout.d.ts +5 -0
  10. package/build/components/AdminLayout/Breadcrumb.d.ts +8 -0
  11. package/build/components/AdminLayout/MainContent.d.ts +17 -0
  12. package/build/components/AdminLayout/Navbar.d.ts +10 -0
  13. package/build/components/AdminLayout/Sidebar.d.ts +14 -0
  14. package/build/components/AdminLayout/TabBar.d.ts +13 -0
  15. package/build/components/AdminLayout/TabPane.d.ts +4 -0
  16. package/build/components/AdminLayout/index.d.ts +3 -0
  17. package/build/components/AdminLayout/types.d.ts +42 -0
  18. package/build/components/CouponCard/CouponCard.d.ts +20 -0
  19. package/build/components/CouponCard/index.d.ts +1 -0
  20. package/build/components/OrderForm/OrderForm.d.ts +18 -0
  21. package/build/components/OrderForm/index.d.ts +1 -0
  22. package/build/components/OrderList/OrderList.d.ts +29 -0
  23. package/build/components/OrderList/index.d.ts +1 -0
  24. package/build/components/ProductForm/ProductForm.d.ts +18 -0
  25. package/build/components/ProductForm/index.d.ts +3 -0
  26. package/build/components/ProductList/ProductList.d.ts +47 -0
  27. package/build/components/ProductList/index.d.ts +3 -0
  28. package/build/components/PromotionCard/PromotionCard.d.ts +22 -0
  29. package/build/components/PromotionCard/index.d.ts +1 -0
  30. package/build/components/RoleCard/RoleCard.d.ts +18 -0
  31. package/build/components/RoleCard/index.d.ts +1 -0
  32. package/build/components/UserCard/UserCard.d.ts +17 -0
  33. package/build/components/UserCard/index.d.ts +1 -0
  34. package/build/entry-meta.d.ts +603 -0
  35. package/build/index.css +1 -0
  36. package/build/index.js +1 -0
  37. package/build/mall-components-meta.js +2563 -0
  38. package/build/mall-components.cdn.umd.css +1 -0
  39. package/build/mall-components.cdn.umd.js +8 -0
  40. package/build/mall-components.codesandbox.combined.js +1094 -0
  41. package/build/mall-components.codesandbox.css +401 -0
  42. package/build/mall-components.codesandbox.js +1080 -0
  43. package/build/mall-components.umd.css +1 -0
  44. package/build/mall-components.umd.js +8 -0
  45. package/build/meta/adminLayoutMeta.d.ts +3 -0
  46. package/build/meta/couponCardMeta.d.ts +128 -0
  47. package/build/meta/icons.d.ts +10 -0
  48. package/build/meta/orderFormMeta.d.ts +111 -0
  49. package/build/meta/orderListMeta.d.ts +170 -0
  50. package/build/meta/productFormMeta.d.ts +3 -0
  51. package/build/meta/productListMeta.d.ts +200 -0
  52. package/build/meta/promotionCardMeta.d.ts +129 -0
  53. package/build/meta/roleCardMeta.d.ts +3 -0
  54. package/build/meta/tabPaneMeta.d.ts +3 -0
  55. package/build/meta/userCardMeta.d.ts +3 -0
  56. package/build/meta.d.ts +605 -0
  57. package/build/setters/RestApiTester.d.ts +11 -0
  58. package/build/types/common.d.ts +17 -0
  59. package/build/types/marketing.d.ts +128 -0
  60. package/build/types/order.d.ts +174 -0
  61. package/build/types/permission.d.ts +101 -0
  62. package/build/types/product.d.ts +47 -0
  63. package/package.json +1 -0
  64. package/src/adapters/DataSourceAdapter.ts +445 -0
  65. package/src/components/AdminLayout/AdminLayout.scss +447 -0
  66. package/src/components/AdminLayout/AdminLayout.tsx +681 -0
  67. package/src/components/AdminLayout/Breadcrumb.tsx +60 -0
  68. package/src/components/AdminLayout/MainContent.tsx +54 -0
  69. package/src/components/AdminLayout/Navbar.tsx +76 -0
  70. package/src/components/AdminLayout/Sidebar.tsx +256 -0
  71. package/src/components/AdminLayout/TabBar.tsx +177 -0
  72. package/src/components/AdminLayout/TabPane.tsx +29 -0
  73. package/src/components/AdminLayout/index.ts +3 -0
  74. package/src/components/AdminLayout/types.ts +46 -0
  75. package/src/components/CouponCard/CouponCard.scss +55 -0
  76. package/src/components/CouponCard/CouponCard.tsx +687 -0
  77. package/src/components/CouponCard/index.ts +1 -0
  78. package/src/components/OrderForm/OrderForm.scss +148 -0
  79. package/src/components/OrderForm/OrderForm.tsx +503 -0
  80. package/src/components/OrderForm/index.ts +1 -0
  81. package/src/components/OrderList/OrderList.scss +160 -0
  82. package/src/components/OrderList/OrderList.tsx +885 -0
  83. package/src/components/OrderList/index.ts +1 -0
  84. package/src/components/ProductForm/ProductForm.scss +23 -0
  85. package/src/components/ProductForm/ProductForm.tsx +442 -0
  86. package/src/components/ProductForm/index.ts +3 -0
  87. package/src/components/ProductList/ProductList.scss +293 -0
  88. package/src/components/ProductList/ProductList.tsx +454 -0
  89. package/src/components/ProductList/index.ts +3 -0
  90. package/src/components/PromotionCard/PromotionCard.scss +71 -0
  91. package/src/components/PromotionCard/PromotionCard.tsx +579 -0
  92. package/src/components/PromotionCard/index.ts +1 -0
  93. package/src/components/RoleCard/RoleCard.scss +77 -0
  94. package/src/components/RoleCard/RoleCard.tsx +463 -0
  95. package/src/components/RoleCard/index.ts +1 -0
  96. package/src/components/UserCard/UserCard.scss +51 -0
  97. package/src/components/UserCard/UserCard.tsx +432 -0
  98. package/src/components/UserCard/index.ts +1 -0
  99. package/src/entry-components.ts +39 -0
  100. package/src/entry-meta.ts +23 -0
  101. package/src/index.scss +4 -0
  102. package/src/index.ts +36 -0
  103. package/src/index.tsx +17 -0
  104. package/src/meta/adminLayoutMeta.ts +154 -0
  105. package/src/meta/couponCardMeta.ts +287 -0
  106. package/src/meta/icons.ts +41 -0
  107. package/src/meta/orderFormMeta.ts +279 -0
  108. package/src/meta/orderListMeta.ts +443 -0
  109. package/src/meta/productFormMeta.ts +253 -0
  110. package/src/meta/productListMeta.ts +434 -0
  111. package/src/meta/promotionCardMeta.ts +276 -0
  112. package/src/meta/roleCardMeta.ts +142 -0
  113. package/src/meta/tabPaneMeta.ts +69 -0
  114. package/src/meta/userCardMeta.ts +128 -0
  115. package/src/meta.ts +25 -0
  116. package/src/setters/RestApiTester.tsx +219 -0
  117. package/src/shims/require.js +8 -0
  118. package/src/types/common.ts +19 -0
  119. package/src/types/marketing.ts +124 -0
  120. package/src/types/order.ts +169 -0
  121. package/src/types/permission.ts +102 -0
  122. package/src/types/product.ts +49 -0
@@ -0,0 +1,401 @@
1
+ /* src/components/AdminLayout/AdminLayout.scss */
2
+ .admin-layout {
3
+ display: flex;
4
+ height: 100vh;
5
+ width: 100%;
6
+ overflow: hidden;
7
+ background-color: #f0f2f5;
8
+ .sidebar-container {
9
+ width: 256px;
10
+ height: 100vh;
11
+ background:
12
+ linear-gradient(
13
+ 180deg,
14
+ #001529 0%,
15
+ #002140 100%);
16
+ transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
17
+ overflow-y: auto;
18
+ overflow-x: hidden;
19
+ flex-shrink: 0;
20
+ z-index: 10;
21
+ box-shadow: 2px 0 8px rgba(0, 0, 0, 0.15);
22
+ &::-webkit-scrollbar {
23
+ width: 6px;
24
+ }
25
+ &::-webkit-scrollbar-thumb {
26
+ background: rgba(255, 255, 255, 0.2);
27
+ border-radius: 3px;
28
+ &:hover {
29
+ background: rgba(255, 255, 255, 0.3);
30
+ }
31
+ }
32
+ .sidebar-logo {
33
+ height: 64px;
34
+ display: flex;
35
+ align-items: center;
36
+ justify-content: center;
37
+ padding: 16px;
38
+ border-bottom: 1px solid rgba(255, 255, 255, 0.1);
39
+ background: rgba(255, 255, 255, 0.02);
40
+ .logo-text {
41
+ color: #fff;
42
+ font-size: 20px;
43
+ font-weight: 600;
44
+ white-space: nowrap;
45
+ letter-spacing: 1px;
46
+ }
47
+ .logo-icon {
48
+ color: #fff;
49
+ font-size: 24px;
50
+ font-weight: bold;
51
+ }
52
+ }
53
+ .ant-menu {
54
+ border-right: none !important;
55
+ background: transparent !important;
56
+ .ant-menu-item {
57
+ margin: 0;
58
+ border-radius: 0;
59
+ height: 48px;
60
+ line-height: 48px;
61
+ padding-left: 24px !important;
62
+ margin: 0 0 4px 0;
63
+ &:first-child {
64
+ margin-top: 8px;
65
+ }
66
+ &:hover {
67
+ background: rgba(255, 255, 255, 0.08) !important;
68
+ color: #fff !important;
69
+ }
70
+ &.ant-menu-item-selected {
71
+ background:
72
+ linear-gradient(
73
+ 90deg,
74
+ #1890ff 0%,
75
+ #096dd9 100%) !important;
76
+ color: #fff !important;
77
+ box-shadow: 0 2px 8px rgba(24, 144, 255, 0.3);
78
+ &::after {
79
+ display: none;
80
+ }
81
+ }
82
+ }
83
+ .ant-menu-submenu {
84
+ .ant-menu-submenu-title {
85
+ height: 48px;
86
+ line-height: 48px;
87
+ padding-left: 24px !important;
88
+ margin: 0 0 4px 0;
89
+ &:hover {
90
+ background: rgba(255, 255, 255, 0.08) !important;
91
+ color: #fff !important;
92
+ }
93
+ }
94
+ &.ant-menu-submenu-selected > .ant-menu-submenu-title {
95
+ color: #1890ff !important;
96
+ }
97
+ .ant-menu-sub {
98
+ background: rgba(0, 0, 0, 0.2) !important;
99
+ .ant-menu-item {
100
+ height: 44px;
101
+ line-height: 44px;
102
+ padding-left: 48px !important;
103
+ &:hover {
104
+ background: rgba(255, 255, 255, 0.05) !important;
105
+ }
106
+ &.ant-menu-item-selected {
107
+ background: rgba(24, 144, 255, 0.15) !important;
108
+ color: #1890ff !important;
109
+ box-shadow: none;
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+ &.collapsed {
116
+ width: 80px;
117
+ .ant-menu-inline-collapsed {
118
+ width: 80px;
119
+ }
120
+ .sidebar-logo {
121
+ padding: 12px;
122
+ }
123
+ .ant-menu-item {
124
+ padding-left: 0 !important;
125
+ text-align: center;
126
+ }
127
+ }
128
+ }
129
+ .layout-right {
130
+ flex: 1;
131
+ display: flex;
132
+ flex-direction: column;
133
+ overflow: hidden;
134
+ min-width: 0;
135
+ .navbar-container {
136
+ height: 64px;
137
+ background: #fff;
138
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
139
+ display: flex;
140
+ align-items: center;
141
+ justify-content: space-between;
142
+ padding: 0 24px;
143
+ z-index: 9;
144
+ flex-shrink: 0;
145
+ .navbar-left {
146
+ display: flex;
147
+ align-items: center;
148
+ gap: 16px;
149
+ .hamburger-btn {
150
+ width: 40px;
151
+ height: 40px;
152
+ border: none;
153
+ background: transparent;
154
+ cursor: pointer;
155
+ display: flex;
156
+ align-items: center;
157
+ justify-content: center;
158
+ border-radius: 8px;
159
+ font-size: 18px;
160
+ color: rgba(0, 0, 0, 0.65);
161
+ transition: all 0.3s;
162
+ &:hover {
163
+ background: rgba(24, 144, 255, 0.08);
164
+ color: #1890ff;
165
+ }
166
+ }
167
+ }
168
+ .navbar-right {
169
+ .user-info {
170
+ cursor: pointer;
171
+ display: flex;
172
+ align-items: center;
173
+ gap: 8px;
174
+ padding: 8px 12px;
175
+ border-radius: 8px;
176
+ transition: all 0.3s;
177
+ &:hover {
178
+ background: rgba(0, 0, 0, 0.04);
179
+ }
180
+ .user-avatar {
181
+ background:
182
+ linear-gradient(
183
+ 135deg,
184
+ #1890ff 0%,
185
+ #096dd9 100%);
186
+ }
187
+ .username {
188
+ color: rgba(0, 0, 0, 0.85);
189
+ font-size: 14px;
190
+ font-weight: 500;
191
+ }
192
+ }
193
+ }
194
+ }
195
+ .main-content {
196
+ flex: 1;
197
+ display: flex;
198
+ flex-direction: column;
199
+ overflow: hidden;
200
+ background: #f0f2f5;
201
+ .tab-bar-container {
202
+ background: #fff;
203
+ display: flex;
204
+ align-items: center;
205
+ border-bottom: 1px solid #e8e8e8;
206
+ padding: 0 16px;
207
+ height: 44px;
208
+ flex-shrink: 0;
209
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
210
+ .tab-bar-scroll {
211
+ flex: 1;
212
+ overflow-x: auto;
213
+ overflow-y: hidden;
214
+ white-space: nowrap;
215
+ display: flex;
216
+ align-items: center;
217
+ gap: 8px;
218
+ scrollbar-width: thin;
219
+ &::-webkit-scrollbar {
220
+ height: 4px;
221
+ }
222
+ &::-webkit-scrollbar-thumb {
223
+ background: rgba(0, 0, 0, 0.15);
224
+ border-radius: 2px;
225
+ }
226
+ .tab-item {
227
+ display: inline-flex;
228
+ align-items: center;
229
+ gap: 8px;
230
+ padding: 8px 16px;
231
+ cursor: pointer;
232
+ border-radius: 4px 4px 0 0;
233
+ position: relative;
234
+ transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
235
+ user-select: none;
236
+ height: 36px;
237
+ font-size: 13px;
238
+ color: rgba(0, 0, 0, 0.65);
239
+ background: transparent;
240
+ border: 1px solid transparent;
241
+ border-bottom: none;
242
+ margin-bottom: -1px;
243
+ .tab-icon {
244
+ display: flex;
245
+ align-items: center;
246
+ font-size: 14px;
247
+ }
248
+ .tab-label {
249
+ max-width: 120px;
250
+ overflow: hidden;
251
+ text-overflow: ellipsis;
252
+ white-space: nowrap;
253
+ }
254
+ .tab-close-btn {
255
+ display: flex;
256
+ align-items: center;
257
+ justify-content: center;
258
+ width: 16px;
259
+ height: 16px;
260
+ border-radius: 50%;
261
+ opacity: 0;
262
+ transition: all 0.2s;
263
+ margin-left: 4px;
264
+ &.visible {
265
+ opacity: 1;
266
+ }
267
+ &:hover {
268
+ background: rgba(0, 0, 0, 0.15);
269
+ color: #fff;
270
+ }
271
+ }
272
+ &:hover {
273
+ color: #1890ff;
274
+ background: rgba(24, 144, 255, 0.06);
275
+ .tab-close-btn {
276
+ opacity: 1;
277
+ }
278
+ }
279
+ &.active {
280
+ color: #1890ff;
281
+ background: #fff;
282
+ border-color: #e8e8e8;
283
+ font-weight: 500;
284
+ .tab-close-btn {
285
+ opacity: 1;
286
+ }
287
+ &::after {
288
+ content: "";
289
+ position: absolute;
290
+ bottom: -1px;
291
+ left: 0;
292
+ right: 0;
293
+ height: 2px;
294
+ background:
295
+ linear-gradient(
296
+ 90deg,
297
+ #1890ff 0%,
298
+ #096dd9 100%);
299
+ }
300
+ }
301
+ }
302
+ }
303
+ .tab-actions {
304
+ margin-left: 8px;
305
+ padding-left: 12px;
306
+ border-left: 1px solid #e8e8e8;
307
+ .close-all-btn {
308
+ width: 32px;
309
+ height: 32px;
310
+ border: none;
311
+ background: transparent;
312
+ cursor: pointer;
313
+ display: flex;
314
+ align-items: center;
315
+ justify-content: center;
316
+ border-radius: 8px;
317
+ color: rgba(0, 0, 0, 0.45);
318
+ transition: all 0.2s;
319
+ &:hover {
320
+ background: rgba(255, 77, 79, 0.08);
321
+ color: #ff4d4f;
322
+ }
323
+ }
324
+ }
325
+ }
326
+ .content-wrapper {
327
+ flex: 1;
328
+ overflow: auto;
329
+ background: #f0f2f5;
330
+ padding: 24px;
331
+ .page-container {
332
+ min-height: 100%;
333
+ background: #fff;
334
+ border-radius: 8px;
335
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
336
+ animation: fadeIn 0.3s ease-in-out;
337
+ }
338
+ }
339
+ }
340
+ }
341
+ .mobile-overlay {
342
+ display: none;
343
+ }
344
+ &.is-collapse {
345
+ .sidebar-container {
346
+ width: 80px;
347
+ }
348
+ }
349
+ }
350
+ @keyframes fadeIn {
351
+ from {
352
+ opacity: 0;
353
+ transform: translateY(10px);
354
+ }
355
+ to {
356
+ opacity: 1;
357
+ transform: translateY(0);
358
+ }
359
+ }
360
+ @media (max-width: 768px) {
361
+ .admin-layout {
362
+ .sidebar-container {
363
+ position: fixed;
364
+ left: 0;
365
+ top: 0;
366
+ z-index: 1000;
367
+ transform: translateX(-100%);
368
+ transition: transform 0.3s;
369
+ &.collapsed {
370
+ transform: translateX(-100%);
371
+ width: 256px;
372
+ }
373
+ }
374
+ .mobile-overlay {
375
+ display: block;
376
+ position: fixed;
377
+ top: 0;
378
+ left: 0;
379
+ right: 0;
380
+ bottom: 0;
381
+ background: rgba(0, 0, 0, 0.45);
382
+ z-index: 999;
383
+ opacity: 0;
384
+ visibility: hidden;
385
+ transition: all 0.3s;
386
+ &.visible {
387
+ opacity: 1;
388
+ visibility: visible;
389
+ }
390
+ }
391
+ &:not(.is-collapse) {
392
+ .sidebar-container {
393
+ transform: translateX(0);
394
+ }
395
+ .mobile-overlay.visible {
396
+ opacity: 1;
397
+ visibility: visible;
398
+ }
399
+ }
400
+ }
401
+ }