@addev-be/ui 0.16.4 → 0.16.7

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 (206) hide show
  1. package/assets/icons/table.svg +1 -1
  2. package/dist/Icons.d.ts +9 -1
  3. package/dist/Icons.js +17 -1
  4. package/dist/components/auth/LoginForm.js +1 -1
  5. package/dist/components/auth/PasswordRecoveryForm.js +1 -1
  6. package/dist/components/auth/PasswordResetForm.js +1 -1
  7. package/dist/components/data/DataGrid/DataGridCell.js +5 -5
  8. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.d.ts +2 -2
  9. package/dist/components/data/DataGrid/DataGridColumnsModal/helpers.js +1 -7
  10. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +3 -3
  11. package/dist/components/data/DataGrid/DataGridColumnsModal/index.js +16 -21
  12. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.d.ts +2 -0
  13. package/dist/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.js +23 -0
  14. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.d.ts +2 -0
  15. package/dist/components/data/DataGrid/DataGridEditableCell/DateEditableCell.js +27 -0
  16. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.d.ts +5 -0
  17. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.js +32 -0
  18. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.d.ts +2 -0
  19. package/dist/components/data/DataGrid/DataGridEditableCell/TextEditableCell.js +23 -0
  20. package/dist/components/data/DataGrid/DataGridEditableCell/index.d.ts +2 -0
  21. package/dist/components/data/DataGrid/DataGridEditableCell/index.js +91 -0
  22. package/dist/components/data/DataGrid/DataGridEditableCell/styles.d.ts +3 -0
  23. package/dist/components/data/DataGrid/DataGridEditableCell/styles.js +17 -0
  24. package/dist/components/data/DataGrid/DataGridEditableCell/types.d.ts +11 -0
  25. package/dist/components/data/{AdvancedRequestDataGrid → DataGrid/DataGridEditableCell}/types.js +1 -0
  26. package/dist/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.js +17 -1
  27. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.d.ts +4 -3
  28. package/dist/components/data/DataGrid/DataGridFilterMenu/hooks.js +11 -12
  29. package/dist/components/data/DataGrid/DataGridFilterMenu/index.d.ts +5 -4
  30. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +44 -40
  31. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +1 -1
  32. package/dist/components/data/DataGrid/DataGridFooter.js +5 -5
  33. package/dist/components/data/DataGrid/DataGridHeader.js +40 -6
  34. package/dist/components/data/DataGrid/DataGridHeaderCell.d.ts +1 -1
  35. package/dist/components/data/DataGrid/DataGridHeaderCell.js +11 -23
  36. package/dist/components/data/DataGrid/DataGridRowTemplate.d.ts +1 -1
  37. package/dist/components/data/DataGrid/DataGridRowTemplate.js +8 -9
  38. package/dist/components/data/DataGrid/FilterModalContent/index.js +1 -1
  39. package/dist/components/data/DataGrid/constants.d.ts +6 -0
  40. package/dist/components/data/DataGrid/constants.js +9 -0
  41. package/dist/components/data/DataGrid/helpers/columns.d.ts +13 -12
  42. package/dist/components/data/DataGrid/helpers/columns.js +100 -130
  43. package/dist/components/data/DataGrid/hooks/index.d.ts +3 -3
  44. package/dist/components/data/DataGrid/hooks/index.js +8 -12
  45. package/dist/components/data/DataGrid/hooks/useDataGrid.js +71 -23
  46. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.d.ts +9 -0
  47. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.js +71 -0
  48. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +25 -30
  49. package/dist/components/data/DataGrid/index.js +16 -3
  50. package/dist/components/data/DataGrid/styles.d.ts +13 -8
  51. package/dist/components/data/DataGrid/styles.js +58 -30
  52. package/dist/components/data/DataGrid/types.d.ts +81 -15
  53. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.d.ts +2 -0
  54. package/dist/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.js +19 -0
  55. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +16 -17
  56. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +236 -84
  57. package/dist/components/data/SqlRequestDataGrid/index.js +77 -63
  58. package/dist/components/data/SqlRequestDataGrid/styles.d.ts +2 -0
  59. package/dist/components/data/SqlRequestDataGrid/styles.js +14 -0
  60. package/dist/components/data/SqlRequestDataGrid/types.d.ts +13 -3
  61. package/dist/components/data/SqlRequestDataGrid/types.js +1 -0
  62. package/dist/components/data/SqlRequestForeignList/index.d.ts +4 -0
  63. package/dist/components/data/SqlRequestForeignList/index.js +131 -0
  64. package/dist/components/data/SqlRequestForeignList/styles.d.ts +9 -0
  65. package/dist/components/data/SqlRequestForeignList/styles.js +22 -0
  66. package/dist/components/data/SqlRequestForeignList/types.d.ts +22 -0
  67. package/dist/components/data/SqlRequestForeignList/types.js +3 -0
  68. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.d.ts +10 -0
  69. package/dist/components/data/SqlRequestGrid/filters/FiltersSidebar.js +51 -0
  70. package/dist/components/data/SqlRequestGrid/filters/styles.d.ts +4 -0
  71. package/dist/components/data/SqlRequestGrid/filters/styles.js +17 -0
  72. package/dist/components/data/SqlRequestGrid/index.d.ts +1 -1
  73. package/dist/components/data/SqlRequestGrid/index.js +139 -49
  74. package/dist/components/data/SqlRequestGrid/styles.d.ts +0 -12
  75. package/dist/components/data/SqlRequestGrid/styles.js +4 -20
  76. package/dist/components/data/SqlRequestGrid/types.d.ts +14 -4
  77. package/dist/components/data/VirtualScroller/index.d.ts +4 -3
  78. package/dist/components/data/VirtualScroller/index.js +15 -5
  79. package/dist/components/data/VirtualScroller/styles.d.ts +4 -2
  80. package/dist/components/data/VirtualScroller/styles.js +9 -6
  81. package/dist/components/data/index.d.ts +1 -2
  82. package/dist/components/data/index.js +1 -2
  83. package/dist/components/forms/AutoTextArea.d.ts +10 -0
  84. package/dist/components/forms/AutoTextArea.js +40 -0
  85. package/dist/components/forms/Button.d.ts +9 -2
  86. package/dist/components/forms/Button.js +13 -7
  87. package/dist/components/forms/Form/Checkbox.d.ts +3 -0
  88. package/dist/components/forms/Form/Checkbox.js +33 -0
  89. package/dist/components/forms/Form/FormGroup.d.ts +9 -0
  90. package/dist/components/forms/Form/FormGroup.js +10 -0
  91. package/dist/components/forms/Form/Input.d.ts +3 -0
  92. package/dist/components/forms/Form/Input.js +33 -0
  93. package/dist/components/forms/Form/Row.d.ts +9 -0
  94. package/dist/components/forms/Form/Row.js +10 -0
  95. package/dist/components/forms/Form/Select.d.ts +18 -0
  96. package/dist/components/forms/Form/Select.js +47 -0
  97. package/dist/components/forms/Form/TextArea.d.ts +4 -0
  98. package/dist/components/forms/Form/TextArea.js +34 -0
  99. package/dist/components/forms/Form/index.d.ts +80 -0
  100. package/dist/components/forms/Form/index.js +29 -0
  101. package/dist/components/forms/Form/styles.d.ts +19 -0
  102. package/dist/components/forms/Form/styles.js +49 -0
  103. package/dist/components/forms/IconButton.d.ts +2 -1
  104. package/dist/components/forms/IconButton.js +12 -12
  105. package/dist/components/forms/NumberInput.d.ts +9 -0
  106. package/dist/components/forms/NumberInput.js +41 -0
  107. package/dist/components/forms/Select.d.ts +5 -6
  108. package/dist/components/forms/Select.js +2 -5
  109. package/dist/components/forms/index.d.ts +4 -0
  110. package/dist/components/forms/index.js +4 -0
  111. package/dist/components/layout/Columns.d.ts +5 -0
  112. package/dist/components/layout/Columns.js +19 -0
  113. package/dist/components/layout/Dropdown/index.d.ts +1 -0
  114. package/dist/components/layout/Dropdown/index.js +24 -3
  115. package/dist/components/layout/Grid/index.d.ts +6 -0
  116. package/dist/components/layout/Grid/index.js +6 -0
  117. package/dist/components/layout/Grid/styles.d.ts +14 -0
  118. package/dist/components/layout/Grid/styles.js +29 -0
  119. package/dist/components/layout/Masonry/index.d.ts +3 -0
  120. package/dist/components/layout/Masonry/index.js +20 -0
  121. package/dist/components/layout/Masonry/styles.d.ts +5 -0
  122. package/dist/components/layout/Masonry/styles.js +17 -0
  123. package/dist/components/layout/index.d.ts +4 -1
  124. package/dist/components/layout/index.js +4 -1
  125. package/dist/components/search/QuickSearchBar.js +6 -0
  126. package/dist/components/ui/Avatar/index.d.ts +10 -0
  127. package/dist/components/ui/Avatar/index.js +52 -0
  128. package/dist/components/ui/Avatar/styles.d.ts +4 -0
  129. package/dist/components/ui/Avatar/styles.js +43 -0
  130. package/dist/components/ui/Card/styles.js +1 -1
  131. package/dist/components/ui/Ellipsis.d.ts +13 -0
  132. package/dist/components/ui/Ellipsis.js +28 -0
  133. package/dist/components/ui/Label.d.ts +9 -0
  134. package/dist/components/ui/Label.js +74 -0
  135. package/dist/components/ui/ToastNotification.d.ts +14 -0
  136. package/dist/components/ui/ToastNotification.js +78 -0
  137. package/dist/components/ui/index.d.ts +3 -0
  138. package/dist/components/ui/index.js +3 -0
  139. package/dist/helpers/index.d.ts +1 -0
  140. package/dist/helpers/index.js +1 -0
  141. package/dist/helpers/numbers.d.ts +3 -0
  142. package/dist/helpers/numbers.js +33 -1
  143. package/dist/helpers/responsive.d.ts +37 -0
  144. package/dist/helpers/responsive.js +57 -0
  145. package/dist/hooks/index.d.ts +5 -0
  146. package/dist/hooks/index.js +5 -0
  147. package/dist/hooks/useContainerMediaQuery.d.ts +17 -0
  148. package/dist/hooks/useContainerMediaQuery.js +10 -0
  149. package/dist/hooks/useMediaQuery.d.ts +17 -0
  150. package/dist/hooks/useMediaQuery.js +11 -0
  151. package/dist/hooks/useMediaQueryForWidth.d.ts +17 -0
  152. package/dist/hooks/useMediaQueryForWidth.js +26 -0
  153. package/dist/hooks/useMutableState.d.ts +2 -0
  154. package/dist/hooks/useMutableState.js +16 -0
  155. package/dist/hooks/useShowArchived.d.ts +6 -0
  156. package/dist/hooks/useShowArchived.js +21 -0
  157. package/dist/index.d.ts +1 -0
  158. package/dist/index.js +1 -0
  159. package/dist/providers/AuthenticationProvider/index.js +4 -3
  160. package/dist/providers/PortalsProvider/styles.js +1 -1
  161. package/dist/providers/ThemeProvider/defaultTheme.js +13 -0
  162. package/dist/providers/ThemeProvider/helpers.d.ts +3 -0
  163. package/dist/providers/ThemeProvider/helpers.js +13 -0
  164. package/dist/providers/ThemeProvider/types.d.ts +2 -1
  165. package/dist/providers/TrackingProvider/hooks.d.ts +1 -0
  166. package/dist/providers/TrackingProvider/hooks.js +15 -0
  167. package/dist/providers/TrackingProvider/index.d.ts +8 -0
  168. package/dist/providers/TrackingProvider/index.js +41 -0
  169. package/dist/providers/UiProviders/index.js +2 -1
  170. package/dist/providers/index.d.ts +2 -0
  171. package/dist/providers/index.js +2 -0
  172. package/dist/services/globalSearch.d.ts +2 -1
  173. package/dist/services/index.d.ts +7 -0
  174. package/dist/services/index.js +20 -0
  175. package/dist/services/requests/generic.d.ts +29 -0
  176. package/dist/services/requests/generic.js +29 -0
  177. package/dist/services/requests/tracking.d.ts +18 -0
  178. package/dist/services/requests/tracking.js +8 -0
  179. package/dist/services/smartQueries.d.ts +51 -0
  180. package/dist/services/smartQueries.js +10 -0
  181. package/dist/services/smartRequests.d.ts +0 -0
  182. package/dist/services/smartRequests.js +1 -0
  183. package/dist/services/types/generic.d.ts +44 -0
  184. package/dist/services/types/generic.js +79 -0
  185. package/dist/services/types/tracking.d.ts +24 -0
  186. package/dist/services/types/tracking.js +47 -0
  187. package/dist/services/updateSqlRequests.d.ts +24 -0
  188. package/dist/services/updateSqlRequests.js +7 -0
  189. package/package.json +1 -1
  190. package/src/components/data/DataGrid/styles.ts +9 -2
  191. package/src/components/forms/NumberInput.tsx +53 -53
  192. package/src/components/ui/Avatar/styles.ts +61 -61
  193. package/src/components/ui/Label.tsx +90 -90
  194. package/src/providers/TrackingProvider/hooks.ts +14 -14
  195. package/tsconfig.tsbuildinfo +1 -1
  196. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.d.ts +0 -14
  197. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +0 -76
  198. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.d.ts +0 -22
  199. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +0 -156
  200. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.d.ts +0 -2
  201. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.js +0 -18
  202. package/dist/components/data/AdvancedRequestDataGrid/index.d.ts +0 -2
  203. package/dist/components/data/AdvancedRequestDataGrid/index.js +0 -215
  204. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +0 -21
  205. package/dist/components/data/DataGrid/DataGridEditableCell.d.ts +0 -2
  206. package/dist/components/data/DataGrid/DataGridEditableCell.js +0 -27
