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