karsten-design-system 1.1.59 → 1.1.60

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 (133) hide show
  1. package/dist/index.js +1822 -38
  2. package/dist/index.js.map +1 -1
  3. package/package.json +2 -1
  4. package/dist/.storybook/index.css.js +0 -7
  5. package/dist/.storybook/index.css.js.map +0 -1
  6. package/dist/_virtual/jsx-runtime.js +0 -6
  7. package/dist/_virtual/jsx-runtime.js.map +0 -1
  8. package/dist/_virtual/jsx-runtime2.js +0 -4
  9. package/dist/_virtual/jsx-runtime2.js.map +0 -1
  10. package/dist/_virtual/react-jsx-runtime.production.js +0 -4
  11. package/dist/_virtual/react-jsx-runtime.production.js.map +0 -1
  12. package/dist/assets/icons/error.js +0 -8
  13. package/dist/assets/icons/error.js.map +0 -1
  14. package/dist/assets/icons/filter.js +0 -8
  15. package/dist/assets/icons/filter.js.map +0 -1
  16. package/dist/assets/icons/info.js +0 -8
  17. package/dist/assets/icons/info.js.map +0 -1
  18. package/dist/assets/icons/success.js +0 -8
  19. package/dist/assets/icons/success.js.map +0 -1
  20. package/dist/assets/icons/text.js +0 -8
  21. package/dist/assets/icons/text.js.map +0 -1
  22. package/dist/assets/logoSmall.js +0 -8
  23. package/dist/assets/logoSmall.js.map +0 -1
  24. package/dist/components/floating-label/index.js +0 -14
  25. package/dist/components/floating-label/index.js.map +0 -1
  26. package/dist/node_modules/date-fns/locale/_lib/buildFormatLongFn.js +0 -11
  27. package/dist/node_modules/date-fns/locale/_lib/buildFormatLongFn.js.map +0 -1
  28. package/dist/node_modules/date-fns/locale/_lib/buildLocalizeFn.js +0 -65
  29. package/dist/node_modules/date-fns/locale/_lib/buildLocalizeFn.js.map +0 -1
  30. package/dist/node_modules/date-fns/locale/_lib/buildMatchFn.js +0 -60
  31. package/dist/node_modules/date-fns/locale/_lib/buildMatchFn.js.map +0 -1
  32. package/dist/node_modules/date-fns/locale/_lib/buildMatchPatternFn.js +0 -23
  33. package/dist/node_modules/date-fns/locale/_lib/buildMatchPatternFn.js.map +0 -1
  34. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatDistance.js +0 -104
  35. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatDistance.js.map +0 -1
  36. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatLong.js +0 -42
  37. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatLong.js.map +0 -1
  38. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatRelative.js +0 -25
  39. package/dist/node_modules/date-fns/locale/pt-BR/_lib/formatRelative.js.map +0 -1
  40. package/dist/node_modules/date-fns/locale/pt-BR/_lib/localize.js +0 -180
  41. package/dist/node_modules/date-fns/locale/pt-BR/_lib/localize.js.map +0 -1
  42. package/dist/node_modules/date-fns/locale/pt-BR/_lib/match.js +0 -137
  43. package/dist/node_modules/date-fns/locale/pt-BR/_lib/match.js.map +0 -1
  44. package/dist/node_modules/date-fns/locale/pt-BR.js +0 -29
  45. package/dist/node_modules/date-fns/locale/pt-BR.js.map +0 -1
  46. package/dist/node_modules/react/cjs/react-jsx-runtime.production.js +0 -45
  47. package/dist/node_modules/react/cjs/react-jsx-runtime.production.js.map +0 -1
  48. package/dist/node_modules/react/jsx-runtime.js +0 -18
  49. package/dist/node_modules/react/jsx-runtime.js.map +0 -1
  50. package/dist/node_modules/style-inject/dist/style-inject.es.js +0 -29
  51. package/dist/node_modules/style-inject/dist/style-inject.es.js.map +0 -1
  52. package/dist/stories/components/accordion.js +0 -30
  53. package/dist/stories/components/accordion.js.map +0 -1
  54. package/dist/stories/components/autoComplete.js +0 -30
  55. package/dist/stories/components/autoComplete.js.map +0 -1
  56. package/dist/stories/components/basicHeader.js +0 -9
  57. package/dist/stories/components/basicHeader.js.map +0 -1
  58. package/dist/stories/components/breadcrumb.js +0 -10
  59. package/dist/stories/components/breadcrumb.js.map +0 -1
  60. package/dist/stories/components/button.js +0 -19
  61. package/dist/stories/components/button.js.map +0 -1
  62. package/dist/stories/components/calendarInput.js +0 -99
  63. package/dist/stories/components/calendarInput.js.map +0 -1
  64. package/dist/stories/components/card.js +0 -9
  65. package/dist/stories/components/card.js.map +0 -1
  66. package/dist/stories/components/cardButton.js +0 -11
  67. package/dist/stories/components/cardButton.js.map +0 -1
  68. package/dist/stories/components/cardIconsButton.js +0 -11
  69. package/dist/stories/components/cardIconsButton.js.map +0 -1
  70. package/dist/stories/components/chart.js +0 -9
  71. package/dist/stories/components/chart.js.map +0 -1
  72. package/dist/stories/components/dialog.js +0 -10
  73. package/dist/stories/components/dialog.js.map +0 -1
  74. package/dist/stories/components/divider.js +0 -9
  75. package/dist/stories/components/divider.js.map +0 -1
  76. package/dist/stories/components/emptyContent.js +0 -8
  77. package/dist/stories/components/emptyContent.js.map +0 -1
  78. package/dist/stories/components/expandablePanel.js +0 -10
  79. package/dist/stories/components/expandablePanel.js.map +0 -1
  80. package/dist/stories/components/fileUpload.js +0 -96
  81. package/dist/stories/components/fileUpload.js.map +0 -1
  82. package/dist/stories/components/filterButton.js +0 -33
  83. package/dist/stories/components/filterButton.js.map +0 -1
  84. package/dist/stories/components/header.js +0 -37
  85. package/dist/stories/components/header.js.map +0 -1
  86. package/dist/stories/components/iconButton.js +0 -14
  87. package/dist/stories/components/iconButton.js.map +0 -1
  88. package/dist/stories/components/infoCard.js +0 -9
  89. package/dist/stories/components/infoCard.js.map +0 -1
  90. package/dist/stories/components/input.js +0 -60
  91. package/dist/stories/components/input.js.map +0 -1
  92. package/dist/stories/components/inputSwitch.js +0 -14
  93. package/dist/stories/components/inputSwitch.js.map +0 -1
  94. package/dist/stories/components/inputTextArea.js +0 -20
  95. package/dist/stories/components/inputTextArea.js.map +0 -1
  96. package/dist/stories/components/internalMenu.js +0 -30
  97. package/dist/stories/components/internalMenu.js.map +0 -1
  98. package/dist/stories/components/link.js +0 -8
  99. package/dist/stories/components/link.js.map +0 -1
  100. package/dist/stories/components/megaMenu.js +0 -13
  101. package/dist/stories/components/megaMenu.js.map +0 -1
  102. package/dist/stories/components/modal.js +0 -38
  103. package/dist/stories/components/modal.js.map +0 -1
  104. package/dist/stories/components/multiselect.js +0 -125
  105. package/dist/stories/components/multiselect.js.map +0 -1
  106. package/dist/stories/components/notification.js +0 -16
  107. package/dist/stories/components/notification.js.map +0 -1
  108. package/dist/stories/components/notificationItem.js +0 -16
  109. package/dist/stories/components/notificationItem.js.map +0 -1
  110. package/dist/stories/components/paginator.js +0 -28
  111. package/dist/stories/components/paginator.js.map +0 -1
  112. package/dist/stories/components/radioButton.js +0 -17
  113. package/dist/stories/components/radioButton.js.map +0 -1
  114. package/dist/stories/components/select.js +0 -98
  115. package/dist/stories/components/select.js.map +0 -1
  116. package/dist/stories/components/sidebar.js +0 -17
  117. package/dist/stories/components/sidebar.js.map +0 -1
  118. package/dist/stories/components/skeleton.js +0 -9
  119. package/dist/stories/components/skeleton.js.map +0 -1
  120. package/dist/stories/components/spinner.js +0 -18
  121. package/dist/stories/components/spinner.js.map +0 -1
  122. package/dist/stories/components/table.js +0 -167
  123. package/dist/stories/components/table.js.map +0 -1
  124. package/dist/stories/components/tagStatus.js +0 -33
  125. package/dist/stories/components/tagStatus.js.map +0 -1
  126. package/dist/stories/components/toast.js +0 -18
  127. package/dist/stories/components/toast.js.map +0 -1
  128. package/dist/utils/masks/index.js +0 -90
  129. package/dist/utils/masks/index.js.map +0 -1
  130. package/dist/utils/nestedValue.js +0 -9
  131. package/dist/utils/nestedValue.js.map +0 -1
  132. package/dist/utils/sortData.js +0 -48
  133. package/dist/utils/sortData.js.map +0 -1