@@ -1,17 +1,16 @@
1
- import { SqlRequestDataGridColumn, SqlRequestDataGridColumns } from '../types';
2
- export declare const sqlTextColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
3
- /**
4
- * Creates a column with a composed value from multiple fields,
5
- * and filtered by a text filter on the first field
6
- */
7
- export declare const sqlComposedColumn: <R extends Record<string, any>>(key: string, title: string, fields: string[], options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
8
- export declare const sqlMailColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
9
- export declare const sqlPhoneColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
10
- export declare const sqlDateColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
11
- export declare const sqlDateTimeColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
12
- export declare const sqlMonthColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
13
- export declare const sqlNumberColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
14
- export declare const sqlMoneyColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
15
- export declare const sqlPercentageColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
16
- export declare const sqlCheckboxColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
17
- export declare const sqlColorColumn: <R extends Record<string, any>>(key: string, title: string, options?: Partial<SqlRequestDataGridColumn<R>>) => SqlRequestDataGridColumns<R>;
1
+ import { SqlRequestDataGridCheckboxColumn, SqlRequestDataGridDateColumn, SqlRequestDataGridForeignListColumn, SqlRequestDataGridNumberColumn, SqlRequestDataGridTextColumn } from '../types';
2
+ import { DeepPartial } from '../../../../typings';
3
+ import { SqlRequestForeignListItemFC } from '../../SqlRequestForeignList/types';
4
+ export declare const sqlTextColumn: <R extends Record<string, any>>(key: string, title: React.ReactNode, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
5
+ export declare const sqlMailColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
6
+ export declare const sqlPhoneColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
7
+ export declare const sqlDateColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridDateColumn<R>>) => SqlRequestDataGridDateColumn<R>;
8
+ export declare const sqlDateTimeColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridDateColumn<R>>) => SqlRequestDataGridDateColumn<R>;
9
+ export declare const sqlMonthColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
10
+ export declare const sqlNumberColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, options?: DeepPartial<SqlRequestDataGridNumberColumn<R>>) => SqlRequestDataGridNumberColumn<R>;
11
+ export declare const sqlMoneyColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, currency?: string | ((row: R) => string), options?: DeepPartial<SqlRequestDataGridNumberColumn<R>>) => SqlRequestDataGridNumberColumn<R>;
12
+ export declare const sqlPercentageColumn: <R extends Record<string, any>>(key: string, title: string, decimals?: number, options?: DeepPartial<SqlRequestDataGridNumberColumn<R>>) => SqlRequestDataGridNumberColumn<R>;
13
+ export declare const sqlCheckboxColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridCheckboxColumn<R>>) => SqlRequestDataGridCheckboxColumn<R>;
14
+ export declare const sqlImageColumn: <R extends Record<string, any>>(key: string, title: string, urlPrefix: string, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
15
+ export declare const sqlColorColumn: <R extends Record<string, any>>(key: string, title: string, options?: DeepPartial<SqlRequestDataGridTextColumn<R>>) => SqlRequestDataGridTextColumn<R>;
16
+ export declare const sqlForeignListColumn: <R extends Record<string, any>, T extends Record<string, any>, C extends string>(key: string, columnMapping: Record<keyof R, C>, title: string, requestName: string, ItemTemplate: SqlRequestForeignListItemFC<T>, options?: DeepPartial<SqlRequestDataGridForeignListColumn<R, T | null>>) => SqlRequestDataGridForeignListColumn<R, T | null>;
@@ -11,126 +11,278 @@ var __assign = (this && this.__assign) || function () {
11
11
  return __assign.apply(this, arguments);
12
12
  };
13
13
  Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.sqlColorColumn = exports.sqlCheckboxColumn = exports.sqlPercentageColumn = exports.sqlMoneyColumn = exports.sqlNumberColumn = exports.sqlMonthColumn = exports.sqlDateTimeColumn = exports.sqlDateColumn = exports.sqlPhoneColumn = exports.sqlMailColumn = exports.sqlComposedColumn = exports.sqlTextColumn = void 0;
14
+ exports.sqlForeignListColumn = exports.sqlColorColumn = exports.sqlImageColumn = exports.sqlCheckboxColumn = exports.sqlPercentageColumn = exports.sqlMoneyColumn = exports.sqlNumberColumn = exports.sqlMonthColumn = exports.sqlDateTimeColumn = exports.sqlDateColumn = exports.sqlPhoneColumn = exports.sqlMailColumn = exports.sqlTextColumn = void 0;
15
15
  var jsx_runtime_1 = require("react/jsx-runtime");
16
+ /* eslint-disable @typescript-eslint/no-explicit-any */
17
+ var react_1 = require("react");
18
+ var styles_1 = require("../styles");
16
19
  var helpers_1 = require("../../DataGrid/helpers");
17
20
  var dates_1 = require("../../../../helpers/dates");
18
21
  var numbers_1 = require("../../../../helpers/numbers");
22
+ var lodash_1 = require("lodash");
23
+ var CheckboxEditableCell_1 = require("../../DataGrid/DataGridEditableCell/CheckboxEditableCell");
24
+ var constants_1 = require("../../DataGrid/constants");
25
+ var DateEditableCell_1 = require("../../DataGrid/DataGridEditableCell/DateEditableCell");
26
+ var NumberEditableCell_1 = require("../../DataGrid/DataGridEditableCell/NumberEditableCell");
27
+ var SqlRequestForeignList_1 = require("../../SqlRequestForeignList");
28
+ var TextEditableCell_1 = require("../../DataGrid/DataGridEditableCell/TextEditableCell");
19
29
  var sqlTextColumn = function (key, title, options) {
20
- var _a;
21
- return (_a = {},
22
- _a[key] = __assign(__assign({ name: title, render: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }) }, options), { footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }),
23
- _a);
30
+ return (0, lodash_1.merge)({
31
+ key: key,
32
+ type: 'text',
33
+ name: title,
34
+ render: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
35
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
36
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
37
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }),
38
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
39
+ editComponent: TextEditableCell_1.TextEditableCell,
40
+ }, options);
24
41
  };
