@fast-simon/dashboard-utilities 1.0.3 → 1.0.5

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 (196) hide show
  1. package/lib/@types/banner.d.ts +7 -0
  2. package/lib/@types/banner.js +2 -0
  3. package/lib/@types/banner.js.map +1 -0
  4. package/lib/@types/categories.d.ts +16 -0
  5. package/lib/@types/categories.js +2 -0
  6. package/lib/@types/categories.js.map +1 -0
  7. package/lib/@types/currency.d.ts +1 -0
  8. package/lib/@types/currency.js +2 -0
  9. package/lib/@types/currency.js.map +1 -0
  10. package/lib/@types/editorProduct.d.ts +26 -0
  11. package/lib/@types/editorProduct.js +6 -0
  12. package/lib/@types/editorProduct.js.map +1 -0
  13. package/lib/@types/iconProps.d.ts +9 -0
  14. package/lib/@types/iconProps.js +2 -0
  15. package/lib/@types/iconProps.js.map +1 -0
  16. package/lib/@types/product.d.ts +158 -0
  17. package/lib/@types/product.js +8 -0
  18. package/lib/@types/product.js.map +1 -0
  19. package/lib/@types/productLabel.d.ts +1 -0
  20. package/lib/@types/productLabel.js +2 -0
  21. package/lib/@types/productLabel.js.map +1 -0
  22. package/lib/@types/promoTile.d.ts +11 -0
  23. package/lib/@types/promoTile.js +2 -0
  24. package/lib/@types/promoTile.js.map +1 -0
  25. package/lib/@types/results.d.ts +42 -0
  26. package/lib/@types/results.js +2 -0
  27. package/lib/@types/results.js.map +1 -0
  28. package/lib/@types/sideMenu.d.ts +19 -0
  29. package/lib/@types/sideMenu.js +2 -0
  30. package/lib/@types/sideMenu.js.map +1 -0
  31. package/lib/@types/sortBy.d.ts +3 -0
  32. package/lib/@types/sortBy.js +2 -0
  33. package/lib/@types/sortBy.js.map +1 -0
  34. package/lib/App.d.ts +3 -0
  35. package/lib/App.js +15 -0
  36. package/lib/App.js.map +1 -0
  37. package/lib/components/BackOfficeFiltersMenu/BackOfficeFiltersMenu.d.ts +9 -0
  38. package/lib/components/BackOfficeFiltersMenu/BackOfficeFiltersMenu.js +74 -0
  39. package/lib/components/BackOfficeFiltersMenu/BackOfficeFiltersMenu.js.map +1 -0
  40. package/lib/components/BackOfficeFiltersMenu/index.d.ts +1 -0
  41. package/lib/components/BackOfficeFiltersMenu/index.js +2 -0
  42. package/lib/components/BackOfficeFiltersMenu/index.js.map +1 -0
  43. package/lib/components/BackOfficeFiltersMenu/utils.d.ts +7 -0
  44. package/lib/components/BackOfficeFiltersMenu/utils.js +239 -0
  45. package/lib/components/BackOfficeFiltersMenu/utils.js.map +1 -0
  46. package/lib/components/CheckboxFilter/Checkbox/Checkbox.d.ts +10 -0
  47. package/lib/components/CheckboxFilter/Checkbox/Checkbox.js +7 -0
  48. package/lib/components/CheckboxFilter/Checkbox/Checkbox.js.map +1 -0
  49. package/lib/components/CheckboxFilter/CheckboxFilter.d.ts +6 -0
  50. package/lib/components/CheckboxFilter/CheckboxFilter.js +9 -0
  51. package/lib/components/CheckboxFilter/CheckboxFilter.js.map +1 -0
  52. package/lib/components/DragAndDrop/DndContextWrapper.d.ts +20 -0
  53. package/lib/components/DragAndDrop/DndContextWrapper.js +33 -0
  54. package/lib/components/DragAndDrop/DndContextWrapper.js.map +1 -0
  55. package/lib/components/DragAndDrop/Droppable.d.ts +7 -0
  56. package/lib/components/DragAndDrop/Droppable.js +10 -0
  57. package/lib/components/DragAndDrop/Droppable.js.map +1 -0
  58. package/lib/components/DragAndDrop/SortableItem.d.ts +13 -0
  59. package/lib/components/DragAndDrop/SortableItem.js +39 -0
  60. package/lib/components/DragAndDrop/SortableItem.js.map +1 -0
  61. package/lib/components/FacetItem/FacetItem.d.ts +13 -0
  62. package/lib/components/FacetItem/FacetItem.js +40 -0
  63. package/lib/components/FacetItem/FacetItem.js.map +1 -0
  64. package/lib/components/FastSimonApi/FastSimonApi.d.ts +32 -0
  65. package/lib/components/FastSimonApi/FastSimonApi.js +398 -0
  66. package/lib/components/FastSimonApi/FastSimonApi.js.map +1 -0
  67. package/lib/components/FastSimonApi/context.d.ts +50 -0
  68. package/lib/components/FastSimonApi/context.js +10 -0
  69. package/lib/components/FastSimonApi/context.js.map +1 -0
  70. package/lib/components/FastSimonApi/index.d.ts +3 -0
  71. package/lib/components/FastSimonApi/index.js +3 -0
  72. package/lib/components/FastSimonApi/index.js.map +1 -0
  73. package/lib/components/FastSimonApi/reducer.d.ts +172 -0
  74. package/lib/components/FastSimonApi/reducer.js +67 -0
  75. package/lib/components/FastSimonApi/reducer.js.map +1 -0
  76. package/lib/components/FromToFilter/From/From.d.ts +17 -0
  77. package/lib/components/FromToFilter/From/From.js +22 -0
  78. package/lib/components/FromToFilter/From/From.js.map +1 -0
  79. package/lib/components/FromToFilter/FromToFilter.d.ts +14 -0
  80. package/lib/components/FromToFilter/FromToFilter.js +58 -0
  81. package/lib/components/FromToFilter/FromToFilter.js.map +1 -0
  82. package/lib/components/FromToFilter/To/To.d.ts +18 -0
  83. package/lib/components/FromToFilter/To/To.js +23 -0
  84. package/lib/components/FromToFilter/To/To.js.map +1 -0
  85. package/lib/components/FromToFilter/utils.d.ts +25 -0
  86. package/lib/components/FromToFilter/utils.js +7 -0
  87. package/lib/components/FromToFilter/utils.js.map +1 -0
  88. package/lib/components/InStoreFiltersMenu/InStoreFiltersMenu.d.ts +10 -0
  89. package/lib/components/InStoreFiltersMenu/InStoreFiltersMenu.js +34 -0
  90. package/lib/components/InStoreFiltersMenu/InStoreFiltersMenu.js.map +1 -0
  91. package/lib/components/InStoreFiltersMenu/index.d.ts +1 -0
  92. package/lib/components/InStoreFiltersMenu/index.js +2 -0
  93. package/lib/components/InStoreFiltersMenu/index.js.map +1 -0
  94. package/lib/components/Input/Input.d.ts +22 -0
  95. package/lib/components/Input/Input.js +49 -0
  96. package/lib/components/Input/Input.js.map +1 -0
  97. package/lib/components/Input/index.d.ts +1 -0
  98. package/lib/components/Input/index.js +2 -0
  99. package/lib/components/Input/index.js.map +1 -0
  100. package/lib/components/LastReceivedDateFilter/LastReceivedDate.d.ts +9 -0
  101. package/lib/components/LastReceivedDateFilter/LastReceivedDate.js +88 -0
  102. package/lib/components/LastReceivedDateFilter/LastReceivedDate.js.map +1 -0
  103. package/lib/components/LastReceivedDateFilter/utils.d.ts +3 -0
  104. package/lib/components/LastReceivedDateFilter/utils.js +43 -0
  105. package/lib/components/LastReceivedDateFilter/utils.js.map +1 -0
  106. package/lib/components/RadioFilter/Radio/Radio.d.ts +10 -0
  107. package/lib/components/RadioFilter/Radio/Radio.js +7 -0
  108. package/lib/components/RadioFilter/Radio/Radio.js.map +1 -0
  109. package/lib/components/RadioFilter/RadioFilter.d.ts +9 -0
  110. package/lib/components/RadioFilter/RadioFilter.js +45 -0
  111. package/lib/components/RadioFilter/RadioFilter.js.map +1 -0
  112. package/lib/components/RadioFilter/utils.d.ts +1 -0
  113. package/lib/components/RadioFilter/utils.js +8 -0
  114. package/lib/components/RadioFilter/utils.js.map +1 -0
  115. package/lib/components/ReactDatePicker/ReactDatePicker.d.ts +11 -0
  116. package/lib/components/ReactDatePicker/ReactDatePicker.js +16 -0
  117. package/lib/components/ReactDatePicker/ReactDatePicker.js.map +1 -0
  118. package/lib/components/ReactDatePicker/index.d.ts +1 -0
  119. package/lib/components/ReactDatePicker/index.js +2 -0
  120. package/lib/components/ReactDatePicker/index.js.map +1 -0
  121. package/lib/components/RenderIfVisible/RenderIfVisible.d.ts +12 -0
  122. package/lib/components/RenderIfVisible/RenderIfVisible.js +59 -0
  123. package/lib/components/RenderIfVisible/RenderIfVisible.js.map +1 -0
  124. package/lib/components/RenderIfVisible/index.d.ts +1 -0
  125. package/lib/components/RenderIfVisible/index.js +2 -0
  126. package/lib/components/RenderIfVisible/index.js.map +1 -0
  127. package/lib/components/SingleFilter/SingleFilter.d.ts +11 -0
  128. package/lib/components/SingleFilter/SingleFilter.js +90 -0
  129. package/lib/components/SingleFilter/SingleFilter.js.map +1 -0
  130. package/lib/components/SingleFilter/utils.d.ts +3 -0
  131. package/lib/components/SingleFilter/utils.js +42 -0
  132. package/lib/components/SingleFilter/utils.js.map +1 -0
  133. package/lib/components/SliderFilter/SliderFilter.d.ts +20 -0
  134. package/lib/components/SliderFilter/SliderFilter.js +46 -0
  135. package/lib/components/SliderFilter/SliderFilter.js.map +1 -0
  136. package/lib/components/SliderFilter/index.d.ts +1 -0
  137. package/lib/components/SliderFilter/index.js +2 -0
  138. package/lib/components/SliderFilter/index.js.map +1 -0
  139. package/lib/components/Tooltip/Tooltip.d.ts +8 -0
  140. package/lib/components/Tooltip/Tooltip.js +9 -0
  141. package/lib/components/Tooltip/Tooltip.js.map +1 -0
  142. package/lib/components/common.d.ts +34 -0
  143. package/lib/components/common.js +80 -0
  144. package/lib/components/common.js.map +1 -0
  145. package/lib/components/productGrid/ProductGrid.d.ts +7 -0
  146. package/lib/components/productGrid/ProductGrid.js +11 -0
  147. package/lib/components/productGrid/ProductGrid.js.map +1 -0
  148. package/lib/components/productGrid/index.d.ts +1 -0
  149. package/lib/components/productGrid/index.js +2 -0
  150. package/lib/components/productGrid/index.js.map +1 -0
  151. package/lib/icons/BackOfficeFiltersIcon.d.ts +2 -0
  152. package/lib/icons/BackOfficeFiltersIcon.js +7 -0
  153. package/lib/icons/BackOfficeFiltersIcon.js.map +1 -0
  154. package/lib/icons/BannersIcon.d.ts +2 -0
  155. package/lib/icons/BannersIcon.js +7 -0
  156. package/lib/icons/BannersIcon.js.map +1 -0
  157. package/lib/icons/HelpIcon.d.ts +7 -0
  158. package/lib/icons/HelpIcon.js +5 -0
  159. package/lib/icons/HelpIcon.js.map +1 -0
  160. package/lib/icons/InStoreFiltersIcon.d.ts +2 -0
  161. package/lib/icons/InStoreFiltersIcon.js +7 -0
  162. package/lib/icons/InStoreFiltersIcon.js.map +1 -0
  163. package/lib/icons/PromoteIcon.d.ts +2 -0
  164. package/lib/icons/PromoteIcon.js +7 -0
  165. package/lib/icons/PromoteIcon.js.map +1 -0
  166. package/lib/icons/RemoveIcon.d.ts +2 -0
  167. package/lib/icons/RemoveIcon.js +7 -0
  168. package/lib/icons/RemoveIcon.js.map +1 -0
  169. package/lib/icons/RestoreIcon.d.ts +2 -0
  170. package/lib/icons/RestoreIcon.js +7 -0
  171. package/lib/icons/RestoreIcon.js.map +1 -0
  172. package/lib/icons/index.d.ts +7 -0
  173. package/lib/icons/index.js +8 -0
  174. package/lib/icons/index.js.map +1 -0
  175. package/lib/main.d.ts +15 -0
  176. package/lib/main.js +2 -0
  177. package/lib/main.js.map +1 -0
  178. package/lib/services/API.d.ts +21 -0
  179. package/lib/services/API.js +50 -0
  180. package/lib/services/API.js.map +1 -0
  181. package/lib/services/landingPage.d.ts +28 -0
  182. package/lib/services/landingPage.js +153 -0
  183. package/lib/services/landingPage.js.map +1 -0
  184. package/lib/utils/customTagsFilters.d.ts +4 -0
  185. package/lib/utils/customTagsFilters.js +10 -0
  186. package/lib/utils/customTagsFilters.js.map +1 -0
  187. package/lib/utils/products.d.ts +30 -0
  188. package/lib/utils/products.js +39 -0
  189. package/lib/utils/products.js.map +1 -0
  190. package/lib/utils/shopifyMarkets.d.ts +3 -0
  191. package/lib/utils/shopifyMarkets.js +7 -0
  192. package/lib/utils/shopifyMarkets.js.map +1 -0
  193. package/lib/utils/useDragToSelect.d.ts +13 -0
  194. package/lib/utils/useDragToSelect.js +177 -0
  195. package/lib/utils/useDragToSelect.js.map +1 -0
  196. package/package.json +10 -12
