@quillsql/react 2.13.47 → 2.13.49

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 (298) hide show
  1. package/dist/cjs/Chart.d.ts +2 -2
  2. package/dist/cjs/Chart.d.ts.map +1 -1
  3. package/dist/cjs/Chart.js +56 -49
  4. package/dist/cjs/ChartBuilder.d.ts +3 -2
  5. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  6. package/dist/cjs/ChartBuilder.js +172 -138
  7. package/dist/cjs/ChartEditor.d.ts +2 -2
  8. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  9. package/dist/cjs/ChartEditor.js +5 -2
  10. package/dist/cjs/Context.d.ts +121 -41
  11. package/dist/cjs/Context.d.ts.map +1 -1
  12. package/dist/cjs/Context.js +449 -261
  13. package/dist/cjs/Dashboard.d.ts.map +1 -1
  14. package/dist/cjs/Dashboard.js +26 -25
  15. package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +0 -3
  16. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
  17. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  18. package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +472 -96
  19. package/dist/cjs/QuillProvider.d.ts +3 -1
  20. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  21. package/dist/cjs/QuillProvider.js +2 -2
  22. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  23. package/dist/cjs/ReportBuilder.js +25 -14
  24. package/dist/cjs/SQLEditor.d.ts +1 -1
  25. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  26. package/dist/cjs/SQLEditor.js +51 -16
  27. package/dist/cjs/Table.d.ts.map +1 -1
  28. package/dist/cjs/Table.js +85 -14
  29. package/dist/cjs/assets/ExclamationFilledIcon.d.ts.map +1 -1
  30. package/dist/cjs/components/Chart/BarChart.d.ts.map +1 -1
  31. package/dist/cjs/components/Chart/BarChart.js +2 -1
  32. package/dist/cjs/components/Chart/CustomReferenceLine.d.ts +1 -1
  33. package/dist/cjs/components/Chart/CustomReferenceLine.d.ts.map +1 -1
  34. package/dist/cjs/components/Chart/CustomReferenceLine.js +7 -6
  35. package/dist/cjs/components/Chart/GaugeChart.d.ts +1 -1
  36. package/dist/cjs/components/Chart/GaugeChart.d.ts.map +1 -1
  37. package/dist/cjs/components/Chart/GaugeChart.js +63 -36
  38. package/dist/cjs/components/Chart/InternalChart.d.ts.map +1 -1
  39. package/dist/cjs/components/Chart/InternalChart.js +30 -33
  40. package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
  41. package/dist/cjs/components/Chart/LineChart.js +3 -1
  42. package/dist/cjs/components/Chart/MapChart.d.ts +3 -3
  43. package/dist/cjs/components/Chart/MapChart.d.ts.map +1 -1
  44. package/dist/cjs/components/Chart/MapChart.js +62 -34
  45. package/dist/cjs/components/Chart/PieChart.d.ts +3 -1
  46. package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
  47. package/dist/cjs/components/Chart/PieChart.js +80 -39
  48. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  49. package/dist/cjs/components/Dashboard/DashboardFilter.js +4 -20
  50. package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  51. package/dist/cjs/components/Dashboard/DashboardTemplate.js +2 -1
  52. package/dist/cjs/components/Dashboard/DataLoader.d.ts +4 -4
  53. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  54. package/dist/cjs/components/Dashboard/DataLoader.js +101 -65
  55. package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
  56. package/dist/cjs/components/Dashboard/MetricComponent.js +2 -2
  57. package/dist/cjs/components/Dashboard/util.d.ts +1 -1
  58. package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
  59. package/dist/cjs/components/Dashboard/util.js +7 -6
  60. package/dist/cjs/components/QuillMultiSelectSectionList.d.ts.map +1 -1
  61. package/dist/cjs/components/QuillMultiSelectSectionList.js +32 -22
  62. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  63. package/dist/cjs/components/QuillMultiSelectWithCombo.js +186 -159
  64. package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
  65. package/dist/cjs/components/QuillSelect.js +83 -75
  66. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  67. package/dist/cjs/components/QuillSelectWithCombo.js +18 -11
  68. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  69. package/dist/cjs/components/QuillTable.js +59 -61
  70. package/dist/cjs/components/ReportBuilder/FilterStack.d.ts +2 -1
  71. package/dist/cjs/components/ReportBuilder/FilterStack.d.ts.map +1 -1
  72. package/dist/cjs/components/ReportBuilder/FilterStack.js +3 -4
  73. package/dist/cjs/components/ReportBuilder/ui.d.ts +2 -2
  74. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  75. package/dist/cjs/components/ReportBuilder/ui.js +4 -7
  76. package/dist/cjs/components/UiComponents.d.ts +1 -1
  77. package/dist/cjs/hooks/useAskQuill.d.ts.map +1 -1
  78. package/dist/cjs/hooks/useAskQuill.js +5 -1
  79. package/dist/cjs/hooks/useDashboard.d.ts +2 -2
  80. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  81. package/dist/cjs/hooks/useDashboard.js +160 -69
  82. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  83. package/dist/cjs/hooks/useExport.js +29 -15
  84. package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -1
  85. package/dist/cjs/hooks/useQuill.d.ts +1 -0
  86. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  87. package/dist/cjs/hooks/useQuill.js +22 -12
  88. package/dist/cjs/hooks/useReport.d.ts +2 -2
  89. package/dist/cjs/hooks/useReport.d.ts.map +1 -1
  90. package/dist/cjs/hooks/useReport.js +3 -4
  91. package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
  92. package/dist/cjs/hooks/useVirtualTables.js +16 -22
  93. package/dist/cjs/index.d.ts +2 -2
  94. package/dist/cjs/index.d.ts.map +1 -1
  95. package/dist/cjs/index.js +2 -1
  96. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +2 -1
  97. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  98. package/dist/cjs/internals/ReportBuilder/PivotModal.js +19 -7
  99. package/dist/cjs/models/Client.d.ts +0 -1
  100. package/dist/cjs/models/Client.d.ts.map +1 -1
  101. package/dist/cjs/models/Data.d.ts +20 -0
  102. package/dist/cjs/models/Data.d.ts.map +1 -0
  103. package/dist/cjs/models/Data.js +2 -0
  104. package/dist/cjs/models/Filter.d.ts +42 -4
  105. package/dist/cjs/models/Filter.d.ts.map +1 -1
  106. package/dist/cjs/models/Pivot.d.ts.map +1 -1
  107. package/dist/cjs/utils/astProcessing.d.ts +3 -2
  108. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  109. package/dist/cjs/utils/astProcessing.js +28 -37
  110. package/dist/cjs/utils/client.d.ts +3 -2
  111. package/dist/cjs/utils/client.d.ts.map +1 -1
  112. package/dist/cjs/utils/client.js +38 -39
  113. package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
  114. package/dist/cjs/utils/columnProcessing.js +14 -3
  115. package/dist/cjs/utils/constants.d.ts +1 -0
  116. package/dist/cjs/utils/constants.d.ts.map +1 -1
  117. package/dist/cjs/utils/constants.js +2 -1
  118. package/dist/cjs/utils/dashboard.d.ts +3 -2
  119. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  120. package/dist/cjs/utils/dashboard.js +30 -12
  121. package/dist/cjs/utils/dataFetcher.d.ts +8 -5
  122. package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
  123. package/dist/cjs/utils/dataFetcher.js +189 -65
  124. package/dist/cjs/utils/filterProcessing.d.ts +2 -1
  125. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  126. package/dist/cjs/utils/filterProcessing.js +24 -38
  127. package/dist/cjs/utils/getDomain.d.ts.map +1 -1
  128. package/dist/cjs/utils/paginationProcessing.d.ts +1 -0
  129. package/dist/cjs/utils/paginationProcessing.d.ts.map +1 -1
  130. package/dist/cjs/utils/paginationProcessing.js +6 -1
  131. package/dist/cjs/utils/pivotConstructor.d.ts +2 -1
  132. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  133. package/dist/cjs/utils/pivotConstructor.js +15 -9
  134. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  135. package/dist/cjs/utils/pivotProcessing.js +3 -5
  136. package/dist/cjs/utils/queryConstructor.js +1 -1
  137. package/dist/cjs/utils/report.d.ts +10 -7
  138. package/dist/cjs/utils/report.d.ts.map +1 -1
  139. package/dist/cjs/utils/report.js +52 -60
  140. package/dist/cjs/utils/schema.d.ts +4 -3
  141. package/dist/cjs/utils/schema.d.ts.map +1 -1
  142. package/dist/cjs/utils/schema.js +30 -44
  143. package/dist/cjs/utils/tableProcessing.d.ts +16 -10
  144. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  145. package/dist/cjs/utils/tableProcessing.js +92 -90
  146. package/dist/cjs/utils/textProcessing.d.ts.map +1 -1
  147. package/dist/cjs/utils/textProcessing.js +2 -1
  148. package/dist/cjs/utils/ui.d.ts.map +1 -1
  149. package/dist/esm/Chart.d.ts +2 -2
  150. package/dist/esm/Chart.d.ts.map +1 -1
  151. package/dist/esm/Chart.js +60 -53
  152. package/dist/esm/ChartBuilder.d.ts +3 -2
  153. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  154. package/dist/esm/ChartBuilder.js +173 -139
  155. package/dist/esm/ChartEditor.d.ts +2 -2
  156. package/dist/esm/ChartEditor.d.ts.map +1 -1
  157. package/dist/esm/ChartEditor.js +6 -3
  158. package/dist/esm/Context.d.ts +121 -41
  159. package/dist/esm/Context.d.ts.map +1 -1
  160. package/dist/esm/Context.js +450 -262
  161. package/dist/esm/Dashboard.d.ts.map +1 -1
  162. package/dist/esm/Dashboard.js +28 -27
  163. package/dist/esm/DateRangePicker/QuillDateRangePicker.js +0 -3
  164. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
  165. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  166. package/dist/esm/DateRangePicker/dateRangePickerUtils.js +471 -95
  167. package/dist/esm/QuillProvider.d.ts +3 -1
  168. package/dist/esm/QuillProvider.d.ts.map +1 -1
  169. package/dist/esm/QuillProvider.js +2 -2
  170. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  171. package/dist/esm/ReportBuilder.js +28 -17
  172. package/dist/esm/SQLEditor.d.ts +1 -1
  173. package/dist/esm/SQLEditor.d.ts.map +1 -1
  174. package/dist/esm/SQLEditor.js +54 -19
  175. package/dist/esm/Table.d.ts.map +1 -1
  176. package/dist/esm/Table.js +88 -17
  177. package/dist/esm/assets/ExclamationFilledIcon.d.ts.map +1 -1
  178. package/dist/esm/components/Chart/BarChart.d.ts.map +1 -1
  179. package/dist/esm/components/Chart/BarChart.js +2 -1
  180. package/dist/esm/components/Chart/CustomReferenceLine.d.ts +1 -1
  181. package/dist/esm/components/Chart/CustomReferenceLine.d.ts.map +1 -1
  182. package/dist/esm/components/Chart/CustomReferenceLine.js +8 -7
  183. package/dist/esm/components/Chart/GaugeChart.d.ts +1 -1
  184. package/dist/esm/components/Chart/GaugeChart.d.ts.map +1 -1
  185. package/dist/esm/components/Chart/GaugeChart.js +65 -38
  186. package/dist/esm/components/Chart/InternalChart.d.ts.map +1 -1
  187. package/dist/esm/components/Chart/InternalChart.js +32 -35
  188. package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
  189. package/dist/esm/components/Chart/LineChart.js +3 -1
  190. package/dist/esm/components/Chart/MapChart.d.ts +3 -3
  191. package/dist/esm/components/Chart/MapChart.d.ts.map +1 -1
  192. package/dist/esm/components/Chart/MapChart.js +67 -39
  193. package/dist/esm/components/Chart/PieChart.d.ts +3 -1
  194. package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
  195. package/dist/esm/components/Chart/PieChart.js +80 -39
  196. package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  197. package/dist/esm/components/Dashboard/DashboardFilter.js +5 -21
  198. package/dist/esm/components/Dashboard/DashboardSection.js +2 -2
  199. package/dist/esm/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  200. package/dist/esm/components/Dashboard/DashboardTemplate.js +3 -2
  201. package/dist/esm/components/Dashboard/DataLoader.d.ts +4 -4
  202. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  203. package/dist/esm/components/Dashboard/DataLoader.js +102 -66
  204. package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
  205. package/dist/esm/components/Dashboard/MetricComponent.js +2 -2
  206. package/dist/esm/components/Dashboard/util.d.ts +1 -1
  207. package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
  208. package/dist/esm/components/Dashboard/util.js +8 -7
  209. package/dist/esm/components/QuillMultiSelectSectionList.d.ts.map +1 -1
  210. package/dist/esm/components/QuillMultiSelectSectionList.js +32 -22
  211. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  212. package/dist/esm/components/QuillMultiSelectWithCombo.js +187 -160
  213. package/dist/esm/components/QuillSelect.d.ts.map +1 -1
  214. package/dist/esm/components/QuillSelect.js +85 -77
  215. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  216. package/dist/esm/components/QuillSelectWithCombo.js +18 -11
  217. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  218. package/dist/esm/components/QuillTable.js +59 -61
  219. package/dist/esm/components/ReportBuilder/FilterStack.d.ts +2 -1
  220. package/dist/esm/components/ReportBuilder/FilterStack.d.ts.map +1 -1
  221. package/dist/esm/components/ReportBuilder/FilterStack.js +3 -4
  222. package/dist/esm/components/ReportBuilder/ui.d.ts +2 -2
  223. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  224. package/dist/esm/components/ReportBuilder/ui.js +4 -7
  225. package/dist/esm/components/UiComponents.d.ts +1 -1
  226. package/dist/esm/hooks/useAskQuill.d.ts.map +1 -1
  227. package/dist/esm/hooks/useAskQuill.js +6 -2
  228. package/dist/esm/hooks/useDashboard.d.ts +2 -2
  229. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  230. package/dist/esm/hooks/useDashboard.js +162 -71
  231. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  232. package/dist/esm/hooks/useExport.js +31 -17
  233. package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -1
  234. package/dist/esm/hooks/useQuill.d.ts +1 -0
  235. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  236. package/dist/esm/hooks/useQuill.js +23 -13
  237. package/dist/esm/hooks/useReport.d.ts +2 -2
  238. package/dist/esm/hooks/useReport.d.ts.map +1 -1
  239. package/dist/esm/hooks/useReport.js +4 -5
  240. package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
  241. package/dist/esm/hooks/useVirtualTables.js +17 -23
  242. package/dist/esm/index.d.ts +2 -2
  243. package/dist/esm/index.d.ts.map +1 -1
  244. package/dist/esm/index.js +1 -1
  245. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +2 -1
  246. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  247. package/dist/esm/internals/ReportBuilder/PivotModal.js +20 -8
  248. package/dist/esm/models/Client.d.ts +0 -1
  249. package/dist/esm/models/Client.d.ts.map +1 -1
  250. package/dist/esm/models/Data.d.ts +20 -0
  251. package/dist/esm/models/Data.d.ts.map +1 -0
  252. package/dist/esm/models/Data.js +1 -0
  253. package/dist/esm/models/Filter.d.ts +42 -4
  254. package/dist/esm/models/Filter.d.ts.map +1 -1
  255. package/dist/esm/models/Pivot.d.ts.map +1 -1
  256. package/dist/esm/utils/astProcessing.d.ts +3 -2
  257. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  258. package/dist/esm/utils/astProcessing.js +28 -37
  259. package/dist/esm/utils/client.d.ts +3 -2
  260. package/dist/esm/utils/client.d.ts.map +1 -1
  261. package/dist/esm/utils/client.js +38 -39
  262. package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
  263. package/dist/esm/utils/columnProcessing.js +14 -3
  264. package/dist/esm/utils/constants.d.ts +1 -0
  265. package/dist/esm/utils/constants.d.ts.map +1 -1
  266. package/dist/esm/utils/constants.js +1 -0
  267. package/dist/esm/utils/dashboard.d.ts +3 -2
  268. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  269. package/dist/esm/utils/dashboard.js +31 -13
  270. package/dist/esm/utils/dataFetcher.d.ts +8 -5
  271. package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
  272. package/dist/esm/utils/dataFetcher.js +187 -65
  273. package/dist/esm/utils/filterProcessing.d.ts +2 -1
  274. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  275. package/dist/esm/utils/filterProcessing.js +25 -39
  276. package/dist/esm/utils/getDomain.d.ts.map +1 -1
  277. package/dist/esm/utils/paginationProcessing.d.ts +1 -0
  278. package/dist/esm/utils/paginationProcessing.d.ts.map +1 -1
  279. package/dist/esm/utils/paginationProcessing.js +5 -0
  280. package/dist/esm/utils/pivotConstructor.d.ts +2 -1
  281. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  282. package/dist/esm/utils/pivotConstructor.js +16 -10
  283. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  284. package/dist/esm/utils/pivotProcessing.js +5 -7
  285. package/dist/esm/utils/queryConstructor.js +1 -1
  286. package/dist/esm/utils/report.d.ts +10 -7
  287. package/dist/esm/utils/report.d.ts.map +1 -1
  288. package/dist/esm/utils/report.js +53 -61
  289. package/dist/esm/utils/schema.d.ts +4 -3
  290. package/dist/esm/utils/schema.d.ts.map +1 -1
  291. package/dist/esm/utils/schema.js +30 -44
  292. package/dist/esm/utils/tableProcessing.d.ts +16 -10
  293. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  294. package/dist/esm/utils/tableProcessing.js +94 -92
  295. package/dist/esm/utils/textProcessing.d.ts.map +1 -1
  296. package/dist/esm/utils/textProcessing.js +2 -1
  297. package/dist/esm/utils/ui.d.ts.map +1 -1
  298. package/package.json +2 -1
