@digigov/react-modules 1.2.0-2177f152 → 1.2.0-2271444d

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 (97) hide show
  1. package/Faq/Results.d.ts +9 -0
  2. package/Faq/Results.js +34 -0
  3. package/Faq/hooks.d.ts +15 -0
  4. package/Faq/hooks.js +54 -0
  5. package/Faq/index.d.ts +43 -0
  6. package/Faq/index.js +197 -0
  7. package/Faq/slug.d.ts +1 -0
  8. package/Faq/slug.js +94 -0
  9. package/Faq/utils.d.ts +1 -0
  10. package/Faq/utils.js +3 -0
  11. package/FilteredResults/DataTable.js +12 -0
  12. package/FilteredResults/FilterChips.js +34 -0
  13. package/FilteredResults/FilterFields.js +13 -0
  14. package/FilteredResults/hooks.d.ts +1 -1
  15. package/FilteredResults/hooks.js +78 -0
  16. package/FilteredResults/index.js +96 -112
  17. package/index.d.ts +2 -1
  18. package/index.js +3 -3
  19. package/lazy.d.ts +13 -12
  20. package/lazy.js +28 -0
  21. package/package.json +32 -13
  22. package/registry.d.ts +6 -1
  23. package/registry.js +34 -0
  24. package/src/Faq/Faq.stories.js +7 -0
  25. package/src/Faq/Results.tsx +53 -0
  26. package/src/Faq/__stories__/Default.tsx +292 -0
  27. package/src/Faq/hooks.ts +89 -0
  28. package/src/Faq/index.test.tsx +24 -0
  29. package/src/Faq/index.tsx +286 -0
  30. package/src/Faq/slug.ts +140 -0
  31. package/src/Faq/splitted.test.tsx +19 -0
  32. package/src/Faq/utils.ts +5 -0
  33. package/src/FilteredResults/__stories__/Default.tsx +1 -1
  34. package/src/FilteredResults/index.test.tsx +14 -11
  35. package/src/FilteredResults/splitted.test.tsx +9 -5
  36. package/src/index.ts +1 -0
  37. package/src/lazy.ts +11 -0
  38. package/src/registry.ts +43 -0
  39. package/FilteredResults/DataTable/index.js +0 -18
  40. package/FilteredResults/DataTable/package.json +0 -6
  41. package/FilteredResults/DataTable.js.map +0 -7
  42. package/FilteredResults/FilterChips/index.js +0 -52
  43. package/FilteredResults/FilterChips/package.json +0 -6
  44. package/FilteredResults/FilterChips.js.map +0 -7
  45. package/FilteredResults/FilterFields/index.js +0 -11
  46. package/FilteredResults/FilterFields/package.json +0 -6
  47. package/FilteredResults/FilterFields.js.map +0 -7
  48. package/FilteredResults/FilteredResults.stories/index.js +0 -12
  49. package/FilteredResults/FilteredResults.stories/package.json +0 -6
  50. package/FilteredResults/FilteredResults.stories.d.ts +0 -8
  51. package/FilteredResults/FilteredResults.stories.js.map +0 -7
  52. package/FilteredResults/__stories__/Default/index.js +0 -220
  53. package/FilteredResults/__stories__/Default/package.json +0 -6
  54. package/FilteredResults/__stories__/Default.d.ts +0 -2
  55. package/FilteredResults/__stories__/Default.js.map +0 -7
  56. package/FilteredResults/hooks/index.js +0 -105
  57. package/FilteredResults/hooks/package.json +0 -6
  58. package/FilteredResults/hooks.js.map +0 -7
  59. package/FilteredResults/index.js.map +0 -7
  60. package/FilteredResults/index.test.d.ts +0 -1
  61. package/FilteredResults/package.json +0 -6
  62. package/FilteredResults/splitted.test.d.ts +0 -1
  63. package/ReactModules.stories/index.js +0 -7
  64. package/ReactModules.stories/package.json +0 -6
  65. package/ReactModules.stories.d.ts +0 -4
  66. package/ReactModules.stories.js.map +0 -7
  67. package/cjs/FilteredResults/DataTable/index.js +0 -42
  68. package/cjs/FilteredResults/DataTable.js.map +0 -7
  69. package/cjs/FilteredResults/FilterChips/index.js +0 -82
  70. package/cjs/FilteredResults/FilterChips.js.map +0 -7
  71. package/cjs/FilteredResults/FilterFields/index.js +0 -44
  72. package/cjs/FilteredResults/FilterFields.js.map +0 -7
  73. package/cjs/FilteredResults/FilteredResults.stories/index.js +0 -45
  74. package/cjs/FilteredResults/FilteredResults.stories.js.map +0 -7
  75. package/cjs/FilteredResults/__stories__/Default/index.js +0 -250
  76. package/cjs/FilteredResults/__stories__/Default.js.map +0 -7
  77. package/cjs/FilteredResults/hooks/index.js +0 -132
  78. package/cjs/FilteredResults/hooks.js.map +0 -7
  79. package/cjs/FilteredResults/index.js +0 -153
  80. package/cjs/FilteredResults/index.js.map +0 -7
  81. package/cjs/ReactModules.stories/index.js +0 -26
  82. package/cjs/ReactModules.stories.js.map +0 -7
  83. package/cjs/index.js +0 -22
  84. package/cjs/index.js.map +0 -7
  85. package/cjs/lazy/index.js +0 -71
  86. package/cjs/lazy.js.map +0 -7
  87. package/cjs/registry/index.js +0 -73
  88. package/cjs/registry.js.map +0 -7
  89. package/index.js.map +0 -7
  90. package/lazy/index.js +0 -42
  91. package/lazy/package.json +0 -6
  92. package/lazy.js.map +0 -7
  93. package/registry/index.js +0 -44
  94. package/registry/package.json +0 -6
  95. package/registry.js.map +0 -7
  96. package/src/lazy.js +0 -38
  97. package/src/registry.js +0 -41