25
42
  exports.sqlTextColumn = sqlTextColumn;
26
- /**
27
- * Creates a column with a composed value from multiple fields,
28
- * and filtered by a text filter on the first field
29
- */
30
- var sqlComposedColumn = function (key, title, fields, options) {
31
- var _a;
32
- return (_a = {},
33
- _a[key] = __assign({ field: {
34
- fieldAlias: key,
35
- operator: 'jsonObject',
36
- operands: fields.flatMap(function (field) { return [
37
- { constantValue: field },
38
- { fieldName: field },
39
- ]; }),
40
- }, name: title, render: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(fields[0])), { getter: function (value) { var _a; return (_a = value[fields[0]]) !== null && _a !== void 0 ? _a : 0; } }), filterField: fields[0], sortField: fields[0], footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
41
- _a);
42
- };
43
- exports.sqlComposedColumn = sqlComposedColumn;
44
43
  var sqlMailColumn = function (key, title, options) {
45
- var _a;
46
- return (_a = {},
47
- _a[key] = __assign({ name: title, render: function (row) { var _a; return (0, jsx_runtime_1.jsx)("a", { href: "mailto:".concat(row[key]), children: (_a = row[key]) !== null && _a !== void 0 ? _a : '' }); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
48
- _a);
44
+ return (0, lodash_1.merge)({
45
+ key: key,
46
+ type: 'text',
47
+ name: title,
48
+ render: function (row) { var _a; return (0, jsx_runtime_1.jsx)("a", { href: "mailto:".concat(row[key]), children: (_a = row[key]) !== null && _a !== void 0 ? _a : '' }); },
49
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
50
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
51
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }),
52
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
53
+ editComponent: TextEditableCell_1.TextEditableCell,
54
+ }, options);
49
55
  };
50
56
  exports.sqlMailColumn = sqlMailColumn;
51
57
  var sqlPhoneColumn = function (key, title, options) {
52
- var _a;
53
- return (_a = {},
54
- _a[key] = __assign({ name: title, render: function (row) { var _a; return (0, jsx_runtime_1.jsx)("a", { href: "tel:".concat(row[key]), children: (_a = row[key]) !== null && _a !== void 0 ? _a : '' }); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
55
- _a);
58
+ return (0, lodash_1.merge)({
59
+ key: key,
60
+ type: 'text',
61
+ name: title,
62
+ render: function (row) { var _a; return (0, jsx_runtime_1.jsx)("a", { href: "tel:".concat(row[key]), children: (_a = row[key]) !== null && _a !== void 0 ? _a : '' }); },
63
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
64
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
65
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }),
66
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
67
+ editComponent: TextEditableCell_1.TextEditableCell,
68
+ }, options);
56
69
  };
57
70
  exports.sqlPhoneColumn = sqlPhoneColumn;
58
71
  var sqlDateColumn = function (key, title, options) {
59
- var _a;
60
- return (_a = {},
61
- _a[key] = __assign({ name: title, type: 'date', render: function (row) { return (0, dates_1.formatDate)(row[key]); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, excelFormatter: function () { return 'dd/mm/yyyy'; }, excelValue: function (value) { return (0, dates_1.formatDate)(value, 'YYYY-MM-DD'); }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, formatter: function (value) { return (0, dates_1.formatDate)(value); }, renderer: function (value) { return (0, dates_1.formatDate)(value); } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
62
- _a);
72
+ return (0, lodash_1.merge)({
73
+ key: key,
74
+ name: title,
75
+ type: 'date',
76
+ render: function (row) { return (0, dates_1.formatDate)(row[key]); },
77
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
78
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
79
+ excelOptions: {
80
+ formatter: function () { return 'dd/mm/yyyy'; },
81
+ valueGetter: function (value) { return (0, dates_1.formatDate)(value, 'YYYY-MM-DD'); },
82
+ },
83
+ filter: __assign(__assign({}, (0, helpers_1.dateFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, formatter: function (value) { return (0, dates_1.formatDate)(value); }, renderer: function (value) { return (0, dates_1.formatDate)(value); } }),
84
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
85
+ editComponent: DateEditableCell_1.DateEditableCell,
86
+ }, options);
63
87
  };
64
88
  exports.sqlDateColumn = sqlDateColumn;
65
89
  var sqlDateTimeColumn = function (key, title, options) {
66
- var _a;
67
- return (_a = {},
68
- _a[key] = __assign({ name: title, type: 'date', render: function (row) { return (0, dates_1.formatDateTime)(row[key]); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, excelFormatter: function () { return 'dd/mm/yyyy hh:mm:ss'; }, excelValue: function (value) { return (0, dates_1.formatDateTime)(value, 'YYYY-MM-DD HH:mm:ss'); }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, formatter: function (value) { return (0, dates_1.formatDateTime)(value); }, renderer: function (value) { return (0, dates_1.formatDateTime)(value); } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
69
- _a);
90
+ return (0, lodash_1.merge)({
91
+ key: key,
92
+ name: title,
93
+ type: 'date',
94
+ render: function (row) { return (0, dates_1.formatDateTime)(row[key]); },
95
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
96
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
97
+ excelOptions: {
98
+ formatter: function () { return 'dd/mm/yyyy hh:mm:ss'; },
99
+ valueGetter: function (value) { return (0, dates_1.formatDateTime)(value, 'YYYY-MM-DD HH:mm:ss'); },
100
+ },
101
+ filter: __assign(__assign({}, (0, helpers_1.dateFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, formatter: function (value) { return (0, dates_1.formatDateTime)(value); }, renderer: function (value) { return (0, dates_1.formatDateTime)(value); } }),
102
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
103
+ editComponent: DateEditableCell_1.DateEditableCell,
104
+ }, options);
70
105
  };
71
106
  exports.sqlDateTimeColumn = sqlDateTimeColumn;
72
107
  var sqlMonthColumn = function (key, title, options) {
73
- var _a;
74
- return (_a = {},
75
- _a[key] = __assign({ name: title, render: function (row) { return (row[key] ? "".concat(row[key], " mois ") : ''); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
76
- _a);
108
+ return (0, lodash_1.merge)({
109
+ key: key,
110
+ type: 'text',
111
+ name: title,
112
+ render: function (row) { return (row[key] ? "".concat(row[key], " mois ") : ''); },
113
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
114
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
115
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; } }),
116
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
117
+ }, options);
77
118
  };
78
119
  exports.sqlMonthColumn = sqlMonthColumn;
79
120
  var sqlNumberColumn = function (key, title, decimals, options) {
80
- var _a;
81
121
  if (decimals === void 0) { decimals = 2; }
82
- return (_a = {},
83
- _a[key] = __assign({ name: title, render: function (row) { var _a; return (_a = (0, numbers_1.formatNumber)(row[key], decimals)) !== null && _a !== void 0 ? _a : ''; }, excelFormatter: function () { return (0, helpers_1.buildExcelFormat)(decimals); }, excelValue: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: function (value) { var _a; return (_a = (0, numbers_1.formatNumber)(value, decimals)) !== null && _a !== void 0 ? _a : ''; } }), footer: {
84
- sum: null,
85
- avg: null,
86
- count: null,
87
- max: null,
88
- min: null,
89
- } }, options),
90
- _a);
122
+ var column = {
123
+ key: key,
124
+ name: title,
125
+ type: 'number',
126
+ decimals: decimals,
127
+ textAlign: 'right',
128
+ render: function (row) { var _a; return (_a = (0, numbers_1.formatNumber)(row[key], decimals)) !== null && _a !== void 0 ? _a : ''; },
129
+ excelOptions: {
130
+ formatter: function () { return (0, helpers_1.buildExcelFormat)(decimals); },
131
+ valueGetter: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); },
132
+ },
133
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
134
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : 0; },
135
+ filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: function (value) { var _a; return (_a = (0, numbers_1.formatNumber)(value, decimals)) !== null && _a !== void 0 ? _a : ''; } }),
136
+ footer: {
137
+ sum: null,
138
+ avg: null,
139
+ count: null,
140
+ max: null,
141
+ min: null,
142
+ },
143
+ editComponent: (0, react_1.forwardRef)(function (props, ref) { return ((0, jsx_runtime_1.jsx)(NumberEditableCell_1.NumberEditableCell, __assign({ ref: ref, decimals: column.decimals, currency: column.currency }, props))); }),
144
+ };
145
+ return (0, lodash_1.merge)(column, options);
91
146
  };
92
147
  exports.sqlNumberColumn = sqlNumberColumn;
93
- var sqlMoneyColumn = function (key, title, decimals, options) {
94
- var _a;
148
+ var sqlMoneyColumn = function (key, title, decimals, currency, options) {
95
149
  if (decimals === void 0) { decimals = 2; }
96
- return (_a = {},
97
- _a[key] = __assign({ name: title, type: 'number', render: function (row) { var _a; return (_a = (0, numbers_1.formatMoney)(row[key], decimals)) !== null && _a !== void 0 ? _a : ''; }, excelFormatter: function () { return (0, helpers_1.buildExcelFormat)(decimals, ' €'); }, excelValue: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: function (value) { var _a; return (_a = (0, numbers_1.formatMoney)(value, decimals)) !== null && _a !== void 0 ? _a : ''; } }), footer: {
98
- sum: null,
99
- avg: null,
100
- count: null,
101
- max: null,
102
- min: null,
103
- } }, options),
104
- _a);
150
+ if (currency === void 0) { currency = 'EUR'; }
151
+ var column = {
152
+ key: key,
153
+ name: title,
154
+ type: 'number',
155
+ decimals: decimals,
156
+ currency: currency,
157
+ textAlign: 'right',
158
+ render: typeof currency === 'function'
159
+ ? function (row) { var _a; return (_a = (0, numbers_1.formatMoney)(row[key], decimals, currency(row))) !== null && _a !== void 0 ? _a : ''; }
160
+ : function (row) { var _a; return (_a = (0, numbers_1.formatMoney)(row[key], decimals, currency)) !== null && _a !== void 0 ? _a : ''; },
161
+ excelOptions: {
162
+ formatter: typeof currency === 'function'
163
+ ? function (row) { return (0, helpers_1.buildExcelFormat)(decimals, currency(row)); }
164
+ : function () { return (0, helpers_1.buildExcelFormat)(decimals, currency); },
165
+ valueGetter: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); },
166
+ },
167
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
168
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : 0; },
169
+ filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: typeof currency === 'function'
170
+ ? function (value) { var _a; return (_a = (0, numbers_1.formatMoney)(value, decimals, currency(value))) !== null && _a !== void 0 ? _a : ''; }
171
+ : function (value) { var _a; return (_a = (0, numbers_1.formatMoney)(value, decimals, currency)) !== null && _a !== void 0 ? _a : ''; } }),
172
+ footer: {
173
+ sum: null,
174
+ avg: null,
175
+ count: null,
176
+ max: null,
177
+ min: null,
178
+ },
179
+ editComponent: (0, react_1.forwardRef)(function (props, ref) { return ((0, jsx_runtime_1.jsx)(NumberEditableCell_1.NumberEditableCell, __assign({ ref: ref, decimals: column.decimals, currency: column.currency }, props))); }),
180
+ };
181
+ return (0, lodash_1.merge)(column, options);
105
182
  };
