dtable-ui-component 0.1.75 → 0.1.79

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 (164) hide show
  1. package/README.md +20 -2
  2. package/lib/AutoNumberFormatter/index.css +1 -0
  3. package/{es/components/cell-formatter/auto-number-formatter.js → lib/AutoNumberFormatter/index.js} +1 -0
  4. package/lib/ButtonFormatter/index.css +13 -0
  5. package/{es/components/cell-formatter/button-formatter.js → lib/ButtonFormatter/index.js} +1 -0
  6. package/lib/CTimeFormatter/index.css +1 -0
  7. package/{es/components/cell-formatter/ctime-formatter.js → lib/CTimeFormatter/index.js} +1 -0
  8. package/lib/CheckboxEditor/index.js +104 -0
  9. package/lib/CheckboxFormatter/index.css +1 -0
  10. package/{es/components/cell-formatter/checkbox-formatter.js → lib/CheckboxFormatter/index.js} +1 -0
  11. package/lib/CollaboratorEditor/index.css +48 -0
  12. package/lib/CollaboratorEditor/index.js +237 -0
  13. package/lib/CollaboratorEditor/mb-collaborator-editor-popover/index.css +86 -0
  14. package/lib/CollaboratorEditor/mb-collaborator-editor-popover/index.js +178 -0
  15. package/lib/CollaboratorEditor/pc-collaborator-editor-popover/index.css +1 -0
  16. package/lib/CollaboratorEditor/pc-collaborator-editor-popover/index.js +110 -0
  17. package/lib/CollaboratorFormatter/index.css +1 -0
  18. package/{es/components/cell-formatter/collaborator-formatter.js → lib/CollaboratorFormatter/index.js} +3 -2
  19. package/lib/CollaboratorItem/index.css +49 -0
  20. package/{es/components/common/collaborator-item.js → lib/CollaboratorItem/index.js} +1 -0
  21. package/lib/CreatorFormatter/index.css +1 -0
  22. package/{es/components/cell-formatter/creator-formatter.js → lib/CreatorFormatter/index.js} +3 -2
  23. package/lib/DateEditor/index.css +4 -0
  24. package/lib/DateEditor/index.js +152 -0
  25. package/{es/css → lib/DateEditor/mb-date-editor-popover}/custom-rc-calendar.css +0 -0
  26. package/lib/DateEditor/mb-date-editor-popover/index.css +45 -0
  27. package/lib/DateEditor/mb-date-editor-popover/index.js +245 -0
  28. package/lib/DateEditor/pc-date-editor-popover.js +142 -0
  29. package/lib/DateFormatter/index.css +1 -0
  30. package/{es/components/cell-formatter/date-formatter.js → lib/DateFormatter/index.js} +2 -1
  31. package/lib/DtableSelect/index.js +140 -0
  32. package/lib/DurationFormatter/index.css +1 -0
  33. package/{es/components/cell-formatter/duration-formatter.js → lib/DurationFormatter/index.js} +2 -1
  34. package/{es/components/common/edit-editor-button.js → lib/EditEditorButton/index.js} +0 -0
  35. package/lib/EmailFormatter/index.css +5 -0
  36. package/{es/components/cell-formatter/email-formatter.js → lib/EmailFormatter/index.js} +1 -0
  37. package/lib/FileEditor/index.js +46 -0
  38. package/lib/FileEditor/pc-files-addition/index.js +0 -0
  39. package/lib/FileEditor/pc-files-addition/pc-file-uploaded-item.js +0 -0
  40. package/lib/FileEditor/pc-files-preview/index.js +0 -0
  41. package/lib/FileEditor/pc-files-preview/pc-file-item-preview.js +0 -0
  42. package/lib/FileFormatter/index.css +29 -0
  43. package/{es/components/cell-formatter/file-formatter.js → lib/FileFormatter/index.js} +2 -1
  44. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/excel.png +0 -0
  45. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/file.png +0 -0
  46. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/music.png +0 -0
  47. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/pdf.png +0 -0
  48. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/pic.png +0 -0
  49. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/ppt.png +0 -0
  50. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/txt.png +0 -0
  51. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/video.png +0 -0
  52. package/{es/assets/images → lib/FileItemFormatter/assets}/file/192/word.png +0 -0
  53. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/excel.png +0 -0
  54. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/file.png +0 -0
  55. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/music.png +0 -0
  56. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/pdf.png +0 -0
  57. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/pic.png +0 -0
  58. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/ppt.png +0 -0
  59. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/txt.png +0 -0
  60. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/video.png +0 -0
  61. package/{es/assets/images → lib/FileItemFormatter/assets}/file/24/word.png +0 -0
  62. package/{es/assets/images → lib/FileItemFormatter/assets}/folder/folder-192.png +0 -0
  63. package/{es/assets/images → lib/FileItemFormatter/assets}/folder/folder-24.png +0 -0
  64. package/{es/components/cell-formatter/widgets/file-item-formatter.js → lib/FileItemFormatter/index.js} +2 -2
  65. package/lib/FileItemFormatter/utils.js +72 -0
  66. package/{es/components/file-uploader → lib/FileUploader}/index.js +0 -0
  67. package/{es/utils → lib/FormulaFormatter}/cell-value-validator.js +1 -2
  68. package/lib/FormulaFormatter/index.css +19 -0
  69. package/{es/components/cell-formatter/formula-formatter.js → lib/FormulaFormatter/index.js} +7 -8
  70. package/{es/utils/column-utils.js → lib/FormulaFormatter/utils.js} +5 -1
  71. package/lib/GeolocationFormatter/index.css +1 -0
  72. package/{es/components/cell-formatter/geolocation-formatter.js → lib/GeolocationFormatter/index.js} +2 -1
  73. package/lib/HtmlLongTextFormatter/index.css +63 -0
  74. package/{es/components/cell-formatter/widgets/long-text-formatter/html-long-text-formatter.js → lib/HtmlLongTextFormatter/index.js} +5 -2
  75. package/{es/utils → lib/HtmlLongTextFormatter}/markdown2html.js +2 -2
  76. package/{es/utils → lib/HtmlLongTextFormatter}/unified/index.js +8 -5
  77. package/{es/utils → lib/HtmlLongTextFormatter}/vfile/core.js +4 -2
  78. package/{es/utils → lib/HtmlLongTextFormatter}/vfile/index.js +4 -3
  79. package/{es/components/common → lib/ImageFormatter}/images-lazy-load.js +2 -2
  80. package/lib/ImageFormatter/index.css +34 -0
  81. package/{es/components/cell-formatter/image-formatter.js → lib/ImageFormatter/index.js} +4 -3
  82. package/lib/ImageFormatter/utils.js +7 -0
  83. package/{es/css/image-previewer-ligntbox.css → lib/ImagePreviewerLightbox/index.css} +0 -0
  84. package/{es/components/cell-formatter/widgets/image-previewer-lightbox.js → lib/ImagePreviewerLightbox/index.js} +3 -3
  85. package/lib/ImagePreviewerLightbox/utils.js +8 -0
  86. package/lib/LastModifierFormatter/index.css +1 -0
  87. package/{es/components/cell-formatter/last-modifier-formatter.js → lib/LastModifierFormatter/index.js} +5 -4
  88. package/lib/LinkEditor/index.css +9 -0
  89. package/lib/LinkEditor/index.js +304 -0
  90. package/{es/components/common → lib/LinkEditor}/link-editor-option.js +0 -0
  91. package/lib/LinkEditor/mb-link-editor-popover/index.css +85 -0
  92. package/lib/LinkEditor/mb-link-editor-popover/index.js +171 -0
  93. package/lib/LinkEditor/pc-link-editor-popover/index.css +63 -0
  94. package/lib/LinkEditor/pc-link-editor-popover/index.js +115 -0
  95. package/lib/LinkFormatter/index.css +27 -0
  96. package/{es/components/cell-formatter/link-formatter.js → lib/LinkFormatter/index.js} +2 -2
  97. package/{es/css/loading.css → lib/Loading/index.css} +0 -0
  98. package/{es/components/loading.js → lib/Loading/index.js} +1 -1
  99. package/{es/components/cell-formatter/long-text-formatter.js → lib/LongTextFormatter/index.js} +4 -6
  100. package/{es/components/common/mobile/mb-editor-header.js → lib/MBEditorHeader/index.js} +0 -0
  101. package/lib/MTimeFormatter/index.css +1 -0
  102. package/{es/components/cell-formatter/mtime-formatter.js → lib/MTimeFormatter/index.js} +1 -0
  103. package/{es/components/common/modal-portal.js → lib/ModalPortal/index.js} +0 -0
  104. package/lib/MultipleSelectEditor/index.css +9 -0
  105. package/lib/MultipleSelectEditor/index.js +236 -0
  106. package/lib/MultipleSelectFormatter/index.css +1 -0
  107. package/{es/components/cell-formatter/multiple-select-formatter.js → lib/MultipleSelectFormatter/index.js} +2 -1
  108. package/lib/NumberEditor/index.js +154 -0
  109. package/lib/NumberFormatter/index.css +1 -0
  110. package/{es/components/cell-formatter/number-formatter.js → lib/NumberFormatter/index.js} +2 -1
  111. package/lib/RateFormatter/index.css +1 -0
  112. package/{es/components/cell-formatter/rate-formatter.js → lib/RateFormatter/index.js} +1 -0
  113. package/{es/components/common/select-item.js → lib/SelectItem/index.js} +0 -0
  114. package/lib/SimpleLongTextFormatter/index.css +63 -0
  115. package/{es/components/cell-formatter/widgets/long-text-formatter/simple-long-text-formatter.js → lib/SimpleLongTextFormatter/index.js} +5 -2
  116. package/{es/utils → lib/SimpleLongTextFormatter}/normalize-long-text-value.js +3 -3
  117. package/lib/SingleSelectEditor/index.css +9 -0
  118. package/lib/SingleSelectEditor/index.js +201 -0
  119. package/lib/SingleSelectFormatter/index.css +1 -0
  120. package/{es/components/cell-formatter/single-select-formatter.js → lib/SingleSelectFormatter/index.js} +2 -1
  121. package/lib/TextEditor/index.js +122 -0
  122. package/lib/TextFormatter/index.css +1 -0
  123. package/{es/components/cell-formatter/text-formatter.js → lib/TextFormatter/index.js} +1 -0
  124. package/lib/UrlFormatter/index.css +5 -0
  125. package/{es/components/cell-formatter/url-formatter.js → lib/UrlFormatter/index.js} +1 -0
  126. package/{es → lib}/assets/images/avatar/default_avatar.png +0 -0
  127. package/{es/components/cell-factory/cell-formatter-factory.js → lib/cellFormatterFactory/index.js} +3 -3
  128. package/{es → lib}/constants/cell-types.js +0 -0
  129. package/lib/constants/index.js +49 -0
  130. package/lib/css/cell-editor.css +6 -0
  131. package/lib/css/cell-formatter.css +4 -0
  132. package/lib/css/mb-cell-editor.css +55 -0
  133. package/lib/formatterConfig/index.js +31 -0
  134. package/lib/index.js +45 -0
  135. package/{es → lib}/lang/index.js +0 -0
  136. package/{es → lib}/locals/de.js +0 -0
  137. package/{es → lib}/locals/en.js +0 -0
  138. package/{es → lib}/locals/fr.js +0 -0
  139. package/{es → lib}/locals/zh-CN.js +0 -0
  140. package/lib/select-editor/index.js +4 -0
  141. package/lib/select-editor/mb-select-editor-popover/index.css +127 -0
  142. package/lib/select-editor/mb-select-editor-popover/index.js +231 -0
  143. package/lib/select-editor/pc-select-editor-popover/index.css +72 -0
  144. package/lib/select-editor/pc-select-editor-popover/index.js +144 -0
  145. package/{es/components/common → lib/select-editor}/select-editor-option.js +0 -0
  146. package/{es/components/toast → lib/toaster}/alert.js +0 -0
  147. package/{es/components/toast → lib/toaster}/index.js +0 -0
  148. package/{es/components/toast → lib/toaster}/toast.js +0 -0
  149. package/{es/components/toast → lib/toaster}/toastManager.js +0 -0
  150. package/{es/components/toast → lib/toaster}/toaster.js +0 -0
  151. package/lib/utils/editor-utils.js +71 -0
  152. package/{es → lib}/utils/number-precision.js +1 -0
  153. package/lib/utils/utils.js +25 -0
  154. package/{es → lib}/utils/value-format-utils.js +7 -10
  155. package/package.json +9 -8
  156. package/es/app.css +0 -20
  157. package/es/app.js +0 -91
  158. package/es/components/cell-formatter/formatter-config.js +0 -31
  159. package/es/components/cell-formatter/index.js +0 -27
  160. package/es/constants/index.js +0 -48
  161. package/es/css/cell-editor.css +0 -614
  162. package/es/css/cell-formatter.css +0 -247
  163. package/es/index.js +0 -6
  164. package/es/utils/utils.js +0 -116
