dtable-ui-component 6.0.3 → 6.0.4

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 (262) hide show
  1. package/lib/ButtonFormatter/index.js +8 -2
  2. package/lib/CheckboxEditor/index.css +8 -20
  3. package/lib/CheckboxEditor/index.js +98 -35
  4. package/lib/CheckboxFormatter/index.css +5 -0
  5. package/lib/CheckboxFormatter/index.js +9 -15
  6. package/lib/CollaboratorEditor/index.css +12 -35
  7. package/lib/CollaboratorEditor/index.js +18 -212
  8. package/lib/CollaboratorEditor/{mb-collaborator-editor-popover → mb-collaborator-editor}/index.js +27 -30
  9. package/lib/CollaboratorEditor/pc-collaborator-editor/index.js +257 -0
  10. package/lib/CollaboratorItem/index.css +7 -1
  11. package/lib/CollaboratorItem/index.js +6 -2
  12. package/lib/Comment/body/comment.js +190 -0
  13. package/lib/Comment/body/index.css +95 -0
  14. package/lib/Comment/body/index.js +32 -0
  15. package/lib/Comment/footer/btns/index.css +40 -0
  16. package/lib/Comment/footer/btns/index.js +113 -0
  17. package/lib/Comment/footer/index.css +157 -0
  18. package/lib/Comment/footer/index.js +169 -0
  19. package/lib/Comment/footer/input/index.css +52 -0
  20. package/lib/Comment/footer/input/index.js +448 -0
  21. package/lib/Comment/footer/input/participant/index.css +0 -0
  22. package/lib/Comment/footer/input/participant/index.js +53 -0
  23. package/lib/Comment/footer/participants/index.css +22 -0
  24. package/lib/Comment/footer/participants/index.js +68 -0
  25. package/lib/Comment/footer/participants/participant/index.css +5 -0
  26. package/lib/Comment/footer/participants/participant/index.js +32 -0
  27. package/lib/Comment/footer/participants/participant-select/index.css +104 -0
  28. package/lib/Comment/footer/participants/participant-select/index.js +182 -0
  29. package/lib/Comment/index.css +19 -0
  30. package/lib/Comment/index.js +304 -0
  31. package/lib/Comment/model.js +25 -0
  32. package/lib/Comment/utils/common.js +62 -0
  33. package/lib/Comment/utils/index.js +27 -0
  34. package/lib/Comment/utils/utilities.js +176 -0
  35. package/lib/DTableColorPicker/index.css +1 -1
  36. package/lib/DTableCustomizeSelect/index.js +2 -2
  37. package/lib/DTableFiltersPopover/utils/index.js +1 -7
  38. package/lib/DTableFiltersPopover/widgets/filter-calendar.js +2 -2
  39. package/lib/DTableGroupSelect/index.js +3 -3
  40. package/lib/DTableSelect/index.js +3 -1
  41. package/lib/DateEditor/index.js +14 -51
  42. package/lib/DateEditor/pc-date-editor-popover.js +149 -12
  43. package/lib/{common/delete-tip.js → DeleteTip/index.js} +12 -16
  44. package/lib/Department-editor/department-single-select.js +1 -1
  45. package/lib/Department-editor/index.js +3 -4
  46. package/lib/DepartmentSingleSelectFormatter/index.js +3 -2
  47. package/lib/DigitalSignEditor/constants.js +7 -0
  48. package/lib/DigitalSignEditor/index.css +69 -0
  49. package/lib/DigitalSignEditor/index.js +182 -0
  50. package/lib/DigitalSignEditor/service.js +39 -0
  51. package/lib/DigitalSignEditor/signature-board/index.css +35 -0
  52. package/lib/DigitalSignEditor/signature-board/index.js +135 -0
  53. package/lib/DigitalSignEditor/signature-board/signature-tool.js +396 -0
  54. package/lib/DigitalSignEditor/utils.js +29 -0
  55. package/lib/DurationEditor/index.js +110 -0
  56. package/lib/EmailEditor/index.js +58 -0
  57. package/lib/FileEditor/addition-previewer/index.css +1 -0
  58. package/lib/FileEditor/addition-previewer/index.js +52 -0
  59. package/lib/FileEditor/addition-previewer/local-file-addition/index.css +1 -0
  60. package/lib/FileEditor/addition-previewer/local-file-addition/index.js +252 -0
  61. package/lib/FileEditor/constants.js +7 -0
  62. package/lib/FileEditor/files-previewer/file-previewer/dropdown-menu.js +74 -0
  63. package/lib/FileEditor/files-previewer/file-previewer/file-name-editor/index.css +5 -0
  64. package/lib/FileEditor/files-previewer/file-previewer/file-name-editor/index.js +77 -0
  65. package/lib/FileEditor/files-previewer/file-previewer/index.css +88 -0
  66. package/lib/FileEditor/files-previewer/file-previewer/index.js +167 -0
  67. package/lib/FileEditor/files-previewer/index.css +56 -0
  68. package/lib/FileEditor/files-previewer/index.js +277 -0
  69. package/lib/FileEditor/index.css +6 -0
  70. package/lib/FileEditor/index.js +258 -11
  71. package/lib/FileEditor/utils.js +22 -0
  72. package/lib/FileItemFormatter/index.js +19 -20
  73. package/lib/FileUploader/index.css +9 -0
  74. package/lib/FileUploader/index.js +268 -14
  75. package/lib/FormulaFormatter/cell-value-validator.js +17 -17
  76. package/lib/FormulaFormatter/index.js +2 -1
  77. package/lib/FormulaFormatter/utils.js +0 -31
  78. package/lib/GeolocationEditor/country-editor.js +319 -0
  79. package/lib/GeolocationEditor/index.css +641 -0
  80. package/lib/GeolocationEditor/index.js +240 -0
  81. package/lib/GeolocationEditor/location-editor.js +368 -0
  82. package/lib/GeolocationEditor/map-editor/index.js +456 -0
  83. package/lib/GeolocationEditor/map-editor/large-editor/index.css +137 -0
  84. package/lib/GeolocationEditor/map-editor/large-editor/index.js +461 -0
  85. package/lib/GeolocationEditor/map-editor-utils.js +153 -0
  86. package/lib/GeolocationEditor/map-selection-editor/index.js +455 -0
  87. package/lib/GeolocationEditor/map-selection-editor/large-editor/index.css +1 -0
  88. package/lib/GeolocationEditor/map-selection-editor/large-editor/index.js +447 -0
  89. package/lib/GeolocationEditor/parse-geolocation.js +282 -0
  90. package/lib/GeolocationEditor/province-city-editor.js +292 -0
  91. package/lib/GeolocationEditor/province-editor.js +226 -0
  92. package/lib/GeolocationEditor/selector-header-item.js +28 -0
  93. package/lib/GeolocationEditor/selector-list.js +33 -0
  94. package/lib/ImageEditor/addition-previewer/image-link/index.css +45 -0
  95. package/lib/ImageEditor/addition-previewer/image-link/index.js +73 -0
  96. package/lib/ImageEditor/addition-previewer/index.css +106 -0
  97. package/lib/ImageEditor/addition-previewer/index.js +63 -0
  98. package/lib/ImageEditor/addition-previewer/local-image-addition/index.css +125 -0
  99. package/lib/ImageEditor/addition-previewer/local-image-addition/index.js +254 -0
  100. package/lib/ImageEditor/constants.js +7 -0
  101. package/lib/ImageEditor/images-previewer/image-preview/index.css +59 -0
  102. package/lib/ImageEditor/images-previewer/image-preview/index.js +155 -0
  103. package/lib/ImageEditor/images-previewer/index.css +18 -0
  104. package/lib/ImageEditor/images-previewer/index.js +140 -0
  105. package/lib/ImageEditor/index.css +24 -0
  106. package/lib/ImageEditor/index.js +194 -0
  107. package/lib/ImageFormatter/images-lazy-load.js +4 -2
  108. package/lib/ImageFormatter/index.js +8 -3
  109. package/lib/ImageThumbnail/index.css +20 -0
  110. package/lib/ImageThumbnail/index.js +137 -0
  111. package/lib/LinkEditor/index.js +2 -3
  112. package/lib/LinkEditor/pc-link-editor-popover/index.js +1 -1
  113. package/lib/MultipleSelectEditor/index.js +16 -177
  114. package/lib/NumberEditor/index.js +63 -77
  115. package/lib/RoleStatusEditor/index.css +0 -2
  116. package/lib/RowExpandDialog/body/index.css +21 -0
  117. package/lib/RowExpandDialog/body/index.js +262 -0
  118. package/lib/RowExpandDialog/column-content/index.css +48 -0
  119. package/lib/RowExpandDialog/column-content/index.js +50 -0
  120. package/lib/RowExpandDialog/header/index.css +31 -0
  121. package/lib/RowExpandDialog/header/index.js +55 -0
  122. package/lib/RowExpandDialog/index.css +28 -0
  123. package/lib/RowExpandDialog/index.js +237 -0
  124. package/lib/RowExpandEditor/RowExpandAddBtn/index.css +22 -0
  125. package/lib/RowExpandEditor/RowExpandAddBtn/index.js +24 -0
  126. package/lib/RowExpandEditor/RowExpandCheckboxEditor/index.css +18 -0
  127. package/lib/RowExpandEditor/RowExpandCheckboxEditor/index.js +43 -0
  128. package/lib/RowExpandEditor/RowExpandCollaboratorEditor/index.css +5 -0
  129. package/lib/RowExpandEditor/RowExpandCollaboratorEditor/index.js +232 -0
  130. package/lib/RowExpandEditor/RowExpandDateEditor/index.js +130 -0
  131. package/lib/RowExpandEditor/RowExpandDepartmentEditor/index.js +104 -0
  132. package/lib/RowExpandEditor/RowExpandDigitalSignEditor/index.css +13 -0
  133. package/lib/RowExpandEditor/RowExpandDigitalSignEditor/index.js +208 -0
  134. package/lib/RowExpandEditor/RowExpandDurationEditor/index.js +105 -0
  135. package/lib/RowExpandEditor/RowExpandEmailEditor/index.css +2 -0
  136. package/lib/RowExpandEditor/RowExpandEmailEditor/index.js +125 -0
  137. package/lib/RowExpandEditor/RowExpandFileEditor/index.css +1 -0
  138. package/lib/RowExpandEditor/RowExpandFileEditor/index.js +148 -0
  139. package/lib/RowExpandEditor/RowExpandGeolocationEditor/index.css +17 -0
  140. package/lib/RowExpandEditor/RowExpandGeolocationEditor/index.js +165 -0
  141. package/lib/RowExpandEditor/RowExpandImageEditor/index.css +11 -0
  142. package/lib/RowExpandEditor/RowExpandImageEditor/index.js +170 -0
  143. package/lib/RowExpandEditor/RowExpandLongTextEditor/index.css +6 -0
  144. package/lib/RowExpandEditor/RowExpandLongTextEditor/index.js +123 -0
  145. package/lib/RowExpandEditor/RowExpandMultipleSelectEditor/index.css +44 -0
  146. package/lib/RowExpandEditor/RowExpandMultipleSelectEditor/index.js +247 -0
  147. package/lib/RowExpandEditor/RowExpandNumberEditor/index.js +105 -0
  148. package/lib/RowExpandEditor/RowExpandRateEditor/index.css +13 -0
  149. package/lib/RowExpandEditor/RowExpandRateEditor/index.js +152 -0
  150. package/lib/RowExpandEditor/RowExpandSingleSelectorEditor/index.css +58 -0
  151. package/lib/RowExpandEditor/RowExpandSingleSelectorEditor/index.js +206 -0
  152. package/lib/RowExpandEditor/RowExpandTextEditor/index.css +4 -0
  153. package/lib/RowExpandEditor/RowExpandTextEditor/index.js +127 -0
  154. package/lib/RowExpandEditor/RowExpandUrlEditor/index.css +31 -0
  155. package/lib/RowExpandEditor/RowExpandUrlEditor/index.js +130 -0
  156. package/lib/RowExpandEditor/constants.js +44 -0
  157. package/lib/RowExpandEditor/index.css +0 -0
  158. package/lib/RowExpandEditor/index.js +32 -0
  159. package/lib/RowExpandFormatter/RowExpandDepartmentFormatter/index.js +27 -0
  160. package/lib/{RowExpandEmailFormatter → RowExpandFormatter/RowExpandEmailFormatter}/index.css +1 -1
  161. package/lib/{RowExpandEmailFormatter → RowExpandFormatter/RowExpandEmailFormatter}/index.js +1 -1
  162. package/lib/{RowExpandFileFormatter → RowExpandFormatter/RowExpandFileFormatter}/index.css +6 -6
  163. package/lib/{RowExpandFileFormatter → RowExpandFormatter/RowExpandFileFormatter}/index.js +3 -1
  164. package/lib/{RowExpandFileFormatter → RowExpandFormatter/RowExpandFileFormatter}/row-expand-file-item-formatter.js +12 -13
  165. package/lib/{RowExpandFormulaFormatter → RowExpandFormatter/RowExpandFormulaFormatter}/index.js +11 -10
  166. package/lib/{RowExpandImageFormatter → RowExpandFormatter/RowExpandImageFormatter}/index.css +6 -6
  167. package/lib/{RowExpandImageFormatter → RowExpandFormatter/RowExpandImageFormatter}/index.js +1 -1
  168. package/lib/{RowExpandImageFormatter → RowExpandFormatter/RowExpandImageFormatter}/row-expand-image-item-formatter.js +5 -5
  169. package/lib/{RowExpandLinkFormatter → RowExpandFormatter/RowExpandLinkFormatter}/collaborator-item-formatter.js +1 -1
  170. package/lib/{RowExpandLinkFormatter → RowExpandFormatter/RowExpandLinkFormatter}/index.css +2 -2
  171. package/lib/{RowExpandLinkFormatter → RowExpandFormatter/RowExpandLinkFormatter}/index.js +20 -20
  172. package/lib/{RowExpandRateFormatter → RowExpandFormatter/RowExpandRateFormatter}/index.css +1 -1
  173. package/lib/RowExpandFormatter/RowExpandUrlFormatter/index.css +1 -0
  174. package/lib/{RowExpandUrlFormatter → RowExpandFormatter/RowExpandUrlFormatter}/index.js +4 -3
  175. package/lib/RowExpandFormatter/constants.js +61 -0
  176. package/lib/RowExpandFormatter/index.css +28 -3
  177. package/lib/RowExpandFormatter/index.js +113 -131
  178. package/lib/SimpleLongTextFormatter/widgets/longTextEditor.css +2 -2
  179. package/lib/SingleSelectEditor/index.js +16 -156
  180. package/lib/SvgIcon/index.css +11 -0
  181. package/lib/SvgIcon/index.js +29 -0
  182. package/lib/TextEditor/index.js +112 -42
  183. package/lib/UploadProgress/index.js +38 -0
  184. package/lib/UrlEditor/index.js +61 -0
  185. package/lib/common/editor-base.js +52 -0
  186. package/lib/constants/file.js +96 -0
  187. package/lib/constants/index.js +27 -15
  188. package/lib/constants/key-codes.js +109 -0
  189. package/lib/css/cell-editor.css +18 -2
  190. package/lib/formatterConfig/base-formatter-config.js +23 -23
  191. package/lib/formatterConfig/index.js +3 -3
  192. package/lib/hooks/index.js +16 -0
  193. package/lib/index.js +81 -46
  194. package/lib/lang/index.js +19 -16
  195. package/lib/locales/de.json +167 -0
  196. package/lib/locales/en.json +167 -0
  197. package/lib/locales/es.json +167 -0
  198. package/lib/locales/fr.json +167 -0
  199. package/lib/locales/pt.json +167 -0
  200. package/lib/locales/ru.json +167 -0
  201. package/lib/locales/zh-CN.json +167 -0
  202. package/lib/select-editor/index.js +6 -6
  203. package/lib/select-editor/{mb-select-editor-popover → mb-select-editor}/index.js +3 -3
  204. package/lib/select-editor/pc-select-editor/index.css +85 -0
  205. package/lib/select-editor/pc-select-editor/index.js +295 -0
  206. package/lib/toaster/toast.js +19 -15
  207. package/lib/utils/cell-comparer.js +35 -0
  208. package/lib/utils/cell.js +55 -0
  209. package/lib/utils/column-utils.js +25 -0
  210. package/lib/utils/editor-utils.js +1 -6
  211. package/lib/utils/get-event-transfer.js +75 -0
  212. package/lib/utils/hotkey.js +37 -0
  213. package/lib/utils/object-utils.js +61 -0
  214. package/lib/utils/url.js +127 -8
  215. package/lib/utils/utils.js +119 -2
  216. package/package.json +3 -2
  217. package/lib/CollaboratorEditor/pc-collaborator-editor-popover/index.js +0 -97
  218. package/lib/FileEditor/pc-files-addition/index.js +0 -1
  219. package/lib/FileEditor/pc-files-addition/pc-file-uploaded-item.js +0 -1
  220. package/lib/FileEditor/pc-files-preview/index.js +0 -1
  221. package/lib/FileEditor/pc-files-preview/pc-file-item-preview.js +0 -1
  222. package/lib/FileItemFormatter/assets/file/192/excel.png +0 -0
  223. package/lib/FileItemFormatter/assets/file/192/file.png +0 -0
  224. package/lib/FileItemFormatter/assets/file/192/music.png +0 -0
  225. package/lib/FileItemFormatter/assets/file/192/pdf.png +0 -0
  226. package/lib/FileItemFormatter/assets/file/192/pic.png +0 -0
  227. package/lib/FileItemFormatter/assets/file/192/ppt.png +0 -0
  228. package/lib/FileItemFormatter/assets/file/192/txt.png +0 -0
  229. package/lib/FileItemFormatter/assets/file/192/video.png +0 -0
  230. package/lib/FileItemFormatter/assets/file/192/word.png +0 -0
  231. package/lib/FileItemFormatter/assets/file/24/excel.png +0 -0
  232. package/lib/FileItemFormatter/assets/file/24/file.png +0 -0
  233. package/lib/FileItemFormatter/assets/file/24/music.png +0 -0
  234. package/lib/FileItemFormatter/assets/file/24/pdf.png +0 -0
  235. package/lib/FileItemFormatter/assets/file/24/pic.png +0 -0
  236. package/lib/FileItemFormatter/assets/file/24/ppt.png +0 -0
  237. package/lib/FileItemFormatter/assets/file/24/txt.png +0 -0
  238. package/lib/FileItemFormatter/assets/file/24/video.png +0 -0
  239. package/lib/FileItemFormatter/assets/file/24/word.png +0 -0
  240. package/lib/FileItemFormatter/assets/folder/folder-192.png +0 -0
  241. package/lib/FileItemFormatter/assets/folder/folder-24.png +0 -0
  242. package/lib/FileItemFormatter/utils.js +0 -99
  243. package/lib/MultipleSelectEditor/index.css +0 -9
  244. package/lib/RowExpandLinkFormatter/utils.js +0 -71
  245. package/lib/RowExpandUrlFormatter/index.css +0 -1
  246. package/lib/SingleSelectEditor/index.css +0 -14
  247. package/lib/common/modal-portal.js +0 -26
  248. package/lib/locals/de.js +0 -103
  249. package/lib/locals/en.js +0 -104
  250. package/lib/locals/es.js +0 -103
  251. package/lib/locals/fr.js +0 -103
  252. package/lib/locals/pt.js +0 -103
  253. package/lib/locals/ru.js +0 -103
  254. package/lib/locals/zh-CN.js +0 -104
  255. package/lib/select-editor/pc-select-editor-popover/index.css +0 -71
  256. package/lib/select-editor/pc-select-editor-popover/index.js +0 -122
  257. /package/lib/CollaboratorEditor/{mb-collaborator-editor-popover → mb-collaborator-editor}/index.css +0 -0
  258. /package/lib/CollaboratorEditor/{pc-collaborator-editor-popover → pc-collaborator-editor}/index.css +0 -0
  259. /package/lib/{common/delete-tip.css → DeleteTip/index.css} +0 -0
  260. /package/lib/{RowExpandLinkFormatter → RowExpandFormatter/RowExpandLinkFormatter}/value-display-utils.js +0 -0
  261. /package/lib/{RowExpandRateFormatter → RowExpandFormatter/RowExpandRateFormatter}/index.js +0 -0
  262. /package/lib/select-editor/{mb-select-editor-popover → mb-select-editor}/index.css +0 -0
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _reactstrap = require("reactstrap");
10
+ var _imagesPreviewer = _interopRequireDefault(require("./images-previewer"));
11
+ var _additionPreviewer = _interopRequireDefault(require("./addition-previewer"));
12
+ var _constants = require("../constants");
13
+ var _DTableModalHeader = _interopRequireDefault(require("../DTableModalHeader"));
14
+ var _lang = require("../lang");
15
+ var _constants2 = require("./constants");
16
+ require("./index.css");
17
+ class ImageEditor extends _react.default.Component {
18
+ constructor(props) {
19
+ var _this;
20
+ super(props);
21
+ _this = this;
22
+ this.getValue = () => {
23
+ return this.state.value;
24
+ };
25
+ this.getEditorView = () => {
26
+ const {
27
+ isInModal,
28
+ value
29
+ } = this.props;
30
+ return !value || value.length === 0 || isInModal ? _constants.FILE_EDITOR_STATUS.ADDITION : _constants.FILE_EDITOR_STATUS.PREVIEWER;
31
+ };
32
+ this.deleteImage = function (index) {
33
+ let type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
34
+ let uploadLocalImageValue = _this.state.uploadLocalImageValue.slice(0);
35
+ let value = _this.state.value.slice(0);
36
+ if (_this.state.editorView === _constants.FILE_EDITOR_STATUS.PREVIEWER) {
37
+ value.splice(index, 1);
38
+ } else {
39
+ if (type === 'localPicture') {
40
+ uploadLocalImageValue.splice(index, 1);
41
+ }
42
+ }
43
+ _this.setState({
44
+ uploadLocalImageValue: uploadLocalImageValue,
45
+ isUpdated: true,
46
+ value: value
47
+ });
48
+ };
49
+ this.resetAdditionImage = () => {
50
+ this.setState({
51
+ uploadLocalImageValue: [],
52
+ imageLinkValue: []
53
+ });
54
+ };
55
+ this.toggle = e => {
56
+ e.stopPropagation();
57
+ if (this.state.isOpen && this.state.isUpdated) {
58
+ if (this.state.editorView === _constants.FILE_EDITOR_STATUS.ADDITION) {
59
+ let {
60
+ value,
61
+ uploadLocalImageValue
62
+ } = this.state;
63
+ let newValue = value.concat(uploadLocalImageValue);
64
+ this.setState({
65
+ value: newValue
66
+ }, () => {
67
+ this.props.isInModal ? this.props.onCommit(this.getValue()) : this.props.onCommit();
68
+ });
69
+ return;
70
+ }
71
+ this.props.isInModal ? this.props.onCommit(this.getValue()) : this.props.onCommit();
72
+ }
73
+ if (this.props.isInModal) {
74
+ this.props.onToggle();
75
+ }
76
+ const nextIsOpen = !this.state.isOpen;
77
+ this.setState({
78
+ isOpen: nextIsOpen
79
+ }, () => {
80
+ if (!nextIsOpen) {
81
+ this.props.onCommitCancel && this.props.onCommitCancel();
82
+ }
83
+ });
84
+ };
85
+ this.closeEditor = () => {
86
+ this.setState({
87
+ isOpen: false
88
+ });
89
+ };
90
+ this.togglePreviewer = type => {
91
+ this.setState({
92
+ editorView: type
93
+ });
94
+ };
95
+ this.fileUploadCompleted = fileMessage => {
96
+ let uploadLocalImageValue = this.state.uploadLocalImageValue.slice(0);
97
+ const imageUrl = fileMessage.url;
98
+ uploadLocalImageValue.push(imageUrl);
99
+ this.setState({
100
+ uploadLocalImageValue: uploadLocalImageValue,
101
+ isUpdated: true
102
+ });
103
+ };
104
+ this.addUploadedFile = fileMessageList => {
105
+ let uploadLocalImageValue = this.state.uploadLocalImageValue.slice(0);
106
+ // eslint-disable-next-line no-unused-vars
107
+ for (let fileMessage of fileMessageList) {
108
+ uploadLocalImageValue.push(fileMessage.url);
109
+ }
110
+ this.setState({
111
+ uploadLocalImageValue: uploadLocalImageValue,
112
+ isUpdated: true
113
+ });
114
+ };
115
+ this.renderHeader = () => {
116
+ let {
117
+ editorView
118
+ } = this.state;
119
+ if (this.props.isInModal) {
120
+ return /*#__PURE__*/_react.default.createElement("span", null, (0, _lang.getLocale)('Add_images'));
121
+ }
122
+ if (editorView === _constants.FILE_EDITOR_STATUS.PREVIEWER) {
123
+ return /*#__PURE__*/_react.default.createElement("span", null, (0, _lang.getLocale)('All_images'));
124
+ }
125
+ return /*#__PURE__*/_react.default.createElement("div", {
126
+ onClick: this.showImageListPreviewer
127
+ }, /*#__PURE__*/_react.default.createElement("span", {
128
+ "aria-hidden": "true",
129
+ className: "dtable-font dtable-icon-return mr-2"
130
+ }), /*#__PURE__*/_react.default.createElement("span", null, (0, _lang.getLocale)('Add_images')));
131
+ };
132
+ this.showImageListPreviewer = () => {
133
+ let {
134
+ value,
135
+ uploadLocalImageValue,
136
+ imageLinkValue
137
+ } = this.state;
138
+ let newValue = value.concat(uploadLocalImageValue, imageLinkValue);
139
+ this.setState({
140
+ value: newValue
141
+ });
142
+ this.togglePreviewer(_constants.FILE_EDITOR_STATUS.PREVIEWER);
143
+ };
144
+ this.saveImageLink = imageUrl => {
145
+ this.setState({
146
+ imageLinkValue: imageUrl,
147
+ isUpdated: true
148
+ });
149
+ this.showImageListPreviewer();
150
+ };
151
+ this.uploadFile = (file, callback) => {
152
+ return this.props.uploadFile(file, _constants2.IMAGES_FOLDER, callback);
153
+ };
154
+ this.state = {
155
+ value: props.value || [],
156
+ editorView: this.getEditorView(),
157
+ isOpen: true,
158
+ isShowFileChooser: false,
159
+ uploadLocalImageValue: [],
160
+ imageLinkValue: [],
161
+ isUpdated: false
162
+ };
163
+ }
164
+ render() {
165
+ return /*#__PURE__*/_react.default.createElement(_reactstrap.Modal, {
166
+ className: "dtable-ui-image-editor-dialog",
167
+ contentClassName: "dtable-ui-image-editor-modal",
168
+ isOpen: this.state.isOpen,
169
+ toggle: this.toggle
170
+ }, /*#__PURE__*/_react.default.createElement(_DTableModalHeader.default, {
171
+ toggle: this.toggle
172
+ }, this.renderHeader()), /*#__PURE__*/_react.default.createElement(_reactstrap.ModalBody, {
173
+ className: "p-0"
174
+ }, /*#__PURE__*/_react.default.createElement("div", {
175
+ className: "dtable-ui-image-editor-container"
176
+ }, this.state.editorView === _constants.FILE_EDITOR_STATUS.PREVIEWER && /*#__PURE__*/_react.default.createElement(_imagesPreviewer.default, {
177
+ value: this.state.value,
178
+ togglePreviewer: this.togglePreviewer,
179
+ deleteImage: this.deleteImage,
180
+ resetAdditionImage: this.resetAdditionImage
181
+ }), this.state.editorView === _constants.FILE_EDITOR_STATUS.ADDITION && /*#__PURE__*/_react.default.createElement(_additionPreviewer.default, {
182
+ deleteImage: this.deleteImage,
183
+ handleFilesChange: this.handleFilesChange,
184
+ uploadLocalImageValue: this.state.uploadLocalImageValue,
185
+ togglePreviewer: this.togglePreviewer,
186
+ saveImageLink: this.saveImageLink,
187
+ fileUploadCompleted: this.fileUploadCompleted,
188
+ addUploadedFile: this.addUploadedFile,
189
+ showImageListPreviewer: this.showImageListPreviewer,
190
+ uploadFile: this.uploadFile
191
+ }))));
192
+ }
193
+ }
194
+ var _default = exports.default = ImageEditor;
@@ -39,11 +39,13 @@ class ImagesLazyLoad extends _react.default.Component {
39
39
  loadedCount: 0
40
40
  }, () => {
41
41
  let {
42
- server
42
+ server,
43
+ dtableUuid
43
44
  } = this.props;
44
45
  images.forEach((item, index) => {
45
46
  let url = (0, _url.getImageThumbnailUrl)(item, {
46
- server
47
+ server,
48
+ dtableUuid
47
49
  });
48
50
  this.lazyLoadImage(url, image => {
49
51
  let {
@@ -67,7 +67,9 @@ class ImageFormatter extends _react.default.Component {
67
67
  value,
68
68
  server,
69
69
  containerClassName,
70
- readOnly
70
+ lightboxClassName,
71
+ readOnly,
72
+ dtableUuid
71
73
  } = this.props;
72
74
  const className = (0, _classnames.default)('dtable-ui cell-formatter-container image-formatter', containerClassName);
73
75
  const {
@@ -96,9 +98,11 @@ class ImageFormatter extends _react.default.Component {
96
98
  images: value,
97
99
  server: server,
98
100
  onImageClick: this.onImageClick,
99
- renderItem: this.props.renderItem
101
+ renderItem: this.props.renderItem,
102
+ dtableUuid: dtableUuid
100
103
  })), isPreviewImage && /*#__PURE__*/_react.default.createElement(_ImagePreviewerLightbox.default, {
101
104
  imageItems: value,
105
+ className: lightboxClassName,
102
106
  imageIndex: previewImageIndex,
103
107
  closeImagePopup: this.closeImagePopup,
104
108
  moveToPrevImage: this.movePrev,
@@ -110,7 +114,8 @@ class ImageFormatter extends _react.default.Component {
110
114
  server: server,
111
115
  moveToPrevRowImage: this.props.moveToPrevRowImage,
112
116
  moveToNextRowImage: this.props.moveToNextRowImage,
113
- onViewOriginal: this.props.onViewOriginal
117
+ onViewOriginal: this.props.onViewOriginal,
118
+ dtableUuid: dtableUuid
114
119
  }));
115
120
  }
116
121
  }
@@ -0,0 +1,20 @@
1
+ .dtable-ui-image-thumbnail {
2
+ height: 100px;
3
+ width: 100px;
4
+ border: 2px solid #ededed;
5
+ border-radius: 4px;
6
+ cursor: pointer;
7
+ display: flex;
8
+ align-items: center;
9
+ justify-content: center;
10
+ margin: 5px;
11
+ position: relative;
12
+ }
13
+
14
+ .dtable-ui-image-thumbnail .dtable-ui-image-icons-choice {
15
+ display: none;
16
+ }
17
+
18
+ .dtable-ui-image-thumbnail:hover .dtable-ui-image-icons-choice {
19
+ display: flex;
20
+ }
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _reactstrap = require("reactstrap");
10
+ var _classnames = _interopRequireDefault(require("classnames"));
11
+ var _DeleteTip = _interopRequireDefault(require("../DeleteTip"));
12
+ var _url = require("../utils/url");
13
+ var _lang = require("../lang");
14
+ require("./index.css");
15
+ class ImageThumbnail extends _react.default.Component {
16
+ constructor(props) {
17
+ super(props);
18
+ this.getUrl = src => {
19
+ if ((0, _url.checkSVGImage)(src)) {
20
+ this.setState({
21
+ imageThumbnailUrl: src
22
+ });
23
+ return;
24
+ }
25
+ const imageThumbnailUrl = (0, _url.getImageThumbnailUrl)(src);
26
+ (0, _url.checkImgExists)(imageThumbnailUrl).then(() => {
27
+ this.setState({
28
+ imageThumbnailUrl
29
+ });
30
+ }).catch(() => {
31
+ this.setState({
32
+ imageThumbnailUrl: this.imageLoadingFailedUrl
33
+ });
34
+ });
35
+ };
36
+ this.onClick = () => {
37
+ this.props.onClick(this.props.index);
38
+ };
39
+ this.downloadImage = e => {
40
+ e.stopPropagation();
41
+ this.props.downloadImage(this.props.src);
42
+ };
43
+ this.deleteImage = () => {
44
+ this.closeTip();
45
+ this.props.deleteImage(this.props.index);
46
+ };
47
+ this.onClickDelete = e => {
48
+ e.stopPropagation();
49
+ this.position = {
50
+ top: e.clientY,
51
+ left: e.clientX
52
+ };
53
+ this.setState({
54
+ showTip: true
55
+ });
56
+ };
57
+ this.closeTip = () => {
58
+ this.setState({
59
+ showTip: false
60
+ });
61
+ };
62
+ this.toggle = () => {
63
+ this.setState({
64
+ isTooltipOpen: !this.state.isTooltipOpen
65
+ });
66
+ };
67
+ this.state = {
68
+ imageThumbnailUrl: '',
69
+ showTip: false,
70
+ isTooltipOpen: false
71
+ };
72
+ this.ref = null;
73
+ const {
74
+ mediaUrl = ''
75
+ } = props.config || {};
76
+ this.imageLoadingFailedUrl = "".concat(mediaUrl, "img/image-loading-failed.png");
77
+ }
78
+ componentDidMount() {
79
+ this.getUrl(this.props.src);
80
+ }
81
+ UNSAFE_componentWillReceiveProps(nextProps) {
82
+ if (nextProps.src !== this.props.src) {
83
+ this.getUrl(nextProps.src);
84
+ }
85
+ }
86
+ render() {
87
+ const {
88
+ index,
89
+ downloadImage,
90
+ src,
91
+ className,
92
+ name
93
+ } = this.props;
94
+ const {
95
+ imageThumbnailUrl
96
+ } = this.state;
97
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
98
+ className: (0, _classnames.default)('dtable-ui-image-thumbnail', className),
99
+ onClick: this.onClick,
100
+ ref: ref => this.ref = ref
101
+ }, /*#__PURE__*/_react.default.createElement("img", {
102
+ src: imageThumbnailUrl,
103
+ id: "item-image-".concat(index),
104
+ alt: ""
105
+ }), /*#__PURE__*/_react.default.createElement("div", {
106
+ className: "dtable-ui-image-icons-choice"
107
+ }, downloadImage && /*#__PURE__*/_react.default.createElement("span", {
108
+ className: "image-icon",
109
+ onClick: this.downloadImage
110
+ }, /*#__PURE__*/_react.default.createElement("i", {
111
+ "aria-hidden": "true",
112
+ className: "dtable-font dtable-icon-download"
113
+ })), /*#__PURE__*/_react.default.createElement("span", {
114
+ className: "image-icon",
115
+ onClick: this.onClickDelete
116
+ }, /*#__PURE__*/_react.default.createElement("i", {
117
+ "aria-hidden": "true",
118
+ className: "dtable-font dtable-icon-fork-number"
119
+ })))), this.state.showTip && /*#__PURE__*/_react.default.createElement(_DeleteTip.default, {
120
+ position: this.position,
121
+ toggle: this.closeTip,
122
+ handleDelete: this.deleteImage,
123
+ deleteTip: this.props.deleteTip || (0, _lang.getLocale)('Are_you_sure_you_want_to_delete_this_image')
124
+ }), this.ref && /*#__PURE__*/_react.default.createElement(_reactstrap.Tooltip, {
125
+ placement: "bottom",
126
+ isOpen: this.state.isTooltipOpen,
127
+ toggle: this.toggle,
128
+ target: this.ref,
129
+ delay: {
130
+ show: 0,
131
+ hide: 0
132
+ },
133
+ fade: false
134
+ }, name || (0, _url.getFileName)(src)));
135
+ }
136
+ }
137
+ var _default = exports.default = ImageThumbnail;
@@ -10,7 +10,6 @@ var _react = _interopRequireWildcard(require("react"));
10
10
  var _reactResponsive = _interopRequireDefault(require("react-responsive"));
