zartui 0.1.21 → 0.1.22

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 (227) hide show
  1. package/README.md +20 -20
  2. package/changelog.generated.md +29 -0
  3. package/es/area/style/index.js +4 -0
  4. package/es/area/style/less.js +4 -0
  5. package/es/avatar/index.css +1 -1
  6. package/es/avatar/index.js +41 -27
  7. package/es/avatar/index.less +40 -11
  8. package/es/avatar/local.less +1 -1
  9. package/es/button/index.less +206 -206
  10. package/es/calendar/index.less +250 -250
  11. package/es/calendar/style/index.js +1 -1
  12. package/es/calendar/style/less.js +1 -1
  13. package/es/cell/index.less +103 -103
  14. package/es/cell-group/index.less +22 -22
  15. package/es/checkbox/index.less +89 -89
  16. package/es/checkbox-group/index.less +8 -8
  17. package/es/col/index.less +20 -20
  18. package/es/datetime-picker/style/index.js +4 -0
  19. package/es/datetime-picker/style/less.js +4 -0
  20. package/es/dialog/index.less +125 -125
  21. package/es/dialog/style/index.js +1 -1
  22. package/es/dialog/style/less.js +1 -1
  23. package/es/empty/Developing.js +1643 -0
  24. package/es/empty/Error.js +484 -0
  25. package/es/empty/NotFound.js +645 -0
  26. package/es/empty/NotRight.js +395 -0
  27. package/es/empty/Search.js +336 -0
  28. package/es/empty/index.css +1 -0
  29. package/es/empty/index.js +105 -0
  30. package/es/empty/index.less +33 -0
  31. package/es/empty/style/index.js +2 -0
  32. package/es/empty/style/less.js +2 -0
  33. package/es/field/index.less +172 -172
  34. package/es/icon/index.less +10 -10
  35. package/es/icon/local.less +1 -1
  36. package/es/image/index.less +47 -47
  37. package/es/image-preview/index.less +103 -103
  38. package/es/image-preview/style/index.js +1 -1
  39. package/es/image-preview/style/less.js +1 -1
  40. package/es/index.js +5 -3
  41. package/es/info/index.less +29 -29
  42. package/es/loading/index.less +103 -103
  43. package/es/locale/lang/zh-CN.js +16 -0
  44. package/es/mixins/bind-event.js +2 -2
  45. package/es/mixins/checkbox.js +2 -2
  46. package/es/mixins/click-outside.js +2 -2
  47. package/es/mixins/slots.js +3 -3
  48. package/es/nav-bar/index.less +74 -74
  49. package/es/number-keyboard/index.less +142 -142
  50. package/es/overlay/index.less +11 -11
  51. package/es/password-input/index.css +1 -0
  52. package/es/password-input/index.js +80 -0
  53. package/es/password-input/index.less +83 -0
  54. package/es/password-input/style/index.js +2 -0
  55. package/es/password-input/style/less.js +2 -0
  56. package/es/pdf-viewer/style/index.js +1 -1
  57. package/es/pdf-viewer/style/less.js +1 -1
  58. package/es/picker/PickerColumn.js +5 -6
  59. package/es/picker/index.js +34 -5
  60. package/es/picker/index.less +151 -151
  61. package/es/picker/shared.js +4 -0
  62. package/es/picker/style/index.js +4 -0
  63. package/es/picker/style/less.js +4 -0
  64. package/es/popup/index.less +137 -137
  65. package/es/popup/style/index.js +1 -1
  66. package/es/popup/style/less.js +1 -1
  67. package/es/radio/index.less +86 -86
  68. package/es/radio-group/index.less +8 -8
  69. package/es/rate/index.css +1 -1
  70. package/es/rate/index.js +1 -1
  71. package/es/rate/index.less +47 -47
  72. package/es/row/index.less +42 -42
  73. package/es/slider/index.less +94 -94
  74. package/es/step/index.less +139 -139
  75. package/es/stepper/index.less +130 -130
  76. package/es/steps/index.less +21 -21
  77. package/es/sticky/index.less +11 -11
  78. package/es/style/animation.less +139 -139
  79. package/es/style/base.less +11 -11
  80. package/es/style/clearfix.less +5 -5
  81. package/es/style/ellipsis.less +13 -13
  82. package/es/style/hairline.less +47 -47
  83. package/es/style/halfPxBorder.less +15 -15
  84. package/es/style/mixins/clearfix.less +7 -7
  85. package/es/style/mixins/ellipsis.less +15 -15
  86. package/es/style/mixins/hairline.less +39 -39
  87. package/es/style/normalize.less +38 -38
  88. package/es/style/reset.less +171 -171
  89. package/es/style/var.less +936 -919
  90. package/es/swipe/index.less +56 -56
  91. package/es/swipe-cell/index.less +29 -29
  92. package/es/swipe-item/index.less +8 -8
  93. package/es/switch/index.less +56 -56
  94. package/es/switch/shared.js +2 -2
  95. package/es/switch-cell/index.less +15 -15
  96. package/es/tab/index.less +17 -17
  97. package/es/tabs/index.less +153 -153
  98. package/es/tag/index.less +99 -99
  99. package/es/toast/index.less +75 -75
  100. package/es/toast/style/index.js +1 -1
  101. package/es/toast/style/less.js +1 -1
  102. package/es/uploader/index.less +163 -163
  103. package/es/uploader/style/index.js +1 -1
  104. package/es/uploader/style/less.js +1 -1
  105. package/es/utils/create/bem.js +7 -7
  106. package/es/utils/create/component.js +2 -2
  107. package/es/utils/dom/raf.js +2 -2
  108. package/es/utils/dom/reset-scroll.js +3 -3
  109. package/es/utils/index.js +29 -29
  110. package/es/utils/router.js +2 -2
  111. package/lib/7893e51cf0a4877dac80.worker.js +10 -0
  112. package/lib/area/style/index.js +4 -0
  113. package/lib/area/style/less.js +4 -0
  114. package/lib/avatar/index.css +1 -1
  115. package/lib/avatar/index.js +42 -28
  116. package/lib/avatar/index.less +40 -11
  117. package/lib/avatar/local.less +1 -1
  118. package/lib/be09b519a460e229fd8d.worker.js +2527 -0
  119. package/lib/button/index.less +206 -206
  120. package/lib/calendar/index.less +250 -250
  121. package/lib/calendar/style/index.js +1 -1
  122. package/lib/calendar/style/less.js +1 -1
  123. package/lib/cell/index.less +103 -103
  124. package/lib/cell-group/index.less +22 -22
  125. package/lib/checkbox/index.less +89 -89
  126. package/lib/checkbox-group/index.less +8 -8
  127. package/lib/col/index.less +20 -20
  128. package/lib/datetime-picker/style/index.js +4 -0
  129. package/lib/datetime-picker/style/less.js +4 -0
  130. package/lib/dialog/index.less +125 -125
  131. package/lib/dialog/style/index.js +1 -1
  132. package/lib/dialog/style/less.js +1 -1
  133. package/lib/empty/Developing.js +1648 -0
  134. package/lib/empty/Error.js +489 -0
  135. package/lib/empty/NotFound.js +650 -0
  136. package/lib/empty/NotRight.js +400 -0
  137. package/lib/empty/Search.js +341 -0
  138. package/lib/empty/index.css +1 -0
  139. package/lib/empty/index.js +119 -0
  140. package/lib/empty/index.less +33 -0
  141. package/lib/empty/style/index.js +2 -0
  142. package/lib/empty/style/less.js +2 -0
  143. package/lib/field/index.less +172 -172
  144. package/lib/icon/index.less +10 -10
  145. package/lib/icon/local.less +1 -1
  146. package/lib/image/index.less +47 -47
  147. package/lib/image-preview/index.less +103 -103
  148. package/lib/image-preview/style/index.js +1 -1
  149. package/lib/image-preview/style/less.js +1 -1
  150. package/lib/index.css +1 -1
  151. package/lib/index.js +10 -2
  152. package/lib/index.less +5 -3
  153. package/lib/info/index.less +29 -29
  154. package/lib/loading/index.less +103 -103
  155. package/lib/locale/lang/zh-CN.js +16 -0
  156. package/lib/mixins/bind-event.js +2 -2
  157. package/lib/mixins/checkbox.js +2 -2
  158. package/lib/mixins/click-outside.js +2 -2
  159. package/lib/mixins/slots.js +3 -3
  160. package/lib/nav-bar/index.less +74 -74
  161. package/lib/number-keyboard/index.less +142 -142
  162. package/lib/overlay/index.less +11 -11
  163. package/lib/password-input/index.css +1 -0
  164. package/lib/password-input/index.js +93 -0
  165. package/lib/password-input/index.less +83 -0
  166. package/lib/password-input/style/index.js +2 -0
  167. package/lib/password-input/style/less.js +2 -0
  168. package/lib/pdf-viewer/style/index.js +1 -1
  169. package/lib/pdf-viewer/style/less.js +1 -1
  170. package/lib/picker/PickerColumn.js +5 -6
  171. package/lib/picker/index.js +36 -6
  172. package/lib/picker/index.less +151 -151
  173. package/lib/picker/shared.js +4 -0
  174. package/lib/picker/style/index.js +4 -0
  175. package/lib/picker/style/less.js +4 -0
  176. package/lib/popup/index.less +137 -137
  177. package/lib/popup/style/index.js +1 -1
  178. package/lib/popup/style/less.js +1 -1
  179. package/lib/radio/index.less +86 -86
  180. package/lib/radio-group/index.less +8 -8
  181. package/lib/rate/index.css +1 -1
  182. package/lib/rate/index.js +1 -1
  183. package/lib/rate/index.less +47 -47
  184. package/lib/row/index.less +42 -42
  185. package/lib/slider/index.less +94 -94
  186. package/lib/step/index.less +139 -139
  187. package/lib/stepper/index.less +130 -130
  188. package/lib/steps/index.less +21 -21
  189. package/lib/sticky/index.less +11 -11
  190. package/lib/style/animation.less +139 -139
  191. package/lib/style/base.less +11 -11
  192. package/lib/style/clearfix.less +5 -5
  193. package/lib/style/ellipsis.less +13 -13
  194. package/lib/style/hairline.less +47 -47
  195. package/lib/style/halfPxBorder.less +15 -15
  196. package/lib/style/mixins/clearfix.less +7 -7
  197. package/lib/style/mixins/ellipsis.less +15 -15
  198. package/lib/style/mixins/hairline.less +39 -39
  199. package/lib/style/normalize.less +38 -38
  200. package/lib/style/reset.less +171 -171
  201. package/lib/style/var.less +936 -919
  202. package/lib/swipe/index.less +56 -56
  203. package/lib/swipe-cell/index.less +29 -29
  204. package/lib/swipe-item/index.less +8 -8
  205. package/lib/switch/index.less +56 -56
  206. package/lib/switch/shared.js +2 -2
  207. package/lib/switch-cell/index.less +15 -15
  208. package/lib/tab/index.less +17 -17
  209. package/lib/tabs/index.less +153 -153
  210. package/lib/tag/index.less +99 -99
  211. package/lib/toast/index.less +75 -75
  212. package/lib/toast/style/index.js +1 -1
  213. package/lib/toast/style/less.js +1 -1
  214. package/lib/uploader/index.less +163 -163
  215. package/lib/uploader/style/index.js +1 -1
  216. package/lib/uploader/style/less.js +1 -1
  217. package/lib/utils/create/bem.js +7 -7
  218. package/lib/utils/create/component.js +2 -2
  219. package/lib/utils/dom/raf.js +2 -2
  220. package/lib/utils/dom/reset-scroll.js +3 -3
  221. package/lib/utils/index.js +29 -29
  222. package/lib/utils/router.js +2 -2
  223. package/lib/zart.js +26508 -55081
  224. package/lib/zart.min.js +5 -5
  225. package/package.json +74 -74
  226. package/lib/a037f57fc4d92a8a1f1e.worker.js +0 -60600
  227. package/lib/b7cf90b4775181215df7.worker.js +0 -10
