@cloudparker/moldex.js 0.0.31 → 0.0.33

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.
@@ -12,7 +12,7 @@ export type PickerDialogPropsType = {
12
12
  closeButtonClassName?: string;
13
13
  identity?: string;
14
14
  value?: any | any[];
15
- search?: string;
15
+ search?: string | string[];
16
16
  };
17
17
  export declare function openDialog<R>(props?: DialogPropsType): Promise<R>;
18
18
  export declare function openConfirmDialog(params?: DialogPropsType & {
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-50{z-index:50}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.-mb-2{margin-bottom:-.5rem}.ml-3{margin-left:.75rem}.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}.\!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-10{width:2.5rem}.w-11\/12{width:91.666667%}.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-72{width:18rem}.w-8{width:2rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-full{max-width:100%}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.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-x-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-x-0{--tw-translate-x:0px}.translate-x-1\/2{--tw-translate-x:50%}.translate-x-1\/2,.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}.scale-100,.translate-y-4{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-100{--tw-scale-x:1;--tw-scale-y:1}.scale-95{--tw-scale-x:.95;--tw-scale-y:.95}.scale-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}.gap-y-5{row-gap:1.25rem}.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-10{padding:2.5rem}.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}.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\:w-3\/4{width:75%}.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\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:w-1\/2{width:50%}.md\:w-2\/3{width:66.666667%}.md\:w-3\/4{width:75%}}@media (min-width:1024px){.lg\:w-1\/2{width:50%}.lg\:w-1\/3{width:33.333333%}.lg\:w-2\/3{width:66.666667%}.lg\:w-px{width:1px}.lg\:bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}}@media (min-width:1280px){.xl\:w-1\/2{width:50%}.xl\:w-1\/3{width:33.333333%}.xl\:w-1\/4{width:25%}}@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}.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-50{z-index:50}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.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}.\!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-10{width:2.5rem}.w-11\/12{width:91.666667%}.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-72{width:18rem}.w-8{width:2rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-7xl{max-width:80rem}.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}.py-8{padding-top:2rem;padding-bottom:2rem}.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}.text-left{text-align:left}.text-center{text-align:center}.text-start{text-align:start}.align-middle{vertical-align:middle}.text-3xl{font-size:1.875rem;line-height:2.25rem}.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}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.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\:w-3\/4{width:75%}.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\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:w-1\/2{width:50%}.md\:w-2\/3{width:66.666667%}.md\:w-3\/4{width:75%}}@media (min-width:1024px){.lg\:w-1\/2{width:50%}.lg\:w-1\/3{width:33.333333%}.lg\:w-2\/3{width:66.666667%}.lg\:w-px{width:1px}.lg\:bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}@media (min-width:1280px){.xl\:w-1\/2{width:50%}.xl\:w-1\/3{width:33.333333%}.xl\:w-1\/4{width:25%}}@media (prefers-color-scheme:dark){.dark\:bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}}
@@ -16,7 +16,7 @@
16
16
  itemSnippet?: Snippet<[any, number]>;
17
17
  itemTitle?: string;
18
18
  itemSubtitle?: string;
19
- search?: string;
19
+ search?: string | string[];
20
20
  identity?: string;
21
21
  iconPath?: string;
22
22
  hasCheckbox?: boolean;
@@ -85,7 +85,13 @@
85
85
  res.subtitle = item.hasOwnProperty(itemSubtitle) ? item[itemSubtitle] : itemSubtitle;
86
86
  }
87
87
  if (search) {
88
- res[searchField] = (item[search] || '').trim().toLowerCase();
88
+ if (typeof search === 'string') {
89
+ res[searchField] = (item[search] || '').trim().toLowerCase();
90
+ } else {
91
+ res[searchField] = (search.map((fieldName) => item[fieldName]).join(' ') || '')
92
+ .trim()
93
+ .toLowerCase();
94
+ }
89
95
  } else {
90
96
  res[searchField] = `${res.title || ''} ${res.subtitle || ''}`.trim().toLowerCase();
91
97
  }