@@ -0,0 +1,304 @@
1
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
3
+ import _inherits from "@babel/runtime/helpers/esm/inherits";
4
+ import _createSuper from "@babel/runtime/helpers/esm/createSuper";
5
+ import React, { Fragment } from 'react';
6
+ import MediaQuery from 'react-responsive';
7
+ import { getLocale } from '../lang';
8
+ import { CellType } from '../constants';
9
+ import { getNumberDisplayString, getDateDisplayString } from '../utils/value-format-utils';
10
+ import EditEditorButton from '../EditEditorButton';
11
+ import LinkEditorOption from './link-editor-option';
12
+ import PCLinkEditorPopover from './pc-link-editor-popover';
13
+ import MBLinkEditorPopover from './mb-link-editor-popover';
14
+ import './index.css';
15
+
16
+ var LinkEditor = /*#__PURE__*/function (_React$Component) {
17
+ _inherits(LinkEditor, _React$Component);
18
+
19
+ var _super = _createSuper(LinkEditor);
20
+
21
+ function LinkEditor(props) {
22
+ var _this;
23
+
24
+ _classCallCheck(this, LinkEditor);
25
+
26
+ _this = _super.call(this, props);
27
+
28
+ _this.onDocumentToggle = function (e) {
29
+ if (_this.editorContainer !== e.target && !_this.editorContainer.contains(e.target)) {
30
+ _this.onClosePopover();
31
+ }
32
+ };
33
+
34
+ _this.getLinkedCellValue = function () {
35
+ var _this$props = _this.props,
36
+ row = _this$props.row,
37
+ column = _this$props.column,
38
+ linkMetaData = _this$props.linkMetaData;
39
+
40
+ var _ref = column.data || {},
41
+ link_id = _ref.link_id,
42
+ table_id = _ref.table_id,
43
+ other_table_id = _ref.other_table_id;
44
+
45
+ _this.linkId = link_id;
46
+ _this.tableId = table_id;
47
+ _this.otherTableId = other_table_id;
48
+ return linkMetaData.getLinkedCellValue(_this.linkId, _this.tableId, _this.otherTableId, row._id);
49
+ };
50
+
51
+ _this.formatLinkedValuesToOptions = function () {
52
+ var _this$props2 = _this.props,
53
+ column = _this$props2.column,
54
+ linkMetaData = _this$props2.linkMetaData;
55
+ var rowIds = _this.state.newValue;
56
+
57
+ if (rowIds && Array.isArray(rowIds) && rowIds.length > 0) {
58
+ var linkedRows = linkMetaData.getLinkedRows(_this.otherTableId, rowIds);
59
+ var linkedTable = linkMetaData.getLinkedTable(_this.otherTableId);
60
+ return linkedRows.map(function (linkedRow) {
61
+ var displayColumnKey = column.data.display_column_key; // format value to display
62
+
63
+ var displayValue = _this.getDisplayValue(linkedTable, linkedRow, displayColumnKey);
64
+
65
+ return {
66
+ id: linkedRow._id,
67
+ name: displayValue
68
+ };
69
+ });
70
+ }
71
+
72
+ return [];
73
+ };
74
+
75
+ _this.getDisplayValue = function (linkedTable, linkedRow, displayColumnKey) {
76
+ var value = linkedRow[displayColumnKey];
77
+ var linkedColumn = linkedTable.columns.find(function (column) {
78
+ return column.key === displayColumnKey;
79
+ });
80
+ var type = linkedColumn.type,
81
+ data = linkedColumn.data;
82
+
83
+ switch (type) {
84
+ case CellType.NUMBER:
85
+ {
86
+ return getNumberDisplayString(value, data);
87
+ }
88
+
89
+ case CellType.DATE:
90
+ {
91
+ var format = data.format;
92
+ return getDateDisplayString(value, format);
93
+ }
94
+
95
+ default:
96
+ return value;
97
+ }
98
+ };
99
+
100
+ _this.getAvailableLinkedOptions = function () {
101
+ var _this$props3 = _this.props,
102
+ column = _this$props3.column,
103
+ linkMetaData = _this$props3.linkMetaData;
104
+ var displayColumnKey = column.data.display_column_key;
105
+ var linkedTable = linkMetaData.getLinkedTable(_this.otherTableId);
106
+ var availableRows = linkedTable.rows.filter(function (row) {
107
+ return !!row[displayColumnKey];
108
+ });
109
+ var availableOptions = availableRows.map(function (row) {
110
+ var displayValue = _this.getDisplayValue(linkedTable, row, displayColumnKey);
111
+
112
+ return {
113
+ id: row._id,
114
+ name: displayValue
115
+ };
116
+ });
117
+ return availableOptions;
118
+ };
119
+
120
+ _this.onCommit = function (newValue) {// nothing todo
121
+ };
122
+
123
+ _this.onAddOptionToggle = function (event) {
124
+ event.nativeEvent.stopImmediatePropagation();
125
+ event.stopPropagation();
126
+
127
+ if (_this.props.isReadOnly) {
128
+ return;
129
+ }
130
+
131
+ var isPopoverShow = !_this.state.isPopoverShow;
132
+
133
+ if (isPopoverShow) {
134
+ var popoverPosition = _this.caculatePopoverPosition();
135
+
136
+ _this.setState({
137
+ isPopoverShow: isPopoverShow,
138
+ popoverPosition: popoverPosition
139
+ });
140
+ } else {
141
+ _this.setState({
142
+ isPopoverShow: isPopoverShow
143
+ });
144
+ }
145
+ };
146
+
147
+ _this.onOptionItemToggle = function (option) {
148
+ var _this$props4 = _this.props,
149
+ row = _this$props4.row,
150
+ linkMetaData = _this$props4.linkMetaData;
151
+
152
+ var newValue = _this.state.newValue.slice();
153
+
154
+ var optionIndex = newValue.findIndex(function (option_id) {
155
+ return option_id === option.id;
156
+ });
157
+
158
+ if (optionIndex !== -1) {
159
+ newValue.splice(optionIndex, 1);
160
+ linkMetaData.removeLink(_this.linkId, _this.tableId, _this.otherTableId, row._id, option.id);
161
+ } else {
162
+ newValue.push(option.id);
163
+ linkMetaData.addLink(_this.linkId, _this.tableId, _this.otherTableId, row._id, option.id);
164
+ }
165
+
166
+ _this.setState({
167
+ newValue: newValue
168
+ });
169
+ };
170
+
171
+ _this.onDeleteOption = function (option) {
172
+ var _this$props5 = _this.props,
173
+ row = _this$props5.row,
174
+ linkMetaData = _this$props5.linkMetaData;
175
+
176
+ var newValue = _this.state.newValue.slice();
177
+
178
+ var optionIndex = newValue.findIndex(function (option_id) {
179
+ return option_id === option.id;
180
+ });
181
+ newValue.splice(optionIndex, 1);
182
+
183
+ _this.setState({
184
+ newValue: newValue
185
+ }, function () {
186
+ linkMetaData.removeLink(_this.linkId, _this.tableId, _this.otherTableId, row._id, option.id);
187
+ });
188
+ };
189
+
190
+ _this.caculatePopoverPosition = function () {
191
+ var POPOVER_MAX_HEIGHT = 200;
192
+ var innerHeight = window.innerHeight;
193
+
194
+ var _this$editor$getClien = _this.editor.getClientRects()[0],
195
+ top = _this$editor$getClien.top,
196
+ height = _this$editor$getClien.height;
197
+
198
+ var isBelow = innerHeight - (top + height) > POPOVER_MAX_HEIGHT;
199
+ var position = {
200
+ top: height + 1,
201
+ left: 0
202
+ };
203
+
204
+ if (!isBelow) {
205
+ var bottom = height + 1;
206
+ position = {
207
+ bottom: bottom,
208
+ left: 0
209
+ };
210
+ }
211
+
212
+ return position;
213
+ };
214
+
215
+ _this.onClosePopover = function () {
216
+ _this.setState({
217
+ isPopoverShow: false
218
+ });
219
+ };
220
+
221
+ _this.setEditorContainerRef = function (editorContainer) {
222
+ _this.editorContainer = editorContainer;
223
+ };
224
+
225
+ _this.setEditorRef = function (editor) {
226
+ _this.editor = editor;
227
+ };
228
+
229
+ _this.linkId = '';
230
+ _this.tableId = '';
231
+ _this.otherTableId = '';
232
+ _this.state = {
233
+ newValue: _this.getLinkedCellValue(),
234
+ isPopoverShow: false,
235
+ popoverPosition: {}
236
+ };
237
+ return _this;
238
+ }
239
+
240
+ _createClass(LinkEditor, [{
241
+ key: "componentDidMount",
242
+ value: function componentDidMount() {
243
+ document.addEventListener('click', this.onDocumentToggle);
244
+ }
245
+ }, {
246
+ key: "componentWillUnmount",
247
+ value: function componentWillUnmount() {
248
+ document.removeEventListener('click', this.onDocumentToggle);
249
+ }
250
+ }, {
251
+ key: "render",
252
+ value: function render() {
253
+ var _this2 = this;
254
+
255
+ var isReadOnly = this.props.isReadOnly;
256
+ var _this$state = this.state,
257
+ isPopoverShow = _this$state.isPopoverShow,
258
+ popoverPosition = _this$state.popoverPosition;
259
+ var options = this.getAvailableLinkedOptions();
260
+ var selectedOptions = this.formatLinkedValuesToOptions();
261
+ var isShowRemoveIcon = !isReadOnly;
262
+ return /*#__PURE__*/React.createElement("div", {
263
+ ref: this.setEditorContainerRef,
264
+ className: "cell-editor dtable-ui-link-editor"
265
+ }, /*#__PURE__*/React.createElement("div", {
266
+ ref: this.setEditorRef,
267
+ className: "dtable-ui-link-editor-container",
268
+ onClick: this.onAddOptionToggle
269
+ }, selectedOptions.length === 0 && /*#__PURE__*/React.createElement(EditEditorButton, {
270
+ text: getLocale('Add_an_option')
271
+ }), selectedOptions.length !== 0 && selectedOptions.map(function (option) {
272
+ return /*#__PURE__*/React.createElement(LinkEditorOption, {
273
+ key: option.id,
274
+ option: option,
275
+ isShowRemoveIcon: isShowRemoveIcon,
276
+ onDeleteLinkOption: _this2.onDeleteOption
277
+ });
278
+ })), isPopoverShow && /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement(MediaQuery, {
279
+ query: "(min-width: 768px)"
280
+ }, /*#__PURE__*/React.createElement(PCLinkEditorPopover, {
281
+ popoverPosition: popoverPosition,
282
+ options: options,
283
+ selectedOptions: selectedOptions,
284
+ onOptionItemToggle: this.onOptionItemToggle
285
+ })), /*#__PURE__*/React.createElement(MediaQuery, {
286
+ query: "(max-width: 767.8px)"
287
+ }, /*#__PURE__*/React.createElement(MBLinkEditorPopover, {
288
+ isReadOnly: this.props.isReadOnly,
289
+ value: this.state.newValue,
290
+ column: this.props.column,
291
+ options: options,
292
+ onOptionItemToggle: this.onOptionItemToggle,
293
+ onClosePopover: this.onClosePopover
294
+ }))));
295
+ }
296
+ }]);
297
+
298
+ return LinkEditor;
299
+ }(React.Component);
300
+
301
+ LinkEditor.defaultProps = {
302
+ isReadOnly: false
303
+ };
304
+ export default LinkEditor;
@@ -0,0 +1,85 @@
1
+ @import url('../../css/mb-cell-editor.css');
2
+
3
+ @media screen and (max-width: 767.8px) {
4
+ .dtable-ui-mb-link-editor-body .mb-search-link-items {
5
+ padding: 8px 16px;
6
+ margin-top: 20px;
7
+ border-top: 1px solid #e9e9e9;
8
+ border-bottom: 1px solid #e9e9e9;
9
+ background-color: #fff;
10
+ }
11
+
12
+ .dtable-ui-mb-link-editor-body .mb-search-link-items > input {
13
+ outline: none;
14
+ height: 30px;
15
+ padding: 0;
16
+ line-height: 30px;
17
+ border: none;
18
+ }
19
+
20
+ .dtable-ui-mb-link-editor-body .mb-search-link-items > input:focus,
21
+ .dtable-ui-mb-link-editor-body .mb-search-link-items > input:active {
22
+ outline: none;
23
+ box-shadow: none;
24
+ }
25
+
26
+ .dtable-ui-mb-link-editor-body .mb-link-container {
27
+ flex: 1;
28
+ display: flex;
29
+ flex-direction: column;
30
+ margin-top: 10px;
31
+ min-height: 0;
32
+ }
33
+
34
+ .dtable-ui-mb-link-editor-body .mb-link-container .title {
35
+ padding: 6px 16px;
36
+ border-bottom: 1px solid #e9e9e9;
37
+ }
38
+
39
+ .dtable-ui-mb-link-editor-body .mb-link-container .content {
40
+ flex: 1;
41
+ overflow: auto;
42
+ display: flex;
43
+ flex-direction: column;
44
+ border-bottom: 1px solid #e9e9e9;
45
+ }
46
+
47
+ .dtable-ui-mb-link-editor-body .search-result-none {
48
+ padding: 16px 0 16px 16px;
49
+ }
50
+
51
+ .dtable-ui-mb-link-editor-body .mb-link-option-item {
52
+ display: flex;
53
+ align-items: center;
54
+ justify-content: space-between;
55
+ height: 50px;
56
+ padding: 10px 10px 10px 16px;
57
+ font-size: 13px;
58
+ color: #202428;
59
+ background-color: #fff;
60
+ }
61
+
62
+ .dtable-ui-mb-link-editor-body .mb-link-option-item {
63
+ border-bottom: 1px solid #e9e9e9;
64
+ }
65
+
66
+ .dtable-ui-mb-link-editor-body .mb-link-option-item .mb-option-info {
67
+ display: flex;
68
+ align-items: center;
69
+ }
70
+
71
+ .dtable-ui-mb-link-editor-body .mb-link-option-item .option-name {
72
+ padding: 0 10px;
73
+ max-width: 250px;
74
+ white-space: nowrap;
75
+ overflow: hidden;
76
+ text-overflow: ellipsis;
77
+ background: #eceff4;
78
+ border-radius: 3px;
79
+ }
80
+
81
+ .dtable-ui-mb-link-editor-body .mb-link-option-item .dtable-font {
82
+ font-size: 12px;
83
+ color: #798d99;
84
+ }
85
+ }
@@ -0,0 +1,171 @@
1
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
3
+ import _assertThisInitialized from "@babel/runtime/helpers/esm/assertThisInitialized";
4
+ import _inherits from "@babel/runtime/helpers/esm/inherits";
5
+ import _createSuper from "@babel/runtime/helpers/esm/createSuper";
6
+ import React from 'react';
7
+ import { getLocale } from '../../lang';
8
+ import MBEditorHeader from '../../MBEditorHeader';
9
+ import './index.css';
10
+
11
+ var MBLinkEditorPopover = /*#__PURE__*/function (_React$Component) {
12
+ _inherits(MBLinkEditorPopover, _React$Component);
13
+
14
+ var _super = _createSuper(MBLinkEditorPopover);
15
+
16
+ function MBLinkEditorPopover(props) {
17
+ var _this;
18
+
19
+ _classCallCheck(this, MBLinkEditorPopover);
20
+
21
+ _this = _super.call(this, props);
22
+
23
+ _this.handleHistaryBack = function (e) {
24
+ e.preventDefault();
25
+
26
+ _this.props.onClosePopover();
27
+ };
28
+
29
+ _this.onContainerClick = function (event) {
30
+ if (_this.editorPopover && _this.editorPopover.contains(event.target)) {
31
+ event.stopPropagation();
32
+ event.nativeEvent.stopImmediatePropagation();
33
+ return false;
34
+ }
35
+ };
36
+
37
+ _this.onChangeSearch = function (event) {
38
+ var searchVal = _this.state.searchVal;
39
+
40
+ if (searchVal === event.target.value) {
41
+ return;
42
+ }
43
+
44
+ searchVal = event.target.value;
45
+
46
+ _this.setState({
47
+ searchVal: searchVal
48
+ });
49
+ };
50
+
51
+ _this.getSelectedOptions = function () {
52
+ var _this$props = _this.props,
53
+ value = _this$props.value,
54
+ options = _this$props.options;
55
+
56
+ if (!Array.isArray(value)) {
57
+ return [];
58
+ }
59
+
60
+ return options.filter(function (option) {
61
+ return value.indexOf(option.email) > -1;
62
+ });
63
+ };
64
+
65
+ _this.getFilterOptions = function () {
66
+ var options = _this.props.options;
67
+ var searchVal = _this.state.searchVal;
68
+ return searchVal ? options.filter(function (item) {
69
+ return item.name.indexOf(searchVal) > -1;
70
+ }) : options;
71
+ };
72
+
73
+ _this.onSelectOption = function (option) {
74
+ _this.props.onOptionItemToggle(option);
75
+ };
76
+
77
+ _this.onRemoveOption = function (option) {
78
+ _this.props.onOptionItemToggle(option);
79
+ };
80
+
81
+ _this.renderFilteredOptions = function (options) {
82
+ var value = _this.props.value;
83
+ return options.map(function (option, index) {
84
+ var isSelect = value.some(function (item) {
85
+ return item === option.id;
86
+ });
87
+ return /*#__PURE__*/React.createElement("div", {
88
+ className: "mb-link-option-item",
89
+ key: index,
90
+ onMouseDown: _this.onSelectOption.bind(_assertThisInitialized(_this), option)
91
+ }, /*#__PURE__*/React.createElement("span", {
92
+ className: "mb-option-info"
93
+ }, /*#__PURE__*/React.createElement("span", {
94
+ className: "option-name"
95
+ }, option.name)), isSelect && /*#__PURE__*/React.createElement("i", {
96
+ className: "mb-option-checked dtable-font dtable-icon-check-mark"
97
+ }));
98
+ });
99
+ };
100
+
101
+ _this.setEditorPopover = function (editorPopover) {
102
+ _this.editorPopover = editorPopover;
103
+ };
104
+
105
+ _this.state = {
106
+ searchVal: ''
107
+ };
108
+ return _this;
109
+ }
110
+
111
+ _createClass(MBLinkEditorPopover, [{
112
+ key: "componentDidMount",
113
+ value: function componentDidMount() {
114
+ history.pushState(null, null, '#'); // eslint-disable-line
115
+
116
+ window.addEventListener('popstate', this.handleHistaryBack, false);
117
+ }
118
+ }, {
119
+ key: "componentWillUnmount",
120
+ value: function componentWillUnmount() {
121
+ window.removeEventListener('popstate', this.handleHistaryBack, false);
122
+ }
123
+ }, {
124
+ key: "render",
125
+ value: function render() {
126
+ var column = this.props.column;
127
+ var searchVal = this.state.searchVal;
128
+ var filterOptions = this.getFilterOptions();
129
+ return /*#__PURE__*/React.createElement("div", {
130
+ ref: this.setEditorPopover,
131
+ className: "dtable-ui-mb-editor-popover mb-link-editor-popover",
132
+ onClick: this.onContainerClick
133
+ }, /*#__PURE__*/React.createElement(MBEditorHeader, {
134
+ title: column.name,
135
+ leftContent: /*#__PURE__*/React.createElement("i", {
136
+ className: "dtable-font dtable-icon-return"
137
+ }),
138
+ rightContent: /*#__PURE__*/React.createElement("span", null, getLocale('Done')),
139
+ onLeftClick: this.props.onClosePopover,
140
+ onRightClick: this.props.onClosePopover
141
+ }), /*#__PURE__*/React.createElement("div", {
142
+ className: "dtable-ui-mb-editor-body dtable-ui-mb-link-editor-body"
143
+ }, /*#__PURE__*/React.createElement("div", {
144
+ className: "mb-search-link-items"
145
+ }, /*#__PURE__*/React.createElement("input", {
146
+ className: "form-control",
147
+ type: "text",
148
+ placeholder: getLocale('Find_an_option'),
149
+ value: searchVal,
150
+ onChange: this.onChangeSearch,
151
+ onClick: this.onInputClick
152
+ })), /*#__PURE__*/React.createElement("div", {
153
+ className: "mb-link-container"
154
+ }, /*#__PURE__*/React.createElement("div", {
155
+ className: "title"
156
+ }, getLocale('Choose_an_option')), /*#__PURE__*/React.createElement("div", {
157
+ className: "content"
158
+ }, filterOptions.length === 0 && /*#__PURE__*/React.createElement("div", {
159
+ className: "search-result-none"
160
+ }, getLocale('No_options_available')), filterOptions.length > 0 && this.renderFilteredOptions(filterOptions)))));
161
+ }
162
+ }]);
163
+
164
+ return MBLinkEditorPopover;
165
+ }(React.Component);
166
+
167
+ MBLinkEditorPopover.defaultProps = {
168
+ isReadOnly: false,
169
+ value: []
170
+ };
171
+ export default MBLinkEditorPopover;
@@ -0,0 +1,63 @@
1
+ @import url('../../css/cell-editor.css');
2
+
3
+ .dtable-ui-link-editor-popover .link-options-search {
4
+ padding: 10px 10px 0 10px;
5
+ }
6
+
7
+ .dtable-ui-link-editor-popover .link-options-search input {
8
+ height: 28px;
9
+ }
10
+
11
+ .dtable-ui-link-editor-popover .link-options-container {
12
+ min-height: 160px;
13
+ max-height: 200px;
14
+ margin: 10px 0;
15
+ padding: 0 10px;
16
+ overflow: auto;
17
+ }
18
+
19
+ /* option item */
20
+ .dtable-ui-link-editor-popover .link-option-item {
21
+ display: flex;
22
+ height: 30px;
23
+ padding-left: 12px;
24
+ font-size: 14px;
25
+ line-height: 30px;
26
+ margin-left: 10px;
27
+ cursor: pointer;
28
+ }
29
+
30
+ .dtable-ui-link-editor-popover .link-option-item:hover {
31
+ background-color: #f5f5f5;
32
+ }
33
+
34
+ .dtable-ui-link-editor-popover .option-info {
35
+ flex: 1;
36
+ display: flex;
37
+ align-items: center;
38
+ }
39
+
40
+ .dtable-ui-link-editor-popover .option-info .option-name {
41
+ max-width: 250px;
42
+ white-space: nowrap;
43
+ overflow: hidden;
44
+ text-overflow: ellipsis;
45
+ }
46
+
47
+ .dtable-ui-link-editor-popover .option-checked {
48
+ width: 20px;
49
+ text-align: center;
50
+ }
51
+
52
+ .dtable-ui-link-editor-popover .option-checked .dtable-font {
53
+ font-size: 12px;
54
+ color: #798d99;
55
+ }
56
+
57
+ .dtable-ui-link-editor-popover .select-options-add {
58
+ display: flex;
59
+ align-items: center;
60
+ padding: 0 10px;
61
+ height: 30px;
62
+ border-top: 1px solid #ccc;
63
+ }