@arco-design/mobile-react 2.30.9 → 2.31.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 (166) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/README.en-US.md +70 -2
  3. package/README.md +69 -2
  4. package/cjs/carousel/index.js +3 -0
  5. package/cjs/form/form-item.d.ts +3 -0
  6. package/cjs/form/form-item.js +38 -10
  7. package/cjs/form/style/css/index.css +13 -0
  8. package/cjs/form/style/index.less +18 -0
  9. package/cjs/icon/IconCheck/index.js +1 -2
  10. package/cjs/icon/IconDownload/index.d.ts +7 -0
  11. package/cjs/icon/IconDownload/index.js +41 -0
  12. package/cjs/icon/IconFile/index.d.ts +7 -0
  13. package/cjs/icon/IconFile/index.js +41 -0
  14. package/cjs/icon/IconKeyboard/index.js +1 -0
  15. package/cjs/icon/IconQuestionCircle/index.js +1 -2
  16. package/cjs/icon/IconUpload/index.js +6 -4
  17. package/cjs/icon/IconUserFill/index.js +1 -2
  18. package/cjs/icon/index.d.ts +3 -1
  19. package/cjs/icon/index.js +17 -7
  20. package/cjs/icon/type.d.ts +3 -1
  21. package/cjs/image-picker/index.js +15 -161
  22. package/cjs/image-picker/type.d.ts +4 -73
  23. package/cjs/index.d.ts +1 -0
  24. package/cjs/index.js +6 -2
  25. package/cjs/input/hooks.js +2 -2
  26. package/cjs/input/props.d.ts +2 -2
  27. package/cjs/picker/index.js +60 -19
  28. package/cjs/picker/type.d.ts +7 -2
  29. package/cjs/picker-view/components/cascader.d.ts +1 -0
  30. package/cjs/picker-view/components/cascader.js +8 -1
  31. package/cjs/picker-view/components/picker-cell.d.ts +1 -0
  32. package/cjs/picker-view/components/picker-cell.js +6 -1
  33. package/cjs/picker-view/index.d.ts +6 -1
  34. package/cjs/picker-view/index.js +25 -13
  35. package/cjs/style.d.ts +1 -0
  36. package/cjs/style.js +3 -1
  37. package/cjs/tabs/tab-cell.js +54 -29
  38. package/cjs/tabs/type.d.ts +5 -0
  39. package/cjs/uploader/index.d.ts +16 -0
  40. package/cjs/uploader/index.js +180 -0
  41. package/cjs/uploader/style/css/index.css +650 -0
  42. package/cjs/uploader/style/css/index.d.ts +4 -0
  43. package/cjs/uploader/style/css/index.js +9 -0
  44. package/cjs/uploader/style/index.d.ts +4 -0
  45. package/cjs/uploader/style/index.js +9 -0
  46. package/cjs/uploader/style/index.less +161 -0
  47. package/cjs/uploader/type.d.ts +108 -0
  48. package/cjs/uploader/type.js +3 -0
  49. package/cjs/uploader/upload/index.d.ts +2 -0
  50. package/cjs/uploader/upload/index.js +19 -0
  51. package/cjs/uploader/upload/type.d.ts +107 -0
  52. package/cjs/uploader/upload/type.js +3 -0
  53. package/cjs/uploader/upload/upload.d.ts +20 -0
  54. package/cjs/uploader/upload/upload.js +189 -0
  55. package/dist/index.js +679 -310
  56. package/dist/index.min.js +4 -4
  57. package/dist/style.css +593 -0
  58. package/dist/style.min.css +1 -1
  59. package/esm/carousel/index.js +3 -0
  60. package/esm/form/form-item.d.ts +3 -0
  61. package/esm/form/form-item.js +36 -10
  62. package/esm/form/style/css/index.css +13 -0
  63. package/esm/form/style/index.less +18 -0
  64. package/esm/icon/IconCheck/index.js +1 -2
  65. package/esm/icon/IconDownload/index.d.ts +7 -0
  66. package/esm/icon/IconDownload/index.js +30 -0
  67. package/esm/icon/IconFile/index.d.ts +7 -0
  68. package/esm/icon/IconFile/index.js +30 -0
  69. package/esm/icon/IconKeyboard/index.js +1 -0
  70. package/esm/icon/IconQuestionCircle/index.js +1 -2
  71. package/esm/icon/IconUpload/index.js +6 -4
  72. package/esm/icon/IconUserFill/index.js +1 -2
  73. package/esm/icon/index.d.ts +3 -1
  74. package/esm/icon/index.js +3 -1
  75. package/esm/icon/type.d.ts +3 -1
  76. package/esm/image-picker/index.js +14 -160
  77. package/esm/image-picker/type.d.ts +4 -73
  78. package/esm/index.d.ts +1 -0
  79. package/esm/index.js +2 -1
  80. package/esm/input/hooks.js +2 -2
  81. package/esm/input/props.d.ts +2 -2
  82. package/esm/picker/index.js +61 -20
  83. package/esm/picker/type.d.ts +7 -2
  84. package/esm/picker-view/components/cascader.d.ts +1 -0
  85. package/esm/picker-view/components/cascader.js +8 -1
  86. package/esm/picker-view/components/picker-cell.d.ts +1 -0
  87. package/esm/picker-view/components/picker-cell.js +6 -1
  88. package/esm/picker-view/index.d.ts +6 -1
  89. package/esm/picker-view/index.js +26 -13
  90. package/esm/style.d.ts +1 -0
  91. package/esm/style.js +2 -1
  92. package/esm/tabs/tab-cell.js +56 -30
  93. package/esm/tabs/type.d.ts +5 -0
  94. package/esm/uploader/index.d.ts +16 -0
  95. package/esm/uploader/index.js +150 -0
  96. package/esm/uploader/style/css/index.css +650 -0
  97. package/esm/uploader/style/css/index.d.ts +4 -0
  98. package/esm/uploader/style/css/index.js +4 -0
  99. package/esm/uploader/style/index.d.ts +4 -0
  100. package/esm/uploader/style/index.js +4 -0
  101. package/esm/uploader/style/index.less +161 -0
  102. package/esm/uploader/type.d.ts +108 -0
  103. package/esm/uploader/type.js +1 -0
  104. package/esm/uploader/upload/index.d.ts +2 -0
  105. package/esm/uploader/upload/index.js +2 -0
  106. package/esm/uploader/upload/type.d.ts +107 -0
  107. package/esm/uploader/upload/type.js +1 -0
  108. package/esm/uploader/upload/upload.d.ts +20 -0
  109. package/esm/uploader/upload/upload.js +175 -0
  110. package/package.json +3 -3
  111. package/tokens/app/arcodesign/default/css-variables.less +27 -0
  112. package/tokens/app/arcodesign/default/index.d.ts +27 -0
  113. package/tokens/app/arcodesign/default/index.js +28 -1
  114. package/tokens/app/arcodesign/default/index.json +292 -0
  115. package/tokens/app/arcodesign/default/index.less +27 -0
  116. package/umd/carousel/index.js +3 -0
  117. package/umd/form/form-item.d.ts +3 -0
  118. package/umd/form/form-item.js +38 -10
  119. package/umd/form/style/css/index.css +13 -0
  120. package/umd/form/style/index.less +18 -0
  121. package/umd/icon/IconCheck/index.js +1 -2
  122. package/umd/icon/IconDownload/index.d.ts +7 -0
  123. package/umd/icon/IconDownload/index.js +49 -0
  124. package/umd/icon/IconFile/index.d.ts +7 -0
  125. package/umd/icon/IconFile/index.js +49 -0
  126. package/umd/icon/IconKeyboard/index.js +1 -0
  127. package/umd/icon/IconQuestionCircle/index.js +1 -2
  128. package/umd/icon/IconUpload/index.js +6 -4
  129. package/umd/icon/IconUserFill/index.js +1 -2
  130. package/umd/icon/index.d.ts +3 -1
  131. package/umd/icon/index.js +15 -9
  132. package/umd/icon/type.d.ts +3 -1
  133. package/umd/image-picker/index.js +17 -163
  134. package/umd/image-picker/type.d.ts +4 -73
  135. package/umd/index.d.ts +1 -0
  136. package/umd/index.js +7 -5
  137. package/umd/input/hooks.js +2 -2
  138. package/umd/input/props.d.ts +2 -2
  139. package/umd/picker/index.js +60 -19
  140. package/umd/picker/type.d.ts +7 -2
  141. package/umd/picker-view/components/cascader.d.ts +1 -0
  142. package/umd/picker-view/components/cascader.js +8 -1
  143. package/umd/picker-view/components/picker-cell.d.ts +1 -0
  144. package/umd/picker-view/components/picker-cell.js +6 -1
  145. package/umd/picker-view/index.d.ts +6 -1
  146. package/umd/picker-view/index.js +25 -13
  147. package/umd/style.d.ts +1 -0
  148. package/umd/style.js +4 -4
  149. package/umd/tabs/tab-cell.js +54 -29
  150. package/umd/tabs/type.d.ts +5 -0
  151. package/umd/uploader/index.d.ts +16 -0
  152. package/umd/uploader/index.js +178 -0
  153. package/umd/uploader/style/css/index.css +650 -0
  154. package/umd/uploader/style/css/index.d.ts +4 -0
  155. package/umd/uploader/style/css/index.js +15 -0
  156. package/umd/uploader/style/index.d.ts +4 -0
  157. package/umd/uploader/style/index.js +15 -0
  158. package/umd/uploader/style/index.less +161 -0
  159. package/umd/uploader/type.d.ts +108 -0
  160. package/umd/uploader/type.js +17 -0
  161. package/umd/uploader/upload/index.d.ts +2 -0
  162. package/umd/uploader/upload/index.js +27 -0
  163. package/umd/uploader/upload/type.d.ts +107 -0
  164. package/umd/uploader/upload/type.js +17 -0
  165. package/umd/uploader/upload/upload.d.ts +20 -0
  166. package/umd/uploader/upload/upload.js +200 -0