@@ -20,7 +20,7 @@ declare const ListPickerDialog: $$__sveltets_2_IsomorphicComponent<{
20
20
  itemSnippet?: Snippet<[any, number]>;
21
21
  itemTitle?: string;
22
22
  itemSubtitle?: string;
23
- search?: string;
23
+ search?: string | string[];
24
24
  identity?: string;
25
25
  iconPath?: string;
26
26
  hasCheckbox?: boolean;
@@ -1,25 +1,30 @@
1
1
  <script lang="ts">
2
2
  import type { Snippet } from 'svelte';
3
+
3
4
  import '../../../../../tailwind.css';
4
5
 
6
+ type PositionType = 'left' | 'right' | 'top' | 'bottom';
7
+
5
8
  type PropsType = {
6
- children?: Snippet;
7
- id?: string;
8
9
  backdropClassName?: string;
10
+ children?: Snippet;
9
11
  className?: string;
10
12
  containerClassName?: string;
11
- drawerContainerClassName?: string;
12
13
  drawerClassName?: string;
14
+ floatingSnippet?: Snippet;
15
+ id?: string;
16
+ position?: PositionType;
13
17
  };
14
18
 
15
19
  let {
16
- id = '',
17
- children,
18
20
  backdropClassName = '',
19
- className = 'bg-indigo-600 text-white',
21
+ children,
22
+ className = '',
20
23
  containerClassName = '',
21
- drawerContainerClassName = '',
22
- drawerClassName = ''
24
+ drawerClassName = '',
25
+ floatingSnippet,
26
+ id = '',
27
+ position = 'left'
23
28
  }: PropsType = $props();
24
29
 
25
30
  let isPlaced: boolean = $state(false);
@@ -62,18 +67,37 @@
62
67
  aria-hidden="true"
63
68
  ></div>
64
69
  <!-- Drawer -->
65
- <div class="fixed inset-0 flex {drawerContainerClassName}">
70
+ <div
71
+ class="fixed inset-0 flex
72
+ {position === 'right' ? 'flex-row' : ''}
73
+ {position === 'right' ? 'flex-row-reverse' : ''}
74
+ {position === 'top' ? 'flex-col' : ''}
75
+ {position === 'bottom' ? 'flex-col-reverse' : ''}"
76
+ >
66
77
  <div
67
- class="relative flex w-full max-w-xs flex-1 transition ease-in-out duration-300 transform {isOpened
68
- ? 'translate-x-0'
69
- : '-translate-x-full'} {drawerClassName}"
78
+ class="relative flex transition ease-in-out duration-300 transform
79
+ {position === 'right' ? 'flex-row' : ''}
80
+ {position === 'right' ? 'flex-row-reverse' : ''}
81
+ {position === 'top' ? 'flex-col' : ''}
82
+ {position === 'bottom' ? 'flex-col-reverse' : ''}
83
+ {position === 'left' ? (isOpened ? 'translate-x-0' : '-translate-x-full') : ''}
84
+ {position === 'right' ? (isOpened ? 'translate-x-0' : 'translate-x-full') : ''}
85
+ {position === 'top' ? (isOpened ? 'translate-y-0' : '-translate-y-full') : ''}
86
+ {position === 'bottom' ? (isOpened ? 'translate-y-0' : 'translate-y-full') : ''}
87
+ {drawerClassName} "
70
88
  >