package/dist/index.js CHANGED
@@ -1,39 +1,1823 @@
1
- import './.storybook/index.css.js';
2
- export { Accordion } from './stories/components/accordion.js';
3
- export { AutoComplete } from './stories/components/autoComplete.js';
4
- export { BasicHeader } from './stories/components/basicHeader.js';
5
- export { Breadcrumb } from './stories/components/breadcrumb.js';
6
- export { Button } from './stories/components/button.js';
7
- export { CalendarInput } from './stories/components/calendarInput.js';
8
- export { Card } from './stories/components/card.js';
9
- export { CardButton } from './stories/components/cardButton.js';
10
- export { CardIconsButton } from './stories/components/cardIconsButton.js';
11
- export { Chart } from './stories/components/chart.js';
12
- export { Dialog } from './stories/components/dialog.js';
13
- export { Divider } from './stories/components/divider.js';
14
- export { EmptyContent } from './stories/components/emptyContent.js';
15
- export { ExpandablePanel } from './stories/components/expandablePanel.js';
16
- export { FileUpload } from './stories/components/fileUpload.js';
17
- export { FilterButton } from './stories/components/filterButton.js';
18
- export { Header } from './stories/components/header.js';
19
- export { IconButton } from './stories/components/iconButton.js';
20
- export { InfoCard } from './stories/components/infoCard.js';
21
- export { Input } from './stories/components/input.js';
22
- export { InputSwitch } from './stories/components/inputSwitch.js';
23
- export { InputTextArea } from './stories/components/inputTextArea.js';
24
- export { InternalMenu } from './stories/components/internalMenu.js';
25
- export { Link } from './stories/components/link.js';
26
- export { MegaMenu } from './stories/components/megaMenu.js';
27
- export { Modal } from './stories/components/modal.js';
28
- export { MultiSelect } from './stories/components/multiselect.js';
29
- export { Notification } from './stories/components/notification.js';
30
- export { Paginator } from './stories/components/paginator.js';
31
- export { RadioButton } from './stories/components/radioButton.js';
32
- export { Select } from './stories/components/select.js';
33
- export { Sidebar } from './stories/components/sidebar.js';
34
- export { Skeleton } from './stories/components/skeleton.js';
35
- export { Spinner } from './stories/components/spinner.js';
36
- export { Table } from './stories/components/table.js';
37
- export { TagStatus } from './stories/components/tagStatus.js';
38
- export { Toast } from './stories/components/toast.js';
1
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
+ import clsx from 'clsx';
3
+ import React, { useState, useEffect, useId, useRef } from 'react';
4
+ import { IconField } from 'primereact/iconfield';
5
+ import { InputIcon } from 'primereact/inputicon';
6
+ import { InputText } from 'primereact/inputtext';
7
+ import { Link as Link$1 } from 'react-router-dom';
8
+ import { Button as Button$1 } from 'primereact/button';
9
+ import { addLocale } from 'primereact/api';
10
+ import { Calendar } from 'primereact/calendar';
11
+ import { Chart as Chart$1 } from 'primereact/chart';
12
+ import { Divider as Divider$1 } from 'primereact/divider';
13
+ import { InputSwitch as InputSwitch$1 } from 'primereact/inputswitch';
14
+ import { InputTextarea } from 'primereact/inputtextarea';
15
+ import { Sidebar as Sidebar$1 } from 'primereact/sidebar';
16
+ import { format } from 'date-fns';
17
+ import { Paginator as Paginator$1 } from 'primereact/paginator';
18
+ import { classNames } from 'primereact/utils';
19
+ import { Skeleton as Skeleton$1 } from 'primereact/skeleton';
20
+
21
+ function styleInject(css, ref) {
22
+ if ( ref === void 0 ) ref = {};
23
+ var insertAt = ref.insertAt;
24
+
25
+ if (typeof document === 'undefined') { return; }
26
+
27
+ var head = document.head || document.getElementsByTagName('head')[0];
28
+ var style = document.createElement('style');
29
+ style.type = 'text/css';
30
+
31
+ if (insertAt === 'top') {
32
+ if (head.firstChild) {
33
+ head.insertBefore(style, head.firstChild);
34
+ } else {
35
+ head.appendChild(style);
36
+ }
37
+ } else {
38
+ head.appendChild(style);
39
+ }
40
+
41
+ if (style.styleSheet) {
42
+ style.styleSheet.cssText = css;
43
+ } else {
44
+ style.appendChild(document.createTextNode(css));
45
+ }
46
+ }
47
+
48
+ var css_248z = "@layer tailwind-base, primereact, tailwind-utilities;@import \"primereact/resources/themes/lara-light-blue/theme.css\";@import \"primeicons/primeicons.css\";@import url(\"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap\");@layer tailwind-base{*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }\r\n /*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid;box-sizing:border-box}:after,:before{--tw-content:\"\"}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}*{font-family:Roboto,sans-serif}}@layer tailwind-utilities{.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.p-calendar.p-invalid input::-moz-placeholder{color:#ec4a54!important}.p-calendar.p-invalid input::placeholder{color:#ec4a54!important}.p-calendar.p-custom input::-moz-placeholder{color:#a0a4b3!important}.p-calendar.p-custom input::placeholder{color:#a0a4b3!important}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.-bottom-1{bottom:-.25rem}.-top-3{top:-.75rem}.bottom-0{bottom:0}.left-4{left:1rem}.right-1{right:.25rem}.right-3{right:.75rem}.right-5{right:1.25rem}.top-1{top:.25rem}.top-1\\/2{top:50%}.top-5{top:1.25rem}.top-\\[9px\\]{top:9px}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-40{z-index:40}.z-50{z-index:50}.z-\\[999\\]{z-index:999}.z-\\[9\\]{z-index:9}.m-0{margin:0}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.line-clamp-3{-webkit-box-orient:vertical;-webkit-line-clamp:3;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.\\!h-8{height:2rem!important}.h-2{height:.5rem}.h-4{height:1rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-\\[160px\\]{height:160px}.h-\\[400px\\]{height:400px}.h-\\[calc\\(100vh_-114\\.8px\\)\\]{height:calc(100vh - 114.8px)}.h-\\[calc\\(100vh_-_125px\\)\\]{height:calc(100vh - 125px)}.h-\\[calc\\(100vh_-_64px\\)\\]{height:calc(100vh - 64px)}.h-fit{height:-moz-fit-content;height:fit-content}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-60{max-height:15rem}.max-h-\\[70vh\\]{max-height:70vh}.min-h-16{min-height:4rem}.min-h-\\[60px\\]{min-height:60px}.\\!w-8{width:2rem!important}.w-1\\/2{width:50%}.w-1\\/3{width:33.333333%}.w-10\\/12{width:83.333333%}.w-100{width:100%}.w-2{width:.5rem}.w-2\\/3{width:66.666667%}.w-4{width:1rem}.w-40{width:10rem}.w-44{width:11rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-72{width:18rem}.w-8{width:2rem}.w-96{width:24rem}.w-\\[240px\\]{width:240px}.w-\\[276px\\]{width:276px}.w-\\[40rem\\]{width:40rem}.w-\\[40vw\\]{width:40vw}.w-\\[60vw\\]{width:60vw}.w-\\[90\\%\\]{width:90%}.w-\\[900px\\]{width:900px}.w-full{width:100%}.w-max{width:-moz-max-content;width:max-content}.w-screen{width:100vw}.min-w-0{min-width:0}.min-w-6{min-width:1.5rem}.min-w-7{min-width:1.75rem}.min-w-72{min-width:18rem}.min-w-\\[305px\\]{min-width:305px}.min-w-full{min-width:100%}.max-w-\\[calc\\(100\\%-20px\\)\\]{max-width:calc(100% - 20px)}.max-w-full{max-width:100%}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.-translate-y-1\\/2{--tw-translate-y:-50%}.-translate-y-1\\/2,.translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-full{--tw-translate-y:100%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-auto{cursor:auto}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-6{row-gap:1.5rem}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.\\!rounded-full{border-radius:9999px!important}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-l-full{border-bottom-left-radius:9999px;border-top-left-radius:9999px}.rounded-r-full{border-bottom-right-radius:9999px;border-top-right-radius:9999px}.rounded-r-lg{border-bottom-right-radius:.5rem;border-top-right-radius:.5rem}.rounded-se-lg{border-start-end-radius:.5rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-0{border-left-width:0}.border-l-4{border-left-width:4px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-\\[\\#13294B\\]{--tw-border-opacity:1;border-color:rgb(19 41 75/var(--tw-border-opacity,1))}.border-\\[\\#1565C0\\]{--tw-border-opacity:1;border-color:rgb(21 101 192/var(--tw-border-opacity,1))}.border-\\[\\#2E7D32\\]{--tw-border-opacity:1;border-color:rgb(46 125 50/var(--tw-border-opacity,1))}.border-\\[\\#5EEAD4\\]{--tw-border-opacity:1;border-color:rgb(94 234 212/var(--tw-border-opacity,1))}.border-\\[\\#67E8F9\\]{--tw-border-opacity:1;border-color:rgb(103 232 249/var(--tw-border-opacity,1))}.border-\\[\\#6EE7B7\\]{--tw-border-opacity:1;border-color:rgb(110 231 183/var(--tw-border-opacity,1))}.border-\\[\\#7DD3FC\\]{--tw-border-opacity:1;border-color:rgb(125 211 252/var(--tw-border-opacity,1))}.border-\\[\\#A5B4FC\\]{--tw-border-opacity:1;border-color:rgb(165 180 252/var(--tw-border-opacity,1))}.border-\\[\\#BEF264\\]{--tw-border-opacity:1;border-color:rgb(190 242 100/var(--tw-border-opacity,1))}.border-\\[\\#BFDBFE\\]{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-\\[\\#C4B5FD\\]{--tw-border-opacity:1;border-color:rgb(196 181 253/var(--tw-border-opacity,1))}.border-\\[\\#C62828\\]{--tw-border-opacity:1;border-color:rgb(198 40 40/var(--tw-border-opacity,1))}.border-\\[\\#CBD5E1\\]{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-\\[\\#D1D5DB\\]{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-\\[\\#D4D4D4\\]{--tw-border-opacity:1;border-color:rgb(212 212 212/var(--tw-border-opacity,1))}.border-\\[\\#D4D4D8\\]{--tw-border-opacity:1;border-color:rgb(212 212 216/var(--tw-border-opacity,1))}.border-\\[\\#D6D3D1\\]{--tw-border-opacity:1;border-color:rgb(214 211 209/var(--tw-border-opacity,1))}.border-\\[\\#F0ABFC\\]{--tw-border-opacity:1;border-color:rgb(240 171 252/var(--tw-border-opacity,1))}.border-\\[\\#F1F1F4\\]{--tw-border-opacity:1;border-color:rgb(241 241 244/var(--tw-border-opacity,1))}.border-\\[\\#F9A8D4\\]{--tw-border-opacity:1;border-color:rgb(249 168 212/var(--tw-border-opacity,1))}.border-\\[\\#FCA5A5\\]{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-\\[\\#FCD34D\\]{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.border-\\[\\#FDA4AF\\]{--tw-border-opacity:1;border-color:rgb(253 164 175/var(--tw-border-opacity,1))}.border-\\[\\#FDBA74\\]{--tw-border-opacity:1;border-color:rgb(253 186 116/var(--tw-border-opacity,1))}.border-\\[\\#e6e6e6\\]{--tw-border-opacity:1;border-color:rgb(230 230 230/var(--tw-border-opacity,1))}.border-\\[\\#f3f4f6\\]{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-background{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-gray{--tw-border-opacity:1;border-color:rgb(160 164 179/var(--tw-border-opacity,1))}.border-gray50{--tw-border-opacity:1;border-color:rgb(224 224 224/var(--tw-border-opacity,1))}.border-grayDark{--tw-border-opacity:1;border-color:rgb(100 105 129/var(--tw-border-opacity,1))}.border-primary{--tw-border-opacity:1;border-color:rgb(19 41 75/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-redError{--tw-border-opacity:1;border-color:rgb(236 74 84/var(--tw-border-opacity,1))}.border-secondary{--tw-border-opacity:1;border-color:rgb(232 236 249/var(--tw-border-opacity,1))}.border-secondaryActive{--tw-border-opacity:1;border-color:rgb(164 180 232/var(--tw-border-opacity,1))}.border-stone{--tw-border-opacity:1;border-color:rgb(230 230 230/var(--tw-border-opacity,1))}.border-stoneDark{--tw-border-opacity:1;border-color:rgb(194 194 194/var(--tw-border-opacity,1))}.border-stoneLight{--tw-border-opacity:1;border-color:rgb(241 241 244/var(--tw-border-opacity,1))}.border-b-primary{--tw-border-opacity:1;border-bottom-color:rgb(19 41 75/var(--tw-border-opacity,1))}.border-b-stone{--tw-border-opacity:1;border-bottom-color:rgb(230 230 230/var(--tw-border-opacity,1))}.border-t-transparent{border-top-color:transparent}.bg-\\[\\#1d6ee731\\]{background-color:#1d6ee731}.bg-\\[\\#CCFBF1\\]{--tw-bg-opacity:1;background-color:rgb(204 251 241/var(--tw-bg-opacity,1))}.bg-\\[\\#CFFAFE\\]{--tw-bg-opacity:1;background-color:rgb(207 250 254/var(--tw-bg-opacity,1))}.bg-\\[\\#D1FAE5\\]{--tw-bg-opacity:1;background-color:rgb(209 250 229/var(--tw-bg-opacity,1))}.bg-\\[\\#DBEAFE\\]{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-\\[\\#E0E7FF\\]{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity,1))}.bg-\\[\\#E0F2FE\\]{--tw-bg-opacity:1;background-color:rgb(224 242 254/var(--tw-bg-opacity,1))}.bg-\\[\\#E3F2FD\\]{--tw-bg-opacity:1;background-color:rgb(227 242 253/var(--tw-bg-opacity,1))}.bg-\\[\\#E6F4EA\\]{--tw-bg-opacity:1;background-color:rgb(230 244 234/var(--tw-bg-opacity,1))}.bg-\\[\\#E7E5E4\\]{--tw-bg-opacity:1;background-color:rgb(231 229 228/var(--tw-bg-opacity,1))}.bg-\\[\\#ECFCCB\\]{--tw-bg-opacity:1;background-color:rgb(236 252 203/var(--tw-bg-opacity,1))}.bg-\\[\\#EDE9FE\\]{--tw-bg-opacity:1;background-color:rgb(237 233 254/var(--tw-bg-opacity,1))}.bg-\\[\\#F1F5F9\\]{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-\\[\\#F3F4F6\\]{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-\\[\\#F4F4F5\\]{--tw-bg-opacity:1;background-color:rgb(244 244 245/var(--tw-bg-opacity,1))}.bg-\\[\\#F5F5F5\\]{--tw-bg-opacity:1;background-color:rgb(245 245 245/var(--tw-bg-opacity,1))}.bg-\\[\\#FAE8FF\\]{--tw-bg-opacity:1;background-color:rgb(250 232 255/var(--tw-bg-opacity,1))}.bg-\\[\\#FCE7F3\\]{--tw-bg-opacity:1;background-color:rgb(252 231 243/var(--tw-bg-opacity,1))}.bg-\\[\\#FEE2E2\\]{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-\\[\\#FEF3C7\\]{--tw-bg-opacity:1;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.bg-\\[\\#FEF9C3\\]{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.bg-\\[\\#FFE4E6\\]{--tw-bg-opacity:1;background-color:rgb(255 228 230/var(--tw-bg-opacity,1))}.bg-\\[\\#FFEBEE\\]{--tw-bg-opacity:1;background-color:rgb(255 235 238/var(--tw-bg-opacity,1))}.bg-\\[\\#FFEDD5\\]{--tw-bg-opacity:1;background-color:rgb(255 237 213/var(--tw-bg-opacity,1))}.bg-\\[\\#e6e6e6\\]{--tw-bg-opacity:1;background-color:rgb(230 230 230/var(--tw-bg-opacity,1))}.bg-background{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-backgroundDark\\/20{background-color:rgba(66,66,66,.2)}.bg-black{background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black,.bg-blue{--tw-bg-opacity:1}.bg-blue{background-color:rgb(0 69 186/var(--tw-bg-opacity,1))}.bg-gray{background-color:rgb(160 164 179/var(--tw-bg-opacity,1))}.bg-gray,.bg-green{--tw-bg-opacity:1}.bg-green{background-color:rgb(10 168 54/var(--tw-bg-opacity,1))}.bg-greenBackground{background-color:#0aa83612}.bg-primary{--tw-bg-opacity:1;background-color:rgb(19 41 75/var(--tw-bg-opacity,1))}.bg-primary\\/5{background-color:rgba(19,41,75,.05)}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-redErrorOpacity{background-color:#a80a0a14}.bg-secondary{--tw-bg-opacity:1;background-color:rgb(232 236 249/var(--tw-bg-opacity,1))}.bg-stone{--tw-bg-opacity:1;background-color:rgb(230 230 230/var(--tw-bg-opacity,1))}.bg-stoneBackground{--tw-bg-opacity:1;background-color:rgb(250 250 251/var(--tw-bg-opacity,1))}.bg-stoneLight{--tw-bg-opacity:1;background-color:rgb(241 241 244/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-\\[\\#13294B\\]{--tw-gradient-from:#13294b var(--tw-gradient-from-position);--tw-gradient-to:rgba(19,41,75,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\\[\\#FAFAFB\\]{--tw-gradient-from:#fafafb var(--tw-gradient-from-position);--tw-gradient-to:rgba(250,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\\[\\#FFFFFF\\]{--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\\[\\#f3f4f6\\]{--tw-gradient-from:#f3f4f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(243,244,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-\\[\\#FAFAFB\\]{--tw-gradient-to:rgba(250,250,251,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fafafb var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-\\[\\#0C1C34\\]{--tw-gradient-to:#0c1c34 var(--tw-gradient-to-position)}.to-\\[\\#FAFAFB\\]{--tw-gradient-to:#fafafb var(--tw-gradient-to-position)}.to-\\[\\#FFFFFF\\],.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.object-cover{-o-object-fit:cover;object-fit:cover}.\\!p-2{padding:.5rem!important}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\\[2px\\]{padding:2px}.\\!py-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\\.5{padding-bottom:.625rem;padding-top:.625rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-top:1rem}.pb-4,.py-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pl-2{padding-left:.5rem}.pl-4{padding-left:1rem}.pl-6{padding-left:1.5rem}.pr-4{padding-right:1rem}.pt-1\\.5{padding-top:.375rem}.pt-10{padding-top:2.5rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.font-roboto{font-family:Roboto,sans-serif}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\\[18px\\]{font-size:18px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.\\!font-bold{font-weight:700!important}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.normal-case{text-transform:none}.\\!text-background{--tw-text-opacity:1!important;color:rgb(255 255 255/var(--tw-text-opacity,1))!important}.\\!text-backgroundDark{--tw-text-opacity:1!important;color:rgb(66 66 66/var(--tw-text-opacity,1))!important}.\\!text-gray100{color:rgb(102 102 102/var(--tw-text-opacity,1))!important}.\\!text-gray100,.\\!text-grayDark{--tw-text-opacity:1!important}.\\!text-grayDark{color:rgb(100 105 129/var(--tw-text-opacity,1))!important}.\\!text-green{color:rgb(10 168 54/var(--tw-text-opacity,1))!important}.\\!text-green,.\\!text-primary{--tw-text-opacity:1!important}.\\!text-primary{color:rgb(19 41 75/var(--tw-text-opacity,1))!important}.\\!text-white{--tw-text-opacity:1!important;color:rgb(255 255 255/var(--tw-text-opacity,1))!important}.text-\\[\\#0369A1\\]{--tw-text-opacity:1;color:rgb(3 105 161/var(--tw-text-opacity,1))}.text-\\[\\#065F46\\]{--tw-text-opacity:1;color:rgb(6 95 70/var(--tw-text-opacity,1))}.text-\\[\\#0D47A1\\]{--tw-text-opacity:1;color:rgb(13 71 161/var(--tw-text-opacity,1))}.text-\\[\\#13294B\\]{--tw-text-opacity:1;color:rgb(19 41 75/var(--tw-text-opacity,1))}.text-\\[\\#134E4A\\]{--tw-text-opacity:1;color:rgb(19 78 74/var(--tw-text-opacity,1))}.text-\\[\\#155E75\\]{--tw-text-opacity:1;color:rgb(21 94 117/var(--tw-text-opacity,1))}.text-\\[\\#1B5E20\\]{--tw-text-opacity:1;color:rgb(27 94 32/var(--tw-text-opacity,1))}.text-\\[\\#1E40AF\\]{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-\\[\\#334155\\]{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-\\[\\#365314\\]{--tw-text-opacity:1;color:rgb(54 83 20/var(--tw-text-opacity,1))}.text-\\[\\#3730A3\\]{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity,1))}.text-\\[\\#374151\\]{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-\\[\\#3F3F46\\]{--tw-text-opacity:1;color:rgb(63 63 70/var(--tw-text-opacity,1))}.text-\\[\\#404040\\]{--tw-text-opacity:1;color:rgb(64 64 64/var(--tw-text-opacity,1))}.text-\\[\\#44403C\\]{--tw-text-opacity:1;color:rgb(68 64 60/var(--tw-text-opacity,1))}.text-\\[\\#646981\\]{--tw-text-opacity:1;color:rgb(100 105 129/var(--tw-text-opacity,1))}.text-\\[\\#6B21A8\\]{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity,1))}.text-\\[\\#6D28D9\\]{--tw-text-opacity:1;color:rgb(109 40 217/var(--tw-text-opacity,1))}.text-\\[\\#878787\\]{--tw-text-opacity:1;color:rgb(135 135 135/var(--tw-text-opacity,1))}.text-\\[\\#92400E\\]{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-\\[\\#991B1B\\]{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-\\[\\#9A3412\\]{--tw-text-opacity:1;color:rgb(154 52 18/var(--tw-text-opacity,1))}.text-\\[\\#9D174D\\]{--tw-text-opacity:1;color:rgb(157 23 77/var(--tw-text-opacity,1))}.text-\\[\\#A21CAF\\]{--tw-text-opacity:1;color:rgb(162 28 175/var(--tw-text-opacity,1))}.text-\\[\\#B71C1C\\]{--tw-text-opacity:1;color:rgb(183 28 28/var(--tw-text-opacity,1))}.text-\\[\\#BE123C\\]{--tw-text-opacity:1;color:rgb(190 18 60/var(--tw-text-opacity,1))}.text-\\[\\#a0a4b3\\]{--tw-text-opacity:1;color:rgb(160 164 179/var(--tw-text-opacity,1))}.text-background{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-backgroundDark{--tw-text-opacity:1;color:rgb(66 66 66/var(--tw-text-opacity,1))}.text-gray{--tw-text-opacity:1;color:rgb(160 164 179/var(--tw-text-opacity,1))}.text-grayDark{--tw-text-opacity:1;color:rgb(100 105 129/var(--tw-text-opacity,1))}.text-green{--tw-text-opacity:1;color:rgb(10 168 54/var(--tw-text-opacity,1))}.text-primary{--tw-text-opacity:1;color:rgb(19 41 75/var(--tw-text-opacity,1))}.text-redError{--tw-text-opacity:1;color:rgb(236 74 84/var(--tw-text-opacity,1))}.text-stone{--tw-text-opacity:1;color:rgb(230 230 230/var(--tw-text-opacity,1))}.text-stoneDark{--tw-text-opacity:1;color:rgb(194 194 194/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.opacity-50{opacity:.5}.\\!shadow-none{--tw-shadow:0 0 #0000!important;--tw-shadow-colored:0 0 #0000!important;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)!important}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-\\[0_4px_12px_rgba\\(0\\2c 0\\2c 0\\2c 0\\.50\\)\\]{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\\[0_4px_12px_rgba\\(0\\2c 0\\2c 0\\2c 0\\.50\\)\\]{--tw-shadow:0 4px 12px rgba(0,0,0,.5);--tw-shadow-colored:0 4px 12px var(--tw-shadow-color)}.shadow-container{--tw-shadow:0px 0px 5px 3px rgba(0,0,0,.1);--tw-shadow-colored:0px 0px 5px 3px var(--tw-shadow-color)}.shadow-container,.shadow-header{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-header{--tw-shadow:0px 0px 20px 0px hsla(0,0%,54%,.3);--tw-shadow-colored:0px 0px 20px 0px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-none{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-gray{--tw-ring-opacity:1;--tw-ring-color:rgb(160 164 179/var(--tw-ring-opacity,1))}.ring-redError{--tw-ring-opacity:1;--tw-ring-color:rgb(236 74 84/var(--tw-ring-opacity,1))}.ring-stone{--tw-ring-opacity:1;--tw-ring-color:rgb(230 230 230/var(--tw-ring-opacity,1))}.ring-offset-2{--tw-ring-offset-width:2px}.ring-offset-background{--tw-ring-offset-color:#fff}.ring-offset-secondary{--tw-ring-offset-color:#e8ecf9}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}}.placeholder\\:\\!text-redError::-moz-placeholder{--tw-text-opacity:1!important;color:rgb(236 74 84/var(--tw-text-opacity,1))!important}.placeholder\\:\\!text-redError::placeholder{--tw-text-opacity:1!important;color:rgb(236 74 84/var(--tw-text-opacity,1))!important}.placeholder\\:text-gray::-moz-placeholder{--tw-text-opacity:1;color:rgb(160 164 179/var(--tw-text-opacity,1))}.placeholder\\:text-gray::placeholder{--tw-text-opacity:1;color:rgb(160 164 179/var(--tw-text-opacity,1))}.placeholder\\:text-redError::-moz-placeholder{--tw-text-opacity:1;color:rgb(236 74 84/var(--tw-text-opacity,1))}.placeholder\\:text-redError::placeholder{--tw-text-opacity:1;color:rgb(236 74 84/var(--tw-text-opacity,1))}.first\\:rounded-ss-lg:first-child{border-start-start-radius:.5rem}.checked\\:bg-primary:checked{--tw-bg-opacity:1;background-color:rgb(19 41 75/var(--tw-bg-opacity,1))}.hover\\:border-grayDark:hover{--tw-border-opacity:1;border-color:rgb(100 105 129/var(--tw-border-opacity,1))}.hover\\:border-primary:hover{--tw-border-opacity:1;border-color:rgb(19 41 75/var(--tw-border-opacity,1))}.hover\\:border-primary\\/50:hover{border-color:rgba(19,41,75,.5)}.hover\\:border-red-500:hover{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.hover\\:border-stone:hover{--tw-border-opacity:1;border-color:rgb(230 230 230/var(--tw-border-opacity,1))}.hover\\:bg-grayDark:hover{--tw-bg-opacity:1;background-color:rgb(100 105 129/var(--tw-bg-opacity,1))}.hover\\:bg-greenBackgroundActive:hover{background-color:#0aa83633}.hover\\:bg-primaryActive:hover{--tw-bg-opacity:1;background-color:rgb(12 28 52/var(--tw-bg-opacity,1))}.hover\\:bg-secondary:hover{--tw-bg-opacity:1;background-color:rgb(232 236 249/var(--tw-bg-opacity,1))}.hover\\:bg-secondaryActive:hover{--tw-bg-opacity:1;background-color:rgb(164 180 232/var(--tw-bg-opacity,1))}.hover\\:bg-stone:hover{--tw-bg-opacity:1;background-color:rgb(230 230 230/var(--tw-bg-opacity,1))}.hover\\:bg-stoneBackground:hover{--tw-bg-opacity:1;background-color:rgb(250 250 251/var(--tw-bg-opacity,1))}.hover\\:font-bold:hover{font-weight:700}.hover\\:text-backgroundDark:hover{--tw-text-opacity:1;color:rgb(66 66 66/var(--tw-text-opacity,1))}.hover\\:text-primary:hover{--tw-text-opacity:1;color:rgb(19 41 75/var(--tw-text-opacity,1))}.hover\\:text-slate-200:hover{--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.hover\\:underline:hover{text-decoration-line:underline}.hover\\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\\:border-primary:focus{--tw-border-opacity:1;border-color:rgb(19 41 75/var(--tw-border-opacity,1))}.focus\\:shadow-md:focus{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.focus\\:shadow-md:focus,.focus\\:shadow-none:focus{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\\:shadow-none:focus{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.disabled\\:border-stone:disabled{--tw-border-opacity:1;border-color:rgb(230 230 230/var(--tw-border-opacity,1))}.disabled\\:border-stoneDark:disabled{--tw-border-opacity:1;border-color:rgb(194 194 194/var(--tw-border-opacity,1))}.disabled\\:bg-stone:disabled{--tw-bg-opacity:1;background-color:rgb(230 230 230/var(--tw-bg-opacity,1))}.disabled\\:bg-stoneDark:disabled{--tw-bg-opacity:1;background-color:rgb(194 194 194/var(--tw-bg-opacity,1))}.disabled\\:text-background:disabled{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.disabled\\:text-stoneDark:disabled{--tw-text-opacity:1;color:rgb(194 194 194/var(--tw-text-opacity,1))}.group:hover .group-hover\\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:640px){.sm\\:w-auto{width:auto}.sm\\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\\:flex-row{flex-direction:row}.sm\\:justify-end{justify-content:flex-end}}@media (min-width:768px){.md\\:w-1\\/2{width:50%}.md\\:min-w-\\[110px\\]{min-width:110px}.md\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\\:w-1\\/3{width:33.333333%}.lg\\:min-w-\\[110px\\]{min-width:110px}.lg\\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.\\[\\&\\:\\:-webkit-scrollbar-thumb\\]\\:rounded-md::-webkit-scrollbar-thumb{border-radius:.375rem}.\\[\\&\\:\\:-webkit-scrollbar-thumb\\]\\:bg-stoneDark::-webkit-scrollbar-thumb{--tw-bg-opacity:1;background-color:rgb(194 194 194/var(--tw-bg-opacity,1))}.\\[\\&\\:\\:-webkit-scrollbar-track\\]\\:rounded-r-md::-webkit-scrollbar-track{border-bottom-right-radius:.375rem;border-top-right-radius:.375rem}.\\[\\&\\:\\:-webkit-scrollbar-track\\]\\:bg-stone::-webkit-scrollbar-track{--tw-bg-opacity:1;background-color:rgb(230 230 230/var(--tw-bg-opacity,1))}.\\[\\&\\:\\:-webkit-scrollbar\\]\\:w-1::-webkit-scrollbar{width:.25rem}";
49
+ styleInject(css_248z,{"insertAt":"top"});
50
+
51
+ function Accordion({ tabsChildren, headers, multiple = false, activeIndex, className, onClickFavorite, showFavorite = false, }) {
52
+ const [openIndexes, setOpenIndexes] = useState(activeIndex
53
+ ? Array.isArray(activeIndex)
54
+ ? activeIndex
55
+ : [activeIndex]
56
+ : []);
57
+ const toggleTab = (index) => {
58
+ if (multiple) {
59
+ setOpenIndexes((prev) => prev.includes(index)
60
+ ? prev.filter((i) => i !== index)
61
+ : [...prev, index]);
62
+ }
63
+ else {
64
+ setOpenIndexes((prev) => (prev.includes(index) ? [] : [index]));
65
+ }
66
+ };
67
+ return (jsx("div", { className: clsx('w-full flex flex-col text-primary', className), children: tabsChildren.map((tab, index) => (jsxs("div", { className: "w-full", children: [jsx("div", { className: "flex items-center justify-between w-full border-b border-b-primary bg-background", children: jsxs("button", { onClick: () => toggleTab(index), className: "flex items-center justify-between w-full px-4 py-2", "aria-label": "Abrir aba de menus", children: [jsxs("div", { className: "flex items-center gap-3", children: [showFavorite && (jsx("i", { className: clsx('text-primary cursor-pointer text-lg', headers[index]?.isFavorite
68
+ ? 'pi pi-star-fill text-primary'
69
+ : 'pi pi-star'), onClick: (e) => {
70
+ e.stopPropagation();
71
+ onClickFavorite?.(index);
72
+ } })), jsx("span", { className: "text-left text-primary text-base font-bold font-roboto", children: headers[index].label })] }), jsx("i", { className: clsx('pi', openIndexes.includes(index) ? 'pi-angle-up' : 'pi-angle-down', 'text-primary ml-4') })] }) }), openIndexes.includes(index) && jsx("div", { className: "py-4", children: tab })] }, index))) }));
73
+ }
74
+
75
+ const FloatingLabel = ({ value, label, disabled, error, }) => {
76
+ const [isFloating, setIsFloating] = useState(!!value);
77
+ useEffect(() => {
78
+ setIsFloating(!!value);
79
+ }, [value]);
80
+ return (jsx("label", { className: clsx('absolute left-4 text-gray transition-all bg-background px-1 z-20 font-roboto text-sm', isFloating ? '-top-3 text-primary' : 'top-[9px]', disabled ? 'text-stoneDark' : error ? 'text-redError' : 'text-gray'), children: isFloating ? label : value }));
81
+ };
82
+
83
+ const maskCPF = (value) => {
84
+ value = value.replace(/\D/g, '');
85
+ value = value.slice(0, 11);
86
+ if (value.length <= 3) {
87
+ return value;
88
+ }
89
+ if (value.length <= 6) {
90
+ return value.replace(/(\d{3})(\d{1,})/, '$1.$2');
91
+ }
92
+ if (value.length <= 9) {
93
+ return value.replace(/(\d{3})(\d{3})(\d{1,})/, '$1.$2.$3');
94
+ }
95
+ return value.replace(/(\d{3})(\d{3})(\d{3})(\d{1,})/, '$1.$2.$3-$4');
96
+ };
97
+ const maskCNPJ = (value) => {
98
+ value = value.replace(/\D/g, '');
99
+ value = value.slice(0, 14);
100
+ if (value.length <= 2) {
101
+ return value;
102
+ }
103
+ if (value.length <= 5) {
104
+ return value.replace(/(\d{2})(\d{1,})/, '$1.$2');
105
+ }
106
+ if (value.length <= 8) {
107
+ return value.replace(/(\d{2})(\d{3})(\d{1,})/, '$1.$2.$3');
108
+ }
109
+ if (value.length <= 12) {
110
+ return value.replace(/(\d{2})(\d{3})(\d{3})(\d{1,})/, '$1.$2.$3/$4');
111
+ }
112
+ return value.replace(/(\d{2})(\d{3})(\d{3})(\d{4})(\d{1,})/, '$1.$2.$3/$4-$5');
113
+ };
114
+ // export const maskNumber = (value: string) => {
115
+ // value = value.replace(/\D/g, '');
116
+ // value = value.slice(0, 12);
117
+ // return value.replace(/(\d)(\d{2})$/, '$1,$2');
118
+ // };
119
+ const maskOnlyNumbers = (value) => {
120
+ value = value.replace(/\D/g, '');
121
+ value = value.slice(0, 15);
122
+ return value;
123
+ };
124
+ const maskNumberWithDecimal = (value) => {
125
+ const regex = /^[0-9]+([.,][0-9]+)?$/;
126
+ value = value.slice(0, 20);
127
+ if (!regex.test(value)) {
128
+ return value.replace(/[^0-9.,]/g, '').replace(/([.,]).*\1/g, '$1');
129
+ }
130
+ return value;
131
+ };
132
+ const maskCellphone = (value) => {
133
+ value = value.replace(/\D/g, '');
134
+ value = value.slice(0, 11);
135
+ if (value.length <= 2) {
136
+ return value.replace(/(\d{2})/, '($1');
137
+ }
138
+ if (value.length <= 6) {
139
+ return value.replace(/(\d{2})(\d{4})/, '($1) $2');
140
+ }
141
+ return value.replace(/(\d{2})(\d{4})(\d{4})/, '($1) $2-$3');
142
+ };
143
+ const maskPhone = (value) => {
144
+ value = value.replace(/\D/g, '');
145
+ value = value.slice(0, 10);
146
+ if (value.length <= 2) {
147
+ return value.replace(/(\d{2})/, '($1');
148
+ }
149
+ if (value.length <= 6) {
150
+ return value.replace(/(\d{2})(\d{4})/, '($1) $2');
151
+ }
152
+ return value.replace(/(\d{2})(\d{4})(\d{4})/, '($1) $2-$3');
153
+ };
154
+ const maskCEP = (value) => {
155
+ value = value.replace(/\D/g, '');
156
+ value = value.slice(0, 8);
157
+ return value.replace(/(\d{5})(\d{1,})/, '$1-$2');
158
+ };
159
+ const maskMoneyBRL = (value) => {
160
+ value = value.replace(/\D/g, '');
161
+ if (!value)
162
+ return '';
163
+ value = value.slice(0, 13);
164
+ const numericValue = parseFloat(value) / 100;
165
+ return numericValue.toLocaleString('pt-BR', {
166
+ style: 'currency',
167
+ currency: 'BRL',
168
+ });
169
+ };
170
+
171
+ const variants$4 = {
172
+ green: 'text-green',
173
+ gray: 'text-gray',
174
+ };
175
+ function Input({ onChange, placeholder, disabled = false, error, icon, onClickIcon, iconColor = 'green', label, mask, ...props }) {
176
+ const inputId = useId();
177
+ const [inputValue, setInputValue] = useState('');
178
+ const applyMask = (value, mask) => {
179
+ switch (mask) {
180
+ case 'cpf':
181
+ return maskCPF(value);
182
+ case 'cnpj':
183
+ return maskCNPJ(value);
184
+ case 'numbers':
185
+ return maskOnlyNumbers(value);
186
+ case 'cellphone':
187
+ return maskCellphone(value);
188
+ case 'phone':
189
+ return maskPhone(value);
190
+ case 'decimal':
191
+ return maskNumberWithDecimal(value);
192
+ case 'cep':
193
+ return maskCEP(value);
194
+ case 'currency':
195
+ return maskMoneyBRL(value);
196
+ default:
197
+ return value;
198
+ }
199
+ };
200
+ useEffect(() => {
201
+ const formatted = applyMask(props?.value ?? '', mask);
202
+ setInputValue(formatted);
203
+ }, [props?.value, mask]);
204
+ const handleChange = (e) => {
205
+ const value = applyMask(e.target.value, mask);
206
+ setInputValue(value);
207
+ onChange(value);
208
+ };
209
+ const hasError = (props?.value && error && !disabled) ||
210
+ (!!error && !disabled && props?.value?.length === 0);
211
+ return (jsxs("div", { className: "relative flex flex-col w-100", children: [jsxs(IconField, { className: "w-100", children: [jsx(InputIcon, { className: clsx(`pi ${icon} px-2 cursor-pointer`, hasError
212
+ ? 'text-redError'
213
+ : disabled
214
+ ? 'text-stone'
215
+ : variants$4[iconColor]), onClick: onClickIcon }), jsx(InputText, { id: inputId, type: "text", placeholder: placeholder, className: clsx('focus:shadow-none text-base w-100 font-roboto border !p-2 rounded-md', hasError
216
+ ? 'border-redError placeholder:text-redError'
217
+ : 'border-gray focus:border-primary', disabled && 'border-stoneDark text-disabled', error && 'border-redError text-redError', !error && 'border-gray placeholder:text-gray'), onChange: handleChange, disabled: disabled, invalid: hasError, ...props, value: inputValue })] }), jsx(FloatingLabel, { value: props?.value ? props?.value?.toString() : '', label: label || '', disabled: disabled, error: error }), hasError && jsx("span", { className: "text-redError text-xs px-2", children: error })] }));
218
+ }
219
+
220
+ function AutoComplete({ items, onChange, error, ...props }) {
221
+ const [isOpen, setIsOpen] = useState(false);
222
+ const [filteredItems, setFilteredItems] = useState(items);
223
+ const handleInputChange = (value) => {
224
+ onChange(value);
225
+ setIsOpen(!!value);
226
+ const filtered = items.filter((item) => item.toLowerCase().includes(value.toLowerCase()));
227
+ setFilteredItems(filtered);
228
+ };
229
+ const handleSelect = (selectedValue) => {
230
+ onChange(selectedValue);
231
+ setIsOpen(false);
232
+ };
233
+ const handleIconClick = () => {
234
+ if (isOpen) {
235
+ onChange('');
236
+ setFilteredItems(items);
237
+ }
238
+ setIsOpen(!isOpen);
239
+ };
240
+ return (jsxs("div", { className: "relative w-100", children: [jsx(IconField, { className: "w-100", children: jsx(Input, { ...props, onChange: handleInputChange, icon: isOpen ? 'pi-times' : 'pi-search', iconColor: isOpen ? 'gray' : 'green', onClickIcon: handleIconClick, error: error }) }), isOpen && filteredItems.length > 0 && (jsx("div", { className: "absolute w-100 max-h-48 -bottom-1 translate-y-full overflow-y-auto bg-white shadow-md z-10 rounded-md border border-stoneDark [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-track]:rounded-r-md [&::-webkit-scrollbar-thumb]:rounded-md [&::-webkit-scrollbar-track]:bg-stone [&::-webkit-scrollbar-thumb]:bg-stoneDark", children: jsx("ul", { children: filteredItems.map((item) => (jsx("li", { onClick: () => handleSelect(item), className: "p-3 text-backgroundDark cursor-pointer hover:bg-secondary rounded-md", children: item }, item))) }) }))] }));
241
+ }
242
+
243
+ function LogoSmall() {
244
+ return (jsxs("svg", { width: "92", height: "19", viewBox: "0 0 92 19", fill: "none", children: [jsxs("g", { clipPath: "url(#clip0_297_2300)", children: [jsx("path", { d: "M91.7394 11.8865C91.7803 10.4995 91.7909 9.58382 91.7705 9.14601C91.7156 7.98967 91.4236 7.04721 90.8966 6.31195C90.3697 5.5767 89.4247 4.87486 88.0886 4.78128C85.8182 4.62755 84.8462 4.99183 83.2655 6.19498C82.5381 6.74642 81.8208 7.64544 81.1852 8.34393L81.3415 5.3862H77.1061C77.1809 7.94956 77.1775 10.5229 77.0959 13.1031L77.0109 15.2888C76.9701 16.141 76.9225 16.9932 76.8647 17.8488H81.1274C81.1172 17.0066 81.1443 15.8736 81.2123 14.4499C81.2803 13.0295 81.3619 11.9968 81.4639 11.3451C81.6236 10.4126 82.0046 9.63732 82.6027 9.02573C83.2008 8.41077 83.9454 7.66883 84.8699 7.66883C86.5865 7.70893 87.484 9.38328 87.6403 11.8331C87.7082 13.2066 87.6943 15.2152 87.6059 17.8488H91.8179C91.7328 16.1644 91.7091 14.1759 91.7394 11.8865Z", fill: "#878787" }), jsx("path", { d: "M70.8993 16.094C69.6314 16.1241 68.5607 15.586 67.7176 15.0079C66.8747 14.4297 66.4192 13.4137 66.3477 11.9532H76.0593V10.9806C75.8622 6.92673 73.6051 4.90479 69.2337 4.90479C68.1051 4.90479 67.0854 5.0886 66.1778 5.45622C65.2702 5.82385 64.5054 6.33853 63.8697 7.00695C63.2409 7.66868 62.7718 8.44069 62.4727 9.31301C62.1701 10.1919 62.0409 11.1311 62.0919 12.1337C62.1667 13.6777 62.595 14.9009 63.3734 15.7966C64.1553 16.6956 65.1274 17.3206 66.2933 17.6648C67.4593 18.0091 68.7204 18.263 70.0665 18.1828C72.361 18.0491 74.5875 16.9563 76.0593 16.0172V14.0988C74.4414 15.195 72.0211 16.0673 70.8993 16.094ZM66.2253 10.5261C66.1778 9.55028 66.4089 8.70469 66.9222 7.98617C67.4389 7.26428 68.2411 6.88329 69.3323 6.8365C69.9033 6.8365 70.386 6.96684 70.7803 7.22084C71.178 7.47483 71.4738 7.80904 71.6709 8.22012C71.8681 8.62785 71.9803 9.06567 72.0041 9.52688C72.0109 9.6672 71.9973 9.84769 71.9667 10.0783C71.9361 10.3022 71.9157 10.4493 71.9123 10.5261H66.2253Z", fill: "#878787" }), jsx("path", { d: "M62.0138 5.39624H57.9823L58.1285 1.92383L54.1003 2.76603C53.876 6.74309 53.8114 10.7335 53.7095 14.7239C53.7026 15.0214 53.6823 15.3924 53.7061 15.8368C53.7367 16.4451 53.9372 16.9364 54.148 17.3107C54.3587 17.6817 54.6918 17.9657 55.1337 18.1563C55.5756 18.3468 56.3643 18.5372 57.1087 18.4938C58.8321 18.3902 59.7363 18.0827 60.4705 17.8288L60.909 15.5394C60.4909 15.6864 60.0116 15.8101 59.6717 15.8368C58.9612 15.887 58.5262 15.8435 57.9517 15.252C57.6016 14.8877 57.7851 12.7588 57.8021 12.0871L57.9075 7.95292H61.4631C61.5549 7.09736 61.7827 6.3153 62.0138 5.39624Z", fill: "#878787" }), jsx("path", { d: "M51.4557 7.79912L51.6257 5.51983C49.8478 5.15554 47.9443 4.94165 46.6764 5.01851C45.1841 5.10541 43.9808 5.33935 43.0766 5.89414C42.1758 6.45226 41.7475 7.27107 41.8018 8.34387C41.8291 8.94547 41.9922 9.4534 42.2811 9.86453C42.5701 10.2789 43.046 10.7535 43.7122 11.2916C43.8822 11.4319 44.2221 11.6826 44.7286 12.0469C45.2351 12.4145 45.643 12.7253 45.9523 12.986C46.2651 13.2467 46.5234 13.5307 46.7444 13.8382C46.9585 14.1457 47.0775 14.4632 47.0945 14.784C47.0673 15.2619 46.826 15.5961 46.3738 15.7866C45.9252 15.9738 45.3982 16.0708 44.8068 16.0708C44.2255 16.0373 43.6 15.9371 42.9169 15.7666C42.237 15.5928 41.6659 15.3722 41.207 15.1115L41.5164 17.9189C42.9882 18.2664 44.7116 18.4402 46.69 18.4402C47.5092 18.4402 48.3012 18.2932 49.0694 18.0058C49.8376 17.7117 50.4563 17.3039 50.9254 16.7826C51.3945 16.2545 51.6121 15.663 51.5815 15.0046C51.5509 14.3964 51.3265 13.8215 50.905 13.2901C50.4869 12.762 49.8717 12.204 49.0661 11.6224C48.8485 11.4787 48.5799 11.3016 48.2604 11.0911C47.9409 10.8738 47.635 10.6365 47.3427 10.3658C47.0537 10.0917 46.8123 9.79769 46.6186 9.4768C46.4283 9.15599 46.2855 8.81513 46.3059 8.4575C46.35 7.73895 47.0469 7.33791 48.2672 7.29112C49.0729 7.2577 49.943 7.37801 51.4557 7.79912Z", fill: "#878787" }), jsx("path", { d: "M40.459 8.32386L40.7479 4.92163C39.9151 4.92163 38.5826 5.22577 37.7396 5.69365C36.917 6.15151 36.4139 6.68624 35.6593 7.43153L35.7375 5.41292C34.3132 5.41292 32.9739 5.36947 31.5496 5.36947C31.7161 9.63397 31.7569 13.7113 31.5088 17.9658H35.8497C35.8258 17.4812 35.7443 17.0634 35.7238 16.7024C35.6593 15.6129 35.6083 14.6337 35.6253 13.7614C35.6422 12.8891 35.7273 12.0402 35.87 11.2315C36.0162 10.416 36.2099 9.66065 36.5396 9.27635C37.2399 8.46088 38.2767 8.21357 39.3882 8.21357C39.7553 8.21357 40.1122 8.24699 40.459 8.32386Z", fill: "#878787" }), jsx("path", { d: "M24.2312 5.07852C22.1339 5.10192 20.0467 5.36928 17.9086 5.77368L17.6435 7.81233C18.8842 7.41128 20.1793 7.11384 21.539 6.84982C24.7445 6.22485 27.1749 9.11574 23.2692 10.0983C20.0196 10.9104 16.9365 11.6825 16.2362 13.0794C14.8595 15.8233 16.9501 17.5946 19.7646 18.2095C21.5798 18.6072 23.3779 18.5036 25.1523 17.9622C26.5427 17.9555 27.7018 17.9488 29.092 17.9388C29.1091 14.5867 29.3164 11.2346 29.2892 7.87918C29.2756 5.90401 27.1409 5.04845 24.2312 5.07852ZM25.3088 15.9135C24.068 16.368 22.936 16.6354 21.4812 16.2744C19.9584 15.8968 19.5641 13.9685 21.1651 13.1062C22.552 12.3542 24.4793 11.8997 25.5365 11.2346L25.3088 15.9135Z", fill: "#878787" }), jsx("path", { d: "M16.6135 0.5C14.8935 0.5 13.1735 0.5 11.4535 0.5C8.955 2.37156 5.90933 5.30589 4.76379 8.58446C4.77399 7.47824 4.79439 6.12804 4.82838 4.53054C4.85897 2.8194 4.87937 1.47589 4.89297 0.5H0.249625C0.259823 2.42503 0.27342 3.87549 0.27342 4.85805C0.280218 5.84062 0.283618 7.12732 0.283618 8.73148C0.287018 10.3357 0.280219 11.95 0.259824 13.5808C0.242828 15.2118 0.219032 16.6389 0.181641 17.8587H4.99154C4.98135 17.6615 4.96435 17.3741 4.93716 16.9931C4.90996 16.6121 4.88956 16.3247 4.88277 16.1375C4.82158 14.8709 4.78419 13.6209 4.77059 12.3944C4.757 11.2514 4.7536 10.5596 4.76379 9.48347C6.27985 11.1612 7.39819 12.4981 8.22761 13.6978C9.09099 14.9478 9.80141 16.3314 10.6784 17.8587H16.1478L8.80209 8.67804C9.04001 6.5057 13.9791 1.58617 16.6135 0.5Z", fill: "#878787" })] }), jsx("defs", { children: jsx("clipPath", { id: "clip0_297_2300", children: jsx("rect", { width: "91.6364", height: "18", fill: "white", transform: "translate(0.181641 0.5)" }) }) })] }));
245
+ }
246
+
247
+ function BasicHeader() {
248
+ return (jsx(Fragment, { children: jsx("div", { className: "w-100 min-h-16 border-b border-b-stone flex flex-row justify-between items-center px-8 shadow-header", children: jsx("div", { className: "flex flex-row items-center gap-4", children: jsx(LogoSmall, {}) }) }) }));
249
+ }
250
+
251
+ function Breadcrumb({ items }) {
252
+ return (jsx("nav", { className: "w-100", children: jsx("ol", { className: "flex items-center gap-2", children: items?.map((item, index) => (jsxs("li", { className: "flex flex-row gap-2", "aria-label": "breadcrumb", children: [jsx(Link$1, { to: item.href, className: clsx('text-base text-primary hover:underline'), children: item.label }), index < items.length - 1 && (jsx("span", { className: "text-base text-primary", children: '>' }))] }, index))) }) }));
253
+ }
254
+
255
+ const variants$3 = {
256
+ primary: 'bg-primary !text-background border-primary hover:bg-primaryActive disabled:bg-stoneDark disabled:border-stoneDark',
257
+ outline: 'bg-background !text-primary border-primary hover:bg-stone disabled:bg-stoneDark disabled:text-background disabled:border-stoneDark',
258
+ secondary: 'bg-stoneLight !text-grayDark border-stoneLight hover:bg-stone hover:border-stone disabled:bg-stone disabled:border-stone',
259
+ secondaryOutline: 'bg-transparent !text-backgroundDark border-stoneDark hover:bg-stone disabled:text-stoneDark',
260
+ gray: 'bg-gray !text-background border-gray hover:bg-grayDark hover:border-grayDark ',
261
+ grayOutline: 'bg-transparent !text-gray100 border-gray50 hover:bg-stone disabled:bg-stone disabled:text-stoneDark',
262
+ tab: 'bg-background !text-primary border-background hover:bg-secondaryActive hover:border-grayDark disabled:bg-stoneDark disabled:text-background disabled:border-stoneDark',
263
+ };
264
+ function Button({ variant = 'primary', selected = false, rightIcon, className, width = 'w-100', ...props }) {
265
+ return (jsx(Button$1, { ...props, className: clsx('!py-2 !shadow-none font-roboto', variants$3[variant], selected && variant === 'tab' && 'bg-secondary border-grayDark ', width, className), "aria-label": "componente de bot\u00E3o", children: rightIcon && jsx("span", { className: `pi pl-2 ${rightIcon}`, children: " " }) }));
266
+ }
267
+
268
+ addLocale('pt-BR', {
269
+ firstDayOfWeek: 0,
270
+ dayNames: [
271
+ 'domingo',
272
+ 'segunda-feira',
273
+ 'terça-feira',
274
+ 'quarta-feira',
275
+ 'quinta-feira',
276
+ 'sexta-feira',
277
+ 'sábado',
278
+ ],
279
+ dayNamesShort: ['dom', 'seg', 'ter', 'qua', 'qui', 'sex', 'sáb'],
280
+ dayNamesMin: ['D', 'S', 'T', 'Q', 'Q', 'S', 'S'],
281
+ monthNames: [
282
+ 'janeiro',
283
+ 'fevereiro',
284
+ 'março',
285
+ 'abril',
286
+ 'maio',
287
+ 'junho',
288
+ 'julho',
289
+ 'agosto',
290
+ 'setembro',
291
+ 'outubro',
292
+ 'novembro',
293
+ 'dezembro',
294
+ ],
295
+ monthNamesShort: [
296
+ 'jan',
297
+ 'fev',
298
+ 'mar',
299
+ 'abr',
300
+ 'mai',
301
+ 'jun',
302
+ 'jul',
303
+ 'ago',
304
+ 'set',
305
+ 'out',
306
+ 'nov',
307
+ 'dez',
308
+ ],
309
+ today: 'Hoje',
310
+ clear: 'Limpar',
311
+ dateFormat: 'dd/mm/yy',
312
+ });
313
+ function CalendarInput({ error, placeholder = 'Selecione uma data', label, disabled = false, ...props }) {
314
+ const calendarRef = useRef(null);
315
+ const hasError = (error && !disabled) || (!!error && !disabled);
316
+ const dateTemplate = (data) => {
317
+ const date = new Date(`${data.year}/${data.month + 1}/${data.day}`);
318
+ const dayComponent = (className) => {
319
+ return (jsx("div", { className: `w-full h-full flex justify-center items-center text-grayDark ${className}`, children: data.day }));
320
+ };
321
+ if (props.selectionMode === 'range') {
322
+ const [start, end] = Array.isArray(props.value)
323
+ ? props.value
324
+ : [null, null];
325
+ if (start && date.getTime() === start.getTime()) {
326
+ return dayComponent('bg-stone');
327
+ }
328
+ if (start && end && date >= start && date <= end) {
329
+ return dayComponent('bg-stone');
330
+ }
331
+ return dayComponent();
332
+ }
333
+ if (props.selectionMode === 'single' || !props.selectionMode) {
334
+ const selectedDate = props.value;
335
+ if (selectedDate && date.getTime() === selectedDate.getTime()) {
336
+ return dayComponent('bg-stone');
337
+ }
338
+ }
339
+ return dayComponent();
340
+ };
341
+ const handleInputClick = () => {
342
+ if (!disabled) {
343
+ calendarRef.current?.show();
344
+ }
345
+ };
346
+ return (jsx("div", { className: "relative flex flex-col w-full min-w-full", children: jsxs("div", { onClick: handleInputClick, children: [jsx(FloatingLabel, { value: props?.value ? props.value.toString() : '', label: label, disabled: disabled, error: error }), jsxs("div", { className: "relative w-full min-w-full", children: [jsx(Calendar, { ...props, disabled: disabled, placeholder: placeholder, ref: calendarRef, panelStyle: { width: '530px', height: '500px' }, className: clsx('w-full min-w-full focus:shadow-none border-none z-0 font-roboto border rounded-md', hasError
347
+ ? 'border-redError placeholder:!text-redError p-invalid'
348
+ : 'border-gray focus:border-primary', disabled && 'border-stoneDark text-disabled', error && 'border-redError text-redError p-invalid', !error && 'border-gray p-custom'), dateFormat: "dd/mm/yy", inputStyle: {
349
+ border: `1px solid ${error && !props.value ? '#EC4A54' : '#a0a4b3'}`,
350
+ boxShadow: 'none',
351
+ color: hasError ? '#EC4A54' : '',
352
+ height: '42px',
353
+ fontSize: '16px',
354
+ }, hideOnDateTimeSelect: true, hideOnRangeSelection: true, todayButtonClassName: "bg-primary text-background", dateTemplate: dateTemplate, invalid: hasError, locale: "pt-BR" }), jsx(InputIcon, { className: clsx(`pi pi-calendar text-gray cursor-pointer absolute right-3 top-1/2 transform -translate-y-1/2`, disabled && 'text-disabled', hasError && 'text-redError') })] }), hasError && (jsx("div", { className: "mb-4", children: jsx("span", { className: "absolute text-redError text-xs px-2", children: error }) }))] }) }));
355
+ }
356
+
357
+ function Card({ children, className, ariaLabel = 'Card de informação', }) {
358
+ return (jsx("div", { className: clsx('bg-background shadow-container rounded-md p-3', className ? className : 'w-full h-full'), "aria-label": ariaLabel, children: children }));
359
+ }
360
+
361
+ function CardButton({ label, description, onClick, isLight = true, }) {
362
+ return (jsxs("div", { className: `cursor-pointer rounded-2xl p-4 h-[160px] w-full bg-gradient-to-br hover:shadow-md transition-shadow duration-200 border ${isLight ? 'border-[#f3f4f6] from-[#f3f4f6] to-white' : 'border-[#13294B] from-[#13294B] to-[#0C1C34]'}`, onClick: () => {
363
+ if (onClick)
364
+ onClick();
365
+ }, children: [jsx("h3", { className: `text-lg font-bold ${isLight ? 'text-[#13294B]' : 'text-white'}`, children: label }), description && (jsx("p", { className: `text-sm mt-2 line-clamp-3 ${isLight ? 'text-[#13294B]' : 'text-white'}`, children: description }))] }));
366
+ }
367
+
368
+ function CardIconsButton({ label, leftIcon, onClick, isLight = true, }) {
369
+ return (jsxs("div", { className: `cursor-pointer rounded-xl p-4 w-full min-h-[60px] bg-gradient-to-br hover:shadow-md transition-shadow duration-200 border flex items-center justify-between gap-4 ${isLight ? 'border-[#f3f4f6] from-[#f3f4f6] to-white' : 'border-[#13294B] from-[#13294B] to-[#0C1C34]'}`, onClick: () => {
370
+ if (onClick)
371
+ onClick();
372
+ }, "aria-label": `Botão de navegação para ${label}`, children: [jsxs("div", { className: "flex items-center gap-3 flex-grow overflow-hidden", children: [leftIcon && (jsx("div", { className: `text-xl flex-shrink-0 flex items-center ${isLight ? 'text-[#13294B]' : 'text-white'}`, children: leftIcon })), jsx("h3", { className: `text-base font-semibold break-words ${isLight ? 'text-[#646981]' : 'text-white'}`, children: label })] }), jsx("div", { className: "flex items-center justify-center h-full", children: jsx("i", { className: `pi pi-angle-right text-xl flex-shrink-0 ${isLight ? 'text-[#646981]' : 'text-white'}` }) })] }));
373
+ }
374
+
375
+ function Chart(props) {
376
+ return jsx(Chart$1, { ...props });
377
+ }
378
+
379
+ function Dialog({ title, description, labelConfirmButton, onClose, onClick, }) {
380
+ return (jsx("div", { className: "fixed inset-0 bg-black bg-opacity-50 z-20 flex justify-center items-center", children: jsxs(Card, { className: "flex flex-col", children: [jsxs("div", { className: "flex flex-row items-center justify-between px-4 pt-4 pb-6 border-b border-b-stone", children: [jsx("h2", { className: "text-primary font-semibold", children: title }), jsx("i", { className: "pi pi-times", style: { color: '#606060', cursor: 'pointer' }, onClick: onClose })] }), jsxs("div", { className: "flex flex-col items-center p-6", children: [jsx("span", { className: "text-primary", children: description }), jsxs("div", { className: "w-100 flex flex-row justify-end pt-10 gap-4", children: [jsx("div", { className: "w-1/3", children: jsx(Button, { label: "Cancelar", variant: "outline", onClick: onClose }) }), jsx("div", { className: "w-1/3", children: jsx(Button, { label: labelConfirmButton, variant: "primary", onClick: onClick }) })] })] })] }) }));
381
+ }
382
+
383
+ function Divider({ ...props }) {
384
+ return jsx(Divider$1, { ...props });
385
+ }
386
+
387
+ function EmptyContent({ message = 'Não há dados disponíveis.' }) {
388
+ return (jsx("div", { className: "p-6 text-justify text-primary bg-stoneBackground", children: jsxs("div", { className: 'py-2 px-4 rounded-lg font-semibold', children: [jsx("i", { className: 'pi pi-database mr-2' }), message] }) }));
389
+ }
390
+
391
+ function ExpandablePanel({ title, children, defaultOpen = true, isLight = true, }) {
392
+ const [isOpen, setIsOpen] = useState(defaultOpen);
393
+ return (jsx("div", { className: "relative p-[2px] rounded-lg bg-gradient-to-r from-[#FAFAFB] via-[#FAFAFB] to-[#FAFAFB] mb-4", children: jsxs("div", { className: "bg-white rounded-lg overflow-hidden", children: [jsxs("div", { className: `flex justify-between items-center px-4 py-2 cursor-pointer bg-gradient-to-r ${isLight ? 'from-[#FFFFFF] via-[#FAFAFB] to-[#FFFFFF]' : 'from-[#13294B] to-[#0C1C34]'}`, onClick: () => setIsOpen(!isOpen), children: [jsx("div", { className: `text-xl font-bold ${isLight ? 'text-primary' : 'text-white'}`, children: title }), jsx("button", { children: isOpen ? (jsx("i", { className: `pi pi-chevron-down ${isLight ? 'text-primary' : 'text-white'}` })) : (jsx("i", { className: `pi pi-chevron-up ${isLight ? 'text-primary' : 'text-white'}` })) })] }), isOpen && jsx("div", { className: "p-4 text-primary", children: children })] }) }));
394
+ }
395
+
396
+ function FileUpload({ label = 'Enviar arquivos', value = [], onChange, multiple = true, fileTypes, className, error, disabled = false, }) {
397
+ const [isDragging, setIsDragging] = useState(false);
398
+ const fileInputRef = useRef(null);
399
+ const [uploadFiles, setUploadFiles] = useState(value);
400
+ useEffect(() => {
401
+ setUploadFiles(value);
402
+ }, [value]);
403
+ const updateFiles = (newFiles) => {
404
+ setUploadFiles(newFiles);
405
+ onChange?.(newFiles);
406
+ };
407
+ const generateFileWithPreview = (files, allowedTypes = ['image', 'pdf']) => {
408
+ const allowedMimeTypes = getAcceptedMimeTypes(allowedTypes).split(',');
409
+ return Array.from(files)
410
+ .filter((file) => allowedMimeTypes.some((mime) => {
411
+ if (mime === 'image/*')
412
+ return file.type.startsWith('image/');
413
+ return file.type === mime;
414
+ }))
415
+ .map((file) => {
416
+ const type = file.type.startsWith('image/') ? 'image' : 'pdf';
417
+ const previewUrl = type === 'image' ? URL.createObjectURL(file) : undefined;
418
+ return { file, type, previewUrl };
419
+ });
420
+ };
421
+ const getAcceptedMimeTypes = (types = ['image', 'pdf']) => {
422
+ const mimeMap = {
423
+ image: 'image/*',
424
+ pdf: 'application/pdf',
425
+ };
426
+ return types.map((type) => mimeMap[type]).join(',');
427
+ };
428
+ const handleFileChange = (selectedFiles) => {
429
+ if (!selectedFiles)
430
+ return;
431
+ const newFiles = generateFileWithPreview(selectedFiles, fileTypes);
432
+ updateFiles([...(uploadFiles || []), ...newFiles]);
433
+ };
434
+ const handleRemoveFile = (fileToRemove) => {
435
+ const updated = uploadFiles
436
+ .map((file) => {
437
+ if (file.id && file.id === fileToRemove.id) {
438
+ return { ...file, isDeleted: true };
439
+ }
440
+ if (!file.id && file.file === fileToRemove.file) {
441
+ return null;
442
+ }
443
+ return file;
444
+ })
445
+ .filter(Boolean);
446
+ updateFiles(updated);
447
+ };
448
+ const getSupportedFileText = (types = ['image', 'pdf']) => {
449
+ const includesImage = types.includes('image');
450
+ const includesPdf = types.includes('pdf');
451
+ if (includesImage && includesPdf)
452
+ return 'Suporta imagens e PDFs';
453
+ if (includesImage)
454
+ return 'Suporta apenas imagens';
455
+ if (includesPdf)
456
+ return 'Suporta apenas PDFs';
457
+ return '';
458
+ };
459
+ const handleDragOver = (e) => {
460
+ e.preventDefault();
461
+ setIsDragging(true);
462
+ };
463
+ const handleDragLeave = (e) => {
464
+ e.preventDefault();
465
+ setIsDragging(false);
466
+ };
467
+ const handleDrop = (e) => {
468
+ e.preventDefault();
469
+ setIsDragging(false);
470
+ if (isDisabled || disabled)
471
+ return;
472
+ handleFileChange(e.dataTransfer.files);
473
+ };
474
+ const visibleFiles = uploadFiles.filter((file) => !file.isDeleted);
475
+ const isDisabled = !multiple && visibleFiles.length > 0;
476
+ return (jsxs("div", { className: clsx('space-y-3', className), children: [jsx("label", { htmlFor: "file-upload", className: "text-[18px] font-medium text-primary", children: label }), jsxs("div", { role: "button", "aria-label": "\u00C1rea de envio de arquivos", "aria-disabled": isDisabled || disabled, className: clsx('border-2 border-dashed rounded-lg p-2 text-center cursor-pointer transition-colors', isDragging && !error
477
+ ? 'border-primary bg-primary/5'
478
+ : 'border-[#e6e6e6] hover:border-primary/50', isDisabled || (disabled && 'bg-gray-200 cursor-auto'), error && 'border-red-500 hover:border-red-500'), onDragOver: handleDragOver, onDragLeave: handleDragLeave, onDrop: handleDrop, onClick: () => fileInputRef.current?.click(), children: [jsx("input", { id: "file-upload", ref: fileInputRef, type: "file", onChange: (e) => handleFileChange(e.target.files), className: "hidden", multiple: multiple, accept: getAcceptedMimeTypes(fileTypes), disabled: isDisabled || disabled }), jsxs("div", { className: "flex flex-col items-center justify-center space-y-3", children: [jsx("i", { className: "pi pi-upload text-xl text-[#a0a4b3]" }), jsx("p", { className: "text-lg font-semibold text-primary", children: isDisabled ? 'Limite atingido' : 'Arraste e solte arquivos aqui' }), jsx("p", { className: "text-sm text-[#a0a4b3]", children: isDisabled
479
+ ? 'Já possui um arquivo selecionado'
480
+ : 'ou clique para selecionar arquivos' }), jsx("p", { className: "text-xs text-[#a0a4b3]", children: getSupportedFileText(fileTypes) })] })] }), error && (jsx("span", { className: "text-redError text-xs", role: "alert", "aria-live": "assertive", children: error })), visibleFiles.length > 0 && (jsxs("div", { className: "space-y-4", children: [jsxs("p", { className: "text-base text-[#a0a4b3]", children: ["Arquivos selecionados (", visibleFiles.length, ")"] }), jsx("div", { className: "grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-4", children: visibleFiles.map((file, index) => (jsxs("div", { className: "relative group overflow-hidden rounded border border-gray-200", children: [jsx("div", { className: "aspect-square bg-[#e6e6e6] flex items-center justify-center", children: file.type === 'image' && file.previewUrl ? (jsx("img", { src: file?.previewUrl, alt: file?.file?.name || file?.name, className: "object-cover w-full h-full transition-transform duration-300 ease-in-out group-hover:scale-105" })) : (jsxs("div", { className: "flex flex-col items-center justify-center p-4 transition-transform duration-300 ease-in-out group-hover:scale-105", children: [jsx("i", { className: "pi pi-file-pdf text-4xl text-primary" }), jsx("span", { className: "mt-2 text-xs text-center truncate max-w-full", children: file?.file?.name || file?.name })] })) }), jsx("button", { type: "button", className: "absolute top-1 right-1 w-6 h-6 flex items-center justify-center bg-primary hover:bg-primaryActive rounded-full transition-colors", onClick: (e) => {
481
+ e.stopPropagation();
482
+ handleRemoveFile(file);
483
+ }, "aria-label": `Remover o arquivo ${file.file?.name || file.name}`, children: jsx("i", { className: "pi pi-times text-white text-xs hover:text-slate-200" }) })] }, index))) })] }))] }));
484
+ }
485
+
486
+ const variants$2 = {
487
+ green: {
488
+ text: '!text-green',
489
+ button: 'bg-greenBackground hover:bg-greenBackgroundActive',
490
+ },
491
+ main: {
492
+ text: '!text-white',
493
+ button: 'bg-gray hover:bg-grayDark',
494
+ },
495
+ primary: {
496
+ text: '!text-white',
497
+ button: 'bg-primary hover:bg-primaryActive',
498
+ },
499
+ };
500
+ function FilterButton({ filterOptions, setOption, option, variant, icon, label, ...props }) {
501
+ const [isOpen, setIsOpen] = useState(false);
502
+ const toggleDropdown = () => {
503
+ setIsOpen(!isOpen);
504
+ };
505
+ const handleSelect = (selectedOption) => {
506
+ setIsOpen(false);
507
+ setOption(selectedOption.value === option?.value ? null : selectedOption);
508
+ };
509
+ return (jsxs("div", { className: "relative flex flex-col items-end", children: [jsx(Button$1, { ...props, icon: icon, label: label, className: clsx('w-max shadow-none border-none !py-2 gap-2 items-center disabled:bg-stoneDark', props.disabled ? '!disabled:text-background' : variants$2[variant].text, variants$2[variant].button), onClick: toggleDropdown }), isOpen && (jsx("div", { className: `absolute w-40 bg-background shadow-md border border-gray z-[9] rounded-md p-2 -bottom-1 translate-y-full`, children: jsx("ul", { children: filterOptions.map((filterOption) => (jsxs("li", { onClick: () => handleSelect(filterOption), className: "p-2 flex justify-between items-center cursor-pointer", children: [filterOption.label, jsx("input", { type: "radio", onChange: () => handleSelect(filterOption), checked: filterOption?.value === option?.value, className: "appearance-none w-2 h-2 rounded-full ring-1 ring-offset-2 ring-offset-background ring-gray checked:bg-primary cursor-pointer" })] }, filterOption.value))) }) }))] }));
510
+ }
511
+
512
+ function Sidebar({ item, onClose, topItem }) {
513
+ return (jsxs("div", { className: "relative w-100", children: [jsx("div", { className: "fixed bottom-0 w-100 h-[calc(100vh_-_64px)] bg-backgroundDark/20 z-50", onClick: onClose }), jsxs("div", { className: "fixed h-[calc(100vh_-_64px)] bottom-0 w-72 bg-background z-50", children: [jsx("div", { className: "cursor-pointer flex flex-row gap-3 items-center border-b pl-6 px-2 py-2 border-b-stone hover:bg-stoneBackground hover:font-bold", children: jsx(Link$1, { to: "/", className: "font-roboto text-base text-backgroundDark hover:font-bold", onClick: onClose, "aria-label": "Ir para o inicio", children: "In\u00EDcio" }, "home-id") }, 'home-div'), topItem &&
514
+ topItem.map((item) => (jsxs("div", { className: "cursor-pointer flex flex-row gap-3 items-center border-b pl-6 px-2 py-2 border-b-stone hover:bg-stoneBackground hover:font-bold", children: [item?.isWindowOpen && (jsx("button", { className: "font-roboto text-base text-backgroundDark hover:font-bold", onClick: () => {
515
+ if (onClose)
516
+ onClose();
517
+ if (typeof window !== 'undefined') {
518
+ window.open(item?.path, '_blank');
519
+ }
520
+ }, "aria-label": `Ir para ${item?.title}`, children: item?.title }, item?.id || item.title)), !item?.isWindowOpen && (jsx(Link$1, { to: item?.path || '', className: "font-roboto text-base text-backgroundDark hover:font-bold", onClick: onClose, "aria-label": `Ir para ${item?.title}`, children: item?.title }, item?.id || item.title))] }, `top-item-${item?.id ?? item.title}`))), jsxs("div", { className: "flex flex-row gap-3 items-center pl-6 pt-8 pb-4", children: [jsx("i", { className: "pi pi-star !text-backgroundDark !font-bold text-lg" }), jsx("p", { className: "text-backgroundDark font-bold text-lg", children: "Favoritos" })] }), jsx("div", { className: "overflow-y-auto overflow-x-hidden [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-track]:rounded-r-md [&::-webkit-scrollbar-thumb]:rounded-md [&::-webkit-scrollbar-track]:bg-stone [&::-webkit-scrollbar-thumb]:bg-stoneDark", children: item &&
521
+ item.map((item) => (jsx(Link$1, { className: "flex flex-row items-center pl-6 gap-2 border-b border-b-stone hover:bg-stoneBackground hover:font-bold", to: item.path || '', onClick: onClose, "aria-label": `Ir para ${item.title}`, children: jsx("span", { className: "font-roboto text-base py-2 text-backgroundDark hover:font-bold", children: item.title }) }, item.id))) })] }, 'sidebar-div')] }));
522
+ }
523
+
524
+ function Header({ sidebarItems, sidebarTopItems, username, userConfigItems, setOpenNotifications, }) {
525
+ const [openSidebar, setOpenSidebar] = useState(false);
526
+ const [openUserConfig, setOpenUserConfig] = useState(false);
527
+ const userConfigRef = useRef(null);
528
+ useEffect(() => {
529
+ function handleClickOutside(event) {
530
+ if (userConfigRef.current &&
531
+ !userConfigRef.current.contains(event.target)) {
532
+ setOpenUserConfig(false);
533
+ }
534
+ }
535
+ if (openUserConfig) {
536
+ document.addEventListener('mousedown', handleClickOutside);
537
+ }
538
+ else {
539
+ document.removeEventListener('mousedown', handleClickOutside);
540
+ }
541
+ return () => {
542
+ document.removeEventListener('mousedown', handleClickOutside);
543
+ };
544
+ }, [openUserConfig]);
545
+ return (jsxs(Fragment, { children: [jsxs("div", { className: "w-100 min-h-16 border-b border-b-stone flex flex-row justify-between items-center px-8 shadow-header", children: [jsxs("div", { className: "flex flex-row items-center gap-4", children: [jsx("button", { className: "bg-transparent border-none", onClick: () => setOpenSidebar(!openSidebar), "aria-label": "Abrir menu lateral", children: jsx("i", { className: `${openSidebar ? 'pi pi-list' : 'pi pi-bars'} text-[#878787] cursor-pointer hover:text-backgroundDark text-xl mt-1 }` }) }), jsx(LogoSmall, {})] }), jsxs("div", { className: "relative flex flex-row gap-4 items-center", children: [jsx("button", { className: "bg-transparent border-none", onClick: () => setOpenNotifications(true), "aria-label": "Abrir notifica\u00E7\u00E3o", children: jsx("i", { className: "pi pi-bell text-[#878787] cursor-pointer hover:text-backgroundDark" }) }), jsxs("div", { ref: userConfigRef, className: "relative", children: [jsx("button", { className: "bg-transparent border-none", onClick: () => setOpenUserConfig(!openUserConfig), "aria-label": "Abrir menu de configura\u00E7\u00F5es do usu\u00E1rio", children: jsxs("p", { className: "text-[#878787] hover:text-backgroundDark font-roboto font-bold cursor-pointer transition-colors duration-200", children: ["Ol\u00E1, ", username] }) }), openUserConfig && (jsx("div", { className: `absolute w-100 bg-background shadow-md border border-stoneLight z-20 rounded-md p-2 -bottom-1 translate-y-full`, children: jsx("ul", { children: userConfigItems.map(({ id, title, onClick, path }) => (jsx("li", { className: "p-2 hover:bg-stoneBackground", children: jsx("a", { onClick: () => {
546
+ if (onClick)
547
+ onClick();
548
+ setOpenUserConfig(false);
549
+ }, href: path, className: "block w-full font-base font-roboto text-backgroundDark cursor-pointer hover:font-bold", "aria-label": "Op\u00E7\u00F5es de configura\u00E7\u00F5es do usu\u00E1rio", children: title }) }, id))) }) }))] })] })] }), openSidebar && (jsx(Sidebar, { topItem: sidebarTopItems, item: sidebarItems, onClose: () => {
550
+ setOpenSidebar(false);
551
+ } }))] }));
552
+ }
553
+
554
+ const variants$1 = {
555
+ border: 'border-primary hover:border-primary shadow-none',
556
+ shadow: 'border-background hover:border-stone focus:shadow-md',
557
+ };
558
+ function IconButton({ variant, icon, ...props }) {
559
+ return (jsx(Button$1, { ...props, icon: `pi ${icon}`, rounded: true, text: variant === 'shadow', raised: variant === 'shadow', outlined: variant === 'border', className: clsx('bg-background text-primary hover:bg-stone disabled:bg-stoneDark disabled:border-stoneDark disabled:text-background', variants$1[variant]) }));
560
+ }
561
+
562
+ function InfoCard({ title, children, icon, className, titleClassName, }) {
563
+ return (jsxs("div", { className: clsx('bg-background rounded-lg p-4 border border-stone overflow-hidden', className), children: [jsxs("div", { className: "flex justify-between items-center mb-2", children: [jsx("span", { className: clsx('text-sm font-roboto text-primary', titleClassName), children: title }), icon] }), jsx("div", { className: "font-roboto text-primary break-words overflow-wrap break-all max-w-full", children: children })] }));
564
+ }
565
+
566
+ function InputSwitch({ checked, onChange, disabled = false, error, ariaLabel = 'Switch', }) {
567
+ const inputId = useId();
568
+ return (jsxs("div", { className: "flex flex-col gap-1", children: [jsx(InputSwitch$1, { id: inputId, checked: checked, onChange: (e) => onChange(e.value), disabled: disabled, className: clsx('transition-all border-2 rounded-full p-inputswitch', disabled
569
+ ? 'opacity-50 cursor-not-allowed border-none'
570
+ : 'border-none', error ? 'p-inputswitch-error' : '', checked ? 'p-inputswitch-checked' : ''), "aria-label": ariaLabel }), error && jsx("span", { className: "text-redError text-xs", children: error })] }));
571
+ }
572
+
573
+ function InputTextArea({ onChange, placeholder, disabled = false, error, label, rows = 2, ...props }) {
574
+ const inputTextAreaId = useId();
575
+ const handleChange = (e) => {
576
+ onChange(e.target.value);
577
+ };
578
+ const hasError = (props.value && error && !disabled) ||
579
+ (!!error && !disabled && props.value?.length === 0);
580
+ return (jsxs("div", { className: "relative flex flex-col w-full", children: [jsx(InputTextarea, { id: inputTextAreaId, rows: rows, placeholder: placeholder, onChange: handleChange, disabled: disabled, invalid: hasError, className: clsx('w-100 font-roboto border !p-2 rounded-md focus:shadow-none', hasError
581
+ ? 'border-redError placeholder:text-redError'
582
+ : 'border-gray focus:border-primary', disabled && 'border-stoneDark text-disabled', error && 'border-redError text-redError', !error && 'border-gray placeholder:text-gray'), ...props }), jsx(FloatingLabel, { value: props?.value ? props.value.toString() : '', label: label || '', disabled: disabled, error: error }), hasError && jsx("span", { className: "text-redError text-xs px-2", children: error })] }));
583
+ }
584
+
585
+ function TextIcon() {
586
+ return (jsxs("svg", { width: "16", height: "10", viewBox: "0 0 16 10", fill: "none", children: [jsx("path", { d: "M1 1H14.5", stroke: "#666666", strokeWidth: "2", strokeLinecap: "round" }), jsx("path", { d: "M1 5H14.5", stroke: "#666666", strokeWidth: "2", strokeLinecap: "round" }), jsx("path", { d: "M1 9H10", stroke: "#666666", strokeWidth: "2", strokeLinecap: "round" })] }));
587
+ }
588
+
589
+ function InternalMenu({ item, isFiltering }) {
590
+ const [openItems, setOpenItems] = useState([]);
591
+ const toggleMenu = (menuItem) => {
592
+ setOpenItems((prev) => prev.includes(menuItem)
593
+ ? prev.filter((item) => item !== menuItem)
594
+ : [...prev, menuItem]);
595
+ };
596
+ useEffect(() => {
597
+ if (isFiltering) {
598
+ setOpenItems(item);
599
+ }
600
+ else {
601
+ const initialOpen = item.filter((menuItem) => menuItem.isActive);
602
+ setOpenItems(initialOpen);
603
+ }
604
+ }, [isFiltering, item]);
605
+ return (jsx("div", { className: "w-72 overflow-x-hidden overflow-y-auto [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-track]:rounded-r-md [&::-webkit-scrollbar-thumb]:rounded-md [&::-webkit-scrollbar-track]:bg-stone [&::-webkit-scrollbar-thumb]:bg-stoneDark ", children: item.map((menuItem) => {
606
+ const isOpen = openItems.includes(menuItem);
607
+ return (jsxs("div", { children: [jsxs("div", { className: "cursor-pointer flex flex-row justify-between items-center border-b px-2 py-1 border-b-stone", onClick: () => toggleMenu(menuItem), children: [jsxs("div", { className: "flex flex-row items-center gap-2", children: [jsx(TextIcon, {}), jsx("span", { className: "font-roboto text-base text-primary", children: menuItem.title })] }), menuItem.subItem && (jsx("i", { className: `pi ${isOpen ? 'pi-angle-up' : 'pi-angle-down'} px-2 text-primary` }))] }), menuItem.subItem && isOpen && (jsx("div", { className: "flex flex-col", children: menuItem.subItem.map((subItem) => (jsx(Link$1, { className: clsx('cursor-pointer text-base text-primary pl-6 py-1 hover:font-bold hover:text-primary hover:bg-stoneBackground', subItem.isActive ? 'text-primary font-bold' : ''), to: subItem.path, children: jsx("span", { children: subItem.title }) }, subItem.id))) }))] }, menuItem.id));
608
+ }) }));
609
+ }
610
+
611
+ function Link({ href, children, className }) {
612
+ return (jsx("a", { href: href, className: `text-primary hover:underline font-bold font-roboto ${className}`, children: children }));
613
+ }
614
+
615
+ function MegaMenu({ items }) {
616
+ return (jsx("div", { className: "w-100 flex items-center justify-between", children: items.map((item, index) => {
617
+ const isfirst = index === 0;
618
+ const isLast = index === items.length - 1;
619
+ return (jsx("a", { onClick: item.onClick, className: clsx('w-100 p-2 font-medium border border-stoneDark text-center cursor-pointer', item.active && 'bg-primary text-background', !item.active && 'text-primary', isfirst && 'rounded-l-full', !isfirst && 'border-l-0', isLast && 'rounded-r-full'), "aria-label": "Itens do menu", children: item.label }, index));
620
+ }) }));
621
+ }
622
+
623
+ function Modal({ title, size = 'md', onClose, onConfirm, labelCloseButton = 'Fechar', labelConfirmButton = 'Confirmar', isExpanded = false, ariaLabel = 'Modal de informçoes', children, }) {
624
+ const [isFullScreen, setIsFullScreen] = useState(false);
625
+ const toggleFullScreen = () => {
626
+ setIsFullScreen(!isFullScreen);
627
+ };
628
+ const modalSizeClass = isFullScreen
629
+ ? 'w-screen h-screen'
630
+ : {
631
+ sm: 'w-1/3',
632
+ md: 'w-1/2',
633
+ lg: 'w-2/3',
634
+ xl: 'w-[90%]',
635
+ }[size];
636
+ return (jsx("div", { className: "fixed inset-0 bg-black bg-opacity-50 z-20 flex justify-center items-center", children: jsxs(Card, { className: `flex flex-col ${modalSizeClass}`, "aria-label": ariaLabel, children: [jsxs("div", { className: `flex flex-row items-center justify-between px-4 pt-4 pb-6 border-b border-b-stone`, children: [title && (jsx("div", { className: "text-primary font-bold text-xl", children: title })), jsxs("div", { className: "flex items-center gap-6", children: [isExpanded && (jsx(Fragment, { children: isFullScreen ? (jsx(Fragment, { children: jsx("button", { onClick: toggleFullScreen, "aria-label": "Minimizar tela", style: {
637
+ color: '#606060',
638
+ width: '24px',
639
+ height: '24px',
640
+ cursor: 'pointer',
641
+ }, children: jsx("i", { className: "pi pi-window-minimize" }) }) })) : (jsx(Fragment, { children: jsx("button", { onClick: toggleFullScreen, "aria-label": "Maximizar tela", style: {
642
+ color: '#606060',
643
+ width: '24px',
644
+ height: '24px',
645
+ cursor: 'pointer',
646
+ }, children: jsx("i", { className: "pi pi-window-maximize" }) }) })) })), jsx("button", { onClick: onClose, "aria-label": "Fechar modal", style: {
647
+ color: '#606060',
648
+ width: '24px',
649
+ height: '24px',
650
+ cursor: 'pointer',
651
+ }, children: jsx("i", { className: "pi pi-times cursor-pointer" }) })] })] }), jsx("div", { className: `flex-1 overflow-y-auto text-primary ${isFullScreen ? 'h-full' : 'max-h-[70vh]'} p-6`, children: children }), jsxs("div", { className: "w-full flex flex-col sm:flex-row sm:justify-end pt-10 gap-4 px-6", children: [onClose && (jsx(Button, { label: labelCloseButton, variant: "outline", onClick: onClose, className: "w-full sm:w-auto lg:min-w-[110px] md:min-w-[110px] px-4", "aria-label": "Fechar modal" })), onConfirm && (jsx(Button, { label: labelConfirmButton, variant: "primary", onClick: onConfirm, className: "w-full sm:w-auto lg:min-w-[110px] md:min-w-[110px] px-4", "aria-label": "Confirmar modal" }))] })] }) }));
652
+ }
653
+
654
+ function MultiSelect(props) {
655
+ const { options, placeholder = 'Selecione uma opção', label = 'Opção', disabled = false, error, isLoading = false, isReadOnly = true, ariaLabel = 'Selecione uma ou mais opções', } = props;
656
+ const [isOpen, setIsOpen] = useState(false);
657
+ const [visibleText, setVisibleText] = useState('');
658
+ const [searchText, setSearchText] = useState('');
659
+ const [highlightedIndex, setHighlightedIndex] = useState(-1);
660
+ const containerRef = useRef(null);
661
+ const normalize = (str) => str
662
+ .normalize('NFD')
663
+ .replace(/[\u0300-\u036f]/g, '')
664
+ .toLowerCase();
665
+ const filteredOptions = options.filter((option) => normalize(option.label).includes(normalize(searchText)));
666
+ const toggleDropdown = () => {
667
+ if (!disabled && !isLoading) {
668
+ const newState = !isOpen;
669
+ setIsOpen(newState);
670
+ if (!newState) {
671
+ setSearchText('');
672
+ setHighlightedIndex(-1);
673
+ }
674
+ }
675
+ };
676
+ const handleSelect = (option) => {
677
+ const currentValues = Array.isArray(props.value) ? props.value : [];
678
+ const alreadySelected = currentValues.some((v) => v.value === option.value);
679
+ const newValues = alreadySelected
680
+ ? currentValues.filter((v) => v.value !== option.value)
681
+ : [...currentValues, option];
682
+ props.onChange(newValues.length > 0 ? newValues : null);
683
+ setSearchText('');
684
+ const newFiltered = options.filter((opt) => normalize(opt.label).includes(normalize('')));
685
+ const newIndex = newFiltered.findIndex((o) => o.value === option.value);
686
+ setHighlightedIndex(newIndex);
687
+ };
688
+ const hasError = !!error && !disabled;
689
+ const isInputDisabled = disabled || isLoading;
690
+ useEffect(() => {
691
+ const handleClickOutside = (event) => {
692
+ if (containerRef.current &&
693
+ !containerRef.current.contains(event.target)) {
694
+ setIsOpen(false);
695
+ setSearchText('');
696
+ setHighlightedIndex(-1);
697
+ }
698
+ };
699
+ document.addEventListener('mousedown', handleClickOutside);
700
+ return () => {
701
+ document.removeEventListener('mousedown', handleClickOutside);
702
+ };
703
+ }, []);
704
+ const selectedText = () => {
705
+ const selected = Array.isArray(props.value) ? props.value : [];
706
+ if (selected.length === 0)
707
+ return '';
708
+ if (selected.length === 1)
709
+ return selected[0].label;
710
+ return `${selected.length} itens selecionados`;
711
+ };
712
+ useEffect(() => {
713
+ const selected = Array.isArray(props.value) ? props.value : [];
714
+ if (selected.length === 0) {
715
+ setVisibleText('');
716
+ }
717
+ else if (selected.length === 1) {
718
+ setVisibleText(selected[0].label);
719
+ }
720
+ else {
721
+ const count = selected.length;
722
+ setVisibleText(`${count} itens selecionados`);
723
+ }
724
+ }, [props.value]);
725
+ return (jsx(Fragment, { children: jsxs("div", { ref: containerRef, className: "relative flex flex-col w-100", children: [jsxs("div", { className: "relative w-full cursor-pointer", onClick: toggleDropdown, children: [jsx(FloatingLabel, { value: selectedText(), label: label, disabled: isInputDisabled, error: error }), jsxs(IconField, { className: "w-full", children: [jsx(InputText, { placeholder: placeholder, type: "text", value: isLoading
726
+ ? 'Carregando...'
727
+ : isOpen && !isReadOnly
728
+ ? searchText
729
+ : visibleText, onChange: (e) => {
730
+ setSearchText(e.target.value);
731
+ if (!isOpen)
732
+ setIsOpen(true);
733
+ setHighlightedIndex(-1);
734
+ }, onKeyDown: (e) => {
735
+ if (!isOpen)
736
+ return;
737
+ if (e.key === 'ArrowDown') {
738
+ e.preventDefault();
739
+ setHighlightedIndex((prev) => prev < filteredOptions.length - 1 ? prev + 1 : 0);
740
+ }
741
+ if (e.key === 'ArrowUp') {
742
+ e.preventDefault();
743
+ setHighlightedIndex((prev) => prev > 0 ? prev - 1 : filteredOptions.length - 1);
744
+ }
745
+ if (e.key === 'Enter') {
746
+ e.preventDefault();
747
+ if (highlightedIndex >= 0 &&
748
+ highlightedIndex < filteredOptions.length) {
749
+ handleSelect(filteredOptions[highlightedIndex]);
750
+ }
751
+ }
752
+ if (e.key === 'Escape') {
753
+ e.preventDefault();
754
+ setIsOpen(false);
755
+ setSearchText('');
756
+ setHighlightedIndex(-1);
757
+ }
758
+ }, onClick: toggleDropdown, className: clsx('focus:shadow-none text-base w-100 font-roboto border !p-2 rounded-md', hasError
759
+ ? 'border-redError placeholder:text-redError'
760
+ : 'border-gray focus:border-primary', isInputDisabled && 'border-stoneDark text-disabled', error && 'border-redError text-redError', !error && 'border-gray placeholder:text-gray', isLoading && 'text-gray', 'truncate'), invalid: hasError, readOnly: !isOpen || isReadOnly, style: { height: '42px', fontSize: '16px' }, disabled: isInputDisabled, "aria-label": ariaLabel }), jsx(InputIcon, { className: clsx(isLoading
761
+ ? 'pi pi-spinner pi-spin'
762
+ : isOpen
763
+ ? 'pi pi-angle-up'
764
+ : 'pi pi-angle-down', 'text-gray px-2 flex items-center cursor-pointer', isInputDisabled && 'text-disabled', error && 'text-redError'), onClick: toggleDropdown })] })] }), isOpen && !isLoading && (jsx("div", { className: clsx('absolute w-full bg-background border shadow-md z-40 rounded-md -bottom-1 translate-y-full', error ? 'border-redError' : 'border-gray'), children: jsx("div", { children: jsx("ul", { className: "max-h-60 overflow-y-auto", children: filteredOptions.map((option, index) => (jsxs("li", { onClick: () => handleSelect(option), className: clsx('p-2 flex justify-between items-center cursor-pointer', 'hover:bg-stoneBackground hover:font-bold', index === highlightedIndex &&
765
+ 'bg-stoneBackground font-bold'), title: option.label, children: [jsx("span", { className: "truncate max-w-[calc(100%-20px)]", children: option.label }), jsx("input", { type: 'checkbox', checked: Array.isArray(props.value) &&
766
+ props.value.some((v) => v.value === option.value), onChange: () => handleSelect(option), className: clsx('appearance-none w-2 h-2 ring-1 ring-offset-2 ring-offset-background ring-gray checked:bg-primary cursor-pointer rounded-md') })] }, option.value))) }) }) })), hasError && (jsx("span", { className: "text-redError text-xs px-2", children: error }))] }) }));
767
+ }
768
+
769
+ function FilterIcon({ color }) {
770
+ return (jsx("svg", { width: "16", height: "15", viewBox: "0 0 16 15", fill: "none", children: jsx("path", { d: "M14.3164 0.75C14.918 0.75 15.2188 1.46094 14.7812 1.87109L9.75 6.92969V14.0938C9.75 14.6406 9.14844 14.9414 8.71094 14.6406L6.52344 13.1094C6.33203 13 6.25 12.7812 6.25 12.5625V6.92969L1.19141 1.87109C0.753906 1.46094 1.05469 0.75 1.65625 0.75H14.3164Z", fill: color }) }));
771
+ }
772
+
773
+ function buildFormatLongFn(args) {
774
+ return (options = {}) => {
775
+ // TODO: Remove String()
776
+ const width = options.width ? String(options.width) : args.defaultWidth;
777
+ const format = args.formats[width] || args.formats[args.defaultWidth];
778
+ return format;
779
+ };
780
+ }
781
+
782
+ /**
783
+ * The localize function argument callback which allows to convert raw value to
784
+ * the actual type.
785
+ *
786
+ * @param value - The value to convert
787
+ *
788
+ * @returns The converted value
789
+ */
790
+
791
+ /**
792
+ * The map of localized values for each width.
793
+ */
794
+
795
+ /**
796
+ * The index type of the locale unit value. It types conversion of units of
797
+ * values that don't start at 0 (i.e. quarters).
798
+ */
799
+
800
+ /**
801
+ * Converts the unit value to the tuple of values.
802
+ */
803
+
804
+ /**
805
+ * The tuple of localized era values. The first element represents BC,
806
+ * the second element represents AD.
807
+ */
808
+
809
+ /**
810
+ * The tuple of localized quarter values. The first element represents Q1.
811
+ */
812
+
813
+ /**
814
+ * The tuple of localized day values. The first element represents Sunday.
815
+ */
816
+
817
+ /**
818
+ * The tuple of localized month values. The first element represents January.
819
+ */
820
+
821
+ function buildLocalizeFn(args) {
822
+ return (value, options) => {
823
+ const context = options?.context ? String(options.context) : "standalone";
824
+
825
+ let valuesArray;
826
+ if (context === "formatting" && args.formattingValues) {
827
+ const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;
828
+ const width = options?.width ? String(options.width) : defaultWidth;
829
+
830
+ valuesArray =
831
+ args.formattingValues[width] || args.formattingValues[defaultWidth];
832
+ } else {
833
+ const defaultWidth = args.defaultWidth;
834
+ const width = options?.width ? String(options.width) : args.defaultWidth;
835
+
836
+ valuesArray = args.values[width] || args.values[defaultWidth];
837
+ }
838
+ const index = args.argumentCallback ? args.argumentCallback(value) : value;
839
+
840
+ // @ts-expect-error - For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!
841
+ return valuesArray[index];
842
+ };
843
+ }
844
+
845
+ function buildMatchFn(args) {
846
+ return (string, options = {}) => {
847
+ const width = options.width;
848
+
849
+ const matchPattern =
850
+ (width && args.matchPatterns[width]) ||
851
+ args.matchPatterns[args.defaultMatchWidth];
852
+ const matchResult = string.match(matchPattern);
853
+
854
+ if (!matchResult) {
855
+ return null;
856
+ }
857
+ const matchedString = matchResult[0];
858
+
859
+ const parsePatterns =
860
+ (width && args.parsePatterns[width]) ||
861
+ args.parsePatterns[args.defaultParseWidth];
862
+
863
+ const key = Array.isArray(parsePatterns)
864
+ ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString))
865
+ : // [TODO] -- I challenge you to fix the type
866
+ findKey(parsePatterns, (pattern) => pattern.test(matchedString));
867
+
868
+ let value;
869
+
870
+ value = args.valueCallback ? args.valueCallback(key) : key;
871
+ value = options.valueCallback
872
+ ? // [TODO] -- I challenge you to fix the type
873
+ options.valueCallback(value)
874
+ : value;
875
+
876
+ const rest = string.slice(matchedString.length);
877
+
878
+ return { value, rest };
879
+ };
880
+ }
881
+
882
+ function findKey(object, predicate) {
883
+ for (const key in object) {
884
+ if (
885
+ Object.prototype.hasOwnProperty.call(object, key) &&
886
+ predicate(object[key])
887
+ ) {
888
+ return key;
889
+ }
890
+ }
891
+ return undefined;
892
+ }
893
+
894
+ function findIndex(array, predicate) {
895
+ for (let key = 0; key < array.length; key++) {
896
+ if (predicate(array[key])) {
897
+ return key;
898
+ }
899
+ }
900
+ return undefined;
901
+ }
902
+
903
+ function buildMatchPatternFn(args) {
904
+ return (string, options = {}) => {
905
+ const matchResult = string.match(args.matchPattern);
906
+ if (!matchResult) return null;
907
+ const matchedString = matchResult[0];
908
+
909
+ const parseResult = string.match(args.parsePattern);
910
+ if (!parseResult) return null;
911
+ let value = args.valueCallback
912
+ ? args.valueCallback(parseResult[0])
913
+ : parseResult[0];
914
+
915
+ // [TODO] I challenge you to fix the type
916
+ value = options.valueCallback ? options.valueCallback(value) : value;
917
+
918
+ const rest = string.slice(matchedString.length);
919
+
920
+ return { value, rest };
921
+ };
922
+ }
923
+
924
+ const formatDistanceLocale = {
925
+ lessThanXSeconds: {
926
+ one: "menos de um segundo",
927
+ other: "menos de {{count}} segundos",
928
+ },
929
+
930
+ xSeconds: {
931
+ one: "1 segundo",
932
+ other: "{{count}} segundos",
933
+ },
934
+
935
+ halfAMinute: "meio minuto",
936
+
937
+ lessThanXMinutes: {
938
+ one: "menos de um minuto",
939
+ other: "menos de {{count}} minutos",
940
+ },
941
+
942
+ xMinutes: {
943
+ one: "1 minuto",
944
+ other: "{{count}} minutos",
945
+ },
946
+
947
+ aboutXHours: {
948
+ one: "cerca de 1 hora",
949
+ other: "cerca de {{count}} horas",
950
+ },
951
+
952
+ xHours: {
953
+ one: "1 hora",
954
+ other: "{{count}} horas",
955
+ },
956
+
957
+ xDays: {
958
+ one: "1 dia",
959
+ other: "{{count}} dias",
960
+ },
961
+
962
+ aboutXWeeks: {
963
+ one: "cerca de 1 semana",
964
+ other: "cerca de {{count}} semanas",
965
+ },
966
+
967
+ xWeeks: {
968
+ one: "1 semana",
969
+ other: "{{count}} semanas",
970
+ },
971
+
972
+ aboutXMonths: {
973
+ one: "cerca de 1 mês",
974
+ other: "cerca de {{count}} meses",
975
+ },
976
+
977
+ xMonths: {
978
+ one: "1 mês",
979
+ other: "{{count}} meses",
980
+ },
981
+
982
+ aboutXYears: {
983
+ one: "cerca de 1 ano",
984
+ other: "cerca de {{count}} anos",
985
+ },
986
+
987
+ xYears: {
988
+ one: "1 ano",
989
+ other: "{{count}} anos",
990
+ },
991
+
992
+ overXYears: {
993
+ one: "mais de 1 ano",
994
+ other: "mais de {{count}} anos",
995
+ },
996
+
997
+ almostXYears: {
998
+ one: "quase 1 ano",
999
+ other: "quase {{count}} anos",
1000
+ },
1001
+ };
1002
+
1003
+ const formatDistance = (token, count, options) => {
1004
+ let result;
1005
+
1006
+ const tokenValue = formatDistanceLocale[token];
1007
+ if (typeof tokenValue === "string") {
1008
+ result = tokenValue;
1009
+ } else if (count === 1) {
1010
+ result = tokenValue.one;
1011
+ } else {
1012
+ result = tokenValue.other.replace("{{count}}", String(count));
1013
+ }
1014
+
1015
+ if (options?.addSuffix) {
1016
+ if (options.comparison && options.comparison > 0) {
1017
+ return "em " + result;
1018
+ } else {
1019
+ return "há " + result;
1020
+ }
1021
+ }
1022
+
1023
+ return result;
1024
+ };
1025
+
1026
+ const dateFormats = {
1027
+ full: "EEEE, d 'de' MMMM 'de' y",
1028
+ long: "d 'de' MMMM 'de' y",
1029
+ medium: "d MMM y",
1030
+ short: "dd/MM/yyyy",
1031
+ };
1032
+
1033
+ const timeFormats = {
1034
+ full: "HH:mm:ss zzzz",
1035
+ long: "HH:mm:ss z",
1036
+ medium: "HH:mm:ss",
1037
+ short: "HH:mm",
1038
+ };
1039
+
1040
+ const dateTimeFormats = {
1041
+ full: "{{date}} 'às' {{time}}",
1042
+ long: "{{date}} 'às' {{time}}",
1043
+ medium: "{{date}}, {{time}}",
1044
+ short: "{{date}}, {{time}}",
1045
+ };
1046
+
1047
+ const formatLong = {
1048
+ date: buildFormatLongFn({
1049
+ formats: dateFormats,
1050
+ defaultWidth: "full",
1051
+ }),
1052
+
1053
+ time: buildFormatLongFn({
1054
+ formats: timeFormats,
1055
+ defaultWidth: "full",
1056
+ }),
1057
+
1058
+ dateTime: buildFormatLongFn({
1059
+ formats: dateTimeFormats,
1060
+ defaultWidth: "full",
1061
+ }),
1062
+ };
1063
+
1064
+ const formatRelativeLocale = {
1065
+ lastWeek: (date) => {
1066
+ const weekday = date.getDay();
1067
+ const last = weekday === 0 || weekday === 6 ? "último" : "última";
1068
+ return "'" + last + "' eeee 'às' p";
1069
+ },
1070
+ yesterday: "'ontem às' p",
1071
+ today: "'hoje às' p",
1072
+ tomorrow: "'amanhã às' p",
1073
+ nextWeek: "eeee 'às' p",
1074
+ other: "P",
1075
+ };
1076
+
1077
+ const formatRelative = (token, date, _baseDate, _options) => {
1078
+ const format = formatRelativeLocale[token];
1079
+
1080
+ if (typeof format === "function") {
1081
+ return format(date);
1082
+ }
1083
+
1084
+ return format;
1085
+ };
1086
+
1087
+ const eraValues = {
1088
+ narrow: ["AC", "DC"],
1089
+ abbreviated: ["AC", "DC"],
1090
+ wide: ["antes de cristo", "depois de cristo"],
1091
+ };
1092
+
1093
+ const quarterValues = {
1094
+ narrow: ["1", "2", "3", "4"],
1095
+ abbreviated: ["T1", "T2", "T3", "T4"],
1096
+ wide: ["1º trimestre", "2º trimestre", "3º trimestre", "4º trimestre"],
1097
+ };
1098
+
1099
+ const monthValues = {
1100
+ narrow: ["j", "f", "m", "a", "m", "j", "j", "a", "s", "o", "n", "d"],
1101
+ abbreviated: [
1102
+ "jan",
1103
+ "fev",
1104
+ "mar",
1105
+ "abr",
1106
+ "mai",
1107
+ "jun",
1108
+ "jul",
1109
+ "ago",
1110
+ "set",
1111
+ "out",
1112
+ "nov",
1113
+ "dez",
1114
+ ],
1115
+
1116
+ wide: [
1117
+ "janeiro",
1118
+ "fevereiro",
1119
+ "março",
1120
+ "abril",
1121
+ "maio",
1122
+ "junho",
1123
+ "julho",
1124
+ "agosto",
1125
+ "setembro",
1126
+ "outubro",
1127
+ "novembro",
1128
+ "dezembro",
1129
+ ],
1130
+ };
1131
+
1132
+ const dayValues = {
1133
+ narrow: ["D", "S", "T", "Q", "Q", "S", "S"],
1134
+ short: ["dom", "seg", "ter", "qua", "qui", "sex", "sab"],
1135
+ abbreviated: [
1136
+ "domingo",
1137
+ "segunda",
1138
+ "terça",
1139
+ "quarta",
1140
+ "quinta",
1141
+ "sexta",
1142
+ "sábado",
1143
+ ],
1144
+
1145
+ wide: [
1146
+ "domingo",
1147
+ "segunda-feira",
1148
+ "terça-feira",
1149
+ "quarta-feira",
1150
+ "quinta-feira",
1151
+ "sexta-feira",
1152
+ "sábado",
1153
+ ],
1154
+ };
1155
+
1156
+ const dayPeriodValues = {
1157
+ narrow: {
1158
+ am: "a",
1159
+ pm: "p",
1160
+ midnight: "mn",
1161
+ noon: "md",
1162
+ morning: "manhã",
1163
+ afternoon: "tarde",
1164
+ evening: "tarde",
1165
+ night: "noite",
1166
+ },
1167
+ abbreviated: {
1168
+ am: "AM",
1169
+ pm: "PM",
1170
+ midnight: "meia-noite",
1171
+ noon: "meio-dia",
1172
+ morning: "manhã",
1173
+ afternoon: "tarde",
1174
+ evening: "tarde",
1175
+ night: "noite",
1176
+ },
1177
+ wide: {
1178
+ am: "a.m.",
1179
+ pm: "p.m.",
1180
+ midnight: "meia-noite",
1181
+ noon: "meio-dia",
1182
+ morning: "manhã",
1183
+ afternoon: "tarde",
1184
+ evening: "tarde",
1185
+ night: "noite",
1186
+ },
1187
+ };
1188
+
1189
+ const formattingDayPeriodValues = {
1190
+ narrow: {
1191
+ am: "a",
1192
+ pm: "p",
1193
+ midnight: "mn",
1194
+ noon: "md",
1195
+ morning: "da manhã",
1196
+ afternoon: "da tarde",
1197
+ evening: "da tarde",
1198
+ night: "da noite",
1199
+ },
1200
+ abbreviated: {
1201
+ am: "AM",
1202
+ pm: "PM",
1203
+ midnight: "meia-noite",
1204
+ noon: "meio-dia",
1205
+ morning: "da manhã",
1206
+ afternoon: "da tarde",
1207
+ evening: "da tarde",
1208
+ night: "da noite",
1209
+ },
1210
+ wide: {
1211
+ am: "a.m.",
1212
+ pm: "p.m.",
1213
+ midnight: "meia-noite",
1214
+ noon: "meio-dia",
1215
+ morning: "da manhã",
1216
+ afternoon: "da tarde",
1217
+ evening: "da tarde",
1218
+ night: "da noite",
1219
+ },
1220
+ };
1221
+
1222
+ const ordinalNumber = (dirtyNumber, options) => {
1223
+ const number = Number(dirtyNumber);
1224
+
1225
+ if (options?.unit === "week") {
1226
+ return number + "ª";
1227
+ }
1228
+ return number + "º";
1229
+ };
1230
+
1231
+ const localize = {
1232
+ ordinalNumber,
1233
+
1234
+ era: buildLocalizeFn({
1235
+ values: eraValues,
1236
+ defaultWidth: "wide",
1237
+ }),
1238
+
1239
+ quarter: buildLocalizeFn({
1240
+ values: quarterValues,
1241
+ defaultWidth: "wide",
1242
+ argumentCallback: (quarter) => quarter - 1,
1243
+ }),
1244
+
1245
+ month: buildLocalizeFn({
1246
+ values: monthValues,
1247
+ defaultWidth: "wide",
1248
+ }),
1249
+
1250
+ day: buildLocalizeFn({
1251
+ values: dayValues,
1252
+ defaultWidth: "wide",
1253
+ }),
1254
+
1255
+ dayPeriod: buildLocalizeFn({
1256
+ values: dayPeriodValues,
1257
+ defaultWidth: "wide",
1258
+ formattingValues: formattingDayPeriodValues,
1259
+ defaultFormattingWidth: "wide",
1260
+ }),
1261
+ };
1262
+
1263
+ const matchOrdinalNumberPattern = /^(\d+)[ºªo]?/i;
1264
+ const parseOrdinalNumberPattern = /\d+/i;
1265
+
1266
+ const matchEraPatterns = {
1267
+ narrow: /^(ac|dc|a|d)/i,
1268
+ abbreviated: /^(a\.?\s?c\.?|d\.?\s?c\.?)/i,
1269
+ wide: /^(antes de cristo|depois de cristo)/i,
1270
+ };
1271
+ const parseEraPatterns = {
1272
+ any: [/^ac/i, /^dc/i],
1273
+ wide: [/^antes de cristo/i, /^depois de cristo/i],
1274
+ };
1275
+
1276
+ const matchQuarterPatterns = {
1277
+ narrow: /^[1234]/i,
1278
+ abbreviated: /^T[1234]/i,
1279
+ wide: /^[1234](º)? trimestre/i,
1280
+ };
1281
+ const parseQuarterPatterns = {
1282
+ any: [/1/i, /2/i, /3/i, /4/i],
1283
+ };
1284
+
1285
+ const matchMonthPatterns = {
1286
+ narrow: /^[jfmajsond]/i,
1287
+ abbreviated: /^(jan|fev|mar|abr|mai|jun|jul|ago|set|out|nov|dez)/i,
1288
+ wide: /^(janeiro|fevereiro|março|abril|maio|junho|julho|agosto|setembro|outubro|novembro|dezembro)/i,
1289
+ };
1290
+ const parseMonthPatterns = {
1291
+ narrow: [
1292
+ /^j/i,
1293
+ /^f/i,
1294
+ /^m/i,
1295
+ /^a/i,
1296
+ /^m/i,
1297
+ /^j/i,
1298
+ /^j/i,
1299
+ /^a/i,
1300
+ /^s/i,
1301
+ /^o/i,
1302
+ /^n/i,
1303
+ /^d/i,
1304
+ ],
1305
+
1306
+ any: [
1307
+ /^ja/i,
1308
+ /^fev/i,
1309
+ /^mar/i,
1310
+ /^abr/i,
1311
+ /^mai/i,
1312
+ /^jun/i,
1313
+ /^jul/i,
1314
+ /^ago/i,
1315
+ /^set/i,
1316
+ /^out/i,
1317
+ /^nov/i,
1318
+ /^dez/i,
1319
+ ],
1320
+ };
1321
+
1322
+ const matchDayPatterns = {
1323
+ narrow: /^(dom|[23456]ª?|s[aá]b)/i,
1324
+ short: /^(dom|[23456]ª?|s[aá]b)/i,
1325
+ abbreviated: /^(dom|seg|ter|qua|qui|sex|s[aá]b)/i,
1326
+ wide: /^(domingo|(segunda|ter[cç]a|quarta|quinta|sexta)([- ]feira)?|s[aá]bado)/i,
1327
+ };
1328
+ const parseDayPatterns = {
1329
+ short: [/^d/i, /^2/i, /^3/i, /^4/i, /^5/i, /^6/i, /^s[aá]/i],
1330
+ narrow: [/^d/i, /^2/i, /^3/i, /^4/i, /^5/i, /^6/i, /^s[aá]/i],
1331
+ any: [/^d/i, /^seg/i, /^t/i, /^qua/i, /^qui/i, /^sex/i, /^s[aá]b/i],
1332
+ };
1333
+
1334
+ const matchDayPeriodPatterns = {
1335
+ narrow: /^(a|p|mn|md|(da) (manhã|tarde|noite))/i,
1336
+ any: /^([ap]\.?\s?m\.?|meia[-\s]noite|meio[-\s]dia|(da) (manhã|tarde|noite))/i,
1337
+ };
1338
+ const parseDayPeriodPatterns = {
1339
+ any: {
1340
+ am: /^a/i,
1341
+ pm: /^p/i,
1342
+ midnight: /^mn|^meia[-\s]noite/i,
1343
+ noon: /^md|^meio[-\s]dia/i,
1344
+ morning: /manhã/i,
1345
+ afternoon: /tarde/i,
1346
+ evening: /tarde/i,
1347
+ night: /noite/i,
1348
+ },
1349
+ };
1350
+
1351
+ const match = {
1352
+ ordinalNumber: buildMatchPatternFn({
1353
+ matchPattern: matchOrdinalNumberPattern,
1354
+ parsePattern: parseOrdinalNumberPattern,
1355
+ valueCallback: (value) => parseInt(value, 10),
1356
+ }),
1357
+
1358
+ era: buildMatchFn({
1359
+ matchPatterns: matchEraPatterns,
1360
+ defaultMatchWidth: "wide",
1361
+ parsePatterns: parseEraPatterns,
1362
+ defaultParseWidth: "any",
1363
+ }),
1364
+
1365
+ quarter: buildMatchFn({
1366
+ matchPatterns: matchQuarterPatterns,
1367
+ defaultMatchWidth: "wide",
1368
+ parsePatterns: parseQuarterPatterns,
1369
+ defaultParseWidth: "any",
1370
+ valueCallback: (index) => index + 1,
1371
+ }),
1372
+
1373
+ month: buildMatchFn({
1374
+ matchPatterns: matchMonthPatterns,
1375
+ defaultMatchWidth: "wide",
1376
+ parsePatterns: parseMonthPatterns,
1377
+ defaultParseWidth: "any",
1378
+ }),
1379
+
1380
+ day: buildMatchFn({
1381
+ matchPatterns: matchDayPatterns,
1382
+ defaultMatchWidth: "wide",
1383
+ parsePatterns: parseDayPatterns,
1384
+ defaultParseWidth: "any",
1385
+ }),
1386
+
1387
+ dayPeriod: buildMatchFn({
1388
+ matchPatterns: matchDayPeriodPatterns,
1389
+ defaultMatchWidth: "any",
1390
+ parsePatterns: parseDayPeriodPatterns,
1391
+ defaultParseWidth: "any",
1392
+ }),
1393
+ };
1394
+
1395
+ /**
1396
+ * @category Locales
1397
+ * @summary Portuguese locale (Brazil).
1398
+ * @language Portuguese
1399
+ * @iso-639-2 por
1400
+ * @author Lucas Duailibe [@duailibe](https://github.com/duailibe)
1401
+ * @author Yago Carballo [@yagocarballo](https://github.com/YagoCarballo)
1402
+ */
1403
+ const ptBR = {
1404
+ code: "pt-BR",
1405
+ formatDistance: formatDistance,
1406
+ formatLong: formatLong,
1407
+ formatRelative: formatRelative,
1408
+ localize: localize,
1409
+ match: match,
1410
+ options: {
1411
+ weekStartsOn: 0 /* Sunday */,
1412
+ firstWeekContainsDate: 1,
1413
+ },
1414
+ };
1415
+
1416
+ const formatDate = (date) => {
1417
+ return format(date, "EEEE',' dd 'de' MMM '-' HH:mm", {
1418
+ locale: ptBR,
1419
+ }).replace('.', '');
1420
+ };
1421
+ function NotificationItem({ notification, onDelete, onClick, }) {
1422
+ return (jsxs("div", { className: "flex flex-row items-start gap-2 px-4 hover:text-primary cursor-pointer rounded", children: [jsx("i", { className: "pi pi-circle-fill text-xs pt-1.5", style: { color: notification.active ? '#0AA836' : '#A0A4B3' } }), jsxs("div", { className: "flex-1 text-left", onClick: () => onClick(notification.id), children: [jsx("h2", { className: clsx('text-base font-bold', !notification.active && 'text-gray'), children: notification.title }), jsx("p", { className: clsx('text-sm py-1 text-gray'), children: notification.description }), jsx("p", { className: clsx('text-sm font-bold', !notification.active && 'text-gray'), children: formatDate(notification.date) })] }), jsx("div", { className: "min-w-6 cursor-pointer", onClick: () => onDelete(notification.id), children: jsx("i", { className: "pi pi-trash text-[#878787] hover:text-backgroundDark" }) })] }, notification.id));
1423
+ }
1424
+
1425
+ function Notification({ onClose, onReadAll, onDeleteNotificationbyId, onClickNotification, notifications, setFilter, filter, setInputValue, inputValue, filterOptions, }) {
1426
+ const customContent = (jsxs("div", { children: [jsxs("div", { className: "flex justify-between items-center px-4 py-3 border-b border-[#F1F1F4]", children: [jsxs("div", { className: "flex items-center gap-2", children: [jsx("i", { className: "pi pi-bell text-backgroundDark" }), jsx("h2", { className: "font-roboto text-base text-backgroundDark font-bold", children: "Notifica\u00E7\u00F5es" })] }), jsx("div", { className: "flex items-center gap-2", children: jsx(Button, { label: "Marcar todas como lidas", variant: "secondaryOutline", onClick: onReadAll, className: "px-2 py-1 text-xs h-7" }) })] }), jsxs("div", { className: "px-4 py-2 flex flex-row gap-4", children: [jsx(Input, { value: inputValue, onChange: setInputValue, label: "Pesquisar", placeholder: "Pesquisar", icon: "pi-search", iconColor: "gray" }), jsx(FilterButton, { variant: "primary", label: "Filter", icon: jsx(FilterIcon, { color: "#FFFFFF" }), option: filter, setOption: (option) => setFilter(option), filterOptions: filterOptions })] }), jsx("div", { className: "text-center pt-4", children: notifications.length > 0 ? (jsx("div", { className: "w-100 h-[calc(100vh_-114.8px)] overflow-y-auto [&::-webkit-scrollbar]:w-1 [&::-webkit-scrollbar-track]:rounded-r-md [&::-webkit-scrollbar-thumb]:rounded-md [&::-webkit-scrollbar-track]:bg-stone [&::-webkit-scrollbar-thumb]:bg-stoneDark", children: notifications.map((notification) => (jsxs("div", { className: "w-100 hover:bg-stoneBackground", children: [jsx(NotificationItem, { notification: notification, onDelete: onDeleteNotificationbyId, onClick: onClickNotification }), jsx(Divider$1, {})] }, notification.id))) })) : (jsx("p", { children: " Sem notifica\u00E7\u00F5es" })) })] }));
1427
+ return (jsx(Sidebar$1, { visible: true, position: "right", onHide: onClose, className: "w-10/12 md:w-1/2 lg:w-1/3", content: customContent }));
1428
+ }
1429
+
1430
+ function Paginator(props) {
1431
+ const template = {
1432
+ layout: 'PrevPageLink PageLinks NextPageLink',
1433
+ PrevPageLink: (options) => {
1434
+ return (jsx("button", { className: classNames(options.className, '!w-8 !h-8 min-w-0 mr-2 font-roboto'), onClick: options.onClick, disabled: options.disabled, "aria-label": "Pr\u00F3xima p\u00E1gina", children: jsx("span", { className: "pi pi-angle-left" }) }));
1435
+ },
1436
+ NextPageLink: (options) => {
1437
+ return (jsx("button", { className: classNames(options.className, '!w-8 !h-8 min-w-0 ml-2 font-roboto'), onClick: options.onClick, disabled: options.disabled, "aria-label": "P\u00E1gina anterior", children: jsx("span", { className: "pi pi-angle-right" }) }));
1438
+ },
1439
+ PageLinks: (options) => {
1440
+ return React.cloneElement(options.element, {
1441
+ className: classNames(options.element.props.className, '!rounded-full !w-8 !h-8 min-w-0 font-roboto', {
1442
+ 'bg-primary text-white': options.page === options.currentPage,
1443
+ 'hover:bg-gray-100': options.page !== options.currentPage,
1444
+ }),
1445
+ });
1446
+ },
1447
+ };
1448
+ return jsx(Paginator$1, { ...props, template: template });
1449
+ }
1450
+
1451
+ const variants = {
1452
+ white: 'ring-offset-background',
1453
+ secondary: 'ring-offset-secondary',
1454
+ };
1455
+ function RadioButton({ label, value, checked, onChange, disabled = false, error = false, variant = 'secondary', ariaLabel = 'Radio button', }) {
1456
+ return (jsxs("label", { className: clsx('flex items-center gap-2 cursor-pointer font-roboto text-primary', disabled && 'text-disabled', error && !checked && 'text-redError'), children: [jsx("input", { type: "radio", value: value, checked: checked, onChange: onChange, disabled: disabled, className: clsx('font-roboto appearance-none w-2 h-2 border-0 rounded-full shadow-none ring-1 ring-offset-2 checked:bg-primary transition-colors duration-200', disabled
1457
+ ? 'ring-stone'
1458
+ : error && !checked
1459
+ ? 'ring-redError'
1460
+ : 'ring-gray', variants[variant]), "aria-label": ariaLabel }), label] }));
1461
+ }
1462
+
1463
+ function Select(props) {
1464
+ const { options, placeholder = 'Selecione uma opção', label = 'Opção', disabled = false, error, isLoading = false, isReadOnly = true, ariaLabel = 'Selecione uma opção', } = props;
1465
+ const [isOpen, setIsOpen] = useState(false);
1466
+ const [searchText, setSearchText] = useState('');
1467
+ const [highlightedIndex, setHighlightedIndex] = useState(-1);
1468
+ const containerRef = useRef(null);
1469
+ const normalize = (str) => str
1470
+ .normalize('NFD')
1471
+ .replace(/[\u0300-\u036f]/g, '')
1472
+ .toLowerCase();
1473
+ const filteredOptions = options.filter((option) => normalize(option.label).includes(normalize(searchText)));
1474
+ const toggleDropdown = () => {
1475
+ if (!disabled && !isLoading) {
1476
+ const newState = !isOpen;
1477
+ setIsOpen(newState);
1478
+ setSearchText('');
1479
+ setHighlightedIndex(-1);
1480
+ }
1481
+ };
1482
+ const handleSelect = (option) => {
1483
+ if (props.value?.value === option.value) {
1484
+ props.onChange(null);
1485
+ }
1486
+ else {
1487
+ props.onChange(option);
1488
+ }
1489
+ setSearchText('');
1490
+ setIsOpen(false);
1491
+ setHighlightedIndex(-1);
1492
+ };
1493
+ const hasError = !!error && !disabled;
1494
+ const isInputDisabled = disabled || isLoading;
1495
+ useEffect(() => {
1496
+ const handleClickOutside = (event) => {
1497
+ if (containerRef.current &&
1498
+ !containerRef.current.contains(event.target)) {
1499
+ setIsOpen(false);
1500
+ setSearchText('');
1501
+ setHighlightedIndex(-1);
1502
+ }
1503
+ };
1504
+ document.addEventListener('mousedown', handleClickOutside);
1505
+ return () => {
1506
+ document.removeEventListener('mousedown', handleClickOutside);
1507
+ };
1508
+ }, []);
1509
+ return (jsxs("div", { ref: containerRef, className: "relative flex flex-col w-100", children: [jsxs("div", { className: "relative w-full cursor-pointer", onClick: toggleDropdown, children: [jsx(FloatingLabel, { value: props.value ? props.value.label : '', label: label, disabled: isInputDisabled, error: error }), jsxs(IconField, { className: "w-full", children: [jsx(InputText, { placeholder: placeholder, type: "text", value: isLoading
1510
+ ? 'Carregando...'
1511
+ : isOpen
1512
+ ? searchText
1513
+ : (props.value?.label ?? ''), onClick: toggleDropdown, onChange: (e) => {
1514
+ if (isOpen) {
1515
+ setSearchText(e.target.value);
1516
+ setHighlightedIndex(0);
1517
+ }
1518
+ }, onKeyDown: (e) => {
1519
+ if (!isOpen)
1520
+ return;
1521
+ if (e.key === 'ArrowDown') {
1522
+ e.preventDefault();
1523
+ setHighlightedIndex((prev) => prev < filteredOptions.length - 1 ? prev + 1 : 0);
1524
+ }
1525
+ if (e.key === 'ArrowUp') {
1526
+ e.preventDefault();
1527
+ setHighlightedIndex((prev) => prev > 0 ? prev - 1 : filteredOptions.length - 1);
1528
+ }
1529
+ if (e.key === 'Enter') {
1530
+ e.preventDefault();
1531
+ if (highlightedIndex >= 0 &&
1532
+ highlightedIndex < filteredOptions.length) {
1533
+ handleSelect(filteredOptions[highlightedIndex]);
1534
+ }
1535
+ }
1536
+ if (e.key === 'Escape') {
1537
+ e.preventDefault();
1538
+ setIsOpen(false);
1539
+ setSearchText('');
1540
+ setHighlightedIndex(-1);
1541
+ }
1542
+ }, className: clsx('focus:shadow-none text-base w-100 font-roboto border !p-2 rounded-md', hasError
1543
+ ? 'border-redError placeholder:text-redError'
1544
+ : 'border-gray focus:border-primary', isInputDisabled && 'border-stoneDark text-disabled', error && 'border-redError text-redError', !error && 'border-gray placeholder:text-gray', isLoading && 'text-gray', 'truncate'), invalid: hasError, readOnly: !isOpen || isReadOnly, style: { height: '42px', fontSize: '16px' }, disabled: isInputDisabled, "aria-label": ariaLabel }), jsx(InputIcon, { className: clsx(isLoading
1545
+ ? 'pi pi-spinner pi-spin'
1546
+ : isOpen
1547
+ ? 'pi pi-angle-up'
1548
+ : 'pi pi-angle-down', 'text-gray px-2 flex items-center cursor-pointer', isInputDisabled && 'text-disabled', error && 'text-redError'), onClick: toggleDropdown })] })] }), isOpen && !isLoading && (jsx("div", { className: clsx('absolute w-full bg-background border shadow-md z-40 rounded-md p-2 -bottom-1 translate-y-full', error ? 'border-redError' : 'border-gray'), children: jsx("ul", { className: "max-h-60 overflow-y-auto", children: filteredOptions.map((option, index) => (jsxs("li", { onClick: () => handleSelect(option), className: clsx('p-2 flex justify-between items-center cursor-pointer', 'hover:bg-stoneBackground hover:font-bold', index === highlightedIndex && 'bg-stoneBackground font-bold'), children: [jsx("span", { className: "truncate max-w-[calc(100%-20px)]", children: option.label }), jsx("input", { type: 'radio', checked: props.value?.value === option.value, onChange: () => handleSelect(option), className: clsx('appearance-none w-2 h-2 rounded-full ring-1 ring-offset-2 ring-offset-background ring-gray checked:bg-primary cursor-pointer') })] }, option.value))) }) })), hasError && jsx("span", { className: "text-redError text-xs px-2", children: error })] }));
1549
+ }
1550
+
1551
+ function Skeleton({ shape = 'rectangle', width = '100%', height = '1rem', borderRadius, animation = 'wave', size, className, }) {
1552
+ return (jsx("div", { className: className, children: jsx(Skeleton$1, { shape: shape, width: width, height: height, borderRadius: borderRadius, animation: animation, size: size, "aria-label": "skeleton" }) }));
1553
+ }
1554
+
1555
+ const colorVariants = {
1556
+ primary: 'border-primary',
1557
+ secondary: 'border-secondary',
1558
+ };
1559
+ const sizeVariants = {
1560
+ sm: 'w-4 h-4',
1561
+ md: 'w-6 h-6',
1562
+ lg: 'w-8 h-8',
1563
+ };
1564
+ function Spinner({ size = 'md', color = 'primary' }) {
1565
+ return (jsx("div", { className: clsx('border-2 border-t-transparent animate-spin rounded-full', colorVariants[color], sizeVariants[size]), "aria-label": "loading", role: "status" }));
1566
+ }
1567
+
1568
+ /* eslint-disable @typescript-eslint/no-explicit-any */
1569
+ function getNestedValue(obj, path) {
1570
+ if (!obj || !path)
1571
+ return undefined;
1572
+ return path.split('.').reduce((acc, part) => acc?.[part], obj);
1573
+ }
1574
+
1575
+ // import { SortDirection } from '../types'
1576
+ // export function sortData<T>(
1577
+ // data: T[],
1578
+ // column: keyof T,
1579
+ // direction: SortDirection
1580
+ // ): T[] {
1581
+ // return [...data].sort((a, b) => {
1582
+ // const aValue = a[column]
1583
+ // const bValue = b[column]
1584
+ // if (typeof aValue === 'number' && typeof bValue === 'number') {
1585
+ // return direction === 'ASC' ? aValue - bValue : bValue - aValue
1586
+ // }
1587
+ // if (aValue instanceof Date && bValue instanceof Date) {
1588
+ // return direction === 'ASC'
1589
+ // ? aValue.getTime() - bValue.getTime()
1590
+ // : bValue.getTime() - aValue.getTime()
1591
+ // }
1592
+ // const aString = String(aValue).toLowerCase()
1593
+ // const bString = String(bValue).toLowerCase()
1594
+ // return direction === 'ASC'
1595
+ // ? aString.localeCompare(bString)
1596
+ // : bString.localeCompare(aString)
1597
+ // })
1598
+ // }
1599
+ function sortData(data, columnPath, direction) {
1600
+ return [...data].sort((a, b) => {
1601
+ const aValue = getNestedValue(a, columnPath);
1602
+ const bValue = getNestedValue(b, columnPath);
1603
+ if (typeof aValue === 'number' && typeof bValue === 'number') {
1604
+ return direction === 'ASC' ? aValue - bValue : bValue - aValue;
1605
+ }
1606
+ if (aValue instanceof Date && bValue instanceof Date) {
1607
+ return direction === 'ASC'
1608
+ ? aValue.getTime() - bValue.getTime()
1609
+ : bValue.getTime() - aValue.getTime();
1610
+ }
1611
+ const aString = String(aValue || '').toLowerCase();
1612
+ const bString = String(bValue || '').toLowerCase();
1613
+ return direction === 'ASC'
1614
+ ? aString.localeCompare(bString)
1615
+ : bString.localeCompare(aString);
1616
+ });
1617
+ }
1618
+
1619
+ function parseDateRange(value) {
1620
+ try {
1621
+ const parsed = JSON.parse(value);
1622
+ const start = parsed[0] ? new Date(parsed[0]) : null;
1623
+ const end = parsed[1] ? new Date(parsed[1]) : null;
1624
+ return [start, end];
1625
+ }
1626
+ catch {
1627
+ return [null, null];
1628
+ }
1629
+ }
1630
+ function Table({ columns, data, totalRecords, actions = [], isOrdered = true, actionsHeaderClassName = '', actionsColumnsClassName = '', rowsPerPage = 10, onPageChange, isPaginated = true, isLoading = false, onFilterChange, onSortChange, }) {
1631
+ const [sortDirection, setSortDirection] = useState({});
1632
+ const [sortedData, setSortedData] = useState(data);
1633
+ const [currentPage, setCurrentPage] = useState(1);
1634
+ const [filters, setFilters] = useState({});
1635
+ const [openFilter, setOpenFilter] = useState(null);
1636
+ const filterModalRef = useRef(null);
1637
+ const [filterStatus, setFilterStatus] = useState({});
1638
+ const handleSort = (dataIndex) => {
1639
+ setSortDirection((prev) => {
1640
+ const current = prev[dataIndex];
1641
+ let nextDirection;
1642
+ if (current === 'ASC')
1643
+ nextDirection = 'DESC';
1644
+ else if (current === 'DESC')
1645
+ nextDirection = null;
1646
+ else
1647
+ nextDirection = 'ASC';
1648
+ const newSortDirection = { [dataIndex]: nextDirection };
1649
+ if (nextDirection === null) {
1650
+ setSortedData(data);
1651
+ }
1652
+ else {
1653
+ const sorted = sortData(data, dataIndex, nextDirection);
1654
+ setSortedData(sorted);
1655
+ }
1656
+ if (onSortChange) {
1657
+ onSortChange(dataIndex, nextDirection);
1658
+ }
1659
+ return newSortDirection;
1660
+ });
1661
+ };
1662
+ useEffect(() => {
1663
+ setSortedData(data);
1664
+ }, [data]);
1665
+ useEffect(() => {
1666
+ const handleClickOutside = (event) => {
1667
+ const target = event.target;
1668
+ const isClickInsideFilter = filterModalRef.current && filterModalRef.current.contains(target);
1669
+ const isClickInsideCalendar = (target instanceof HTMLElement && target.closest('.p-datepicker')) !==
1670
+ null;
1671
+ if (!isClickInsideFilter && !isClickInsideCalendar) {
1672
+ setOpenFilter(null);
1673
+ }
1674
+ };
1675
+ document.addEventListener('mousedown', handleClickOutside);
1676
+ return () => {
1677
+ document.removeEventListener('mousedown', handleClickOutside);
1678
+ };
1679
+ }, []);
1680
+ const handleFilter = (column) => {
1681
+ setOpenFilter(null);
1682
+ if (onFilterChange) {
1683
+ onFilterChange(filters);
1684
+ }
1685
+ setFilterStatus((prev) => ({
1686
+ ...prev,
1687
+ [column.dataIndex]: filters[column.dataIndex]
1688
+ ? 'applied'
1689
+ : 'default',
1690
+ }));
1691
+ };
1692
+ const handleClearFilter = (column) => {
1693
+ const dataIndex = column.dataIndex;
1694
+ const newFilters = {
1695
+ ...filters,
1696
+ [dataIndex]: '',
1697
+ };
1698
+ setFilters(newFilters);
1699
+ setFilterStatus((prev) => ({
1700
+ ...prev,
1701
+ [dataIndex]: 'default',
1702
+ }));
1703
+ setOpenFilter(null);
1704
+ if (onFilterChange) {
1705
+ onFilterChange(newFilters);
1706
+ }
1707
+ };
1708
+ return (jsxs("div", { children: [jsxs("table", { className: "w-100", children: [jsx("thead", { children: jsxs("tr", { className: "bg-gray-100", children: [columns.map((column) => (jsxs("th", { scope: "col", className: "bg-primary first:rounded-ss-lg font-bold text-background text-sm uppercase p-3 text-left", children: [jsx("div", { children: openFilter === column.dataIndex && (jsxs("div", { ref: filterModalRef, className: "absolute mt-6 bg-background border rounded-md shadow-md p-4 z-10 w-[276px] normal-case", children: [jsxs("div", { className: "space-y-4 text-primary", children: [jsxs("h1", { className: "text-primary text-sm", children: ["Filtrar por ", column?.label?.toLowerCase()] }), jsxs("div", { className: "w-full", children: [column.filterType === 'text' && (jsx(Input, { placeholder: "Digite para filtrar", value: filters[column.dataIndex] || '', onChange: (e) => setFilters((prev) => ({
1709
+ ...prev,
1710
+ [column.dataIndex]: e,
1711
+ })), mask: column?.mask, "aria-label": `Filtrar por ${column.label}` })), column.filterType === 'select' && (jsx(Select, { options: column.filterOptions || [], value: column.filterOptions?.find((option) => option.value ===
1712
+ filters[column.dataIndex]) || null, onChange: (selected) => setFilters((prev) => ({
1713
+ ...prev,
1714
+ [column.dataIndex]: selected?.value ?? null,
1715
+ })), placeholder: "Selecione uma op\u00E7\u00E3o", label: "", "aria-label": `Filtrar por ${column.label}` })), column.filterType === 'multiSelect' && (jsx(MultiSelect, { options: column.filterOptions || [], value: (filters[column.dataIndex]
1716
+ ? JSON.parse(filters[column.dataIndex])
1717
+ : []), onChange: (selected) => setFilters((prev) => ({
1718
+ ...prev,
1719
+ [column.dataIndex]: selected
1720
+ ? JSON.stringify(selected)
1721
+ : '',
1722
+ })), placeholder: "Selecione uma ou mais op\u00E7\u00F5es", label: "", "aria-label": `Filtrar por ${column.label}` })), column.filterType === 'singleDate' && (jsx(CalendarInput, { label: "", selectionMode: "single", placeholder: "Selecione uma data", value: filters[column.dataIndex]
1723
+ ? new Date(filters[column.dataIndex])
1724
+ : null, onChange: (e) => {
1725
+ const value = e?.value;
1726
+ setFilters((prev) => ({
1727
+ ...prev,
1728
+ [column.dataIndex]: value instanceof Date
1729
+ ? value.toISOString()
1730
+ : '',
1731
+ }));
1732
+ }, ariaLabel: `Filtrar por ${column.label}` })), column.filterType === 'rangeDate' && (jsx(CalendarInput, { label: "", selectionMode: "range", placeholder: "Selecione as datas", value: filters[column.dataIndex]
1733
+ ? parseDateRange(filters[column.dataIndex])
1734
+ : null, onChange: (e) => {
1735
+ const range = e?.value;
1736
+ setFilters((prev) => ({
1737
+ ...prev,
1738
+ [column.dataIndex]: range
1739
+ ? JSON.stringify(range)
1740
+ : '',
1741
+ }));
1742
+ }, ariaLabel: `Filtrar por ${column.label}` }))] })] }), jsxs("div", { className: "flex justify-between mt-4", children: [jsx(Button, { variant: "outline", onClick: () => {
1743
+ setFilters((prev) => ({
1744
+ ...prev,
1745
+ [column.dataIndex]: '',
1746
+ }));
1747
+ setOpenFilter(null);
1748
+ }, label: "Fechar", width: "10", size: "small", "aria-label": "Fechar filtro" }), jsx(Button, { variant: "secondary", onClick: () => handleClearFilter(column), label: "Limpar", width: "10", size: "small", "aria-label": "Limpar filtro" }), jsx(Button, { variant: "primary", onClick: () => handleFilter(column), label: "Aplicar", width: "10", size: "small", "aria-label": "Aplicar filtro" })] })] })) }), column.label, isOrdered && (jsx("button", { onClick: () => handleSort(column.dataIndex), "aria-label": `Ordenar por ${column.label}`, children: jsx("i", { className: clsx('pl-2 text-xs cursor-pointer pi', sortDirection[column.dataIndex] === 'ASC' &&
1749
+ 'pi-sort-amount-up-alt', sortDirection[column.dataIndex] === 'DESC' &&
1750
+ 'pi-sort-amount-down', !sortDirection[column.dataIndex] && 'pi-sort-alt') }) })), column.filterable && (jsx(Fragment, { children: jsx("button", { onClick: () => setOpenFilter((prev) => prev === column.dataIndex
1751
+ ? null
1752
+ : column.dataIndex), "aria-label": `Filtrar por ${column.label}`, children: jsx("i", { className: clsx('pl-2 text-xs cursor-pointer', filterStatus[column.dataIndex] === 'applied'
1753
+ ? 'pi pi-filter-slash'
1754
+ : 'pi pi-filter') }) }) }))] }, String(column.dataIndex)))), actions.length > 0 && (jsx("th", { scope: "col", className: clsx('bg-primary rounded-se-lg font-bold text-background text-sm uppercase p-3 text-right pr-4', actionsHeaderClassName), children: "A\u00C7\u00D5ES" }))] }) }), jsx("tbody", { children: isLoading ? (jsx("tr", { children: jsx("td", { colSpan: columns.length + (actions.length > 0 ? 1 : 0), className: "p-6 text-center bg-gray-50", children: jsx("div", { className: "py-2 px-4 flex justify-center items-center gap-2", children: jsx(Spinner, { size: "lg" }) }) }) })) : sortedData.length > 0 ? (sortedData.map((row, index) => (jsxs("tr", { className: clsx(index % 2 === 0 ? 'bg-stoneBackground' : 'bg-background', 'text-primary text-base'), children: [columns.map((column) => {
1755
+ const value = getNestedValue(row, column.dataIndex);
1756
+ return (jsx("td", { className: clsx('p-3 text-sm text-left', typeof column.style === 'function'
1757
+ ? column.style(getNestedValue(row, column.dataIndex), row)
1758
+ : column.style), children: column.render
1759
+ ? column.render(value, row)
1760
+ : String(value) }, String(column.dataIndex)));
1761
+ }), actions.length > 0 && (jsx("td", { className: clsx('text-sm text-right flex flex-row justify-end p-3 gap-2', actionsColumnsClassName), children: actions.map((action, idx) => (jsx("span", { className: clsx('cursor-pointer', action.disabled &&
1762
+ 'opacity-50 pointer-events-none cursor-not-allowed'), onClick: () => {
1763
+ if (!action.disabled)
1764
+ action.onClick(row);
1765
+ }, "aria-label": action?.ariaLabel || action.label, role: "button", children: action.icon }, idx))) }))] }, index)))) : (jsx("tr", { children: jsxs("td", { colSpan: columns.length + (actions.length > 0 ? 1 : 0), className: "p-6 text-center text-primary bg-stoneBackground", children: [jsx("i", { className: "pi pi-database mr-2" }), " N\u00E3o h\u00E1 dados dispon\u00EDveis."] }) })) })] }), sortedData.length > 0 && isPaginated && (jsx(Paginator, { first: (currentPage - 1) * rowsPerPage, rows: rowsPerPage, totalRecords: totalRecords, onPageChange: (event) => {
1766
+ setCurrentPage(event.page + 1);
1767
+ onPageChange(event.page + 1);
1768
+ } }))] }));
1769
+ }
1770
+
1771
+ const colorMap = {
1772
+ blue: 'bg-[#DBEAFE] text-[#1E40AF] border-[#BFDBFE]',
1773
+ red: 'bg-[#FEE2E2] text-[#991B1B] border-[#FCA5A5]',
1774
+ green: 'bg-[#D1FAE5] text-[#065F46] border-[#6EE7B7]',
1775
+ gray: 'bg-[#F3F4F6] text-[#374151] border-[#D1D5DB]',
1776
+ purple: 'bg-[#EDE9FE] text-[#6B21A8] border-[#C4B5FD]',
1777
+ yellow: 'bg-[#FEF9C3] text-[#92400E] border-[#FCD34D]',
1778
+ orange: 'bg-[#FFEDD5] text-[#9A3412] border-[#FDBA74]',
1779
+ pink: 'bg-[#FCE7F3] text-[#9D174D] border-[#F9A8D4]',
1780
+ emerald: 'bg-[#D1FAE5] text-[#065F46] border-[#6EE7B7]',
1781
+ teal: 'bg-[#CCFBF1] text-[#134E4A] border-[#5EEAD4]',
1782
+ cyan: 'bg-[#CFFAFE] text-[#155E75] border-[#67E8F9]',
1783
+ sky: 'bg-[#E0F2FE] text-[#0369A1] border-[#7DD3FC]',
1784
+ indigo: 'bg-[#E0E7FF] text-[#3730A3] border-[#A5B4FC]',
1785
+ violet: 'bg-[#EDE9FE] text-[#6D28D9] border-[#C4B5FD]',
1786
+ fuchsia: 'bg-[#FAE8FF] text-[#A21CAF] border-[#F0ABFC]',
1787
+ rose: 'bg-[#FFE4E6] text-[#BE123C] border-[#FDA4AF]',
1788
+ stone: 'bg-[#E7E5E4] text-[#44403C] border-[#D6D3D1]',
1789
+ amber: 'bg-[#FEF3C7] text-[#92400E] border-[#FCD34D]',
1790
+ lime: 'bg-[#ECFCCB] text-[#365314] border-[#BEF264]',
1791
+ slate: 'bg-[#F1F5F9] text-[#334155] border-[#CBD5E1]',
1792
+ zinc: 'bg-[#F4F4F5] text-[#3F3F46] border-[#D4D4D8]',
1793
+ neutral: 'bg-[#F5F5F5] text-[#404040] border-[#D4D4D4]',
1794
+ };
1795
+ function TagStatus({ value, color = 'gray' }) {
1796
+ const colorClass = colorMap[color];
1797
+ return (jsx("span", { className: `text-sm px-2 py-1 rounded-xl font-medium border ${colorClass}`, children: value }));
1798
+ }
1799
+
1800
+ function ErrorIcon() {
1801
+ return (jsxs("svg", { width: "27", height: "27", viewBox: "0 0 27 27", fill: "none", className: "min-w-7", children: [jsx("circle", { cx: "13.5", cy: "13.5", r: "12.5", stroke: "#B71C1C", strokeWidth: "2" }), jsx("path", { d: "M8 8L19 19", stroke: "#B71C1C", strokeWidth: "2", strokeLinecap: "round" }), jsx("path", { d: "M19 8L8 19", stroke: "#B71C1C", strokeWidth: "2", strokeLinecap: "round" })] }));
1802
+ }
1803
+
1804
+ function InfoIcon() {
1805
+ return (jsxs("svg", { width: "27", height: "27", viewBox: "0 0 27 27", fill: "none", children: [jsx("circle", { cx: "13.5", cy: "13.5", r: "12.5", stroke: "#0045ba", strokeWidth: "2" }), jsx("path", { d: "M14.6294 8L14.3877 15.4048H12.6299L12.3809 8H14.6294ZM12.3223 17.6973C12.3223 17.3848 12.4297 17.126 12.6445 16.9209C12.8643 16.7109 13.1523 16.606 13.5088 16.606C13.8701 16.606 14.1582 16.7109 14.373 16.9209C14.5879 17.126 14.6953 17.3848 14.6953 17.6973C14.6953 18 14.5879 18.2563 14.373 18.4663C14.1582 18.6763 13.8701 18.7812 13.5088 18.7812C13.1523 18.7812 12.8643 18.6763 12.6445 18.4663C12.4297 18.2563 12.3223 18 12.3223 17.6973Z", fill: "#0045ba" })] }));
1806
+ }
1807
+
1808
+ function SuccessIcon() {
1809
+ return (jsxs("svg", { width: "27", height: "27", viewBox: "0 0 27 27", fill: "none", className: "min-w-7", children: [jsx("circle", { cx: "13.5", cy: "13.5", r: "12.5", stroke: '#1B5E20', strokeWidth: "2" }), jsx("path", { d: "M7 12.5L12 17.5L19.5 10", stroke: '#1B5E20', strokeWidth: "2", strokeLinecap: "round" })] }));
1810
+ }
1811
+
1812
+ function Toast({ messages }) {
1813
+ return (jsx("div", { className: "fixed top-5 right-5 flex flex-col gap-2 z-[999]", children: messages.map(({ id, severity, summary, detail }) => (jsxs("div", { className: clsx('p-2 rounded flex items-center gap-2 transition-opacity bg-white border border-l-4 rounded-r-lg shadow-[0_4px_12px_rgba(0,0,0,0.50)]', severity === 'success'
1814
+ ? 'bg-[#E6F4EA] border-[#2E7D32] text-[#1B5E20]'
1815
+ : '', severity === 'info'
1816
+ ? 'bg-[#E3F2FD] border-[#1565C0] text-[#0D47A1]'
1817
+ : '', severity === 'error'
1818
+ ? 'bg-[#FFEBEE] border-[#C62828] text-[#B71C1C]'
1819
+ : ''), "aria-label": "toast", children: [severity === 'success' && jsx(SuccessIcon, {}), severity === 'info' && jsx(InfoIcon, {}), severity === 'error' && jsx(ErrorIcon, {}), jsxs("div", { children: [jsx("strong", { children: summary }), jsx("p", { children: detail })] })] }, id))) }));
1820
+ }
1821
+
1822
+ export { Accordion, AutoComplete, BasicHeader, Breadcrumb, Button, CalendarInput, Card, CardButton, CardIconsButton, Chart, Dialog, Divider, EmptyContent, ExpandablePanel, FileUpload, FilterButton, Header, IconButton, InfoCard, Input, InputSwitch, InputTextArea, InternalMenu, Link, MegaMenu, Modal, MultiSelect, Notification, Paginator, RadioButton, Select, Sidebar, Skeleton, Spinner, Table, TagStatus, Toast };
39
1823
  //# sourceMappingURL=index.js.map