@@ -0,0 +1,177 @@
1
+ import React, { useCallback, useEffect, useState } from "react";
2
+ import DragSelect from "dragselect";
3
+ export const useDragToSelect = ({ areaRef, selectables, areaId, onSelectCommitted, onSelect, isDragAndDropActive, disabled, onDispatch, }) => {
4
+ // const { state, dispatcher } = useVisualEditorContext();
5
+ const [dragselect, setDragSelect] = React.useState();
6
+ const [prevSelectables, setPrevSelectables] = useState([]);
7
+ const setSelected = useCallback((items) => {
8
+ const selected = items.map((el) => {
9
+ const wrapper = el.closest(".main-product-container") ||
10
+ el.querySelector(".main-product-container");
11
+ return {
12
+ id: wrapper === null || wrapper === void 0 ? void 0 : wrapper.getAttribute("product-id"),
13
+ pos: wrapper === null || wrapper === void 0 ? void 0 : wrapper.getAttribute("product-index"),
14
+ };
15
+ });
16
+ const ids = {};
17
+ selected.forEach((el) => {
18
+ const id = el.id.includes("_")
19
+ ? el.id.split("_")[1]
20
+ : String(el.id);
21
+ ids[id] = parseInt(el.pos);
22
+ });
23
+ onSelect(ids);
24
+ }, [onSelect]);
25
+ const onselect = (callback_object) => {
26
+ var _a;
27
+ if (window.isDragAndDropActive ||
28
+ (callback_object === null || callback_object === void 0 ? void 0 : callback_object.isDragging) ||
29
+ !((_a = callback_object.event) === null || _a === void 0 ? void 0 : _a.target) ||
30
+ callback_object.event.target.localName === "svg") {
31
+ return;
32
+ }
33
+ if (callback_object.event.target.classList.contains("material-symbols-outlined") ||
34
+ callback_object.event.target.className.includes("icon") ||
35
+ callback_object.event.target.className.includes("Tooltip")) {
36
+ return;
37
+ }
38
+ setSelected(callback_object.items);
39
+ };
40
+ const commit = (callback_object) => {
41
+ var _a, _b, _c;
42
+ // dispatcher.setIsDragToSelectActive(false);
43
+ onDispatch("setIsDragToSelectActive", false);
44
+ if ((callback_object === null || callback_object === void 0 ? void 0 : callback_object.isDragging) ||
45
+ window.isDragAndDropActive) {
46
+ const area = document.getElementById(areaId);
47
+ if (area) {
48
+ area.style.userSelect = "";
49
+ area.style.webkitUserSelect = "";
50
+ }
51
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.clearSelection();
52
+ return;
53
+ }
54
+ if ((_c = (_b = (_a = callback_object === null || callback_object === void 0 ? void 0 : callback_object.event) === null || _a === void 0 ? void 0 : _a.target) === null || _b === void 0 ? void 0 : _b.closest) === null || _c === void 0 ? void 0 : _c.call(_b, ".main-product-container")) {
55
+ return;
56
+ }
57
+ onselect(callback_object);
58
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.clearSelection();
59
+ };
60
+ const onSelectStart = (callback_object) => {
61
+ var _a, _b, _c, _d;
62
+ // dispatcher.setIsDragToSelectActive(true);
63
+ onDispatch("setIsDragToSelectActive", true);
64
+ if (!(callback_object === null || callback_object === void 0 ? void 0 : callback_object.isDragging) &&
65
+ !window.isDragAndDropActive &&
66
+ callback_object.items.length !== 1) {
67
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.clearSelection();
68
+ }
69
+ if (window.getSelection) {
70
+ (_b = (_a = window.getSelection()) === null || _a === void 0 ? void 0 : _a.removeAllRanges) === null || _b === void 0 ? void 0 : _b.call(_a);
71
+ }
72
+ else if (document.getSelection) {
73
+ (_d = (_c = document.getSelection()) === null || _c === void 0 ? void 0 : _c.empty) === null || _d === void 0 ? void 0 : _d.call(_c);
74
+ }
75
+ const area = document.getElementById(areaId);
76
+ if (area) {
77
+ area.style.userSelect = "none";
78
+ area.style.webkitUserSelect = "none";
79
+ }
80
+ };
81
+ const onscroll = (callback_object) => {
82
+ var _a;
83
+ if (((_a = callback_object === null || callback_object === void 0 ? void 0 : callback_object.items) === null || _a === void 0 ? void 0 : _a.length) > 1 &&
84
+ !window.isDragAndDropActive) {
85
+ setSelected(callback_object.items);
86
+ }
87
+ };
88
+ useEffect(() => {
89
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.subscribe("dragmove", onselect);
90
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.subscribe("callback", commit);
91
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.subscribe("dragstart", onSelectStart);
92
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.subscribe("autoscroll", onscroll);
93
+ return () => {
94
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.unsubscribe("dragmove", onselect);
95
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.unsubscribe("callback", commit);
96
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.unsubscribe("dragstart", onSelectStart);
97
+ dragselect === null || dragselect === void 0 ? void 0 : dragselect.unsubscribe("autoscroll", onscroll);
98
+ };
99
+ }, [dragselect, setSelected]);
100
+ useEffect(() => {
101
+ const prevIds = prevSelectables.map((el) => {
102
+ const wrapper = el.closest(".main-product-container");
103
+ return wrapper === null || wrapper === void 0 ? void 0 : wrapper.getAttribute("product-id");
104
+ });
105
+ const currentIds = selectables.map((el) => {
106
+ const wrapper = el.closest(".main-product-container");
107
+ return wrapper === null || wrapper === void 0 ? void 0 : wrapper.getAttribute("product-id");
108
+ });
109
+ if (!dragselect && areaRef.current) {
110
+ if (onSelectCommitted) {
111
+ console.log("init dragselect");
112
+ }
113
+ setDragSelect(new DragSelect({
114
+ selectables: selectables,
115
+ area: document.getElementById(areaId),
116
+ autoScrollSpeed: 15,
117
+ overflowTolerance: { x: 0, y: 0 },
118
+ }));
119
+ }
120
+ else if (dragselect &&
121
+ JSON.stringify(prevIds) !== JSON.stringify(currentIds) &&
122
+ !isDragAndDropActive) {
123
+ dragselect.setSettings({
124
+ selectables: selectables,
125
+ overflowTolerance: { x: 0, y: 0 },
126
+ });
127
+ setPrevSelectables(selectables);
128
+ }
129
+ }, [selectables, areaRef, disabled, isDragAndDropActive]);
130
+ useEffect(() => {
131
+ const mousedownCallback = (e) => {
132
+ var _a;
133
+ if (e.target.closest("#page_top")) {
134
+ return;
135
+ }
136
+ if (e.target.closest(".actions-bar-container") ||
137
+ e.target.closest(".scroll-to-top-btn") ||
138
+ e.target.closest(".paste-button-container")) {
139
+ return;
140
+ }
141
+ if (!((_a = e.target) === null || _a === void 0 ? void 0 : _a.closest("#" + areaId))) {
142
+ // dispatcher.setIsCutting(false);
143
+ // dispatcher.setSelectedProducts([]);
144
+ onDispatch("setIsCutting", false);
145
+ onDispatch("setSelectedProducts", []);
146
+ onSelect({});
147
+ }
148
+ };
149
+ document.addEventListener("mousedown", mousedownCallback);
150
+ return () => {
151
+ document.removeEventListener("mousedown", mousedownCallback);
152
+ };
153
+ }, []);
154
+ useEffect(() => {
155
+ document.querySelectorAll(".ds-selector-area").forEach((el) => {
156
+ el.style.visibility = isDragAndDropActive ? "hidden" : "visible";
157
+ });
158
+ }, [isDragAndDropActive]);
159
+ useEffect(() => {
160
+ if (dragselect && disabled) {
161
+ dragselect.clearSelection();
162
+ dragselect.setSettings({
163
+ selectables: [],
164
+ area: document.createElement("div"),
165
+ overflowTolerance: { x: 0, y: 0 },
166
+ });
167
+ }
168
+ else if (dragselect && disabled === false) {
169
+ dragselect.setSettings({
170
+ selectables: selectables,
171
+ area: document.getElementById(areaId),
172
+ overflowTolerance: { x: 0, y: 0 },
173
+ });
174
+ }
175
+ }, [dragselect, disabled]);
176
+ };
177
+ //# sourceMappingURL=useDragToSelect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDragToSelect.js","sourceRoot":"","sources":["../../src/utils/useDragToSelect.ts"],"names":[],"mappings":"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","sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport DragSelect from \"dragselect\";\ninterface Props {\n areaRef: React.RefObject<HTMLDivElement>;\n selectables: HTMLElement[];\n areaId: string;\n onSelectCommitted?: (selectedIDS: string[]) => void;\n onSelect: (ids: Record<string, number>) => void;\n isDragAndDropActive: boolean;\n disabled?: boolean;\n onDispatch: (key: string, value: any) => void;\n}\nexport const useDragToSelect = ({\n areaRef,\n selectables,\n areaId,\n onSelectCommitted,\n onSelect,\n isDragAndDropActive,\n disabled,\n onDispatch,\n}: Props) => {\n // const { state, dispatcher } = useVisualEditorContext();\n\n const [dragselect, setDragSelect] = React.useState<DragSelect>();\n\n const [prevSelectables, setPrevSelectables] = useState<HTMLElement[]>([]);\n\n const setSelected = useCallback(\n (items: HTMLElement[]) => {\n const selected = items.map((el: HTMLElement) => {\n const wrapper =\n el.closest(\".main-product-container\") ||\n el.querySelector(\".main-product-container\");\n return {\n id: wrapper?.getAttribute(\"product-id\"),\n pos: wrapper?.getAttribute(\"product-index\"),\n };\n });\n const ids: Record<string, number> = {};\n selected.forEach((el: any) => {\n const id = el.id.includes(\"_\")\n ? el.id.split(\"_\")[1]\n : String(el.id);\n ids[id] = parseInt(el.pos);\n });\n\n onSelect(ids);\n },\n [onSelect]\n );\n\n const onselect = (callback_object: any) => {\n if (\n (window as any).isDragAndDropActive ||\n callback_object?.isDragging ||\n !callback_object.event?.target ||\n callback_object.event.target.localName === \"svg\"\n ) {\n return;\n }\n if (\n callback_object.event.target.classList.contains(\n \"material-symbols-outlined\"\n ) ||\n callback_object.event.target.className.includes(\"icon\") ||\n callback_object.event.target.className.includes(\"Tooltip\")\n ) {\n return;\n }\n\n setSelected(callback_object.items);\n };\n\n const commit = (callback_object: any) => {\n // dispatcher.setIsDragToSelectActive(false);\n onDispatch(\"setIsDragToSelectActive\", false);\n if (\n callback_object?.isDragging ||\n (window as any).isDragAndDropActive\n ) {\n const area = document.getElementById(areaId) as HTMLElement;\n if (area) {\n area.style.userSelect = \"\";\n area.style.webkitUserSelect = \"\";\n }\n dragselect?.clearSelection();\n return;\n }\n if (\n callback_object?.event?.target?.closest?.(\".main-product-container\")\n ) {\n return;\n }\n onselect(callback_object);\n dragselect?.clearSelection();\n };\n\n const onSelectStart = (callback_object: any) => {\n // dispatcher.setIsDragToSelectActive(true);\n onDispatch(\"setIsDragToSelectActive\", true);\n\n if (\n !callback_object?.isDragging &&\n !(window as any).isDragAndDropActive &&\n callback_object.items.length !== 1\n ) {\n dragselect?.clearSelection();\n }\n if (window.getSelection) {\n window.getSelection()?.removeAllRanges?.();\n } else if (document.getSelection) {\n document.getSelection()?.empty?.();\n }\n const area = document.getElementById(areaId) as HTMLElement;\n if (area) {\n area.style.userSelect = \"none\";\n area.style.webkitUserSelect = \"none\";\n }\n };\n\n const onscroll = (callback_object: any) => {\n if (\n callback_object?.items?.length > 1 &&\n !(window as any).isDragAndDropActive\n ) {\n setSelected(callback_object.items);\n }\n };\n\n useEffect(() => {\n dragselect?.subscribe(\"dragmove\", onselect);\n dragselect?.subscribe(\"callback\", commit);\n dragselect?.subscribe(\"dragstart\", onSelectStart);\n dragselect?.subscribe(\"autoscroll\", onscroll);\n return () => {\n dragselect?.unsubscribe(\"dragmove\", onselect);\n dragselect?.unsubscribe(\"callback\", commit);\n dragselect?.unsubscribe(\"dragstart\", onSelectStart);\n dragselect?.unsubscribe(\"autoscroll\", onscroll);\n };\n }, [dragselect, setSelected]);\n\n useEffect(() => {\n const prevIds = prevSelectables.map((el: HTMLElement) => {\n const wrapper = el.closest(\".main-product-container\");\n return wrapper?.getAttribute(\"product-id\");\n });\n const currentIds = selectables.map((el: HTMLElement) => {\n const wrapper = el.closest(\".main-product-container\");\n return wrapper?.getAttribute(\"product-id\");\n });\n\n if (!dragselect && areaRef.current) {\n if (onSelectCommitted) {\n console.log(\"init dragselect\");\n }\n setDragSelect(\n new DragSelect({\n selectables: selectables as HTMLElement[],\n area: document.getElementById(areaId) as HTMLElement,\n autoScrollSpeed: 15,\n overflowTolerance: { x: 0, y: 0 },\n })\n );\n } else if (\n dragselect &&\n JSON.stringify(prevIds) !== JSON.stringify(currentIds) &&\n !isDragAndDropActive\n ) {\n dragselect.setSettings({\n selectables: selectables as HTMLElement[],\n overflowTolerance: { x: 0, y: 0 },\n });\n setPrevSelectables(selectables);\n }\n }, [selectables, areaRef, disabled, isDragAndDropActive]);\n\n useEffect(() => {\n const mousedownCallback = (e: any) => {\n if (e.target.closest(\"#page_top\")) {\n return;\n }\n if (\n e.target.closest(\".actions-bar-container\") ||\n e.target.closest(\".scroll-to-top-btn\") ||\n e.target.closest(\".paste-button-container\")\n ) {\n return;\n }\n if (!e.target?.closest(\"#\" + areaId)) {\n // dispatcher.setIsCutting(false);\n // dispatcher.setSelectedProducts([]);\n onDispatch(\"setIsCutting\", false);\n onDispatch(\"setSelectedProducts\", []);\n onSelect({});\n }\n };\n\n document.addEventListener(\"mousedown\", mousedownCallback);\n return () => {\n document.removeEventListener(\"mousedown\", mousedownCallback);\n };\n }, []);\n\n useEffect(() => {\n document.querySelectorAll(\".ds-selector-area\").forEach((el: any) => {\n el.style.visibility = isDragAndDropActive ? \"hidden\" : \"visible\";\n });\n }, [isDragAndDropActive]);\n\n useEffect(() => {\n if (dragselect && disabled) {\n dragselect.clearSelection();\n dragselect.setSettings({\n selectables: [],\n area: document.createElement(\"div\"),\n overflowTolerance: { x: 0, y: 0 },\n });\n } else if (dragselect && disabled === false) {\n dragselect.setSettings({\n selectables: selectables as HTMLElement[],\n area: document.getElementById(areaId) as HTMLElement,\n overflowTolerance: { x: 0, y: 0 },\n });\n }\n }, [dragselect, disabled]);\n};\n"]}
package/package.json CHANGED
@@ -3,11 +3,11 @@
3
3
  "files": [
4
4
  "lib/**/*"
5
5
  ],
