dtable-ui-component 0.1.75-beta2 → 0.1.75-beta3

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 (223) hide show
  1. package/es/AutoNumberFormatter/index.css +1 -0
  2. package/es/AutoNumberFormatter/index.js +36 -0
  3. package/es/ButtonFormatter/index.css +13 -0
  4. package/es/ButtonFormatter/index.js +56 -0
  5. package/es/CTimeFormatter/index.css +1 -0
  6. package/es/CTimeFormatter/index.js +58 -0
  7. package/es/CheckboxFormatter/index.css +1 -0
  8. package/es/CheckboxFormatter/index.js +45 -0
  9. package/es/CollaboratorFormatter/index.css +1 -0
  10. package/es/CollaboratorFormatter/index.js +91 -0
  11. package/es/CollaboratorItem/index.css +49 -0
  12. package/es/CollaboratorItem/index.js +64 -0
  13. package/es/CreatorFormatter/index.css +1 -0
  14. package/es/CreatorFormatter/index.js +87 -0
  15. package/es/DateFormatter/index.css +1 -0
  16. package/es/DateFormatter/index.js +60 -0
  17. package/es/DurationFormatter/index.css +1 -0
  18. package/es/DurationFormatter/index.js +38 -0
  19. package/es/EmailFormatter/index.css +5 -0
  20. package/es/EmailFormatter/index.js +36 -0
  21. package/es/FileFormatter/index.css +29 -0
  22. package/es/FileFormatter/index.js +64 -0
  23. package/es/FileItemFormatter/index.js +50 -0
  24. package/es/FileUploader/index.js +53 -0
  25. package/es/FormulaFormatter/index.css +19 -0
  26. package/es/FormulaFormatter/index.js +164 -0
  27. package/es/GeolocationFormatter/index.css +1 -0
  28. package/es/GeolocationFormatter/index.js +53 -0
  29. package/es/ImageFormatter/images-lazy-load.js +150 -0
  30. package/es/ImageFormatter/index.css +34 -0
  31. package/es/ImageFormatter/index.js +154 -0
  32. package/es/ImagePreviewerLightbox/index.css +87 -0
  33. package/es/ImagePreviewerLightbox/index.js +119 -0
  34. package/es/LastModifierFormatter/index.css +1 -0
  35. package/es/LastModifierFormatter/index.js +87 -0
  36. package/es/LinkFormatter/index.css +27 -0
  37. package/es/LinkFormatter/index.js +144 -0
  38. package/es/Loading/index.css +54 -0
  39. package/es/Loading/index.js +7 -0
  40. package/es/LongTextFormatter/html-long-text-formatter.js +96 -0
  41. package/es/LongTextFormatter/index.css +63 -0
  42. package/es/LongTextFormatter/index.js +29 -0
  43. package/es/LongTextFormatter/simple-long-text-formatter.js +104 -0
  44. package/es/MTimeFormatter/index.css +1 -0
  45. package/es/MTimeFormatter/index.js +58 -0
  46. package/es/ModalPortal/index.js +44 -0
  47. package/es/MultipleSelectFormatter/index.css +1 -0
  48. package/es/MultipleSelectFormatter/index.js +70 -0
  49. package/es/NumberFormatter/index.css +1 -0
  50. package/es/NumberFormatter/index.js +47 -0
  51. package/es/RateFormatter/index.css +1 -0
  52. package/es/RateFormatter/index.js +80 -0
  53. package/es/SelectItem/index.js +58 -0
  54. package/es/SingleSelectFormatter/index.css +1 -0
  55. package/es/SingleSelectFormatter/index.js +70 -0
  56. package/es/TextFormatter/index.css +1 -0
  57. package/es/TextFormatter/index.js +56 -0
  58. package/es/UrlFormatter/index.css +5 -0
  59. package/es/UrlFormatter/index.js +36 -0
  60. package/es/app.css +20 -0
  61. package/es/app.js +91 -0
  62. package/es/assets/images/avatar/default_avatar.png +0 -0
  63. package/es/assets/images/file/192/excel.png +0 -0
  64. package/es/assets/images/file/192/file.png +0 -0
  65. package/es/assets/images/file/192/music.png +0 -0
  66. package/es/assets/images/file/192/pdf.png +0 -0
  67. package/es/assets/images/file/192/pic.png +0 -0
  68. package/es/assets/images/file/192/ppt.png +0 -0
  69. package/es/assets/images/file/192/txt.png +0 -0
  70. package/es/assets/images/file/192/video.png +0 -0
  71. package/es/assets/images/file/192/word.png +0 -0
  72. package/es/assets/images/file/24/excel.png +0 -0
  73. package/es/assets/images/file/24/file.png +0 -0
  74. package/es/assets/images/file/24/music.png +0 -0
  75. package/es/assets/images/file/24/pdf.png +0 -0
  76. package/es/assets/images/file/24/pic.png +0 -0
  77. package/es/assets/images/file/24/ppt.png +0 -0
  78. package/es/assets/images/file/24/txt.png +0 -0
  79. package/es/assets/images/file/24/video.png +0 -0
  80. package/es/assets/images/file/24/word.png +0 -0
  81. package/es/assets/images/folder/folder-192.png +0 -0
  82. package/es/assets/images/folder/folder-24.png +0 -0
  83. package/es/cellFormatterFactory/index.js +25 -0
  84. package/es/components/cell-editor/checkbox-editor.js +104 -0
  85. package/es/components/cell-editor/collaborator-editor.js +236 -0
  86. package/es/components/cell-editor/date-editor.js +151 -0
  87. package/es/components/cell-editor/index.js +9 -0
  88. package/es/components/cell-editor/link-editor.js +303 -0
  89. package/es/components/cell-editor/multiple-select-editor.js +237 -0
  90. package/es/components/cell-editor/number-editor.js +154 -0
  91. package/es/components/cell-editor/single-select-editor.js +202 -0
  92. package/es/components/cell-editor/text-editor.js +122 -0
  93. package/es/components/cell-editor-dialog/pc-file-editor-dialog.js +46 -0
  94. package/es/components/cell-editor-dialog/pc-files-addition/index.js +0 -0
  95. package/es/components/cell-editor-dialog/pc-files-addition/pc-file-uploaded-item.js +0 -0
  96. package/es/components/cell-editor-dialog/pc-files-preview/index.js +0 -0
  97. package/es/components/cell-editor-dialog/pc-files-preview/pc-file-item-preview.js +0 -0
  98. package/es/components/cell-editor-popover/mb-collaborator-editor-popover.js +177 -0
  99. package/es/components/cell-editor-popover/mb-date-editor-popover.js +245 -0
  100. package/es/components/cell-editor-popover/mb-link-editor-popover.js +170 -0
  101. package/es/components/cell-editor-popover/mb-select-editor-popover.js +230 -0
  102. package/es/components/cell-editor-popover/pc-collaborator-editor-popover.js +109 -0
  103. package/es/components/cell-editor-popover/pc-date-editor-popover.js +142 -0
  104. package/es/components/cell-editor-popover/pc-link-editor-popover.js +114 -0
  105. package/es/components/cell-editor-popover/pc-select-editor-popover.js +143 -0
  106. package/es/components/common/collaborator-item.js +63 -0
  107. package/es/components/common/edit-editor-button.js +56 -0
  108. package/es/components/common/link-editor-option.js +113 -0
  109. package/es/components/common/mobile/mb-editor-header.js +48 -0
  110. package/es/components/common/select-editor-option.js +106 -0
  111. package/es/constants/cell-types.js +25 -0
  112. package/es/constants/index.js +49 -0
  113. package/es/css/cell-editor.css +614 -0
  114. package/es/css/cell-formatter.css +4 -0
  115. package/es/css/custom-rc-calendar.css +118 -0
  116. package/es/formatterConfig/index.js +31 -0
  117. package/es/index.js +31 -0
  118. package/es/lang/index.js +50 -0
  119. package/es/locals/de.js +2 -0
  120. package/es/locals/en.js +17 -0
  121. package/es/locals/fr.js +2 -0
  122. package/es/locals/zh-CN.js +17 -0
  123. package/{lib/toast → es/toaster}/alert.js +0 -0
  124. package/{lib/toast → es/toaster}/index.js +0 -0
  125. package/{lib/toast → es/toaster}/toast.js +0 -0
  126. package/{lib/toast → es/toaster}/toastManager.js +0 -0
  127. package/{lib/toast → es/toaster}/toaster.js +0 -0
  128. package/es/utils/cell-value-validator.js +31 -0
  129. package/es/utils/column-utils.js +7 -0
  130. package/es/utils/editor-utils.js +71 -0
  131. package/es/utils/markdown2html.js +62 -0
  132. package/es/utils/normalize-long-text-value.js +69 -0
  133. package/es/utils/number-precision.js +164 -0
  134. package/es/utils/unified/index.js +470 -0
  135. package/es/utils/utils.js +116 -0
  136. package/es/utils/value-format-utils.js +497 -0
  137. package/es/utils/vfile/core.js +172 -0
  138. package/es/utils/vfile/index.js +48 -0
  139. package/lib/AutoNumberFormatter/index.js +38 -27
  140. package/lib/ButtonFormatter/index.js +59 -47
  141. package/lib/CTimeFormatter/index.js +53 -39
  142. package/lib/CheckboxFormatter/index.js +48 -35
  143. package/lib/CollaboratorFormatter/index.js +64 -42
  144. package/lib/CollaboratorItem/index.js +61 -44
  145. package/lib/CreatorFormatter/index.js +62 -42
  146. package/lib/DateFormatter/index.js +55 -40
  147. package/lib/DurationFormatter/index.js +42 -29
  148. package/lib/EmailFormatter/index.js +38 -27
  149. package/lib/FileFormatter/index.js +65 -50
  150. package/lib/FileItemFormatter/index.js +44 -31
  151. package/lib/FileUploader/index.js +44 -34
  152. package/lib/FormulaFormatter/index.js +102 -81
  153. package/lib/GeolocationFormatter/index.js +50 -35
  154. package/lib/ImageFormatter/images-lazy-load.js +81 -73
  155. package/lib/ImageFormatter/index.js +109 -90
  156. package/lib/ImagePreviewerLightbox/index.js +60 -27
  157. package/lib/LastModifierFormatter/index.js +62 -42
  158. package/lib/LinkFormatter/index.js +80 -59
  159. package/lib/Loading/index.js +13 -4
  160. package/lib/LongTextFormatter/html-long-text-formatter.js +60 -49
  161. package/lib/LongTextFormatter/index.js +28 -9
  162. package/lib/LongTextFormatter/simple-long-text-formatter.js +58 -52
  163. package/lib/MTimeFormatter/index.js +53 -39
  164. package/lib/ModalPortal/index.js +37 -30
  165. package/lib/MultipleSelectFormatter/index.js +55 -39
  166. package/lib/NumberFormatter/index.js +50 -35
  167. package/lib/RateFormatter/index.js +52 -37
  168. package/lib/SelectItem/index.js +46 -31
  169. package/lib/SingleSelectFormatter/index.js +54 -38
  170. package/lib/TextFormatter/index.js +44 -31
  171. package/lib/UrlFormatter/index.js +38 -27
  172. package/lib/app.js +80 -75
  173. package/lib/cellFormatterFactory/index.js +20 -17
  174. package/lib/components/cell-editor/checkbox-editor.js +66 -59
  175. package/lib/components/cell-editor/collaborator-editor.js +126 -113
  176. package/lib/components/cell-editor/date-editor.js +119 -99
  177. package/lib/components/cell-editor/index.js +40 -9
  178. package/lib/components/cell-editor/link-editor.js +140 -122
  179. package/lib/components/cell-editor/multiple-select-editor.js +127 -114
  180. package/lib/components/cell-editor/number-editor.js +86 -78
  181. package/lib/components/cell-editor/single-select-editor.js +120 -106
  182. package/lib/components/cell-editor/text-editor.js +72 -65
  183. package/lib/components/cell-editor-dialog/pc-file-editor-dialog.js +51 -31
  184. package/lib/components/cell-editor-dialog/pc-files-addition/index.js +1 -0
  185. package/lib/components/cell-editor-dialog/pc-files-addition/pc-file-uploaded-item.js +1 -0
  186. package/lib/components/cell-editor-dialog/pc-files-preview/index.js +1 -0
  187. package/lib/components/cell-editor-dialog/pc-files-preview/pc-file-item-preview.js +1 -0
  188. package/lib/components/cell-editor-popover/mb-collaborator-editor-popover.js +111 -105
  189. package/lib/components/cell-editor-popover/mb-date-editor-popover.js +157 -140
  190. package/lib/components/cell-editor-popover/mb-link-editor-popover.js +109 -103
  191. package/lib/components/cell-editor-popover/mb-select-editor-popover.js +155 -142
  192. package/lib/components/cell-editor-popover/pc-collaborator-editor-popover.js +89 -74
  193. package/lib/components/cell-editor-popover/pc-date-editor-popover.js +102 -88
  194. package/lib/components/cell-editor-popover/pc-link-editor-popover.js +91 -77
  195. package/lib/components/cell-editor-popover/pc-select-editor-popover.js +105 -91
  196. package/lib/components/common/collaborator-item.js +59 -43
  197. package/lib/components/common/edit-editor-button.js +39 -28
  198. package/lib/components/common/link-editor-option.js +71 -63
  199. package/lib/components/common/mobile/mb-editor-header.js +52 -39
  200. package/lib/components/common/select-editor-option.js +74 -58
  201. package/lib/constants/cell-types.js +54 -25
  202. package/lib/constants/index.js +28 -5
  203. package/lib/formatterConfig/index.js +59 -28
  204. package/lib/index.js +139 -31
  205. package/lib/lang/index.js +27 -11
  206. package/lib/locals/de.js +6 -1
  207. package/lib/locals/en.js +6 -1
  208. package/lib/locals/fr.js +6 -1
  209. package/lib/locals/zh-CN.js +6 -1
  210. package/lib/toaster/alert.js +164 -0
  211. package/lib/toaster/index.js +12 -0
  212. package/lib/toaster/toast.js +223 -0
  213. package/lib/toaster/toastManager.js +189 -0
  214. package/lib/toaster/toaster.js +92 -0
  215. package/lib/utils/cell-value-validator.js +9 -5
  216. package/lib/utils/column-utils.js +13 -5
  217. package/lib/utils/editor-utils.js +13 -3
  218. package/lib/utils/markdown2html.js +7 -1
  219. package/lib/utils/normalize-long-text-value.js +6 -1
  220. package/lib/utils/number-precision.js +32 -13
  221. package/lib/utils/utils.js +33 -8
  222. package/lib/utils/value-format-utils.js +110 -58
  223. package/package.json +5 -5