@@ -157,15 +157,18 @@ function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, v
157
157
  if (!option) {
158
158
  return false;
159
159
  }
160
- return option.label
160
+ return (option.label
161
161
  .toString()
162
162
  .toLowerCase()
163
163
  .replace(/\s+/g, '')
164
- .includes(searchQuery.toLowerCase().replace(/\s+/g, ''))
165
- || (isNumber || isUuid ? option.value.toString()
166
- .toLowerCase()
167
- .replace(/\s+/g, '')
168
- .includes(searchQuery.toLowerCase().replace(/\s+/g, '')) : false);
164
+ .includes(searchQuery.toLowerCase().replace(/\s+/g, '')) ||
165
+ (isNumber || isUuid
166
+ ? option.value
167
+ .toString()
168
+ .toLowerCase()
169
+ .replace(/\s+/g, '')
170
+ .includes(searchQuery.toLowerCase().replace(/\s+/g, ''))
171
+ : false));
169
172
  })
170
173
  .sort((a, b) => {
171
174
  if (a.value === null) {
@@ -204,14 +207,19 @@ function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, v
204
207
  let mutationObserver;
205
208
  if (showModal && buttonRef.current) {
206
209
  updatePosition();
207
- setZ((0, useOnClickOutside_1.getEffectiveZIndex)(buttonRef.current));
210
+ setZ((0, useOnClickOutside_1.getEffectiveZIndex)(buttonRef.current) + 1);
208
211
  resizeObserver = new ResizeObserver(() => updatePosition());
209
212
  resizeObserver.observe(buttonRef.current);
210
213
  mutationObserver = new MutationObserver(() => updatePosition());
211
- mutationObserver.observe(buttonRef.current, { attributes: true, subtree: true });
214
+ mutationObserver.observe(buttonRef.current, {
215
+ attributes: true,
216
+ subtree: true,
217
+ });
212
218
  // Track scrolling of the nearest scrollable ancestor
213
219
  scrollableParentRef.current = (0, ui_1.getScrollableParent)(buttonRef.current);
214
- scrollableParentRef.current.addEventListener('scroll', updatePosition, { passive: true });
220
+ scrollableParentRef.current.addEventListener('scroll', updatePosition, {
221
+ passive: true,
222
+ });
215
223
  const handleResize = () => requestAnimationFrame(updatePosition);
216
224
  window.addEventListener('resize', handleResize, { passive: true });
217
225
  return () => {
@@ -227,7 +235,7 @@ function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, v
227
235
  borderRadius: '6px',
228
236
  width: width,
229
237
  minWidth: width,
230
- ...style
238
+ ...style,
231
239
  }, children: [label && ((0, jsx_runtime_1.jsx)("div", { style: {
232
240
  fontSize: 14,
233
241
  color: theme?.secondaryTextColor,
@@ -269,54 +277,61 @@ function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, v
269
277
  width: '100%',
270
278
  textAlign: 'left',
271
279
  zIndex: 1,
272
- }, children: selectedOptionsLabel }), (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: "currentColor", "aria-hidden": "true", "data-slot": "icon", height: 20, width: 20, style: { minHeight: 20, minWidth: 20 }, children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06Z", clipRule: "evenodd" }) })] }), showModal && (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsxs)("div", { style: {
273
- position: 'absolute',
274
- top: `${popoverPosition?.top ?? 0}px`,
275
- left: `${popoverPosition?.left ?? 0}px`,
276
- width: `${popoverPosition?.width ?? 0}px`,
277
- maxHeight: `${Math.max(popoverPosition?.maxHeight ?? 0, 100)}px`,
278
- minHeight: options.length > 2 ? 120 : options.length * 40,
279
- visibility: popoverPosition ? 'visible' : 'hidden',
280
- display: 'flex',
281
- flexDirection: 'column',
282
- boxSizing: 'border-box',
283
- borderWidth: 1,
284
- borderStyle: 'solid',
285
- borderColor: theme?.borderColor,
286
- borderRadius: 6,
287
- background: 'white',
288
- marginTop: 12,
289
- zIndex: z,
290
- padding: 6,
291
- fontFamily: theme?.fontFamily,
292
- overflow: 'scroll',
293
- fontSize: 14,
294
- }, ref: modalRef, "data-portal-ignore": "true", children: [!exceedsLimit && options && options.length > 20 && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(exports.ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
295
- setSearchQuery(value);
296
- } }), (0, jsx_runtime_1.jsx)("div", { style: {
297
- height: 9,
298
- width: 230,
299
- borderTop: '1px solid #e7e7e7',
300
- } })] })), !isLoading &&
301
- (!filteredItems || filteredItems.length === 0 || exceedsLimit) && ((0, jsx_runtime_1.jsxs)("div", { style: {
302
- display: 'flex',
303
- alignItems: 'center',
304
- padding: 8,
305
- margin: 0,
306
- boxSizing: 'border-box',
307
- borderWidth: 0,
308
- fontSize: 14,
309
- borderStyle: 'solid',
310
- borderColor: theme?.borderColor,
311
- borderRadius: 4,
312
- fontFamily: theme?.fontFamily,
313
- textOverflow: 'ellipsis',
314
- whiteSpace: 'nowrap',
315
- height: 34,
316
- minHeight: 34,
317
- gap: 6,
318
- overflow: 'hidden',
319
- }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
280
+ fontWeight: value?.length || isLoading ? undefined : 300,
281
+ color: value?.length || isLoading
282
+ ? undefined
283
+ : theme?.secondaryTextColor,
284
+ }, children: selectedOptionsLabel }), (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: "currentColor", "aria-hidden": "true", "data-slot": "icon", height: 20, width: 20, style: { minHeight: 20, minWidth: 20 }, children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06Z", clipRule: "evenodd" }) })] }), showModal &&
285
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsxs)("div", { style: {
286
+ position: 'absolute',
287
+ top: `${popoverPosition?.top ?? 0}px`,
288
+ left: `${popoverPosition?.left ?? 0}px`,
289
+ width: `${popoverPosition?.width ?? 0}px`,
290
+ maxHeight: `${Math.max(popoverPosition?.maxHeight ?? 0, 100)}px`,
291
+ minHeight: options.length > 2 ? 120 : options.length * 40,
292
+ visibility: popoverPosition ? 'visible' : 'hidden',
293
+ display: 'flex',
294
+ flexDirection: 'column',
295
+ boxSizing: 'border-box',
296
+ borderWidth: 1,
297
+ borderStyle: 'solid',
298
+ borderColor: theme?.borderColor,
299
+ borderRadius: 6,
300
+ background: 'white',
301
+ marginTop: 12,
302
+ zIndex: z,
303
+ padding: 6,
304
+ fontFamily: theme?.fontFamily,
305
+ overflow: 'scroll',
306
+ fontSize: 14,
307
+ }, ref: modalRef, "data-portal-ignore": "true", children: [!exceedsLimit && options && options.length > 20 && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(exports.ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
308
+ setSearchQuery(value);
309
+ } }), (0, jsx_runtime_1.jsx)("div", { style: {
310
+ height: 9,
311
+ width: 230,
312
+ borderTop: '1px solid #e7e7e7',
313
+ } })] })), !isLoading &&
314
+ (!filteredItems ||
315
+ filteredItems.length === 0 ||
316
+ exceedsLimit) && ((0, jsx_runtime_1.jsxs)("div", { style: {
317
+ display: 'flex',
318
+ alignItems: 'center',
319
+ padding: 8,
320
+ margin: 0,
321
+ boxSizing: 'border-box',
322
+ borderWidth: 0,
323
+ fontSize: 14,
324
+ borderStyle: 'solid',
325
+ borderColor: theme?.borderColor,
326
+ borderRadius: 4,
327
+ fontFamily: theme?.fontFamily,
328
+ textOverflow: 'ellipsis',
329
+ whiteSpace: 'nowrap',
330
+ height: 34,
331
+ minHeight: 34,
332
+ gap: 6,
333
+ overflow: 'hidden',
334
+ }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
320
335
  .quill-option {
321
336
  background: white;
322
337
  }
@@ -324,126 +339,138 @@ function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, v
324
339
  background: #F4F4F5;
325
340
  }
326
341
  ` }), (0, jsx_runtime_1.jsx)("span", { style: {
327
- textOverflow: 'ellipsis',
328
- whiteSpace: 'nowrap',
329
- overflow: 'hidden',
330
- cursor: 'default',
331
- }, children: exceedsLimit
332
- ? 'Too many options'
333
- : (emptyLabel ?? 'No options available') })] })), !exceedsLimit && !isLoading ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [searchQuery === '' && potentialOptions.length > 0 && ((0, jsx_runtime_1.jsxs)("button", { style: {
334
- display: 'flex',
335
- alignItems: 'center',
336
- padding: 8,
337
- margin: 0,
338
- boxSizing: 'border-box',
339
- borderWidth: 0,
340
- fontSize: 14,
341
- borderStyle: 'solid',
342
- borderColor: theme?.borderColor,
343
- borderRadius: 4,
344
- fontFamily: theme?.fontFamily,
345
- textOverflow: 'ellipsis',
346
- whiteSpace: 'nowrap',
347
- height: 34,
348
- minHeight: 34,
349
- gap: 6,
350
- overflow: 'hidden',
351
- }, className: "quill-option", onClick: () => {
352
- // if any are selected, deselect all
353
- if (selectAllCheckboxState === CheckboxState.SELECTED ||
354
- selectAllCheckboxState === CheckboxState.INDETERMINATE) {
355
- setSelectAllCheckboxState(CheckboxState.UNSELECTED);
356
- setSelectedOptions([]);
342
+ textOverflow: 'ellipsis',
343
+ whiteSpace: 'nowrap',
344
+ overflow: 'hidden',
345
+ cursor: 'default',
346
+ }, children: exceedsLimit
347
+ ? 'Too many options'
348
+ : (emptyLabel ?? 'No options available') })] })), !exceedsLimit && !isLoading ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [searchQuery === '' && potentialOptions.length > 0 && ((0, jsx_runtime_1.jsxs)("button", { style: {
349
+ display: 'flex',
350
+ alignItems: 'center',
351
+ padding: 8,
352
+ margin: 0,
353
+ boxSizing: 'border-box',
354
+ borderWidth: 0,
355
+ fontSize: 14,
356
+ borderStyle: 'solid',
357
+ borderColor: theme?.borderColor,
358
+ borderRadius: 4,
359
+ fontFamily: theme?.fontFamily,
360
+ textOverflow: 'ellipsis',
361
+ whiteSpace: 'nowrap',
362
+ height: 34,
363
+ minHeight: 34,
364
+ gap: 6,
365
+ overflow: 'hidden',
366
+ }, className: "quill-option", onClick: () => {
367
+ // if any are selected, deselect all
368
+ if (selectAllCheckboxState === CheckboxState.SELECTED ||
369
+ selectAllCheckboxState === CheckboxState.INDETERMINATE) {
370
+ setSelectAllCheckboxState(CheckboxState.UNSELECTED);
371
+ setSelectedOptions([]);
372
+ const updatedChangeEvent = {
373
+ target: { value: [] },
374
+ };
375
+ debounce(updatedChangeEvent);
376
+ return;
377
+ }
378
+ // if none are selected, select all
357
379
  const updatedChangeEvent = {
358
- target: { value: [] },
380
+ target: {
381
+ value: options.map((opt) => opt.value),
382
+ },
359
383
  };
384
+ setSelectAllCheckboxState(CheckboxState.SELECTED);
385
+ setSelectedOptions(options.map((opt) => opt.value));
360
386
  debounce(updatedChangeEvent);
361
- return;
362
- }
363
- // if none are selected, select all
364
- const updatedChangeEvent = {
365
- target: {
366
- value: options.map((opt) => opt.value),
367
- },
368
- };
369
- setSelectAllCheckboxState(CheckboxState.SELECTED);
370
- setSelectedOptions(options.map((opt) => opt.value));
371
- debounce(updatedChangeEvent);
372
- }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
387
+ }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
373
388
  .quill-option {
374
389
  background: white;
375
390
  }
376
391
  .quill-option:hover {
377
392
  background: #F4F4F5;
378
393
  }
379
- ` }), (0, jsx_runtime_1.jsx)("input", { ref: selectAllRef, type: "checkbox", checked: selectAllCheckboxState === CheckboxState.SELECTED, style: { width: '14px', height: '14px', margin: 'auto 0' }, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { style: {
380
- textOverflow: 'ellipsis',
381
- whiteSpace: 'nowrap',
382
- overflow: 'hidden',
383
- }, children: 'Select all' })] })), filteredItems.map((option) => ((0, jsx_runtime_1.jsxs)("button", { style: {
384
- display: 'flex',
385
- alignItems: 'center',
386
- padding: 8,
387
- margin: 0,
388
- boxSizing: 'border-box',
389
- borderWidth: 0,
390
- fontSize: 14,
391
- borderStyle: 'solid',
392
- borderColor: theme?.borderColor,
393
- borderRadius: 4,
394
- fontFamily: theme?.fontFamily,
395
- textOverflow: 'ellipsis',
396
- whiteSpace: 'nowrap',
397
- height: 34,
398
- minHeight: 34,
399
- gap: 6,
400
- overflow: 'hidden',
401
- }, className: "quill-option", onClick: () => {
402
- // Manually create a synthetic ChangeEvent and pass it to callback
403
- const changeEvent = { target: { value: option.value } };
404
- let updateSelectedOptions = [...selectedOptions];
405
- if (selectedOptions.includes(changeEvent.target.value)) {
406
- updateSelectedOptions = selectedOptions.filter((opt) => opt !== changeEvent.target.value);
407
- if (updateSelectedOptions.length === 0) {
408
- setSelectAllCheckboxState(CheckboxState.UNSELECTED);
394
+ ` }), (0, jsx_runtime_1.jsx)("input", { ref: selectAllRef, type: "checkbox", checked: selectAllCheckboxState === CheckboxState.SELECTED, style: {
395
+ width: '14px',
396
+ height: '14px',
397
+ margin: 'auto 0',
398
+ }, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { style: {
399
+ textOverflow: 'ellipsis',
400
+ whiteSpace: 'nowrap',
401
+ overflow: 'hidden',
402
+ }, children: (0, jsx_runtime_1.jsx)("span", { style: {
403
+ color: theme?.secondaryTextColor,
404
+ fontWeight: 300,
405
+ }, children: "Select all" }) })] })), filteredItems.map((option) => ((0, jsx_runtime_1.jsxs)("button", { style: {
406
+ display: 'flex',
407
+ alignItems: 'center',
408
+ padding: 8,
409
+ margin: 0,
410
+ boxSizing: 'border-box',
411
+ borderWidth: 0,
412
+ fontSize: 14,
413
+ borderStyle: 'solid',
414
+ borderColor: theme?.borderColor,
415
+ borderRadius: 4,
416
+ fontFamily: theme?.fontFamily,
417
+ textOverflow: 'ellipsis',
418
+ whiteSpace: 'nowrap',
419
+ height: 34,
420
+ minHeight: 34,
421
+ gap: 6,
422
+ overflow: 'hidden',
423
+ }, className: "quill-option", onClick: () => {
424
+ // Manually create a synthetic ChangeEvent and pass it to callback
425
+ const changeEvent = { target: { value: option.value } };
426
+ let updateSelectedOptions = [...selectedOptions];
427
+ if (selectedOptions.includes(changeEvent.target.value)) {
428
+ updateSelectedOptions = selectedOptions.filter((opt) => opt !== changeEvent.target.value);
429
+ if (updateSelectedOptions.length === 0) {
430
+ setSelectAllCheckboxState(CheckboxState.UNSELECTED);
431
+ }
432
+ else {
433
+ setSelectAllCheckboxState(CheckboxState.INDETERMINATE);
434
+ }
435
+ setSelectedOptions(updateSelectedOptions);
409
436
  }
410
437
  else {
411
- setSelectAllCheckboxState(CheckboxState.INDETERMINATE);
412
- }
413
- setSelectedOptions(updateSelectedOptions);
414
- }
415
- else {
416
- updateSelectedOptions = [
417
- ...updateSelectedOptions,
418
- changeEvent.target.value,
419
- ];
420
- if (updateSelectedOptions.length === potentialOptions.length) {
421
- setSelectAllCheckboxState(CheckboxState.SELECTED);
438
+ updateSelectedOptions = [
439
+ ...updateSelectedOptions,
440
+ changeEvent.target.value,
441
+ ];
442
+ if (updateSelectedOptions.length ===
443
+ potentialOptions.length) {
444
+ setSelectAllCheckboxState(CheckboxState.SELECTED);
445
+ }
446
+ else {
447
+ setSelectAllCheckboxState(CheckboxState.INDETERMINATE);
448
+ }
449
+ setSelectedOptions(updateSelectedOptions);
422
450
  }
423
- else {
424
- setSelectAllCheckboxState(CheckboxState.INDETERMINATE);
451
+ const updatedChangeEvent = {
452
+ target: { value: updateSelectedOptions },
453
+ };
454
+ if (updateSelectedOptions.length === 0) {
455
+ updatedChangeEvent.target.value = [];
425
456
  }
426
- setSelectedOptions(updateSelectedOptions);
427
- }
428
- const updatedChangeEvent = {
429
- target: { value: updateSelectedOptions },
430
- };
431
- if (updateSelectedOptions.length === 0) {
432
- updatedChangeEvent.target.value = [];
433
- }
434
- debounce(updatedChangeEvent);
435
- }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
457
+ debounce(updatedChangeEvent);
458
+ }, children: [(0, jsx_runtime_1.jsx)("style", { children: `
436
459
  .quill-option {
437
460
  background: white;
438
461
  }
439
462
  .quill-option:hover {
440
463
  background: #F4F4F5;
441
464
  }
442
- ` }), (0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: selectedOptions.includes(option.value), style: { width: '14px', height: '14px', margin: 'auto 0' }, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { style: {
443
- textOverflow: 'ellipsis',
444
- whiteSpace: 'nowrap',
445
- overflow: 'hidden',
446
- }, children: option.label ?? nullLabel })] }, option.value)))] })) : isLoading ? ((0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)(UiComponents_1.LoadingSpinner, {}) })) : null] }), document.body)] }));
465
+ ` }), (0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: selectedOptions.includes(option.value), style: {
466
+ width: '14px',
467
+ height: '14px',
468
+ margin: 'auto 0',
469
+ }, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { style: {
470
+ textOverflow: 'ellipsis',
471
+ whiteSpace: 'nowrap',
472
+ overflow: 'hidden',
473
+ }, children: option.label ?? nullLabel })] }, option.value)))] })) : isLoading ? ((0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)(UiComponents_1.LoadingSpinner, {}) })) : null] }), document.body)] }));
447
474
  }
