@cloudparker/moldex.js 0.0.38 → 0.0.40
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.
- package/dist/actions/ripple.d.ts +2 -8
- package/dist/actions/ripple.js +11 -4
- package/dist/services/date/date-service.d.ts +13 -13
- package/dist/services/date/date-service.js +14 -15
- package/dist/tailwind.css +1 -1
- package/dist/views/core/button/components/button/button.svelte +6 -3
- package/dist/views/core/button/components/button/button.svelte.d.ts +2 -1
- package/dist/views/core/button/components/button-back/button-back.svelte +1 -1
- package/dist/views/core/button/components/button-menu/button-menu.svelte +81 -73
- package/dist/views/core/button/components/button-menu/button-menu.svelte.d.ts +32 -32
- package/dist/views/core/drawer/components/drawer/drawer.svelte +4 -2
- package/dist/views/core/input/components/checkbox-field/checkbox-field.svelte +5 -3
- package/dist/views/core/input/components/color-field/color-field.svelte +7 -1
- package/dist/views/core/input/components/file-field/file-field.svelte +2 -0
- package/dist/views/core/input/components/input-field/input-field.svelte +10 -11
- package/dist/views/core/input/components/label/label.svelte +1 -1
- package/dist/views/core/input/components/password-field/password-field.svelte +6 -0
- package/dist/views/core/input/components/phone-field/phone-field.svelte +24 -4
- package/dist/views/core/navbar/components/navbar/navbar.svelte +35 -12
- package/dist/views/core/navbar/components/navbar/navbar.svelte.d.ts +8 -4
- package/dist/views/core/sidebar/components/sidebar.svelte +1 -1
- package/package.json +1 -1
package/dist/actions/ripple.d.ts
CHANGED
|
@@ -3,14 +3,8 @@ export type RipplePropsType = {
|
|
|
3
3
|
/**
|
|
4
4
|
* The color of the ripple effect, default is rgba(0, 0, 0, 0.12)
|
|
5
5
|
*/
|
|
6
|
-
color?: string;
|
|
7
|
-
/**
|
|
8
|
-
* If true, the ripple effect will be light color rgba(255, 255, 255, 0.12), default is false.
|
|
9
|
-
*/
|
|
10
|
-
light?: boolean;
|
|
6
|
+
color?: string | 'light' | 'dark';
|
|
11
7
|
};
|
|
12
|
-
export declare
|
|
13
|
-
export declare const LIGHT_RIPPLE_COLOR = "rgba(255, 255, 255, 0.12)";
|
|
14
|
-
export declare function ripple(node: HTMLElement, { color, light }?: RipplePropsType): {
|
|
8
|
+
export declare function ripple(node: HTMLElement, { color }?: RipplePropsType): {
|
|
15
9
|
destroy(): void;
|
|
16
10
|
};
|
package/dist/actions/ripple.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { isTouchDevice } from '../services';
|
|
2
2
|
import '../tailwind.css';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
export function ripple(node, { color
|
|
3
|
+
const DARK_RIPPLE_COLOR = 'rgba(0, 0, 0, 0.12)';
|
|
4
|
+
const LIGHT_RIPPLE_COLOR = 'rgba(255, 255, 255, 0.12)';
|
|
5
|
+
export function ripple(node, { color } = {}) {
|
|
6
6
|
let containerRemoveTimer;
|
|
7
7
|
const isTouchEnabled = isTouchDevice();
|
|
8
8
|
let timeoutInstance;
|
|
@@ -22,7 +22,14 @@ export function ripple(node, { color, light } = {}) {
|
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
24
|
function startRipple(event) {
|
|
25
|
-
|
|
25
|
+
let isDarkMOde = document.documentElement.classList.contains('dark') || document.body.classList.contains('dark');
|
|
26
|
+
let rippleColor = color || (isDarkMOde ? LIGHT_RIPPLE_COLOR : DARK_RIPPLE_COLOR);
|
|
27
|
+
if (color == 'light') {
|
|
28
|
+
rippleColor = LIGHT_RIPPLE_COLOR;
|
|
29
|
+
}
|
|
30
|
+
if (color == 'dark') {
|
|
31
|
+
rippleColor = DARK_RIPPLE_COLOR;
|
|
32
|
+
}
|
|
26
33
|
const circle = document.createElement('span');
|
|
27
34
|
const diameter = Math.max(node.clientWidth, node.clientHeight);
|
|
28
35
|
const radius = diameter / 2;
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { type unitOfTime } from "moment";
|
|
2
|
-
export declare
|
|
3
|
-
TODAY
|
|
4
|
-
TOMORROW
|
|
5
|
-
YESTERDAY
|
|
6
|
-
THIS_WEEK
|
|
7
|
-
LAST_WEEK
|
|
8
|
-
NEXT_WEEK
|
|
9
|
-
THIS_MONTH
|
|
10
|
-
LAST_MONTH
|
|
11
|
-
NEXT_MONTH
|
|
12
|
-
THIS_YEAR
|
|
13
|
-
LAST_YEAR
|
|
14
|
-
NEXT_YEAR
|
|
2
|
+
export declare class PeriodEnum {
|
|
3
|
+
static TODAY: number;
|
|
4
|
+
static TOMORROW: number;
|
|
5
|
+
static YESTERDAY: number;
|
|
6
|
+
static THIS_WEEK: number;
|
|
7
|
+
static LAST_WEEK: number;
|
|
8
|
+
static NEXT_WEEK: number;
|
|
9
|
+
static THIS_MONTH: number;
|
|
10
|
+
static LAST_MONTH: number;
|
|
11
|
+
static NEXT_MONTH: number;
|
|
12
|
+
static THIS_YEAR: number;
|
|
13
|
+
static LAST_YEAR: number;
|
|
14
|
+
static NEXT_YEAR: number;
|
|
15
15
|
}
|
|
16
16
|
export type FirestoreTimestamp = {
|
|
17
17
|
seconds: number;
|
|
@@ -1,19 +1,18 @@
|
|
|
1
1
|
import moment, {} from "moment";
|
|
2
|
-
export
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
})(PeriodEnum || (PeriodEnum = {}));
|
|
2
|
+
export class PeriodEnum {
|
|
3
|
+
static TODAY = 1;
|
|
4
|
+
static TOMORROW = 2;
|
|
5
|
+
static YESTERDAY = 3;
|
|
6
|
+
static THIS_WEEK = 4;
|
|
7
|
+
static LAST_WEEK = 5;
|
|
8
|
+
static NEXT_WEEK = 6;
|
|
9
|
+
static THIS_MONTH = 7;
|
|
10
|
+
static LAST_MONTH = 8;
|
|
11
|
+
static NEXT_MONTH = 9;
|
|
12
|
+
static THIS_YEAR = 10;
|
|
13
|
+
static LAST_YEAR = 11;
|
|
14
|
+
static NEXT_YEAR = 12;
|
|
15
|
+
}
|
|
17
16
|
export function getDateWith(yearChange) {
|
|
18
17
|
const date = new Date();
|
|
19
18
|
date.setFullYear(date.getFullYear() + yearChange);
|
package/dist/tailwind.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tailwindcss v3.4.10 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}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-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color: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{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}[multiple],[type=date],[type=datetime-local],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],input:where(:not([type])),select,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow:0 0 #0000}[multiple]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,input:where(:not([type])):focus,select:focus,textarea:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-year-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple],[size]:where(select:not([size="1"])){background-image:none;background-position:0 0;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--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(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}[type=checkbox]:checked,[type=radio]:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}[type=checkbox]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0'/%3E%3C/svg%3E")}@media (forced-colors:active) {[type=checkbox]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=radio]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E")}@media (forced-colors:active) {[type=radio]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:checked:focus,[type=checkbox]:checked:hover,[type=radio]:checked:focus,[type=radio]:checked:hover{border-color:transparent;background-color:currentColor}[type=checkbox]:indeterminate{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}@media (forced-colors:active) {[type=checkbox]:indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:indeterminate:focus,[type=checkbox]:indeterminate:hover{border-color:transparent;background-color:currentColor}[type=file]{background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}[type=file]:focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}*,: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: }.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-20{bottom:5rem}.left-1\/2{left:50%}.right-0{right:0}.start-1{inset-inline-start:.25rem}.top-0{top:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-mb-2{margin-bottom:-.5rem}.ml-4{margin-left:1rem}.ms-1{margin-inline-start:.25rem}.mt-1{margin-top:.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.inline-grid{display:inline-grid}.hidden{display:none}.\!h-4{height:1rem!important}.\!h-5{height:1.25rem!important}.\!h-6{height:1.5rem!important}.\!h-7{height:1.75rem!important}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-1\/2vh{max-height:50vh}.max-h-80{max-height:20rem}.max-h-full{max-height:100%}.max-h-screen{max-height:100vh}.min-h-full{min-height:100%}.min-h-max{min-height:-moz-max-content;min-height:max-content}.\!w-4{width:1rem!important}.\!w-5{width:1.25rem!important}.\!w-6{width:1.5rem!important}.\!w-7{width:1.75rem!important}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-60{width:15rem}.w-64{width:16rem}.w-7\/10{width:70%}.w-72{width:18rem}.w-8{width:2rem}.w-96{width:24rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-full{max-width:100%}.shrink-0{flex-shrink:0}.flex-grow,.grow{flex-grow:1}.origin-top-left{transform-origin:top left}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-x-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-x-full{--tw-translate-x:-100%}.-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%}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-1\/2{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-x-1\/2{--tw-translate-x:50%}.translate-x-full{--tw-translate-x:100%}.translate-x-full,.translate-y-0{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-0{--tw-translate-y:0px}.translate-y-4{--tw-translate-y:1rem}.translate-y-4,.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%}.scale-100{--tw-scale-x:1;--tw-scale-y:1}.scale-100,.scale-95{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))}.scale-95{--tw-scale-x:.95;--tw-scale-y:.95}.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 ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-auto{cursor:auto}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.place-items-center{place-items:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-0{gap:0}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1.5rem*var(--tw-space-x-reverse));margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.text-ellipsis{text-overflow:ellipsis}.text-nowrap{text-wrap:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-bl-lg{border-bottom-left-radius:.5rem}.rounded-br-lg{border-bottom-right-radius:.5rem}.rounded-tl-lg{border-top-left-radius:.5rem}.rounded-tr-lg{border-top-right-radius:.5rem}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.bg-gray-500\/20{background-color:hsla(220,9%,46%,.2)}.bg-gray-900\/10{background-color:rgba(17,24,39,.1)}.bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity))}.bg-sky-400{--tw-bg-opacity:1;background-color:rgb(56 189 248/var(--tw-bg-opacity))}.bg-sky-500{--tw-bg-opacity:1;background-color:rgb(14 165 233/var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-0{padding-left:0;padding-right:0}.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-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pb-1{padding-bottom:.25rem}.pl-12{padding-left:3rem}.pl-16{padding-left:4rem}.pr-14{padding-right:3.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-16{padding-top:4rem}.text-left{text-align:left}.text-center{text-align:center}.text-start{text-align:start}.align-middle{vertical-align:middle}.text-3xs{font-size:8px}.text-base{font-size:1rem;line-height:1.5rem}.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}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-6{line-height:1.5rem}.leading-normal{line-height:1.5}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity))}.text-transparent{color:transparent}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-black{--tw-ring-opacity:1;--tw-ring-color:rgb(0 0 0/var(--tw-ring-opacity))}.ring-gray-900\/5{--tw-ring-color:rgba(17,24,39,.05)}.ring-opacity-5{--tw-ring-opacity:0.05}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes ripple-effect{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}.ripple{position:absolute;border-radius:9999px;background-color:currentColor;transform:scale(0);animation:ripple-effect .5s linear;background-color:var(--ripple-color)}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.hover\:bg-indigo-700:hover{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity))}.focus\:border-indigo-500:focus{--tw-border-opacity:1;border-color:rgb(99 102 241/var(--tw-border-opacity))}.focus\:bg-gray-100:focus{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.focus\:bg-gray-200:focus{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.focus\:bg-gray-50:focus{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.focus\:bg-indigo-700:focus{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.focus\:bg-red-700:focus{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0:focus{--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(var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-indigo-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(99 102 241/var(--tw-ring-opacity))}.focus\:ring-indigo-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(79 70 229/var(--tw-ring-opacity))}.disabled\:bg-white:disabled{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.disabled\:text-gray-400:disabled{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:start-0{inset-inline-start:0}.peer:placeholder-shown~.peer-placeholder-shown\:start-0{inset-inline-start:0}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:bg-transparent{background-color:transparent}.peer:placeholder-shown~.peer-placeholder-shown\:bg-transparent{background-color:transparent}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-1{padding-left:.25rem;padding-right:.25rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-1{padding-left:.25rem;padding-right:.25rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-2{padding-left:.5rem;padding-right:.5rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-2{padding-left:.5rem;padding-right:.5rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-2\.5{padding-left:.625rem;padding-right:.625rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-2\.5{padding-left:.625rem;padding-right:.625rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-4{padding-left:1rem;padding-right:1rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-4{padding-left:1rem;padding-right:1rem}.peer:focus~.peer-focus\:start-1{inset-inline-start:.25rem}.peer:focus~.peer-focus\:top-0{top:0}.peer:focus~.peer-focus\:bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.peer:focus~.peer-focus\:px-0{padding-left:0;padding-right:0}.peer:focus~.peer-focus\:px-1{padding-left:.25rem;padding-right:.25rem}@media (min-width:640px){.sm\:fixed{position:fixed}.sm\:inset-y-0{top:0;bottom:0}.sm\:flex{display:flex}.sm\:w-72{width:18rem}.sm\:translate-y-0{--tw-translate-y:0px}.sm\:scale-100,.sm\:translate-y-0{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))}.sm\:scale-100{--tw-scale-x:1;--tw-scale-y:1}.sm\:scale-95{--tw-scale-x:.95;--tw-scale-y:.95;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))}.sm\:flex-col{flex-direction:column}.sm\:pl-72{padding-left:18rem}.sm\:pr-72{padding-right:18rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:fixed{position:fixed}.md\:inset-y-0{top:0;bottom:0}.md\:flex{display:flex}.md\:w-72{width:18rem}.md\:flex-col{flex-direction:column}.md\:pl-72{padding-left:18rem}.md\:pr-72{padding-right:18rem}}@media (min-width:1024px){.lg\:fixed{position:fixed}.lg\:inset-y-0{top:0;bottom:0}.lg\:flex{display:flex}.lg\:w-72{width:18rem}.lg\:w-px{width:1px}.lg\:flex-col{flex-direction:column}.lg\:bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.lg\:pl-72{padding-left:18rem}.lg\:pr-72{padding-right:18rem}}@media (min-width:1280px){.xl\:fixed{position:fixed}.xl\:inset-y-0{top:0;bottom:0}.xl\:flex{display:flex}.xl\:w-72{width:18rem}.xl\:flex-col{flex-direction:column}.xl\:pl-72{padding-left:18rem}.xl\:pr-72{padding-right:18rem}}@media (min-width:1536px){.\32xl\:fixed{position:fixed}.\32xl\:inset-y-0{top:0;bottom:0}.\32xl\:flex{display:flex}.\32xl\:w-72{width:18rem}.\32xl\:flex-col{flex-direction:column}.\32xl\:pl-72{padding-left:18rem}.\32xl\:pr-72{padding-right:18rem}}@media (prefers-color-scheme:dark){.dark\:bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}}
|
|
1
|
+
/*! tailwindcss v3.4.10 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}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-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color: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{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}[multiple],[type=date],[type=datetime-local],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],input:where(:not([type])),select,textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow:0 0 #0000}[multiple]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,input:where(:not([type])):focus,select:focus,textarea:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-meridiem-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-year-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple],[size]:where(select:not([size="1"])){background-image:none;background-position:0 0;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--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(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}[type=checkbox]:checked,[type=radio]:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}[type=checkbox]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0'/%3E%3C/svg%3E")}@media (forced-colors:active) {[type=checkbox]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=radio]:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E")}@media (forced-colors:active) {[type=radio]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:checked:focus,[type=checkbox]:checked:hover,[type=radio]:checked:focus,[type=radio]:checked:hover{border-color:transparent;background-color:currentColor}[type=checkbox]:indeterminate{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}@media (forced-colors:active) {[type=checkbox]:indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:indeterminate:focus,[type=checkbox]:indeterminate:hover{border-color:transparent;background-color:currentColor}[type=file]{background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}[type=file]:focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}*,: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: }.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.invisible{visibility:hidden}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-20{bottom:5rem}.left-1\/2{left:50%}.right-0{right:0}.start-1{inset-inline-start:.25rem}.top-0{top:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-mb-2{margin-bottom:-.5rem}.mb-1{margin-bottom:.25rem}.ml-4{margin-left:1rem}.ms-1{margin-inline-start:.25rem}.mt-1{margin-top:.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.inline-grid{display:inline-grid}.hidden{display:none}.\!h-4{height:1rem!important}.\!h-5{height:1.25rem!important}.\!h-6{height:1.5rem!important}.\!h-7{height:1.75rem!important}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-1\/2vh{max-height:50vh}.max-h-80{max-height:20rem}.max-h-full{max-height:100%}.max-h-screen{max-height:100vh}.min-h-full{min-height:100%}.min-h-max{min-height:-moz-max-content;min-height:max-content}.\!w-4{width:1rem!important}.\!w-5{width:1.25rem!important}.\!w-6{width:1.5rem!important}.\!w-7{width:1.75rem!important}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-60{width:15rem}.w-64{width:16rem}.w-7\/10{width:70%}.w-72{width:18rem}.w-8{width:2rem}.w-96{width:24rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-full{max-width:100%}.shrink-0{flex-shrink:0}.flex-grow,.grow{flex-grow:1}.origin-top-left{transform-origin:top left}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-x-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-x-full{--tw-translate-x:-100%}.-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%}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-1\/2{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-x-1\/2{--tw-translate-x:50%}.translate-x-full{--tw-translate-x:100%}.translate-x-full,.translate-y-0{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-0{--tw-translate-y:0px}.translate-y-4{--tw-translate-y:1rem}.translate-y-4,.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%}.scale-100{--tw-scale-x:1;--tw-scale-y:1}.scale-100,.scale-95{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))}.scale-95{--tw-scale-x:.95;--tw-scale-y:.95}.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 ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-auto{cursor:auto}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.place-items-center{place-items:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-0{gap:0}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1.5rem*var(--tw-space-x-reverse));margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.text-ellipsis{text-overflow:ellipsis}.text-nowrap{text-wrap:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-bl-lg{border-bottom-left-radius:.5rem}.rounded-br-lg{border-bottom-right-radius:.5rem}.rounded-tl-lg{border-top-left-radius:.5rem}.rounded-tr-lg{border-top-right-radius:.5rem}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.bg-gray-500\/20{background-color:hsla(220,9%,46%,.2)}.bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity))}.bg-sky-400{--tw-bg-opacity:1;background-color:rgb(56 189 248/var(--tw-bg-opacity))}.bg-sky-500{--tw-bg-opacity:1;background-color:rgb(14 165 233/var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-0{padding-left:0;padding-right:0}.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-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.pb-1{padding-bottom:.25rem}.pl-12{padding-left:3rem}.pl-16{padding-left:4rem}.pr-14{padding-right:3.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-16{padding-top:4rem}.text-left{text-align:left}.text-center{text-align:center}.text-start{text-align:start}.align-middle{vertical-align:middle}.text-3xs{font-size:8px}.text-base{font-size:1rem;line-height:1.5rem}.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}.font-light{font-weight:300}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-6{line-height:1.5rem}.leading-normal{line-height:1.5}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity))}.text-transparent{color:transparent}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-0{--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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-0,.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-black{--tw-ring-opacity:1;--tw-ring-color:rgb(0 0 0/var(--tw-ring-opacity))}.ring-gray-900\/5{--tw-ring-color:rgba(17,24,39,.05)}.ring-opacity-5{--tw-ring-opacity:0.05}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes ripple-effect{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}.ripple{position:absolute;border-radius:9999px;background-color:currentColor;transform:scale(0);animation:ripple-effect .5s linear;background-color:var(--ripple-color)}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.hover\:bg-indigo-700:hover{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.focus\:bg-gray-200:focus{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.focus\:bg-gray-50:focus{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.focus\:bg-indigo-700:focus{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.focus\:bg-red-700:focus{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.focus\:bg-white:focus{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0:focus{--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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-0:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--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(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-indigo-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(79 70 229/var(--tw-ring-opacity))}.disabled\:bg-white:disabled{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.disabled\:text-gray-400:disabled{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:start-0{inset-inline-start:0}.peer:placeholder-shown~.peer-placeholder-shown\:start-0{inset-inline-start:0}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:placeholder-shown~.peer-placeholder-shown\:top-1\/2{top:50%}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:bg-transparent{background-color:transparent}.peer:placeholder-shown~.peer-placeholder-shown\:bg-transparent{background-color:transparent}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-1{padding-left:.25rem;padding-right:.25rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-1{padding-left:.25rem;padding-right:.25rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-2{padding-left:.5rem;padding-right:.5rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-2{padding-left:.5rem;padding-right:.5rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-2\.5{padding-left:.625rem;padding-right:.625rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-2\.5{padding-left:.625rem;padding-right:.625rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:px-4{padding-left:1rem;padding-right:1rem}.peer:placeholder-shown~.peer-placeholder-shown\:px-4{padding-left:1rem;padding-right:1rem}.peer:-moz-placeholder-shown~.peer-placeholder-shown\:ps-16{padding-inline-start:4rem}.peer:placeholder-shown~.peer-placeholder-shown\:ps-16{padding-inline-start:4rem}.peer:focus~.peer-focus\:start-1{inset-inline-start:.25rem}.peer:focus~.peer-focus\:top-0{top:0}.peer:focus~.peer-focus\:bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.peer:focus~.peer-focus\:px-0{padding-left:0;padding-right:0}.peer:focus~.peer-focus\:px-1{padding-left:.25rem;padding-right:.25rem}@media (min-width:640px){.sm\:fixed{position:fixed}.sm\:inset-y-0{top:0;bottom:0}.sm\:flex{display:flex}.sm\:w-72{width:18rem}.sm\:translate-y-0{--tw-translate-y:0px}.sm\:scale-100,.sm\:translate-y-0{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))}.sm\:scale-100{--tw-scale-x:1;--tw-scale-y:1}.sm\:scale-95{--tw-scale-x:.95;--tw-scale-y:.95;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))}.sm\:flex-col{flex-direction:column}.sm\:pl-72{padding-left:18rem}.sm\:pr-72{padding-right:18rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:fixed{position:fixed}.md\:inset-y-0{top:0;bottom:0}.md\:flex{display:flex}.md\:w-72{width:18rem}.md\:flex-col{flex-direction:column}.md\:pl-72{padding-left:18rem}.md\:pr-72{padding-right:18rem}}@media (min-width:1024px){.lg\:fixed{position:fixed}.lg\:inset-y-0{top:0;bottom:0}.lg\:flex{display:flex}.lg\:w-72{width:18rem}.lg\:w-px{width:1px}.lg\:flex-col{flex-direction:column}.lg\:bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.lg\:pl-72{padding-left:18rem}.lg\:pr-72{padding-right:18rem}}@media (min-width:1280px){.xl\:fixed{position:fixed}.xl\:inset-y-0{top:0;bottom:0}.xl\:flex{display:flex}.xl\:w-72{width:18rem}.xl\:flex-col{flex-direction:column}.xl\:pl-72{padding-left:18rem}.xl\:pr-72{padding-right:18rem}}@media (min-width:1536px){.\32xl\:fixed{position:fixed}.\32xl\:inset-y-0{top:0;bottom:0}.\32xl\:flex{display:flex}.\32xl\:w-72{width:18rem}.\32xl\:flex-col{flex-direction:column}.\32xl\:pl-72{padding-left:18rem}.\32xl\:pr-72{padding-right:18rem}}@media (prefers-color-scheme:dark){.dark\:border-gray-600{--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity))}.dark\:bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.dark\:bg-transparent{background-color:transparent}.dark\:hover\:bg-gray-900:hover{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}}
|
|
@@ -14,7 +14,8 @@
|
|
|
14
14
|
spinnerClassName?: string;
|
|
15
15
|
onlySpinner?: boolean;
|
|
16
16
|
children?: Snippet;
|
|
17
|
-
|
|
17
|
+
hasRipple?: boolean;
|
|
18
|
+
rippleColor?: string | 'light' | 'dark';
|
|
18
19
|
onClick?: (ev: MouseEvent) => void;
|
|
19
20
|
};
|
|
20
21
|
</script>
|
|
@@ -41,12 +42,14 @@
|
|
|
41
42
|
spinnerClassName = '',
|
|
42
43
|
onlySpinner = false,
|
|
43
44
|
children,
|
|
44
|
-
|
|
45
|
+
hasRipple = true,
|
|
46
|
+
rippleColor,
|
|
45
47
|
onClick = (ev: MouseEvent) => {}
|
|
46
48
|
}: ButtonPropsType = $props();
|
|
47
49
|
|
|
48
50
|
function maybeRipple(node: HTMLElement, options?: RipplePropsType) {
|
|
49
|
-
if (
|
|
51
|
+
if (hasRipple) {
|
|
52
|
+
options = options || { color: rippleColor };
|
|
50
53
|
return ripple(node, options);
|
|
51
54
|
}
|
|
52
55
|
return {
|
|
@@ -13,7 +13,8 @@ export type ButtonPropsType = {
|
|
|
13
13
|
spinnerClassName?: string;
|
|
14
14
|
onlySpinner?: boolean;
|
|
15
15
|
children?: Snippet;
|
|
16
|
-
|
|
16
|
+
hasRipple?: boolean;
|
|
17
|
+
rippleColor?: string | 'light' | 'dark';
|
|
17
18
|
onClick?: (ev: MouseEvent) => void;
|
|
18
19
|
};
|
|
19
20
|
import '../../../../../tailwind.css';
|
|
@@ -29,7 +29,7 @@
|
|
|
29
29
|
{#snippet button()}
|
|
30
30
|
<Button
|
|
31
31
|
{iconPath}
|
|
32
|
-
className="w-12 h-12 p-3 rounded-full
|
|
32
|
+
className="w-12 h-12 p-3 rounded-full hover:bg-gray-50 dark:hover:bg-gray-900 {className}"
|
|
33
33
|
{iconClassName}
|
|
34
34
|
{onClick}
|
|
35
35
|
/>
|
|
@@ -1,101 +1,109 @@
|
|
|
1
|
+
<script lang="ts" module>
|
|
2
|
+
</script>
|
|
3
|
+
|
|
1
4
|
<script lang="ts">
|
|
2
5
|
import '../../../../../tailwind.css';
|
|
3
|
-
|
|
6
|
+
|
|
4
7
|
import { ripple } from '../../../../../actions/ripple.js';
|
|
5
|
-
|
|
6
|
-
import {
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
Icon,
|
|
11
|
+
mdiCheckCircle,
|
|
12
|
+
mdiCheckCircleOutline,
|
|
13
|
+
mdiChevronDown
|
|
14
|
+
} from '../../../icon';
|
|
7
15
|
import type { Snippet } from 'svelte';
|
|
8
16
|
import type { ListItemType } from '../button-list-item/button-list-item.svelte';
|
|
9
17
|
import ButtonListItem from '../button-list-item/button-list-item.svelte';
|
|
10
18
|
|
|
11
|
-
|
|
12
|
-
OPENED
|
|
13
|
-
CLOSED
|
|
19
|
+
class MenuStateEnum {
|
|
20
|
+
static OPENED = 'OPENED';
|
|
21
|
+
static CLOSED = 'CLOSED';
|
|
14
22
|
}
|
|
15
23
|
|
|
16
24
|
type PropsType = {
|
|
17
|
-
|
|
25
|
+
backgropClassName?: string;
|
|
26
|
+
buttonSnippet?: Snippet;
|
|
27
|
+
checkClassName?: string;
|
|
28
|
+
checkIconClassName?: string;
|
|
29
|
+
checkIconPath?: string;
|
|
30
|
+
children?: Snippet;
|
|
18
31
|
className?: string;
|
|
19
|
-
|
|
20
|
-
style?: string;
|
|
32
|
+
containerClassName?: string;
|
|
21
33
|
disabled?: boolean | undefined | null;
|
|
22
|
-
|
|
23
|
-
imgClassName?: string;
|
|
24
|
-
imgAlt?: string;
|
|
25
|
-
leftIconPath?: string;
|
|
26
|
-
leftIconClassName?: string;
|
|
27
|
-
rightIconPath?: string;
|
|
28
|
-
rightIconClassName?: string;
|
|
29
|
-
title?: string | any;
|
|
30
|
-
titleClassName?: string;
|
|
34
|
+
dividerClassName?: string;
|
|
31
35
|
dropdownClassName?: string;
|
|
32
|
-
dropdownStyle?: string;
|
|
33
|
-
hasCheck?: boolean;
|
|
34
|
-
checkIconPath?: string;
|
|
35
|
-
checkIconClassName?: string;
|
|
36
|
-
menus?: string[] | ListItemType[];
|
|
37
|
-
containerClassName?: string;
|
|
38
|
-
backgropClassName?: string;
|
|
39
|
-
menuItemClassName?: string;
|
|
40
|
-
uncheckIconPath?: string;
|
|
41
|
-
uncheckIconClassName?: string;
|
|
42
|
-
dropdownOpenClassName?: string;
|
|
43
36
|
dropdownCloseClassName?: string;
|
|
44
|
-
|
|
37
|
+
dropdownOpenClassName?: string;
|
|
38
|
+
dropdownStyle?: string;
|
|
39
|
+
dropIconClassName?: string;
|
|
40
|
+
dropIconPath?: string;
|
|
41
|
+
hasCheckbox?: boolean;
|
|
42
|
+
id?: string;
|
|
43
|
+
imgAlt?: string;
|
|
44
|
+
imgClassName?: string;
|
|
45
|
+
imgSrc?: string;
|
|
46
|
+
leftIconClassName?: string;
|
|
47
|
+
leftIconPath?: string;
|
|
45
48
|
listIconClassName?: string;
|
|
46
49
|
listImgClassName?: string;
|
|
47
|
-
listTitleClassName?: string;
|
|
48
50
|
listSubtitleClassName?: string;
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
dropIconClassName?: string;
|
|
52
|
-
onmenuclick?: (ev: MouseEvent, item: string | ListItemType, index: number) => void;
|
|
53
|
-
children?: Snippet;
|
|
54
|
-
buttonSnippet?: Snippet;
|
|
55
|
-
menuItemSnippet?: Snippet<[ListItemType, number]>;
|
|
51
|
+
listTitleClassName?: string;
|
|
52
|
+
menuItemClassName?: string;
|
|
56
53
|
menuItemInnerSnippet?: Snippet<[ListItemType, number]>;
|
|
54
|
+
menuItemSnippet?: Snippet<[ListItemType, number]>;
|
|
55
|
+
menus?: string[] | ListItemType[];
|
|
56
|
+
onmenuclick?: (ev: MouseEvent, item: string | ListItemType, index: number) => void;
|
|
57
|
+
rightIconClassName?: string;
|
|
58
|
+
rightIconPath?: string;
|
|
59
|
+
screenOnlyDesc?: string;
|
|
60
|
+
style?: string;
|
|
61
|
+
title?: string | any;
|
|
62
|
+
titleClassName?: string;
|
|
63
|
+
uncheckIconClassName?: string;
|
|
64
|
+
uncheckIconPath?: string;
|
|
57
65
|
};
|
|
58
66
|
|
|
59
67
|
let {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
style = '',
|
|
64
|
-
imgSrc = '',
|
|
65
|
-
imgClassName = '',
|
|
66
|
-
imgAlt = 'Menu',
|
|
67
|
-
leftIconPath = '',
|
|
68
|
-
leftIconClassName = '',
|
|
69
|
-
rightIconPath = '',
|
|
70
|
-
rightIconClassName = '',
|
|
71
|
-
dropIconPath = mdiChevronDown,
|
|
72
|
-
dropIconClassName = '',
|
|
73
|
-
titleClassName = '',
|
|
74
|
-
title = 'Button',
|
|
75
|
-
dropdownStyle = '',
|
|
76
|
-
dropdownClassName = '',
|
|
77
|
-
hasCheck = false,
|
|
78
|
-
uncheckIconPath = mdiCheckCircleOutline,
|
|
79
|
-
checkIconPath = mdiCheckCircle,
|
|
68
|
+
backgropClassName = '',
|
|
69
|
+
buttonSnippet,
|
|
70
|
+
checkClassName = '',
|
|
80
71
|
checkIconClassName = '',
|
|
72
|
+
checkIconPath = mdiCheckCircle,
|
|
73
|
+
children,
|
|
74
|
+
className = '',
|
|
81
75
|
containerClassName = '',
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
menuItemClassName = '',
|
|
85
|
-
uncheckIconClassName = '',
|
|
86
|
-
dropdownOpenClassName = '',
|
|
76
|
+
dividerClassName = '',
|
|
77
|
+
dropdownClassName = '',
|
|
87
78
|
dropdownCloseClassName = '',
|
|
88
|
-
|
|
79
|
+
dropdownOpenClassName = '',
|
|
80
|
+
dropdownStyle = '',
|
|
81
|
+
dropIconClassName = '',
|
|
82
|
+
dropIconPath = mdiChevronDown,
|
|
83
|
+
hasCheckbox = false,
|
|
84
|
+
id = 'menu',
|
|
85
|
+
imgAlt = 'Menu',
|
|
86
|
+
imgClassName = '',
|
|
87
|
+
imgSrc = '',
|
|
88
|
+
leftIconClassName = '',
|
|
89
|
+
leftIconPath = '',
|
|
89
90
|
listIconClassName = '',
|
|
90
91
|
listImgClassName = '',
|
|
91
|
-
listTitleClassName = '',
|
|
92
92
|
listSubtitleClassName = '',
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
buttonSnippet,
|
|
93
|
+
listTitleClassName = '',
|
|
94
|
+
menuItemClassName = '',
|
|
95
|
+
menuItemInnerSnippet,
|
|
97
96
|
menuItemSnippet,
|
|
98
|
-
|
|
97
|
+
menus = [],
|
|
98
|
+
onmenuclick = (ev: MouseEvent, item: string | ListItemType, index: number) => {},
|
|
99
|
+
rightIconClassName = '',
|
|
100
|
+
rightIconPath = '',
|
|
101
|
+
screenOnlyDesc = 'Menu',
|
|
102
|
+
style = '',
|
|
103
|
+
title = 'Button',
|
|
104
|
+
titleClassName = '',
|
|
105
|
+
uncheckIconClassName = '',
|
|
106
|
+
uncheckIconPath = mdiCheckCircleOutline
|
|
99
107
|
}: PropsType = $props();
|
|
100
108
|
|
|
101
109
|
let expanded = $state(false);
|
|
@@ -176,7 +184,7 @@
|
|
|
176
184
|
{#if dropIconPath}
|
|
177
185
|
<Icon path={dropIconPath} className="w-5 h-5 text-gray-400 {dropIconClassName}" />
|
|
178
186
|
{/if}
|
|
179
|
-
{/if}
|
|
187
|
+
{/if}
|
|
180
188
|
</div>
|
|
181
189
|
</button>
|
|
182
190
|
{#if dropdownState == MenuStateEnum.OPENED}
|
|
@@ -211,8 +219,8 @@
|
|
|
211
219
|
<ButtonListItem
|
|
212
220
|
item={menu}
|
|
213
221
|
{index}
|
|
214
|
-
{
|
|
215
|
-
|
|
222
|
+
{hasCheckbox}
|
|
223
|
+
{id}
|
|
216
224
|
className={menuItemClassName}
|
|
217
225
|
{uncheckIconPath}
|
|
218
226
|
{checkIconPath}
|
|
@@ -15,46 +15,46 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
|
|
|
15
15
|
z_$$bindings?: Bindings;
|
|
16
16
|
}
|
|
17
17
|
declare const ButtonMenu: $$__sveltets_2_IsomorphicComponent<{
|
|
18
|
-
|
|
18
|
+
backgropClassName?: string;
|
|
19
|
+
buttonSnippet?: Snippet;
|
|
20
|
+
checkClassName?: string;
|
|
21
|
+
checkIconClassName?: string;
|
|
22
|
+
checkIconPath?: string;
|
|
23
|
+
children?: Snippet;
|
|
19
24
|
className?: string;
|
|
20
|
-
|
|
21
|
-
style?: string;
|
|
25
|
+
containerClassName?: string;
|
|
22
26
|
disabled?: boolean | undefined | null;
|
|
23
|
-
|
|
24
|
-
imgClassName?: string;
|
|
25
|
-
imgAlt?: string;
|
|
26
|
-
leftIconPath?: string;
|
|
27
|
-
leftIconClassName?: string;
|
|
28
|
-
rightIconPath?: string;
|
|
29
|
-
rightIconClassName?: string;
|
|
30
|
-
title?: string | any;
|
|
31
|
-
titleClassName?: string;
|
|
27
|
+
dividerClassName?: string;
|
|
32
28
|
dropdownClassName?: string;
|
|
33
|
-
dropdownStyle?: string;
|
|
34
|
-
hasCheck?: boolean;
|
|
35
|
-
checkIconPath?: string;
|
|
36
|
-
checkIconClassName?: string;
|
|
37
|
-
menus?: string[] | ListItemType[];
|
|
38
|
-
containerClassName?: string;
|
|
39
|
-
backgropClassName?: string;
|
|
40
|
-
menuItemClassName?: string;
|
|
41
|
-
uncheckIconPath?: string;
|
|
42
|
-
uncheckIconClassName?: string;
|
|
43
|
-
dropdownOpenClassName?: string;
|
|
44
29
|
dropdownCloseClassName?: string;
|
|
45
|
-
|
|
30
|
+
dropdownOpenClassName?: string;
|
|
31
|
+
dropdownStyle?: string;
|
|
32
|
+
dropIconClassName?: string;
|
|
33
|
+
dropIconPath?: string;
|
|
34
|
+
hasCheckbox?: boolean;
|
|
35
|
+
id?: string;
|
|
36
|
+
imgAlt?: string;
|
|
37
|
+
imgClassName?: string;
|
|
38
|
+
imgSrc?: string;
|
|
39
|
+
leftIconClassName?: string;
|
|
40
|
+
leftIconPath?: string;
|
|
46
41
|
listIconClassName?: string;
|
|
47
42
|
listImgClassName?: string;
|
|
48
|
-
listTitleClassName?: string;
|
|
49
43
|
listSubtitleClassName?: string;
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
dropIconClassName?: string;
|
|
53
|
-
onmenuclick?: (ev: MouseEvent, item: string | ListItemType, index: number) => void;
|
|
54
|
-
children?: Snippet;
|
|
55
|
-
buttonSnippet?: Snippet;
|
|
56
|
-
menuItemSnippet?: Snippet<[ListItemType, number]>;
|
|
44
|
+
listTitleClassName?: string;
|
|
45
|
+
menuItemClassName?: string;
|
|
57
46
|
menuItemInnerSnippet?: Snippet<[ListItemType, number]>;
|
|
47
|
+
menuItemSnippet?: Snippet<[ListItemType, number]>;
|
|
48
|
+
menus?: string[] | ListItemType[];
|
|
49
|
+
onmenuclick?: (ev: MouseEvent, item: string | ListItemType, index: number) => void;
|
|
50
|
+
rightIconClassName?: string;
|
|
51
|
+
rightIconPath?: string;
|
|
52
|
+
screenOnlyDesc?: string;
|
|
53
|
+
style?: string;
|
|
54
|
+
title?: string | any;
|
|
55
|
+
titleClassName?: string;
|
|
56
|
+
uncheckIconClassName?: string;
|
|
57
|
+
uncheckIconPath?: string;
|
|
58
58
|
}, {
|
|
59
59
|
[evt: string]: CustomEvent<any>;
|
|
60
60
|
}, {}, {}, "">;
|
|
@@ -61,7 +61,7 @@
|
|
|
61
61
|
<div {id} class="relative z-30 {containerClassName}" role="dialog" aria-modal="true">
|
|
62
62
|
<!-- Backdrop -->
|
|
63
63
|
<div
|
|
64
|
-
class="fixed inset-0 bg-
|
|
64
|
+
class="fixed inset-0 bg-base-900/10 bg-base-50/10 transition-opacity ease-linear duration-300 {isOpened
|
|
65
65
|
? 'opacity-100'
|
|
66
66
|
: 'opacity-0'} {backdropClassName}"
|
|
67
67
|
aria-hidden="true"
|
|
@@ -86,7 +86,9 @@
|
|
|
86
86
|
{position === 'bottom' ? (isOpened ? 'translate-y-0' : 'translate-y-full') : ''}
|
|
87
87
|
{drawerClassName} "
|
|
88
88
|
>
|
|
89
|
-
<div
|
|
89
|
+
<div
|
|
90
|
+
class="grow w-72 bg-white dark:bg-base-800 text-base-800 dark:text-base-200 border-base-100 dark:border-base-700 {className}"
|
|
91
|
+
>
|
|
90
92
|
{#if children}
|
|
91
93
|
{@render children()}
|
|
92
94
|
{/if}
|
|
@@ -34,8 +34,10 @@
|
|
|
34
34
|
|
|
35
35
|
{#snippet labelSnippet()}
|
|
36
36
|
<div class="text-sm leading-6 mx-4 flex-grow">
|
|
37
|
-
<div class="font-medium text-sm text-
|
|
38
|
-
|
|
37
|
+
<div class="font-medium text-sm text-base-900 dark:text-base-100 {labelClassName}">
|
|
38
|
+
{label || ''}
|
|
39
|
+
</div>
|
|
40
|
+
<div class="text-xs text-base-500 dark:text-base-500 {descClassName}">{desc || ''}</div>
|
|
39
41
|
</div>
|
|
40
42
|
{/snippet}
|
|
41
43
|
<div class=" {containerClassName}">
|
|
@@ -49,7 +51,7 @@
|
|
|
49
51
|
aria-describedby="comments-description"
|
|
50
52
|
name={name || id}
|
|
51
53
|
type="checkbox"
|
|
52
|
-
class="
|
|
54
|
+
class="w-4 h-4 rounded focus:ring-2 text-pimary-600 dark:text-pimary-600 bg-gray-100 dark:bg-gray-700 border-gray-300 dark:border-gray-600 focus:ring-pimary-500 dark:focus:ring-pimary-600"
|
|
53
55
|
onchange={(ev) => handleChange(ev)}
|
|
54
56
|
/>
|
|
55
57
|
{#if position == 'left'}
|
|
@@ -6,6 +6,8 @@
|
|
|
6
6
|
import InputField, { type InputFieldPropsType } from '../input-field/input-field.svelte';
|
|
7
7
|
|
|
8
8
|
let {
|
|
9
|
+
id,
|
|
10
|
+
name,
|
|
9
11
|
size,
|
|
10
12
|
appearance,
|
|
11
13
|
value = $bindable('#000000'),
|
|
@@ -73,7 +75,9 @@
|
|
|
73
75
|
|
|
74
76
|
{#snippet colorButton()}
|
|
75
77
|
<button
|
|
76
|
-
|
|
78
|
+
id="btn-color-picker-{name || id}"
|
|
79
|
+
type="button"
|
|
80
|
+
class="px-2 h-full hover:bg-base-100 hover:bg-base-900 {btnRoundedClassName}"
|
|
77
81
|
use:ripple
|
|
78
82
|
onclick={handleColorBtnClick}
|
|
79
83
|
>
|
|
@@ -85,6 +89,8 @@
|
|
|
85
89
|
<InputField
|
|
86
90
|
{...props}
|
|
87
91
|
type="text"
|
|
92
|
+
{id}
|
|
93
|
+
{name}
|
|
88
94
|
bind:this={inputFieldRef}
|
|
89
95
|
className="pr-8 {props?.className}"
|
|
90
96
|
rightSnippet={colorButton}
|
|
@@ -182,7 +182,7 @@
|
|
|
182
182
|
floatingLabelPaddingClassName = flpcn;
|
|
183
183
|
}
|
|
184
184
|
|
|
185
|
-
floatingLabelClassName = `absolute duration-300 transform top-0 rounded -translate-y-1/2 peer-placeholder-shown:top-1/2 peer-focus:top-0 peer-placeholder-shown:start-0 peer-focus:start-1 bg-white peer-
|
|
185
|
+
floatingLabelClassName = `absolute duration-300 transform top-0 rounded -translate-y-1/2 peer-placeholder-shown:top-1/2 peer-focus:top-0 peer-placeholder-shown:start-0 peer-focus:start-1 bg-white peer-focus:bg-white dark:bg-base-700 peer-focus:bg-base-800 peer-placeholder-shown:bg-transparent start-1 ${floatingLabelPaddingClassName} ${floatingLabelTextClassName}`;
|
|
186
186
|
}
|
|
187
187
|
});
|
|
188
188
|
|
|
@@ -191,28 +191,27 @@
|
|
|
191
191
|
switch (appearance) {
|
|
192
192
|
case 'normal':
|
|
193
193
|
appearanceClassName =
|
|
194
|
-
'bg-
|
|
194
|
+
'border rounded-lg bg-base-100 dark:bg-base-700 border-base-300 dark:border-base-500 text-base-950 dark:text-base-50 focus:ring-primary-500 focus:border-primary-500 dark:focus:ring-primary-500 dark:focus:border-primary-500 focus:bg-white dark:focus:bg-base-800 ';
|
|
195
195
|
break;
|
|
196
196
|
case 'box':
|
|
197
197
|
appearanceClassName =
|
|
198
|
-
'bg-
|
|
198
|
+
'border bg-base-100 dark:bg-base-700 border-base-300 dark:border-base-500 text-base-950 dark:text-base-50 focus:ring-primary-500 focus:border-primary-500 dark:focus:ring-primary-500 dark:focus:border-primary-500 focus:bg-white dark:focus:bg-base-800 ';
|
|
199
199
|
break;
|
|
200
200
|
case 'fill':
|
|
201
201
|
appearanceClassName =
|
|
202
|
-
'
|
|
202
|
+
' border-0 appearance-none focus:ring-0 bg-base-100 dark:bg-base-700 text-base-950 dark:text-base-50 focus:bg-white dark:focus:bg-base-800 ';
|
|
203
203
|
break;
|
|
204
|
-
|
|
205
204
|
case 'underline':
|
|
206
205
|
appearanceClassName =
|
|
207
|
-
'bg-transparent border-0 border-b-2 border-
|
|
206
|
+
'bg-transparent border-0 border-b-2 appearance-none focus:ring-0 text-base-950 dark:text-base-50 border-base-300 dark:border-base-700 focus:border-primary-500 dark:focus:border-primary-500';
|
|
208
207
|
break;
|
|
209
208
|
case 'fill-underline':
|
|
210
209
|
appearanceClassName =
|
|
211
|
-
'
|
|
210
|
+
'border-0 border-b-2 appearance-none ring-0 text-base-950 dark:text-base-50 bg-base-100 dark:bg-base-700 border-base-300 dark:border-base-500 focus:border-primary-500 dark:focus:border-primary-500 ';
|
|
212
211
|
break;
|
|
213
212
|
case 'none':
|
|
214
213
|
appearanceClassName =
|
|
215
|
-
'
|
|
214
|
+
'border-0 focus:ring-0 appearance-none text-base-950 dark:text-base-50 bg-transparent dark:bg-transparent focus:bg-base-100 dark:focus:bg-base-800 hover:bg-base-100 dark:hover:bg-base-800';
|
|
216
215
|
break;
|
|
217
216
|
}
|
|
218
217
|
}
|
|
@@ -256,7 +255,7 @@
|
|
|
256
255
|
<Label
|
|
257
256
|
forName={id}
|
|
258
257
|
{label}
|
|
259
|
-
className="{floatingLabelClassName} {labelClassName}"
|
|
258
|
+
className=" {floatingLabel ? '' : 'mb-1 '} {floatingLabelClassName} {labelClassName}"
|
|
260
259
|
{required}
|
|
261
260
|
{requiredSymbolColor}
|
|
262
261
|
{requiredSymbol}
|
|
@@ -281,7 +280,7 @@
|
|
|
281
280
|
<textarea
|
|
282
281
|
bind:this={inputRef}
|
|
283
282
|
bind:value
|
|
284
|
-
class="block w-full peer {appearanceClassName} {sizeClassName} {className}"
|
|
283
|
+
class="block w-full peer outline-none {appearanceClassName} {sizeClassName} {className}"
|
|
285
284
|
{title}
|
|
286
285
|
{id}
|
|
287
286
|
{name}
|
|
@@ -312,7 +311,7 @@
|
|
|
312
311
|
<input
|
|
313
312
|
bind:this={inputRef}
|
|
314
313
|
bind:value
|
|
315
|
-
class="block w-full peer {appearanceClassName} {sizeClassName} {className}"
|
|
314
|
+
class="block w-full peer outline-none {appearanceClassName} {sizeClassName} {className}"
|
|
316
315
|
{title}
|
|
317
316
|
{type}
|
|
318
317
|
{id}
|
|
@@ -26,7 +26,7 @@
|
|
|
26
26
|
|
|
27
27
|
<label
|
|
28
28
|
for={forName || ''}
|
|
29
|
-
class="block text-sm text-
|
|
29
|
+
class="block text-sm text-base-500 dark:text-base-400 {hasRequiredSymbol && required ? 'required' : ''} {className}"
|
|
30
30
|
style="--requiredSymbolColor:{requiredSymbolColor}; --requiredSymbol: '{requiredSymbol}'; "
|
|
31
31
|
>
|
|
32
32
|
{#if children}
|
|
@@ -10,6 +10,8 @@
|
|
|
10
10
|
appearance,
|
|
11
11
|
buttonClassName,
|
|
12
12
|
iconClassName,
|
|
13
|
+
name,
|
|
14
|
+
id,
|
|
13
15
|
value = $bindable(),
|
|
14
16
|
...props
|
|
15
17
|
}: InputFieldPropsType & {
|
|
@@ -62,6 +64,8 @@
|
|
|
62
64
|
|
|
63
65
|
{#snippet showPasswordButton()}
|
|
64
66
|
<button
|
|
67
|
+
id="btn-eye-{name || id}"
|
|
68
|
+
type="button"
|
|
65
69
|
class="px-3 h-full hover:bg-gray-100 {btnRoundedClassName} {buttonClassName}"
|
|
66
70
|
use:ripple
|
|
67
71
|
onclick={handleTogglePassword}
|
|
@@ -77,6 +81,8 @@
|
|
|
77
81
|
bind:this={inputFieldRef}
|
|
78
82
|
{...props}
|
|
79
83
|
{type}
|
|
84
|
+
{id}
|
|
85
|
+
{name}
|
|
80
86
|
maxlength={props?.maxlength || 200}
|
|
81
87
|
rightSnippet={showPasswordButton}
|
|
82
88
|
{size}
|
|
@@ -29,12 +29,16 @@
|
|
|
29
29
|
import type { DialogSizeType } from '../../../dialog';
|
|
30
30
|
|
|
31
31
|
let {
|
|
32
|
+
id,
|
|
33
|
+
name,
|
|
32
34
|
value = $bindable(''),
|
|
33
35
|
size,
|
|
34
36
|
appearance,
|
|
35
37
|
buttonClassName,
|
|
36
38
|
className,
|
|
37
39
|
dialCode = $bindable('+1'),
|
|
40
|
+
floatingLabel,
|
|
41
|
+
labelClassName,
|
|
38
42
|
...props
|
|
39
43
|
}: InputFieldPropsType & {
|
|
40
44
|
buttonClassName?: string;
|
|
@@ -52,13 +56,13 @@
|
|
|
52
56
|
if (!_dailCode && !_phoneNumber && LibPhonenumber) {
|
|
53
57
|
try {
|
|
54
58
|
if (dialCode) {
|
|
55
|
-
_dailCode =
|
|
59
|
+
_dailCode = formatDialCode(dialCode);
|
|
56
60
|
}
|
|
57
61
|
if (value) {
|
|
58
62
|
let parsed = LibPhonenumber?.parsePhoneNumber(value as string);
|
|
59
63
|
if (parsed && parsed.isValid()) {
|
|
60
64
|
_phoneNumber = parsed.nationalNumber || '';
|
|
61
|
-
_dailCode =
|
|
65
|
+
_dailCode = formatDialCode(parsed.countryCallingCode);
|
|
62
66
|
}
|
|
63
67
|
}
|
|
64
68
|
} catch (error) {}
|
|
@@ -75,6 +79,14 @@
|
|
|
75
79
|
inputFieldRef?.focus();
|
|
76
80
|
}
|
|
77
81
|
|
|
82
|
+
function formatDialCode(dialcode: string) {
|
|
83
|
+
dialcode = `${dialCode}`.trim();
|
|
84
|
+
if (!dialCode.startsWith('+')) {
|
|
85
|
+
dialcode = `+${dialCode}`;
|
|
86
|
+
}
|
|
87
|
+
return dialcode;
|
|
88
|
+
}
|
|
89
|
+
|
|
78
90
|
async function hanleDialCodePicker() {
|
|
79
91
|
if (EasyCountryData) {
|
|
80
92
|
let items = EasyCountryData.getCountries();
|
|
@@ -117,6 +129,7 @@
|
|
|
117
129
|
function updatePhonenumber(_dialCode: string, _phoneNumber: string) {
|
|
118
130
|
if (LibPhonenumber) {
|
|
119
131
|
if (_phoneNumber) {
|
|
132
|
+
_dialCode = formatDialCode(_dialCode);
|
|
120
133
|
try {
|
|
121
134
|
// console.log('updatePhonenumber', { dialCode, phoneNumber });
|
|
122
135
|
let parsed = LibPhonenumber.parsePhoneNumber(_dialCode + _phoneNumber);
|
|
@@ -142,7 +155,8 @@
|
|
|
142
155
|
ev.key === 'ArrowLeft' ||
|
|
143
156
|
ev.key === 'ArrowRight' ||
|
|
144
157
|
ev.key === 'ArrowUp' ||
|
|
145
|
-
ev.key === 'ArrowDown'
|
|
158
|
+
ev.key === 'ArrowDown'||
|
|
159
|
+
ev.key === 'Tab'
|
|
146
160
|
)
|
|
147
161
|
) {
|
|
148
162
|
ev.preventDefault();
|
|
@@ -152,6 +166,8 @@
|
|
|
152
166
|
|
|
153
167
|
{#snippet showPasswordButton()}
|
|
154
168
|
<button
|
|
169
|
+
id="btn-dialcode-picker-{name || id}"
|
|
170
|
+
type="button"
|
|
155
171
|
class="w-16 h-full hover:bg-gray-100 font-bold text-gray-400 {btnRoundedClassName} {buttonClassName}"
|
|
156
172
|
use:ripple
|
|
157
173
|
onclick={hanleDialCodePicker}
|
|
@@ -177,11 +193,15 @@
|
|
|
177
193
|
bind:this={inputFieldRef}
|
|
178
194
|
value={_phoneNumber}
|
|
179
195
|
type="tel"
|
|
196
|
+
{id}
|
|
197
|
+
{name}
|
|
180
198
|
maxlength={props?.maxlength || 12}
|
|
181
199
|
leftSnippet={showPasswordButton}
|
|
182
200
|
{size}
|
|
183
201
|
{appearance}
|
|
184
|
-
|
|
202
|
+
{floatingLabel}
|
|
203
|
+
className="pl-16 {className}"
|
|
204
|
+
labelClassName=" {floatingLabel ? 'peer-placeholder-shown:ps-16' : ''} {labelClassName}"
|
|
185
205
|
oninput={handleNumberInput}
|
|
186
206
|
onkeydown={handleNumberKeyDown}
|
|
187
207
|
/>
|
|
@@ -1,22 +1,26 @@
|
|
|
1
1
|
<script lang="ts">
|
|
2
|
-
import '
|
|
2
|
+
import ButtonBack from '../../../button/components/button-back/button-back.svelte';
|
|
3
3
|
import Button from '../../../button/components/button/button.svelte';
|
|
4
|
-
import type { Snippet } from 'svelte';
|
|
5
4
|
import { Icon, mdiMenu } from '../../../icon';
|
|
5
|
+
import type { Snippet } from 'svelte';
|
|
6
|
+
import '../../../../../tailwind.css';
|
|
6
7
|
|
|
7
8
|
type PropsType = {
|
|
9
|
+
backIconPath?: string;
|
|
10
|
+
backButtonClassName?: string;
|
|
8
11
|
centerContainerClassName?: string;
|
|
9
|
-
centerSnippet?: Snippet
|
|
12
|
+
centerSnippet?: Snippet<[]>;
|
|
10
13
|
children?: Snippet;
|
|
11
14
|
className?: String;
|
|
12
15
|
drawerButtonClassName?: string;
|
|
16
|
+
hasBack?: boolean;
|
|
13
17
|
hasLogo?: boolean;
|
|
14
18
|
hasMore?: boolean;
|
|
15
19
|
hasSubtitle?: boolean;
|
|
16
20
|
hasTitle?: boolean;
|
|
17
21
|
id?: string;
|
|
18
22
|
leftContainerClassName?: string;
|
|
19
|
-
leftSnippet?: Snippet
|
|
23
|
+
leftSnippet?: Snippet<[]>;
|
|
20
24
|
logoButtonClassName?: string;
|
|
21
25
|
logoIconClassName?: string;
|
|
22
26
|
logoIconPath?: string;
|
|
@@ -26,8 +30,9 @@
|
|
|
26
30
|
morePosition?: 'left' | 'right';
|
|
27
31
|
onLogo?: () => void;
|
|
28
32
|
onMore?: () => void;
|
|
33
|
+
onBack?: () => void;
|
|
29
34
|
rightContainerClassName?: string;
|
|
30
|
-
rightSnippet?: Snippet
|
|
35
|
+
rightSnippet?: Snippet<[]>;
|
|
31
36
|
subtitle?: string;
|
|
32
37
|
subtitleClassName?: string;
|
|
33
38
|
title?: string;
|
|
@@ -35,11 +40,14 @@
|
|
|
35
40
|
};
|
|
36
41
|
|
|
37
42
|
let {
|
|
43
|
+
backButtonClassName,
|
|
44
|
+
backIconPath,
|
|
38
45
|
centerContainerClassName = '',
|
|
39
46
|
centerSnippet,
|
|
40
47
|
children,
|
|
41
48
|
className = '',
|
|
42
49
|
drawerButtonClassName = '',
|
|
50
|
+
hasBack = false,
|
|
43
51
|
hasLogo = false,
|
|
44
52
|
hasMore = false,
|
|
45
53
|
hasSubtitle = false,
|
|
@@ -56,6 +64,7 @@
|
|
|
56
64
|
morePosition = 'left',
|
|
57
65
|
onLogo,
|
|
58
66
|
onMore,
|
|
67
|
+
onBack,
|
|
59
68
|
rightContainerClassName = '',
|
|
60
69
|
rightSnippet,
|
|
61
70
|
subtitle = '',
|
|
@@ -66,12 +75,22 @@
|
|
|
66
75
|
</script>
|
|
67
76
|
|
|
68
77
|
<nav
|
|
69
|
-
class="sticky top-0 z-20 flex h-16 shrink-0 items-center px-2 border-b border-
|
|
78
|
+
class="sticky top-0 z-20 flex h-16 shrink-0 items-center px-2 border-b border-base-100 dark:border-base-700 bg-white dark:bg-base-800 shadow-sm {className}"
|
|
70
79
|
>
|
|
80
|
+
{#if hasBack}
|
|
81
|
+
<div class="h-full flex items-center">
|
|
82
|
+
<ButtonBack
|
|
83
|
+
iconPath={backIconPath}
|
|
84
|
+
className=" text-base-800 dark:text-base-100 {backButtonClassName}"
|
|
85
|
+
onClick={onBack}
|
|
86
|
+
/>
|
|
87
|
+
</div>
|
|
88
|
+
{/if}
|
|
71
89
|
{#if hasMore && morePosition === 'left'}
|
|
72
90
|
<div class="h-full">
|
|
73
91
|
<Button
|
|
74
|
-
className="h-full px-2 text-
|
|
92
|
+
className="h-full px-2 text-base-800 dark:text-base-100 {drawerButtonClassName}"
|
|
93
|
+
iconClassName=""
|
|
75
94
|
iconPath={moreIconPath}
|
|
76
95
|
disabled={!onMore}
|
|
77
96
|
onClick={onMore}
|
|
@@ -80,12 +99,12 @@
|
|
|
80
99
|
{/if}
|
|
81
100
|
{#if hasLogo}
|
|
82
101
|
<div class="h-full">
|
|
83
|
-
<Button className="h-full px-2 {logoButtonClassName}" disabled={!onLogo} onClick={onLogo}>
|
|
102
|
+
<Button className="h-full px-2 text-base-800 dark:text-base-100 {logoButtonClassName}" disabled={!onLogo} onClick={onLogo}>
|
|
84
103
|
{#if logoIconPath}
|
|
85
104
|
<Icon path={logoIconPath} className="h-10 w-10 {logoIconClassName}" />
|
|
86
105
|
{/if}
|
|
87
106
|
{#if logoImgSrc}
|
|
88
|
-
<img src={logoImgSrc} class="h-8 w-8 bg-
|
|
107
|
+
<img src={logoImgSrc} class="h-8 w-8 bg-base-50 {logoImgClassName}" alt="logo" />
|
|
89
108
|
{/if}
|
|
90
109
|
</Button>
|
|
91
110
|
</div>
|
|
@@ -96,10 +115,14 @@
|
|
|
96
115
|
<div class="h-full flex items-center">
|
|
97
116
|
<div>
|
|
98
117
|
{#if hasTitle}
|
|
99
|
-
<div class="font-bold px-2 {titleClassName}">
|
|
118
|
+
<div class="font-bold px-2 text-base-800 dark:text-base-100 {titleClassName}">
|
|
119
|
+
{title || ''}
|
|
120
|
+
</div>
|
|
100
121
|
{/if}
|
|
101
122
|
{#if hasSubtitle}
|
|
102
|
-
<div class="text-sm px-2 text-
|
|
123
|
+
<div class="text-sm px-2 text-base-600 dark:text-base-500 {subtitleClassName}">
|
|
124
|
+
{subtitle || ''}
|
|
125
|
+
</div>
|
|
103
126
|
{/if}
|
|
104
127
|
</div>
|
|
105
128
|
</div>
|
|
@@ -122,7 +145,7 @@
|
|
|
122
145
|
{#if hasMore && morePosition === 'right'}
|
|
123
146
|
<div class="h-full">
|
|
124
147
|
<Button
|
|
125
|
-
className="h-full px-2 text-
|
|
148
|
+
className="h-full px-2 text-base-800 dark:text-base-100 {drawerButtonClassName}"
|
|
126
149
|
iconPath={moreIconPath}
|
|
127
150
|
disabled={!onMore}
|
|
128
151
|
onClick={onMore}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import '../../../../../tailwind.css';
|
|
2
1
|
import type { Snippet } from 'svelte';
|
|
2
|
+
import '../../../../../tailwind.css';
|
|
3
3
|
interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
|
|
4
4
|
new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
|
|
5
5
|
$$bindings?: Bindings;
|
|
@@ -14,18 +14,21 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
|
|
|
14
14
|
z_$$bindings?: Bindings;
|
|
15
15
|
}
|
|
16
16
|
declare const Navbar: $$__sveltets_2_IsomorphicComponent<{
|
|
17
|
+
backIconPath?: string;
|
|
18
|
+
backButtonClassName?: string;
|
|
17
19
|
centerContainerClassName?: string;
|
|
18
|
-
centerSnippet?: Snippet
|
|
20
|
+
centerSnippet?: Snippet<[]>;
|
|
19
21
|
children?: Snippet;
|
|
20
22
|
className?: String;
|
|
21
23
|
drawerButtonClassName?: string;
|
|
24
|
+
hasBack?: boolean;
|
|
22
25
|
hasLogo?: boolean;
|
|
23
26
|
hasMore?: boolean;
|
|
24
27
|
hasSubtitle?: boolean;
|
|
25
28
|
hasTitle?: boolean;
|
|
26
29
|
id?: string;
|
|
27
30
|
leftContainerClassName?: string;
|
|
28
|
-
leftSnippet?: Snippet
|
|
31
|
+
leftSnippet?: Snippet<[]>;
|
|
29
32
|
logoButtonClassName?: string;
|
|
30
33
|
logoIconClassName?: string;
|
|
31
34
|
logoIconPath?: string;
|
|
@@ -35,8 +38,9 @@ declare const Navbar: $$__sveltets_2_IsomorphicComponent<{
|
|
|
35
38
|
morePosition?: "left" | "right";
|
|
36
39
|
onLogo?: () => void;
|
|
37
40
|
onMore?: () => void;
|
|
41
|
+
onBack?: () => void;
|
|
38
42
|
rightContainerClassName?: string;
|
|
39
|
-
rightSnippet?: Snippet
|
|
43
|
+
rightSnippet?: Snippet<[]>;
|
|
40
44
|
subtitle?: string;
|
|
41
45
|
subtitleClassName?: string;
|
|
42
46
|
title?: string;
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
|
|
39
39
|
<div
|
|
40
40
|
{id}
|
|
41
|
-
class="hidden bg-white pt-16 {responsiveClassName} {position == 'right'
|
|
41
|
+
class="hidden bg-white dark:bg-base-800 text-base-800 dark:text-base-200 border-base-100 dark:border-base-700 pt-16 {responsiveClassName} {position == 'right'
|
|
42
42
|
? 'right-0'
|
|
43
43
|
: ''} {className}"
|
|
44
44
|
>
|