106
183
  exports.sqlMoneyColumn = sqlMoneyColumn;
107
184
  var sqlPercentageColumn = function (key, title, decimals, options) {
108
- var _a;
109
185
  if (decimals === void 0) { decimals = 2; }
110
- return (_a = {},
111
- _a[key] = __assign({ name: title, render: function (row) { var _a; return (_a = (0, numbers_1.formatPercentage)(row[key])) !== null && _a !== void 0 ? _a : ''; }, excelFormatter: function () { return (0, helpers_1.buildExcelFormat)(decimals, '%'); }, excelValue: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: function (value) { var _a; return (_a = (0, numbers_1.formatPercentage)(value, decimals)) !== null && _a !== void 0 ? _a : ''; } }) }, options),
112
- _a);
186
+ var column = {
187
+ key: key,
188
+ name: title,
189
+ type: 'number',
190
+ render: function (row) { var _a; return (_a = (0, numbers_1.formatPercentage)(row[key])) !== null && _a !== void 0 ? _a : ''; },
191
+ excelOptions: {
192
+ formatter: function () { return (0, helpers_1.buildExcelFormat)(decimals, '%'); },
193
+ valueGetter: function (value) { return (0, numbers_1.formatNumberInvariant)(value, decimals); },
194
+ },
195
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
196
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : 0; },
197
+ filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : 0; }, renderer: function (value) { var _a; return (_a = (0, numbers_1.formatPercentage)(value, decimals)) !== null && _a !== void 0 ? _a : ''; } }),
198
+ editComponent: (0, react_1.forwardRef)(function (props, ref) { return ((0, jsx_runtime_1.jsx)(NumberEditableCell_1.NumberEditableCell, __assign({ ref: ref, decimals: column.decimals, currency: column.currency }, props))); }),
199
+ };
200
+ return (0, lodash_1.merge)(column, options);
113
201
  };