@@ -0,0 +1,230 @@
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, { Fragment } from 'react';
7
+ import { getLocale } from '../../lang';
8
+ import SelectEditorOption from '../common/select-editor-option';
9
+ import MBEditorHeader from '../common/mobile/mb-editor-header';
10
+
11
+ var MBSingleSelectPopover = /*#__PURE__*/function (_React$Component) {
12
+ _inherits(MBSingleSelectPopover, _React$Component);
13
+
14
+ var _super = _createSuper(MBSingleSelectPopover);
15
+
16
+ function MBSingleSelectPopover(props) {
17
+ var _this;
18
+
19
+ _classCallCheck(this, MBSingleSelectPopover);
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.id) > -1;
62
+ });
63
+ };
64
+
65
+ _this.getFilteredOptions = 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.onAddNewOption = function (event) {
78
+ event.stopPropagation();
79
+ event.nativeEvent.stopImmediatePropagation();
80
+
81
+ var newOption = _this.state.searchVal.trim();
82
+
83
+ if (newOption) {
84
+ _this.props.onAddNewOption(newOption);
85
+
86
+ _this.props.onClosePopover();
87
+ }
88
+ };
89
+
90
+ _this.onRemoveOption = function (option) {
91
+ _this.props.onOptionItemToggle(option);
92
+ };
93
+
94
+ _this.renderSelectOptions = function (options) {
95
+ var value = _this.props.value;
96
+ return options.map(function (option, index) {
97
+ var isSelect = value.some(function (item) {
98
+ return item === option.id;
99
+ });
100
+ var style = {
101
+ backgroundColor: option.color,
102
+ color: option.textColor || null
103
+ };
104
+ return /*#__PURE__*/React.createElement("div", {
105
+ className: "mb-select-option-item",
106
+ key: index,
107
+ onMouseDown: _this.onSelectOption.bind(_assertThisInitialized(_this), option)
108
+ }, /*#__PURE__*/React.createElement("span", {
109
+ className: "mb-select-item"
110
+ }, /*#__PURE__*/React.createElement("span", {
111
+ className: "item-name",
112
+ style: style
113
+ }, option.name)), /*#__PURE__*/React.createElement("span", {
114
+ className: "mb-item-checked"
115
+ }, isSelect && /*#__PURE__*/React.createElement("i", {
116
+ className: "dtable-font dtable-icon-check-mark"
117
+ })));
118
+ });
119
+ };
120
+
121
+ _this.setEditorPopover = function (editorPopover) {
122
+ _this.editorPopover = editorPopover;
123
+ };
124
+
125
+ _this.state = {
126
+ searchVal: ''
127
+ };
128
+ return _this;
129
+ }
130
+
131
+ _createClass(MBSingleSelectPopover, [{
132
+ key: "componentDidMount",
133
+ value: function componentDidMount() {
134
+ history.pushState(null, null, '#'); // eslint-disable-line
135
+
136
+ window.addEventListener('popstate', this.handleHistaryBack, false);
137
+ }
138
+ }, {
139
+ key: "componentWillUnmount",
140
+ value: function componentWillUnmount() {
141
+ window.removeEventListener('popstate', this.handleHistaryBack, false);
142
+ }
143
+ }, {
144
+ key: "render",
145
+ value: function render() {
146
+ var _this2 = this;
147
+
148
+ var _this$props2 = this.props,
149
+ isReadOnly = _this$props2.isReadOnly,
150
+ column = _this$props2.column,
151
+ isSupportNewOption = _this$props2.isSupportNewOption,
152
+ isShowRemoveIcon = _this$props2.isShowRemoveIcon;
153
+ var searchVal = this.state.searchVal;
154
+ var selectedOptions = this.getSelectedOptions();
155
+ var filteredOptions = this.getFilteredOptions();
156
+ var isShowRemoveBtn = !isReadOnly && isShowRemoveIcon;
157
+ var isShowCreateBtn = !isReadOnly && isSupportNewOption && !!searchVal;
158
+
159
+ if (isShowCreateBtn) {
160
+ isShowCreateBtn = filteredOptions.length === 0;
161
+ }
162
+
163
+ return /*#__PURE__*/React.createElement("div", {
164
+ ref: this.setEditorPopover,
165
+ className: "dtable-ui-mb-editor-popover mb-select-editor-popover",
166
+ style: {
167
+ zIndex: 99
168
+ },
169
+ onClick: this.onContainerClick
170
+ }, /*#__PURE__*/React.createElement(MBEditorHeader, {
171
+ title: column.name,
172
+ leftContent: /*#__PURE__*/React.createElement("i", {
173
+ className: "dtable-font dtable-icon-return"
174
+ }),
175
+ onLeftClick: this.props.onClosePopover
176
+ }), /*#__PURE__*/React.createElement("div", {
177
+ className: "dtable-ui-mb-editor-body dtable-ui-mb-select-editor-body"
178
+ }, /*#__PURE__*/React.createElement("div", {
179
+ className: "mb-selected-item"
180
+ }, /*#__PURE__*/React.createElement("div", {
181
+ className: "title"
182
+ }, getLocale('Current_option')), /*#__PURE__*/React.createElement("div", {
183
+ className: "content"
184
+ }, selectedOptions.length === 0 && /*#__PURE__*/React.createElement("span", {
185
+ className: "empty-placeholder"
186
+ }, getLocale('No_option')), selectedOptions.length > 0 && selectedOptions.map(function (selectedOption) {
187
+ return /*#__PURE__*/React.createElement(SelectEditorOption, {
188
+ key: selectedOption.id,
189
+ option: selectedOption,
190
+ isShowRemoveIcon: isShowRemoveBtn,
191
+ onDeleteSelectOption: _this2.onRemoveOption
192
+ });
193
+ }))), /*#__PURE__*/React.createElement("div", {
194
+ className: "mb-search-select-items"
195
+ }, /*#__PURE__*/React.createElement("input", {
196
+ className: "form-control",
197
+ type: "text",
198
+ placeholder: getLocale('Find_an_option'),
199
+ value: searchVal,
200
+ onChange: this.onChangeSearch,
201
+ onClick: this.onInputClick
202
+ })), /*#__PURE__*/React.createElement("div", {
203
+ className: "mb-select-options-container"
204
+ }, /*#__PURE__*/React.createElement("div", {
205
+ className: "title"
206
+ }, /*#__PURE__*/React.createElement("span", null, getLocale('Choose_an_option'))), /*#__PURE__*/React.createElement("div", {
207
+ className: "content"
208
+ }, /*#__PURE__*/React.createElement(Fragment, null, filteredOptions.length === 0 && /*#__PURE__*/React.createElement("div", {
209
+ className: "search-result-none"
210
+ }, getLocale('No_options_available')), filteredOptions.length > 0 && this.renderSelectOptions(filteredOptions)))), isShowCreateBtn && /*#__PURE__*/React.createElement("div", {
211
+ className: "mb-create-select-item",
212
+ onClick: this.onAddNewOption
213
+ }, /*#__PURE__*/React.createElement("i", {
214
+ className: "dtable-font dtable-icon-add-table"
215
+ }), /*#__PURE__*/React.createElement("span", {
216
+ className: "add-new-option"
217
+ }, "".concat(getLocale('Add_an_option'), " ").concat(searchVal)))));
218
+ }
219
+ }]);
220
+
221
+ return MBSingleSelectPopover;
222
+ }(React.Component);
223
+
224
+ MBSingleSelectPopover.defaultProps = {
225
+ isReadOnly: false,
226
+ isShowRemoveIcon: false,
227
+ isSupportNewOption: false,
228
+ value: []
229
+ };
230
+ export default MBSingleSelectPopover;
@@ -0,0 +1,109 @@
1
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
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 CollaboratorItem from '../common/collaborator-item';
9
+
10
+ var PCCollaboratorEditorPopover = /*#__PURE__*/function (_React$Component) {
11
+ _inherits(PCCollaboratorEditorPopover, _React$Component);
12
+
13
+ var _super = _createSuper(PCCollaboratorEditorPopover);
14
+
15
+ function PCCollaboratorEditorPopover(props) {
16
+ var _this;
17
+
18
+ _classCallCheck(this, PCCollaboratorEditorPopover);
19
+
20
+ _this = _super.call(this, props);
21
+
22
+ _this.onValueChanged = function (event) {
23
+ var value = event.target.value;
24
+
25
+ _this.setState({
26
+ searchValue: value
27
+ });
28
+ };
29
+
30
+ _this.onInputClick = function (event) {
31
+ event.nativeEvent.stopImmediatePropagation();
32
+ event.stopPropagation();
33
+ };
34
+
35
+ _this.onCollaboratorItemToggle = function (item) {
36
+ _this.props.onCollaboratorItemToggle(item);
37
+ };
38
+
39
+ _this.getFilterCollaborator = function () {
40
+ var collaborators = _this.props.collaborators;
41
+
42
+ var filter = _this.state.searchValue.toLowerCase();
43
+
44
+ if (!filter) {
45
+ return collaborators;
46
+ }
47
+
48
+ return collaborators.filter(function (collaborator) {
49
+ return collaborator.name.toString().toLowerCase().indexOf(filter) > -1;
50
+ });
51
+ };
52
+
53
+ _this.state = {
54
+ searchValue: ''
55
+ };
56
+ return _this;
57
+ }
58
+
59
+ _createClass(PCCollaboratorEditorPopover, [{
60
+ key: "render",
61
+ value: function render() {
62
+ var _this2 = this;
63
+
64
+ var searchValue = this.state.searchValue;
65
+ var _this$props = this.props,
66
+ selectedCollaborators = _this$props.selectedCollaborators,
67
+ popoverPosition = _this$props.popoverPosition;
68
+ var collaborators = this.getFilterCollaborator();
69
+ var popoverStyle = Object.assign({}, _objectSpread({}, popoverPosition), {
70
+ position: 'absolute'
71
+ });
72
+ return /*#__PURE__*/React.createElement("div", {
73
+ className: "dtable-ui-editor-popover dtable-ui-collaborator-editor-popover",
74
+ style: popoverStyle
75
+ }, /*#__PURE__*/React.createElement("div", {
76
+ className: "collaborator-search-container"
77
+ }, /*#__PURE__*/React.createElement("input", {
78
+ className: "form-control",
79
+ value: searchValue,
80
+ onChange: this.onValueChanged,
81
+ onClick: this.onInputClick,
82
+ placeholder: getLocale('Find_a_collaborator')
83
+ })), /*#__PURE__*/React.createElement("div", {
84
+ className: "collaborator-list-container"
85
+ }, collaborators.length > 0 && collaborators.map(function (collaborator, index) {
86
+ var isSelect = selectedCollaborators.some(function (selectedCollaborator) {
87
+ return selectedCollaborator.email === collaborator.email;
88
+ });
89
+ return /*#__PURE__*/React.createElement("div", {
90
+ key: index,
91
+ className: "collaborator-item-container",
92
+ onClick: _this2.onCollaboratorItemToggle.bind(_this2, collaborator)
93
+ }, /*#__PURE__*/React.createElement(CollaboratorItem, {
94
+ collaborator: collaborator
95
+ }), /*#__PURE__*/React.createElement("div", {
96
+ className: "collaborator-checked"
97
+ }, isSelect && /*#__PURE__*/React.createElement("i", {
98
+ className: "dtable-font dtable-icon-check-mark"
99
+ })));
100
+ }), collaborators.length === 0 && /*#__PURE__*/React.createElement("div", {
101
+ className: "search-option-null"
102
+ }, getLocale('No_collaborators_available'))));
103
+ }
104
+ }]);
105
+
106
+ return PCCollaboratorEditorPopover;
107
+ }(React.Component);
108
+
109
+ export default PCCollaboratorEditorPopover;
@@ -0,0 +1,142 @@
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 from 'react';
6
+ import moment from 'moment';
7
+ import DatePicker from '@seafile/seafile-calendar/lib/Picker';
8
+ import Calendar from '@seafile/seafile-calendar';
9
+ import { initDateEditorLanguage } from '../../utils/editor-utils';
10
+ import '@seafile/seafile-calendar/assets/index.css';
11
+ import { getLocale } from '../../lang';
12
+
13
+ var PCDateEditorPopover = /*#__PURE__*/function (_React$Component) {
14
+ _inherits(PCDateEditorPopover, _React$Component);
15
+
16
+ var _super = _createSuper(PCDateEditorPopover);
17
+
18
+ function PCDateEditorPopover(props) {
19
+ var _this;
20
+
21
+ _classCallCheck(this, PCDateEditorPopover);
22
+
23
+ _this = _super.call(this, props);
24
+
25
+ _this.onChange = function (value) {
26
+ if (!value) return;
27
+ var dateFormat = _this.props.dateFormat;
28
+
29
+ _this.setState({
30
+ datePickerValue: value,
31
+ open: true // if value changed, don't close datePicker
32
+
33
+ });
34
+
35
+ _this.props.onValueChanged(value.format(dateFormat));
36
+ };
37
+
38
+ _this.onOpenChange = function (open) {
39
+ _this.setState({
40
+ open: open
41
+ });
42
+
43
+ return;
44
+ };
45
+
46
+ _this.onClear = function () {
47
+ _this.setState({
48
+ datePickerValue: null
49
+ });
50
+ };
51
+
52
+ _this.onFocusDatePicker = function () {
53
+ _this.setState({
54
+ open: true
55
+ });
56
+ };
57
+
58
+ _this.handleMouseDown = function (event) {
59
+ event.preventDefault();
60
+ event.stopPropagation();
61
+ };
62
+
63
+ _this.getCalendarContainer = function () {
64
+ return _this.calendarContainerRef.current;
65
+ };
66
+
67
+ _this.getCalender = function () {
68
+ var _this$props = _this.props,
69
+ dateFormat = _this$props.dateFormat,
70
+ showHourAndMinute = _this$props.showHourAndMinute,
71
+ lang = _this$props.lang;
72
+ var defaultValue = moment().clone();
73
+ return /*#__PURE__*/React.createElement(Calendar, {
74
+ locale: initDateEditorLanguage(lang),
75
+ style: {
76
+ zIndex: 1001
77
+ },
78
+ format: dateFormat,
79
+ defaultValue: defaultValue,
80
+ showHourAndMinute: showHourAndMinute,
81
+ dateInputPlaceholder: getLocale('Please_input'),
82
+ showDateInput: true,
83
+ focusablePanel: false,
84
+ onClear: _this.onClear
85
+ });
86
+ };
87
+
88
+ _this.state = {
89
+ open: true,
90
+ datePickerValue: props.value ? moment(props.value) : null
91
+ };
92
+ _this.calendarContainerRef = React.createRef();
93
+ return _this;
94
+ } // event trigger sequence: onOpenChange --> onChange
95
+
96
+
97
+ _createClass(PCDateEditorPopover, [{
98
+ key: "render",
99
+ value: function render() {
100
+ var _this2 = this;
101
+
102
+ var dateFormat = this.props.dateFormat;
103
+ var _this$state = this.state,
104
+ open = _this$state.open,
105
+ datePickerValue = _this$state.datePickerValue;
106
+ var calendar = this.getCalender();
107
+ return /*#__PURE__*/React.createElement(DatePicker, {
108
+ open: open,
109
+ value: datePickerValue,
110
+ animation: "slide-up",
111
+ style: {
112
+ zIndex: 1001
113
+ },
114
+ calendar: calendar,
115
+ getCalendarContainer: this.getCalendarContainer,
116
+ onChange: this.onChange,
117
+ onOpenChange: this.onOpenChange
118
+ }, function (_ref) {
119
+ var value = _ref.value;
120
+ value = value && value.format(dateFormat);
121
+ return /*#__PURE__*/React.createElement("span", {
122
+ className: "dtable-ui-date-editor-container",
123
+ tabIndex: "0",
124
+ onFocus: _this2.onFocusDatePicker
125
+ }, /*#__PURE__*/React.createElement("input", {
126
+ readOnly: true,
127
+ tabIndex: "-1",
128
+ className: "form-control",
129
+ placeholder: getLocale('Please_select'),
130
+ value: value || '',
131
+ onMouseDown: _this2.handleMouseDown
132
+ }), /*#__PURE__*/React.createElement("div", {
133
+ ref: _this2.calendarContainerRef
134
+ }));
135
+ });
136
+ }
137
+ }]);
138
+
139
+ return PCDateEditorPopover;
140
+ }(React.Component);
141
+
142
+ export default PCDateEditorPopover;
@@ -0,0 +1,114 @@
1
+ import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
2
+ import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
+ import _createClass from "@babel/runtime/helpers/esm/createClass";
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
+
9
+ var PCLinkEditorPopover = /*#__PURE__*/function (_React$Component) {
10
+ _inherits(PCLinkEditorPopover, _React$Component);
11
+
12
+ var _super = _createSuper(PCLinkEditorPopover);
13
+
14
+ function PCLinkEditorPopover(props) {
15
+ var _this;
16
+
17
+ _classCallCheck(this, PCLinkEditorPopover);
18
+
19
+ _this = _super.call(this, props);
20
+
21
+ _this.onValueChanged = function (event) {
22
+ var value = event.target.value;
23
+
24
+ _this.setState({
25
+ searchValue: value
26
+ });
27
+ };
28
+
29
+ _this.onInputClick = function (event) {
30
+ event.nativeEvent.stopImmediatePropagation();
31
+ event.stopPropagation();
32
+ };
33
+
34
+ _this.onOptionItemToggle = function (item) {
35
+ _this.props.onOptionItemToggle(item);
36
+ };
37
+
38
+ _this.getFilterOptions = function () {
39
+ var options = _this.props.options;
40
+
41
+ var filter = _this.state.searchValue.toLowerCase();
42
+
43
+ if (!filter) {
44
+ return options;
45
+ }
46
+
47
+ return options.filter(function (option) {
48
+ return option.name.toString().toLowerCase().indexOf(filter) > -1;
49
+ });
50
+ };
51
+
52
+ _this.state = {
53
+ searchValue: ''
54
+ };
55
+ return _this;
56
+ }
57
+
58
+ _createClass(PCLinkEditorPopover, [{
59
+ key: "render",
60
+ value: function render() {
61
+ var _this2 = this;
62
+
63
+ var options = this.getFilterOptions();
64
+ var _this$props = this.props,
65
+ popoverPosition = _this$props.popoverPosition,
66
+ selectedOptions = _this$props.selectedOptions;
67
+ var searchValue = this.state.searchValue;
68
+ var popoverStyle = Object.assign({}, _objectSpread({}, popoverPosition), {
69
+ position: 'absolute'
70
+ });
71
+ return /*#__PURE__*/React.createElement("div", {
72
+ className: "dtable-ui-editor-popover dtable-ui-link-editor-popover",
73
+ style: popoverStyle
74
+ }, /*#__PURE__*/React.createElement("div", {
75
+ className: "link-options-search"
76
+ }, /*#__PURE__*/React.createElement("input", {
77
+ className: "form-control",
78
+ value: searchValue,
79
+ onChange: this.onValueChanged,
80
+ onClick: this.onInputClick,
81
+ placeholder: getLocale('Find_an_option')
82
+ })), /*#__PURE__*/React.createElement("div", {
83
+ className: "link-options-container"
84
+ }, options.length > 0 && options.map(function (option, index) {
85
+ var isSelect = selectedOptions.some(function (selectedOption) {
86
+ return selectedOption.id === option.id;
87
+ });
88
+ return /*#__PURE__*/React.createElement("div", {
89
+ key: index,
90
+ className: "link-option-item",
91
+ onClick: _this2.onOptionItemToggle.bind(_this2, option)
92
+ }, /*#__PURE__*/React.createElement("div", {
93
+ className: "option-info"
94
+ }, /*#__PURE__*/React.createElement("div", {
95
+ className: "option-name"
96
+ }, option.name)), /*#__PURE__*/React.createElement("div", {
97
+ className: "option-checked"
98
+ }, isSelect && /*#__PURE__*/React.createElement("i", {
99
+ className: "dtable-font dtable-icon-check-mark"
100
+ })));
101
+ }), options.length === 0 && /*#__PURE__*/React.createElement("div", {
102
+ className: "link-option-null"
103
+ }, getLocale('No_options_available'))));
104
+ }
105
+ }]);
106
+
107
+ return PCLinkEditorPopover;
108
+ }(React.Component);
109
+
110
+ PCLinkEditorPopover.defaultProps = {
111
+ popoverPosition: {},
112
+ options: []
113
+ };
114
+ export default PCLinkEditorPopover;