6
- "version": "1.0.3",
6
+ "version": "1.0.5",
7
7
  "scripts": {
8
8
  "dev": "vite",
9
- "build": "tsc && vite build",
10
9
  "preview": "vite preview",
10
+ "build": "tsc -p tsconfig-build.json",
11
11
  "prepublishOnly": "npm version patch && npm run build",
12
12
  "tsc": "tsc"
13
13
  },
@@ -36,21 +36,21 @@
36
36
  "moment": "^2.29.1",
37
37
  "rc-slider": "^10.1.1",
38
38
  "react-datepicker": "^4.10.0",
39
- "react-select": "^5.2.1",
40
- "tss-react": "^3.6.0",
41
- "usehooks-ts": "^2.9.1",
42
39
  "react-jss": "^10.6.0",
43
40
  "react-loading-skeleton": "^2.2.0",
44
41
  "react-multi-carousel": "^2.6.3",
45
- "react-switch": "^6.0.0"
42
+ "react-select": "^5.2.1",
43
+ "react-switch": "^6.0.0",
44
+ "tss-react": "^3.6.0",
45
+ "usehooks-ts": "^2.9.1"
46
46
  },
47
47
  "devDependencies": {
48
48
  "@types/node": "^18.13.0",
49
- "@types/react": "^17.0.33",
49
+ "@types/react": "^18.3.3",
50
50
  "@types/react-datepicker": "^4.10.0",
51
- "@types/react-dom": "^17.0.10",
51
+ "@types/react-dom": "^18.3.0",
52
52
  "@types/react-modal": "^3.13.1",
53
- "@types/react-router-dom": "^5.1.5",
53
+ "@types/react-redux": "^7.1.25",
54
54
  "@vitejs/plugin-react": "^1.0.7",
55
55
  "axios": "^0.24.0",
56
56
  "copyfiles": "^2.4.1",
@@ -60,9 +60,7 @@
60
60
  "react-datepicker": "^4.10.0",
61
61
  "react-dom": "^17.0.2",
62
62
  "react-modal": "3.14.4",
63
- "react-router-dom": "^5.2.0",
64
- "rimraf": "^3.0.2",
65
- "typescript": "^4.4.4",
63
+ "typescript": "^4.9.5",
66
64
  "vite": "^2.7.2"
67
65
  }
68
66
  }