114
202
  exports.sqlPercentageColumn = sqlPercentageColumn;
115
203
  var sqlCheckboxColumn = function (key, title, options) {
116
- var _a;
117
- return (_a = {},
118
- _a[key] = __assign({ name: title, render: function (row) {
119
- var _a;
120
- var value = !!+((_a = row[key]) !== null && _a !== void 0 ? _a : 0);
121
- return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: value, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { children: value ? ' Oui' : ' Non' })] }));
122
- }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return +((_a = value[key]) !== null && _a !== void 0 ? _a : 0); } }), footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); } }, options),
123
- _a);
204
+ return (0, lodash_1.merge)({
205
+ key: key,
206
+ name: title,
207
+ type: 'checkbox',
208
+ render: function (row) {
209
+ var _a;
210
+ var value = !!+((_a = row[key]) !== null && _a !== void 0 ? _a : 0);
211
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: value, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { children: value ? ' Oui' : ' Non' })] }));
212
+ },
213
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
214
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
215
+ filter: __assign(__assign({}, (0, helpers_1.numberFilter)(key)), { getter: function (value) { var _a; return +((_a = value[key]) !== null && _a !== void 0 ? _a : 0); } }),
216
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
217
+ editComponent: CheckboxEditableCell_1.CheckboxEditableCell,
218
+ }, options);
124
219
  };