11
11
  var _dtableUtils = require("dtable-utils");
12
12
  var _lang = require("../lang");
13
- var _constants = require("../constants");
14
13
  var _EditEditorButton = _interopRequireDefault(require("../EditEditorButton"));
15
14
  var _linkEditorOption = _interopRequireDefault(require("./link-editor-option"));
16
15
  var _pcLinkEditorPopover = _interopRequireDefault(require("./pc-link-editor-popover"));
@@ -73,11 +72,11 @@ class LinkEditor extends _react.default.Component {
73
72
  data
74
73
  } = linkedColumn;
75
74
  switch (type) {
76
- case _constants.CellType.NUMBER:
75
+ case _dtableUtils.CellType.NUMBER:
77
76
  {
78
77
  return (0, _dtableUtils.getNumberDisplayString)(value, data);
79
78
  }
80
- case _constants.CellType.DATE:
79
+ case _dtableUtils.CellType.DATE:
81
80
  {
82
81
  let {
83
82
  format
@@ -55,7 +55,7 @@ class PCLinkEditorPopover extends _react.default.Component {
55
55
  position: 'absolute'
56
56
  });
57
57
  return /*#__PURE__*/_react.default.createElement("div", {
58
- className: "dtable-ui-editor-popover dtable-ui-link-editor-popover",
58
+ className: "dtable-ui-editor-container dtable-ui-link-editor-popover",
59
59
  style: popoverStyle
60
60
  }, /*#__PURE__*/_react.default.createElement("div", {
61
61
  className: "link-options-search"
@@ -1,188 +1,27 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.default = void 0;
9
- var _react = _interopRequireWildcard(require("react"));
8
+ var _react = _interopRequireDefault(require("react"));
10
9
  var _reactResponsive = _interopRequireDefault(require("react-responsive"));
11
- var _lang = require("../lang");
12
- var _EditEditorButton = _interopRequireDefault(require("../EditEditorButton"));
13
10
  var _selectEditor = require("../select-editor");
14
- require("./index.css");
15
- class MultipleSelectEditor extends _react.default.Component {
16
- constructor(props) {
17
- super(props);
18
- this.onMouseDown = e => {
19
- if (this.editorContainer !== e.target && !this.editorContainer.contains(e.target)) {
20
- this.onClosePopover();
21
- }
22
- };
23
- this.getFormattedOptions = () => {
24
- let {
25
- newValue
26
- } = this.state;
27
- if (Array.isArray(newValue) && newValue.length > 0) {
28
- return newValue.map(option_id => {
29
- return this.options.find(option => option.id === option_id);
30
- }).filter(option => !!option);
31
- }
32
- return [];
33
- };
34
- this.onAddOptionToggle = event => {
35
- event.nativeEvent.stopImmediatePropagation();
36
- event.stopPropagation();
37
- if (this.props.isReadOnly) {
38
- return;
39
- }
40
- let isPopoverShow = !this.state.isPopoverShow;
41
- if (isPopoverShow) {
42
- let popoverPosition = this.caculatePopoverPosition();
43
- this.setState({
44
- isPopoverShow,
45
- popoverPosition
46
- });
47
- } else {
48
- this.setState({
49
- isPopoverShow
50
- });
51
- }
52
- };
53
- this.onCommit = newValue => {
54
- let updated = {};
55
- let {
56
- column
57
- } = this.props;
58
- updated[column.key] = newValue;
59
- this.props.onCommit(updated);
60
- };
61
- this.onOptionItemToggle = option => {
62
- let newValue = this.state.newValue.slice();
63
- let optionIndex = newValue.findIndex(option_id => option_id === option.id);
64
- if (optionIndex !== -1) {
65
- newValue.splice(optionIndex, 1);
66
- } else {
67
- newValue.push(option.id);
68
- }
69
- this.setState({
70
- newValue
71
- }, () => {
72
- this.onCommit(newValue);
73
- });
74
- };
75
- this.onDeleteOption = option => {
76
- let newValue = this.state.newValue.slice();
77
- let optionIndex = newValue.findIndex(option_id => option_id === option.id);
78
- newValue.splice(optionIndex, 1);
79
- this.setState({
80
- newValue
81
- }, () => {
82
- this.onCommit(newValue);
83
- });
84
- };
85
- this.onAddNewOption = optionName => {
86
- this.props.onAddNewOption(optionName);
87
- this.onClosePopover();
88
- };
89
- this.caculatePopoverPosition = () => {
90
- const POPOVER_MAX_HEIGHT = 200;
91
- let innerHeight = window.innerHeight;
92
- let {
93
- top,
94
- height
95
- } = this.editor.getClientRects()[0];
96
- let isBelow = innerHeight - (top + height) > POPOVER_MAX_HEIGHT;
97
- let position = {
98
- top: height + 1,
99
- left: 0
100
- };
101
- if (!isBelow) {
102
- let bottom = height + 1;
103
- position = {
104
- bottom: bottom,
105
- left: 0
106
- };
107
- }
108
- return position;
109
- };
110
- this.onClosePopover = () => {
111
- this.setState({
112
- isPopoverShow: false
113
- });
114
- };
115
- this.setEditorContainerRef = editorContainer => {
116
- this.editorContainer = editorContainer;
117
- };
118
- this.setEditorRef = editor => {
119
- this.editor = editor;
120
- };
121
- this.state = {
122
- newValue: Array.isArray(props.value) ? props.value : [],
123
- isPopoverShow: false,
124
- popoverPosition: {}
125
- };
126
- let {
127
- column: _column
128
- } = this.props;
129
- this.options = _column.data && (_column.data.options || []);
130
- }
131
- componentDidMount() {
132
- document.addEventListener('mousedown', this.onMouseDown);
133
- }
134
- componentWillUnmount() {
135
- document.removeEventListener('mousedown', this.onMouseDown);
136
- }
137
- render() {
138
- let {
139
- isPopoverShow,
140
- popoverPosition
141
- } = this.state;
142
- let options = this.options;
143
- let selectedOptions = this.getFormattedOptions();
144
- return /*#__PURE__*/_react.default.createElement("div", {
145
- ref: this.setEditorContainerRef,
146
- className: "cell-editor dtable-ui-multiple-select-editor"
147
- }, /*#__PURE__*/_react.default.createElement("div", {
148
- ref: this.setEditorRef,
149
- className: "dtable-ui-select-editor-container",
150
- onClick: this.onAddOptionToggle
151
- }, selectedOptions.length === 0 && /*#__PURE__*/_react.default.createElement(_EditEditorButton.default, {
152
- text: (0, _lang.getLocale)('Add_an_option')
153
- }), selectedOptions.length !== 0 && selectedOptions.map(option => {
154
- return /*#__PURE__*/_react.default.createElement(_selectEditor.SelectEditorOption, {
155
- key: option.id,
156
- option: option,
157
- isShowRemoveIcon: true,
158
- onDeleteSelectOption: this.onDeleteOption
159
- });
160
- })), isPopoverShow && /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement(_reactResponsive.default, {
161
- query: "(min-width: 768px)"
162
- }, /*#__PURE__*/_react.default.createElement(_selectEditor.PCSelectEditorPopover, {
163
- popoverPosition: popoverPosition,
164
- options: options,
165
- selectedOptions: selectedOptions,
166
- onOptionItemToggle: this.onOptionItemToggle,
167
- isSupportNewOption: this.props.isSupportNewOption,
168
- onAddNewOption: this.onAddNewOption
169
- })), /*#__PURE__*/_react.default.createElement(_reactResponsive.default, {
170
- query: "(max-width: 767.8px)"
171
- }, /*#__PURE__*/_react.default.createElement(_selectEditor.MBSelectEditorPopover, {
172
- isReadOnly: this.props.isReadOnly,
173
- value: this.state.newValue,
174
- column: this.props.column,
175
- options: options,
176
- onOptionItemToggle: this.onOptionItemToggle,
177
- isShowRemoveIcon: true,
178
- isSupportNewOption: this.props.isSupportNewOption,
179
- onAddNewOption: this.onAddNewOption,
180
- onClosePopover: this.onClosePopover
181
- }))));
182
- }
183
- }
184
- MultipleSelectEditor.defaultProps = {
185
- isReadOnly: false,
186
- value: []
11
+ const MultipleSelectEditor = _ref => {
12
+ let {
13
+ value: oldValue,
14
+ ...props
15
+ } = _ref;
16
+ const value = oldValue ? Array.isArray(oldValue) ? oldValue : [oldValue] : [];
17
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_reactResponsive.default, {
18
+ query: "(min-width: 768px)"
19
+ }, /*#__PURE__*/_react.default.createElement(_selectEditor.PCSelectEditor, Object.assign({}, props, {
20
+ value: value
21
+ }))), /*#__PURE__*/_react.default.createElement(_reactResponsive.default, {
22
+ query: "(max-width: 767.8px)"
23
+ }, /*#__PURE__*/_react.default.createElement(_selectEditor.MBSelectEditor, Object.assign({}, props, {
24
+ value: value
25
+ }))));
187
26
  };
188
27
  var _default = exports.default = MultipleSelectEditor;