@protonradio/proton-ui 0.11.23-beta.1 → 0.11.23-beta.3

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.
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../../../node_modules/react/jsx-runtime.cjs.js"),s=require("react"),S=require("../../ThemeProvider.cjs.js");;/* empty css */const F=require("../../../utils/copy.cjs.js"),o=require("../../../utils/string.cjs.js"),W=s.forwardRef(({prefix:l,suffix:d,description:i,descriptionPosition:j="top",isDisabled:v,error:n,onChange:_,label:x,name:u,placeholder:P,type:T="text",value:y,autoFocus:g,autoComplete:k,isRequired:h=!1,isReadOnly:R=!1,onSubmit:b,onClear:E,"data-testid":z},O)=>{const N=s.useRef(null),c=s.useRef(null),p=s.useRef(null),r=s.useRef(null),{className:B}=S.useTheme(),D=O||N;s.useEffect(()=>{if(!r.current)return;const t=()=>{var $,q;if(r.current){const a=r.current.offsetWidth||200;r.current.style.setProperty("--container-width",`${a}px`)}if(c.current){const a=c.current.offsetWidth||32;($=r.current)==null||$.style.setProperty("--prefix-width",`${a}px`)}if(p.current){const a=p.current.offsetWidth||32;(q=r.current)==null||q.style.setProperty("--suffix-width",`${a}px`)}};t();const f=new ResizeObserver(t);return r.current&&f.observe(r.current),c.current&&f.observe(c.current),p.current&&f.observe(p.current),()=>{f.disconnect()}},[l,d]);const w=`${u}-input`,m=`${u}-error`,I=`${u}-description`;return e.jsxRuntimeExports.jsxs("div",{ref:r,children:[i&&j==="top"&&e.jsxRuntimeExports.jsx("div",{id:I,className:"proton-Input__text","aria-live":"polite",children:i}),e.jsxRuntimeExports.jsxs("div",{className:o.csx("proton-Input__container-inner",l&&"proton-Input__has-prefix",d&&"proton-Input__has-suffix"),children:[l&&e.jsxRuntimeExports.jsx("div",{ref:c,className:o.csx("proton-Input__descriptor","proton-Input__prefix"),children:l}),e.jsxRuntimeExports.jsx("input",{id:w,name:u,type:T,value:y,onChange:t=>{_==null||_(t.target.value)},onKeyDown:t=>{switch(t.key){case"Enter":b&&(t.preventDefault(),b(t));break;case"Escape":E&&(t.preventDefault(),E());break}},onCopy:async()=>{var t;return await F.copyTextToClipboard((t=N.current)==null?void 0:t.value)},disabled:v,readOnly:R,required:h,autoFocus:g,autoComplete:k?"on":"off",placeholder:x?void 0:P,"aria-label":x||u,"aria-invalid":!!n,"aria-errormessage":typeof n=="string"?n:m,"aria-required":h,"aria-readonly":R,"aria-describedby":n?m:i?I:void 0,"aria-disabled":v,"data-testid":z,ref:D,className:o.csx("proton-Input",n&&"proton-Input--error",x&&"proton-Input__label-top",B)}),e.jsxRuntimeExports.jsxs("label",{htmlFor:w,className:o.csx("proton-Input__label",y&&"proton-Input__label--filled"),children:[x,h&&e.jsxRuntimeExports.jsx("span",{"aria-hidden":"true",children:" *"})]}),d&&e.jsxRuntimeExports.jsx("div",{ref:p,className:o.csx("proton-Input__descriptor","proton-Input__suffix"),children:d})]}),n?e.jsxRuntimeExports.jsx("div",{role:"alert",className:o.csx("proton-Input__error","proton-Input__text"),id:m,children:n}):i&&j==="bottom"?e.jsxRuntimeExports.jsx("div",{id:I,className:"proton-Input__text","aria-live":"polite",children:i}):null]})});W.displayName="ProtonUIInput";exports.Input=W;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const s=require("../../../node_modules/react/jsx-runtime.cjs.js"),r=require("react"),L=require("../../ThemeProvider.cjs.js");;/* empty css */const M=require("../../../utils/copy.cjs.js"),d=require("../../../utils/string.cjs.js"),J=r.forwardRef(({prefix:f,suffix:l,description:c,descriptionPosition:v="top",isDisabled:S,error:a,onChange:I,label:x,name:p,placeholder:$,type:q="text",value:w,autoFocus:z,autoComplete:A,isRequired:y=!1,isReadOnly:R=!1,onSubmit:T,onClear:W,"data-testid":V},B)=>{const N=r.useRef(null),u=r.useRef(null),h=r.useRef(null),n=r.useRef(null),{className:U}=L.useTheme(),F=B||N;r.useEffect(()=>{if(!n.current)return;let e=0,C=Date.now();const i={containerWidth:0,prefixWidth:0,suffixWidth:0},E=j=>{var D,k;e++;const P=Date.now(),_=P-C;C=P;const K=(j==null?void 0:j.map(t=>t.target.className||"unknown").join(","))||"initial";if(fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:149",message:"ResizeObserver callback invoked",data:{callbackCount:e,timeSinceLastUpdate:_,triggeredBy:K},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"A"})}).catch(()=>{}),n.current){const t=n.current.offsetWidth||200,o=t!==i.containerWidth;fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:152",message:"Reading container width",data:{containerWidth:t,previousValue:i.containerWidth,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"C"})}).catch(()=>{}),n.current.style.setProperty("--container-width",`${t}px`),i.containerWidth=t,fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:157",message:"Set container-width CSS property",data:{containerWidth:t,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"A"})}).catch(()=>{})}if(u.current){const t=u.current.offsetWidth||32,o=t!==i.prefixWidth;fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:163",message:"Reading prefix width",data:{prefixWidth:t,previousValue:i.prefixWidth,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"C"})}).catch(()=>{}),(D=n.current)==null||D.style.setProperty("--prefix-width",`${t}px`),i.prefixWidth=t,fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:168",message:"Set prefix-width CSS property",data:{prefixWidth:t,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"A"})}).catch(()=>{})}if(h.current){const t=h.current.offsetWidth||32,o=t!==i.suffixWidth;fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:174",message:"Reading suffix width",data:{suffixWidth:t,previousValue:i.suffixWidth,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"C"})}).catch(()=>{}),(k=n.current)==null||k.style.setProperty("--suffix-width",`${t}px`),i.suffixWidth=t,fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:179",message:"Set suffix-width CSS property",data:{suffixWidth:t,changed:o},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"A"})}).catch(()=>{})}_<10&&fetch("http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({location:"Input.tsx:185",message:"Rapid callback detected",data:{callbackCount:e,timeSinceLastUpdate:_},timestamp:Date.now(),sessionId:"debug-session",runId:"run1",hypothesisId:"E"})}).catch(()=>{})};E();const m=new ResizeObserver(E);return n.current&&m.observe(n.current),u.current&&m.observe(u.current),h.current&&m.observe(h.current),()=>{m.disconnect()}},[f,l]);const O=`${p}-input`,b=`${p}-error`,g=`${p}-description`;return s.jsxRuntimeExports.jsxs("div",{ref:n,className:"proton-Input__container",children:[c&&v==="top"&&s.jsxRuntimeExports.jsx("div",{id:g,className:"proton-Input__text","aria-live":"polite",children:c}),s.jsxRuntimeExports.jsxs("div",{className:d.csx("proton-Input__container-inner",f&&"proton-Input__has-prefix",l&&"proton-Input__has-suffix"),children:[f&&s.jsxRuntimeExports.jsx("div",{ref:u,className:d.csx("proton-Input__descriptor","proton-Input__prefix"),children:f}),s.jsxRuntimeExports.jsx("input",{id:O,name:p,type:q,value:w,onChange:e=>{I==null||I(e.target.value)},onKeyDown:e=>{switch(e.key){case"Enter":T&&(e.preventDefault(),T(e));break;case"Escape":W&&(e.preventDefault(),W());break}},onCopy:async()=>{var e;return await M.copyTextToClipboard((e=N.current)==null?void 0:e.value)},disabled:S,readOnly:R,required:y,autoFocus:z,autoComplete:A?"on":"off",placeholder:x?void 0:$,"aria-label":x||p,"aria-invalid":!!a,"aria-errormessage":typeof a=="string"?a:b,"aria-required":y,"aria-readonly":R,"aria-describedby":a?b:c?g:void 0,"aria-disabled":S,"data-testid":V,ref:F,className:d.csx("proton-Input",a&&"proton-Input--error",x&&"proton-Input__label-top",U)}),s.jsxRuntimeExports.jsxs("label",{htmlFor:O,className:d.csx("proton-Input__label",w&&"proton-Input__label--filled"),children:[x,y&&s.jsxRuntimeExports.jsx("span",{"aria-hidden":"true",children:" *"})]}),l&&s.jsxRuntimeExports.jsx("div",{ref:h,className:d.csx("proton-Input__descriptor","proton-Input__suffix"),children:l})]}),a?s.jsxRuntimeExports.jsx("div",{role:"alert",className:d.csx("proton-Input__error","proton-Input__text"),id:b,children:a}):c&&v==="bottom"?s.jsxRuntimeExports.jsx("div",{id:g,className:"proton-Input__text","aria-live":"polite",children:c}):null]})});J.displayName="ProtonUIInput";exports.Input=J;
2
2
  //# sourceMappingURL=Input.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Input.cjs.js","sources":["../../../../src/components/Input/BaseInput/Input.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef } from \"react\";\n\nimport { useTheme } from \"../../ThemeProvider\";\nimport { csx } from \"../../../utils\";\nimport \"./Input.css\";\nimport { copyTextToClipboard } from \"../../../utils/copy\";\n\nexport interface BaseInputProps {\n /**\n * onChange handler for the input\n */\n onChange?: (value: string) => void;\n\n /** Whether the input is disabled. */\n isDisabled?: boolean;\n\n /** Description text shown above the input. */\n description?: React.ReactNode | string;\n\n /**\n * The position of the description text.\n * @default \"top\"\n */\n descriptionPosition?: \"top\" | \"bottom\";\n\n /** Error state that changes the input's visual style and displays an error message. */\n error?: React.ReactNode | string;\n\n /**\n * Label for the input element.\n * @note When a label is provided, the input will have extra padding, and the label will float above the text input when focused or filled.\n */\n label?: string;\n\n /** Test ID for the component. */\n \"data-testid\"?: string;\n\n /** Content to display before the input. Typically used for icons. */\n prefix?: React.ReactNode;\n\n /** Content to display after the input. Typically used for icons. */\n suffix?: React.ReactNode;\n\n /**\n * Should the browser's autocomplete be enabled?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete\n */\n autoComplete?: boolean;\n\n /**\n * Should the input be autofocused?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autofocus\n */\n autoFocus?: boolean;\n\n /**\n * The name attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/name\n */\n name: string;\n\n /**\n * The placeholder text to display when the input is empty.\n * @note label takes precedence over placeholder, if both are provided.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/placeholder\n */\n placeholder?: string;\n\n /**\n * The type attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/type\n * @default \"text\"\n */\n type?: string;\n\n /**\n * The value of the input.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value\n */\n value?: string;\n\n /**\n * Whether the input is required.\n * @default false\n */\n isRequired?: boolean;\n\n /**\n * Whether the input is read-only.\n * @default false\n */\n isReadOnly?: boolean;\n\n /**\n * Called when the input is submitted (e.g. by pressing Enter).\n */\n onSubmit?: React.FormEventHandler<HTMLInputElement>;\n\n /**\n * Called when the input is cleared (e.g. by pressing Escape).\n */\n onClear?: () => void;\n}\n\n/**\n * A controlled and customizable input component with support for labels, prefixes, suffixes, and error states.\n *\n * API:\n * - {@link BaseInputProps}\n */\nexport const Input = forwardRef<HTMLInputElement, BaseInputProps>(\n (\n {\n prefix,\n suffix,\n description,\n descriptionPosition = \"top\",\n isDisabled,\n error,\n onChange,\n label,\n name,\n placeholder,\n type = \"text\",\n value,\n autoFocus,\n autoComplete,\n isRequired = false,\n isReadOnly = false,\n onSubmit,\n onClear,\n \"data-testid\": testId,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const prefixRef = useRef<HTMLDivElement>(null);\n const suffixRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const { className } = useTheme();\n const ref = forwardedRef || inputRef;\n\n // Control dynamic prefix and suffix widths using ResizeObserver\n useEffect(() => {\n if (!containerRef.current) return;\n\n const updateSizes = () => {\n if (containerRef.current) {\n const containerWidth = containerRef.current.offsetWidth || 200;\n containerRef.current.style.setProperty(\n \"--container-width\",\n `${containerWidth}px`\n );\n }\n\n if (prefixRef.current) {\n const prefixWidth = prefixRef.current.offsetWidth || 32;\n containerRef.current?.style.setProperty(\n \"--prefix-width\",\n `${prefixWidth}px`\n );\n }\n\n if (suffixRef.current) {\n const suffixWidth = suffixRef.current.offsetWidth || 32;\n containerRef.current?.style.setProperty(\n \"--suffix-width\",\n `${suffixWidth}px`\n );\n }\n };\n\n updateSizes();\n\n const resizeObserver = new ResizeObserver(updateSizes);\n\n if (containerRef.current) {\n resizeObserver.observe(containerRef.current);\n }\n if (prefixRef.current) {\n resizeObserver.observe(prefixRef.current);\n }\n if (suffixRef.current) {\n resizeObserver.observe(suffixRef.current);\n }\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [prefix, suffix]);\n\n const inputId = `${name}-input`;\n const errorId = `${name}-error`;\n const descriptionId = `${name}-description`;\n\n return (\n <div ref={containerRef}>\n {description && descriptionPosition === \"top\" && (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n )}\n <div className={csx(\n \"proton-Input__container-inner\",\n prefix && \"proton-Input__has-prefix\",\n suffix && \"proton-Input__has-suffix\"\n )}>\n {prefix && (\n <div\n ref={prefixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__prefix\"\n )}\n >\n {prefix}\n </div>\n )}\n\n <input\n id={inputId}\n name={name}\n type={type}\n value={value}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e.target.value);\n }}\n onKeyDown={(e: React.KeyboardEvent<HTMLInputElement>) => {\n switch (e.key) {\n case \"Enter\":\n if (onSubmit) {\n e.preventDefault();\n onSubmit(e);\n }\n break;\n case \"Escape\":\n if (onClear) {\n e.preventDefault();\n onClear();\n }\n break;\n }\n }}\n onCopy={async () =>\n await copyTextToClipboard(inputRef.current?.value)\n }\n disabled={isDisabled}\n readOnly={isReadOnly}\n required={isRequired}\n autoFocus={autoFocus}\n autoComplete={autoComplete ? \"on\" : \"off\"}\n placeholder={label ? undefined : placeholder}\n aria-label={label || name}\n aria-invalid={Boolean(error)}\n aria-errormessage={typeof error === \"string\" ? error : errorId}\n aria-required={isRequired}\n aria-readonly={isReadOnly}\n aria-describedby={\n error ? errorId : description ? descriptionId : undefined\n }\n aria-disabled={isDisabled}\n data-testid={testId}\n ref={ref}\n className={csx(\n \"proton-Input\",\n error && \"proton-Input--error\",\n label && \"proton-Input__label-top\",\n className\n )}\n />\n\n <label\n htmlFor={inputId}\n className={csx(\n \"proton-Input__label\",\n value && \"proton-Input__label--filled\"\n )}\n >\n {label}\n {isRequired && <span aria-hidden=\"true\"> *</span>}\n </label>\n\n {suffix && (\n <div\n ref={suffixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__suffix\"\n )}\n >\n {suffix}\n </div>\n )}\n </div>\n\n {error ? (\n <div\n role=\"alert\"\n className={csx(\"proton-Input__error\", \"proton-Input__text\")}\n id={errorId}\n >\n {error}\n </div>\n ) : description && descriptionPosition === \"bottom\" ? (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n ) : null}\n </div>\n );\n }\n);\n\nInput.displayName = \"ProtonUIInput\";\n"],"names":["Input","forwardRef","prefix","suffix","description","descriptionPosition","isDisabled","error","onChange","label","name","placeholder","type","value","autoFocus","autoComplete","isRequired","isReadOnly","onSubmit","onClear","testId","forwardedRef","inputRef","useRef","prefixRef","suffixRef","containerRef","className","useTheme","ref","useEffect","updateSizes","containerWidth","prefixWidth","_a","suffixWidth","_b","resizeObserver","inputId","errorId","descriptionId","jsxs","jsx","csx","e","copyTextToClipboard"],"mappings":"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"}
1
+ {"version":3,"file":"Input.cjs.js","sources":["../../../../src/components/Input/BaseInput/Input.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef } from \"react\";\n\nimport { useTheme } from \"../../ThemeProvider\";\nimport { csx } from \"../../../utils\";\nimport \"./Input.css\";\nimport { copyTextToClipboard } from \"../../../utils/copy\";\n\nexport interface BaseInputProps {\n /**\n * onChange handler for the input\n */\n onChange?: (value: string) => void;\n\n /** Whether the input is disabled. */\n isDisabled?: boolean;\n\n /** Description text shown above the input. */\n description?: React.ReactNode | string;\n\n /**\n * The position of the description text.\n * @default \"top\"\n */\n descriptionPosition?: \"top\" | \"bottom\";\n\n /** Error state that changes the input's visual style and displays an error message. */\n error?: React.ReactNode | string;\n\n /**\n * Label for the input element.\n * @note When a label is provided, the input will have extra padding, and the label will float above the text input when focused or filled.\n */\n label?: string;\n\n /** Test ID for the component. */\n \"data-testid\"?: string;\n\n /** Content to display before the input. Typically used for icons. */\n prefix?: React.ReactNode;\n\n /** Content to display after the input. Typically used for icons. */\n suffix?: React.ReactNode;\n\n /**\n * Should the browser's autocomplete be enabled?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete\n */\n autoComplete?: boolean;\n\n /**\n * Should the input be autofocused?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autofocus\n */\n autoFocus?: boolean;\n\n /**\n * The name attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/name\n */\n name: string;\n\n /**\n * The placeholder text to display when the input is empty.\n * @note label takes precedence over placeholder, if both are provided.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/placeholder\n */\n placeholder?: string;\n\n /**\n * The type attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/type\n * @default \"text\"\n */\n type?: string;\n\n /**\n * The value of the input.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value\n */\n value?: string;\n\n /**\n * Whether the input is required.\n * @default false\n */\n isRequired?: boolean;\n\n /**\n * Whether the input is read-only.\n * @default false\n */\n isReadOnly?: boolean;\n\n /**\n * Called when the input is submitted (e.g. by pressing Enter).\n */\n onSubmit?: React.FormEventHandler<HTMLInputElement>;\n\n /**\n * Called when the input is cleared (e.g. by pressing Escape).\n */\n onClear?: () => void;\n}\n\n/**\n * A controlled and customizable input component with support for labels, prefixes, suffixes, and error states.\n *\n * API:\n * - {@link BaseInputProps}\n */\nexport const Input = forwardRef<HTMLInputElement, BaseInputProps>(\n (\n {\n prefix,\n suffix,\n description,\n descriptionPosition = \"top\",\n isDisabled,\n error,\n onChange,\n label,\n name,\n placeholder,\n type = \"text\",\n value,\n autoFocus,\n autoComplete,\n isRequired = false,\n isReadOnly = false,\n onSubmit,\n onClear,\n \"data-testid\": testId,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const prefixRef = useRef<HTMLDivElement>(null);\n const suffixRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const { className } = useTheme();\n const ref = forwardedRef || inputRef;\n\n // Control dynamic prefix and suffix widths using ResizeObserver\n useEffect(() => {\n if (!containerRef.current) return;\n\n // #region agent log\n let callbackCount = 0;\n let lastUpdateTime = Date.now();\n const previousValues = {\n containerWidth: 0,\n prefixWidth: 0,\n suffixWidth: 0,\n };\n // #endregion\n\n const updateSizes = (entries?: ResizeObserverEntry[]) => {\n // #region agent log\n callbackCount++;\n const now = Date.now();\n const timeSinceLastUpdate = now - lastUpdateTime;\n lastUpdateTime = now;\n const triggeredBy =\n entries?.map((e) => e.target.className || \"unknown\").join(\",\") ||\n \"initial\";\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:149\",\n message: \"ResizeObserver callback invoked\",\n data: { callbackCount, timeSinceLastUpdate, triggeredBy },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n\n if (containerRef.current) {\n const containerWidth = containerRef.current.offsetWidth || 200;\n // #region agent log\n const containerWidthChanged =\n containerWidth !== previousValues.containerWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:152\",\n message: \"Reading container width\",\n data: {\n containerWidth,\n previousValue: previousValues.containerWidth,\n changed: containerWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current.style.setProperty(\n \"--container-width\",\n `${containerWidth}px`\n );\n // #region agent log\n previousValues.containerWidth = containerWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:157\",\n message: \"Set container-width CSS property\",\n data: { containerWidth, changed: containerWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n if (prefixRef.current) {\n const prefixWidth = prefixRef.current.offsetWidth || 32;\n // #region agent log\n const prefixWidthChanged = prefixWidth !== previousValues.prefixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:163\",\n message: \"Reading prefix width\",\n data: {\n prefixWidth,\n previousValue: previousValues.prefixWidth,\n changed: prefixWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current?.style.setProperty(\n \"--prefix-width\",\n `${prefixWidth}px`\n );\n // #region agent log\n previousValues.prefixWidth = prefixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:168\",\n message: \"Set prefix-width CSS property\",\n data: { prefixWidth, changed: prefixWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n if (suffixRef.current) {\n const suffixWidth = suffixRef.current.offsetWidth || 32;\n // #region agent log\n const suffixWidthChanged = suffixWidth !== previousValues.suffixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:174\",\n message: \"Reading suffix width\",\n data: {\n suffixWidth,\n previousValue: previousValues.suffixWidth,\n changed: suffixWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current?.style.setProperty(\n \"--suffix-width\",\n `${suffixWidth}px`\n );\n // #region agent log\n previousValues.suffixWidth = suffixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:179\",\n message: \"Set suffix-width CSS property\",\n data: { suffixWidth, changed: suffixWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n // #region agent log\n if (timeSinceLastUpdate < 10) {\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:185\",\n message: \"Rapid callback detected\",\n data: { callbackCount, timeSinceLastUpdate },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"E\",\n }),\n }\n ).catch(() => {});\n }\n // #endregion\n };\n\n updateSizes();\n\n const resizeObserver = new ResizeObserver(updateSizes);\n\n if (containerRef.current) {\n resizeObserver.observe(containerRef.current);\n }\n if (prefixRef.current) {\n resizeObserver.observe(prefixRef.current);\n }\n if (suffixRef.current) {\n resizeObserver.observe(suffixRef.current);\n }\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [prefix, suffix]);\n\n const inputId = `${name}-input`;\n const errorId = `${name}-error`;\n const descriptionId = `${name}-description`;\n\n return (\n <div ref={containerRef} className=\"proton-Input__container\">\n {description && descriptionPosition === \"top\" && (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n )}\n <div\n className={csx(\n \"proton-Input__container-inner\",\n prefix && \"proton-Input__has-prefix\",\n suffix && \"proton-Input__has-suffix\"\n )}\n >\n {prefix && (\n <div\n ref={prefixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__prefix\"\n )}\n >\n {prefix}\n </div>\n )}\n\n <input\n id={inputId}\n name={name}\n type={type}\n value={value}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e.target.value);\n }}\n onKeyDown={(e: React.KeyboardEvent<HTMLInputElement>) => {\n switch (e.key) {\n case \"Enter\":\n if (onSubmit) {\n e.preventDefault();\n onSubmit(e);\n }\n break;\n case \"Escape\":\n if (onClear) {\n e.preventDefault();\n onClear();\n }\n break;\n }\n }}\n onCopy={async () =>\n await copyTextToClipboard(inputRef.current?.value)\n }\n disabled={isDisabled}\n readOnly={isReadOnly}\n required={isRequired}\n autoFocus={autoFocus}\n autoComplete={autoComplete ? \"on\" : \"off\"}\n placeholder={label ? undefined : placeholder}\n aria-label={label || name}\n aria-invalid={Boolean(error)}\n aria-errormessage={typeof error === \"string\" ? error : errorId}\n aria-required={isRequired}\n aria-readonly={isReadOnly}\n aria-describedby={\n error ? errorId : description ? descriptionId : undefined\n }\n aria-disabled={isDisabled}\n data-testid={testId}\n ref={ref}\n className={csx(\n \"proton-Input\",\n error && \"proton-Input--error\",\n label && \"proton-Input__label-top\",\n className\n )}\n />\n\n <label\n htmlFor={inputId}\n className={csx(\n \"proton-Input__label\",\n value && \"proton-Input__label--filled\"\n )}\n >\n {label}\n {isRequired && <span aria-hidden=\"true\"> *</span>}\n </label>\n\n {suffix && (\n <div\n ref={suffixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__suffix\"\n )}\n >\n {suffix}\n </div>\n )}\n </div>\n\n {error ? (\n <div\n role=\"alert\"\n className={csx(\"proton-Input__error\", \"proton-Input__text\")}\n id={errorId}\n >\n {error}\n </div>\n ) : description && descriptionPosition === \"bottom\" ? (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n ) : null}\n </div>\n );\n }\n);\n\nInput.displayName = \"ProtonUIInput\";\n"],"names":["Input","forwardRef","prefix","suffix","description","descriptionPosition","isDisabled","error","onChange","label","name","placeholder","type","value","autoFocus","autoComplete","isRequired","isReadOnly","onSubmit","onClear","testId","forwardedRef","inputRef","useRef","prefixRef","suffixRef","containerRef","className","useTheme","ref","useEffect","callbackCount","lastUpdateTime","previousValues","updateSizes","entries","now","timeSinceLastUpdate","triggeredBy","e","containerWidth","containerWidthChanged","prefixWidth","prefixWidthChanged","_a","suffixWidth","suffixWidthChanged","_b","resizeObserver","inputId","errorId","descriptionId","jsxs","jsx","csx","copyTextToClipboard"],"mappings":"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"}
@@ -1,186 +1,342 @@
1
- import { j as r } from "../../../node_modules/react/jsx-runtime.es.js";
2
- import { forwardRef as K, useRef as _, useEffect as U } from "react";
3
- import { useTheme as g } from "../../ThemeProvider.es.js";
1
+ import { j as n } from "../../../node_modules/react/jsx-runtime.es.js";
2
+ import { forwardRef as L, useRef as I, useEffect as q } from "react";
3
+ import { useTheme as G } from "../../ThemeProvider.es.js";
4
4
  /* empty css */
5
- import { copyTextToClipboard as q } from "../../../utils/copy.es.js";
6
- import { csx as o } from "../../../utils/string.es.js";
7
- const A = K(
5
+ import { copyTextToClipboard as H } from "../../../utils/copy.es.js";
6
+ import { csx as r } from "../../../utils/string.es.js";
7
+ const M = L(
8
8
  ({
9
9
  prefix: u,
10
- suffix: l,
11
- description: s,
12
- descriptionPosition: v = "top",
13
- isDisabled: y,
14
- error: n,
15
- onChange: x,
16
- label: d,
17
- name: i,
18
- placeholder: k,
19
- type: z = "text",
20
- value: b,
21
- autoFocus: P,
22
- autoComplete: T,
23
- isRequired: h = !1,
24
- isReadOnly: j = !1,
10
+ suffix: f,
11
+ description: d,
12
+ descriptionPosition: w = "top",
13
+ isDisabled: S,
14
+ error: o,
15
+ onChange: y,
16
+ label: l,
17
+ name: p,
18
+ placeholder: $,
19
+ type: E = "text",
20
+ value: j,
21
+ autoFocus: z,
22
+ autoComplete: A,
23
+ isRequired: b = !1,
24
+ isReadOnly: W = !1,
25
25
  onSubmit: N,
26
- onClear: w,
27
- "data-testid": D
28
- }, O) => {
29
- const W = _(null), a = _(null), p = _(null), e = _(null), { className: B } = g(), F = O || W;
30
- U(() => {
31
- if (!e.current) return;
32
- const t = () => {
33
- var R, E;
34
- if (e.current) {
35
- const c = e.current.offsetWidth || 200;
36
- e.current.style.setProperty(
26
+ onClear: T,
27
+ "data-testid": V
28
+ }, U) => {
29
+ const O = I(null), c = I(null), h = I(null), s = I(null), { className: B } = G(), F = U || O;
30
+ q(() => {
31
+ if (!s.current) return;
32
+ let e = 0, D = Date.now();
33
+ const a = {
34
+ containerWidth: 0,
35
+ prefixWidth: 0,
36
+ suffixWidth: 0
37
+ }, P = (_) => {
38
+ var k, J;
39
+ e++;
40
+ const R = Date.now(), v = R - D;
41
+ D = R;
42
+ const K = (_ == null ? void 0 : _.map((t) => t.target.className || "unknown").join(",")) || "initial";
43
+ if (fetch(
44
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
45
+ {
46
+ method: "POST",
47
+ headers: { "Content-Type": "application/json" },
48
+ body: JSON.stringify({
49
+ location: "Input.tsx:149",
50
+ message: "ResizeObserver callback invoked",
51
+ data: { callbackCount: e, timeSinceLastUpdate: v, triggeredBy: K },
52
+ timestamp: Date.now(),
53
+ sessionId: "debug-session",
54
+ runId: "run1",
55
+ hypothesisId: "A"
56
+ })
57
+ }
58
+ ).catch(() => {
59
+ }), s.current) {
60
+ const t = s.current.offsetWidth || 200, i = t !== a.containerWidth;
61
+ fetch(
62
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
63
+ {
64
+ method: "POST",
65
+ headers: { "Content-Type": "application/json" },
66
+ body: JSON.stringify({
67
+ location: "Input.tsx:152",
68
+ message: "Reading container width",
69
+ data: {
70
+ containerWidth: t,
71
+ previousValue: a.containerWidth,
72
+ changed: i
73
+ },
74
+ timestamp: Date.now(),
75
+ sessionId: "debug-session",
76
+ runId: "run1",
77
+ hypothesisId: "C"
78
+ })
79
+ }
80
+ ).catch(() => {
81
+ }), s.current.style.setProperty(
37
82
  "--container-width",
38
- `${c}px`
39
- );
83
+ `${t}px`
84
+ ), a.containerWidth = t, fetch(
85
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
86
+ {
87
+ method: "POST",
88
+ headers: { "Content-Type": "application/json" },
89
+ body: JSON.stringify({
90
+ location: "Input.tsx:157",
91
+ message: "Set container-width CSS property",
92
+ data: { containerWidth: t, changed: i },
93
+ timestamp: Date.now(),
94
+ sessionId: "debug-session",
95
+ runId: "run1",
96
+ hypothesisId: "A"
97
+ })
98
+ }
99
+ ).catch(() => {
100
+ });
40
101
  }
41
- if (a.current) {
42
- const c = a.current.offsetWidth || 32;
43
- (R = e.current) == null || R.style.setProperty(
102
+ if (c.current) {
103
+ const t = c.current.offsetWidth || 32, i = t !== a.prefixWidth;
104
+ fetch(
105
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
106
+ {
107
+ method: "POST",
108
+ headers: { "Content-Type": "application/json" },
109
+ body: JSON.stringify({
110
+ location: "Input.tsx:163",
111
+ message: "Reading prefix width",
112
+ data: {
113
+ prefixWidth: t,
114
+ previousValue: a.prefixWidth,
115
+ changed: i
116
+ },
117
+ timestamp: Date.now(),
118
+ sessionId: "debug-session",
119
+ runId: "run1",
120
+ hypothesisId: "C"
121
+ })
122
+ }
123
+ ).catch(() => {
124
+ }), (k = s.current) == null || k.style.setProperty(
44
125
  "--prefix-width",
45
- `${c}px`
46
- );
126
+ `${t}px`
127
+ ), a.prefixWidth = t, fetch(
128
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
129
+ {
130
+ method: "POST",
131
+ headers: { "Content-Type": "application/json" },
132
+ body: JSON.stringify({
133
+ location: "Input.tsx:168",
134
+ message: "Set prefix-width CSS property",
135
+ data: { prefixWidth: t, changed: i },
136
+ timestamp: Date.now(),
137
+ sessionId: "debug-session",
138
+ runId: "run1",
139
+ hypothesisId: "A"
140
+ })
141
+ }
142
+ ).catch(() => {
143
+ });
47
144
  }
48
- if (p.current) {
49
- const c = p.current.offsetWidth || 32;
50
- (E = e.current) == null || E.style.setProperty(
145
+ if (h.current) {
146
+ const t = h.current.offsetWidth || 32, i = t !== a.suffixWidth;
147
+ fetch(
148
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
149
+ {
150
+ method: "POST",
151
+ headers: { "Content-Type": "application/json" },
152
+ body: JSON.stringify({
153
+ location: "Input.tsx:174",
154
+ message: "Reading suffix width",
155
+ data: {
156
+ suffixWidth: t,
157
+ previousValue: a.suffixWidth,
158
+ changed: i
159
+ },
160
+ timestamp: Date.now(),
161
+ sessionId: "debug-session",
162
+ runId: "run1",
163
+ hypothesisId: "C"
164
+ })
165
+ }
166
+ ).catch(() => {
167
+ }), (J = s.current) == null || J.style.setProperty(
51
168
  "--suffix-width",
52
- `${c}px`
53
- );
169
+ `${t}px`
170
+ ), a.suffixWidth = t, fetch(
171
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
172
+ {
173
+ method: "POST",
174
+ headers: { "Content-Type": "application/json" },
175
+ body: JSON.stringify({
176
+ location: "Input.tsx:179",
177
+ message: "Set suffix-width CSS property",
178
+ data: { suffixWidth: t, changed: i },
179
+ timestamp: Date.now(),
180
+ sessionId: "debug-session",
181
+ runId: "run1",
182
+ hypothesisId: "A"
183
+ })
184
+ }
185
+ ).catch(() => {
186
+ });
54
187
  }
188
+ v < 10 && fetch(
189
+ "http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324",
190
+ {
191
+ method: "POST",
192
+ headers: { "Content-Type": "application/json" },
193
+ body: JSON.stringify({
194
+ location: "Input.tsx:185",
195
+ message: "Rapid callback detected",
196
+ data: { callbackCount: e, timeSinceLastUpdate: v },
197
+ timestamp: Date.now(),
198
+ sessionId: "debug-session",
199
+ runId: "run1",
200
+ hypothesisId: "E"
201
+ })
202
+ }
203
+ ).catch(() => {
204
+ });
55
205
  };
56
- t();
57
- const f = new ResizeObserver(t);
58
- return e.current && f.observe(e.current), a.current && f.observe(a.current), p.current && f.observe(p.current), () => {
59
- f.disconnect();
206
+ P();
207
+ const m = new ResizeObserver(P);
208
+ return s.current && m.observe(s.current), c.current && m.observe(c.current), h.current && m.observe(h.current), () => {
209
+ m.disconnect();
60
210
  };
61
- }, [u, l]);
62
- const $ = `${i}-input`, m = `${i}-error`, I = `${i}-description`;
63
- return /* @__PURE__ */ r.jsxs("div", { ref: e, children: [
64
- s && v === "top" && /* @__PURE__ */ r.jsx(
211
+ }, [u, f]);
212
+ const C = `${p}-input`, x = `${p}-error`, g = `${p}-description`;
213
+ return /* @__PURE__ */ n.jsxs("div", { ref: s, className: "proton-Input__container", children: [
214
+ d && w === "top" && /* @__PURE__ */ n.jsx(
65
215
  "div",
66
216
  {
67
- id: I,
217
+ id: g,
68
218
  className: "proton-Input__text",
69
219
  "aria-live": "polite",
70
- children: s
220
+ children: d
71
221
  }
72
222
  ),
73
- /* @__PURE__ */ r.jsxs("div", { className: o(
74
- "proton-Input__container-inner",
75
- u && "proton-Input__has-prefix",
76
- l && "proton-Input__has-suffix"
77
- ), children: [
78
- u && /* @__PURE__ */ r.jsx(
79
- "div",
80
- {
81
- ref: a,
82
- className: o(
83
- "proton-Input__descriptor",
84
- "proton-Input__prefix"
223
+ /* @__PURE__ */ n.jsxs(
224
+ "div",
225
+ {
226
+ className: r(
227
+ "proton-Input__container-inner",
228
+ u && "proton-Input__has-prefix",
229
+ f && "proton-Input__has-suffix"
230
+ ),
231
+ children: [
232
+ u && /* @__PURE__ */ n.jsx(
233
+ "div",
234
+ {
235
+ ref: c,
236
+ className: r(
237
+ "proton-Input__descriptor",
238
+ "proton-Input__prefix"
239
+ ),
240
+ children: u
241
+ }
85
242
  ),
86
- children: u
87
- }
88
- ),
89
- /* @__PURE__ */ r.jsx(
90
- "input",
91
- {
92
- id: $,
93
- name: i,
94
- type: z,
95
- value: b,
96
- onChange: (t) => {
97
- x == null || x(t.target.value);
98
- },
99
- onKeyDown: (t) => {
100
- switch (t.key) {
101
- case "Enter":
102
- N && (t.preventDefault(), N(t));
103
- break;
104
- case "Escape":
105
- w && (t.preventDefault(), w());
106
- break;
243
+ /* @__PURE__ */ n.jsx(
244
+ "input",
245
+ {
246
+ id: C,
247
+ name: p,
248
+ type: E,
249
+ value: j,
250
+ onChange: (e) => {
251
+ y == null || y(e.target.value);
252
+ },
253
+ onKeyDown: (e) => {
254
+ switch (e.key) {
255
+ case "Enter":
256
+ N && (e.preventDefault(), N(e));
257
+ break;
258
+ case "Escape":
259
+ T && (e.preventDefault(), T());
260
+ break;
261
+ }
262
+ },
263
+ onCopy: async () => {
264
+ var e;
265
+ return await H((e = O.current) == null ? void 0 : e.value);
266
+ },
267
+ disabled: S,
268
+ readOnly: W,
269
+ required: b,
270
+ autoFocus: z,
271
+ autoComplete: A ? "on" : "off",
272
+ placeholder: l ? void 0 : $,
273
+ "aria-label": l || p,
274
+ "aria-invalid": !!o,
275
+ "aria-errormessage": typeof o == "string" ? o : x,
276
+ "aria-required": b,
277
+ "aria-readonly": W,
278
+ "aria-describedby": o ? x : d ? g : void 0,
279
+ "aria-disabled": S,
280
+ "data-testid": V,
281
+ ref: F,
282
+ className: r(
283
+ "proton-Input",
284
+ o && "proton-Input--error",
285
+ l && "proton-Input__label-top",
286
+ B
287
+ )
107
288
  }
108
- },
109
- onCopy: async () => {
110
- var t;
111
- return await q((t = W.current) == null ? void 0 : t.value);
112
- },
113
- disabled: y,
114
- readOnly: j,
115
- required: h,
116
- autoFocus: P,
117
- autoComplete: T ? "on" : "off",
118
- placeholder: d ? void 0 : k,
119
- "aria-label": d || i,
120
- "aria-invalid": !!n,
121
- "aria-errormessage": typeof n == "string" ? n : m,
122
- "aria-required": h,
123
- "aria-readonly": j,
124
- "aria-describedby": n ? m : s ? I : void 0,
125
- "aria-disabled": y,
126
- "data-testid": D,
127
- ref: F,
128
- className: o(
129
- "proton-Input",
130
- n && "proton-Input--error",
131
- d && "proton-Input__label-top",
132
- B
133
- )
134
- }
135
- ),
136
- /* @__PURE__ */ r.jsxs(
137
- "label",
138
- {
139
- htmlFor: $,
140
- className: o(
141
- "proton-Input__label",
142
- b && "proton-Input__label--filled"
143
289
  ),
144
- children: [
145
- d,
146
- h && /* @__PURE__ */ r.jsx("span", { "aria-hidden": "true", children: " *" })
147
- ]
148
- }
149
- ),
150
- l && /* @__PURE__ */ r.jsx(
151
- "div",
152
- {
153
- ref: p,
154
- className: o(
155
- "proton-Input__descriptor",
156
- "proton-Input__suffix"
290
+ /* @__PURE__ */ n.jsxs(
291
+ "label",
292
+ {
293
+ htmlFor: C,
294
+ className: r(
295
+ "proton-Input__label",
296
+ j && "proton-Input__label--filled"
297
+ ),
298
+ children: [
299
+ l,
300
+ b && /* @__PURE__ */ n.jsx("span", { "aria-hidden": "true", children: " *" })
301
+ ]
302
+ }
157
303
  ),
158
- children: l
159
- }
160
- )
161
- ] }),
162
- n ? /* @__PURE__ */ r.jsx(
304
+ f && /* @__PURE__ */ n.jsx(
305
+ "div",
306
+ {
307
+ ref: h,
308
+ className: r(
309
+ "proton-Input__descriptor",
310
+ "proton-Input__suffix"
311
+ ),
312
+ children: f
313
+ }
314
+ )
315
+ ]
316
+ }
317
+ ),
318
+ o ? /* @__PURE__ */ n.jsx(
163
319
  "div",
164
320
  {
165
321
  role: "alert",
166
- className: o("proton-Input__error", "proton-Input__text"),
167
- id: m,
168
- children: n
322
+ className: r("proton-Input__error", "proton-Input__text"),
323
+ id: x,
324
+ children: o
169
325
  }
170
- ) : s && v === "bottom" ? /* @__PURE__ */ r.jsx(
326
+ ) : d && w === "bottom" ? /* @__PURE__ */ n.jsx(
171
327
  "div",
172
328
  {
173
- id: I,
329
+ id: g,
174
330
  className: "proton-Input__text",
175
331
  "aria-live": "polite",
176
- children: s
332
+ children: d
177
333
  }
178
334
  ) : null
179
335
  ] });
180
336
  }
181
337
  );
182
- A.displayName = "ProtonUIInput";
338
+ M.displayName = "ProtonUIInput";
183
339
  export {
184
- A as Input
340
+ M as Input
185
341
  };
186
342
  //# sourceMappingURL=Input.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Input.es.js","sources":["../../../../src/components/Input/BaseInput/Input.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef } from \"react\";\n\nimport { useTheme } from \"../../ThemeProvider\";\nimport { csx } from \"../../../utils\";\nimport \"./Input.css\";\nimport { copyTextToClipboard } from \"../../../utils/copy\";\n\nexport interface BaseInputProps {\n /**\n * onChange handler for the input\n */\n onChange?: (value: string) => void;\n\n /** Whether the input is disabled. */\n isDisabled?: boolean;\n\n /** Description text shown above the input. */\n description?: React.ReactNode | string;\n\n /**\n * The position of the description text.\n * @default \"top\"\n */\n descriptionPosition?: \"top\" | \"bottom\";\n\n /** Error state that changes the input's visual style and displays an error message. */\n error?: React.ReactNode | string;\n\n /**\n * Label for the input element.\n * @note When a label is provided, the input will have extra padding, and the label will float above the text input when focused or filled.\n */\n label?: string;\n\n /** Test ID for the component. */\n \"data-testid\"?: string;\n\n /** Content to display before the input. Typically used for icons. */\n prefix?: React.ReactNode;\n\n /** Content to display after the input. Typically used for icons. */\n suffix?: React.ReactNode;\n\n /**\n * Should the browser's autocomplete be enabled?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete\n */\n autoComplete?: boolean;\n\n /**\n * Should the input be autofocused?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autofocus\n */\n autoFocus?: boolean;\n\n /**\n * The name attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/name\n */\n name: string;\n\n /**\n * The placeholder text to display when the input is empty.\n * @note label takes precedence over placeholder, if both are provided.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/placeholder\n */\n placeholder?: string;\n\n /**\n * The type attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/type\n * @default \"text\"\n */\n type?: string;\n\n /**\n * The value of the input.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value\n */\n value?: string;\n\n /**\n * Whether the input is required.\n * @default false\n */\n isRequired?: boolean;\n\n /**\n * Whether the input is read-only.\n * @default false\n */\n isReadOnly?: boolean;\n\n /**\n * Called when the input is submitted (e.g. by pressing Enter).\n */\n onSubmit?: React.FormEventHandler<HTMLInputElement>;\n\n /**\n * Called when the input is cleared (e.g. by pressing Escape).\n */\n onClear?: () => void;\n}\n\n/**\n * A controlled and customizable input component with support for labels, prefixes, suffixes, and error states.\n *\n * API:\n * - {@link BaseInputProps}\n */\nexport const Input = forwardRef<HTMLInputElement, BaseInputProps>(\n (\n {\n prefix,\n suffix,\n description,\n descriptionPosition = \"top\",\n isDisabled,\n error,\n onChange,\n label,\n name,\n placeholder,\n type = \"text\",\n value,\n autoFocus,\n autoComplete,\n isRequired = false,\n isReadOnly = false,\n onSubmit,\n onClear,\n \"data-testid\": testId,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const prefixRef = useRef<HTMLDivElement>(null);\n const suffixRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const { className } = useTheme();\n const ref = forwardedRef || inputRef;\n\n // Control dynamic prefix and suffix widths using ResizeObserver\n useEffect(() => {\n if (!containerRef.current) return;\n\n const updateSizes = () => {\n if (containerRef.current) {\n const containerWidth = containerRef.current.offsetWidth || 200;\n containerRef.current.style.setProperty(\n \"--container-width\",\n `${containerWidth}px`\n );\n }\n\n if (prefixRef.current) {\n const prefixWidth = prefixRef.current.offsetWidth || 32;\n containerRef.current?.style.setProperty(\n \"--prefix-width\",\n `${prefixWidth}px`\n );\n }\n\n if (suffixRef.current) {\n const suffixWidth = suffixRef.current.offsetWidth || 32;\n containerRef.current?.style.setProperty(\n \"--suffix-width\",\n `${suffixWidth}px`\n );\n }\n };\n\n updateSizes();\n\n const resizeObserver = new ResizeObserver(updateSizes);\n\n if (containerRef.current) {\n resizeObserver.observe(containerRef.current);\n }\n if (prefixRef.current) {\n resizeObserver.observe(prefixRef.current);\n }\n if (suffixRef.current) {\n resizeObserver.observe(suffixRef.current);\n }\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [prefix, suffix]);\n\n const inputId = `${name}-input`;\n const errorId = `${name}-error`;\n const descriptionId = `${name}-description`;\n\n return (\n <div ref={containerRef}>\n {description && descriptionPosition === \"top\" && (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n )}\n <div className={csx(\n \"proton-Input__container-inner\",\n prefix && \"proton-Input__has-prefix\",\n suffix && \"proton-Input__has-suffix\"\n )}>\n {prefix && (\n <div\n ref={prefixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__prefix\"\n )}\n >\n {prefix}\n </div>\n )}\n\n <input\n id={inputId}\n name={name}\n type={type}\n value={value}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e.target.value);\n }}\n onKeyDown={(e: React.KeyboardEvent<HTMLInputElement>) => {\n switch (e.key) {\n case \"Enter\":\n if (onSubmit) {\n e.preventDefault();\n onSubmit(e);\n }\n break;\n case \"Escape\":\n if (onClear) {\n e.preventDefault();\n onClear();\n }\n break;\n }\n }}\n onCopy={async () =>\n await copyTextToClipboard(inputRef.current?.value)\n }\n disabled={isDisabled}\n readOnly={isReadOnly}\n required={isRequired}\n autoFocus={autoFocus}\n autoComplete={autoComplete ? \"on\" : \"off\"}\n placeholder={label ? undefined : placeholder}\n aria-label={label || name}\n aria-invalid={Boolean(error)}\n aria-errormessage={typeof error === \"string\" ? error : errorId}\n aria-required={isRequired}\n aria-readonly={isReadOnly}\n aria-describedby={\n error ? errorId : description ? descriptionId : undefined\n }\n aria-disabled={isDisabled}\n data-testid={testId}\n ref={ref}\n className={csx(\n \"proton-Input\",\n error && \"proton-Input--error\",\n label && \"proton-Input__label-top\",\n className\n )}\n />\n\n <label\n htmlFor={inputId}\n className={csx(\n \"proton-Input__label\",\n value && \"proton-Input__label--filled\"\n )}\n >\n {label}\n {isRequired && <span aria-hidden=\"true\"> *</span>}\n </label>\n\n {suffix && (\n <div\n ref={suffixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__suffix\"\n )}\n >\n {suffix}\n </div>\n )}\n </div>\n\n {error ? (\n <div\n role=\"alert\"\n className={csx(\"proton-Input__error\", \"proton-Input__text\")}\n id={errorId}\n >\n {error}\n </div>\n ) : description && descriptionPosition === \"bottom\" ? (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n ) : null}\n </div>\n );\n }\n);\n\nInput.displayName = \"ProtonUIInput\";\n"],"names":["Input","forwardRef","prefix","suffix","description","descriptionPosition","isDisabled","error","onChange","label","name","placeholder","type","value","autoFocus","autoComplete","isRequired","isReadOnly","onSubmit","onClear","testId","forwardedRef","inputRef","useRef","prefixRef","suffixRef","containerRef","className","useTheme","ref","useEffect","updateSizes","containerWidth","prefixWidth","_a","suffixWidth","_b","resizeObserver","inputId","errorId","descriptionId","jsxs","jsx","csx","e","copyTextToClipboard"],"mappings":"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"}
1
+ {"version":3,"file":"Input.es.js","sources":["../../../../src/components/Input/BaseInput/Input.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef } from \"react\";\n\nimport { useTheme } from \"../../ThemeProvider\";\nimport { csx } from \"../../../utils\";\nimport \"./Input.css\";\nimport { copyTextToClipboard } from \"../../../utils/copy\";\n\nexport interface BaseInputProps {\n /**\n * onChange handler for the input\n */\n onChange?: (value: string) => void;\n\n /** Whether the input is disabled. */\n isDisabled?: boolean;\n\n /** Description text shown above the input. */\n description?: React.ReactNode | string;\n\n /**\n * The position of the description text.\n * @default \"top\"\n */\n descriptionPosition?: \"top\" | \"bottom\";\n\n /** Error state that changes the input's visual style and displays an error message. */\n error?: React.ReactNode | string;\n\n /**\n * Label for the input element.\n * @note When a label is provided, the input will have extra padding, and the label will float above the text input when focused or filled.\n */\n label?: string;\n\n /** Test ID for the component. */\n \"data-testid\"?: string;\n\n /** Content to display before the input. Typically used for icons. */\n prefix?: React.ReactNode;\n\n /** Content to display after the input. Typically used for icons. */\n suffix?: React.ReactNode;\n\n /**\n * Should the browser's autocomplete be enabled?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete\n */\n autoComplete?: boolean;\n\n /**\n * Should the input be autofocused?\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autofocus\n */\n autoFocus?: boolean;\n\n /**\n * The name attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/name\n */\n name: string;\n\n /**\n * The placeholder text to display when the input is empty.\n * @note label takes precedence over placeholder, if both are provided.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/placeholder\n */\n placeholder?: string;\n\n /**\n * The type attribute of the input element.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/type\n * @default \"text\"\n */\n type?: string;\n\n /**\n * The value of the input.\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#value\n */\n value?: string;\n\n /**\n * Whether the input is required.\n * @default false\n */\n isRequired?: boolean;\n\n /**\n * Whether the input is read-only.\n * @default false\n */\n isReadOnly?: boolean;\n\n /**\n * Called when the input is submitted (e.g. by pressing Enter).\n */\n onSubmit?: React.FormEventHandler<HTMLInputElement>;\n\n /**\n * Called when the input is cleared (e.g. by pressing Escape).\n */\n onClear?: () => void;\n}\n\n/**\n * A controlled and customizable input component with support for labels, prefixes, suffixes, and error states.\n *\n * API:\n * - {@link BaseInputProps}\n */\nexport const Input = forwardRef<HTMLInputElement, BaseInputProps>(\n (\n {\n prefix,\n suffix,\n description,\n descriptionPosition = \"top\",\n isDisabled,\n error,\n onChange,\n label,\n name,\n placeholder,\n type = \"text\",\n value,\n autoFocus,\n autoComplete,\n isRequired = false,\n isReadOnly = false,\n onSubmit,\n onClear,\n \"data-testid\": testId,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const inputRef = useRef<HTMLInputElement>(null);\n const prefixRef = useRef<HTMLDivElement>(null);\n const suffixRef = useRef<HTMLDivElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const { className } = useTheme();\n const ref = forwardedRef || inputRef;\n\n // Control dynamic prefix and suffix widths using ResizeObserver\n useEffect(() => {\n if (!containerRef.current) return;\n\n // #region agent log\n let callbackCount = 0;\n let lastUpdateTime = Date.now();\n const previousValues = {\n containerWidth: 0,\n prefixWidth: 0,\n suffixWidth: 0,\n };\n // #endregion\n\n const updateSizes = (entries?: ResizeObserverEntry[]) => {\n // #region agent log\n callbackCount++;\n const now = Date.now();\n const timeSinceLastUpdate = now - lastUpdateTime;\n lastUpdateTime = now;\n const triggeredBy =\n entries?.map((e) => e.target.className || \"unknown\").join(\",\") ||\n \"initial\";\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:149\",\n message: \"ResizeObserver callback invoked\",\n data: { callbackCount, timeSinceLastUpdate, triggeredBy },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n\n if (containerRef.current) {\n const containerWidth = containerRef.current.offsetWidth || 200;\n // #region agent log\n const containerWidthChanged =\n containerWidth !== previousValues.containerWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:152\",\n message: \"Reading container width\",\n data: {\n containerWidth,\n previousValue: previousValues.containerWidth,\n changed: containerWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current.style.setProperty(\n \"--container-width\",\n `${containerWidth}px`\n );\n // #region agent log\n previousValues.containerWidth = containerWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:157\",\n message: \"Set container-width CSS property\",\n data: { containerWidth, changed: containerWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n if (prefixRef.current) {\n const prefixWidth = prefixRef.current.offsetWidth || 32;\n // #region agent log\n const prefixWidthChanged = prefixWidth !== previousValues.prefixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:163\",\n message: \"Reading prefix width\",\n data: {\n prefixWidth,\n previousValue: previousValues.prefixWidth,\n changed: prefixWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current?.style.setProperty(\n \"--prefix-width\",\n `${prefixWidth}px`\n );\n // #region agent log\n previousValues.prefixWidth = prefixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:168\",\n message: \"Set prefix-width CSS property\",\n data: { prefixWidth, changed: prefixWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n if (suffixRef.current) {\n const suffixWidth = suffixRef.current.offsetWidth || 32;\n // #region agent log\n const suffixWidthChanged = suffixWidth !== previousValues.suffixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:174\",\n message: \"Reading suffix width\",\n data: {\n suffixWidth,\n previousValue: previousValues.suffixWidth,\n changed: suffixWidthChanged,\n },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"C\",\n }),\n }\n ).catch(() => {});\n // #endregion\n containerRef.current?.style.setProperty(\n \"--suffix-width\",\n `${suffixWidth}px`\n );\n // #region agent log\n previousValues.suffixWidth = suffixWidth;\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:179\",\n message: \"Set suffix-width CSS property\",\n data: { suffixWidth, changed: suffixWidthChanged },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"A\",\n }),\n }\n ).catch(() => {});\n // #endregion\n }\n\n // #region agent log\n if (timeSinceLastUpdate < 10) {\n fetch(\n \"http://127.0.0.1:7243/ingest/f16ad2de-908b-4cb9-a792-256436a5e324\",\n {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n location: \"Input.tsx:185\",\n message: \"Rapid callback detected\",\n data: { callbackCount, timeSinceLastUpdate },\n timestamp: Date.now(),\n sessionId: \"debug-session\",\n runId: \"run1\",\n hypothesisId: \"E\",\n }),\n }\n ).catch(() => {});\n }\n // #endregion\n };\n\n updateSizes();\n\n const resizeObserver = new ResizeObserver(updateSizes);\n\n if (containerRef.current) {\n resizeObserver.observe(containerRef.current);\n }\n if (prefixRef.current) {\n resizeObserver.observe(prefixRef.current);\n }\n if (suffixRef.current) {\n resizeObserver.observe(suffixRef.current);\n }\n\n return () => {\n resizeObserver.disconnect();\n };\n }, [prefix, suffix]);\n\n const inputId = `${name}-input`;\n const errorId = `${name}-error`;\n const descriptionId = `${name}-description`;\n\n return (\n <div ref={containerRef} className=\"proton-Input__container\">\n {description && descriptionPosition === \"top\" && (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n )}\n <div\n className={csx(\n \"proton-Input__container-inner\",\n prefix && \"proton-Input__has-prefix\",\n suffix && \"proton-Input__has-suffix\"\n )}\n >\n {prefix && (\n <div\n ref={prefixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__prefix\"\n )}\n >\n {prefix}\n </div>\n )}\n\n <input\n id={inputId}\n name={name}\n type={type}\n value={value}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => {\n onChange?.(e.target.value);\n }}\n onKeyDown={(e: React.KeyboardEvent<HTMLInputElement>) => {\n switch (e.key) {\n case \"Enter\":\n if (onSubmit) {\n e.preventDefault();\n onSubmit(e);\n }\n break;\n case \"Escape\":\n if (onClear) {\n e.preventDefault();\n onClear();\n }\n break;\n }\n }}\n onCopy={async () =>\n await copyTextToClipboard(inputRef.current?.value)\n }\n disabled={isDisabled}\n readOnly={isReadOnly}\n required={isRequired}\n autoFocus={autoFocus}\n autoComplete={autoComplete ? \"on\" : \"off\"}\n placeholder={label ? undefined : placeholder}\n aria-label={label || name}\n aria-invalid={Boolean(error)}\n aria-errormessage={typeof error === \"string\" ? error : errorId}\n aria-required={isRequired}\n aria-readonly={isReadOnly}\n aria-describedby={\n error ? errorId : description ? descriptionId : undefined\n }\n aria-disabled={isDisabled}\n data-testid={testId}\n ref={ref}\n className={csx(\n \"proton-Input\",\n error && \"proton-Input--error\",\n label && \"proton-Input__label-top\",\n className\n )}\n />\n\n <label\n htmlFor={inputId}\n className={csx(\n \"proton-Input__label\",\n value && \"proton-Input__label--filled\"\n )}\n >\n {label}\n {isRequired && <span aria-hidden=\"true\"> *</span>}\n </label>\n\n {suffix && (\n <div\n ref={suffixRef}\n className={csx(\n \"proton-Input__descriptor\",\n \"proton-Input__suffix\"\n )}\n >\n {suffix}\n </div>\n )}\n </div>\n\n {error ? (\n <div\n role=\"alert\"\n className={csx(\"proton-Input__error\", \"proton-Input__text\")}\n id={errorId}\n >\n {error}\n </div>\n ) : description && descriptionPosition === \"bottom\" ? (\n <div\n id={descriptionId}\n className=\"proton-Input__text\"\n aria-live=\"polite\"\n >\n {description}\n </div>\n ) : null}\n </div>\n );\n }\n);\n\nInput.displayName = \"ProtonUIInput\";\n"],"names":["Input","forwardRef","prefix","suffix","description","descriptionPosition","isDisabled","error","onChange","label","name","placeholder","type","value","autoFocus","autoComplete","isRequired","isReadOnly","onSubmit","onClear","testId","forwardedRef","inputRef","useRef","prefixRef","suffixRef","containerRef","className","useTheme","ref","useEffect","callbackCount","lastUpdateTime","previousValues","updateSizes","entries","now","timeSinceLastUpdate","triggeredBy","e","containerWidth","containerWidthChanged","prefixWidth","prefixWidthChanged","_a","suffixWidth","suffixWidthChanged","_b","resizeObserver","inputId","errorId","descriptionId","jsxs","jsx","csx","copyTextToClipboard"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../../../node_modules/react/jsx-runtime.cjs.js"),r=require("react");;/* empty css */const x=require("../../../utils/string.cjs.js"),k=r.forwardRef(({checked:p,defaultChecked:b,onChange:n,name:t,value:j,isDisabled:u=!1,isRequired:a=!1,id:f,"data-testid":_,label:s,description:i,error:o,indeterminate:d=!1},m)=>{const I=r.useRef(null),[C,R]=r.useState(p??b??!1),c=m||I,E=p??C;r.useEffect(()=>{c.current&&(c.current.indeterminate=d)},[d,c]);const v=N=>{const l=N.target.checked;R(l),n==null||n(l)},h=f||`${t}-checkbox`;return e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsx("div",{className:x.csx("proton-CheckboxInput",u&&"proton-CheckboxInput--disabled"),children:e.jsxRuntimeExports.jsxs("div",{className:"proton-CheckboxInput__container",children:[typeof s=="string"?e.jsxRuntimeExports.jsx("label",{htmlFor:h,className:"proton-CheckboxInput__label",children:s}):s,e.jsxRuntimeExports.jsx("input",{ref:c,id:h,name:t,type:"checkbox",checked:E,value:j,disabled:u,required:a,onChange:v,className:x.csx("proton-CheckboxInput__input",o&&"proton-CheckboxInput__input--error"),"aria-label":s?void 0:t,"data-testid":_}),typeof i=="string"?e.jsxRuntimeExports.jsxs("div",{id:`${t}-description`,className:"proton-CheckboxInput__text","aria-live":"polite",children:[i,a&&e.jsxRuntimeExports.jsx("span",{"aria-hidden":"true",className:"proton-CheckboxInput__text",children:" *"})]}):i]})}),typeof o=="string"?e.jsxRuntimeExports.jsx("div",{role:"alert",className:x.csx("proton-CheckboxInput__error","proton-CheckboxInput__text"),id:`${t}-error`,children:o}):o]})});k.displayName="ProtonUICheckboxInput";exports.CheckboxInput=k;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../../../node_modules/react/jsx-runtime.cjs.js"),i=require("react");;/* empty css */const a=require("../../../utils/string.cjs.js"),k=i.forwardRef(({checked:x,defaultChecked:b,onChange:n,name:s,value:m,isDisabled:u=!1,isRequired:p=!1,id:I,"data-testid":v,label:o,description:r,error:t,indeterminate:l=!1},R)=>{const y=i.useRef(null),[_,g]=i.useState(x??b??!1),c=R||y,C=x??_;i.useEffect(()=>{c.current&&(c.current.indeterminate=l)},[l,c]);const E=N=>{const j=N.target.checked;g(j),n==null||n(j)},h=I||`${s}-checkbox`,d=typeof t=="string"?`${s}-error`:void 0,f=typeof r=="string"?`${s}-description`:void 0;return e.jsxRuntimeExports.jsxs("div",{children:[e.jsxRuntimeExports.jsx("div",{className:a.csx(u&&"proton-CheckboxInput--disabled"),children:e.jsxRuntimeExports.jsxs("div",{className:"proton-CheckboxInput__container",children:[typeof o=="string"?e.jsxRuntimeExports.jsx("label",{htmlFor:h,className:"proton-CheckboxInput__label",children:o}):o,e.jsxRuntimeExports.jsx("input",{ref:c,id:h,name:s,type:"checkbox",checked:C,value:m,disabled:u,required:p,onChange:E,className:a.csx("proton-CheckboxInput__input",t&&"proton-CheckboxInput__input--error"),"aria-label":o?void 0:s,"aria-invalid":!!t,"aria-errormessage":d,"aria-describedby":[d,f].filter(Boolean).join(" ")||void 0,"data-testid":v}),typeof r=="string"?e.jsxRuntimeExports.jsxs("div",{id:f,"aria-live":"polite",children:[r,p&&e.jsxRuntimeExports.jsx("span",{"aria-hidden":"true",children:" *"})]}):r]})}),typeof t=="string"?e.jsxRuntimeExports.jsx("div",{role:"alert",className:a.csx("proton-CheckboxInput__error"),id:d,children:t}):t]})});k.displayName="ProtonUICheckboxInput";exports.CheckboxInput=k;
2
2
  //# sourceMappingURL=CheckboxInput.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CheckboxInput.cjs.js","sources":["../../../../src/components/Input/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef, useState } from \"react\";\n\nimport { type BaseInputProps } from \"../BaseInput/Input\";\nimport { csx } from \"../../../utils\";\nimport \"./CheckboxInput.css\";\n\nexport interface CheckboxInputProps {\n /**\n * Whether the checkbox is checked (controlled mode).\n */\n checked?: boolean;\n\n /**\n * Whether the checkbox is checked by default (uncontrolled mode).\n */\n defaultChecked?: boolean;\n\n /** The error attribute of the checkbox input. */\n error?: React.ReactNode | string;\n\n /** The description attribute of the checkbox input. */\n description?: React.ReactNode | string;\n\n /** The test id attribute of the checkbox input. */\n \"data-testid\"?: string;\n\n /**\n * Callback fired when the checkbox state changes.\n */\n onChange?: (checked: boolean) => void;\n\n /**\n * Whether the checkbox is in an indeterminate state. Used for checkboxes that are neither checked nor unchecked.\n * @external https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/indeterminate\n * @reference @external https://medium.com/indigoag-eng/indeterminate-checkboxes-are-weird-704b246c0f19\n */\n indeterminate?: boolean;\n\n /** The id attribute of the checkbox input. */\n id?: string;\n\n /** Whether the checkbox is disabled. */\n isDisabled?: boolean;\n\n /** Whether the checkbox is required. */\n isRequired?: boolean;\n\n /** The name attribute of the checkbox input. */\n name: string;\n\n /** The label attribute of the checkbox input. */\n label?: string | React.ReactNode;\n\n /**\n * The value attribute of the checkbox input (for form submission).\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value\n */\n value?: string;\n}\n\n/**\n * A checkbox input component with support for labels, descriptions, error states, and controlled/uncontrolled modes.\n *\n * API:\n * - {@link CheckboxInputProps}\n * - extends {@link BaseInputProps}\n */\nexport const CheckboxInput = forwardRef<HTMLInputElement, CheckboxInputProps>(\n (\n {\n checked: controlledChecked,\n defaultChecked,\n onChange,\n name,\n value,\n isDisabled = false,\n isRequired = false,\n id,\n \"data-testid\": testId,\n label,\n description,\n error,\n indeterminate = false,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const checkboxRef = useRef<HTMLInputElement>(null);\n const [checked, setChecked] = useState(\n controlledChecked ?? defaultChecked ?? false\n );\n const ref = forwardedRef || checkboxRef;\n const isChecked = controlledChecked ?? checked;\n\n // indeterminate state can only be set via JS\n useEffect(() => {\n if (ref.current) {\n ref.current.indeterminate = indeterminate;\n }\n }, [indeterminate, ref]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newChecked = e.target.checked;\n setChecked(newChecked);\n onChange?.(newChecked);\n };\n\n const checkboxId = id || `${name}-checkbox`;\n\n return (\n <div>\n <div\n className={csx(\n \"proton-CheckboxInput\",\n isDisabled && \"proton-CheckboxInput--disabled\"\n )}\n >\n <div className=\"proton-CheckboxInput__container\">\n {typeof label === \"string\" ? (\n <label\n htmlFor={checkboxId}\n className=\"proton-CheckboxInput__label\"\n >\n {label}\n </label>\n ) : (\n label\n )}\n\n <input\n ref={ref}\n id={checkboxId}\n name={name}\n type=\"checkbox\"\n checked={isChecked}\n value={value}\n disabled={isDisabled}\n required={isRequired}\n onChange={handleChange}\n className={csx(\n \"proton-CheckboxInput__input\",\n error && \"proton-CheckboxInput__input--error\"\n )}\n aria-label={!label ? name : undefined}\n data-testid={testId}\n />\n\n {typeof description === \"string\" ? (\n <div\n id={`${name}-description`}\n className=\"proton-CheckboxInput__text\"\n aria-live=\"polite\"\n >\n {description}\n {isRequired && (\n <span\n aria-hidden=\"true\"\n className=\"proton-CheckboxInput__text\"\n >\n &nbsp;*\n </span>\n )}\n </div>\n ) : (\n description\n )}\n </div>\n </div>\n\n {typeof error === \"string\" ? (\n <div\n role=\"alert\"\n className={csx(\n \"proton-CheckboxInput__error\",\n \"proton-CheckboxInput__text\"\n )}\n id={`${name}-error`}\n >\n {error}\n </div>\n ) : (\n error\n )}\n </div>\n );\n }\n);\n\nCheckboxInput.displayName = \"ProtonUICheckboxInput\";\n"],"names":["CheckboxInput","forwardRef","controlledChecked","defaultChecked","onChange","name","value","isDisabled","isRequired","id","testId","label","description","error","indeterminate","forwardedRef","checkboxRef","useRef","checked","setChecked","useState","ref","isChecked","useEffect","handleChange","e","newChecked","checkboxId","jsx","csx","jsxs"],"mappings":"2PAqEaA,EAAgBC,EAAA,WAC3B,CACE,CACE,QAASC,EACT,eAAAC,EACA,SAAAC,EACA,KAAAC,EACA,MAAAC,EACA,WAAAC,EAAa,GACb,WAAAC,EAAa,GACb,GAAAC,EACA,cAAeC,EACf,MAAAC,EACA,YAAAC,EACA,MAAAC,EACA,cAAAC,EAAgB,IAElBC,IACG,CACG,MAAAC,EAAcC,SAAyB,IAAI,EAC3C,CAACC,EAASC,CAAU,EAAIC,EAAA,SAC5BlB,GAAqBC,GAAkB,EAAA,EAEnCkB,EAAMN,GAAgBC,EACtBM,EAAYpB,GAAqBgB,EAGvCK,EAAAA,UAAU,IAAM,CACVF,EAAI,UACNA,EAAI,QAAQ,cAAgBP,EAC9B,EACC,CAACA,EAAeO,CAAG,CAAC,EAEjB,MAAAG,EAAgBC,GAA2C,CACzD,MAAAC,EAAaD,EAAE,OAAO,QAC5BN,EAAWO,CAAU,EACrBtB,GAAA,MAAAA,EAAWsB,EAAU,EAGjBC,EAAalB,GAAM,GAAGJ,CAAI,YAEhC,gCACG,MACC,CAAA,SAAA,CAAAuB,EAAA,kBAAA,IAAC,MAAA,CACC,UAAWC,EAAA,IACT,uBACAtB,GAAc,gCAChB,EAEA,SAAAuB,EAAA,kBAAA,KAAC,MAAI,CAAA,UAAU,kCACZ,SAAA,CAAA,OAAOnB,GAAU,SAChBiB,EAAA,kBAAA,IAAC,QAAA,CACC,QAASD,EACT,UAAU,8BAET,SAAAhB,CAAA,CAAA,EAGHA,EAGFiB,EAAA,kBAAA,IAAC,QAAA,CACC,IAAAP,EACA,GAAIM,EACJ,KAAAtB,EACA,KAAK,WACL,QAASiB,EACT,MAAAhB,EACA,SAAUC,EACV,SAAUC,EACV,SAAUgB,EACV,UAAWK,EAAA,IACT,8BACAhB,GAAS,oCACX,EACA,aAAaF,EAAe,OAAPN,EACrB,cAAaK,CAAA,CACf,EAEC,OAAOE,GAAgB,SACtBkB,EAAA,kBAAA,KAAC,MAAA,CACC,GAAI,GAAGzB,CAAI,eACX,UAAU,6BACV,YAAU,SAET,SAAA,CAAAO,EACAJ,GACCoB,EAAA,kBAAA,IAAC,OAAA,CACC,cAAY,OACZ,UAAU,6BACX,SAAA,IAAA,CAED,CAAA,CAAA,CAAA,EAIJhB,CAAA,EAEJ,CAAA,CACF,EAEC,OAAOC,GAAU,SAChBe,EAAA,kBAAA,IAAC,MAAA,CACC,KAAK,QACL,UAAWC,EAAA,IACT,8BACA,4BACF,EACA,GAAI,GAAGxB,CAAI,SAEV,SAAAQ,CAAA,CAAA,EAGHA,CAEJ,CAAA,CAAA,CAEJ,CACF,EAEAb,EAAc,YAAc"}
1
+ {"version":3,"file":"CheckboxInput.cjs.js","sources":["../../../../src/components/Input/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef, useState } from \"react\";\n\nimport { csx } from \"../../../utils\";\nimport \"./CheckboxInput.css\";\n\nexport interface CheckboxInputProps {\n /**\n * Whether the checkbox is checked (controlled mode).\n */\n checked?: boolean;\n\n /**\n * Whether the checkbox is checked by default (uncontrolled mode).\n */\n defaultChecked?: boolean;\n\n /** The error attribute of the checkbox input. */\n error?: React.ReactNode | string;\n\n /** The description attribute of the checkbox input. */\n description?: React.ReactNode | string;\n\n /** The test id attribute of the checkbox input. */\n \"data-testid\"?: string;\n\n /**\n * Callback fired when the checkbox state changes.\n */\n onChange?: (checked: boolean) => void;\n\n /**\n * Whether the checkbox is in an indeterminate state. Used for checkboxes that are neither checked nor unchecked.\n * @external https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/indeterminate\n * @reference @external https://medium.com/indigoag-eng/indeterminate-checkboxes-are-weird-704b246c0f19\n */\n indeterminate?: boolean;\n\n /** The id attribute of the checkbox input. */\n id?: string;\n\n /** Whether the checkbox is disabled. */\n isDisabled?: boolean;\n\n /** Whether the checkbox is required. */\n isRequired?: boolean;\n\n /** The name attribute of the checkbox input. */\n name: string;\n\n /** The label attribute of the checkbox input. */\n label?: string | React.ReactNode;\n\n /**\n * The value attribute of the checkbox input (for form submission).\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value\n */\n value?: string;\n}\n\n/**\n * A checkbox input component with support for labels, descriptions, error states, and controlled/uncontrolled modes.\n *\n * API:\n * - {@link CheckboxInputProps}\n */\nexport const CheckboxInput = forwardRef<HTMLInputElement, CheckboxInputProps>(\n (\n {\n checked: controlledChecked,\n defaultChecked,\n onChange,\n name,\n value,\n isDisabled = false,\n isRequired = false,\n id,\n \"data-testid\": testId,\n label,\n description,\n error,\n indeterminate = false,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const checkboxRef = useRef<HTMLInputElement>(null);\n const [checked, setChecked] = useState(\n controlledChecked ?? defaultChecked ?? false\n );\n const ref = forwardedRef || checkboxRef;\n const isChecked = controlledChecked ?? checked;\n\n // indeterminate state can only be set via JS\n useEffect(() => {\n if (ref.current) {\n ref.current.indeterminate = indeterminate;\n }\n }, [indeterminate, ref]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newChecked = e.target.checked;\n setChecked(newChecked);\n onChange?.(newChecked);\n };\n\n const checkboxId = id || `${name}-checkbox`;\n const errorId = typeof error === \"string\" ? `${name}-error` : undefined;\n const descriptionId =\n typeof description === \"string\" ? `${name}-description` : undefined;\n\n return (\n <div>\n <div className={csx(isDisabled && \"proton-CheckboxInput--disabled\")}>\n <div className=\"proton-CheckboxInput__container\">\n {typeof label === \"string\" ? (\n <label\n htmlFor={checkboxId}\n className=\"proton-CheckboxInput__label\"\n >\n {label}\n </label>\n ) : (\n label\n )}\n\n <input\n ref={ref}\n id={checkboxId}\n name={name}\n type=\"checkbox\"\n checked={isChecked}\n value={value}\n disabled={isDisabled}\n required={isRequired}\n onChange={handleChange}\n className={csx(\n \"proton-CheckboxInput__input\",\n error && \"proton-CheckboxInput__input--error\"\n )}\n aria-label={!label ? name : undefined}\n aria-invalid={Boolean(error)}\n aria-errormessage={errorId}\n aria-describedby={\n [errorId, descriptionId].filter(Boolean).join(\" \") || undefined\n }\n data-testid={testId}\n />\n\n {typeof description === \"string\" ? (\n <div id={descriptionId} aria-live=\"polite\">\n {description}\n {isRequired && <span aria-hidden=\"true\">&nbsp;*</span>}\n </div>\n ) : (\n description\n )}\n </div>\n </div>\n\n {typeof error === \"string\" ? (\n <div\n role=\"alert\"\n className={csx(\"proton-CheckboxInput__error\")}\n id={errorId}\n >\n {error}\n </div>\n ) : (\n error\n )}\n </div>\n );\n }\n);\n\nCheckboxInput.displayName = \"ProtonUICheckboxInput\";\n"],"names":["CheckboxInput","forwardRef","controlledChecked","defaultChecked","onChange","name","value","isDisabled","isRequired","id","testId","label","description","error","indeterminate","forwardedRef","checkboxRef","useRef","checked","setChecked","useState","ref","isChecked","useEffect","handleChange","e","newChecked","checkboxId","errorId","descriptionId","jsx","csx","jsxs"],"mappings":"2PAmEaA,EAAgBC,EAAA,WAC3B,CACE,CACE,QAASC,EACT,eAAAC,EACA,SAAAC,EACA,KAAAC,EACA,MAAAC,EACA,WAAAC,EAAa,GACb,WAAAC,EAAa,GACb,GAAAC,EACA,cAAeC,EACf,MAAAC,EACA,YAAAC,EACA,MAAAC,EACA,cAAAC,EAAgB,IAElBC,IACG,CACG,MAAAC,EAAcC,SAAyB,IAAI,EAC3C,CAACC,EAASC,CAAU,EAAIC,EAAA,SAC5BlB,GAAqBC,GAAkB,EAAA,EAEnCkB,EAAMN,GAAgBC,EACtBM,EAAYpB,GAAqBgB,EAGvCK,EAAAA,UAAU,IAAM,CACVF,EAAI,UACNA,EAAI,QAAQ,cAAgBP,EAC9B,EACC,CAACA,EAAeO,CAAG,CAAC,EAEjB,MAAAG,EAAgBC,GAA2C,CACzD,MAAAC,EAAaD,EAAE,OAAO,QAC5BN,EAAWO,CAAU,EACrBtB,GAAA,MAAAA,EAAWsB,EAAU,EAGjBC,EAAalB,GAAM,GAAGJ,CAAI,YAC1BuB,EAAU,OAAOf,GAAU,SAAW,GAAGR,CAAI,SAAW,OACxDwB,EACJ,OAAOjB,GAAgB,SAAW,GAAGP,CAAI,eAAiB,OAE5D,gCACG,MACC,CAAA,SAAA,CAACyB,EAAAA,kBAAAA,IAAA,MAAA,CAAI,UAAWC,EAAI,IAAAxB,GAAc,gCAAgC,EAChE,SAAAyB,EAAA,kBAAA,KAAC,MAAI,CAAA,UAAU,kCACZ,SAAA,CAAA,OAAOrB,GAAU,SAChBmB,EAAA,kBAAA,IAAC,QAAA,CACC,QAASH,EACT,UAAU,8BAET,SAAAhB,CAAA,CAAA,EAGHA,EAGFmB,EAAA,kBAAA,IAAC,QAAA,CACC,IAAAT,EACA,GAAIM,EACJ,KAAAtB,EACA,KAAK,WACL,QAASiB,EACT,MAAAhB,EACA,SAAUC,EACV,SAAUC,EACV,SAAUgB,EACV,UAAWO,EAAA,IACT,8BACAlB,GAAS,oCACX,EACA,aAAaF,EAAe,OAAPN,EACrB,eAAc,EAAQQ,EACtB,oBAAmBe,EACnB,mBACE,CAACA,EAASC,CAAa,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,GAAK,OAExD,cAAanB,CAAA,CACf,EAEC,OAAOE,GAAgB,SACtBoB,EAAAA,kBAAAA,KAAC,OAAI,GAAIH,EAAe,YAAU,SAC/B,SAAA,CAAAjB,EACAJ,GAAcsB,EAAA,kBAAA,IAAC,OAAK,CAAA,cAAY,OAAO,SAAO,KAAA,CAAA,CAAA,CACjD,EAEAlB,CAAA,CAAA,CAEJ,CACF,CAAA,EAEC,OAAOC,GAAU,SAChBiB,EAAA,kBAAA,IAAC,MAAA,CACC,KAAK,QACL,UAAWC,MAAI,6BAA6B,EAC5C,GAAIH,EAEH,SAAAf,CAAA,CAAA,EAGHA,CAEJ,CAAA,CAAA,CAEJ,CACF,EAEAb,EAAc,YAAc"}
@@ -1,109 +1,85 @@
1
1
  import { j as e } from "../../../node_modules/react/jsx-runtime.es.js";
2
- import { forwardRef as y, useRef as R, useState as $, useEffect as g } from "react";
2
+ import { forwardRef as R, useRef as $, useState as w, useEffect as B } from "react";
3
3
  /* empty css */
4
- import { csx as p } from "../../../utils/string.es.js";
5
- const w = y(
4
+ import { csx as d } from "../../../utils/string.es.js";
5
+ const E = R(
6
6
  ({
7
- checked: i,
8
- defaultChecked: u,
9
- onChange: r,
10
- name: t,
11
- value: k,
12
- isDisabled: a = !1,
13
- isRequired: d = !1,
14
- id: f,
15
- "data-testid": b,
16
- label: o,
17
- description: n,
18
- error: c,
19
- indeterminate: x = !1
20
- }, _) => {
21
- const I = R(null), [m, C] = $(
22
- i ?? u ?? !1
23
- ), s = _ || I, j = i ?? m;
24
- g(() => {
25
- s.current && (s.current.indeterminate = x);
26
- }, [x, s]);
27
- const N = (v) => {
28
- const l = v.target.checked;
29
- C(l), r == null || r(l);
30
- }, h = f || `${t}-checkbox`;
7
+ checked: a,
8
+ defaultChecked: k,
9
+ onChange: i,
10
+ name: o,
11
+ value: b,
12
+ isDisabled: p = !1,
13
+ isRequired: l = !1,
14
+ id: m,
15
+ "data-testid": I,
16
+ label: s,
17
+ description: c,
18
+ error: t,
19
+ indeterminate: h = !1
20
+ }, j) => {
21
+ const v = $(null), [_, y] = w(
22
+ a ?? k ?? !1
23
+ ), r = j || v, C = a ?? _;
24
+ B(() => {
25
+ r.current && (r.current.indeterminate = h);
26
+ }, [h, r]);
27
+ const N = (g) => {
28
+ const u = g.target.checked;
29
+ y(u), i == null || i(u);
30
+ }, x = m || `${o}-checkbox`, n = typeof t == "string" ? `${o}-error` : void 0, f = typeof c == "string" ? `${o}-description` : void 0;
31
31
  return /* @__PURE__ */ e.jsxs("div", { children: [
32
- /* @__PURE__ */ e.jsx(
33
- "div",
34
- {
35
- className: p(
36
- "proton-CheckboxInput",
37
- a && "proton-CheckboxInput--disabled"
38
- ),
39
- children: /* @__PURE__ */ e.jsxs("div", { className: "proton-CheckboxInput__container", children: [
40
- typeof o == "string" ? /* @__PURE__ */ e.jsx(
41
- "label",
42
- {
43
- htmlFor: h,
44
- className: "proton-CheckboxInput__label",
45
- children: o
46
- }
47
- ) : o,
48
- /* @__PURE__ */ e.jsx(
49
- "input",
50
- {
51
- ref: s,
52
- id: h,
53
- name: t,
54
- type: "checkbox",
55
- checked: j,
56
- value: k,
57
- disabled: a,
58
- required: d,
59
- onChange: N,
60
- className: p(
61
- "proton-CheckboxInput__input",
62
- c && "proton-CheckboxInput__input--error"
63
- ),
64
- "aria-label": o ? void 0 : t,
65
- "data-testid": b
66
- }
32
+ /* @__PURE__ */ e.jsx("div", { className: d(p && "proton-CheckboxInput--disabled"), children: /* @__PURE__ */ e.jsxs("div", { className: "proton-CheckboxInput__container", children: [
33
+ typeof s == "string" ? /* @__PURE__ */ e.jsx(
34
+ "label",
35
+ {
36
+ htmlFor: x,
37
+ className: "proton-CheckboxInput__label",
38
+ children: s
39
+ }
40
+ ) : s,
41
+ /* @__PURE__ */ e.jsx(
42
+ "input",
43
+ {
44
+ ref: r,
45
+ id: x,
46
+ name: o,
47
+ type: "checkbox",
48
+ checked: C,
49
+ value: b,
50
+ disabled: p,
51
+ required: l,
52
+ onChange: N,
53
+ className: d(
54
+ "proton-CheckboxInput__input",
55
+ t && "proton-CheckboxInput__input--error"
67
56
  ),
68
- typeof n == "string" ? /* @__PURE__ */ e.jsxs(
69
- "div",
70
- {
71
- id: `${t}-description`,
72
- className: "proton-CheckboxInput__text",
73
- "aria-live": "polite",
74
- children: [
75
- n,
76
- d && /* @__PURE__ */ e.jsx(
77
- "span",
78
- {
79
- "aria-hidden": "true",
80
- className: "proton-CheckboxInput__text",
81
- children: " *"
82
- }
83
- )
84
- ]
85
- }
86
- ) : n
87
- ] })
88
- }
89
- ),
90
- typeof c == "string" ? /* @__PURE__ */ e.jsx(
57
+ "aria-label": s ? void 0 : o,
58
+ "aria-invalid": !!t,
59
+ "aria-errormessage": n,
60
+ "aria-describedby": [n, f].filter(Boolean).join(" ") || void 0,
61
+ "data-testid": I
62
+ }
63
+ ),
64
+ typeof c == "string" ? /* @__PURE__ */ e.jsxs("div", { id: f, "aria-live": "polite", children: [
65
+ c,
66
+ l && /* @__PURE__ */ e.jsx("span", { "aria-hidden": "true", children: " *" })
67
+ ] }) : c
68
+ ] }) }),
69
+ typeof t == "string" ? /* @__PURE__ */ e.jsx(
91
70
  "div",
92
71
  {
93
72
  role: "alert",
94
- className: p(
95
- "proton-CheckboxInput__error",
96
- "proton-CheckboxInput__text"
97
- ),
98
- id: `${t}-error`,
99
- children: c
73
+ className: d("proton-CheckboxInput__error"),
74
+ id: n,
75
+ children: t
100
76
  }
101
- ) : c
77
+ ) : t
102
78
  ] });
103
79
  }
104
80
  );
105
- w.displayName = "ProtonUICheckboxInput";
81
+ E.displayName = "ProtonUICheckboxInput";
106
82
  export {
107
- w as CheckboxInput
83
+ E as CheckboxInput
108
84
  };
109
85
  //# sourceMappingURL=CheckboxInput.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"CheckboxInput.es.js","sources":["../../../../src/components/Input/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef, useState } from \"react\";\n\nimport { type BaseInputProps } from \"../BaseInput/Input\";\nimport { csx } from \"../../../utils\";\nimport \"./CheckboxInput.css\";\n\nexport interface CheckboxInputProps {\n /**\n * Whether the checkbox is checked (controlled mode).\n */\n checked?: boolean;\n\n /**\n * Whether the checkbox is checked by default (uncontrolled mode).\n */\n defaultChecked?: boolean;\n\n /** The error attribute of the checkbox input. */\n error?: React.ReactNode | string;\n\n /** The description attribute of the checkbox input. */\n description?: React.ReactNode | string;\n\n /** The test id attribute of the checkbox input. */\n \"data-testid\"?: string;\n\n /**\n * Callback fired when the checkbox state changes.\n */\n onChange?: (checked: boolean) => void;\n\n /**\n * Whether the checkbox is in an indeterminate state. Used for checkboxes that are neither checked nor unchecked.\n * @external https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/indeterminate\n * @reference @external https://medium.com/indigoag-eng/indeterminate-checkboxes-are-weird-704b246c0f19\n */\n indeterminate?: boolean;\n\n /** The id attribute of the checkbox input. */\n id?: string;\n\n /** Whether the checkbox is disabled. */\n isDisabled?: boolean;\n\n /** Whether the checkbox is required. */\n isRequired?: boolean;\n\n /** The name attribute of the checkbox input. */\n name: string;\n\n /** The label attribute of the checkbox input. */\n label?: string | React.ReactNode;\n\n /**\n * The value attribute of the checkbox input (for form submission).\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value\n */\n value?: string;\n}\n\n/**\n * A checkbox input component with support for labels, descriptions, error states, and controlled/uncontrolled modes.\n *\n * API:\n * - {@link CheckboxInputProps}\n * - extends {@link BaseInputProps}\n */\nexport const CheckboxInput = forwardRef<HTMLInputElement, CheckboxInputProps>(\n (\n {\n checked: controlledChecked,\n defaultChecked,\n onChange,\n name,\n value,\n isDisabled = false,\n isRequired = false,\n id,\n \"data-testid\": testId,\n label,\n description,\n error,\n indeterminate = false,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const checkboxRef = useRef<HTMLInputElement>(null);\n const [checked, setChecked] = useState(\n controlledChecked ?? defaultChecked ?? false\n );\n const ref = forwardedRef || checkboxRef;\n const isChecked = controlledChecked ?? checked;\n\n // indeterminate state can only be set via JS\n useEffect(() => {\n if (ref.current) {\n ref.current.indeterminate = indeterminate;\n }\n }, [indeterminate, ref]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newChecked = e.target.checked;\n setChecked(newChecked);\n onChange?.(newChecked);\n };\n\n const checkboxId = id || `${name}-checkbox`;\n\n return (\n <div>\n <div\n className={csx(\n \"proton-CheckboxInput\",\n isDisabled && \"proton-CheckboxInput--disabled\"\n )}\n >\n <div className=\"proton-CheckboxInput__container\">\n {typeof label === \"string\" ? (\n <label\n htmlFor={checkboxId}\n className=\"proton-CheckboxInput__label\"\n >\n {label}\n </label>\n ) : (\n label\n )}\n\n <input\n ref={ref}\n id={checkboxId}\n name={name}\n type=\"checkbox\"\n checked={isChecked}\n value={value}\n disabled={isDisabled}\n required={isRequired}\n onChange={handleChange}\n className={csx(\n \"proton-CheckboxInput__input\",\n error && \"proton-CheckboxInput__input--error\"\n )}\n aria-label={!label ? name : undefined}\n data-testid={testId}\n />\n\n {typeof description === \"string\" ? (\n <div\n id={`${name}-description`}\n className=\"proton-CheckboxInput__text\"\n aria-live=\"polite\"\n >\n {description}\n {isRequired && (\n <span\n aria-hidden=\"true\"\n className=\"proton-CheckboxInput__text\"\n >\n &nbsp;*\n </span>\n )}\n </div>\n ) : (\n description\n )}\n </div>\n </div>\n\n {typeof error === \"string\" ? (\n <div\n role=\"alert\"\n className={csx(\n \"proton-CheckboxInput__error\",\n \"proton-CheckboxInput__text\"\n )}\n id={`${name}-error`}\n >\n {error}\n </div>\n ) : (\n error\n )}\n </div>\n );\n }\n);\n\nCheckboxInput.displayName = \"ProtonUICheckboxInput\";\n"],"names":["CheckboxInput","forwardRef","controlledChecked","defaultChecked","onChange","name","value","isDisabled","isRequired","id","testId","label","description","error","indeterminate","forwardedRef","checkboxRef","useRef","checked","setChecked","useState","ref","isChecked","useEffect","handleChange","e","newChecked","checkboxId","jsx","csx","jsxs"],"mappings":";;;;AAqEO,MAAMA,IAAgBC;AAAA,EAC3B,CACE;AAAA,IACE,SAASC;AAAA,IACT,gBAAAC;AAAA,IACA,UAAAC;AAAA,IACA,MAAAC;AAAA,IACA,OAAAC;AAAA,IACA,YAAAC,IAAa;AAAA,IACb,YAAAC,IAAa;AAAA,IACb,IAAAC;AAAA,IACA,eAAeC;AAAA,IACf,OAAAC;AAAA,IACA,aAAAC;AAAA,IACA,OAAAC;AAAA,IACA,eAAAC,IAAgB;AAAA,KAElBC,MACG;AACG,UAAAC,IAAcC,EAAyB,IAAI,GAC3C,CAACC,GAASC,CAAU,IAAIC;AAAA,MAC5BlB,KAAqBC,KAAkB;AAAA,IAAA,GAEnCkB,IAAMN,KAAgBC,GACtBM,IAAYpB,KAAqBgB;AAGvC,IAAAK,EAAU,MAAM;AACd,MAAIF,EAAI,YACNA,EAAI,QAAQ,gBAAgBP;AAAA,IAC9B,GACC,CAACA,GAAeO,CAAG,CAAC;AAEjB,UAAAG,IAAe,CAACC,MAA2C;AACzD,YAAAC,IAAaD,EAAE,OAAO;AAC5B,MAAAN,EAAWO,CAAU,GACrBtB,KAAA,QAAAA,EAAWsB;AAAA,IAAU,GAGjBC,IAAalB,KAAM,GAAGJ,CAAI;AAEhC,kCACG,OACC,EAAA,UAAA;AAAA,MAAAuB,gBAAAA,EAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWC;AAAA,YACT;AAAA,YACAtB,KAAc;AAAA,UAChB;AAAA,UAEA,UAAAuB,gBAAAA,EAAA,KAAC,OAAI,EAAA,WAAU,mCACZ,UAAA;AAAA,YAAA,OAAOnB,KAAU,WAChBiB,gBAAAA,EAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,SAASD;AAAA,gBACT,WAAU;AAAA,gBAET,UAAAhB;AAAA,cAAA;AAAA,YAAA,IAGHA;AAAA,YAGFiB,gBAAAA,EAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,KAAAP;AAAA,gBACA,IAAIM;AAAA,gBACJ,MAAAtB;AAAA,gBACA,MAAK;AAAA,gBACL,SAASiB;AAAA,gBACT,OAAAhB;AAAA,gBACA,UAAUC;AAAA,gBACV,UAAUC;AAAA,gBACV,UAAUgB;AAAA,gBACV,WAAWK;AAAA,kBACT;AAAA,kBACAhB,KAAS;AAAA,gBACX;AAAA,gBACA,cAAaF,IAAe,SAAPN;AAAA,gBACrB,eAAaK;AAAA,cAAA;AAAA,YACf;AAAA,YAEC,OAAOE,KAAgB,WACtBkB,gBAAAA,EAAA;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,IAAI,GAAGzB,CAAI;AAAA,gBACX,WAAU;AAAA,gBACV,aAAU;AAAA,gBAET,UAAA;AAAA,kBAAAO;AAAA,kBACAJ,KACCoB,gBAAAA,EAAA;AAAA,oBAAC;AAAA,oBAAA;AAAA,sBACC,eAAY;AAAA,sBACZ,WAAU;AAAA,sBACX,UAAA;AAAA,oBAAA;AAAA,kBAED;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA,IAIJhB;AAAA,UAAA,GAEJ;AAAA,QAAA;AAAA,MACF;AAAA,MAEC,OAAOC,KAAU,WAChBe,gBAAAA,EAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,WAAWC;AAAA,YACT;AAAA,YACA;AAAA,UACF;AAAA,UACA,IAAI,GAAGxB,CAAI;AAAA,UAEV,UAAAQ;AAAA,QAAA;AAAA,MAAA,IAGHA;AAAA,IAEJ,EAAA,CAAA;AAAA,EAEJ;AACF;AAEAb,EAAc,cAAc;"}
1
+ {"version":3,"file":"CheckboxInput.es.js","sources":["../../../../src/components/Input/CheckboxInput/CheckboxInput.tsx"],"sourcesContent":["\"use client\";\n\nimport React, { forwardRef, useEffect, useRef, useState } from \"react\";\n\nimport { csx } from \"../../../utils\";\nimport \"./CheckboxInput.css\";\n\nexport interface CheckboxInputProps {\n /**\n * Whether the checkbox is checked (controlled mode).\n */\n checked?: boolean;\n\n /**\n * Whether the checkbox is checked by default (uncontrolled mode).\n */\n defaultChecked?: boolean;\n\n /** The error attribute of the checkbox input. */\n error?: React.ReactNode | string;\n\n /** The description attribute of the checkbox input. */\n description?: React.ReactNode | string;\n\n /** The test id attribute of the checkbox input. */\n \"data-testid\"?: string;\n\n /**\n * Callback fired when the checkbox state changes.\n */\n onChange?: (checked: boolean) => void;\n\n /**\n * Whether the checkbox is in an indeterminate state. Used for checkboxes that are neither checked nor unchecked.\n * @external https://developer.mozilla.org/en-US/docs/Web/API/HTMLInputElement/indeterminate\n * @reference @external https://medium.com/indigoag-eng/indeterminate-checkboxes-are-weird-704b246c0f19\n */\n indeterminate?: boolean;\n\n /** The id attribute of the checkbox input. */\n id?: string;\n\n /** Whether the checkbox is disabled. */\n isDisabled?: boolean;\n\n /** Whether the checkbox is required. */\n isRequired?: boolean;\n\n /** The name attribute of the checkbox input. */\n name: string;\n\n /** The label attribute of the checkbox input. */\n label?: string | React.ReactNode;\n\n /**\n * The value attribute of the checkbox input (for form submission).\n * @external https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#value\n */\n value?: string;\n}\n\n/**\n * A checkbox input component with support for labels, descriptions, error states, and controlled/uncontrolled modes.\n *\n * API:\n * - {@link CheckboxInputProps}\n */\nexport const CheckboxInput = forwardRef<HTMLInputElement, CheckboxInputProps>(\n (\n {\n checked: controlledChecked,\n defaultChecked,\n onChange,\n name,\n value,\n isDisabled = false,\n isRequired = false,\n id,\n \"data-testid\": testId,\n label,\n description,\n error,\n indeterminate = false,\n },\n forwardedRef: React.RefObject<HTMLInputElement>\n ) => {\n const checkboxRef = useRef<HTMLInputElement>(null);\n const [checked, setChecked] = useState(\n controlledChecked ?? defaultChecked ?? false\n );\n const ref = forwardedRef || checkboxRef;\n const isChecked = controlledChecked ?? checked;\n\n // indeterminate state can only be set via JS\n useEffect(() => {\n if (ref.current) {\n ref.current.indeterminate = indeterminate;\n }\n }, [indeterminate, ref]);\n\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const newChecked = e.target.checked;\n setChecked(newChecked);\n onChange?.(newChecked);\n };\n\n const checkboxId = id || `${name}-checkbox`;\n const errorId = typeof error === \"string\" ? `${name}-error` : undefined;\n const descriptionId =\n typeof description === \"string\" ? `${name}-description` : undefined;\n\n return (\n <div>\n <div className={csx(isDisabled && \"proton-CheckboxInput--disabled\")}>\n <div className=\"proton-CheckboxInput__container\">\n {typeof label === \"string\" ? (\n <label\n htmlFor={checkboxId}\n className=\"proton-CheckboxInput__label\"\n >\n {label}\n </label>\n ) : (\n label\n )}\n\n <input\n ref={ref}\n id={checkboxId}\n name={name}\n type=\"checkbox\"\n checked={isChecked}\n value={value}\n disabled={isDisabled}\n required={isRequired}\n onChange={handleChange}\n className={csx(\n \"proton-CheckboxInput__input\",\n error && \"proton-CheckboxInput__input--error\"\n )}\n aria-label={!label ? name : undefined}\n aria-invalid={Boolean(error)}\n aria-errormessage={errorId}\n aria-describedby={\n [errorId, descriptionId].filter(Boolean).join(\" \") || undefined\n }\n data-testid={testId}\n />\n\n {typeof description === \"string\" ? (\n <div id={descriptionId} aria-live=\"polite\">\n {description}\n {isRequired && <span aria-hidden=\"true\">&nbsp;*</span>}\n </div>\n ) : (\n description\n )}\n </div>\n </div>\n\n {typeof error === \"string\" ? (\n <div\n role=\"alert\"\n className={csx(\"proton-CheckboxInput__error\")}\n id={errorId}\n >\n {error}\n </div>\n ) : (\n error\n )}\n </div>\n );\n }\n);\n\nCheckboxInput.displayName = \"ProtonUICheckboxInput\";\n"],"names":["CheckboxInput","forwardRef","controlledChecked","defaultChecked","onChange","name","value","isDisabled","isRequired","id","testId","label","description","error","indeterminate","forwardedRef","checkboxRef","useRef","checked","setChecked","useState","ref","isChecked","useEffect","handleChange","e","newChecked","checkboxId","errorId","descriptionId","jsx","csx","jsxs"],"mappings":";;;;AAmEO,MAAMA,IAAgBC;AAAA,EAC3B,CACE;AAAA,IACE,SAASC;AAAA,IACT,gBAAAC;AAAA,IACA,UAAAC;AAAA,IACA,MAAAC;AAAA,IACA,OAAAC;AAAA,IACA,YAAAC,IAAa;AAAA,IACb,YAAAC,IAAa;AAAA,IACb,IAAAC;AAAA,IACA,eAAeC;AAAA,IACf,OAAAC;AAAA,IACA,aAAAC;AAAA,IACA,OAAAC;AAAA,IACA,eAAAC,IAAgB;AAAA,KAElBC,MACG;AACG,UAAAC,IAAcC,EAAyB,IAAI,GAC3C,CAACC,GAASC,CAAU,IAAIC;AAAA,MAC5BlB,KAAqBC,KAAkB;AAAA,IAAA,GAEnCkB,IAAMN,KAAgBC,GACtBM,IAAYpB,KAAqBgB;AAGvC,IAAAK,EAAU,MAAM;AACd,MAAIF,EAAI,YACNA,EAAI,QAAQ,gBAAgBP;AAAA,IAC9B,GACC,CAACA,GAAeO,CAAG,CAAC;AAEjB,UAAAG,IAAe,CAACC,MAA2C;AACzD,YAAAC,IAAaD,EAAE,OAAO;AAC5B,MAAAN,EAAWO,CAAU,GACrBtB,KAAA,QAAAA,EAAWsB;AAAA,IAAU,GAGjBC,IAAalB,KAAM,GAAGJ,CAAI,aAC1BuB,IAAU,OAAOf,KAAU,WAAW,GAAGR,CAAI,WAAW,QACxDwB,IACJ,OAAOjB,KAAgB,WAAW,GAAGP,CAAI,iBAAiB;AAE5D,kCACG,OACC,EAAA,UAAA;AAAA,MAACyB,gBAAAA,EAAAA,IAAA,OAAA,EAAI,WAAWC,EAAIxB,KAAc,gCAAgC,GAChE,UAAAyB,gBAAAA,EAAA,KAAC,OAAI,EAAA,WAAU,mCACZ,UAAA;AAAA,QAAA,OAAOrB,KAAU,WAChBmB,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,SAASH;AAAA,YACT,WAAU;AAAA,YAET,UAAAhB;AAAA,UAAA;AAAA,QAAA,IAGHA;AAAA,QAGFmB,gBAAAA,EAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,KAAAT;AAAA,YACA,IAAIM;AAAA,YACJ,MAAAtB;AAAA,YACA,MAAK;AAAA,YACL,SAASiB;AAAA,YACT,OAAAhB;AAAA,YACA,UAAUC;AAAA,YACV,UAAUC;AAAA,YACV,UAAUgB;AAAA,YACV,WAAWO;AAAA,cACT;AAAA,cACAlB,KAAS;AAAA,YACX;AAAA,YACA,cAAaF,IAAe,SAAPN;AAAA,YACrB,gBAAc,EAAQQ;AAAA,YACtB,qBAAmBe;AAAA,YACnB,oBACE,CAACA,GAASC,CAAa,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,KAAK;AAAA,YAExD,eAAanB;AAAA,UAAA;AAAA,QACf;AAAA,QAEC,OAAOE,KAAgB,WACtBoB,gBAAAA,EAAAA,KAAC,SAAI,IAAIH,GAAe,aAAU,UAC/B,UAAA;AAAA,UAAAjB;AAAA,UACAJ,KAAcsB,gBAAAA,EAAA,IAAC,QAAK,EAAA,eAAY,QAAO,UAAO,MAAA;AAAA,QAAA,EAAA,CACjD,IAEAlB;AAAA,MAAA,EAAA,CAEJ,EACF,CAAA;AAAA,MAEC,OAAOC,KAAU,WAChBiB,gBAAAA,EAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,WAAWC,EAAI,6BAA6B;AAAA,UAC5C,IAAIH;AAAA,UAEH,UAAAf;AAAA,QAAA;AAAA,MAAA,IAGHA;AAAA,IAEJ,EAAA,CAAA;AAAA,EAEJ;AACF;AAEAb,EAAc,cAAc;"}
package/dist/index.d.ts CHANGED
@@ -450,7 +450,6 @@ declare interface ButtonWithSelectProps extends ButtonProps {
450
450
  *
451
451
  * API:
452
452
  * - {@link CheckboxInputProps}
453
- * - extends {@link BaseInputProps}
454
453
  */
455
454
  export declare const CheckboxInput: default_2.ForwardRefExoticComponent<CheckboxInputProps & default_2.RefAttributes<HTMLInputElement>>;
456
455
 
package/dist/style.css CHANGED
@@ -1 +1 @@
1
- .proton-Button{--proton-button-edge-padding:1.05em;--proton-button__background-color:var(--proton-color__primary);--proton-button__text-color:var(--proton-color__white);color:var(--proton-button__text-color);border-radius:var(--proton-control__border-radius);padding:.45em var(--proton-button-edge-padding);letter-spacing:.05em;cursor:pointer;box-sizing:border-box;background-color:var(--proton-button__background-color);border:0;align-items:center;transition:filter .2s,background-color .2s,outline .2s;display:inline-flex;position:relative}.proton-Button__icon-decorator{justify-content:center;align-items:center;padding-right:.3em;line-height:1;display:flex;position:relative}.proton-Button__icon-decorator--fullWidth{position:absolute}.proton-Button__text{box-sizing:border-box;text-align:center;white-space:nowrap;text-overflow:ellipsis;margin:auto;line-height:normal;overflow:hidden}.proton-Button:hover{filter:brightness(1.16);cursor:pointer}.proton-Button--primary{--proton-button__background-color:var(--proton-color__primary);--proton-button__text-color:var(--proton-color__white)}.proton-Button--secondary{--proton-button__background-color:var(--proton-color__gray-light);--proton-button__text-color:var(--proton-control__text-color)}.proton-ui__theme--dark .proton-Button--secondary{--proton-button__background-color:var(--proton-control__background-color-light)}.proton-Button--danger{--proton-button__background-color:var(--proton-color__danger-medium)}.proton-Button--success{--proton-button__background-color:var(--proton-color__success-medium)}.proton-Button--translucent{--proton-button__background-color:var(--proton-control__background-color-light);--proton-button__text-color:var(--proton-control__text-color)}.proton-Button--disabled,.proton-Button--disabled:hover{opacity:.5;filter:none;cursor:not-allowed}.proton-Button:focus{outline:2px solid var(--proton-color__primary)}.proton-Button:focus-visible{outline:2px solid var(--proton-color__primary)}.proton-Button:active{filter:brightness(1.3);transition:filter .1s ease-out}.proton-Button--fullWidth{width:100%}.proton-Button--small{padding:.2rem .6rem;font-size:.875rem}.proton-Button--medium{padding:.4rem 1rem;font-size:1rem}.proton-Button--large{padding:.6rem 1.6rem;font-size:1.2rem}.proton-Button--xlarge{padding:1rem 2rem .8rem;font-size:1.3rem}.proton-Button--2xlarge{padding:1rem 2.6rem;font-size:1.6rem}.proton-Button--fullWidth .proton-Button__text{transform:translate(calc(var(--proton-button-text-shift)))}.proton-ScreenOverlay__background{-webkit-backdrop-filter:blur(24px)brightness(75%);backdrop-filter:blur(24px)brightness(75%);background-color:#000c;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.proton-ScreenOverlay__z-index{z-index:10000}.proton-ScreenOverlay__image{object-fit:cover;width:100vw;height:100vh;position:absolute}.proton-ScreenOverlay__blur{-webkit-backdrop-filter:blur(24px)brightness(75%);backdrop-filter:blur(24px)brightness(75%);filter:brightness(46%);position:absolute;top:0;bottom:0;left:0;right:0}@keyframes fadeInBackground{0%{-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0000001a}to{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c}}@keyframes fadeOutBackground{0%{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c}to{-webkit-backdrop-filter:blur();backdrop-filter:blur();background:0 0}}.proton-ScreenOverlay__fade-in{animation:.2s ease-in-out forwards fadeInBackground}.proton-ScreenOverlay__fade-out{animation:.2s ease-in-out forwards fadeOutBackground}.proton-ActionMenu__wrapper{z-index:10;width:100%;max-height:100vh;position:fixed;bottom:0;left:0}.proton-ActionMenu__background-wrapper{opacity:0;transition:opacity .3s cubic-bezier(.34,1.56,.64,1);overflow-y:scroll}.proton-ActionMenu__card{background:var(--proton-control__background-color);color:var(--proton-control__text-color);z-index:1;border-radius:.875rem .875rem 0 0;flex-direction:column;height:0;transition:height .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden;box-shadow:0 0 4px #0000001a,0 0 20px #00000026}.proton-ActionMenu__cancel-button{margin:0 .75rem 1rem}.proton-ActionMenu__content{padding:.75rem .75rem 0}.proton-ActionMenu__menu>[data-radix-popper-content-wrapper]{width:100%!important;position:absolute!important;top:0!important;transform:none!important}.proton-ActionMenu__list{flex-direction:column;margin-bottom:.625rem;display:flex}.proton-ActionMenu__item{color:inherit;cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem .5rem .75rem .75rem;transition:filter .2s,background-color .2s,color .2s;display:flex}.proton-ActionMenu__item:hover,.proton-ActionMenu__item:focus{background-color:var(--proton-control__hover-color);border:none;outline:none}.proton-ActionMenu__item[aria-checked=true]:hover,.proton-ActionMenu__item[aria-checked=true]:focus{filter:brightness(1.15)}.proton-ActionMenu__item[aria-checked=true]{background-color:var(--proton-control__interactive-color);color:var(--proton-color__primary)}.proton-ui__theme--dark .proton-ActionMenu__item[aria-checked=true]{background-color:var(--proton-color__primary);color:var(--proton-control__text-color)}.proton-ActionMenu__item[aria-disabled=true],.proton-ActionMenu__list[aria-disabled=true],.proton-ActionMenu__item[aria-disabled=true]:hover{opacity:.5;cursor:not-allowed;background-color:#0000}.proton-ActionMenu__list[aria-disabled=true] .proton-ActionMenu__item{pointer-events:none}.proton-ActionMenu__title{text-align:center;width:100%;font-weight:600}.proton-ActionMenu__back-button{cursor:pointer;z-index:1;align-items:center;width:25%;height:100%;padding-left:.35rem;display:flex;position:absolute;left:0}.proton-ActionMenu__back-button:hover,.proton-ActionMenu__cancel-button:focus{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__back-button:focus-visible{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__cancel-button:focus-visible{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__back-button-container{align-items:center;height:3rem;display:flex;position:relative}.proton-ActionMenu__description{color:var(--proton-control__text-color);opacity:.7;font-size:.875rem}.proton-ActionMenu__item-label{font-weight:500}.proton-ui__theme--dark .proton-ActionMenu__cancel-button button{--proton-button__background-color:var(--proton-control__background-color-light)}.proton-Badge{letter-spacing:.2em;text-align:center;text-transform:uppercase;white-space:nowrap;height:1.6rem;color:#666;background-color:#f2f2f2;border-radius:10rem;padding-left:1rem;padding-right:calc(1rem - .2em);font-size:1rem;font-weight:500;line-height:1.65rem;display:inline-block}.proton-ui__theme--dark .proton-Badge:not([class*=proton-Badge--]),.proton-ui__theme--dark .proton-Badge--secondary{background-color:var(--proton-control__background-color-light);color:var(--proton-control__text-color)}.proton-Badge--primary{background-color:var(--proton-color__primary);color:var(--proton-color__white)}.proton-Badge--success{background-color:var(--proton-color__success-super-light);color:var(--proton-color__success-dark)}.proton-Badge--warning{background-color:var(--proton-color__warning-super-light);color:var(--proton-color__warning-dark)}.proton-Badge--danger{background-color:var(--proton-color__danger-super-light);color:var(--proton-color__danger-dark)}.proton-Badge--transparent{color:#666;background-color:#0000}.proton-Banner{background-color:var(--banner-bg);-webkit-backdrop-filter:var(--banner-blur);backdrop-filter:var(--banner-blur);--tw-backdrop-blur:var(--banner-blur);--banner-bg:var(--proton-control__background-color-light);--banner-title:var(--proton-color__gray-dark);--banner-content:var(--proton-color__gray-medium);--banner-icon:var(--proton-color__gray-medium-light);--banner-blur:none;margin:0}:where(.proton-ui__theme--dark) .proton-Banner{--banner-bg:var(--proton-control__background-color-light);--banner-blur:blur(15px);--banner-title:var(--proton-control__text-color);--banner-content:var(--proton-control__text-color);--banner-icon:var(--proton-control__text-color)}.proton-Banner--warning{--banner-bg:var(--proton-color__warning-super-light);--banner-title:var(--proton-color__warning-dark);--banner-content:var(--proton-color__warning-medium);--banner-icon:var(--proton-color__warning-light)}.proton-Banner--success{--banner-bg:var(--proton-color__success-super-light);--banner-title:var(--proton-color__success-dark);--banner-content:var(--proton-color__success-medium);--banner-icon:var(--proton-color__success-light)}.proton-Banner--danger{--banner-bg:var(--proton-color__danger-super-light);--banner-title:var(--proton-color__danger-dark);--banner-content:var(--proton-color__danger-medium);--banner-icon:var(--proton-color__danger-light)}.proton-Banner--rounded{border-radius:.375rem}.proton-Banner__wrapper{align-items:flex-start;padding:2rem;display:flex}.proton-Banner__wrapper--compact{padding:1rem}.proton-Banner__content-wrapper{min-width:0;color:var(--banner-content);flex:1}.proton-Banner__container{padding:0 .625rem}.proton-Banner__title{letter-spacing:.01rem;color:var(--banner-title);line-height:1.2rem}.proton-Banner__content{color:var(--banner-content);margin:.375rem 0 0}.proton-Banner__icon{fill:var(--banner-icon);height:20px}.proton-Banner__actions{gap:.5rem;margin:.375rem 0 0;display:flex}@media (min-width:768px){.proton-Banner__container{grid-gap:.5rem;grid-template-columns:1fr auto;display:grid}.proton-Banner__title,.proton-Banner__content{grid-column:1;margin:auto 0}.proton-Banner__container:not(:has(.proton-Banner__content)){grid-gap:0px;grid-template-rows:1fr}.proton-Banner__container>div:last-child{grid-area:1/2/span 2;max-height:32px;margin:auto 0}.proton-Banner__actions{margin:0 0 0 .75rem}.proton-Banner__wrapper:not(:has(.proton-Banner__content)){align-items:center}}.proton-ButtonGroup{border:1px solid var(--proton-color__gray-light);border-radius:.25rem;font-weight:400;display:flex;overflow:hidden}.proton-ButtonGroup__option{background-color:var(--proton-color__gray-super-light);cursor:pointer;border-left:1px solid var(--proton-color__gray-light);color:var(--proton-color__gray-dark);text-align:center;border-radius:0;flex:1;padding:.5em 1em}.proton-ButtonGroup__option:first-child{border-left:0}.proton-ButtonGroup__option--selected{background-color:var(--proton-color__white);color:var(--proton-color__primary);z-index:2;cursor:default;border-radius:inherit;box-shadow:0 0 .375rem #00000026}.proton-ButtonGroup__option--selected+.proton-ButtonGroup__option{border-left:1px solid #0000}.proton-MenuTrigger__menu-header{text-transform:uppercase;color:var(--proton-control__text-color);background-color:var(--proton-control__background-color-light);letter-spacing:.1em;padding:.3125rem 1rem .25rem;font-size:.8em;font-weight:700}.proton-MenuTrigger__button{cursor:pointer;color:var(--proton-control__text-color);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s ease-in-out;display:flex}.proton-MenuTrigger__button:disabled{cursor:not-allowed;opacity:.5}.proton-ui__theme--dark .proton-MenuTrigger__button:disabled:hover,.proton-MenuTrigger__button:disabled:hover{background:0 0}.proton-MenuTrigger__button:focus{outline:2px solid var(--proton-color__primary)}.proton-MenuTrigger__button:hover{background-color:var(--proton-control__hover-color)}.proton-MenuTrigger__menu-item .proton-Menu__item,.proton-MenuTrigger__menu-item{color:var(--proton-control__text-color);grid-template:"label kbd""desc kbd"/1fr auto;align-items:center;gap:.1em .5em;padding:.75em 1em;display:grid}.proton-MenuTrigger__menu-item .proton-Menu__item[data-has-submenu=true],.proton-MenuTrigger__menu-item[data-has-submenu=true]{grid-template-columns:unset;grid-template-areas:unset;justify-content:space-between;align-items:center;display:flex}.proton-MenuTrigger__label{grid-area:label}.proton-MenuTrigger__description{opacity:.7;grid-area:desc;font-size:.8em;line-height:1.1}.proton-MenuTrigger__chevron{padding-left:.5rem}.proton-Menu{--menu-bg-color:var(--proton-control__background-color);--menu-item-bg-color:var(--proton-control__background-color);letter-spacing:.05em;border-radius:var(--proton-control__border-radius);background:var(--menu-bg-color);border:1px solid var(--proton-control__border-color);min-width:100px;max-height:420px;color:var(--proton-control__text-color);box-shadow:0 0 3px var(--proton-control__shadow-color);margin:8px 0 0;padding:0;list-style:none;overflow:auto}.proton-Menu__item{background:var(--menu-item-bg-color);cursor:pointer;outline:none;justify-content:space-between;align-items:center;padding:8px 24px 8px 16px;transition:background-color .2s,opacity .2s,color .2s;display:flex}.proton-Menu__item[aria-checked=true]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[aria-checked=true][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[aria-selected=true]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[aria-selected=true][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[data-state=checked]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[data-state=checked][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[data-highlighted=""]{--menu-item-bg-color:var(--proton-control__hover-color)}.proton-Menu__item:hover{--menu-item-bg-color:var(--proton-control__hover-color);box-shadow:none}.proton-Menu__item[aria-disabled=true],.proton-Menu__item[data-disabled=true]{opacity:.5;cursor:not-allowed}.proton-ButtonWithSelect{align-items:stretch;display:flex;position:relative}.proton-ButtonWithSelect button:focus{outline:none}.proton-ButtonWithSelect__button{flex:var(--flex);align-items:stretch;display:flex}.proton-ButtonWithSelect__button button,.proton-ButtonWithSelect__button a{border-top-right-radius:0;border-bottom-right-radius:0;align-items:center;display:flex;position:relative;overflow:hidden}.proton-ButtonWithSelect__button button:after,.proton-ButtonWithSelect__button a:after{content:"";background-color:#00000026;width:1px;position:absolute;top:.3em;bottom:.3em;right:0}.proton-ButtonWithSelect__trigger{flex:0 0 var(--trigger-width);min-width:var(--trigger-width);max-width:var(--trigger-width)}.proton-ButtonWithSelect__trigger .proton-Button{border-top-left-radius:0;border-bottom-left-radius:0;width:100%;height:100%;padding:0}.proton-ButtonWithSelect__trigger-content{flex-direction:column;align-items:center;display:flex}.proton-Table{border-collapse:collapse;color:var(--proton-control__text-color);width:100%;font-weight:300}.proton-Table__caption{display:none}.proton-Table__header{cursor:default;letter-spacing:.1em;text-transform:uppercase;text-align:left;outline:none;padding:.4375rem .625rem;font-size:1rem;font-weight:500;line-height:1rem}.proton-Table__header--center{text-align:center}.proton-Table__header--right{text-align:right}.proton-Table__headerSortIcon{padding:0 .125rem}.proton-Table__row{cursor:default;outline:none}.proton-Table__rowGroup--header{border-bottom:1px solid #ccc}.proton-Table__row--showLines{border-top:1px solid #ccc}.proton-Table--clickable{cursor:pointer}.proton-Table__cell{vertical-align:middle;outline:none;padding:.4375rem .625rem}.proton-Table__cell--center{text-align:center}.proton-Table__cell--right{text-align:right}.proton-Elevation{border-radius:var(--proton-control__border-radius);background-color:var(--proton-control__background-color-light);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);--tw-backdrop-blur:blur(15px);width:100%;height:100%;transition:background-color .2s ease-in-out,-webkit-backdrop-filter .2s ease-in-out,backdrop-filter .2s ease-in-out}@keyframes shimmer{0%{background-position:-300px 0}to{background-position:800px 0}}.proton-Tombstone{background-position:-300px 0;background-repeat:no-repeat;background-size:300px 100%;animation:1.5s linear infinite shimmer}.proton-ui__theme--light .proton-Tombstone{background-color:#d1d1d1;background-image:linear-gradient(-90deg,#d1d1d1,#b8b8b8,#d1d1d1)}.proton-ui__theme--dark .proton-Tombstone{background-color:#3c3c3c;background-image:linear-gradient(-90deg,#363636,#292727,#353535)}.proton-Tombstone--custom{background-image:linear-gradient(-90deg,var(--tombstone-custom-primary)0%,var(--tombstone-custom-secondary)50%,var(--tombstone-custom-primary)100%);background-color:var(--tombstone-custom-background)}.proton-DataTable{width:100%}.proton-DataTable__header-content{align-items:center;gap:.5rem;display:flex}.proton-DataTable__message-cell{position:absolute;left:0;right:0}.proton-DataTable__empty-cell{text-align:center;padding:3rem 1.5rem}.proton-DataTable__sort-button{cursor:pointer;border-radius:var(--proton-control__border-radius);border:none;max-height:.8rem;padding-bottom:1px;transition:background-color .15s ease-in-out,opacity .15s ease-in-out,transform .15s ease-in-out;display:inline-flex}.proton-DataTable__sort-button:hover{background-color:var(--proton-control__hover-color)}.proton-DataTable__sort-button[aria-label*=ascending]{align-items:flex-end;transform:rotateX(180deg)}.proton-Dialog{background-color:var(--proton-control__background-color);border-radius:var(--proton-control__border-radius);box-shadow:0 0 20px 0 var(--proton-control__shadow-color),0 0 4px 0 var(--proton-control__shadow-color);color:var(--proton-control__text-color);outline:none;padding:.65rem .85rem;font-weight:300}.proton-ui__theme--dark .proton-Dialog{background-color:var(--proton-control__background-color-light)}.proton-Dialog__header{color:var(--proton-control__title-color);margin-bottom:.3rem}.proton-Input{width:100%;max-width:var(--container-width,100%);border-radius:var(--proton-control__border-radius);box-sizing:border-box;outline:1px solid var(--proton-control__border-color);background:var(--proton-control__background-color);min-height:40px;max-height:52px;color:var(--proton-control__text-color);border:none;flex:1;padding-left:.75rem;font-size:1.125rem;font-weight:400;transition:outline .1s ease-in-out,background-color .1s ease-in-out,color .1s ease-in-out,opacity .1s ease-in-out}.proton-ui__theme--dark .proton-Input{background-color:var(--proton-control__background-color-light)}.proton-Input:disabled{opacity:.6;cursor:not-allowed}.proton-Input:not(.proton-Input--error):focus{outline:2px solid var(--proton-color__primary)}.proton-Input:not(.proton-Input--error):focus-visible{outline:2px solid var(--proton-color__primary)}.proton-Input.proton-Input--error{outline:2px solid var(--proton-color__danger-medium)}.proton-Input__container-inner{width:100%;position:relative}.proton-Input__descriptor{z-index:1;justify-content:center;height:100%;position:absolute;top:50%;transform:translateY(-50%)}.proton-Input__prefix,.proton-Input__suffix{justify-content:center;align-items:center;min-width:32px;display:flex}.proton-Input__prefix{opacity:.5;cursor:text;left:0}.proton-Input__suffix{outline:none;right:0}.proton-Input__container-inner.proton-Input__has-prefix .proton-Input{padding-left:var(--prefix-width,32px)}.proton-Input__container-inner.proton-Input__has-suffix .proton-Input{padding-right:calc(.75rem + var(--suffix-width,44px))}.proton-Input__text{opacity:.55;color:var(--proton-control__text-color);padding:.25rem 0;font-size:.75rem;font-weight:500}.proton-Input__error{color:var(--proton-color__danger-medium);opacity:1}.proton-Input__label-top{padding-top:1.375rem;padding-bottom:.5rem}.proton-Input__label{opacity:.55;color:var(--proton-control__text-color);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;left:16px;transform:translateY(-50%)}.proton-Input__label--filled,.proton-Input[value]:not([value=""])+.proton-Input__label,.proton-Input:focus+.proton-Input__label{color:var(--proton-color__primary);opacity:1;font-size:.75rem;transform:translateY(-140%)}.proton-Input:focus+.proton-Input__label{color:var(--proton-color__primary);opacity:1}.proton-CheckboxInput{display:flex}.proton-CheckboxInput__container{align-items:center;gap:8px;display:flex}.proton-CheckboxInput__input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:2px solid var(--proton-control__border-color);border-radius:var(--proton-control__border-radius);background-color:var(--proton-control__background-color);width:20px;height:20px;margin:0;transition:background-color .1s ease-in-out,border-color .1s ease-in-out,box-shadow .1s ease-in-out;position:relative}.proton-CheckboxInput__input:checked{background-color:var(--proton-color__primary);border-color:var(--proton-color__primary)}.proton-CheckboxInput__input:checked:after{content:"";border:solid var(--proton-control__text-color);border-width:0 2px 2px 0;width:4px;height:10px;position:absolute;top:48%;left:52%;transform:translate(-50%,-50%)rotate(45deg)}.proton-CheckboxInput__input:indeterminate{background-color:var(--proton-color__primary);border-color:var(--proton-color__primary)}.proton-CheckboxInput__input:indeterminate:after{content:"";background-color:var(--proton-control__text-color);width:10px;height:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.proton-CheckboxInput__input:focus{box-shadow:0 0 0 2px var(--proton-color__primary);outline:none}.proton-CheckboxInput__input:focus-visible{box-shadow:0 0 0 2px var(--proton-color__primary);outline:none}.proton-CheckboxInput__input--error{border-color:var(--proton-color__danger-medium)}.proton-CheckboxInput__input--error:focus{box-shadow:0 0 0 2px var(--proton-color__danger-medium)}.proton-CheckboxInput__input--error:focus-visible{box-shadow:0 0 0 2px var(--proton-color__danger-medium)}.proton-CheckboxInput__input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--proton-control__background-color);border-color:var(--proton-control__border-color)}.proton-CheckboxInput__input:disabled:checked{background-color:var(--proton-control__border-color);border-color:var(--proton-control__border-color)}.proton-CheckboxInput__label{color:var(--proton-control__text-color);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:16px;font-weight:400;line-height:1.5}.proton-CheckboxInput--disabled .proton-CheckboxInput__label{opacity:.6;cursor:not-allowed}.proton-CheckboxInput__text{opacity:.65;color:var(--proton-control__text-color);padding:6px 0;font-size:14px;font-weight:500;line-height:0}.proton-CheckboxInput__error{color:var(--proton-color__danger-medium);opacity:1;margin-top:4px}.proton-CopyInput-button{all:unset;cursor:pointer;color:var(--proton-control__text-color);text-transform:uppercase;letter-spacing:.2em;justify-content:center;align-items:center;width:100%;height:100%;padding:0 .875rem 0 1.4rem;font-size:.75rem;font-weight:600;line-height:1rem;transition:background-color .2s;display:flex}.proton-CopyInput-button svg{margin-bottom:.0625rem;transition:color .2s}.proton-CopyInput-button-text{margin:0 .5rem;transition:color .2s}.proton-CopyInput-button-text--copied,.proton-CopyInput-button--copied svg{color:var(--proton-color__primary)}.proton-Input:not(.proton-Input--error):focus{outline:1px solid var(--proton-control__border-color)}.proton-Input:not(.proton-Input--error):focus-visible{outline:1px solid var(--proton-control__border-color)}.proton-ui__theme--light .proton-CopyInput-button{border-left:1px solid var(--proton-control__border-color);align-items:center;height:100%;transition:background-color .2s;display:flex}.proton-CopyInput-button:hover{background-color:var(--proton-control__background-color-light)}.proton-Input[type=search]{border-radius:3.125rem}.proton-SearchInput__wrapper{width:100%}.proton-SearchInput__button{color:currentColor;cursor:pointer;opacity:1;background-color:#0000;border:none;transition:opacity .2s ease-in-out}.proton-SearchInput__button--hide{opacity:0}.proton-SearchInput__wrapper input[type=search]::-webkit-search-decoration{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-cancel-button{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-results-button{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-results-decoration{display:none}.proton-Modal{background-color:var(--proton-control__background-color);color:var(--proton-control__text-color);max-width:86vw;max-height:80vh;box-shadow:0 .0625rem .25rem -.0625rem var(--proton-control__shadow-color);opacity:1;border-radius:.5rem;padding:2rem;transition:opacity .2s ease-in-out;position:relative;overflow:visible}.proton-Modal__content{margin-top:.5rem}.proton-Modal--closing{opacity:0}@media (max-width:768px){.proton-Modal{border-radius:0;flex-direction:column;justify-content:center;align-items:center;width:100vw;max-width:100vw;height:100vh;max-height:100vh;padding:.25rem .5rem;display:flex}.proton-Modal>div{text-align:center;width:100%}}.proton-Modal__title{color:var(--proton-control__title-color);word-break:break-word;line-height:1.2}.proton-Modal__subtitle{color:var(--proton-control__text-color);line-height:1.5}.proton-Modal__body{word-break:break-word;margin:1rem 0;line-height:1.5}.proton-Modal__actions{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.proton-Modal__close-button{cursor:pointer;color:var(--proton-control__text-color);background:0 0;border:none;border-radius:.25rem;padding:.5rem;font-size:2.2rem;font-weight:800;line-height:1;transition:opacity .15s;position:absolute;top:.375rem;right:.75rem}.proton-Modal__close-button:focus,.proton-Modal__close-button:hover{opacity:.8}.proton-ui__theme--dark .proton-Modal{background-color:var(--proton-control__background-color-light)}.proton-Popover{--slide:translateY(.8rem);transform-origin:var(--radix-popover-content-transform-origin);background-color:var(--proton-control__background-color);border-radius:var(--proton-control__border-radius);box-shadow:0 0 20px 0 var(--proton-control__shadow-color),0 0 4px 0 var(--proton-control__shadow-color);color:var(--proton-control__text-color);max-height:var(--radix-popover-content-available-height);outline:none;padding:.65rem .85rem;font-weight:300;animation:.2s cubic-bezier(.16,1,.3,1) popoverSlideAndFade}@keyframes popoverSlideAndFade{0%{opacity:0;transform:scale(.8)var(--slide)}to{opacity:1;transform:scale(1)translateY(0)}}.arrow{fill:var(--proton-control__background-color);width:.6rem;height:.4rem}.proton-Popover__constrained{width:var(--radix-popover-trigger-width)}.proton-Popover[data-side=top]{--slide:translateY(.8rem)}.proton-Popover[data-side=bottom]{--slide:translateY(-.8rem)}.proton-Popover[data-side=right]{--slide:translateX(-.8rem)}.proton-Popover[data-side=left]{--slide:translateX(.8rem)}.proton-Select{flex-direction:column;width:100%;margin:0;display:flex}.proton-Select__label{color:var(--proton-control__text-color);margin-bottom:.125rem}.proton-Select__trigger{color:var(--proton-control__text-color);font-size:inherit;border-radius:var(--proton-control__border-radius);flex:1;justify-content:space-between;align-items:center;width:100%;padding:.2rem .6rem .2rem 1rem;display:flex}.proton-Select__trigger--rounded{border-radius:3.125rem}button.proton-Select__trigger{letter-spacing:.05em;cursor:pointer;background:var(--proton-control__background-color);outline:1px solid var(--proton-control__border-color);border:none;font-weight:400;transition:outline .2s ease-in-out;position:relative}button.proton-Select__trigger:focus{outline:solid var(--proton-color__primary)2px;border:none}button.proton-Select__trigger:focus-visible{outline:solid var(--proton-color__primary)2px;border:none}.proton-Select__popover{padding-left:.25rem}.proton-Select__trigger_icon{color:var(--proton-control__text-color);width:.75em;height:.75em;margin-left:.8em;transition:transform .2s;position:relative}.proton-Select__trigger_icon svg{width:100%;height:100%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.proton-Select__trigger_icon--flipped{transform:rotateX(180deg)}.proton-Select:hover{cursor:pointer}.proton-Select__trigger--disabled,.proton-Select__trigger--disabled:hover{opacity:.5;filter:none;cursor:not-allowed}.proton-Select__value{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.proton-Switch{flex-flow:column;row-gap:5px;display:flex}.proton-Switch__label{text-transform:uppercase;letter-spacing:.1em;color:var(--proton-control__text-color);font-size:.7em;font-weight:600}.proton-Switch__description{color:var(--proton-control__text-color);align-self:center;font-size:.9em}.proton-Switch__wrapper{column-gap:12px;display:flex}.proton-Switch__toggle{background-color:var(--proton-color__gray-light);cursor:pointer;border-radius:26px;flex-shrink:0;width:50px;height:26px;position:relative}.proton-Switch__slider{background-color:#fff;border-radius:22px;width:22px;height:22px;transition:left .2s;position:absolute;top:2px;left:2px}.proton-Switch--on .proton-Switch__toggle{background-color:var(--proton-color__primary)}.proton-Switch--on .proton-Switch__slider{left:26px}.proton-Switch--disabled{opacity:.4}.proton-Switch--disabled .proton-Switch__toggle{cursor:not-allowed}.proton-TextEllipsis{vertical-align:middle;color:var(--proton-control__text-color,inherit);font-family:inherit;font-size:inherit;line-height:inherit;width:100%;height:100%;display:inline-block;position:relative}.proton-TextEllipsis--single-line{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.proton-TextEllipsis--multi-line{text-overflow:ellipsis;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.proton-TextEmphasis{color:var(--proton-control__title-color);background-image:linear-gradient(0deg,#0000 0,#0000 15%,#ff713480 15%,#ff713480 35%,#0000 35%,#0000);padding:0 .05rem;font-style:normal;font-weight:700}.proton-TextEmphasis a{color:inherit;transition:color .15s}.proton-TextEmphasis a:hover{color:var(--proton-color__primary)}.proton-TextEmphasis--tooltip{background-image:linear-gradient(0deg,#0000 0,#0000 15%,#ff713480 25%,#ff713480 87%,#0000 80%,#0000);background-position:bottom;background-repeat:no-repeat;background-size:100% 35%;font-style:italic;font-weight:400;transition:background-size .3s,border-radius .3s}.proton-TextEmphasis--tooltip:hover{background-size:100% 100%;border-radius:.125rem}.proton-TextEmphasis--tooltip:not(:hover){transition-delay:.2s}.proton__Tooltip{background-color:var(--proton-control__background-color);color:var(--proton-control__text-color)}[data-radix-popper-content-wrapper]{z-index:10000!important}.proton__Tooltip-trigger{display:inherit}.proton__Tooltip-arrow{fill:var(--proton-control__background-color)}.proton__Tooltip[data-state=delayed-open],.proton__Tooltip[data-state=instant-open]{animation:.2s slide}.proton__Tooltip[data-state=closed]{animation:.2s reverse slide}@keyframes slide{0%{opacity:0;transform:var(--origin)}to{opacity:1;transform:translate(0)}}.proton-Waveform{--waveform-bar-color-dark:#ffffffe6;--waveform-bar-color-light:#000000b3;--waveform-disabled-color-dark:#fff3;--waveform-disabled-color-light:#0003;--waveform-animation-curve:cubic-bezier(.34,1.56,.64,1);--waveform-animation-duration:.4s;--waveform-bar-delay-multiplier:.7ms;--waveform-timestamp-padding:.25rem;--waveform-timestamp-font-size:.75rem;--waveform-timestamp-border-radius:.125rem;--waveform-hover-line-width:2px;flex-direction:row;align-items:center;width:100%;height:100%;display:flex;position:relative}.proton-Waveform__container{z-index:0;flex:1;align-items:center;width:100%;height:100%;display:flex;position:relative}.proton-Waveform__container[data-disabled=true]{cursor:not-allowed}.proton-Waveform__timestamp{pointer-events:none;border-radius:var(--waveform-timestamp-border-radius);padding:0 var(--waveform-timestamp-padding);font-size:var(--waveform-timestamp-font-size);z-index:1;background-color:#0009;position:absolute}.proton-ui__theme--light .proton-Waveform__timestamp{color:#000c;background-color:#ffffffe6;box-shadow:0 2px 2px #0000004d}.proton-Waveform__timestamp--left{left:1px}.proton-Waveform__timestamp--right{right:3px}.proton-Waveform__hover-line{width:var(--waveform-hover-line-width);background-color:#ffffff80;position:absolute;top:0;bottom:0;transform:translate(-50%)}.proton-ui__theme--light .proton-Waveform__hover-line{background-color:#00000080}.proton-Waveform__bar-wrapper{flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex;position:relative}.proton-Waveform__bar{background-color:var(--waveform-bar-color-dark);transform-origin:50%;width:100%;height:0;transition:height var(--waveform-animation-duration)var(--waveform-animation-curve);position:relative}.proton-Waveform__bar.proton-Waveform__bar--visible{height:var(--target-height);transition-delay:calc(var(--index)*var(--waveform-bar-delay-multiplier))}.proton-Waveform__bar.proton-Waveform__bar--upper{transform-origin:bottom}.proton-Waveform__bar.proton-Waveform__bar--lower{transform-origin:top}.proton-ui__theme--light .proton-Waveform__bar{background-color:var(--waveform-bar-color-light)}.proton-Waveform__bar.proton-Waveform__bar--disabled{background-color:var(--waveform-disabled-color-dark)}.proton-ui__theme--light .proton-Waveform__bar.proton-Waveform__bar--disabled{background-color:var(--waveform-disabled-color-light)}.proton-Waveform__bar.proton-Waveform__bar--disabled.proton-Waveform__bar--played{background-color:var(--waveform-disabled-color-dark)}.proton-ui__theme--light .proton-Waveform__bar.proton-Waveform__bar--disabled.proton-Waveform__bar--played{background-color:var(--waveform-disabled-color-light)}.proton-Waveform__bar.proton-Waveform__bar--played{background-color:var(--proton-color__primary)}.proton-Waveform__bar--hover{height:var(--hover-height);z-index:10;background-color:color-mix(in srgb,var(--proton-color__primary)50%,transparent);mix-blend-mode:darken;width:100%;position:absolute;top:50%;transform:translateY(-50%)}.proton-ui__theme--light .proton-Waveform__bar--hover{background-color:color-mix(in srgb,var(--proton-color__primary)50%,white);mix-blend-mode:lighten}.proton-Waveform__bar-unavailable{pointer-events:none;text-align:center;z-index:10;color:#fff;background-color:#000000b3;border-radius:4px;padding:3px 6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.proton-ui__theme--light .proton-Waveform__bar-unavailable{color:#000;background-color:#fff;box-shadow:0 5px 5px #0000004d}.proton-Waveform__active-region{pointer-events:none;z-index:1;border:1.5px solid #ffffffb3;border-radius:4px;position:absolute;top:0;bottom:0}.proton-ui__theme--light .proton-Waveform__active-region{border-color:#0000004d}
1
+ .proton-Button{--proton-button-edge-padding:1.05em;--proton-button__background-color:var(--proton-color__primary);--proton-button__text-color:var(--proton-color__white);color:var(--proton-button__text-color);border-radius:var(--proton-control__border-radius);padding:.45em var(--proton-button-edge-padding);letter-spacing:.05em;cursor:pointer;box-sizing:border-box;background-color:var(--proton-button__background-color);border:0;align-items:center;transition:filter .2s,background-color .2s,outline .2s;display:inline-flex;position:relative}.proton-Button__icon-decorator{justify-content:center;align-items:center;padding-right:.3em;line-height:1;display:flex;position:relative}.proton-Button__icon-decorator--fullWidth{position:absolute}.proton-Button__text{box-sizing:border-box;text-align:center;white-space:nowrap;text-overflow:ellipsis;margin:auto;line-height:normal;overflow:hidden}.proton-Button:hover{filter:brightness(1.16);cursor:pointer}.proton-Button--primary{--proton-button__background-color:var(--proton-color__primary);--proton-button__text-color:var(--proton-color__white)}.proton-Button--secondary{--proton-button__background-color:var(--proton-color__gray-light);--proton-button__text-color:var(--proton-control__text-color)}.proton-ui__theme--dark .proton-Button--secondary{--proton-button__background-color:var(--proton-control__background-color-light)}.proton-Button--danger{--proton-button__background-color:var(--proton-color__danger-medium)}.proton-Button--success{--proton-button__background-color:var(--proton-color__success-medium)}.proton-Button--translucent{--proton-button__background-color:var(--proton-control__background-color-light);--proton-button__text-color:var(--proton-control__text-color)}.proton-Button--disabled,.proton-Button--disabled:hover{opacity:.5;filter:none;cursor:not-allowed}.proton-Button:focus{outline:2px solid var(--proton-color__primary)}.proton-Button:focus-visible{outline:2px solid var(--proton-color__primary)}.proton-Button:active{filter:brightness(1.3);transition:filter .1s ease-out}.proton-Button--fullWidth{width:100%}.proton-Button--small{padding:.2rem .6rem;font-size:.875rem}.proton-Button--medium{padding:.4rem 1rem;font-size:1rem}.proton-Button--large{padding:.6rem 1.6rem;font-size:1.2rem}.proton-Button--xlarge{padding:1rem 2rem .8rem;font-size:1.3rem}.proton-Button--2xlarge{padding:1rem 2.6rem;font-size:1.6rem}.proton-Button--fullWidth .proton-Button__text{transform:translate(calc(var(--proton-button-text-shift)))}.proton-ScreenOverlay__background{-webkit-backdrop-filter:blur(24px)brightness(75%);backdrop-filter:blur(24px)brightness(75%);background-color:#000c;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.proton-ScreenOverlay__z-index{z-index:10000}.proton-ScreenOverlay__image{object-fit:cover;width:100vw;height:100vh;position:absolute}.proton-ScreenOverlay__blur{-webkit-backdrop-filter:blur(24px)brightness(75%);backdrop-filter:blur(24px)brightness(75%);filter:brightness(46%);position:absolute;top:0;bottom:0;left:0;right:0}@keyframes fadeInBackground{0%{-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0000001a}to{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c}}@keyframes fadeOutBackground{0%{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000c}to{-webkit-backdrop-filter:blur();backdrop-filter:blur();background:0 0}}.proton-ScreenOverlay__fade-in{animation:.2s ease-in-out forwards fadeInBackground}.proton-ScreenOverlay__fade-out{animation:.2s ease-in-out forwards fadeOutBackground}.proton-ActionMenu__wrapper{z-index:10;width:100%;max-height:100vh;position:fixed;bottom:0;left:0}.proton-ActionMenu__background-wrapper{opacity:0;transition:opacity .3s cubic-bezier(.34,1.56,.64,1);overflow-y:scroll}.proton-ActionMenu__card{background:var(--proton-control__background-color);color:var(--proton-control__text-color);z-index:1;border-radius:.875rem .875rem 0 0;flex-direction:column;height:0;transition:height .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden;box-shadow:0 0 4px #0000001a,0 0 20px #00000026}.proton-ActionMenu__cancel-button{margin:0 .75rem 1rem}.proton-ActionMenu__content{padding:.75rem .75rem 0}.proton-ActionMenu__menu>[data-radix-popper-content-wrapper]{width:100%!important;position:absolute!important;top:0!important;transform:none!important}.proton-ActionMenu__list{flex-direction:column;margin-bottom:.625rem;display:flex}.proton-ActionMenu__item{color:inherit;cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem .5rem .75rem .75rem;transition:filter .2s,background-color .2s,color .2s;display:flex}.proton-ActionMenu__item:hover,.proton-ActionMenu__item:focus{background-color:var(--proton-control__hover-color);border:none;outline:none}.proton-ActionMenu__item[aria-checked=true]:hover,.proton-ActionMenu__item[aria-checked=true]:focus{filter:brightness(1.15)}.proton-ActionMenu__item[aria-checked=true]{background-color:var(--proton-control__interactive-color);color:var(--proton-color__primary)}.proton-ui__theme--dark .proton-ActionMenu__item[aria-checked=true]{background-color:var(--proton-color__primary);color:var(--proton-control__text-color)}.proton-ActionMenu__item[aria-disabled=true],.proton-ActionMenu__list[aria-disabled=true],.proton-ActionMenu__item[aria-disabled=true]:hover{opacity:.5;cursor:not-allowed;background-color:#0000}.proton-ActionMenu__list[aria-disabled=true] .proton-ActionMenu__item{pointer-events:none}.proton-ActionMenu__title{text-align:center;width:100%;font-weight:600}.proton-ActionMenu__back-button{cursor:pointer;z-index:1;align-items:center;width:25%;height:100%;padding-left:.35rem;display:flex;position:absolute;left:0}.proton-ActionMenu__back-button:hover,.proton-ActionMenu__cancel-button:focus{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__back-button:focus-visible{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__cancel-button:focus-visible{background-color:var(--proton-control__hover-color);outline:none}.proton-ActionMenu__back-button-container{align-items:center;height:3rem;display:flex;position:relative}.proton-ActionMenu__description{color:var(--proton-control__text-color);opacity:.7;font-size:.875rem}.proton-ActionMenu__item-label{font-weight:500}.proton-ui__theme--dark .proton-ActionMenu__cancel-button button{--proton-button__background-color:var(--proton-control__background-color-light)}.proton-Badge{letter-spacing:.2em;text-align:center;text-transform:uppercase;white-space:nowrap;height:1.6rem;color:#666;background-color:#f2f2f2;border-radius:10rem;padding-left:1rem;padding-right:calc(1rem - .2em);font-size:1rem;font-weight:500;line-height:1.65rem;display:inline-block}.proton-ui__theme--dark .proton-Badge:not([class*=proton-Badge--]),.proton-ui__theme--dark .proton-Badge--secondary{background-color:var(--proton-control__background-color-light);color:var(--proton-control__text-color)}.proton-Badge--primary{background-color:var(--proton-color__primary);color:var(--proton-color__white)}.proton-Badge--success{background-color:var(--proton-color__success-super-light);color:var(--proton-color__success-dark)}.proton-Badge--warning{background-color:var(--proton-color__warning-super-light);color:var(--proton-color__warning-dark)}.proton-Badge--danger{background-color:var(--proton-color__danger-super-light);color:var(--proton-color__danger-dark)}.proton-Badge--transparent{color:#666;background-color:#0000}.proton-Banner{background-color:var(--banner-bg);-webkit-backdrop-filter:var(--banner-blur);backdrop-filter:var(--banner-blur);--tw-backdrop-blur:var(--banner-blur);--banner-bg:var(--proton-control__background-color-light);--banner-title:var(--proton-color__gray-dark);--banner-content:var(--proton-color__gray-medium);--banner-icon:var(--proton-color__gray-medium-light);--banner-blur:none;margin:0}:where(.proton-ui__theme--dark) .proton-Banner{--banner-bg:var(--proton-control__background-color-light);--banner-blur:blur(15px);--banner-title:var(--proton-control__text-color);--banner-content:var(--proton-control__text-color);--banner-icon:var(--proton-control__text-color)}.proton-Banner--warning{--banner-bg:var(--proton-color__warning-super-light);--banner-title:var(--proton-color__warning-dark);--banner-content:var(--proton-color__warning-medium);--banner-icon:var(--proton-color__warning-light)}.proton-Banner--success{--banner-bg:var(--proton-color__success-super-light);--banner-title:var(--proton-color__success-dark);--banner-content:var(--proton-color__success-medium);--banner-icon:var(--proton-color__success-light)}.proton-Banner--danger{--banner-bg:var(--proton-color__danger-super-light);--banner-title:var(--proton-color__danger-dark);--banner-content:var(--proton-color__danger-medium);--banner-icon:var(--proton-color__danger-light)}.proton-Banner--rounded{border-radius:.375rem}.proton-Banner__wrapper{align-items:flex-start;padding:2rem;display:flex}.proton-Banner__wrapper--compact{padding:1rem}.proton-Banner__content-wrapper{min-width:0;color:var(--banner-content);flex:1}.proton-Banner__container{padding:0 .625rem}.proton-Banner__title{letter-spacing:.01rem;color:var(--banner-title);line-height:1.2rem}.proton-Banner__content{color:var(--banner-content);margin:.375rem 0 0}.proton-Banner__icon{fill:var(--banner-icon);height:20px}.proton-Banner__actions{gap:.5rem;margin:.375rem 0 0;display:flex}@media (min-width:768px){.proton-Banner__container{grid-gap:.5rem;grid-template-columns:1fr auto;display:grid}.proton-Banner__title,.proton-Banner__content{grid-column:1;margin:auto 0}.proton-Banner__container:not(:has(.proton-Banner__content)){grid-gap:0px;grid-template-rows:1fr}.proton-Banner__container>div:last-child{grid-area:1/2/span 2;max-height:32px;margin:auto 0}.proton-Banner__actions{margin:0 0 0 .75rem}.proton-Banner__wrapper:not(:has(.proton-Banner__content)){align-items:center}}.proton-ButtonGroup{border:1px solid var(--proton-color__gray-light);border-radius:.25rem;font-weight:400;display:flex;overflow:hidden}.proton-ButtonGroup__option{background-color:var(--proton-color__gray-super-light);cursor:pointer;border-left:1px solid var(--proton-color__gray-light);color:var(--proton-color__gray-dark);text-align:center;border-radius:0;flex:1;padding:.5em 1em}.proton-ButtonGroup__option:first-child{border-left:0}.proton-ButtonGroup__option--selected{background-color:var(--proton-color__white);color:var(--proton-color__primary);z-index:2;cursor:default;border-radius:inherit;box-shadow:0 0 .375rem #00000026}.proton-ButtonGroup__option--selected+.proton-ButtonGroup__option{border-left:1px solid #0000}.proton-MenuTrigger__menu-header{text-transform:uppercase;color:var(--proton-control__text-color);background-color:var(--proton-control__background-color-light);letter-spacing:.1em;padding:.3125rem 1rem .25rem;font-size:.8em;font-weight:700}.proton-MenuTrigger__button{cursor:pointer;color:var(--proton-control__text-color);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;padding:.25rem;transition:background-color .2s ease-in-out;display:flex}.proton-MenuTrigger__button:disabled{cursor:not-allowed;opacity:.5}.proton-ui__theme--dark .proton-MenuTrigger__button:disabled:hover,.proton-MenuTrigger__button:disabled:hover{background:0 0}.proton-MenuTrigger__button:focus{outline:2px solid var(--proton-color__primary)}.proton-MenuTrigger__button:hover{background-color:var(--proton-control__hover-color)}.proton-MenuTrigger__menu-item .proton-Menu__item,.proton-MenuTrigger__menu-item{color:var(--proton-control__text-color);grid-template:"label kbd""desc kbd"/1fr auto;align-items:center;gap:.1em .5em;padding:.75em 1em;display:grid}.proton-MenuTrigger__menu-item .proton-Menu__item[data-has-submenu=true],.proton-MenuTrigger__menu-item[data-has-submenu=true]{grid-template-columns:unset;grid-template-areas:unset;justify-content:space-between;align-items:center;display:flex}.proton-MenuTrigger__label{grid-area:label}.proton-MenuTrigger__description{opacity:.7;grid-area:desc;font-size:.8em;line-height:1.1}.proton-MenuTrigger__chevron{padding-left:.5rem}.proton-Menu{--menu-bg-color:var(--proton-control__background-color);--menu-item-bg-color:var(--proton-control__background-color);letter-spacing:.05em;border-radius:var(--proton-control__border-radius);background:var(--menu-bg-color);border:1px solid var(--proton-control__border-color);min-width:100px;max-height:420px;color:var(--proton-control__text-color);box-shadow:0 0 3px var(--proton-control__shadow-color);margin:8px 0 0;padding:0;list-style:none;overflow:auto}.proton-Menu__item{background:var(--menu-item-bg-color);cursor:pointer;outline:none;justify-content:space-between;align-items:center;padding:8px 24px 8px 16px;transition:background-color .2s,opacity .2s,color .2s;display:flex}.proton-Menu__item[aria-checked=true]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[aria-checked=true][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[aria-selected=true]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[aria-selected=true][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[data-state=checked]{--menu-item-bg-color:var(--proton-color__primary-light);color:var(--proton-color__primary);font-weight:600}.proton-Menu__item[data-state=checked][data-highlighted=""]{--menu-item-bg-color:var(--proton-color__primary-light);opacity:.75}.proton-Menu__item[data-highlighted=""]{--menu-item-bg-color:var(--proton-control__hover-color)}.proton-Menu__item:hover{--menu-item-bg-color:var(--proton-control__hover-color);box-shadow:none}.proton-Menu__item[aria-disabled=true],.proton-Menu__item[data-disabled=true]{opacity:.5;cursor:not-allowed}.proton-ButtonWithSelect{align-items:stretch;display:flex;position:relative}.proton-ButtonWithSelect button:focus{outline:none}.proton-ButtonWithSelect__button{flex:var(--flex);align-items:stretch;display:flex}.proton-ButtonWithSelect__button button,.proton-ButtonWithSelect__button a{border-top-right-radius:0;border-bottom-right-radius:0;align-items:center;display:flex;position:relative;overflow:hidden}.proton-ButtonWithSelect__button button:after,.proton-ButtonWithSelect__button a:after{content:"";background-color:#00000026;width:1px;position:absolute;top:.3em;bottom:.3em;right:0}.proton-ButtonWithSelect__trigger{flex:0 0 var(--trigger-width);min-width:var(--trigger-width);max-width:var(--trigger-width)}.proton-ButtonWithSelect__trigger .proton-Button{border-top-left-radius:0;border-bottom-left-radius:0;width:100%;height:100%;padding:0}.proton-ButtonWithSelect__trigger-content{flex-direction:column;align-items:center;display:flex}.proton-Table{border-collapse:collapse;color:var(--proton-control__text-color);width:100%;font-weight:300}.proton-Table__caption{display:none}.proton-Table__header{cursor:default;letter-spacing:.1em;text-transform:uppercase;text-align:left;outline:none;padding:.4375rem .625rem;font-size:1rem;font-weight:500;line-height:1rem}.proton-Table__header--center{text-align:center}.proton-Table__header--right{text-align:right}.proton-Table__headerSortIcon{padding:0 .125rem}.proton-Table__row{cursor:default;outline:none}.proton-Table__rowGroup--header{border-bottom:1px solid #ccc}.proton-Table__row--showLines{border-top:1px solid #ccc}.proton-Table--clickable{cursor:pointer}.proton-Table__cell{vertical-align:middle;outline:none;padding:.4375rem .625rem}.proton-Table__cell--center{text-align:center}.proton-Table__cell--right{text-align:right}.proton-Elevation{border-radius:var(--proton-control__border-radius);background-color:var(--proton-control__background-color-light);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);--tw-backdrop-blur:blur(15px);width:100%;height:100%;transition:background-color .2s ease-in-out,-webkit-backdrop-filter .2s ease-in-out,backdrop-filter .2s ease-in-out}@keyframes shimmer{0%{background-position:-300px 0}to{background-position:800px 0}}.proton-Tombstone{background-position:-300px 0;background-repeat:no-repeat;background-size:300px 100%;animation:1.5s linear infinite shimmer}.proton-ui__theme--light .proton-Tombstone{background-color:#d1d1d1;background-image:linear-gradient(-90deg,#d1d1d1,#b8b8b8,#d1d1d1)}.proton-ui__theme--dark .proton-Tombstone{background-color:#3c3c3c;background-image:linear-gradient(-90deg,#363636,#292727,#353535)}.proton-Tombstone--custom{background-image:linear-gradient(-90deg,var(--tombstone-custom-primary)0%,var(--tombstone-custom-secondary)50%,var(--tombstone-custom-primary)100%);background-color:var(--tombstone-custom-background)}.proton-DataTable{width:100%}.proton-DataTable__header-content{align-items:center;gap:.5rem;display:flex}.proton-DataTable__message-cell{position:absolute;left:0;right:0}.proton-DataTable__empty-cell{text-align:center;padding:3rem 1.5rem}.proton-DataTable__sort-button{cursor:pointer;border-radius:var(--proton-control__border-radius);border:none;max-height:.8rem;padding-bottom:1px;transition:background-color .15s ease-in-out,opacity .15s ease-in-out,transform .15s ease-in-out;display:inline-flex}.proton-DataTable__sort-button:hover{background-color:var(--proton-control__hover-color)}.proton-DataTable__sort-button[aria-label*=ascending]{align-items:flex-end;transform:rotateX(180deg)}.proton-Dialog{background-color:var(--proton-control__background-color);border-radius:var(--proton-control__border-radius);box-shadow:0 0 20px 0 var(--proton-control__shadow-color),0 0 4px 0 var(--proton-control__shadow-color);color:var(--proton-control__text-color);outline:none;padding:.65rem .85rem;font-weight:300}.proton-ui__theme--dark .proton-Dialog{background-color:var(--proton-control__background-color-light)}.proton-Dialog__header{color:var(--proton-control__title-color);margin-bottom:.3rem}.proton-Input{max-width:var(--container-width,100%);border-radius:var(--proton-control__border-radius);box-sizing:border-box;outline:1px solid var(--proton-control__border-color);background:var(--proton-control__background-color);width:100%;height:100%;color:var(--proton-control__text-color);border:none;flex:1;padding-left:.75rem;font-size:1.125rem;font-weight:400;transition:outline .1s ease-in-out,background-color .1s ease-in-out,color .1s ease-in-out,opacity .1s ease-in-out}.proton-ui__theme--dark .proton-Input{background-color:var(--proton-control__background-color-light)}.proton-Input:disabled{opacity:.6;cursor:not-allowed}.proton-Input:not(.proton-Input--error):focus{outline:2px solid var(--proton-color__primary)}.proton-Input:not(.proton-Input--error):focus-visible{outline:2px solid var(--proton-color__primary)}.proton-Input.proton-Input--error{outline:2px solid var(--proton-color__danger-medium)}.proton-Input__container{width:100%;height:100%}.proton-Input__container-inner{width:100%;height:100%;position:relative}.proton-Input__descriptor{z-index:1;justify-content:center;height:100%;position:absolute;top:50%;transform:translateY(-50%)}.proton-Input__prefix,.proton-Input__suffix{justify-content:center;align-items:center;min-width:32px;display:flex}.proton-Input__prefix{opacity:.5;cursor:text;left:0}.proton-Input__suffix{outline:none;right:0}.proton-Input__container-inner.proton-Input__has-prefix .proton-Input{padding-left:var(--prefix-width,32px)}.proton-Input__container-inner.proton-Input__has-suffix .proton-Input{padding-right:calc(.75rem + var(--suffix-width,44px))}.proton-Input__text{opacity:.55;color:var(--proton-control__text-color);padding:.25rem 0;font-size:.75rem;font-weight:500}.proton-Input__error{color:var(--proton-color__danger-medium);opacity:1}.proton-Input__label-top{padding-top:1.375rem;padding-bottom:.5rem}.proton-Input__label{opacity:.55;color:var(--proton-control__text-color);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;left:16px;transform:translateY(-50%)}.proton-Input__label--filled,.proton-Input[value]:not([value=""])+.proton-Input__label,.proton-Input:focus+.proton-Input__label{color:var(--proton-color__primary);opacity:1;font-size:.75rem;transform:translateY(-140%)}.proton-Input:focus+.proton-Input__label{color:var(--proton-color__primary);opacity:1}.proton-CheckboxInput__container{align-items:center;gap:8px;display:flex}.proton-CheckboxInput__input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:2px solid var(--proton-control__border-color);border-radius:var(--proton-control__border-radius);background-color:var(--proton-control__background-color);width:18px;height:18px;margin:0;transition:background-color .1s ease-in-out,border-color .1s ease-in-out,box-shadow .1s ease-in-out;position:relative}.proton-CheckboxInput__input:checked{background-color:var(--proton-color__primary);border-color:var(--proton-color__primary)}.proton-CheckboxInput__input:checked:after{content:"";border:solid var(--proton-color__white);border-width:0 2px 2px 0;width:5px;height:10px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(45deg)}.proton-CheckboxInput__input:indeterminate{background-color:var(--proton-color__primary);border-color:var(--proton-color__primary)}.proton-CheckboxInput__input:indeterminate:after{content:"";background-color:var(--proton-control__text-color);width:10px;height:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.proton-CheckboxInput__input:focus{box-shadow:0 0 0 2px var(--proton-color__primary);outline:none}.proton-CheckboxInput__input:focus-visible{box-shadow:0 0 0 2px var(--proton-color__primary);outline:none}.proton-CheckboxInput__input--error{border-color:var(--proton-color__danger-medium)}.proton-CheckboxInput__input--error:focus{box-shadow:0 0 0 2px var(--proton-color__danger-medium)}.proton-CheckboxInput__input--error:focus-visible{box-shadow:0 0 0 2px var(--proton-color__danger-medium)}.proton-CheckboxInput__input:disabled{opacity:.6;cursor:not-allowed}.proton-CheckboxInput__input:disabled:checked{background-color:var(--proton-control__border-color);border-color:var(--proton-control__border-color)}.proton-CheckboxInput__label{color:var(--proton-control__text-color);cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:400}.proton-CheckboxInput--disabled .proton-CheckboxInput__label{opacity:.6;cursor:not-allowed}.proton-CheckboxInput__error{color:var(--proton-color__danger-medium);opacity:1;margin-top:4px}.proton-CopyInput-button{all:unset;cursor:pointer;color:var(--proton-control__text-color);text-transform:uppercase;letter-spacing:.2em;justify-content:center;align-items:center;width:100%;height:100%;padding:0 .875rem 0 1.4rem;font-size:.75rem;font-weight:600;line-height:1rem;transition:background-color .2s;display:flex}.proton-CopyInput-button svg{margin-bottom:.0625rem;transition:color .2s}.proton-CopyInput-button-text{margin:0 .5rem;transition:color .2s}.proton-CopyInput-button-text--copied,.proton-CopyInput-button--copied svg{color:var(--proton-color__primary)}.proton-Input:not(.proton-Input--error):focus{outline:1px solid var(--proton-control__border-color)}.proton-Input:not(.proton-Input--error):focus-visible{outline:1px solid var(--proton-control__border-color)}.proton-ui__theme--light .proton-CopyInput-button{border-left:1px solid var(--proton-control__border-color);align-items:center;height:100%;transition:background-color .2s;display:flex}.proton-CopyInput-button:hover{background-color:var(--proton-control__background-color-light)}.proton-Input[type=search]{border-radius:3.125rem}.proton-SearchInput__wrapper{width:100%}.proton-SearchInput__button{color:currentColor;cursor:pointer;opacity:1;background-color:#0000;border:none;transition:opacity .2s ease-in-out}.proton-SearchInput__button--hide{opacity:0}.proton-SearchInput__wrapper input[type=search]::-webkit-search-decoration{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-cancel-button{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-results-button{display:none}.proton-SearchInput__wrapper input[type=search]::-webkit-search-results-decoration{display:none}.proton-Modal{background-color:var(--proton-control__background-color);color:var(--proton-control__text-color);max-width:86vw;max-height:80vh;box-shadow:0 .0625rem .25rem -.0625rem var(--proton-control__shadow-color);opacity:1;border-radius:.5rem;padding:2rem;transition:opacity .2s ease-in-out;position:relative;overflow:visible}.proton-Modal__content{margin-top:.5rem}.proton-Modal--closing{opacity:0}@media (max-width:768px){.proton-Modal{border-radius:0;flex-direction:column;justify-content:center;align-items:center;width:100vw;max-width:100vw;height:100vh;max-height:100vh;padding:.25rem .5rem;display:flex}.proton-Modal>div{text-align:center;width:100%}}.proton-Modal__title{color:var(--proton-control__title-color);word-break:break-word;line-height:1.2}.proton-Modal__subtitle{color:var(--proton-control__text-color);line-height:1.5}.proton-Modal__body{word-break:break-word;margin:1rem 0;line-height:1.5}.proton-Modal__actions{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.proton-Modal__close-button{cursor:pointer;color:var(--proton-control__text-color);background:0 0;border:none;border-radius:.25rem;padding:.5rem;font-size:2.2rem;font-weight:800;line-height:1;transition:opacity .15s;position:absolute;top:.375rem;right:.75rem}.proton-Modal__close-button:focus,.proton-Modal__close-button:hover{opacity:.8}.proton-ui__theme--dark .proton-Modal{background-color:var(--proton-control__background-color-light)}.proton-Popover{--slide:translateY(.8rem);transform-origin:var(--radix-popover-content-transform-origin);background-color:var(--proton-control__background-color);border-radius:var(--proton-control__border-radius);box-shadow:0 0 20px 0 var(--proton-control__shadow-color),0 0 4px 0 var(--proton-control__shadow-color);color:var(--proton-control__text-color);max-height:var(--radix-popover-content-available-height);outline:none;padding:.65rem .85rem;font-weight:300;animation:.2s cubic-bezier(.16,1,.3,1) popoverSlideAndFade}@keyframes popoverSlideAndFade{0%{opacity:0;transform:scale(.8)var(--slide)}to{opacity:1;transform:scale(1)translateY(0)}}.arrow{fill:var(--proton-control__background-color);width:.6rem;height:.4rem}.proton-Popover__constrained{width:var(--radix-popover-trigger-width)}.proton-Popover[data-side=top]{--slide:translateY(.8rem)}.proton-Popover[data-side=bottom]{--slide:translateY(-.8rem)}.proton-Popover[data-side=right]{--slide:translateX(-.8rem)}.proton-Popover[data-side=left]{--slide:translateX(.8rem)}.proton-Select{flex-direction:column;width:100%;margin:0;display:flex}.proton-Select__label{color:var(--proton-control__text-color);margin-bottom:.125rem}.proton-Select__trigger{color:var(--proton-control__text-color);font-size:inherit;border-radius:var(--proton-control__border-radius);flex:1;justify-content:space-between;align-items:center;width:100%;padding:.2rem .6rem .2rem 1rem;display:flex}.proton-Select__trigger--rounded{border-radius:3.125rem}button.proton-Select__trigger{letter-spacing:.05em;cursor:pointer;background:var(--proton-control__background-color);outline:1px solid var(--proton-control__border-color);border:none;font-weight:400;transition:outline .2s ease-in-out;position:relative}button.proton-Select__trigger:focus{outline:solid var(--proton-color__primary)2px;border:none}button.proton-Select__trigger:focus-visible{outline:solid var(--proton-color__primary)2px;border:none}.proton-Select__popover{padding-left:.25rem}.proton-Select__trigger_icon{color:var(--proton-control__text-color);width:.75em;height:.75em;margin-left:.8em;transition:transform .2s;position:relative}.proton-Select__trigger_icon svg{width:100%;height:100%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.proton-Select__trigger_icon--flipped{transform:rotateX(180deg)}.proton-Select:hover{cursor:pointer}.proton-Select__trigger--disabled,.proton-Select__trigger--disabled:hover{opacity:.5;filter:none;cursor:not-allowed}.proton-Select__value{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.proton-Switch{flex-flow:column;row-gap:5px;display:flex}.proton-Switch__label{text-transform:uppercase;letter-spacing:.1em;color:var(--proton-control__text-color);font-size:.7em;font-weight:600}.proton-Switch__description{color:var(--proton-control__text-color);align-self:center;font-size:.9em}.proton-Switch__wrapper{column-gap:12px;display:flex}.proton-Switch__toggle{background-color:var(--proton-color__gray-light);cursor:pointer;border-radius:26px;flex-shrink:0;width:50px;height:26px;position:relative}.proton-Switch__slider{background-color:#fff;border-radius:22px;width:22px;height:22px;transition:left .2s;position:absolute;top:2px;left:2px}.proton-Switch--on .proton-Switch__toggle{background-color:var(--proton-color__primary)}.proton-Switch--on .proton-Switch__slider{left:26px}.proton-Switch--disabled{opacity:.4}.proton-Switch--disabled .proton-Switch__toggle{cursor:not-allowed}.proton-TextEllipsis{vertical-align:middle;color:var(--proton-control__text-color,inherit);font-family:inherit;font-size:inherit;line-height:inherit;width:100%;height:100%;display:inline-block;position:relative}.proton-TextEllipsis--single-line{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.proton-TextEllipsis--multi-line{text-overflow:ellipsis;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.proton-TextEmphasis{color:var(--proton-control__title-color);background-image:linear-gradient(0deg,#0000 0,#0000 15%,#ff713480 15%,#ff713480 35%,#0000 35%,#0000);padding:0 .05rem;font-style:normal;font-weight:700}.proton-TextEmphasis a{color:inherit;transition:color .15s}.proton-TextEmphasis a:hover{color:var(--proton-color__primary)}.proton-TextEmphasis--tooltip{background-image:linear-gradient(0deg,#0000 0,#0000 15%,#ff713480 25%,#ff713480 87%,#0000 80%,#0000);background-position:bottom;background-repeat:no-repeat;background-size:100% 35%;font-style:italic;font-weight:400;transition:background-size .3s,border-radius .3s}.proton-TextEmphasis--tooltip:hover{background-size:100% 100%;border-radius:.125rem}.proton-TextEmphasis--tooltip:not(:hover){transition-delay:.2s}.proton__Tooltip{background-color:var(--proton-control__background-color);color:var(--proton-control__text-color)}[data-radix-popper-content-wrapper]{z-index:10000!important}.proton__Tooltip-trigger{display:inherit}.proton__Tooltip-arrow{fill:var(--proton-control__background-color)}.proton__Tooltip[data-state=delayed-open],.proton__Tooltip[data-state=instant-open]{animation:.2s slide}.proton__Tooltip[data-state=closed]{animation:.2s reverse slide}@keyframes slide{0%{opacity:0;transform:var(--origin)}to{opacity:1;transform:translate(0)}}.proton-Waveform{--waveform-bar-color-dark:#ffffffe6;--waveform-bar-color-light:#000000b3;--waveform-disabled-color-dark:#fff3;--waveform-disabled-color-light:#0003;--waveform-animation-curve:cubic-bezier(.34,1.56,.64,1);--waveform-animation-duration:.4s;--waveform-bar-delay-multiplier:.7ms;--waveform-timestamp-padding:.25rem;--waveform-timestamp-font-size:.75rem;--waveform-timestamp-border-radius:.125rem;--waveform-hover-line-width:2px;flex-direction:row;align-items:center;width:100%;height:100%;display:flex;position:relative}.proton-Waveform__container{z-index:0;flex:1;align-items:center;width:100%;height:100%;display:flex;position:relative}.proton-Waveform__container[data-disabled=true]{cursor:not-allowed}.proton-Waveform__timestamp{pointer-events:none;border-radius:var(--waveform-timestamp-border-radius);padding:0 var(--waveform-timestamp-padding);font-size:var(--waveform-timestamp-font-size);z-index:1;background-color:#0009;position:absolute}.proton-ui__theme--light .proton-Waveform__timestamp{color:#000c;background-color:#ffffffe6;box-shadow:0 2px 2px #0000004d}.proton-Waveform__timestamp--left{left:1px}.proton-Waveform__timestamp--right{right:3px}.proton-Waveform__hover-line{width:var(--waveform-hover-line-width);background-color:#ffffff80;position:absolute;top:0;bottom:0;transform:translate(-50%)}.proton-ui__theme--light .proton-Waveform__hover-line{background-color:#00000080}.proton-Waveform__bar-wrapper{flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex;position:relative}.proton-Waveform__bar{background-color:var(--waveform-bar-color-dark);transform-origin:50%;width:100%;height:0;transition:height var(--waveform-animation-duration)var(--waveform-animation-curve);position:relative}.proton-Waveform__bar.proton-Waveform__bar--visible{height:var(--target-height);transition-delay:calc(var(--index)*var(--waveform-bar-delay-multiplier))}.proton-Waveform__bar.proton-Waveform__bar--upper{transform-origin:bottom}.proton-Waveform__bar.proton-Waveform__bar--lower{transform-origin:top}.proton-ui__theme--light .proton-Waveform__bar{background-color:var(--waveform-bar-color-light)}.proton-Waveform__bar.proton-Waveform__bar--disabled{background-color:var(--waveform-disabled-color-dark)}.proton-ui__theme--light .proton-Waveform__bar.proton-Waveform__bar--disabled{background-color:var(--waveform-disabled-color-light)}.proton-Waveform__bar.proton-Waveform__bar--disabled.proton-Waveform__bar--played{background-color:var(--waveform-disabled-color-dark)}.proton-ui__theme--light .proton-Waveform__bar.proton-Waveform__bar--disabled.proton-Waveform__bar--played{background-color:var(--waveform-disabled-color-light)}.proton-Waveform__bar.proton-Waveform__bar--played{background-color:var(--proton-color__primary)}.proton-Waveform__bar--hover{height:var(--hover-height);z-index:10;background-color:color-mix(in srgb,var(--proton-color__primary)50%,transparent);mix-blend-mode:darken;width:100%;position:absolute;top:50%;transform:translateY(-50%)}.proton-ui__theme--light .proton-Waveform__bar--hover{background-color:color-mix(in srgb,var(--proton-color__primary)50%,white);mix-blend-mode:lighten}.proton-Waveform__bar-unavailable{pointer-events:none;text-align:center;z-index:10;color:#fff;background-color:#000000b3;border-radius:4px;padding:3px 6px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.proton-ui__theme--light .proton-Waveform__bar-unavailable{color:#000;background-color:#fff;box-shadow:0 5px 5px #0000004d}.proton-Waveform__active-region{pointer-events:none;z-index:1;border:1.5px solid #ffffffb3;border-radius:4px;position:absolute;top:0;bottom:0}.proton-ui__theme--light .proton-Waveform__active-region{border-color:#0000004d}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@protonradio/proton-ui",
3
- "version": "0.11.23-beta.1",
3
+ "version": "0.11.23-beta.3",
4
4
  "description": "",
5
5
  "main": "./dist/proton-ui.umd.js",
6
6
  "module": "./dist/proton-ui.es.js",