@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,178 @@
1
+ (function (global, factory) {
2
+ if (typeof define === "function" && define.amd) {
3
+ define(["exports", "react", "@arco-design/mobile-utils", "../context-provider", "../button", "../_helpers", "../icon", "../loading", "./upload", "./type"], factory);
4
+ } else if (typeof exports !== "undefined") {
5
+ factory(exports, require("react"), require("@arco-design/mobile-utils"), require("../context-provider"), require("../button"), require("../_helpers"), require("../icon"), require("../loading"), require("./upload"), require("./type"));
6
+ } else {
7
+ var mod = {
8
+ exports: {}
9
+ };
10
+ factory(mod.exports, global.react, global.mobileUtils, global.contextProvider, global.button, global._helpers, global.icon, global.loading, global.upload, global.type);
11
+ global.index = mod.exports;
12
+ }
13
+ })(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _react, _mobileUtils, _contextProvider, _button, _helpers, _icon, _loading, _upload, _type) {
14
+ "use strict";
15
+
16
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
17
+
18
+ _exports.__esModule = true;
19
+ var _exportNames = {};
20
+ _exports.default = void 0;
21
+ _react = _interopRequireWildcard(_react);
22
+ _button = _interopRequireDefault(_button);
23
+ _loading = _interopRequireDefault(_loading);
24
+ Object.keys(_type).forEach(function (key) {
25
+ if (key === "default" || key === "__esModule") return;
26
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
27
+ if (key in _exports && _exports[key] === _type[key]) return;
28
+ _exports[key] = _type[key];
29
+ });
30
+
31
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
32
+
33
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
34
+
35
+ var Uploader = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
36
+ var _props$className = props.className,
37
+ className = _props$className === void 0 ? '' : _props$className,
38
+ style = props.style,
39
+ _props$files = props.files,
40
+ files = _props$files === void 0 ? [] : _props$files,
41
+ _props$accept = props.accept,
42
+ accept = _props$accept === void 0 ? undefined : _props$accept,
43
+ _props$multiple = props.multiple,
44
+ multiple = _props$multiple === void 0 ? false : _props$multiple,
45
+ capture = props.capture,
46
+ _props$limit = props.limit,
47
+ limit = _props$limit === void 0 ? 0 : _props$limit,
48
+ _props$hideStatus = props.hideStatus,
49
+ hideStatus = _props$hideStatus === void 0 ? false : _props$hideStatus,
50
+ _props$alwaysShowSele = props.alwaysShowSelect,
51
+ alwaysShowSelect = _props$alwaysShowSele === void 0 ? false : _props$alwaysShowSele,
52
+ disabled = props.disabled,
53
+ renderDeleteArea = props.renderDeleteArea,
54
+ renderLoadedArea = props.renderLoadedArea,
55
+ renderLoadingArea = props.renderLoadingArea,
56
+ renderErrorArea = props.renderErrorArea,
57
+ renderFileIndexArea = props.renderFileIndexArea,
58
+ renderUploadArea = props.renderUploadArea,
59
+ renderFileList = props.renderFileList;
60
+ var domRef = (0, _react.useRef)(null);
61
+ var fileRef = (0, _react.useRef)(null);
62
+ var cacheRef = (0, _helpers.useLatestRef)(files);
63
+ var uploadFunc = new _upload.Upload(props, fileRef, cacheRef);
64
+ (0, _react.useImperativeHandle)(ref, function () {
65
+ return {
66
+ dom: domRef.current
67
+ };
68
+ });
69
+
70
+ var uploaderSelect = function uploaderSelect(prefixCls, locale) {
71
+ var showSelect = files.length < (limit || Infinity);
72
+ return (showSelect || alwaysShowSelect) && /*#__PURE__*/_react.default.createElement("div", {
73
+ className: prefixCls + "-uploader-add",
74
+ onClick: uploadFunc.handleSelect
75
+ }, /*#__PURE__*/_react.default.createElement("input", {
76
+ type: "file",
77
+ accept: accept,
78
+ capture: capture,
79
+ onChange: function onChange(e) {
80
+ return uploadFunc.handleChange(e);
81
+ },
82
+ multiple: multiple,
83
+ ref: fileRef
84
+ }), renderUploadArea && renderUploadArea() || /*#__PURE__*/_react.default.createElement(_button.default, {
85
+ className: prefixCls + "-uploader-add-button",
86
+ size: "medium",
87
+ icon: /*#__PURE__*/_react.default.createElement(_icon.IconUpload, null),
88
+ disabled: disabled
89
+ }, locale.Uploader.uploadBtn));
90
+ };
91
+
92
+ var getUploadList = function getUploadList(prefixCls, locale) {
93
+ var generateItemArea = function generateItemArea(fileItem, index, render, part, defaultArea) {
94
+ if (render) {
95
+ var node = render(fileItem, index);
96
+ return node ? /*#__PURE__*/_react.default.createElement("div", {
97
+ className: prefixCls + "-uploader-list-item-" + part
98
+ }, node) : node;
99
+ }
100
+
101
+ return /*#__PURE__*/_react.default.createElement("div", {
102
+ className: prefixCls + "-uploader-list-item-" + part
103
+ }, defaultArea);
104
+ };
105
+
106
+ return renderFileList && renderFileList({
107
+ retryUpload: uploadFunc.retryUpload,
108
+ deleteFile: uploadFunc.deleteFile
109
+ }) || /*#__PURE__*/_react.default.createElement("div", {
110
+ className: prefixCls + "-uploader-list"
111
+ }, (limit && limit < files.length ? files.slice(0, limit) : files).map(function (fileItem, index) {
112
+ var _cls, _cls2;
113
+
114
+ var file = fileItem.file,
115
+ status = fileItem.status;
116
+ return /*#__PURE__*/_react.default.createElement("div", {
117
+ className: prefixCls + "-uploader-list-item",
118
+ key: index,
119
+ onClick: function onClick(e) {
120
+ return uploadFunc.handleClick(e, fileItem, index);
121
+ }
122
+ }, /*#__PURE__*/_react.default.createElement("div", {
123
+ className: prefixCls + "-uploader-list-item-container"
124
+ }, /*#__PURE__*/_react.default.createElement("div", {
125
+ className: prefixCls + "-uploader-list-item-wrapper"
126
+ }, generateItemArea(fileItem, index, renderFileIndexArea, 'file', /*#__PURE__*/_react.default.createElement(_icon.IconFile, {
127
+ className: prefixCls + "-uploader-list-item-file-icon"
128
+ })), /*#__PURE__*/_react.default.createElement("div", {
129
+ className: (0, _mobileUtils.cls)(prefixCls + "-uploader-list-item-text", (_cls = {}, _cls[prefixCls + "-uploader-list-item-text-error"] = status === 'error', _cls))
130
+ }, file.name)), !hideStatus && /*#__PURE__*/_react.default.createElement("div", {
131
+ className: prefixCls + "-uploader-list-item-status"
132
+ }, status === 'loaded' && generateItemArea(fileItem, index, renderLoadedArea, 'loaded', /*#__PURE__*/_react.default.createElement(_icon.IconCheck, null)), status === 'loading' && generateItemArea(fileItem, index, renderLoadingArea, 'loading', /*#__PURE__*/_react.default.createElement(_loading.default, {
133
+ type: "circle",
134
+ radius: 7
135
+ })), status === 'error' && /*#__PURE__*/_react.default.createElement("div", {
136
+ onClick: function onClick() {
137
+ return uploadFunc.retryUpload(index);
138
+ }
139
+ }, generateItemArea(fileItem, index, renderErrorArea, 'error', /*#__PURE__*/_react.default.createElement("span", null, locale.Uploader.retryUpload))))), /*#__PURE__*/_react.default.createElement("div", {
140
+ className: prefixCls + "-uploader-list-item-delete",
141
+ onClick: function onClick() {
142
+ return uploadFunc.deleteFile(index);
143
+ }
144
+ }, renderDeleteArea && renderDeleteArea(fileItem, index) || /*#__PURE__*/_react.default.createElement(_icon.IconDelete, {
145
+ className: (0, _mobileUtils.cls)(prefixCls + "-uploader-list-item-delete-icon", (_cls2 = {}, _cls2[prefixCls + "-uploader-list-item-delete-icon-disabled"] = disabled, _cls2))
146
+ })));
147
+ }));
148
+ };
149
+
150
+ return /*#__PURE__*/_react.default.createElement(_contextProvider.ContextLayout, null, function (_ref) {
151
+ var _cls3;
152
+
153
+ var prefixCls = _ref.prefixCls,
154
+ _ref$locale = _ref.locale,
155
+ locale = _ref$locale === void 0 ? _mobileUtils.defaultLocale : _ref$locale;
156
+ return /*#__PURE__*/_react.default.createElement("div", {
157
+ className: (0, _mobileUtils.cls)(prefixCls + "-uploader", className, (_cls3 = {}, _cls3[prefixCls + "-uploader-disabled"] = disabled, _cls3)),
158
+ style: style,
159
+ ref: domRef
160
+ }, /*#__PURE__*/_react.default.createElement("div", {
161
+ className: prefixCls + "-uploader-container"
162
+ }, uploaderSelect(prefixCls, locale), getUploadList(prefixCls, locale)));
163
+ });
164
+ });
165
+ /**
166
+ * 文件上传组件
167
+ * @en Uploader Component
168
+ * @type 数据录入
169
+ * @type_en Data Entry
170
+ * @name 文件上传
171
+ * @name_en Uploader
172
+ * @displayName Uploader
173
+ */
174
+
175
+ var _default = (0, _mobileUtils.componentWrapper)(Uploader, 'Uploader');
176
+
177
+ _exports.default = _default;
178
+ });