71
- <div class="flex grow flex-col gap-y-5 overflow-y-auto w-72 {className}">
89
+ <div class="grow w-72 bg-white {className}">
72
90
  {#if children}
73
91
  {@render children()}
74
92
  {/if}
75
93
  </div>
94
+ <div class=" ">
95
+ {#if floatingSnippet}
96
+ {@render floatingSnippet()}
97
+ {/if}
98
+ </div>
76
99
  </div>
100
+
77
101
  <button class="flex-grow cursor-auto" type="button" onclick={handelBackdropClick}></button>
78
102
  </div>
79
103
  </div>
@@ -14,13 +14,14 @@ interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> =
14
14
  z_$$bindings?: Bindings;
15
15
  }
16
16
  declare const Drawer: $$__sveltets_2_IsomorphicComponent<{
17
- children?: Snippet;
18
- id?: string;
19
17
  backdropClassName?: string;
18
+ children?: Snippet;
20
19
  className?: string;
21
20
  containerClassName?: string;
22
- drawerContainerClassName?: string;
23
21
  drawerClassName?: string;
22
+ floatingSnippet?: Snippet;
23
+ id?: string;
24
+ position?: "left" | "right" | "top" | "bottom";
24
25
  }, {
25
26
  [evt: string]: CustomEvent<any>;
26
27
  }, {}, {
@@ -2,14 +2,14 @@ export * from './button/index.js';
2
2
  export * from './dialog/index.js';
3
3
  export * from './drawer/index.js';
4
4
  export * from './icon/index.js';
5
+ export * from './input/index.js';
5
6
  export * from './navbar/index.js';
7
+ export * from './no-data/index.js';
6
8
  export * from './pagination/index.js';
7
9
  export * from './progressbar/index.js';
10
+ export * from './referrer/index.js';
8
11
  export * from './ruler/index.js';
12
+ export * from './screen-detector/index.js';
9
13
  export * from './spinner/index.js';
10
14
  export * from './text/index.js';
11
15
  export * from './toast/index.js';
12
- export * from './screen-detector/index.js';
13
- export * from './referrer/index.js';
14
- export * from './input/index.js';
15
- export * from './no-data/index.js';
@@ -2,14 +2,14 @@ export * from './button/index.js';
2
2
  export * from './dialog/index.js';
3
3
  export * from './drawer/index.js';
4
4
  export * from './icon/index.js';
5
+ export * from './input/index.js';
5
6
  export * from './navbar/index.js';
7
+ export * from './no-data/index.js';
6
8
  export * from './pagination/index.js';
7
9
  export * from './progressbar/index.js';
10
+ export * from './referrer/index.js';
8
11
  export * from './ruler/index.js';
12
+ export * from './screen-detector/index.js';
9
13
  export * from './spinner/index.js';
10
14
  export * from './text/index.js';
11
15
  export * from './toast/index.js';
12
- export * from './screen-detector/index.js';
13
- export * from './referrer/index.js';
14
- export * from './input/index.js';
15
- export * from './no-data/index.js';
@@ -0,0 +1,59 @@
1
+ <script lang="ts">
2
+ type CheckboxPropsType = {
3
+ containerClassName?: string;
4
+ desc?: string;
5
+ descClassName?: string;
6
+ id?: string;
7
+ label?: string;
8
+ labelClassName?: string;
9
+ name?: string;
10
+ onChange?: (value: boolean) => void;
11
+ position?: 'left' | 'right';
12
+ value?: boolean;
13
+ };
14
+
15
+ let {
16
+ containerClassName,
17
+ desc,
18
+ descClassName,
19
+ id,
20
+ label,
21
+ labelClassName,
22
+ name,
23
+ onChange,
24
+ position = 'left',
25
+ value = $bindable(false)
26
+ }: CheckboxPropsType = $props();
27
+
28
+ function handleChange(ev: Event) {
29
+ if (onChange) {
30
+ onChange(value);
31
+ }
32
+ }
33
+ </script>
34
+
35
+ {#snippet labelSnippet()}
36
+ <div class="text-sm leading-6 mx-4 flex-grow">
37
+ <div class="font-medium text-sm text-gray-900">{label || ''}</div>
38
+ <div class="text-xs text-gray-500">{desc || ''}</div>
39
+ </div>
40
+ {/snippet}
41
+ <div class=" {containerClassName}">
42
+ <label for={id || name} class="flex items-center cursor-pointer select-none">
43
+ {#if position == 'right'}
44
+ {@render labelSnippet()}
45
+ {/if}
46
+ <input
47
+ bind:checked={value}
48
+ id={id || name}
49
+ aria-describedby="comments-description"
50
+ name={name || id}
51
+ type="checkbox"
52
+ class="h-4 w-4 rounded border-gray-300 text-indigo-600 focus:ring-indigo-600"
53
+ onchange={(ev) => handleChange(ev)}
54
+ />
55
+ {#if position == 'left'}
56
+ {@render labelSnippet()}
57
+ {/if}
58
+ </label>
59
+ </div>
@@ -0,0 +1,29 @@
1
+ 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> {
2
+ new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
+ $$bindings?: Bindings;
4
+ } & Exports;
5
+ (internal: unknown, props: Props & {
6
+ $$events?: Events;
7
+ $$slots?: Slots;
8
+ }): Exports & {
9
+ $set?: any;
10
+ $on?: any;
11
+ };
12
+ z_$$bindings?: Bindings;
13
+ }
14
+ declare const CheckboxField: $$__sveltets_2_IsomorphicComponent<{
15
+ containerClassName?: string;
16
+ desc?: string;
17
+ descClassName?: string;
18
+ id?: string;
19
+ label?: string;
20
+ labelClassName?: string;
21
+ name?: string;
22
+ onChange?: (value: boolean) => void;
23
+ position?: "left" | "right";
24
+ value?: boolean;
25
+ }, {
26
+ [evt: string]: CustomEvent<any>;
27
+ }, {}, {}, "value">;
28
+ type CheckboxField = InstanceType<typeof CheckboxField>;
29
+ export default CheckboxField;
@@ -1,3 +1,26 @@
1
+ <script module lang="ts">
2
+ export type LibPhoneNumberParseType = {
3
+ isValid: () => boolean;
4
+ nationalNumber: string;
5
+ countryCallingCode: string;
6
+ };
7
+
8
+ export type LibPhoneNumberType = {
9
+ parsePhoneNumber: (phoneNumber: string, dialCode?: string) => LibPhoneNumberParseType;
10
+ };
11
+
12
+ export type CountryType = {
13
+ name: string;
14
+ dialCode: string;
15
+ isoCode: string;
16
+ };
17
+
18
+ export type EasyCountryDataType = {
19
+ getCountries: () => CountryType[];
20
+ getCountry: (params: { name?: string; dialCode?: string; isoCode?: string }) => CountryType;
21
+ };
22
+ </script>
23
+
1
24
  <script lang="ts">
2
25
  import { ripple } from '../../../../../actions';
3
26
  import EasyScriptLoader from '@cloudparker/easy-script-loader-svelte';
@@ -6,7 +29,7 @@
6
29
  import type { DialogSizeType } from '../../../dialog';
7
30
 
8
31
  let {
9
- value,
32
+ value = $bindable(''),
10
33
  size,
11
34
  appearance,
12
35
  buttonClassName,
@@ -18,11 +41,35 @@
18
41
  dialCode?: string;
19
42
  } = $props();
20
43
 
21
- let btnRoundedClassName = $state('');
44
+ let EasyCountryData: EasyCountryDataType;
45
+ let LibPhonenumber: LibPhoneNumberType | null = $state(null);
46
+ let inputFieldRef: InputField | null = $state(null);
22
47
 
23
- let EasyCountryData: any;
48
+ let _dailCode: string = $state('');
49
+ let _phoneNumber: string = $state('');
24
50
 
25
- let inputFieldRef: InputField | null = $state(null);
51
+ $effect(() => {
52
+ if (!_dailCode && !_phoneNumber && LibPhonenumber) {
53
+ try {
54
+ if (dialCode) {
55
+ _dailCode = '+' + dialCode || '';
56
+ }
57
+ if (value) {
58
+ let parsed = LibPhonenumber?.parsePhoneNumber(value as string);
59
+ if (parsed && parsed.isValid()) {
60
+ _phoneNumber = parsed.nationalNumber || '';
61
+ _dailCode = '+' + parsed.countryCallingCode || '';
62
+ }
63
+ }
64
+ } catch (error) {}
65
+ }
66
+ });
67
+
68
+ let btnRoundedClassName = $derived.by(() => {
69
+ if (!appearance || appearance == 'normal') {
70
+ return 'rounded-tl-lg rounded-bl-lg';
71
+ }
72
+ });
26
73
 
27
74
  export function focus() {
28
75
  inputFieldRef?.focus();
@@ -39,27 +86,68 @@
39
86
  itemSubtitle: 'name',
40
87
  size,
41
88
  hasCheck: true,
42
- identity: 'dialCode'
89
+ identity: 'dialCode',
90
+ search: ['name', 'dialCode', 'isoCode']
43
91
  });
44
92
 
45
93
  console.log(res);
46
94
  if (res) {
47
- dialCode = res;
95
+ _dailCode = res;
96
+ dialCode = _dailCode;
97
+ updatePhonenumber(_dailCode, _phoneNumber);
48
98
  inputFieldRef && inputFieldRef.focus();
49
99
  }
50
100
  }
51
101
  }
52
102
 
53
- function handleScriptLoad(lib: any) {
54
- console.log(lib);
103
+ function handleEasyCountryDataScriptLoad(lib: EasyCountryDataType) {
55
104
  EasyCountryData = lib;
56
105
  }
57
106
 
58
- $effect(() => {
59
- if (!appearance || appearance == 'normal') {
60
- btnRoundedClassName = 'rounded-tl-lg rounded-bl-lg';
107
+ function handleLibphonenumberScriptLoad(lib: LibPhoneNumberType) {
108
+ LibPhonenumber = lib;
109
+ }
110
+
111
+ function handleNumberInput(ev: InputEvent) {
112
+ let target: HTMLInputElement = ev.target as HTMLInputElement;
113
+ let _phoneNumber: string = target?.value || '';
114
+ updatePhonenumber(_dailCode, _phoneNumber);
115
+ }
116
+
117
+ function updatePhonenumber(_dialCode: string, _phoneNumber: string) {
118
+ if (LibPhonenumber) {
119
+ if (_phoneNumber) {
120
+ try {
121
+ // console.log('updatePhonenumber', { dialCode, phoneNumber });
122
+ let parsed = LibPhonenumber.parsePhoneNumber(_dialCode + _phoneNumber);
123
+ if (parsed && parsed.isValid()) {
124
+ dialCode = _dialCode;
125
+ value = _dialCode + _phoneNumber;
126
+ } else {
127
+ value = '';
128
+ }
129
+ } catch (error) {
130
+ value = '';
131
+ }
132
+ }
61
133
  }
62
- });
134
+ }
135
+
136
+ function handleNumberKeyDown(ev: KeyboardEvent) {
137
+ if (
138
+ !(
139
+ (ev.key >= '0' && ev.key <= '9') ||
140
+ ev.key === 'Backspace' ||
141
+ ev.key === 'Delete' ||
142
+ ev.key === 'ArrowLeft' ||
143
+ ev.key === 'ArrowRight' ||
144
+ ev.key === 'ArrowUp' ||
145
+ ev.key === 'ArrowDown'
146
+ )
147
+ ) {
148
+ ev.preventDefault();
149
+ }
150
+ }
63
151
  </script>
64
152
 
65
153
  {#snippet showPasswordButton()}
@@ -68,23 +156,32 @@
68
156
  use:ripple
69
157
  onclick={hanleDialCodePicker}
70
158
  >
71
- {dialCode}
159
+ {_dailCode}
72
160
  </button>
73
161
  {/snippet}
74
162
 
75
163
  <EasyScriptLoader
76
164
  scriptName="EasyCountryData"
77
165
  scriptUrl="https://cdn.jsdelivr.net/gh/paramanandapradhan/easy-countrydata@main/dist/index.js"
78
- onLoad={handleScriptLoad}
166
+ onLoad={handleEasyCountryDataScriptLoad}
167
+ />
168
+
169
+ <EasyScriptLoader
170
+ scriptName="libphonenumber"
171
+ scriptUrl="https://unpkg.com/libphonenumber-js@1.11.7/bundle/libphonenumber-min.js"
172
+ onLoad={handleLibphonenumberScriptLoad}
79
173
  />
80
174
 
81
175
  <InputField
82
- bind:this={inputFieldRef}
83
176
  {...props}
177
+ bind:this={inputFieldRef}
178
+ value={_phoneNumber}
84
179
  type="tel"
85
180
  maxlength={props?.maxlength || 12}
86
181
  leftSnippet={showPasswordButton}
87
182
  {size}
88
183
  {appearance}
89
184
  className="pl-16 {className}"
185
+ oninput={handleNumberInput}
186
+ onkeydown={handleNumberKeyDown}
90
187
  />
@@ -1,3 +1,24 @@
1
+ export type LibPhoneNumberParseType = {
2
+ isValid: () => boolean;
3
+ nationalNumber: string;
4
+ countryCallingCode: string;
5
+ };
6
+ export type LibPhoneNumberType = {
7
+ parsePhoneNumber: (phoneNumber: string, dialCode?: string) => LibPhoneNumberParseType;
8
+ };
9
+ export type CountryType = {
10
+ name: string;
11
+ dialCode: string;
12
+ isoCode: string;
13
+ };
14
+ export type EasyCountryDataType = {
15
+ getCountries: () => CountryType[];
16
+ getCountry: (params: {
17
+ name?: string;
18
+ dialCode?: string;
19
+ isoCode?: string;
20
+ }) => CountryType;
21
+ };
1
22
  import { type InputFieldPropsType } from '../input-field/input-field.svelte';
2
23
  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> {
3
24
  new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
@@ -19,6 +40,6 @@ declare const PhoneField: $$__sveltets_2_IsomorphicComponent<InputFieldPropsType
19
40
  [evt: string]: CustomEvent<any>;
20
41
  }, {}, {
21
42
  focus: () => void;
22
- }, "dialCode">;
43
+ }, "value" | "dialCode">;
23
44
  type PhoneField = InstanceType<typeof PhoneField>;
24
45
  export default PhoneField;
@@ -1,6 +1,6 @@
1
1
  <script lang="ts" module>
2
2
  export type RadioValuetype = string | boolean | number | Date;
3
- export type RadioItemType = { value: any; label: string };
3
+ export type RadioItemType = { value: any; label: string; desc?: string };
4
4
  export type RadioItemsType = (RadioValuetype | RadioItemType)[];
5
5
  export type RadioPositionType = 'left' | 'right';
6
6
  export type RadioDirationType = 'vertical' | 'horizontal';
@@ -21,6 +21,7 @@
21
21
  title?: string;
22
22
  titleClassName?: string;
23
23
  value?: RadioValuetype;
24
+ descClassName?: string;
24
25
  onChange?: (value: RadioValuetype) => void;
25
26
  };
26
27
  </script>
@@ -43,6 +44,7 @@
43
44
  title,
44
45
  titleClassName,
45
46
  value = $bindable(),
47
+ descClassName,
46
48
  onChange
47
49
  }: RadioPropsType = $props();
48
50
 
@@ -74,17 +76,27 @@
74
76
  </script>
75
77
 
76
78
  {#snippet labelSnippet(item: RadioItemType, index: number)}
77
- <label
78
- for="option-{index}"
79
- class="ml-3 block text-sm font-medium leading-6 text-gray-900 flex-grow cursor-pointer select-none {required
80
- ? 'required'
81
- : ''} {labelClassName}">{item.label || ''}</label
82
- >
79
+ <div class="leading-6">
80
+ <div
81
+ class="ml-4 block text-sm font-medium text-gray-900 flex-grow {labelClassName}"
82
+ >
83
+ {item.label || ''}
84
+ </div>
85
+ {#if item.desc}
86
+ <div class="ml-4 block text-xs text-gray-500 flex-grow {descClassName}">
87
+ {item.desc || ''}
88
+ </div>
89
+ {/if}
90
+ </div>
83
91
  {/snippet}
84
92
 
85
93
  <fieldset id={fieldsetId}>
86
94
  {#if title}
87
- <legend class="text-sm font-semibold leading-6 text-gray-900 {titleClassName}">{title}</legend>
95
+ <legend
96
+ class="text-sm font-semibold leading-6 text-gray-900 {required
97
+ ? 'required'
98
+ : ''} {titleClassName}">{title}</legend
99
+ >
88
100
  {/if}
89
101
  {#if subtitle}
90
102
  <p class="mt-1 text-sm leading-6 text-gray-600 {subtitleClassName}">{subtitle}</p>
@@ -96,7 +108,10 @@
96
108
  : 'space-x-6 flex items-center'} {groupContainerClassName} "
97
109
  >
98
110
  {#each preparedItems || [] as item, index}
99
- <div class="flex items-center {radioContainerClassName}">
111
+ <label
112
+ class="flex items-center cursor-pointer select-none {radioContainerClassName}"
113
+ for="option-{index}"
114
+ >
100
115
  {#if position == 'right'}
101
116
  {@render labelSnippet(item, index)}
102
117
  {/if}
@@ -114,7 +129,7 @@
114
129
  {#if position == 'left'}
115
130
  {@render labelSnippet(item, index)}
116
131
  {/if}
117
- </div>
132
+ </label>
118
133
  {/each}
119
134
  </div>
120
135
  </fieldset>
@@ -2,6 +2,7 @@ export type RadioValuetype = string | boolean | number | Date;
2
2
  export type RadioItemType = {
3
3
  value: any;
4
4
  label: string;
5
+ desc?: string;
5
6
  };
6
7
  export type RadioItemsType = (RadioValuetype | RadioItemType)[];
7
8
  export type RadioPositionType = 'left' | 'right';
@@ -23,6 +24,7 @@ export type RadioPropsType = {
23
24
  title?: string;
24
25
  titleClassName?: string;
25
26
  value?: RadioValuetype;
27
+ descClassName?: string;
26
28
  onChange?: (value: RadioValuetype) => void;
27
29
  };
28
30
  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> {
@@ -1,5 +1,6 @@
1
1
  import { type InputFieldAppearanceType, type InputFieldPropsType, type InputFieldSizeType } from "./components/input-field/input-field.svelte";
2
2
  import type { RadioDirationType, RadioItemsType, RadioItemType, RadioPositionType, RadioPropsType, RadioValuetype } from "./components/radio-field/radio-field.svelte";
3
+ import CheckboxField from "./components/checkbox-field/checkbox-field.svelte";
3
4
  import ColorField from "./components/color-field/color-field.svelte";
4
5
  import ComboboxField from "./components/combobox-field/combobox-field.svelte";
5
6
  import DateField from "./components/date-field/date-field.svelte";
@@ -18,4 +19,4 @@ import TextField from "./components/text-field/text-field.svelte";
18
19
  import TextareaField from "./components/textarea-field/textarea-field.svelte";
19
20
  import TimeField from "./components/time-field/time-field.svelte";
20
21
  export type { InputFieldAppearanceType, InputFieldPropsType, InputFieldSizeType, RadioDirationType, RadioItemsType, RadioItemType, RadioPositionType, RadioPropsType, RadioValuetype };
21
- export { ColorField, ComboboxField, DateField, DatetimeField, EmailField, FileField, InputField, Label, NumberField, PasswordField, PhoneField, RadioField, RangeField, SearchField, TextareaField, TextField, TimeField };
22
+ export { CheckboxField, ColorField, ComboboxField, DateField, DatetimeField, EmailField, FileField, InputField, Label, NumberField, PasswordField, PhoneField, RadioField, RangeField, SearchField, TextareaField, TextField, TimeField };
@@ -1,4 +1,5 @@
1
1
  import {} from "./components/input-field/input-field.svelte";
2
+ import CheckboxField from "./components/checkbox-field/checkbox-field.svelte";
2
3
  import ColorField from "./components/color-field/color-field.svelte";
3
4
  import ComboboxField from "./components/combobox-field/combobox-field.svelte";
4
5
  import DateField from "./components/date-field/date-field.svelte";
@@ -16,4 +17,4 @@ import SearchField from "./components/search-field/search-field.svelte";
16
17
  import TextField from "./components/text-field/text-field.svelte";
17
18
  import TextareaField from "./components/textarea-field/textarea-field.svelte";
18
19
  import TimeField from "./components/time-field/time-field.svelte";
19
- export { ColorField, ComboboxField, DateField, DatetimeField, EmailField, FileField, InputField, Label, NumberField, PasswordField, PhoneField, RadioField, RangeField, SearchField, TextareaField, TextField, TimeField };
20
+ export { CheckboxField, ColorField, ComboboxField, DateField, DatetimeField, EmailField, FileField, InputField, Label, NumberField, PasswordField, PhoneField, RadioField, RangeField, SearchField, TextareaField, TextField, TimeField };
@@ -5,110 +5,128 @@
5
5
  import { Icon, mdiMenu } from '../../../icon';
6
6
 
7
7
  type PropsType = {
8
- id?: string;
8
+ centerContainerClassName?: string;
9
+ centerSnippet?: Snippet;
10
+ children?: Snippet;
9
11
  className?: String;
10
- hasDrawer?: boolean;
11
- drawerIconPath?: string;
12
12
  drawerButtonClassName?: string;
13
- logoButtonClassName?: string;
14
13
  hasLogo?: boolean;
15
- logoIconPath?: string;
14
+ hasMore?: boolean;
15
+ hasSubtitle?: boolean;
16
+ hasTitle?: boolean;
17
+ id?: string;
18
+ leftContainerClassName?: string;
19
+ leftSnippet?: Snippet;
20
+ logoButtonClassName?: string;
16
21
  logoIconClassName?: string;
17
- logoImgSrc?: string;
22
+ logoIconPath?: string;
18
23
  logoImgClassName?: string;
19
- leftContainerClassName?: string;
20
- centerContainerClassName?: string;
24
+ logoImgSrc?: string;
25
+ moreIconPath?: string;
26
+ morePosition?: 'left' | 'right';
27
+ onLogo?: () => void;
28
+ onMore?: () => void;
21
29
  rightContainerClassName?: string;
22
- title?: string;
30
+ rightSnippet?: Snippet;
23
31
  subtitle?: string;
24
- titleClassName?: string;
25
32
  subtitleClassName?: string;
26
- hasTitle?: boolean;
27
- hasSubtitle?: boolean;
28
- children?: Snippet;
29
- leftSnippet?: Snippet;
30
- centerSnippet?: Snippet;
31
- rightSnippet?: Snippet;
32
- ondrawer?: () => void;
33
- onlogo?: () => void;
33
+ title?: string;
34
+ titleClassName?: string;
34
35
  };
35
36
 
36
37
  let {
37
- id = '',
38
- children,
39
- leftSnippet,
38
+ centerContainerClassName = '',
40
39
  centerSnippet,
41
- rightSnippet,
40
+ children,
42
41
  className = '',
43
- drawerIconPath = mdiMenu,
44
42
  drawerButtonClassName = '',
45
- hasDrawer = false,
46
43
  hasLogo = false,
44
+ hasMore = false,
45
+ hasSubtitle = false,
46
+ hasTitle = false,
47
+ id = '',
48
+ leftContainerClassName = '',
49
+ leftSnippet,
47
50
  logoButtonClassName = '',
48
- logoIconPath,
49
51
  logoIconClassName = 'text-indigo-600',
50
- logoImgSrc,
52
+ logoIconPath,
51
53
  logoImgClassName = '',
52
- leftContainerClassName = '',
53
- centerContainerClassName = '',
54
+ logoImgSrc,
55
+ moreIconPath = mdiMenu,
56
+ morePosition = 'left',
57
+ onLogo,
58
+ onMore,
54
59
  rightContainerClassName = '',
55
- title = '',
60
+ rightSnippet,
56
61
  subtitle = '',
57
- titleClassName = '',
58
62
  subtitleClassName = '',
59
- hasTitle = false,
60
- hasSubtitle = false,
61
- ondrawer,
62
- onlogo
63
+ title = '',
64
+ titleClassName = ''
63
65
  }: PropsType = $props();
64
66
  </script>
65
67
 
66
- <div
68
+ <nav
67
69
  class="sticky top-0 z-10 flex h-16 shrink-0 items-center px-2 border-b border-gray-200 bg-white shadow-sm {className}"
68
70
  >
69
71
  {#if children}
70
72
  {@render children()}
71
73
  {:else}
72
- {#if hasDrawer}
73
- <Button
74
- className="h-full px-2 text-gray-500 hover:text-gray-600 {drawerButtonClassName}"
75
- iconPath={drawerIconPath}
76
- disabled={!ondrawer}
77
- onClick={ondrawer}
78
- ></Button>
74
+ {#if hasMore && morePosition === 'left'}
75
+ <div class="h-full">
76
+ <Button
77
+ className="h-full px-2 text-gray-500 hover:text-gray-600 {drawerButtonClassName}"
78
+ iconPath={moreIconPath}
79
+ disabled={!onMore}
80
+ onClick={onMore}
81
+ />
82
+ </div>
79
83
  {/if}
80
84
  {#if hasLogo}
81
- <Button className="h-full px-2 {logoButtonClassName}" disabled={!onlogo} onClick={onlogo}>
82
- {#if logoIconPath}
83
- <Icon path={logoIconPath} className="h-10 w-10 {logoIconClassName}" />
85
+ <div class="h-full">
86
+ <Button className="h-full px-2 {logoButtonClassName}" disabled={!onLogo} onClick={onLogo}>
87
+ {#if logoIconPath}
88
+ <Icon path={logoIconPath} className="h-10 w-10 {logoIconClassName}" />
89
+ {/if}
90
+ {#if logoImgSrc}
91
+ <img src={logoImgSrc} class="h-8 w-8 bg-gray-50 {logoImgClassName}" alt="logo" />
92
+ {/if}
93
+ </Button>
94
+ </div>
95
+ {/if}
96
+ <div class="h-full flex items-center">
97
+ <div>
98
+ {#if hasTitle}
99
+ <div class="font-bold px-2 {titleClassName}">{title || ''}</div>
84
100
  {/if}
85
- {#if logoImgSrc}
86
- <img src={logoImgSrc} class="h-8 w-8 bg-gray-50 {logoImgClassName}" alt="logo" />
101
+ {#if hasSubtitle}
102
+ <div class="text-sm px-2 text-gray-400 {subtitleClassName}">{subtitle || ''}</div>
87
103
  {/if}
88
- </Button>
104
+ </div>
105
+ </div>
106
+ <div class="h-full {leftContainerClassName}">
107
+ {#if leftSnippet}
108
+ {@render leftSnippet()}
109
+ {/if}
110
+ </div>
111
+ <div class="flex-grow flex items-center justify-center h-full {centerContainerClassName}">
112
+ {#if centerSnippet}
113
+ {@render centerSnippet()}
114
+ {/if}
115
+ </div>
116
+ <div class="h-full {rightContainerClassName}">
117
+ {#if rightSnippet}
118
+ {@render rightSnippet()}
119
+ {/if}
120
+ </div>
121
+ {#if hasMore && morePosition === 'right'}
122
+ <div class="h-full">
123
+ <Button
124
+ className="h-full px-2 text-gray-500 hover:text-gray-600 {drawerButtonClassName}"
125
+ iconPath={moreIconPath}
126
+ disabled={!onMore}
127
+ onClick={onMore}
128
+ />
129
+ </div>
89
130
  {/if}
90
131
  {/if}
91
- <div>
92
- {#if hasTitle}
93
- <div class="font-bold {titleClassName}">{title || ''}</div>
94
- {/if}
95
- {#if hasSubtitle}
96
- <div class="text-sm text-gray-400 {subtitleClassName}">{subtitle || ''}</div>
97
- {/if}
98
- </div>
99
- <div class={leftContainerClassName}>
100
- {#if leftSnippet}
101
- {@render leftSnippet()}
102
- {/if}
103
- </div>
104
- <div class="flex-grow flex justify-center {centerContainerClassName}">
105
- {#if centerSnippet}
106
- {@render centerSnippet()}
107
- {/if}
108
- </div>
109
- <div class={rightContainerClassName}>
110
- {#if rightSnippet}
111
- {@render rightSnippet()}
112
- {/if}
113
- </div>
114
- </div>
132
+ </nav>
@@ -14,32 +14,33 @@ 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
- id?: string;
17
+ centerContainerClassName?: string;
18
+ centerSnippet?: Snippet;
19
+ children?: Snippet;
18
20
  className?: String;
19
- hasDrawer?: boolean;
20
- drawerIconPath?: string;
21
21
  drawerButtonClassName?: string;
22
- logoButtonClassName?: string;
23
22
  hasLogo?: boolean;
24
- logoIconPath?: string;
23
+ hasMore?: boolean;
24
+ hasSubtitle?: boolean;
25
+ hasTitle?: boolean;
26
+ id?: string;
27
+ leftContainerClassName?: string;
28
+ leftSnippet?: Snippet;
29
+ logoButtonClassName?: string;
25
30
  logoIconClassName?: string;
26
- logoImgSrc?: string;
31
+ logoIconPath?: string;
27
32
  logoImgClassName?: string;
28
- leftContainerClassName?: string;
29
- centerContainerClassName?: string;
33
+ logoImgSrc?: string;
34
+ moreIconPath?: string;
35
+ morePosition?: "left" | "right";
36
+ onLogo?: () => void;
37
+ onMore?: () => void;
30
38
  rightContainerClassName?: string;
31
- title?: string;
39
+ rightSnippet?: Snippet;
32
40
  subtitle?: string;
33
- titleClassName?: string;
34
41
  subtitleClassName?: string;
35
- hasTitle?: boolean;
36
- hasSubtitle?: boolean;
37
- children?: Snippet;
38
- leftSnippet?: Snippet;
39
- centerSnippet?: Snippet;
40
- rightSnippet?: Snippet;
41
- ondrawer?: () => void;
42
- onlogo?: () => void;
42
+ title?: string;
43
+ titleClassName?: string;
43
44
  }, {
44
45
  [evt: string]: CustomEvent<any>;
45
46
  }, {}, {}, "">;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloudparker/moldex.js",
3
- "version": "0.0.31",
3
+ "version": "0.0.33",
4
4
  "author": "cloudparker.com",
5
5
  "license": "MIT",
6
6
  "keywords": [