125
220
  exports.sqlCheckboxColumn = sqlCheckboxColumn;
221
+ var sqlImageColumn = function (key, title, urlPrefix, options) {
222
+ return (0, lodash_1.merge)({
223
+ key: key,
224
+ type: 'text',
225
+ name: title,
226
+ render: function (row) { return ((0, jsx_runtime_1.jsx)(styles_1.SqlImageWrapper, { children: (0, jsx_runtime_1.jsx)(styles_1.SqlImage, { src: row[key] ? "".concat(urlPrefix).concat(row[key]) : "".concat(urlPrefix, "no-image.png"), alt: title }) })); },
227
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
228
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
229
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
230
+ }, options);
231
+ };
232
+ exports.sqlImageColumn = sqlImageColumn;
126
233
  var sqlColorColumn = function (key, title, options) {
127
- var _a;
128
- return (_a = {},
129
- _a[key] = __assign({ name: title, render: function (row) { return ((0, jsx_runtime_1.jsx)("div", { style: { position: 'absolute', inset: 0, backgroundColor: row[key] }, children: "\u00A0" })); }, excelValue: function () { return ''; }, excelBackgroundColor: function (value) { return value; }, getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; }, filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, renderer: function (value) { return ((0, jsx_runtime_1.jsx)("div", { style: {
130
- backgroundColor: value,
131
- width: 'var(--space-16)',
132
- height: '1em',
133
- }, children: "\u00A0" })); } }) }, options),
134
- _a);
234
+ return (0, lodash_1.merge)({
235
+ key: key,
236
+ type: 'text',
237
+ name: title,
238
+ render: function (row) { return ((0, jsx_runtime_1.jsx)("div", { style: { position: 'absolute', inset: 0, backgroundColor: row[key] }, children: "\u00A0" })); },
239
+ excelOptions: {
240
+ valueGetter: function () { return ''; },
241
+ colorGetter: function (value) { return value; },
242
+ },
243
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
244
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
245
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, renderer: function (value) { return ((0, jsx_runtime_1.jsx)("div", { style: {
246
+ backgroundColor: value,
247
+ width: 'var(--space-16)',
248
+ height: '1em',
249
+ }, children: "\u00A0" })); } }),
250
+ }, options);
135
251
  };