448
475
  const ListboxTextInput = ({ value, onChange, placeholder, }) => {
449
476
  return ((0, jsx_runtime_1.jsxs)("div", { style: {
@@ -1 +1 @@
1
- {"version":3,"file":"QuillSelect.d.ts","sourceRoot":"","sources":["../../../src/components/QuillSelect.tsx"],"names":[],"mappings":"AACA,OAAO,EAAkB,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAMtE;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,EACnC,OAAO,EACP,KAAK,EACL,KAAK,EACL,QAAQ,EACR,KAAK,EACL,SAAS,EACT,QAAQ,EACR,eAAe,GAChB,EAAE,oBAAoB,2CA0StB"}
1
+ {"version":3,"file":"QuillSelect.d.ts","sourceRoot":"","sources":["../../../src/components/QuillSelect.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAkB,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAatE;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,EACnC,OAAO,EACP,KAAK,EACL,KAAK,EACL,QAAQ,EACR,KAAK,EACL,SAAS,EACT,QAAQ,EACR,eAAe,GAChB,EAAE,oBAAoB,2CA2TtB"}
@@ -93,13 +93,18 @@ function QuillSelectComponent({ options, value, width, onChange, label, isLoadin
93
93
  let mutationObserver;
94
94
  if (showModal && buttonRef.current) {
95
95
  updatePosition();
96
- setZ((0, useOnClickOutside_1.getEffectiveZIndex)(buttonRef.current));
96
+ setZ((0, useOnClickOutside_1.getEffectiveZIndex)(buttonRef.current) + 1);
97
97
  resizeObserver = new ResizeObserver(() => updatePosition());
98
98
  resizeObserver.observe(buttonRef.current);
99
99
  mutationObserver = new MutationObserver(() => updatePosition());
100
- mutationObserver.observe(buttonRef.current, { attributes: true, subtree: true });
100
+ mutationObserver.observe(buttonRef.current, {
101
+ attributes: true,
102
+ subtree: true,
103
+ });
101
104
  scrollableParentRef.current = (0, ui_1.getScrollableParent)(buttonRef.current);
102
- scrollableParentRef.current.addEventListener('scroll', updatePosition, { passive: true });
105
+ scrollableParentRef.current.addEventListener('scroll', updatePosition, {
106
+ passive: true,
107
+ });
103
108
  const handleResize = () => requestAnimationFrame(updatePosition);
104
109
  window.addEventListener('resize', handleResize, { passive: true });
105
110
  return () => {
@@ -153,80 +158,83 @@ function QuillSelectComponent({ options, value, width, onChange, label, isLoadin
153
158
  textOverflow: 'ellipsis',
154
159
  whiteSpace: 'nowrap',
155
160
  overflow: 'hidden',
156
- }, children: options.find((elem) => elem.value === value)?.label || 'Select' }), (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: "currentColor", "aria-hidden": "true", "data-slot": "icon", height: 20, width: 20, style: { minHeight: 20, minWidth: 20 }, children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06Z", clipRule: "evenodd" }) })] }), showModal && (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsxs)("div", { style: {
157
- position: 'absolute',
158
- top: `${popoverPosition?.top ?? 0}px`,
159
- left: `${popoverPosition?.left ?? 0}px`,
160
- width: `${popoverPosition?.width ?? 0}px`,
161
- maxHeight: `${Math.max(popoverPosition?.maxHeight ?? 0, 100)}px`,
162
- minHeight: options.length > 2 ? 120 : options.length * 40,
163
- visibility: popoverPosition ? 'visible' : 'hidden',
164
- display: 'flex',
165
- flexDirection: 'column',
166
- boxSizing: 'border-box',
167
- borderWidth: 1,
168
- borderStyle: 'solid',
169
- borderColor: theme?.borderColor,
170
- borderRadius: 6,
171
- background: 'white',
172
- marginTop: 12,
173
- zIndex: z,
174
- padding: 6,
175
- fontFamily: theme?.fontFamily,
176
- overflow: 'scroll',
177
- fontSize: 14,
178
- }, ref: modalRef, "data-portal-ignore": "true", children: [!isLoading && (!hideEmptyOption || !options.length) && ((0, jsx_runtime_1.jsxs)("button", { style: {
179
- display: 'flex',
180
- alignItems: 'center',
181
- justifyContent: 'space-between',
182
- padding: '8px 8px',
183
- margin: 0,
184
- boxSizing: 'border-box',
185
- borderWidth: 0,
186
- fontSize: 14,
187
- borderStyle: 'solid',
188
- borderColor: theme?.borderColor,
189
- borderRadius: 4,
190
- fontFamily: theme?.fontFamily,
191
- textOverflow: 'ellipsis',
192
- whiteSpace: 'nowrap',
193
- overflow: 'hidden',
194
- height: 34,
195
- minHeight: 34,
196
- }, className: "quill-option", onClick: () => {
197
- const changeEvent = { target: { value: '' } };
198
- onChange(changeEvent);
199
- setShowModal(false);
200
- }, disabled: disabled, children: [(0, jsx_runtime_1.jsx)("style", { children: `
161
+ fontWeight: value !== undefined ? undefined : 300,
162
+ color: value !== undefined ? undefined : theme?.secondaryTextColor,
163
+ }, children: options.find((elem) => elem.value === value)?.label || 'Select' }), (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: "currentColor", "aria-hidden": "true", "data-slot": "icon", height: 20, width: 20, style: { minHeight: 20, minWidth: 20 }, children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06Z", clipRule: "evenodd" }) })] }), showModal &&
164
+ (0, react_dom_1.createPortal)((0, jsx_runtime_1.jsxs)("div", { style: {
165
+ position: 'absolute',
166
+ top: `${popoverPosition?.top ?? 0}px`,
167
+ left: `${popoverPosition?.left ?? 0}px`,
168
+ width: `${popoverPosition?.width ?? 0}px`,
169
+ maxHeight: `${Math.max(popoverPosition?.maxHeight ?? 0, 100)}px`,
170
+ minHeight: options.length > 2 ? 120 : options.length * 40,
171
+ visibility: popoverPosition ? 'visible' : 'hidden',
172
+ display: 'flex',
173
+ flexDirection: 'column',
174
+ boxSizing: 'border-box',
175
+ borderWidth: 1,
176
+ borderStyle: 'solid',
177
+ borderColor: theme?.borderColor,
178
+ borderRadius: 6,
179
+ background: 'white',
180
+ marginTop: 12,
181
+ zIndex: z,
182
+ padding: 6,
183
+ fontFamily: theme?.fontFamily,
184
+ overflow: 'scroll',
185
+ fontSize: 14,
186
+ }, ref: modalRef, "data-portal-ignore": "true", children: [!isLoading && (!hideEmptyOption || !options.length) && ((0, jsx_runtime_1.jsxs)("button", { style: {
187
+ display: 'flex',
188
+ alignItems: 'center',
189
+ justifyContent: 'space-between',
190
+ padding: '8px 8px',
191
+ margin: 0,
192
+ boxSizing: 'border-box',
193
+ borderWidth: 0,
194
+ fontSize: 14,
195
+ borderStyle: 'solid',
196
+ borderColor: theme?.borderColor,
197
+ borderRadius: 4,
198
+ fontFamily: theme?.fontFamily,
199
+ textOverflow: 'ellipsis',
200
+ whiteSpace: 'nowrap',
201
+ overflow: 'hidden',
202
+ height: 34,
203
+ minHeight: 34,
204
+ }, className: "quill-option", onClick: () => {
205
+ const changeEvent = { target: { value: '' } };
206
+ onChange(changeEvent);
207
+ setShowModal(false);
208
+ }, disabled: disabled, children: [(0, jsx_runtime_1.jsx)("style", { children: `
201
209
  .quill-option {
202
210
  background: white;
203
211
  }
204
212
  .quill-option:hover {
205
213
  background: #F4F4F5;
206
214
  }
207
- ` }), 'Select'] })), !isLoading ? (options.map((option) => ((0, jsx_runtime_1.jsxs)("button", { style: {
208
- display: 'flex',
209
- alignItems: 'center',
210
- justifyContent: 'space-between',
211
- padding: '8px 8px',
212
- margin: 0,
213
- boxSizing: 'border-box',
214
- borderWidth: 0,
215
- fontSize: 14,
216
- borderStyle: 'solid',
217
- borderColor: theme?.borderColor,
218
- borderRadius: 4,
219
- fontFamily: theme?.fontFamily,
220
- textOverflow: 'ellipsis',
221
- whiteSpace: 'nowrap',
222
- height: 34,
223
- minHeight: 34,
224
- overflow: 'hidden',
225
- }, className: "quill-option", onClick: () => {
226
- const changeEvent = { target: { value: option.value } };
227
- onChange(changeEvent);
228
- setShowModal(false);
229
- }, disabled: disabled, children: [(0, jsx_runtime_1.jsx)("style", { children: `
215
+ ` }), (0, jsx_runtime_1.jsx)("span", { style: { color: theme?.secondaryTextColor, fontWeight: 300 }, children: "Select" })] })), !isLoading ? (options.map((option) => ((0, jsx_runtime_1.jsxs)("button", { style: {
216
+ display: 'flex',
217
+ alignItems: 'center',
218
+ justifyContent: 'space-between',
219
+ padding: '8px 8px',
220
+ margin: 0,
221
+ boxSizing: 'border-box',
222
+ borderWidth: 0,
223
+ fontSize: 14,
224
+ borderStyle: 'solid',
225
+ borderColor: theme?.borderColor,
226
+ borderRadius: 4,
227
+ fontFamily: theme?.fontFamily,
228
+ textOverflow: 'ellipsis',
229
+ whiteSpace: 'nowrap',
230
+ height: 34,
231
+ minHeight: 34,
232
+ overflow: 'hidden',
233
+ }, className: "quill-option", onClick: () => {
234
+ const changeEvent = { target: { value: option.value } };
235
+ onChange(changeEvent);
236
+ setShowModal(false);
237
+ }, disabled: disabled, children: [(0, jsx_runtime_1.jsx)("style", { children: `
230
238
  .quill-option {
231
239
  background: white;
232
240
  }
@@ -234,8 +242,8 @@ function QuillSelectComponent({ options, value, width, onChange, label, isLoadin
234
242
  background: #F4F4F5;
235
243
  }
236
244
  ` }), (0, jsx_runtime_1.jsx)("span", { style: {
237
- textOverflow: 'ellipsis',
238
- whiteSpace: 'nowrap',
239
- overflow: 'hidden',
240
- }, children: option.label ?? '-' })] }, option.label)))) : ((0, jsx_runtime_1.jsx)(UiComponents_1.LoadingSpinner, {}))] }), document.body)] }));
245
+ textOverflow: 'ellipsis',
246
+ whiteSpace: 'nowrap',
247
+ overflow: 'hidden',
248
+ }, children: option.label ?? '-' })] }, option.label)))) : ((0, jsx_runtime_1.jsx)(UiComponents_1.LoadingSpinner, {}))] }), document.body)] }));
241
249
  }