@@ -1,99 +1,99 @@
1
- @import '../style/var';
2
-
3
- .zt-tag {
4
- position: relative;
5
- display: inline-flex;
6
- align-items: center;
7
- padding: @tag-padding;
8
- color: @tag-text-color;
9
- font-size: @tag-font-size;
10
- line-height: @tag-line-height;
11
- border-radius: @tag-border-radius;
12
-
13
- &--default {
14
- background-color: @tag-default-color;
15
-
16
- &.zt-tag--plain {
17
- color: @tag-default-color;
18
- }
19
- }
20
-
21
- &--danger {
22
- background-color: @tag-danger-color;
23
-
24
- &.zt-tag--plain {
25
- color: @tag-danger-color;
26
- }
27
- }
28
-
29
- &--primary {
30
- background-color: @tag-primary-color;
31
-
32
- &.zt-tag--plain {
33
- color: @tag-primary-color;
34
- }
35
- }
36
-
37
- &--success {
38
- background-color: @tag-success-color;
39
-
40
- &.zt-tag--plain {
41
- color: @tag-success-color;
42
- }
43
- }
44
-
45
- &--warning {
46
- background-color: @tag-warning-color;
47
-
48
- &.zt-tag--plain {
49
- color: @tag-warning-color;
50
- }
51
- }
52
-
53
- &--plain {
54
- background-color: @tag-plain-background-color;
55
- border-color: currentColor;
56
-
57
- &::before {
58
- position: absolute;
59
- top: 0;
60
- right: 0;
61
- bottom: 0;
62
- left: 0;
63
- border: 1px solid;
64
- border-color: inherit;
65
- border-radius: inherit;
66
- content: '';
67
- pointer-events: none;
68
- }
69
- }
70
-
71
- &--medium {
72
- padding: @tag-medium-padding;
73
- }
74
-
75
- &--large {
76
- padding: @tag-large-padding;
77
- font-size: @tag-large-font-size;
78
- border-radius: @tag-large-border-radius;
79
- }
80
-
81
- &--mark {
82
- border-radius: 0 @tag-round-border-radius @tag-round-border-radius 0;
83
-
84
- &::after {
85
- display: block;
86
- width: 2px;
87
- content: '';
88
- }
89
- }
90
-
91
- &--round {
92
- border-radius: @tag-round-border-radius;
93
- }
94
-
95
- &__close {
96
- margin-left: 2px;
97
- cursor: pointer;
98
- }
99
- }
1
+ @import '../style/var';
2
+
3
+ .zt-tag {
4
+ position: relative;
5
+ display: inline-flex;
6
+ align-items: center;
7
+ padding: @tag-padding;
8
+ color: @tag-text-color;
9
+ font-size: @tag-font-size;
10
+ line-height: @tag-line-height;
11
+ border-radius: @tag-border-radius;
12
+
13
+ &--default {
14
+ background-color: @tag-default-color;
15
+
16
+ &.zt-tag--plain {
17
+ color: @tag-default-color;
18
+ }
19
+ }
20
+
21
+ &--danger {
22
+ background-color: @tag-danger-color;
23
+
24
+ &.zt-tag--plain {
25
+ color: @tag-danger-color;
26
+ }
27
+ }
28
+
29
+ &--primary {
30
+ background-color: @tag-primary-color;
31
+
32
+ &.zt-tag--plain {
33
+ color: @tag-primary-color;
34
+ }
35
+ }
36
+
37
+ &--success {
38
+ background-color: @tag-success-color;
39
+
40
+ &.zt-tag--plain {
41
+ color: @tag-success-color;
42
+ }
43
+ }
44
+
45
+ &--warning {
46
+ background-color: @tag-warning-color;
47
+
48
+ &.zt-tag--plain {
49
+ color: @tag-warning-color;
50
+ }
51
+ }
52
+
53
+ &--plain {
54
+ background-color: @tag-plain-background-color;
55
+ border-color: currentColor;
56
+
57
+ &::before {
58
+ position: absolute;
59
+ top: 0;
60
+ right: 0;
61
+ bottom: 0;
62
+ left: 0;
63
+ border: 1px solid;
64
+ border-color: inherit;
65
+ border-radius: inherit;
66
+ content: '';
67
+ pointer-events: none;
68
+ }
69
+ }
70
+
71
+ &--medium {
72
+ padding: @tag-medium-padding;
73
+ }
74
+
75
+ &--large {
76
+ padding: @tag-large-padding;
77
+ font-size: @tag-large-font-size;
78
+ border-radius: @tag-large-border-radius;
79
+ }
80
+
81
+ &--mark {
82
+ border-radius: 0 @tag-round-border-radius @tag-round-border-radius 0;
83
+
84
+ &::after {
85
+ display: block;
86
+ width: 2px;
87
+ content: '';
88
+ }
89
+ }
90
+
91
+ &--round {
92
+ border-radius: @tag-round-border-radius;
93
+ }
94
+
95
+ &__close {
96
+ margin-left: 2px;
97
+ cursor: pointer;
98
+ }
99
+ }
@@ -1,75 +1,75 @@
1
- @import '../style/var';
2
-
3
- .zt-toast {
4
- position: fixed;
5
- top: 50%;
6
- left: 50%;
7
- display: flex;
8
- flex-direction: column;
9
- align-items: center;
10
- justify-content: center;
11
- box-sizing: content-box;
12
-
13
- // hack for avoid max-width when use left & fixed
14
- width: @toast-default-width;
15
- max-width: @toast-max-width;
16
- min-height: @toast-default-min-height;
17
- padding: @toast-default-padding;
18
- color: @toast-text-color;
19
- font-size: @toast-font-size;
20
- line-height: @toast-line-height;
21
-
22
- // allow newline character
23
- white-space: pre-wrap;
24
- text-align: center;
25
- // https://github.com/youzan/vant/issues/8959
26
- word-break: break-all;
27
- background-color: @toast-background-color;
28
- border-radius: @toast-border-radius;
29
- transform: translate3d(-50%, -50%, 0);
30
-
31
- &--unclickable {
32
- // lock scroll
33
- overflow: hidden;
34
-
35
- // should not add pointer-events: none directly to body tag
36
- // that will cause unexpected tap-highlight-color in mobile safari
37
- * {
38
- pointer-events: none;
39
- }
40
- }
41
-
42
- &--text,
43
- &--html {
44
- width: fit-content;
45
- min-width: @toast-text-min-width;
46
- min-height: 0;
47
- padding: @toast-text-padding;
48
-
49
- .zt-toast__text {
50
- margin-top: 0;
51
- }
52
- }
53
-
54
- &--top {
55
- top: @toast-position-top-distance;
56
- }
57
-
58
- &--bottom {
59
- top: auto;
60
- bottom: @toast-position-bottom-distance;
61
- }
62
-
63
- &__icon {
64
- font-size: @toast-icon-size;
65
- }
66
-
67
- &__loading {
68
- padding: @padding-base;
69
- color: @toast-loading-icon-color;
70
- }
71
-
72
- &__text {
73
- margin-top: @padding-xs;
74
- }
75
- }
1
+ @import '../style/var';
2
+
3
+ .zt-toast {
4
+ position: fixed;
5
+ top: 50%;
6
+ left: 50%;
7
+ display: flex;
8
+ flex-direction: column;
9
+ align-items: center;
10
+ justify-content: center;
11
+ box-sizing: content-box;
12
+
13
+ // hack for avoid max-width when use left & fixed
14
+ width: @toast-default-width;
15
+ max-width: @toast-max-width;
16
+ min-height: @toast-default-min-height;
17
+ padding: @toast-default-padding;
18
+ color: @toast-text-color;
19
+ font-size: @toast-font-size;
20
+ line-height: @toast-line-height;
21
+
22
+ // allow newline character
23
+ white-space: pre-wrap;
24
+ text-align: center;
25
+ // https://github.com/youzan/vant/issues/8959
26
+ word-break: break-all;
27
+ background-color: @toast-background-color;
28
+ border-radius: @toast-border-radius;
29
+ transform: translate3d(-50%, -50%, 0);
30
+
31
+ &--unclickable {
32
+ // lock scroll
33
+ overflow: hidden;
34
+
35
+ // should not add pointer-events: none directly to body tag
36
+ // that will cause unexpected tap-highlight-color in mobile safari
37
+ * {
38
+ pointer-events: none;
39
+ }
40
+ }
41
+
42
+ &--text,
43
+ &--html {
44
+ width: fit-content;
45
+ min-width: @toast-text-min-width;
46
+ min-height: 0;
47
+ padding: @toast-text-padding;
48
+
49
+ .zt-toast__text {
50
+ margin-top: 0;
51
+ }
52
+ }
53
+
54
+ &--top {
55
+ top: @toast-position-top-distance;
56
+ }
57
+
58
+ &--bottom {
59
+ top: auto;
60
+ bottom: @toast-position-bottom-distance;
61
+ }
62
+
63
+ &__icon {
64
+ font-size: @toast-icon-size;
65
+ }
66
+
67
+ &__loading {
68
+ padding: @padding-base;
69
+ color: @toast-loading-icon-color;
70
+ }
71
+
72
+ &__text {
73
+ margin-top: @padding-xs;
74
+ }
75
+ }
@@ -1,7 +1,7 @@
1
1
  require('../../style/base.css');