@@ -0,0 +1,150 @@
1
+ import React, { useRef, forwardRef, useImperativeHandle } from 'react';
2
+ import { cls, defaultLocale, componentWrapper } from '@arco-design/mobile-utils';
3
+ import { ContextLayout } from '../context-provider';
4
+ import Button from '../button';
5
+ import { useLatestRef } from '../_helpers';
6
+ import { IconUpload, IconDelete, IconCheck, IconFile } from '../icon';
7
+ import Loading from '../loading';
8
+ import { Upload } from './upload';
9
+ export * from './type';
10
+ var Uploader = /*#__PURE__*/forwardRef(function (props, ref) {
11
+ var _props$className = props.className,
12
+ className = _props$className === void 0 ? '' : _props$className,
13
+ style = props.style,
14
+ _props$files = props.files,
15
+ files = _props$files === void 0 ? [] : _props$files,
16
+ _props$accept = props.accept,
17
+ accept = _props$accept === void 0 ? undefined : _props$accept,
18
+ _props$multiple = props.multiple,
19
+ multiple = _props$multiple === void 0 ? false : _props$multiple,
20
+ capture = props.capture,
21
+ _props$limit = props.limit,
22
+ limit = _props$limit === void 0 ? 0 : _props$limit,
23
+ _props$hideStatus = props.hideStatus,
24
+ hideStatus = _props$hideStatus === void 0 ? false : _props$hideStatus,
25
+ _props$alwaysShowSele = props.alwaysShowSelect,
26
+ alwaysShowSelect = _props$alwaysShowSele === void 0 ? false : _props$alwaysShowSele,
27
+ disabled = props.disabled,
28
+ renderDeleteArea = props.renderDeleteArea,
29
+ renderLoadedArea = props.renderLoadedArea,
30
+ renderLoadingArea = props.renderLoadingArea,
31
+ renderErrorArea = props.renderErrorArea,
32
+ renderFileIndexArea = props.renderFileIndexArea,
33
+ renderUploadArea = props.renderUploadArea,
34
+ renderFileList = props.renderFileList;
35
+ var domRef = useRef(null);
36
+ var fileRef = useRef(null);
37
+ var cacheRef = useLatestRef(files);
38
+ var uploadFunc = new Upload(props, fileRef, cacheRef);
39
+ useImperativeHandle(ref, function () {
40
+ return {
41
+ dom: domRef.current
42
+ };
43
+ });
44
+
45
+ var uploaderSelect = function uploaderSelect(prefixCls, locale) {
46
+ var showSelect = files.length < (limit || Infinity);
47
+ return (showSelect || alwaysShowSelect) && /*#__PURE__*/React.createElement("div", {
48
+ className: prefixCls + "-uploader-add",
49
+ onClick: uploadFunc.handleSelect
50
+ }, /*#__PURE__*/React.createElement("input", {
51
+ type: "file",
52
+ accept: accept,
53
+ capture: capture,
54
+ onChange: function onChange(e) {
55
+ return uploadFunc.handleChange(e);
56
+ },
57
+ multiple: multiple,
58
+ ref: fileRef
59
+ }), renderUploadArea && renderUploadArea() || /*#__PURE__*/React.createElement(Button, {
60
+ className: prefixCls + "-uploader-add-button",
61
+ size: "medium",
62
+ icon: /*#__PURE__*/React.createElement(IconUpload, null),
63
+ disabled: disabled
64
+ }, locale.Uploader.uploadBtn));
65
+ };
66
+
67
+ var getUploadList = function getUploadList(prefixCls, locale) {
68
+ var generateItemArea = function generateItemArea(fileItem, index, render, part, defaultArea) {
69
+ if (render) {
70
+ var node = render(fileItem, index);
71
+ return node ? /*#__PURE__*/React.createElement("div", {
72
+ className: prefixCls + "-uploader-list-item-" + part
73
+ }, node) : node;
74
+ }
75
+
76
+ return /*#__PURE__*/React.createElement("div", {
77
+ className: prefixCls + "-uploader-list-item-" + part
78
+ }, defaultArea);
79
+ };
80
+
81
+ return renderFileList && renderFileList({
82
+ retryUpload: uploadFunc.retryUpload,
83
+ deleteFile: uploadFunc.deleteFile
84
+ }) || /*#__PURE__*/React.createElement("div", {
85
+ className: prefixCls + "-uploader-list"
86
+ }, (limit && limit < files.length ? files.slice(0, limit) : files).map(function (fileItem, index) {
87
+ var _cls, _cls2;
88
+
89
+ var file = fileItem.file,
90
+ status = fileItem.status;
91
+ return /*#__PURE__*/React.createElement("div", {
92
+ className: prefixCls + "-uploader-list-item",
93
+ key: index,
94
+ onClick: function onClick(e) {
95
+ return uploadFunc.handleClick(e, fileItem, index);
96
+ }
97
+ }, /*#__PURE__*/React.createElement("div", {
98
+ className: prefixCls + "-uploader-list-item-container"
99
+ }, /*#__PURE__*/React.createElement("div", {
100
+ className: prefixCls + "-uploader-list-item-wrapper"
101
+ }, generateItemArea(fileItem, index, renderFileIndexArea, 'file', /*#__PURE__*/React.createElement(IconFile, {
102
+ className: prefixCls + "-uploader-list-item-file-icon"
103
+ })), /*#__PURE__*/React.createElement("div", {
104
+ className: cls(prefixCls + "-uploader-list-item-text", (_cls = {}, _cls[prefixCls + "-uploader-list-item-text-error"] = status === 'error', _cls))
105
+ }, file.name)), !hideStatus && /*#__PURE__*/React.createElement("div", {
106
+ className: prefixCls + "-uploader-list-item-status"
107
+ }, status === 'loaded' && generateItemArea(fileItem, index, renderLoadedArea, 'loaded', /*#__PURE__*/React.createElement(IconCheck, null)), status === 'loading' && generateItemArea(fileItem, index, renderLoadingArea, 'loading', /*#__PURE__*/React.createElement(Loading, {
108
+ type: "circle",
109
+ radius: 7
110
+ })), status === 'error' && /*#__PURE__*/React.createElement("div", {
111
+ onClick: function onClick() {
112
+ return uploadFunc.retryUpload(index);
113
+ }
114
+ }, generateItemArea(fileItem, index, renderErrorArea, 'error', /*#__PURE__*/React.createElement("span", null, locale.Uploader.retryUpload))))), /*#__PURE__*/React.createElement("div", {
115
+ className: prefixCls + "-uploader-list-item-delete",
116
+ onClick: function onClick() {
117
+ return uploadFunc.deleteFile(index);
118
+ }
119
+ }, renderDeleteArea && renderDeleteArea(fileItem, index) || /*#__PURE__*/React.createElement(IconDelete, {
120
+ className: cls(prefixCls + "-uploader-list-item-delete-icon", (_cls2 = {}, _cls2[prefixCls + "-uploader-list-item-delete-icon-disabled"] = disabled, _cls2))
121
+ })));
122
+ }));
123
+ };
124
+
125
+ return /*#__PURE__*/React.createElement(ContextLayout, null, function (_ref) {
126
+ var _cls3;
127
+
128
+ var prefixCls = _ref.prefixCls,
129
+ _ref$locale = _ref.locale,
130
+ locale = _ref$locale === void 0 ? defaultLocale : _ref$locale;
131
+ return /*#__PURE__*/React.createElement("div", {
132
+ className: cls(prefixCls + "-uploader", className, (_cls3 = {}, _cls3[prefixCls + "-uploader-disabled"] = disabled, _cls3)),
133
+ style: style,
134
+ ref: domRef
135
+ }, /*#__PURE__*/React.createElement("div", {
136
+ className: prefixCls + "-uploader-container"
137
+ }, uploaderSelect(prefixCls, locale), getUploadList(prefixCls, locale)));
138
+ });
139
+ });
140
+ /**
141
+ * 文件上传组件
142
+ * @en Uploader Component
143
+ * @type 数据录入
144
+ * @type_en Data Entry
145
+ * @name 文件上传
146
+ * @name_en Uploader
147
+ * @displayName Uploader
148
+ */
149
+
150
+ export default componentWrapper(Uploader, 'Uploader');