@@ -1,82 +0,0 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
- var FilterChips_exports = {};
29
- __export(FilterChips_exports, {
30
- FilterChips: () => FilterChips,
31
- default: () => FilterChips_default
32
- });
33
- module.exports = __toCommonJS(FilterChips_exports);
34
- var import_react = __toESM(require("react"));
35
- var import_FormBuilder = require("@digigov/form/FormBuilder");
36
- var import_hooks = require("@digigov/react-modules/FilteredResults/hooks");
37
- var import_FilterContainer = require("@digigov/ui/app/FilterContainer");
38
- var import_Chip = require("@digigov/ui/content/Chip");
39
- var import_Button = require("@digigov/ui/form/Button");
40
- const FilterChips = () => {
41
- const { fieldsMap, reset, resetField, submit } = (0, import_FormBuilder.useFormContext)();
42
- const values = (0, import_FormBuilder.useFormValues)();
43
- const enabledFilters = Object.keys(values).filter((v) => values[v]);
44
- if (enabledFilters.length === 0) return null;
45
- return /* @__PURE__ */ import_react.default.createElement(import_FilterContainer.FilterSelectedSection, { m: 0, mb: 6 }, /* @__PURE__ */ import_react.default.createElement(import_FilterContainer.FilterSelectedHeading, { mb: 0 }, /* @__PURE__ */ import_react.default.createElement(import_Chip.ChipContainer, null, enabledFilters.map((filterKey) => {
46
- return /* @__PURE__ */ import_react.default.createElement(
47
- import_Chip.Chip,
48
- {
49
- mb: 0,
50
- key: filterKey,
51
- onDelete: () => {
52
- resetField(filterKey);
53
- submit();
54
- }
55
- },
56
- /* @__PURE__ */ import_react.default.createElement("b", null, fieldsMap[filterKey].label?.primary),
57
- " ",
58
- ": ",
59
- (0, import_hooks.getOptionLabelForSelectValue)(
60
- fieldsMap[filterKey],
61
- values[filterKey]
62
- )
63
- );
64
- })), /* @__PURE__ */ import_react.default.createElement(
65
- import_Button.Button,
66
- {
67
- onClick: (e) => {
68
- e.preventDefault();
69
- reset();
70
- submit();
71
- },
72
- variant: "link"
73
- },
74
- "\u0395\u03C0\u03B1\u03BD\u03B1\u03C6\u03BF\u03C1\u03AC \u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03CE\u03BD"
75
- )));
76
- };
77
- var FilterChips_default = FilterChips;
78
- // Annotate the CommonJS export names for ESM import in node:
79
- 0 && (module.exports = {
80
- FilterChips
81
- });
82
- //# sourceMappingURL=FilterChips.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/FilteredResults/FilterChips.tsx"],
4
- "sourcesContent": ["import React from 'react';\nimport { useFormContext, useFormValues } from '@digigov/form/FormBuilder';\nimport { getOptionLabelForSelectValue } from '@digigov/react-modules/FilteredResults/hooks';\nimport {\n FilterSelectedHeading,\n FilterSelectedSection,\n} from '@digigov/ui/app/FilterContainer';\nimport { Chip, ChipContainer } from '@digigov/ui/content/Chip';\nimport { Button } from '@digigov/ui/form/Button';\n\nexport const FilterChips = () => {\n const { fieldsMap, reset, resetField, submit } = useFormContext();\n const values = useFormValues();\n const enabledFilters = Object.keys(values).filter((v) => values[v]);\n if (enabledFilters.length === 0) return null;\n return (\n <FilterSelectedSection m={0} mb={6}>\n <FilterSelectedHeading mb={0}>\n <ChipContainer>\n {enabledFilters.map((filterKey) => {\n return (\n <Chip\n mb={0}\n key={filterKey}\n onDelete={() => {\n resetField(filterKey);\n submit();\n }}\n >\n <b>{fieldsMap[filterKey].label?.primary}</b> {': '}\n {getOptionLabelForSelectValue(\n fieldsMap[filterKey],\n values[filterKey]\n )}\n </Chip>\n );\n })}\n </ChipContainer>\n <Button\n onClick={(e) => {\n e.preventDefault();\n reset();\n submit();\n }}\n variant=\"link\"\n >\n \u0395\u03C0\u03B1\u03BD\u03B1\u03C6\u03BF\u03C1\u03AC \u0395\u03C0\u03B9\u03BB\u03BF\u03B3\u03CE\u03BD\n </Button>\n </FilterSelectedHeading>\n </FilterSelectedSection>\n );\n};\n\nexport default FilterChips;\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAClB,yBAA8C;AAC9C,mBAA6C;AAC7C,6BAGO;AACP,kBAAoC;AACpC,oBAAuB;AAEhB,MAAM,cAAc,MAAM;AAC/B,QAAM,EAAE,WAAW,OAAO,YAAY,OAAO,QAAI,mCAAe;AAChE,QAAM,aAAS,kCAAc;AAC7B,QAAM,iBAAiB,OAAO,KAAK,MAAM,EAAE,OAAO,CAAC,MAAM,OAAO,CAAC,CAAC;AAClE,MAAI,eAAe,WAAW,EAAG,QAAO;AACxC,SACE,6BAAAA,QAAA,cAAC,gDAAsB,GAAG,GAAG,IAAI,KAC/B,6BAAAA,QAAA,cAAC,gDAAsB,IAAI,KACzB,6BAAAA,QAAA,cAAC,iCACE,eAAe,IAAI,CAAC,cAAc;AACjC,WACE,6BAAAA,QAAA;AAAA,MAAC;AAAA;AAAA,QACC,IAAI;AAAA,QACJ,KAAK;AAAA,QACL,UAAU,MAAM;AACd,qBAAW,SAAS;AACpB,iBAAO;AAAA,QACT;AAAA;AAAA,MAEA,6BAAAA,QAAA,cAAC,WAAG,UAAU,SAAS,EAAE,OAAO,OAAQ;AAAA,MAAI;AAAA,MAAE;AAAA,UAC7C;AAAA,QACC,UAAU,SAAS;AAAA,QACnB,OAAO,SAAS;AAAA,MAClB;AAAA,IACF;AAAA,EAEJ,CAAC,CACH,GACA,6BAAAA,QAAA;AAAA,IAAC;AAAA;AAAA,MACC,SAAS,CAAC,MAAM;AACd,UAAE,eAAe;AACjB,cAAM;AACN,eAAO;AAAA,MACT;AAAA,MACA,SAAQ;AAAA;AAAA,IACT;AAAA,EAED,CACF,CACF;AAEJ;AAEA,IAAO,sBAAQ;",
6
- "names": ["React"]
7
- }
@@ -1,44 +0,0 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
- var FilterFields_exports = {};
29
- __export(FilterFields_exports, {
30
- FilterFields: () => FilterFields
31
- });
32
- module.exports = __toCommonJS(FilterFields_exports);
33
- var import_react = __toESM(require("react"));
34
- var import_Field = __toESM(require("@digigov/form/Field"));
35
- var import_FilterContainer = require("@digigov/ui/app/FilterContainer");
36
- var import_Button = require("@digigov/ui/form/Button");
37
- const FilterFields = ({ fields, horizontal }) => {
38
- return /* @__PURE__ */ import_react.default.createElement(import_FilterContainer.FilterOptionsSection, { horizontal }, fields.map((field) => /* @__PURE__ */ import_react.default.createElement(import_Field.default, { key: field.key, name: field.key })), /* @__PURE__ */ import_react.default.createElement(import_Button.Button, { type: "submit" }, "\u0391\u03BD\u03B1\u03B6\u03AE\u03C4\u03B7\u03C3\u03B7"));
39
- };
40
- // Annotate the CommonJS export names for ESM import in node:
41
- 0 && (module.exports = {
42
- FilterFields
43
- });
44
- //# sourceMappingURL=FilterFields.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/FilteredResults/FilterFields.tsx"],
4
- "sourcesContent": ["import React from 'react';\nimport Field from '@digigov/form/Field';\nimport { FilterOptionsSection } from '@digigov/ui/app/FilterContainer';\nimport { Button } from '@digigov/ui/form/Button';\n\nexport const FilterFields = ({ fields, horizontal }) => {\n return (\n <FilterOptionsSection horizontal={horizontal}>\n {fields.map((field) => (\n <Field key={field.key} name={field.key} />\n ))}\n <Button type=\"submit\">\u0391\u03BD\u03B1\u03B6\u03AE\u03C4\u03B7\u03C3\u03B7</Button>\n </FilterOptionsSection>\n );\n};\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAAkB;AAClB,mBAAkB;AAClB,6BAAqC;AACrC,oBAAuB;AAEhB,MAAM,eAAe,CAAC,EAAE,QAAQ,WAAW,MAAM;AACtD,SACE,6BAAAA,QAAA,cAAC,+CAAqB,cACnB,OAAO,IAAI,CAAC,UACX,6BAAAA,QAAA,cAAC,aAAAC,SAAA,EAAM,KAAK,MAAM,KAAK,MAAM,MAAM,KAAK,CACzC,GACD,6BAAAD,QAAA,cAAC,wBAAO,MAAK,YAAS,wDAAS,CACjC;AAEJ;",
6
- "names": ["React", "Field"]
7
- }
@@ -1,45 +0,0 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
- var FilteredResults_stories_exports = {};
29
- __export(FilteredResults_stories_exports, {
30
- Default: () => import_Default.Default,
31
- default: () => FilteredResults_stories_default
32
- });
33
- module.exports = __toCommonJS(FilteredResults_stories_exports);
34
- var import_FilteredResults = __toESM(require("@digigov/react-modules/FilteredResults"));
35
- var import_Default = require("@digigov/react-modules/FilteredResults/__stories__/Default");
36
- var FilteredResults_stories_default = {
37
- title: "Digigov React Modules/FilteredResults",
38
- component: import_FilteredResults.default,
39
- displayName: "FilteredResults"
40
- };
41
- // Annotate the CommonJS export names for ESM import in node:
42
- 0 && (module.exports = {
43
- Default
44
- });
45
- //# sourceMappingURL=FilteredResults.stories.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/FilteredResults/FilteredResults.stories.js"],
4
- "sourcesContent": ["import FilteredResults from '@digigov/react-modules/FilteredResults';\nexport default {\n title: 'Digigov React Modules/FilteredResults',\n component: FilteredResults,\n displayName: 'FilteredResults',\n};\nexport { Default } from '@digigov/react-modules/FilteredResults/__stories__/Default';\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6BAA4B;AAM5B,qBAAwB;AALxB,IAAO,kCAAQ;AAAA,EACb,OAAO;AAAA,EACP,WAAW,uBAAAA;AAAA,EACX,aAAa;AACf;",
6
- "names": ["FilteredResults"]
7
- }
@@ -1,250 +0,0 @@
1
- var __create = Object.create;
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
- // If the importer is in node compatibility mode or this is not an ESM
21
- // file that has been converted to a CommonJS file using a Babel-
22
- // compatible transform (i.e. "__esModule" has not been set), then set
23
- // "default" to the CommonJS "module.exports" for node compatibility.
24
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
- mod
26
- ));
27
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
- var Default_exports = {};
29
- __export(Default_exports, {
30
- Default: () => Default
31
- });
32
- module.exports = __toCommonJS(Default_exports);
33
- var import_react = __toESM(require("react"));
34
- var import_FilteredResults = __toESM(require("@digigov/react-modules/FilteredResults"));
35
- var import_DataTable = require("@digigov/react-modules/FilteredResults/DataTable");
36
- var import_hooks = require("@digigov/react-modules/FilteredResults/hooks");
37
- var import_icons = require("@digigov/ui/icons");
38
- var import_Link = __toESM(require("@digigov/ui/navigation/Link"));
39
- const fields = [
40
- {
41
- type: "string",
42
- key: "text",
43
- label: {
44
- primary: "\u0391\u03BD\u03B1\u03B6\u03AE\u03C4\u03B7\u03C3\u03B7 \u03BB\u03AD\u03BE\u03B7\u03C2"
45
- }
46
- },
47
- {
48
- type: "choice:single",
49
- key: "name",
50
- label: {
51
- primary: "\u038C\u03BD\u03BF\u03BC\u03B1"
52
- },
53
- extra: {
54
- component: "Select",
55
- options: [
56
- {
57
- label: {
58
- primary: ""
59
- },
60
- value: ""
61
- },
62
- {
63
- label: {
64
- primary: "\u039A\u03B1\u03BB\u03BB\u03B9\u03CC\u03C0\u03B7 \u03A0\u03B1\u03C0\u03B1\u03B4\u03BF\u03C0\u03BF\u03CD\u03BB\u03BF\u03C5"
65
- },
66
- value: "Kalliopi Papadopoulou"
67
- },
68
- {
69
- label: {
70
- primary: "\u039C\u03AC\u03C1\u03B9\u03BF\u03C2 \u039C\u03B5\u03BD\u03B5\u03BE\u03AD\u03C2"
71
- },
72
- value: "Marios Menekses"
73
- },
74
- {
75
- label: {
76
- primary: "\u039C\u03B1\u03C1\u03AF\u03B1 \u03A6\u03BB\u03BF\u03CD\u03C0\u03B7"
77
- },
78
- value: "Maria Floupi"
79
- },
80
- {
81
- label: {
82
- primary: "\u0397\u03BB\u03AD\u03BA\u03C4\u03C1\u03B1 \u0391\u03C0\u03BF\u03C3\u03C4\u03CC\u03BB\u03BF\u03C5"
83
- },
84
- value: "Ilektra Apostolou"
85
- }
86
- ]
87
- }
88
- },
89
- {
90
- type: "choice:single",
91
- key: "role",
92
- label: {
93
- primary: "\u03A1\u03CC\u03BB\u03BF\u03C2"
94
- },
95
- extra: {
96
- component: "Select",
97
- options: [
98
- {
99
- label: {
100
- primary: ""
101
- },
102
- value: ""
103
- },
104
- {
105
- label: {
106
- primary: "\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2"
107
- },
108
- value: "admin"
109
- },
110
- {
111
- label: {
112
- primary: "\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2"
113
- },
114
- value: "user"
115
- }
116
- ]
117
- }
118
- },
119
- {
120
- type: "choice:single",
121
- key: "rights",
122
- label: {
123
- primary: "\u0394\u03B9\u03BA\u03B1\u03B9\u03CE\u03BC\u03B1\u03C4\u03B1"
124
- },
125
- extra: {
126
- component: "Select",
127
- options: [
128
- {
129
- label: {
130
- primary: ""
131
- },
132
- value: ""
133
- },
134
- {
135
- label: {
136
- primary: "\u039D\u03B1\u03B9"
137
- },
138
- value: true
139
- },
140
- {
141
- label: {
142
- primary: "\u038C\u03C7\u03B9"
143
- },
144
- value: false
145
- }
146
- ]
147
- }
148
- }
149
- ];
150
- const displayLink = (value) => {
151
- return /* @__PURE__ */ import_react.default.createElement(import_Link.default, { href: `#/${value}` }, value);
152
- };
153
- const displayRights = (value) => {
154
- return /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, value ? /* @__PURE__ */ import_react.default.createElement(import_icons.CheckIcon, null) : /* @__PURE__ */ import_react.default.createElement(import_icons.UncheckIcon, null));
155
- };
156
- const data = [
157
- {
158
- name: "\u039C\u03AC\u03C1\u03B9\u03BF\u03C2 \u039C\u03B5\u03BD\u03B5\u03BE\u03AD\u03C2",
159
- case_id: 123,
160
- role: "\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2",
161
- email: "marios@mail.com",
162
- rights: false
163
- },
164
- {
165
- name: "\u039A\u03B1\u03BB\u03BB\u03B9\u03CC\u03C0\u03B7 \u03A0\u03B1\u03C0\u03B1\u03B4\u03BF\u03C0\u03BF\u03CD\u03BB\u03BF\u03C5",
166
- case_id: 124,
167
- role: "\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2",
168
- email: "kalliopi@mail.com",
169
- rights: false
170
- },
171
- {
172
- name: "\u039C\u03B1\u03C1\u03AF\u03B1 \u03A6\u03BB\u03BF\u03CD\u03C0\u03B7",
173
- case_id: 125,
174
- role: "\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2",
175
- email: "maria@mail.com",
176
- rights: true
177
- },
178
- {
179
- name: "\u0397\u03BB\u03AD\u03BA\u03C4\u03C1\u03B1 \u0391\u03C0\u03BF\u03C3\u03C4\u03CC\u03BB\u03BF\u03C5",
180
- case_id: 126,
181
- role: "\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2",
182
- email: "ilektra@mail.com",
183
- rights: true
184
- }
185
- ];
186
- const dataConfig = [
187
- {
188
- key: "name",
189
- title: "\u038C\u03BD\u03BF\u03BC\u03B1"
190
- },
191
- {
192
- key: "case_id",
193
- title: "\u0391\u03C1. \u03A5\u03C0\u03CC\u03B8\u03B5\u03C3\u03B7\u03C2",
194
- displayComponent: displayLink
195
- },
196
- {
197
- key: "role",
198
- title: "\u03A1\u03CC\u03BB\u03BF\u03C2"
199
- },
200
- {
201
- key: "email",
202
- title: "Email"
203
- },
204
- {
205
- key: "rights",
206
- title: "\u0394\u03B9\u03BA\u03B1\u03B9\u03CE\u03BC\u03B1\u03C4\u03B1",
207
- displayComponent: displayRights
208
- }
209
- ];
210
- const initialFilters = {
211
- name: "",
212
- case_id: "",
213
- role: "",
214
- text: "",
215
- rights: ""
216
- };
217
- const Default = () => {
218
- const { search, results } = (0, import_hooks.useStaticSearch)({
219
- fields,
220
- data,
221
- initialFilters
222
- });
223
- const navigate = (url) => {
224
- if (window.history.pushState) {
225
- const newUrl = window.location.protocol + "//" + window.location.host + window.location.pathname + url;
226
- window.history.pushState({ path: newUrl }, "", newUrl);
227
- }
228
- };
229
- const { search: urlSearch, values } = (0, import_hooks.useURLParamsSearch)(search, {
230
- navigate,
231
- fields
232
- });
233
- return /* @__PURE__ */ import_react.default.createElement(
234
- import_FilteredResults.default,
235
- {
236
- data: results,
237
- variant: "block",
238
- currentFilters: values,
239
- defaultFilters: initialFilters,
240
- fields,
241
- onSearch: urlSearch
242
- },
243
- /* @__PURE__ */ import_react.default.createElement(import_DataTable.DataTable, { dataConfig, data: results })
244
- );
245
- };
246
- // Annotate the CommonJS export names for ESM import in node:
247
- 0 && (module.exports = {
248
- Default
249
- });
250
- //# sourceMappingURL=Default.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/FilteredResults/__stories__/Default.tsx"],
4
- "sourcesContent": ["import React from 'react';\nimport { FieldSpec } from '@digigov/form/types';\nimport FilteredResults, {\n DataConfigType,\n} from '@digigov/react-modules/FilteredResults';\nimport { DataTable } from '@digigov/react-modules/FilteredResults/DataTable';\nimport {\n useURLParamsSearch,\n useStaticSearch,\n} from '@digigov/react-modules/FilteredResults/hooks';\nimport { CheckIcon, UncheckIcon } from '@digigov/ui/icons';\nimport Link from '@digigov/ui/navigation/Link';\n\nconst fields: FieldSpec[] = [\n {\n type: 'string',\n key: 'text',\n label: {\n primary: '\u0391\u03BD\u03B1\u03B6\u03AE\u03C4\u03B7\u03C3\u03B7 \u03BB\u03AD\u03BE\u03B7\u03C2',\n },\n },\n {\n type: 'choice:single',\n key: 'name',\n label: {\n primary: '\u038C\u03BD\u03BF\u03BC\u03B1',\n },\n extra: {\n component: 'Select',\n options: [\n {\n label: {\n primary: '',\n },\n value: '',\n },\n {\n label: {\n primary: '\u039A\u03B1\u03BB\u03BB\u03B9\u03CC\u03C0\u03B7 \u03A0\u03B1\u03C0\u03B1\u03B4\u03BF\u03C0\u03BF\u03CD\u03BB\u03BF\u03C5',\n },\n value: 'Kalliopi Papadopoulou',\n },\n {\n label: {\n primary: '\u039C\u03AC\u03C1\u03B9\u03BF\u03C2 \u039C\u03B5\u03BD\u03B5\u03BE\u03AD\u03C2',\n },\n value: 'Marios Menekses',\n },\n {\n label: {\n primary: '\u039C\u03B1\u03C1\u03AF\u03B1 \u03A6\u03BB\u03BF\u03CD\u03C0\u03B7',\n },\n value: 'Maria Floupi',\n },\n {\n label: {\n primary: '\u0397\u03BB\u03AD\u03BA\u03C4\u03C1\u03B1 \u0391\u03C0\u03BF\u03C3\u03C4\u03CC\u03BB\u03BF\u03C5',\n },\n value: 'Ilektra Apostolou',\n },\n ],\n },\n },\n {\n type: 'choice:single',\n key: 'role',\n label: {\n primary: '\u03A1\u03CC\u03BB\u03BF\u03C2',\n },\n extra: {\n component: 'Select',\n options: [\n {\n label: {\n primary: '',\n },\n value: '',\n },\n {\n label: {\n primary: '\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n },\n value: 'admin',\n },\n {\n label: {\n primary: '\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n },\n value: 'user',\n },\n ],\n },\n },\n {\n type: 'choice:single',\n key: 'rights',\n label: {\n primary: '\u0394\u03B9\u03BA\u03B1\u03B9\u03CE\u03BC\u03B1\u03C4\u03B1',\n },\n extra: {\n component: 'Select',\n options: [\n {\n label: {\n primary: '',\n },\n value: '',\n },\n {\n label: {\n primary: '\u039D\u03B1\u03B9',\n },\n value: true,\n },\n {\n label: {\n primary: '\u038C\u03C7\u03B9',\n },\n value: false,\n },\n ],\n },\n },\n];\n\nconst displayLink = (value) => {\n return <Link href={`#/${value}`}>{value}</Link>;\n};\nconst displayRights = (value) => {\n return <>{value ? <CheckIcon /> : <UncheckIcon />}</>;\n};\n\ninterface DataType {\n name: string;\n case_id: number;\n role: string;\n email: string;\n rights: boolean;\n}\n\nconst data: DataType[] = [\n {\n name: '\u039C\u03AC\u03C1\u03B9\u03BF\u03C2 \u039C\u03B5\u03BD\u03B5\u03BE\u03AD\u03C2',\n case_id: 123,\n role: '\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n email: 'marios@mail.com',\n rights: false,\n },\n {\n name: '\u039A\u03B1\u03BB\u03BB\u03B9\u03CC\u03C0\u03B7 \u03A0\u03B1\u03C0\u03B1\u03B4\u03BF\u03C0\u03BF\u03CD\u03BB\u03BF\u03C5',\n case_id: 124,\n role: '\u03A7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n email: 'kalliopi@mail.com',\n rights: false,\n },\n {\n name: '\u039C\u03B1\u03C1\u03AF\u03B1 \u03A6\u03BB\u03BF\u03CD\u03C0\u03B7',\n case_id: 125,\n role: '\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n email: 'maria@mail.com',\n rights: true,\n },\n {\n name: '\u0397\u03BB\u03AD\u03BA\u03C4\u03C1\u03B1 \u0391\u03C0\u03BF\u03C3\u03C4\u03CC\u03BB\u03BF\u03C5',\n case_id: 126,\n role: '\u0394\u03B9\u03B1\u03C7\u03B5\u03B9\u03C1\u03B9\u03C3\u03C4\u03AE\u03C2',\n email: 'ilektra@mail.com',\n rights: true,\n },\n];\n\nconst dataConfig: DataConfigType[] = [\n {\n key: 'name',\n title: '\u038C\u03BD\u03BF\u03BC\u03B1',\n },\n {\n key: 'case_id',\n title: '\u0391\u03C1. \u03A5\u03C0\u03CC\u03B8\u03B5\u03C3\u03B7\u03C2',\n displayComponent: displayLink,\n },\n {\n key: 'role',\n title: '\u03A1\u03CC\u03BB\u03BF\u03C2',\n },\n {\n key: 'email',\n title: 'Email',\n },\n {\n key: 'rights',\n title: '\u0394\u03B9\u03BA\u03B1\u03B9\u03CE\u03BC\u03B1\u03C4\u03B1',\n displayComponent: displayRights,\n },\n];\n\ntype InitialFiltersType = Record<(typeof dataConfig)[number]['key'], string>;\n\nconst initialFilters: InitialFiltersType = {\n name: '',\n case_id: '',\n role: '',\n text: '',\n rights: '',\n};\n\nexport const Default = () => {\n const { search, results } = useStaticSearch<\n Record<string, any>,\n InitialFiltersType\n >({\n fields,\n data,\n initialFilters,\n });\n const navigate = (url) => {\n if (window.history.pushState) {\n const newUrl =\n window.location.protocol +\n '//' +\n window.location.host +\n window.location.pathname +\n url;\n window.history.pushState({ path: newUrl }, '', newUrl);\n }\n };\n const { search: urlSearch, values } = useURLParamsSearch(search, {\n navigate,\n fields,\n });\n\n return (\n <FilteredResults\n data={results}\n variant=\"block\"\n currentFilters={values}\n defaultFilters={initialFilters}\n fields={fields}\n onSearch={urlSearch}\n >\n <DataTable dataConfig={dataConfig} data={results} />\n </FilteredResults>\n );\n};\n"],
5
- "mappings": "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",
6
- "names": ["React", "Link", "FilteredResults"]
7
- }
@@ -1,132 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
- var __getOwnPropNames = Object.getOwnPropertyNames;
4
- var __hasOwnProp = Object.prototype.hasOwnProperty;
5
- var __export = (target, all) => {
6
- for (var name in all)
7
- __defProp(target, name, { get: all[name], enumerable: true });
8
- };
9
- var __copyProps = (to, from, except, desc) => {
10
- if (from && typeof from === "object" || typeof from === "function") {
11
- for (let key of __getOwnPropNames(from))
12
- if (!__hasOwnProp.call(to, key) && key !== except)
13
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
- }
15
- return to;
16
- };
17
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
- var hooks_exports = {};
19
- __export(hooks_exports, {
20
- getOptionLabelForSelectValue: () => getOptionLabelForSelectValue,
21
- isBooleanString: () => isBooleanString,
22
- normalizeText: () => normalizeText,
23
- useStaticSearch: () => useStaticSearch,
24
- useURLParamsSearch: () => useURLParamsSearch
25
- });
26
- module.exports = __toCommonJS(hooks_exports);
27
- var import_react = require("react");
28
- function isBooleanString(str) {
29
- return /^(true|false)$/i.test(str);
30
- }
31
- function normalizeText(text) {
32
- return text.normalize("NFD").replace(/[\u0300-\u036f]/g, "");
33
- }
34
- const getOptionLabelForSelectValue = (field, value) => {
35
- if (field.extra?.options) {
36
- const matchedOption = field.extra.options.find(
37
- (option) => option.value.toString() === value?.toString()
38
- );
39
- if (matchedOption) {
40
- return matchedOption.label.primary;
41
- }
42
- }
43
- return value;
44
- };
45
- const useURLParamsSearch = (searchFunc, { navigate, fields }) => {
46
- const urlParams = new URLSearchParams(window.location.search);
47
- const currentParams = Object.fromEntries(urlParams.entries());
48
- const values = fields.reduce((newValues, field) => {
49
- if (currentParams[field.key]) {
50
- newValues[field.key] = currentParams[field.key];
51
- }
52
- return newValues;
53
- }, {});
54
- const search = (params) => {
55
- navigate(
56
- "?" + new URLSearchParams(
57
- // @ts-ignore
58
- Object.entries({ ...currentParams, ...params }).filter(
59
- ([, value]) => !!value
60
- )
61
- ).toString()
62
- );
63
- return searchFunc(params);
64
- };
65
- return { search, values };
66
- };
67
- function useStaticSearch({ fields, data, initialFilters }) {
68
- const [results, setResults] = (0, import_react.useState)(data);
69
- (0, import_react.useEffect)(() => {
70
- search(initialFilters);
71
- }, [initialFilters]);
72
- const search = (filters) => {
73
- if (!filters || Object.keys(filters).every((key) => filters[key] === "")) {
74
- setResults(data);
75
- return;
76
- }
77
- const newResults = data.filter((row) => {
78
- const filterKeys = Object.keys(filters);
79
- const enabledFilters = filterKeys.filter(
80
- (filterKey) => filters[filterKey]?.toString() && row[filterKey]?.toString()
81
- );
82
- const freeTextFilters = filterKeys.filter(
83
- (filterKey) => filters[filterKey]?.toString() && !row[filterKey]?.toString()
84
- );
85
- let filtersMatchingValue = false;
86
- if (enabledFilters.length > 0) {
87
- filtersMatchingValue = enabledFilters.every((filterKey) => {
88
- if (filters[filterKey]?.toString() !== row[filterKey]?.toString()) {
89
- const field = fields.find((f) => f.key === filterKey);
90
- const optionsObj = field?.extra?.options.find(
91
- (option) => option?.label?.primary === row[filterKey]
92
- );
93
- return optionsObj?.value.toString() === filters[filterKey]?.toString();
94
- }
95
- filtersMatchingValue = true;
96
- return filtersMatchingValue;
97
- });
98
- if (!filtersMatchingValue) {
99
- return false;
100
- }
101
- }
102
- if (freeTextFilters.length > 0) {
103
- return freeTextFilters.every((filterKey) => {
104
- return Object.values(row).some((value) => {
105
- if (typeof value !== "string") {
106
- return false;
107
- }
108
- const normalizedItemValue = normalizeText(
109
- value.toString().toLowerCase()
110
- );
111
- const normalizedFilterValue = normalizeText(
112
- filters[filterKey]?.toString().toLowerCase().trim() || ""
113
- );
114
- return normalizedItemValue.includes(normalizedFilterValue);
115
- });
116
- });
117
- }
118
- return filtersMatchingValue;
119
- });
120
- setResults(newResults);
121
- };
122
- return (0, import_react.useMemo)(() => ({ search, results }), [search, results]);
123
- }
124
- // Annotate the CommonJS export names for ESM import in node:
125
- 0 && (module.exports = {
126
- getOptionLabelForSelectValue,
127
- isBooleanString,
128
- normalizeText,
129
- useStaticSearch,
130
- useURLParamsSearch
131
- });
132
- //# sourceMappingURL=hooks.js.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/FilteredResults/hooks.ts"],
4
- "sourcesContent": ["import { useState, useEffect, useMemo } from 'react';\nimport { FieldSpec } from '@digigov/form/types';\nimport { ScalarType } from '@digigov/react-modules/FilteredResults';\n\nexport function isBooleanString(str: string): boolean {\n return /^(true|false)$/i.test(str);\n}\n\nexport function normalizeText(text: string): string {\n return text.normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n}\n\nexport const getOptionLabelForSelectValue = (field, value) => {\n if (field.extra?.options) {\n const matchedOption = field.extra.options.find(\n (option) => option.value.toString() === value?.toString()\n );\n if (matchedOption) {\n return matchedOption.label.primary;\n }\n }\n return value;\n};\n\nexport const useURLParamsSearch = (searchFunc, { navigate, fields }) => {\n const urlParams = new URLSearchParams(window.location.search);\n const currentParams = Object.fromEntries(urlParams.entries());\n const values = fields.reduce((newValues, field) => {\n if (currentParams[field.key]) {\n newValues[field.key] = currentParams[field.key];\n }\n return newValues;\n }, {});\n\n const search = (params) => {\n navigate(\n '?' +\n new URLSearchParams(\n // @ts-ignore\n Object.entries({ ...currentParams, ...params }).filter(\n ([, value]) => !!value\n )\n ).toString()\n );\n return searchFunc(params);\n };\n return { search, values };\n};\n\ninterface UseStaticSearchProps<\n DT extends Record<string, ScalarType>,\n FT extends Record<string, ScalarType>,\n> {\n fields: FieldSpec[];\n data: DT[];\n initialFilters: FT;\n}\n\nexport function useStaticSearch<\n DT extends Record<string, ScalarType>,\n FT extends Record<string, ScalarType>,\n>({ fields, data, initialFilters }: UseStaticSearchProps<DT, FT>) {\n const [results, setResults] = useState<DT[]>(data);\n\n useEffect(() => {\n search(initialFilters);\n }, [initialFilters]);\n\n const search = (filters: FT) => {\n if (!filters || Object.keys(filters).every((key) => filters[key] === '')) {\n setResults(data);\n return;\n }\n\n const newResults = data.filter((row) => {\n const filterKeys = Object.keys(filters);\n const enabledFilters = filterKeys.filter(\n (filterKey) =>\n filters[filterKey]?.toString() && row[filterKey]?.toString()\n );\n const freeTextFilters = filterKeys.filter(\n (filterKey) =>\n filters[filterKey]?.toString() && !row[filterKey]?.toString()\n );\n let filtersMatchingValue = false;\n\n // Filter the fields that exists as columns in table\n if (enabledFilters.length > 0) {\n filtersMatchingValue = enabledFilters.every((filterKey) => {\n if (filters[filterKey]?.toString() !== row[filterKey]?.toString()) {\n const field = fields.find((f) => f.key === filterKey);\n const optionsObj = field?.extra?.options.find(\n (option) => option?.label?.primary === row[filterKey]\n );\n return (\n optionsObj?.value.toString() === filters[filterKey]?.toString()\n );\n }\n filtersMatchingValue = true;\n return filtersMatchingValue;\n });\n if (!filtersMatchingValue) {\n return false;\n }\n }\n // Filter the free text fields (doesn't exist as columns)\n if (freeTextFilters.length > 0) {\n return freeTextFilters.every((filterKey) => {\n return Object.values(row).some((value) => {\n if (typeof value !== 'string') {\n return false;\n }\n const normalizedItemValue = normalizeText(\n value.toString().toLowerCase()\n );\n\n const normalizedFilterValue = normalizeText(\n filters[filterKey]?.toString().toLowerCase().trim() || ''\n );\n return normalizedItemValue.includes(normalizedFilterValue);\n });\n });\n }\n return filtersMatchingValue;\n });\n\n setResults(newResults);\n };\n\n return useMemo(() => ({ search, results }), [search, results]);\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAA6C;AAItC,SAAS,gBAAgB,KAAsB;AACpD,SAAO,kBAAkB,KAAK,GAAG;AACnC;AAEO,SAAS,cAAc,MAAsB;AAClD,SAAO,KAAK,UAAU,KAAK,EAAE,QAAQ,oBAAoB,EAAE;AAC7D;AAEO,MAAM,+BAA+B,CAAC,OAAO,UAAU;AAC5D,MAAI,MAAM,OAAO,SAAS;AACxB,UAAM,gBAAgB,MAAM,MAAM,QAAQ;AAAA,MACxC,CAAC,WAAW,OAAO,MAAM,SAAS,MAAM,OAAO,SAAS;AAAA,IAC1D;AACA,QAAI,eAAe;AACjB,aAAO,cAAc,MAAM;AAAA,IAC7B;AAAA,EACF;AACA,SAAO;AACT;AAEO,MAAM,qBAAqB,CAAC,YAAY,EAAE,UAAU,OAAO,MAAM;AACtE,QAAM,YAAY,IAAI,gBAAgB,OAAO,SAAS,MAAM;AAC5D,QAAM,gBAAgB,OAAO,YAAY,UAAU,QAAQ,CAAC;AAC5D,QAAM,SAAS,OAAO,OAAO,CAAC,WAAW,UAAU;AACjD,QAAI,cAAc,MAAM,GAAG,GAAG;AAC5B,gBAAU,MAAM,GAAG,IAAI,cAAc,MAAM,GAAG;AAAA,IAChD;AACA,WAAO;AAAA,EACT,GAAG,CAAC,CAAC;AAEL,QAAM,SAAS,CAAC,WAAW;AACzB;AAAA,MACE,MACE,IAAI;AAAA;AAAA,QAEF,OAAO,QAAQ,EAAE,GAAG,eAAe,GAAG,OAAO,CAAC,EAAE;AAAA,UAC9C,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;AAAA,QACnB;AAAA,MACF,EAAE,SAAS;AAAA,IACf;AACA,WAAO,WAAW,MAAM;AAAA,EAC1B;AACA,SAAO,EAAE,QAAQ,OAAO;AAC1B;AAWO,SAAS,gBAGd,EAAE,QAAQ,MAAM,eAAe,GAAiC;AAChE,QAAM,CAAC,SAAS,UAAU,QAAI,uBAAe,IAAI;AAEjD,8BAAU,MAAM;AACd,WAAO,cAAc;AAAA,EACvB,GAAG,CAAC,cAAc,CAAC;AAEnB,QAAM,SAAS,CAAC,YAAgB;AAC9B,QAAI,CAAC,WAAW,OAAO,KAAK,OAAO,EAAE,MAAM,CAAC,QAAQ,QAAQ,GAAG,MAAM,EAAE,GAAG;AACxE,iBAAW,IAAI;AACf;AAAA,IACF;AAEA,UAAM,aAAa,KAAK,OAAO,CAAC,QAAQ;AACtC,YAAM,aAAa,OAAO,KAAK,OAAO;AACtC,YAAM,iBAAiB,WAAW;AAAA,QAChC,CAAC,cACC,QAAQ,SAAS,GAAG,SAAS,KAAK,IAAI,SAAS,GAAG,SAAS;AAAA,MAC/D;AACA,YAAM,kBAAkB,WAAW;AAAA,QACjC,CAAC,cACC,QAAQ,SAAS,GAAG,SAAS,KAAK,CAAC,IAAI,SAAS,GAAG,SAAS;AAAA,MAChE;AACA,UAAI,uBAAuB;AAG3B,UAAI,eAAe,SAAS,GAAG;AAC7B,+BAAuB,eAAe,MAAM,CAAC,cAAc;AACzD,cAAI,QAAQ,SAAS,GAAG,SAAS,MAAM,IAAI,SAAS,GAAG,SAAS,GAAG;AACjE,kBAAM,QAAQ,OAAO,KAAK,CAAC,MAAM,EAAE,QAAQ,SAAS;AACpD,kBAAM,aAAa,OAAO,OAAO,QAAQ;AAAA,cACvC,CAAC,WAAW,QAAQ,OAAO,YAAY,IAAI,SAAS;AAAA,YACtD;AACA,mBACE,YAAY,MAAM,SAAS,MAAM,QAAQ,SAAS,GAAG,SAAS;AAAA,UAElE;AACA,iCAAuB;AACvB,iBAAO;AAAA,QACT,CAAC;AACD,YAAI,CAAC,sBAAsB;AACzB,iBAAO;AAAA,QACT;AAAA,MACF;AAEA,UAAI,gBAAgB,SAAS,GAAG;AAC9B,eAAO,gBAAgB,MAAM,CAAC,cAAc;AAC1C,iBAAO,OAAO,OAAO,GAAG,EAAE,KAAK,CAAC,UAAU;AACxC,gBAAI,OAAO,UAAU,UAAU;AAC7B,qBAAO;AAAA,YACT;AACA,kBAAM,sBAAsB;AAAA,cAC1B,MAAM,SAAS,EAAE,YAAY;AAAA,YAC/B;AAEA,kBAAM,wBAAwB;AAAA,cAC5B,QAAQ,SAAS,GAAG,SAAS,EAAE,YAAY,EAAE,KAAK,KAAK;AAAA,YACzD;AACA,mBAAO,oBAAoB,SAAS,qBAAqB;AAAA,UAC3D,CAAC;AAAA,QACH,CAAC;AAAA,MACH;AACA,aAAO;AAAA,IACT,CAAC;AAED,eAAW,UAAU;AAAA,EACvB;AAEA,aAAO,sBAAQ,OAAO,EAAE,QAAQ,QAAQ,IAAI,CAAC,QAAQ,OAAO,CAAC;AAC/D;",
6
- "names": []
7
- }