2
2
  require('../../loading/index.css');
3
+ require('../../overlay/index.css');
3
4
  require('../../info/index.css');
4
5
  require('../../icon/index.css');
5
- require('../../overlay/index.css');
6
6
  require('../../popup/index.css');
7
7
  require('../index.css');
@@ -1,7 +1,7 @@
1
1
  require('../../style/base.less');
2
2
  require('../../loading/index.less');
3
+ require('../../overlay/index.less');
3
4
  require('../../info/index.less');
4
5
  require('../../icon/index.less');
5
- require('../../overlay/index.less');
6
6
  require('../../popup/index.less');
7
7
  require('../index.less');
@@ -1,163 +1,163 @@
1
- @import '../style/var';
2
-
3
- .zt-uploader {
4
- position: relative;
5
- display: inline-block;
6
-
7
- &__wrapper {
8
- display: flex;
9
- flex-wrap: wrap;
10
-
11
- &--disabled {
12
- opacity: @uploader-disabled-opacity;
13
- }
14
- }
15
-
16
- &__input {
17
- position: absolute;
18
- top: 0;
19
- left: 0;
20
- width: 100%;
21
- height: 100%;
22
- overflow: hidden; // to clip file-upload-button
23
- cursor: pointer;
24
- opacity: 0;
25
-
26
- &-wrapper {
27
- position: relative;
28
- }
29
-
30
- &:disabled {
31
- cursor: not-allowed;
32
- }
33
- }
34
-
35
- &__upload {
36
- position: relative;
37
- display: flex;
38
- flex-direction: column;
39
- align-items: center;
40
- justify-content: center;
41
- box-sizing: border-box;
42
- width: @uploader-size;
43
- height: @uploader-size;
44
- margin: 0 @padding-xs @padding-xs 0;
45
- background-color: @uploader-upload-background-color;
46
-
47
- &:active {
48
- background-color: @uploader-upload-active-color;
49
- }
50
-
51
- &--readonly:active {
52
- background-color: @uploader-upload-background-color;
53
- }
54
-
55
- &-icon {
56
- color: @uploader-icon-color;
57
- font-size: @uploader-icon-size;
58
- }
59
-
60
- &-text {
61
- margin-top: @padding-xs;
62
- color: @uploader-text-color;
63
- font-size: @uploader-text-font-size;
64
- }
65
- }
66
-
67
- &__preview {
68
- position: relative;
69
- margin: 0 @padding-xs @padding-xs 0;
70
- cursor: pointer;
71
-
72
- &-image {
73
- display: block;
74
- width: @uploader-size;
75
- height: @uploader-size;
76
- overflow: hidden;
77
- }
78
-
79
- &-delete {
80
- position: absolute;
81
- top: 0;
82
- right: 0;
83
- width: @uploader-delete-icon-size;
84
- height: @uploader-delete-icon-size;
85
- background-color: @uploader-delete-background-color;
86
- border-radius: 0 0 0 12px;
87
-
88
- &-icon {
89
- position: absolute;
90
- top: -2px;
91
- right: -2px;
92
- color: #fff;
93
- color: @uploader-delete-color;
94
- font-size: 16px;
95
- transform: scale(0.5);
96
- }
97
- }
98
-
99
- &-cover {
100
- position: absolute;
101
- top: 0;
102
- right: 0;
103
- bottom: 0;
104
- left: 0;
105
- }
106
- }
107
-
108
- &__mask {
109
- position: absolute;
110
- top: 0;
111
- right: 0;
112
- bottom: 0;
113
- left: 0;
114
- display: flex;
115
- flex-direction: column;
116
- align-items: center;
117
- justify-content: center;
118
- color: @white;
119
- background-color: @uploader-mask-background-color;
120
-
121
- &-icon {
122
- font-size: @uploader-mask-icon-size;
123
- }
124
-
125
- &-message {
126
- margin-top: 6px;
127
- padding: 0 @padding-base;
128
- font-size: @uploader-mask-message-font-size;
129
- line-height: @uploader-mask-message-line-height;
130
- }
131
- }
132
-
133
- &__loading {
134
- width: @uploader-loading-icon-size;
135
- height: @uploader-loading-icon-size;
136
- color: @uploader-loading-icon-color;
137
- }
138
-
139
- &__file {
140
- display: flex;
141
- flex-direction: column;
142
- align-items: center;
143
- justify-content: center;
144
- width: @uploader-size;
145
- height: @uploader-size;
146
- background-color: @uploader-file-background-color;
147
-
148
- &-icon {
149
- color: @uploader-file-icon-color;
150
- font-size: @uploader-file-icon-size;
151
- }
152
-
153
- &-name {
154
- box-sizing: border-box;
155
- width: 100%;
156
- margin-top: @uploader-file-name-margin-top;
157
- padding: @uploader-file-name-padding;
158
- color: @uploader-file-name-text-color;
159
- font-size: @uploader-file-name-font-size;
160
- text-align: center;
161
- }
162
- }
163
- }
1
+ @import '../style/var';
2
+
3
+ .zt-uploader {
4
+ position: relative;
5
+ display: inline-block;
6
+
7
+ &__wrapper {
8
+ display: flex;
9
+ flex-wrap: wrap;
10
+
11
+ &--disabled {
12
+ opacity: @uploader-disabled-opacity;
13
+ }
14
+ }
15
+
16
+ &__input {
17
+ position: absolute;
18
+ top: 0;
19
+ left: 0;
20
+ width: 100%;
21
+ height: 100%;
22
+ overflow: hidden; // to clip file-upload-button
23
+ cursor: pointer;
24
+ opacity: 0;
25
+
26
+ &-wrapper {
27
+ position: relative;
28
+ }
29
+
30
+ &:disabled {
31
+ cursor: not-allowed;
32
+ }
33
+ }
34
+
35
+ &__upload {
36
+ position: relative;
37
+ display: flex;
38
+ flex-direction: column;
39
+ align-items: center;
40
+ justify-content: center;
41
+ box-sizing: border-box;
42
+ width: @uploader-size;
43
+ height: @uploader-size;
44
+ margin: 0 @padding-xs @padding-xs 0;
45
+ background-color: @uploader-upload-background-color;
46
+
47
+ &:active {
48
+ background-color: @uploader-upload-active-color;
49
+ }
50
+
51
+ &--readonly:active {
52
+ background-color: @uploader-upload-background-color;
53
+ }
54
+
55
+ &-icon {
56
+ color: @uploader-icon-color;
57
+ font-size: @uploader-icon-size;
58
+ }
59
+
60
+ &-text {
61
+ margin-top: @padding-xs;
62
+ color: @uploader-text-color;
63
+ font-size: @uploader-text-font-size;
64
+ }
65
+ }
66
+
67
+ &__preview {
68
+ position: relative;
69
+ margin: 0 @padding-xs @padding-xs 0;
70
+ cursor: pointer;
71
+
72
+ &-image {
73
+ display: block;
74
+ width: @uploader-size;
75
+ height: @uploader-size;
76
+ overflow: hidden;
77
+ }
78
+
79
+ &-delete {
80
+ position: absolute;
81
+ top: 0;
82
+ right: 0;
83
+ width: @uploader-delete-icon-size;
84
+ height: @uploader-delete-icon-size;
85
+ background-color: @uploader-delete-background-color;
86
+ border-radius: 0 0 0 12px;
87
+
88
+ &-icon {
89
+ position: absolute;
90
+ top: -2px;
91
+ right: -2px;
92
+ color: #fff;
93
+ color: @uploader-delete-color;
94
+ font-size: 16px;
95
+ transform: scale(0.5);
96
+ }
97
+ }
98
+
99
+ &-cover {
100
+ position: absolute;
101
+ top: 0;
102
+ right: 0;
103
+ bottom: 0;
104
+ left: 0;
105
+ }
106
+ }
107
+
108
+ &__mask {
109
+ position: absolute;
110
+ top: 0;
111
+ right: 0;
112
+ bottom: 0;
113
+ left: 0;
114
+ display: flex;
115
+ flex-direction: column;
116
+ align-items: center;
117
+ justify-content: center;
118
+ color: @white;
119
+ background-color: @uploader-mask-background-color;
120
+
121
+ &-icon {
122
+ font-size: @uploader-mask-icon-size;
123
+ }
124
+
125
+ &-message {
126
+ margin-top: 6px;
127
+ padding: 0 @padding-base;
128
+ font-size: @uploader-mask-message-font-size;
129
+ line-height: @uploader-mask-message-line-height;
130
+ }
131
+ }
132
+
133
+ &__loading {
134
+ width: @uploader-loading-icon-size;
135
+ height: @uploader-loading-icon-size;
136
+ color: @uploader-loading-icon-color;
137
+ }
138
+
139
+ &__file {
140
+ display: flex;
141
+ flex-direction: column;
142
+ align-items: center;
143
+ justify-content: center;
144
+ width: @uploader-size;
145
+ height: @uploader-size;
146
+ background-color: @uploader-file-background-color;
147
+
148
+ &-icon {
149
+ color: @uploader-file-icon-color;
150
+ font-size: @uploader-file-icon-size;
151
+ }
152
+
153
+ &-name {
154
+ box-sizing: border-box;
155
+ width: 100%;
156
+ margin-top: @uploader-file-name-margin-top;
157
+ padding: @uploader-file-name-padding;
158
+ color: @uploader-file-name-text-color;
159
+ font-size: @uploader-file-name-font-size;
160
+ text-align: center;
161
+ }
162
+ }
163
+ }