136
252
  exports.sqlColorColumn = sqlColorColumn;
253
+ var convertRowToItem = function (row, columnMapping) { return (0, lodash_1.mapKeys)(row, function (_, key) { return columnMapping[key]; }); };
254
+ var convertItemToPartialRow = function (row, item, columnMapping) {
255
+ var partialRow = {};
256
+ Object.entries(columnMapping).forEach(function (_a) {
257
+ var _b;
258
+ var key = _a[0], value = _a[1];
259
+ partialRow[key] = ((_b = item === null || item === void 0 ? void 0 : item[value]) !== null && _b !== void 0 ? _b : null);
260
+ });
261
+ return partialRow;
262
+ };
263
+ var sqlForeignListColumn = function (key, columnMapping, title, requestName, ItemTemplate, options) {
264
+ var column = {
265
+ key: key,
266
+ name: title,
267
+ type: 'foreignList',
268
+ getter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
269
+ sortGetter: function (row) { var _a; return (_a = row[key]) !== null && _a !== void 0 ? _a : ''; },
270
+ render: function (row) { return ((0, jsx_runtime_1.jsx)(ItemTemplate, { item: convertRowToItem(row, columnMapping), index: 0 })); },
271
+ filter: __assign(__assign({}, (0, helpers_1.textFilter)(key)), { getter: function (value) { var _a; return (_a = value[key]) !== null && _a !== void 0 ? _a : ''; }, renderer: function (value) { return value; } }),
272
+ footer: function (rows) { return "".concat(rows[0][key], " \u00E9l\u00E9ments"); },
273
+ requestName: requestName,
274
+ idColumn: 'Id',
275
+ itemTemplate: ItemTemplate,
276
+ columns: Object.values(columnMapping),
277
+ editComponent: (0, react_1.forwardRef)(function (_a, ref) {
278
+ var row = _a.row, onChange = _a.onChange, onClose = _a.onClose, context = _a.context;
279
+ var _b = (0, react_1.useContext)(context).rowHeight, rowHeight = _b === void 0 ? constants_1.DEFAULT_ROW_HEIGHT : _b;
280
+ return ((0, jsx_runtime_1.jsx)(SqlRequestForeignList_1.SqlRequestForeignList, { initialValue: convertRowToItem(row, columnMapping), maxRows: 10, rowHeight: rowHeight - 2, onItemChanged: onChange, onBlur: function () { return onClose(true); }, ref: ref, requestName: column.requestName, idColumn: column.idColumn, columns: column.columns, itemTemplate: column.itemTemplate, valueTemplate: column.valueTemplate }));
281
+ }),
282
+ itemToPartialRow: function (row, value) {
283
+ return convertItemToPartialRow(row, value, columnMapping);
284
+ },
285
+ };
286
+ return (0, lodash_1.merge)(column, options);
287
+ };
288
+ exports.sqlForeignListColumn = sqlForeignListColumn;