| [ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 "use strict"; 2 var wp; 3 (wp ||= {}).components = (() => { 4 var __create = Object.create; 5 var __defProp = Object.defineProperty; 6 var __getOwnPropDesc = Object.getOwnPropertyDescriptor; 7 var __getOwnPropNames = Object.getOwnPropertyNames; 8 var __getProtoOf = Object.getPrototypeOf; 9 var __hasOwnProp = Object.prototype.hasOwnProperty; 10 var __esm = (fn, res) => function __init() { 11 return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res; 12 }; 13 var __commonJS = (cb, mod) => function __require() { 14 return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; 15 }; 16 var __export = (target, all) => { 17 for (var name in all) 18 __defProp(target, name, { get: all[name], enumerable: true }); 19 }; 20 var __copyProps = (to, from2, except, desc) => { 21 if (from2 && typeof from2 === "object" || typeof from2 === "function") { 22 for (let key of __getOwnPropNames(from2)) 23 if (!__hasOwnProp.call(to, key) && key !== except) 24 __defProp(to, key, { get: () => from2[key], enumerable: !(desc = __getOwnPropDesc(from2, key)) || desc.enumerable }); 25 } 26 return to; 27 }; 28 var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( 29 // If the importer is in node compatibility mode or this is not an ESM 30 // file that has been converted to a CommonJS file using a Babel- 31 // compatible transform (i.e. "__esModule" has not been set), then set 32 // "default" to the CommonJS "module.exports" for node compatibility. 33 isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, 34 mod 35 )); 36 var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); 37 38 // package-external:@wordpress/primitives 39 var require_primitives = __commonJS({ 40 "package-external:@wordpress/primitives"(exports, module) { 41 module.exports = window.wp.primitives; 42 } 43 }); 44 45 // package-external:@wordpress/i18n 46 var require_i18n = __commonJS({ 47 "package-external:@wordpress/i18n"(exports, module) { 48 module.exports = window.wp.i18n; 49 } 50 }); 51 52 // package-external:@wordpress/compose 53 var require_compose = __commonJS({ 54 "package-external:@wordpress/compose"(exports, module) { 55 module.exports = window.wp.compose; 56 } 57 }); 58 59 // package-external:@wordpress/element 60 var require_element = __commonJS({ 61 "package-external:@wordpress/element"(exports, module) { 62 module.exports = window.wp.element; 63 } 64 }); 65 66 // vendor-external:react 67 var require_react = __commonJS({ 68 "vendor-external:react"(exports, module) { 69 module.exports = window.React; 70 } 71 }); 72 73 // vendor-external:react/jsx-runtime 74 var require_jsx_runtime = __commonJS({ 75 "vendor-external:react/jsx-runtime"(exports, module) { 76 module.exports = window.ReactJSXRuntime; 77 } 78 }); 79 80 // node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js 81 var require_use_sync_external_store_shim_development = __commonJS({ 82 "node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js"(exports) { 83 "use strict"; 84 (function() { 85 function is(x2, y3) { 86 return x2 === y3 && (0 !== x2 || 1 / x2 === 1 / y3) || x2 !== x2 && y3 !== y3; 87 } 88 function useSyncExternalStore$2(subscribe2, getSnapshot) { 89 didWarnOld18Alpha || void 0 === React37.startTransition || (didWarnOld18Alpha = true, console.error( 90 "You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release." 91 )); 92 var value = getSnapshot(); 93 if (!didWarnUncachedGetSnapshot) { 94 var cachedValue = getSnapshot(); 95 objectIs(value, cachedValue) || (console.error( 96 "The result of getSnapshot should be cached to avoid an infinite loop" 97 ), didWarnUncachedGetSnapshot = true); 98 } 99 cachedValue = useState86({ 100 inst: { value, getSnapshot } 101 }); 102 var inst = cachedValue[0].inst, forceUpdate = cachedValue[1]; 103 useLayoutEffect24( 104 function() { 105 inst.value = value; 106 inst.getSnapshot = getSnapshot; 107 checkIfSnapshotChanged(inst) && forceUpdate({ inst }); 108 }, 109 [subscribe2, value, getSnapshot] 110 ); 111 useEffect80( 112 function() { 113 checkIfSnapshotChanged(inst) && forceUpdate({ inst }); 114 return subscribe2(function() { 115 checkIfSnapshotChanged(inst) && forceUpdate({ inst }); 116 }); 117 }, 118 [subscribe2] 119 ); 120 useDebugValue(value); 121 return value; 122 } 123 function checkIfSnapshotChanged(inst) { 124 var latestGetSnapshot = inst.getSnapshot; 125 inst = inst.value; 126 try { 127 var nextValue = latestGetSnapshot(); 128 return !objectIs(inst, nextValue); 129 } catch (error) { 130 return true; 131 } 132 } 133 function useSyncExternalStore$1(subscribe2, getSnapshot) { 134 return getSnapshot(); 135 } 136 "undefined" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ && "function" === typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart && __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error()); 137 var React37 = require_react(), objectIs = "function" === typeof Object.is ? Object.is : is, useState86 = React37.useState, useEffect80 = React37.useEffect, useLayoutEffect24 = React37.useLayoutEffect, useDebugValue = React37.useDebugValue, didWarnOld18Alpha = false, didWarnUncachedGetSnapshot = false, shim = "undefined" === typeof window || "undefined" === typeof window.document || "undefined" === typeof window.document.createElement ? useSyncExternalStore$1 : useSyncExternalStore$2; 138 exports.useSyncExternalStore = void 0 !== React37.useSyncExternalStore ? React37.useSyncExternalStore : shim; 139 "undefined" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ && "function" === typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop && __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error()); 140 })(); 141 } 142 }); 143 144 // node_modules/use-sync-external-store/shim/index.js 145 var require_shim = __commonJS({ 146 "node_modules/use-sync-external-store/shim/index.js"(exports, module) { 147 "use strict"; 148 if (false) { 149 module.exports = null; 150 } else { 151 module.exports = require_use_sync_external_store_shim_development(); 152 } 153 } 154 }); 155 156 // vendor-external:react-dom 157 var require_react_dom = __commonJS({ 158 "vendor-external:react-dom"(exports, module) { 159 module.exports = window.ReactDOM; 160 } 161 }); 162 163 // package-external:@wordpress/deprecated 164 var require_deprecated = __commonJS({ 165 "package-external:@wordpress/deprecated"(exports, module) { 166 module.exports = window.wp.deprecated; 167 } 168 }); 169 170 // node_modules/@emotion/is-prop-valid/node_modules/@emotion/memoize/dist/emotion-memoize.esm.js 171 function memoize(fn) { 172 var cache2 = /* @__PURE__ */ Object.create(null); 173 return function(arg) { 174 if (cache2[arg] === void 0) cache2[arg] = fn(arg); 175 return cache2[arg]; 176 }; 177 } 178 var init_emotion_memoize_esm = __esm({ 179 "node_modules/@emotion/is-prop-valid/node_modules/@emotion/memoize/dist/emotion-memoize.esm.js"() { 180 } 181 }); 182 183 // node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js 184 var emotion_is_prop_valid_esm_exports = {}; 185 __export(emotion_is_prop_valid_esm_exports, { 186 default: () => isPropValid 187 }); 188 var reactPropsRegex, isPropValid; 189 var init_emotion_is_prop_valid_esm = __esm({ 190 "node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js"() { 191 init_emotion_memoize_esm(); 192 reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; 193 isPropValid = /* @__PURE__ */ memoize( 194 function(prop) { 195 return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111 && prop.charCodeAt(1) === 110 && prop.charCodeAt(2) < 91; 196 } 197 /* Z+1 */ 198 ); 199 } 200 }); 201 202 // node_modules/deepmerge/dist/cjs.js 203 var require_cjs = __commonJS({ 204 "node_modules/deepmerge/dist/cjs.js"(exports, module) { 205 "use strict"; 206 var isMergeableObject = function isMergeableObject2(value) { 207 return isNonNullObject(value) && !isSpecial(value); 208 }; 209 function isNonNullObject(value) { 210 return !!value && typeof value === "object"; 211 } 212 function isSpecial(value) { 213 var stringValue = Object.prototype.toString.call(value); 214 return stringValue === "[object RegExp]" || stringValue === "[object Date]" || isReactElement(value); 215 } 216 var canUseSymbol = typeof Symbol === "function" && Symbol.for; 217 var REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for("react.element") : 60103; 218 function isReactElement(value) { 219 return value.$$typeof === REACT_ELEMENT_TYPE; 220 } 221 function emptyTarget(val) { 222 return Array.isArray(val) ? [] : {}; 223 } 224 function cloneUnlessOtherwiseSpecified(value, options2) { 225 return options2.clone !== false && options2.isMergeableObject(value) ? deepmerge2(emptyTarget(value), value, options2) : value; 226 } 227 function defaultArrayMerge(target, source, options2) { 228 return target.concat(source).map(function(element) { 229 return cloneUnlessOtherwiseSpecified(element, options2); 230 }); 231 } 232 function getMergeFunction(key, options2) { 233 if (!options2.customMerge) { 234 return deepmerge2; 235 } 236 var customMerge = options2.customMerge(key); 237 return typeof customMerge === "function" ? customMerge : deepmerge2; 238 } 239 function getEnumerableOwnPropertySymbols(target) { 240 return Object.getOwnPropertySymbols ? Object.getOwnPropertySymbols(target).filter(function(symbol4) { 241 return Object.propertyIsEnumerable.call(target, symbol4); 242 }) : []; 243 } 244 function getKeys2(target) { 245 return Object.keys(target).concat(getEnumerableOwnPropertySymbols(target)); 246 } 247 function propertyIsOnObject(object, property) { 248 try { 249 return property in object; 250 } catch (_) { 251 return false; 252 } 253 } 254 function propertyIsUnsafe(target, key) { 255 return propertyIsOnObject(target, key) && !(Object.hasOwnProperty.call(target, key) && Object.propertyIsEnumerable.call(target, key)); 256 } 257 function mergeObject(target, source, options2) { 258 var destination = {}; 259 if (options2.isMergeableObject(target)) { 260 getKeys2(target).forEach(function(key) { 261 destination[key] = cloneUnlessOtherwiseSpecified(target[key], options2); 262 }); 263 } 264 getKeys2(source).forEach(function(key) { 265 if (propertyIsUnsafe(target, key)) { 266 return; 267 } 268 if (propertyIsOnObject(target, key) && options2.isMergeableObject(source[key])) { 269 destination[key] = getMergeFunction(key, options2)(target[key], source[key], options2); 270 } else { 271 destination[key] = cloneUnlessOtherwiseSpecified(source[key], options2); 272 } 273 }); 274 return destination; 275 } 276 function deepmerge2(target, source, options2) { 277 options2 = options2 || {}; 278 options2.arrayMerge = options2.arrayMerge || defaultArrayMerge; 279 options2.isMergeableObject = options2.isMergeableObject || isMergeableObject; 280 options2.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified; 281 var sourceIsArray = Array.isArray(source); 282 var targetIsArray = Array.isArray(target); 283 var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray; 284 if (!sourceAndTargetTypesMatch) { 285 return cloneUnlessOtherwiseSpecified(source, options2); 286 } else if (sourceIsArray) { 287 return options2.arrayMerge(target, source, options2); 288 } else { 289 return mergeObject(target, source, options2); 290 } 291 } 292 deepmerge2.all = function deepmergeAll(array, options2) { 293 if (!Array.isArray(array)) { 294 throw new Error("first argument should be an array"); 295 } 296 return array.reduce(function(prev2, next2) { 297 return deepmerge2(prev2, next2, options2); 298 }, {}); 299 }; 300 var deepmerge_1 = deepmerge2; 301 module.exports = deepmerge_1; 302 } 303 }); 304 305 // node_modules/fast-deep-equal/es6/index.js 306 var require_es6 = __commonJS({ 307 "node_modules/fast-deep-equal/es6/index.js"(exports, module) { 308 "use strict"; 309 module.exports = function equal(a3, b3) { 310 if (a3 === b3) return true; 311 if (a3 && b3 && typeof a3 == "object" && typeof b3 == "object") { 312 if (a3.constructor !== b3.constructor) return false; 313 var length2, i3, keys; 314 if (Array.isArray(a3)) { 315 length2 = a3.length; 316 if (length2 != b3.length) return false; 317 for (i3 = length2; i3-- !== 0; ) 318 if (!equal(a3[i3], b3[i3])) return false; 319 return true; 320 } 321 if (a3 instanceof Map && b3 instanceof Map) { 322 if (a3.size !== b3.size) return false; 323 for (i3 of a3.entries()) 324 if (!b3.has(i3[0])) return false; 325 for (i3 of a3.entries()) 326 if (!equal(i3[1], b3.get(i3[0]))) return false; 327 return true; 328 } 329 if (a3 instanceof Set && b3 instanceof Set) { 330 if (a3.size !== b3.size) return false; 331 for (i3 of a3.entries()) 332 if (!b3.has(i3[0])) return false; 333 return true; 334 } 335 if (ArrayBuffer.isView(a3) && ArrayBuffer.isView(b3)) { 336 length2 = a3.length; 337 if (length2 != b3.length) return false; 338 for (i3 = length2; i3-- !== 0; ) 339 if (a3[i3] !== b3[i3]) return false; 340 return true; 341 } 342 if (a3.constructor === RegExp) return a3.source === b3.source && a3.flags === b3.flags; 343 if (a3.valueOf !== Object.prototype.valueOf) return a3.valueOf() === b3.valueOf(); 344 if (a3.toString !== Object.prototype.toString) return a3.toString() === b3.toString(); 345 keys = Object.keys(a3); 346 length2 = keys.length; 347 if (length2 !== Object.keys(b3).length) return false; 348 for (i3 = length2; i3-- !== 0; ) 349 if (!Object.prototype.hasOwnProperty.call(b3, keys[i3])) return false; 350 for (i3 = length2; i3-- !== 0; ) { 351 var key = keys[i3]; 352 if (!equal(a3[key], b3[key])) return false; 353 } 354 return true; 355 } 356 return a3 !== a3 && b3 !== b3; 357 }; 358 } 359 }); 360 361 // package-external:@wordpress/warning 362 var require_warning = __commonJS({ 363 "package-external:@wordpress/warning"(exports, module) { 364 module.exports = window.wp.warning; 365 } 366 }); 367 368 // node_modules/react-is/cjs/react-is.development.js 369 var require_react_is_development = __commonJS({ 370 "node_modules/react-is/cjs/react-is.development.js"(exports) { 371 "use strict"; 372 if (true) { 373 (function() { 374 "use strict"; 375 var hasSymbol = typeof Symbol === "function" && Symbol.for; 376 var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for("react.element") : 60103; 377 var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for("react.portal") : 60106; 378 var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for("react.fragment") : 60107; 379 var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for("react.strict_mode") : 60108; 380 var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for("react.profiler") : 60114; 381 var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for("react.provider") : 60109; 382 var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for("react.context") : 60110; 383 var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for("react.async_mode") : 60111; 384 var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for("react.concurrent_mode") : 60111; 385 var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for("react.forward_ref") : 60112; 386 var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for("react.suspense") : 60113; 387 var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for("react.suspense_list") : 60120; 388 var REACT_MEMO_TYPE = hasSymbol ? Symbol.for("react.memo") : 60115; 389 var REACT_LAZY_TYPE = hasSymbol ? Symbol.for("react.lazy") : 60116; 390 var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for("react.block") : 60121; 391 var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for("react.fundamental") : 60117; 392 var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for("react.responder") : 60118; 393 var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for("react.scope") : 60119; 394 function isValidElementType(type) { 395 return typeof type === "string" || typeof type === "function" || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill. 396 type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === "object" && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE); 397 } 398 function typeOf(object) { 399 if (typeof object === "object" && object !== null) { 400 var $$typeof = object.$$typeof; 401 switch ($$typeof) { 402 case REACT_ELEMENT_TYPE: 403 var type = object.type; 404 switch (type) { 405 case REACT_ASYNC_MODE_TYPE: 406 case REACT_CONCURRENT_MODE_TYPE: 407 case REACT_FRAGMENT_TYPE: 408 case REACT_PROFILER_TYPE: 409 case REACT_STRICT_MODE_TYPE: 410 case REACT_SUSPENSE_TYPE: 411 return type; 412 default: 413 var $$typeofType = type && type.$$typeof; 414 switch ($$typeofType) { 415 case REACT_CONTEXT_TYPE: 416 case REACT_FORWARD_REF_TYPE: 417 case REACT_LAZY_TYPE: 418 case REACT_MEMO_TYPE: 419 case REACT_PROVIDER_TYPE: 420 return $$typeofType; 421 default: 422 return $$typeof; 423 } 424 } 425 case REACT_PORTAL_TYPE: 426 return $$typeof; 427 } 428 } 429 return void 0; 430 } 431 var AsyncMode = REACT_ASYNC_MODE_TYPE; 432 var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE; 433 var ContextConsumer = REACT_CONTEXT_TYPE; 434 var ContextProvider = REACT_PROVIDER_TYPE; 435 var Element2 = REACT_ELEMENT_TYPE; 436 var ForwardRef = REACT_FORWARD_REF_TYPE; 437 var Fragment11 = REACT_FRAGMENT_TYPE; 438 var Lazy = REACT_LAZY_TYPE; 439 var Memo = REACT_MEMO_TYPE; 440 var Portal3 = REACT_PORTAL_TYPE; 441 var Profiler = REACT_PROFILER_TYPE; 442 var StrictMode = REACT_STRICT_MODE_TYPE; 443 var Suspense = REACT_SUSPENSE_TYPE; 444 var hasWarnedAboutDeprecatedIsAsyncMode = false; 445 function isAsyncMode(object) { 446 { 447 if (!hasWarnedAboutDeprecatedIsAsyncMode) { 448 hasWarnedAboutDeprecatedIsAsyncMode = true; 449 console["warn"]("The ReactIs.isAsyncMode() alias has been deprecated, and will be removed in React 17+. Update your code to use ReactIs.isConcurrentMode() instead. It has the exact same API."); 450 } 451 } 452 return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE; 453 } 454 function isConcurrentMode(object) { 455 return typeOf(object) === REACT_CONCURRENT_MODE_TYPE; 456 } 457 function isContextConsumer(object) { 458 return typeOf(object) === REACT_CONTEXT_TYPE; 459 } 460 function isContextProvider(object) { 461 return typeOf(object) === REACT_PROVIDER_TYPE; 462 } 463 function isElement2(object) { 464 return typeof object === "object" && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; 465 } 466 function isForwardRef(object) { 467 return typeOf(object) === REACT_FORWARD_REF_TYPE; 468 } 469 function isFragment(object) { 470 return typeOf(object) === REACT_FRAGMENT_TYPE; 471 } 472 function isLazy(object) { 473 return typeOf(object) === REACT_LAZY_TYPE; 474 } 475 function isMemo(object) { 476 return typeOf(object) === REACT_MEMO_TYPE; 477 } 478 function isPortal(object) { 479 return typeOf(object) === REACT_PORTAL_TYPE; 480 } 481 function isProfiler(object) { 482 return typeOf(object) === REACT_PROFILER_TYPE; 483 } 484 function isStrictMode(object) { 485 return typeOf(object) === REACT_STRICT_MODE_TYPE; 486 } 487 function isSuspense(object) { 488 return typeOf(object) === REACT_SUSPENSE_TYPE; 489 } 490 exports.AsyncMode = AsyncMode; 491 exports.ConcurrentMode = ConcurrentMode; 492 exports.ContextConsumer = ContextConsumer; 493 exports.ContextProvider = ContextProvider; 494 exports.Element = Element2; 495 exports.ForwardRef = ForwardRef; 496 exports.Fragment = Fragment11; 497 exports.Lazy = Lazy; 498 exports.Memo = Memo; 499 exports.Portal = Portal3; 500 exports.Profiler = Profiler; 501 exports.StrictMode = StrictMode; 502 exports.Suspense = Suspense; 503 exports.isAsyncMode = isAsyncMode; 504 exports.isConcurrentMode = isConcurrentMode; 505 exports.isContextConsumer = isContextConsumer; 506 exports.isContextProvider = isContextProvider; 507 exports.isElement = isElement2; 508 exports.isForwardRef = isForwardRef; 509 exports.isFragment = isFragment; 510 exports.isLazy = isLazy; 511 exports.isMemo = isMemo; 512 exports.isPortal = isPortal; 513 exports.isProfiler = isProfiler; 514 exports.isStrictMode = isStrictMode; 515 exports.isSuspense = isSuspense; 516 exports.isValidElementType = isValidElementType; 517 exports.typeOf = typeOf; 518 })(); 519 } 520 } 521 }); 522 523 // node_modules/react-is/index.js 524 var require_react_is = __commonJS({ 525 "node_modules/react-is/index.js"(exports, module) { 526 "use strict"; 527 if (false) { 528 module.exports = null; 529 } else { 530 module.exports = require_react_is_development(); 531 } 532 } 533 }); 534 535 // node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js 536 var require_hoist_non_react_statics_cjs = __commonJS({ 537 "node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js"(exports, module) { 538 "use strict"; 539 var reactIs = require_react_is(); 540 var REACT_STATICS = { 541 childContextTypes: true, 542 contextType: true, 543 contextTypes: true, 544 defaultProps: true, 545 displayName: true, 546 getDefaultProps: true, 547 getDerivedStateFromError: true, 548 getDerivedStateFromProps: true, 549 mixins: true, 550 propTypes: true, 551 type: true 552 }; 553 var KNOWN_STATICS = { 554 name: true, 555 length: true, 556 prototype: true, 557 caller: true, 558 callee: true, 559 arguments: true, 560 arity: true 561 }; 562 var FORWARD_REF_STATICS = { 563 "$$typeof": true, 564 render: true, 565 defaultProps: true, 566 displayName: true, 567 propTypes: true 568 }; 569 var MEMO_STATICS = { 570 "$$typeof": true, 571 compare: true, 572 defaultProps: true, 573 displayName: true, 574 propTypes: true, 575 type: true 576 }; 577 var TYPE_STATICS = {}; 578 TYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS; 579 TYPE_STATICS[reactIs.Memo] = MEMO_STATICS; 580 function getStatics(component) { 581 if (reactIs.isMemo(component)) { 582 return MEMO_STATICS; 583 } 584 return TYPE_STATICS[component["$$typeof"]] || REACT_STATICS; 585 } 586 var defineProperty = Object.defineProperty; 587 var getOwnPropertyNames = Object.getOwnPropertyNames; 588 var getOwnPropertySymbols = Object.getOwnPropertySymbols; 589 var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; 590 var getPrototypeOf = Object.getPrototypeOf; 591 var objectPrototype = Object.prototype; 592 function hoistNonReactStatics(targetComponent, sourceComponent, blacklist) { 593 if (typeof sourceComponent !== "string") { 594 if (objectPrototype) { 595 var inheritedComponent = getPrototypeOf(sourceComponent); 596 if (inheritedComponent && inheritedComponent !== objectPrototype) { 597 hoistNonReactStatics(targetComponent, inheritedComponent, blacklist); 598 } 599 } 600 var keys = getOwnPropertyNames(sourceComponent); 601 if (getOwnPropertySymbols) { 602 keys = keys.concat(getOwnPropertySymbols(sourceComponent)); 603 } 604 var targetStatics = getStatics(targetComponent); 605 var sourceStatics = getStatics(sourceComponent); 606 for (var i3 = 0; i3 < keys.length; ++i3) { 607 var key = keys[i3]; 608 if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) { 609 var descriptor = getOwnPropertyDescriptor(sourceComponent, key); 610 try { 611 defineProperty(targetComponent, key, descriptor); 612 } catch (e3) { 613 } 614 } 615 } 616 } 617 return targetComponent; 618 } 619 module.exports = hoistNonReactStatics; 620 } 621 }); 622 623 // node_modules/highlight-words-core/dist/index.js 624 var require_dist = __commonJS({ 625 "node_modules/highlight-words-core/dist/index.js"(exports, module) { 626 module.exports = /******/ 627 (function(modules) { 628 var installedModules = {}; 629 function __webpack_require__(moduleId) { 630 if (installedModules[moduleId]) 631 return installedModules[moduleId].exports; 632 var module2 = installedModules[moduleId] = { 633 /******/ 634 exports: {}, 635 /******/ 636 id: moduleId, 637 /******/ 638 loaded: false 639 /******/ 640 }; 641 modules[moduleId].call(module2.exports, module2, module2.exports, __webpack_require__); 642 module2.loaded = true; 643 return module2.exports; 644 } 645 __webpack_require__.m = modules; 646 __webpack_require__.c = installedModules; 647 __webpack_require__.p = ""; 648 return __webpack_require__(0); 649 })([ 650 /* 0 */ 651 /***/ 652 (function(module2, exports2, __webpack_require__) { 653 module2.exports = __webpack_require__(1); 654 }), 655 /* 1 */ 656 /***/ 657 (function(module2, exports2, __webpack_require__) { 658 "use strict"; 659 Object.defineProperty(exports2, "__esModule", { 660 value: true 661 }); 662 var _utils = __webpack_require__(2); 663 Object.defineProperty(exports2, "combineChunks", { 664 enumerable: true, 665 get: function get() { 666 return _utils.combineChunks; 667 } 668 }); 669 Object.defineProperty(exports2, "fillInChunks", { 670 enumerable: true, 671 get: function get() { 672 return _utils.fillInChunks; 673 } 674 }); 675 Object.defineProperty(exports2, "findAll", { 676 enumerable: true, 677 get: function get() { 678 return _utils.findAll; 679 } 680 }); 681 Object.defineProperty(exports2, "findChunks", { 682 enumerable: true, 683 get: function get() { 684 return _utils.findChunks; 685 } 686 }); 687 }), 688 /* 2 */ 689 /***/ 690 (function(module2, exports2) { 691 "use strict"; 692 Object.defineProperty(exports2, "__esModule", { 693 value: true 694 }); 695 var findAll2 = exports2.findAll = function findAll3(_ref11) { 696 var autoEscape = _ref11.autoEscape, _ref$caseSensitive = _ref11.caseSensitive, caseSensitive = _ref$caseSensitive === void 0 ? false : _ref$caseSensitive, _ref$findChunks = _ref11.findChunks, findChunks = _ref$findChunks === void 0 ? defaultFindChunks : _ref$findChunks, sanitize2 = _ref11.sanitize, searchWords = _ref11.searchWords, textToHighlight = _ref11.textToHighlight; 697 return fillInChunks({ 698 chunksToHighlight: combineChunks({ 699 chunks: findChunks({ 700 autoEscape, 701 caseSensitive, 702 sanitize: sanitize2, 703 searchWords, 704 textToHighlight 705 }) 706 }), 707 totalLength: textToHighlight ? textToHighlight.length : 0 708 }); 709 }; 710 var combineChunks = exports2.combineChunks = function combineChunks2(_ref25) { 711 var chunks = _ref25.chunks; 712 chunks = chunks.sort(function(first, second) { 713 return first.start - second.start; 714 }).reduce(function(processedChunks, nextChunk) { 715 if (processedChunks.length === 0) { 716 return [nextChunk]; 717 } else { 718 var prevChunk = processedChunks.pop(); 719 if (nextChunk.start <= prevChunk.end) { 720 var endIndex = Math.max(prevChunk.end, nextChunk.end); 721 processedChunks.push({ highlight: false, start: prevChunk.start, end: endIndex }); 722 } else { 723 processedChunks.push(prevChunk, nextChunk); 724 } 725 return processedChunks; 726 } 727 }, []); 728 return chunks; 729 }; 730 var defaultFindChunks = function defaultFindChunks2(_ref32) { 731 var autoEscape = _ref32.autoEscape, caseSensitive = _ref32.caseSensitive, _ref3$sanitize = _ref32.sanitize, sanitize2 = _ref3$sanitize === void 0 ? defaultSanitize : _ref3$sanitize, searchWords = _ref32.searchWords, textToHighlight = _ref32.textToHighlight; 732 textToHighlight = sanitize2(textToHighlight); 733 return searchWords.filter(function(searchWord) { 734 return searchWord; 735 }).reduce(function(chunks, searchWord) { 736 searchWord = sanitize2(searchWord); 737 if (autoEscape) { 738 searchWord = escapeRegExpFn(searchWord); 739 } 740 var regex = new RegExp(searchWord, caseSensitive ? "g" : "gi"); 741 var match5 = void 0; 742 while (match5 = regex.exec(textToHighlight)) { 743 var _start = match5.index; 744 var _end = regex.lastIndex; 745 if (_end > _start) { 746 chunks.push({ highlight: false, start: _start, end: _end }); 747 } 748 if (match5.index === regex.lastIndex) { 749 regex.lastIndex++; 750 } 751 } 752 return chunks; 753 }, []); 754 }; 755 exports2.findChunks = defaultFindChunks; 756 var fillInChunks = exports2.fillInChunks = function fillInChunks2(_ref42) { 757 var chunksToHighlight = _ref42.chunksToHighlight, totalLength = _ref42.totalLength; 758 var allChunks = []; 759 var append2 = function append3(start, end, highlight) { 760 if (end - start > 0) { 761 allChunks.push({ 762 start, 763 end, 764 highlight 765 }); 766 } 767 }; 768 if (chunksToHighlight.length === 0) { 769 append2(0, totalLength, false); 770 } else { 771 var lastIndex = 0; 772 chunksToHighlight.forEach(function(chunk) { 773 append2(lastIndex, chunk.start, false); 774 append2(chunk.start, chunk.end, true); 775 lastIndex = chunk.end; 776 }); 777 append2(lastIndex, totalLength, false); 778 } 779 return allChunks; 780 }; 781 function defaultSanitize(string) { 782 return string; 783 } 784 function escapeRegExpFn(string) { 785 return string.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"); 786 } 787 }) 788 /******/ 789 ]); 790 } 791 }); 792 793 // node_modules/remove-accents/index.js 794 var require_remove_accents = __commonJS({ 795 "node_modules/remove-accents/index.js"(exports, module) { 796 var characterMap = { 797 "\xC0": "A", 798 "\xC1": "A", 799 "\xC2": "A", 800 "\xC3": "A", 801 "\xC4": "A", 802 "\xC5": "A", 803 "\u1EA4": "A", 804 "\u1EAE": "A", 805 "\u1EB2": "A", 806 "\u1EB4": "A", 807 "\u1EB6": "A", 808 "\xC6": "AE", 809 "\u1EA6": "A", 810 "\u1EB0": "A", 811 "\u0202": "A", 812 "\u1EA2": "A", 813 "\u1EA0": "A", 814 "\u1EA8": "A", 815 "\u1EAA": "A", 816 "\u1EAC": "A", 817 "\xC7": "C", 818 "\u1E08": "C", 819 "\xC8": "E", 820 "\xC9": "E", 821 "\xCA": "E", 822 "\xCB": "E", 823 "\u1EBE": "E", 824 "\u1E16": "E", 825 "\u1EC0": "E", 826 "\u1E14": "E", 827 "\u1E1C": "E", 828 "\u0206": "E", 829 "\u1EBA": "E", 830 "\u1EBC": "E", 831 "\u1EB8": "E", 832 "\u1EC2": "E", 833 "\u1EC4": "E", 834 "\u1EC6": "E", 835 "\xCC": "I", 836 "\xCD": "I", 837 "\xCE": "I", 838 "\xCF": "I", 839 "\u1E2E": "I", 840 "\u020A": "I", 841 "\u1EC8": "I", 842 "\u1ECA": "I", 843 "\xD0": "D", 844 "\xD1": "N", 845 "\xD2": "O", 846 "\xD3": "O", 847 "\xD4": "O", 848 "\xD5": "O", 849 "\xD6": "O", 850 "\xD8": "O", 851 "\u1ED0": "O", 852 "\u1E4C": "O", 853 "\u1E52": "O", 854 "\u020E": "O", 855 "\u1ECE": "O", 856 "\u1ECC": "O", 857 "\u1ED4": "O", 858 "\u1ED6": "O", 859 "\u1ED8": "O", 860 "\u1EDC": "O", 861 "\u1EDE": "O", 862 "\u1EE0": "O", 863 "\u1EDA": "O", 864 "\u1EE2": "O", 865 "\xD9": "U", 866 "\xDA": "U", 867 "\xDB": "U", 868 "\xDC": "U", 869 "\u1EE6": "U", 870 "\u1EE4": "U", 871 "\u1EEC": "U", 872 "\u1EEE": "U", 873 "\u1EF0": "U", 874 "\xDD": "Y", 875 "\xE0": "a", 876 "\xE1": "a", 877 "\xE2": "a", 878 "\xE3": "a", 879 "\xE4": "a", 880 "\xE5": "a", 881 "\u1EA5": "a", 882 "\u1EAF": "a", 883 "\u1EB3": "a", 884 "\u1EB5": "a", 885 "\u1EB7": "a", 886 "\xE6": "ae", 887 "\u1EA7": "a", 888 "\u1EB1": "a", 889 "\u0203": "a", 890 "\u1EA3": "a", 891 "\u1EA1": "a", 892 "\u1EA9": "a", 893 "\u1EAB": "a", 894 "\u1EAD": "a", 895 "\xE7": "c", 896 "\u1E09": "c", 897 "\xE8": "e", 898 "\xE9": "e", 899 "\xEA": "e", 900 "\xEB": "e", 901 "\u1EBF": "e", 902 "\u1E17": "e", 903 "\u1EC1": "e", 904 "\u1E15": "e", 905 "\u1E1D": "e", 906 "\u0207": "e", 907 "\u1EBB": "e", 908 "\u1EBD": "e", 909 "\u1EB9": "e", 910 "\u1EC3": "e", 911 "\u1EC5": "e", 912 "\u1EC7": "e", 913 "\xEC": "i", 914 "\xED": "i", 915 "\xEE": "i", 916 "\xEF": "i", 917 "\u1E2F": "i", 918 "\u020B": "i", 919 "\u1EC9": "i", 920 "\u1ECB": "i", 921 "\xF0": "d", 922 "\xF1": "n", 923 "\xF2": "o", 924 "\xF3": "o", 925 "\xF4": "o", 926 "\xF5": "o", 927 "\xF6": "o", 928 "\xF8": "o", 929 "\u1ED1": "o", 930 "\u1E4D": "o", 931 "\u1E53": "o", 932 "\u020F": "o", 933 "\u1ECF": "o", 934 "\u1ECD": "o", 935 "\u1ED5": "o", 936 "\u1ED7": "o", 937 "\u1ED9": "o", 938 "\u1EDD": "o", 939 "\u1EDF": "o", 940 "\u1EE1": "o", 941 "\u1EDB": "o", 942 "\u1EE3": "o", 943 "\xF9": "u", 944 "\xFA": "u", 945 "\xFB": "u", 946 "\xFC": "u", 947 "\u1EE7": "u", 948 "\u1EE5": "u", 949 "\u1EED": "u", 950 "\u1EEF": "u", 951 "\u1EF1": "u", 952 "\xFD": "y", 953 "\xFF": "y", 954 "\u0100": "A", 955 "\u0101": "a", 956 "\u0102": "A", 957 "\u0103": "a", 958 "\u0104": "A", 959 "\u0105": "a", 960 "\u0106": "C", 961 "\u0107": "c", 962 "\u0108": "C", 963 "\u0109": "c", 964 "\u010A": "C", 965 "\u010B": "c", 966 "\u010C": "C", 967 "\u010D": "c", 968 "C\u0306": "C", 969 "c\u0306": "c", 970 "\u010E": "D", 971 "\u010F": "d", 972 "\u0110": "D", 973 "\u0111": "d", 974 "\u0112": "E", 975 "\u0113": "e", 976 "\u0114": "E", 977 "\u0115": "e", 978 "\u0116": "E", 979 "\u0117": "e", 980 "\u0118": "E", 981 "\u0119": "e", 982 "\u011A": "E", 983 "\u011B": "e", 984 "\u011C": "G", 985 "\u01F4": "G", 986 "\u011D": "g", 987 "\u01F5": "g", 988 "\u011E": "G", 989 "\u011F": "g", 990 "\u0120": "G", 991 "\u0121": "g", 992 "\u0122": "G", 993 "\u0123": "g", 994 "\u0124": "H", 995 "\u0125": "h", 996 "\u0126": "H", 997 "\u0127": "h", 998 "\u1E2A": "H", 999 "\u1E2B": "h", 1000 "\u0128": "I", 1001 "\u0129": "i", 1002 "\u012A": "I", 1003 "\u012B": "i", 1004 "\u012C": "I", 1005 "\u012D": "i", 1006 "\u012E": "I", 1007 "\u012F": "i", 1008 "\u0130": "I", 1009 "\u0131": "i", 1010 "\u0132": "IJ", 1011 "\u0133": "ij", 1012 "\u0134": "J", 1013 "\u0135": "j", 1014 "\u0136": "K", 1015 "\u0137": "k", 1016 "\u1E30": "K", 1017 "\u1E31": "k", 1018 "K\u0306": "K", 1019 "k\u0306": "k", 1020 "\u0139": "L", 1021 "\u013A": "l", 1022 "\u013B": "L", 1023 "\u013C": "l", 1024 "\u013D": "L", 1025 "\u013E": "l", 1026 "\u013F": "L", 1027 "\u0140": "l", 1028 "\u0141": "l", 1029 "\u0142": "l", 1030 "\u1E3E": "M", 1031 "\u1E3F": "m", 1032 "M\u0306": "M", 1033 "m\u0306": "m", 1034 "\u0143": "N", 1035 "\u0144": "n", 1036 "\u0145": "N", 1037 "\u0146": "n", 1038 "\u0147": "N", 1039 "\u0148": "n", 1040 "\u0149": "n", 1041 "N\u0306": "N", 1042 "n\u0306": "n", 1043 "\u014C": "O", 1044 "\u014D": "o", 1045 "\u014E": "O", 1046 "\u014F": "o", 1047 "\u0150": "O", 1048 "\u0151": "o", 1049 "\u0152": "OE", 1050 "\u0153": "oe", 1051 "P\u0306": "P", 1052 "p\u0306": "p", 1053 "\u0154": "R", 1054 "\u0155": "r", 1055 "\u0156": "R", 1056 "\u0157": "r", 1057 "\u0158": "R", 1058 "\u0159": "r", 1059 "R\u0306": "R", 1060 "r\u0306": "r", 1061 "\u0212": "R", 1062 "\u0213": "r", 1063 "\u015A": "S", 1064 "\u015B": "s", 1065 "\u015C": "S", 1066 "\u015D": "s", 1067 "\u015E": "S", 1068 "\u0218": "S", 1069 "\u0219": "s", 1070 "\u015F": "s", 1071 "\u0160": "S", 1072 "\u0161": "s", 1073 "\u0162": "T", 1074 "\u0163": "t", 1075 "\u021B": "t", 1076 "\u021A": "T", 1077 "\u0164": "T", 1078 "\u0165": "t", 1079 "\u0166": "T", 1080 "\u0167": "t", 1081 "T\u0306": "T", 1082 "t\u0306": "t", 1083 "\u0168": "U", 1084 "\u0169": "u", 1085 "\u016A": "U", 1086 "\u016B": "u", 1087 "\u016C": "U", 1088 "\u016D": "u", 1089 "\u016E": "U", 1090 "\u016F": "u", 1091 "\u0170": "U", 1092 "\u0171": "u", 1093 "\u0172": "U", 1094 "\u0173": "u", 1095 "\u0216": "U", 1096 "\u0217": "u", 1097 "V\u0306": "V", 1098 "v\u0306": "v", 1099 "\u0174": "W", 1100 "\u0175": "w", 1101 "\u1E82": "W", 1102 "\u1E83": "w", 1103 "X\u0306": "X", 1104 "x\u0306": "x", 1105 "\u0176": "Y", 1106 "\u0177": "y", 1107 "\u0178": "Y", 1108 "Y\u0306": "Y", 1109 "y\u0306": "y", 1110 "\u0179": "Z", 1111 "\u017A": "z", 1112 "\u017B": "Z", 1113 "\u017C": "z", 1114 "\u017D": "Z", 1115 "\u017E": "z", 1116 "\u017F": "s", 1117 "\u0192": "f", 1118 "\u01A0": "O", 1119 "\u01A1": "o", 1120 "\u01AF": "U", 1121 "\u01B0": "u", 1122 "\u01CD": "A", 1123 "\u01CE": "a", 1124 "\u01CF": "I", 1125 "\u01D0": "i", 1126 "\u01D1": "O", 1127 "\u01D2": "o", 1128 "\u01D3": "U", 1129 "\u01D4": "u", 1130 "\u01D5": "U", 1131 "\u01D6": "u", 1132 "\u01D7": "U", 1133 "\u01D8": "u", 1134 "\u01D9": "U", 1135 "\u01DA": "u", 1136 "\u01DB": "U", 1137 "\u01DC": "u", 1138 "\u1EE8": "U", 1139 "\u1EE9": "u", 1140 "\u1E78": "U", 1141 "\u1E79": "u", 1142 "\u01FA": "A", 1143 "\u01FB": "a", 1144 "\u01FC": "AE", 1145 "\u01FD": "ae", 1146 "\u01FE": "O", 1147 "\u01FF": "o", 1148 "\xDE": "TH", 1149 "\xFE": "th", 1150 "\u1E54": "P", 1151 "\u1E55": "p", 1152 "\u1E64": "S", 1153 "\u1E65": "s", 1154 "X\u0301": "X", 1155 "x\u0301": "x", 1156 "\u0403": "\u0413", 1157 "\u0453": "\u0433", 1158 "\u040C": "\u041A", 1159 "\u045C": "\u043A", 1160 "A\u030B": "A", 1161 "a\u030B": "a", 1162 "E\u030B": "E", 1163 "e\u030B": "e", 1164 "I\u030B": "I", 1165 "i\u030B": "i", 1166 "\u01F8": "N", 1167 "\u01F9": "n", 1168 "\u1ED2": "O", 1169 "\u1ED3": "o", 1170 "\u1E50": "O", 1171 "\u1E51": "o", 1172 "\u1EEA": "U", 1173 "\u1EEB": "u", 1174 "\u1E80": "W", 1175 "\u1E81": "w", 1176 "\u1EF2": "Y", 1177 "\u1EF3": "y", 1178 "\u0200": "A", 1179 "\u0201": "a", 1180 "\u0204": "E", 1181 "\u0205": "e", 1182 "\u0208": "I", 1183 "\u0209": "i", 1184 "\u020C": "O", 1185 "\u020D": "o", 1186 "\u0210": "R", 1187 "\u0211": "r", 1188 "\u0214": "U", 1189 "\u0215": "u", 1190 "B\u030C": "B", 1191 "b\u030C": "b", 1192 "\u010C\u0323": "C", 1193 "\u010D\u0323": "c", 1194 "\xCA\u030C": "E", 1195 "\xEA\u030C": "e", 1196 "F\u030C": "F", 1197 "f\u030C": "f", 1198 "\u01E6": "G", 1199 "\u01E7": "g", 1200 "\u021E": "H", 1201 "\u021F": "h", 1202 "J\u030C": "J", 1203 "\u01F0": "j", 1204 "\u01E8": "K", 1205 "\u01E9": "k", 1206 "M\u030C": "M", 1207 "m\u030C": "m", 1208 "P\u030C": "P", 1209 "p\u030C": "p", 1210 "Q\u030C": "Q", 1211 "q\u030C": "q", 1212 "\u0158\u0329": "R", 1213 "\u0159\u0329": "r", 1214 "\u1E66": "S", 1215 "\u1E67": "s", 1216 "V\u030C": "V", 1217 "v\u030C": "v", 1218 "W\u030C": "W", 1219 "w\u030C": "w", 1220 "X\u030C": "X", 1221 "x\u030C": "x", 1222 "Y\u030C": "Y", 1223 "y\u030C": "y", 1224 "A\u0327": "A", 1225 "a\u0327": "a", 1226 "B\u0327": "B", 1227 "b\u0327": "b", 1228 "\u1E10": "D", 1229 "\u1E11": "d", 1230 "\u0228": "E", 1231 "\u0229": "e", 1232 "\u0190\u0327": "E", 1233 "\u025B\u0327": "e", 1234 "\u1E28": "H", 1235 "\u1E29": "h", 1236 "I\u0327": "I", 1237 "i\u0327": "i", 1238 "\u0197\u0327": "I", 1239 "\u0268\u0327": "i", 1240 "M\u0327": "M", 1241 "m\u0327": "m", 1242 "O\u0327": "O", 1243 "o\u0327": "o", 1244 "Q\u0327": "Q", 1245 "q\u0327": "q", 1246 "U\u0327": "U", 1247 "u\u0327": "u", 1248 "X\u0327": "X", 1249 "x\u0327": "x", 1250 "Z\u0327": "Z", 1251 "z\u0327": "z", 1252 "\u0439": "\u0438", 1253 "\u0419": "\u0418", 1254 "\u0451": "\u0435", 1255 "\u0401": "\u0415" 1256 }; 1257 var chars2 = Object.keys(characterMap).join("|"); 1258 var allAccents = new RegExp(chars2, "g"); 1259 var firstAccent = new RegExp(chars2, ""); 1260 function matcher(match5) { 1261 return characterMap[match5]; 1262 } 1263 var removeAccents5 = function(string) { 1264 return string.replace(allAccents, matcher); 1265 }; 1266 var hasAccents = function(string) { 1267 return !!string.match(firstAccent); 1268 }; 1269 module.exports = removeAccents5; 1270 module.exports.has = hasAccents; 1271 module.exports.remove = removeAccents5; 1272 } 1273 }); 1274 1275 // package-external:@wordpress/rich-text 1276 var require_rich_text = __commonJS({ 1277 "package-external:@wordpress/rich-text"(exports, module) { 1278 module.exports = window.wp.richText; 1279 } 1280 }); 1281 1282 // package-external:@wordpress/a11y 1283 var require_a11y = __commonJS({ 1284 "package-external:@wordpress/a11y"(exports, module) { 1285 module.exports = window.wp.a11y; 1286 } 1287 }); 1288 1289 // package-external:@wordpress/keycodes 1290 var require_keycodes = __commonJS({ 1291 "package-external:@wordpress/keycodes"(exports, module) { 1292 module.exports = window.wp.keycodes; 1293 } 1294 }); 1295 1296 // package-external:@wordpress/is-shallow-equal 1297 var require_is_shallow_equal = __commonJS({ 1298 "package-external:@wordpress/is-shallow-equal"(exports, module) { 1299 module.exports = window.wp.isShallowEqual; 1300 } 1301 }); 1302 1303 // node_modules/gradient-parser/build/node.js 1304 var require_node = __commonJS({ 1305 "node_modules/gradient-parser/build/node.js"(exports) { 1306 var GradientParser = GradientParser || {}; 1307 GradientParser.stringify = /* @__PURE__ */ (function() { 1308 var visitor = { 1309 "visit_linear-gradient": function(node2) { 1310 return visitor.visit_gradient(node2); 1311 }, 1312 "visit_repeating-linear-gradient": function(node2) { 1313 return visitor.visit_gradient(node2); 1314 }, 1315 "visit_radial-gradient": function(node2) { 1316 return visitor.visit_gradient(node2); 1317 }, 1318 "visit_repeating-radial-gradient": function(node2) { 1319 return visitor.visit_gradient(node2); 1320 }, 1321 "visit_gradient": function(node2) { 1322 var orientation = visitor.visit(node2.orientation); 1323 if (orientation) { 1324 orientation += ", "; 1325 } 1326 return node2.type + "(" + orientation + visitor.visit(node2.colorStops) + ")"; 1327 }, 1328 "visit_shape": function(node2) { 1329 var result = node2.value, at = visitor.visit(node2.at), style2 = visitor.visit(node2.style); 1330 if (style2) { 1331 result += " " + style2; 1332 } 1333 if (at) { 1334 result += " at " + at; 1335 } 1336 return result; 1337 }, 1338 "visit_default-radial": function(node2) { 1339 var result = "", at = visitor.visit(node2.at); 1340 if (at) { 1341 result += at; 1342 } 1343 return result; 1344 }, 1345 "visit_extent-keyword": function(node2) { 1346 var result = node2.value, at = visitor.visit(node2.at); 1347 if (at) { 1348 result += " at " + at; 1349 } 1350 return result; 1351 }, 1352 "visit_position-keyword": function(node2) { 1353 return node2.value; 1354 }, 1355 "visit_position": function(node2) { 1356 return visitor.visit(node2.value.x) + " " + visitor.visit(node2.value.y); 1357 }, 1358 "visit_%": function(node2) { 1359 return node2.value + "%"; 1360 }, 1361 "visit_em": function(node2) { 1362 return node2.value + "em"; 1363 }, 1364 "visit_px": function(node2) { 1365 return node2.value + "px"; 1366 }, 1367 "visit_calc": function(node2) { 1368 return "calc(" + node2.value + ")"; 1369 }, 1370 "visit_literal": function(node2) { 1371 return visitor.visit_color(node2.value, node2); 1372 }, 1373 "visit_hex": function(node2) { 1374 return visitor.visit_color("#" + node2.value, node2); 1375 }, 1376 "visit_rgb": function(node2) { 1377 return visitor.visit_color("rgb(" + node2.value.join(", ") + ")", node2); 1378 }, 1379 "visit_rgba": function(node2) { 1380 return visitor.visit_color("rgba(" + node2.value.join(", ") + ")", node2); 1381 }, 1382 "visit_hsl": function(node2) { 1383 return visitor.visit_color("hsl(" + node2.value[0] + ", " + node2.value[1] + "%, " + node2.value[2] + "%)", node2); 1384 }, 1385 "visit_hsla": function(node2) { 1386 return visitor.visit_color("hsla(" + node2.value[0] + ", " + node2.value[1] + "%, " + node2.value[2] + "%, " + node2.value[3] + ")", node2); 1387 }, 1388 "visit_var": function(node2) { 1389 return visitor.visit_color("var(" + node2.value + ")", node2); 1390 }, 1391 "visit_color": function(resultColor, node2) { 1392 var result = resultColor, length2 = visitor.visit(node2.length); 1393 if (length2) { 1394 result += " " + length2; 1395 } 1396 return result; 1397 }, 1398 "visit_angular": function(node2) { 1399 return node2.value + "deg"; 1400 }, 1401 "visit_directional": function(node2) { 1402 return "to " + node2.value; 1403 }, 1404 "visit_array": function(elements2) { 1405 var result = "", size3 = elements2.length; 1406 elements2.forEach(function(element, i3) { 1407 result += visitor.visit(element); 1408 if (i3 < size3 - 1) { 1409 result += ", "; 1410 } 1411 }); 1412 return result; 1413 }, 1414 "visit_object": function(obj) { 1415 if (obj.width && obj.height) { 1416 return visitor.visit(obj.width) + " " + visitor.visit(obj.height); 1417 } 1418 return ""; 1419 }, 1420 "visit": function(element) { 1421 if (!element) { 1422 return ""; 1423 } 1424 var result = ""; 1425 if (element instanceof Array) { 1426 return visitor.visit_array(element); 1427 } else if (typeof element === "object" && !element.type) { 1428 return visitor.visit_object(element); 1429 } else if (element.type) { 1430 var nodeVisitor = visitor["visit_" + element.type]; 1431 if (nodeVisitor) { 1432 return nodeVisitor(element); 1433 } else { 1434 throw Error("Missing visitor visit_" + element.type); 1435 } 1436 } else { 1437 throw Error("Invalid node."); 1438 } 1439 } 1440 }; 1441 return function(root) { 1442 return visitor.visit(root); 1443 }; 1444 })(); 1445 var GradientParser = GradientParser || {}; 1446 GradientParser.parse = /* @__PURE__ */ (function() { 1447 var tokens = { 1448 linearGradient: /^(\-(webkit|o|ms|moz)\-)?(linear\-gradient)/i, 1449 repeatingLinearGradient: /^(\-(webkit|o|ms|moz)\-)?(repeating\-linear\-gradient)/i, 1450 radialGradient: /^(\-(webkit|o|ms|moz)\-)?(radial\-gradient)/i, 1451 repeatingRadialGradient: /^(\-(webkit|o|ms|moz)\-)?(repeating\-radial\-gradient)/i, 1452 sideOrCorner: /^to (left (top|bottom)|right (top|bottom)|top (left|right)|bottom (left|right)|left|right|top|bottom)/i, 1453 extentKeywords: /^(closest\-side|closest\-corner|farthest\-side|farthest\-corner|contain|cover)/, 1454 positionKeywords: /^(left|center|right|top|bottom)/i, 1455 pixelValue: /^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))px/, 1456 percentageValue: /^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))\%/, 1457 emValue: /^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))em/, 1458 angleValue: /^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))deg/, 1459 radianValue: /^(-?(([0-9]*\.[0-9]+)|([0-9]+\.?)))rad/, 1460 startCall: /^\(/, 1461 endCall: /^\)/, 1462 comma: /^,/, 1463 hexColor: /^\#([0-9a-fA-F]+)/, 1464 literalColor: /^([a-zA-Z]+)/, 1465 rgbColor: /^rgb/i, 1466 rgbaColor: /^rgba/i, 1467 varColor: /^var/i, 1468 calcValue: /^calc/i, 1469 variableName: /^(--[a-zA-Z0-9-,\s\#]+)/, 1470 number: /^(([0-9]*\.[0-9]+)|([0-9]+\.?))/, 1471 hslColor: /^hsl/i, 1472 hslaColor: /^hsla/i 1473 }; 1474 var input = ""; 1475 function error(msg) { 1476 var err = new Error(input + ": " + msg); 1477 err.source = input; 1478 throw err; 1479 } 1480 function getAST() { 1481 var ast = matchListDefinitions(); 1482 if (input.length > 0) { 1483 error("Invalid input not EOF"); 1484 } 1485 return ast; 1486 } 1487 function matchListDefinitions() { 1488 return matchListing(matchDefinition); 1489 } 1490 function matchDefinition() { 1491 return matchGradient( 1492 "linear-gradient", 1493 tokens.linearGradient, 1494 matchLinearOrientation 1495 ) || matchGradient( 1496 "repeating-linear-gradient", 1497 tokens.repeatingLinearGradient, 1498 matchLinearOrientation 1499 ) || matchGradient( 1500 "radial-gradient", 1501 tokens.radialGradient, 1502 matchListRadialOrientations 1503 ) || matchGradient( 1504 "repeating-radial-gradient", 1505 tokens.repeatingRadialGradient, 1506 matchListRadialOrientations 1507 ); 1508 } 1509 function matchGradient(gradientType, pattern, orientationMatcher) { 1510 return matchCall(pattern, function(captures) { 1511 var orientation = orientationMatcher(); 1512 if (orientation) { 1513 if (!scan(tokens.comma)) { 1514 error("Missing comma before color stops"); 1515 } 1516 } 1517 return { 1518 type: gradientType, 1519 orientation, 1520 colorStops: matchListing(matchColorStop) 1521 }; 1522 }); 1523 } 1524 function matchCall(pattern, callback) { 1525 var captures = scan(pattern); 1526 if (captures) { 1527 if (!scan(tokens.startCall)) { 1528 error("Missing ("); 1529 } 1530 var result = callback(captures); 1531 if (!scan(tokens.endCall)) { 1532 error("Missing )"); 1533 } 1534 return result; 1535 } 1536 } 1537 function matchLinearOrientation() { 1538 var sideOrCorner = matchSideOrCorner(); 1539 if (sideOrCorner) { 1540 return sideOrCorner; 1541 } 1542 var legacyDirection = match5("position-keyword", tokens.positionKeywords, 1); 1543 if (legacyDirection) { 1544 return { 1545 type: "directional", 1546 value: legacyDirection.value 1547 }; 1548 } 1549 return matchAngle(); 1550 } 1551 function matchSideOrCorner() { 1552 return match5("directional", tokens.sideOrCorner, 1); 1553 } 1554 function matchAngle() { 1555 return match5("angular", tokens.angleValue, 1) || match5("angular", tokens.radianValue, 1); 1556 } 1557 function matchListRadialOrientations() { 1558 var radialOrientations, radialOrientation = matchRadialOrientation(), lookaheadCache; 1559 if (radialOrientation) { 1560 radialOrientations = []; 1561 radialOrientations.push(radialOrientation); 1562 lookaheadCache = input; 1563 if (scan(tokens.comma)) { 1564 radialOrientation = matchRadialOrientation(); 1565 if (radialOrientation) { 1566 radialOrientations.push(radialOrientation); 1567 } else { 1568 input = lookaheadCache; 1569 } 1570 } 1571 } 1572 return radialOrientations; 1573 } 1574 function matchRadialOrientation() { 1575 var radialType = matchCircle() || matchEllipse(); 1576 if (radialType) { 1577 radialType.at = matchAtPosition(); 1578 } else { 1579 var extent = matchExtentKeyword(); 1580 if (extent) { 1581 radialType = extent; 1582 var positionAt = matchAtPosition(); 1583 if (positionAt) { 1584 radialType.at = positionAt; 1585 } 1586 } else { 1587 var atPosition = matchAtPosition(); 1588 if (atPosition) { 1589 radialType = { 1590 type: "default-radial", 1591 at: atPosition 1592 }; 1593 } else { 1594 var defaultPosition = matchPositioning(); 1595 if (defaultPosition) { 1596 radialType = { 1597 type: "default-radial", 1598 at: defaultPosition 1599 }; 1600 } 1601 } 1602 } 1603 } 1604 return radialType; 1605 } 1606 function matchCircle() { 1607 var circle = match5("shape", /^(circle)/i, 0); 1608 if (circle) { 1609 circle.style = matchLength() || matchExtentKeyword(); 1610 } 1611 return circle; 1612 } 1613 function matchEllipse() { 1614 var ellipse = match5("shape", /^(ellipse)/i, 0); 1615 if (ellipse) { 1616 ellipse.style = matchPositioning() || matchDistance() || matchExtentKeyword(); 1617 } 1618 return ellipse; 1619 } 1620 function matchExtentKeyword() { 1621 return match5("extent-keyword", tokens.extentKeywords, 1); 1622 } 1623 function matchAtPosition() { 1624 if (match5("position", /^at/, 0)) { 1625 var positioning = matchPositioning(); 1626 if (!positioning) { 1627 error("Missing positioning value"); 1628 } 1629 return positioning; 1630 } 1631 } 1632 function matchPositioning() { 1633 var location = matchCoordinates(); 1634 if (location.x || location.y) { 1635 return { 1636 type: "position", 1637 value: location 1638 }; 1639 } 1640 } 1641 function matchCoordinates() { 1642 return { 1643 x: matchDistance(), 1644 y: matchDistance() 1645 }; 1646 } 1647 function matchListing(matcher) { 1648 var captures = matcher(), result = []; 1649 if (captures) { 1650 result.push(captures); 1651 while (scan(tokens.comma)) { 1652 captures = matcher(); 1653 if (captures) { 1654 result.push(captures); 1655 } else { 1656 error("One extra comma"); 1657 } 1658 } 1659 } 1660 return result; 1661 } 1662 function matchColorStop() { 1663 var color2 = matchColor(); 1664 if (!color2) { 1665 error("Expected color definition"); 1666 } 1667 color2.length = matchDistance(); 1668 return color2; 1669 } 1670 function matchColor() { 1671 return matchHexColor() || matchHSLAColor() || matchHSLColor() || matchRGBAColor() || matchRGBColor() || matchVarColor() || matchLiteralColor(); 1672 } 1673 function matchLiteralColor() { 1674 return match5("literal", tokens.literalColor, 0); 1675 } 1676 function matchHexColor() { 1677 return match5("hex", tokens.hexColor, 1); 1678 } 1679 function matchRGBColor() { 1680 return matchCall(tokens.rgbColor, function() { 1681 return { 1682 type: "rgb", 1683 value: matchListing(matchNumber) 1684 }; 1685 }); 1686 } 1687 function matchRGBAColor() { 1688 return matchCall(tokens.rgbaColor, function() { 1689 return { 1690 type: "rgba", 1691 value: matchListing(matchNumber) 1692 }; 1693 }); 1694 } 1695 function matchVarColor() { 1696 return matchCall(tokens.varColor, function() { 1697 return { 1698 type: "var", 1699 value: matchVariableName() 1700 }; 1701 }); 1702 } 1703 function matchHSLColor() { 1704 return matchCall(tokens.hslColor, function() { 1705 var lookahead = scan(tokens.percentageValue); 1706 if (lookahead) { 1707 error("HSL hue value must be a number in degrees (0-360) or normalized (-360 to 360), not a percentage"); 1708 } 1709 var hue = matchNumber(); 1710 scan(tokens.comma); 1711 var captures = scan(tokens.percentageValue); 1712 var sat = captures ? captures[1] : null; 1713 scan(tokens.comma); 1714 captures = scan(tokens.percentageValue); 1715 var light = captures ? captures[1] : null; 1716 if (!sat || !light) { 1717 error("Expected percentage value for saturation and lightness in HSL"); 1718 } 1719 return { 1720 type: "hsl", 1721 value: [hue, sat, light] 1722 }; 1723 }); 1724 } 1725 function matchHSLAColor() { 1726 return matchCall(tokens.hslaColor, function() { 1727 var hue = matchNumber(); 1728 scan(tokens.comma); 1729 var captures = scan(tokens.percentageValue); 1730 var sat = captures ? captures[1] : null; 1731 scan(tokens.comma); 1732 captures = scan(tokens.percentageValue); 1733 var light = captures ? captures[1] : null; 1734 scan(tokens.comma); 1735 var alpha2 = matchNumber(); 1736 if (!sat || !light) { 1737 error("Expected percentage value for saturation and lightness in HSLA"); 1738 } 1739 return { 1740 type: "hsla", 1741 value: [hue, sat, light, alpha2] 1742 }; 1743 }); 1744 } 1745 function matchPercentage() { 1746 var captures = scan(tokens.percentageValue); 1747 return captures ? captures[1] : null; 1748 } 1749 function matchVariableName() { 1750 return scan(tokens.variableName)[1]; 1751 } 1752 function matchNumber() { 1753 return scan(tokens.number)[1]; 1754 } 1755 function matchDistance() { 1756 return match5("%", tokens.percentageValue, 1) || matchPositionKeyword() || matchCalc() || matchLength(); 1757 } 1758 function matchPositionKeyword() { 1759 return match5("position-keyword", tokens.positionKeywords, 1); 1760 } 1761 function matchCalc() { 1762 return matchCall(tokens.calcValue, function() { 1763 var openParenCount = 1; 1764 var i3 = 0; 1765 while (openParenCount > 0 && i3 < input.length) { 1766 var char2 = input.charAt(i3); 1767 if (char2 === "(") { 1768 openParenCount++; 1769 } else if (char2 === ")") { 1770 openParenCount--; 1771 } 1772 i3++; 1773 } 1774 if (openParenCount > 0) { 1775 error("Missing closing parenthesis in calc() expression"); 1776 } 1777 var calcContent = input.substring(0, i3 - 1); 1778 consume(i3 - 1); 1779 return { 1780 type: "calc", 1781 value: calcContent 1782 }; 1783 }); 1784 } 1785 function matchLength() { 1786 return match5("px", tokens.pixelValue, 1) || match5("em", tokens.emValue, 1); 1787 } 1788 function match5(type, pattern, captureIndex) { 1789 var captures = scan(pattern); 1790 if (captures) { 1791 return { 1792 type, 1793 value: captures[captureIndex] 1794 }; 1795 } 1796 } 1797 function scan(regexp) { 1798 var captures, blankCaptures; 1799 blankCaptures = /^[\n\r\t\s]+/.exec(input); 1800 if (blankCaptures) { 1801 consume(blankCaptures[0].length); 1802 } 1803 captures = regexp.exec(input); 1804 if (captures) { 1805 consume(captures[0].length); 1806 } 1807 return captures; 1808 } 1809 function consume(size3) { 1810 input = input.substr(size3); 1811 } 1812 return function(code) { 1813 input = code.toString().trim(); 1814 if (input.endsWith(";")) { 1815 input = input.slice(0, -1); 1816 } 1817 return getAST(); 1818 }; 1819 })(); 1820 exports.parse = GradientParser.parse; 1821 exports.stringify = GradientParser.stringify; 1822 } 1823 }); 1824 1825 // package-external:@wordpress/dom 1826 var require_dom = __commonJS({ 1827 "package-external:@wordpress/dom"(exports, module) { 1828 module.exports = window.wp.dom; 1829 } 1830 }); 1831 1832 // package-external:@wordpress/date 1833 var require_date = __commonJS({ 1834 "package-external:@wordpress/date"(exports, module) { 1835 module.exports = window.wp.date; 1836 } 1837 }); 1838 1839 // package-external:@wordpress/escape-html 1840 var require_escape_html = __commonJS({ 1841 "package-external:@wordpress/escape-html"(exports, module) { 1842 module.exports = window.wp.escapeHtml; 1843 } 1844 }); 1845 1846 // package-external:@wordpress/html-entities 1847 var require_html_entities = __commonJS({ 1848 "package-external:@wordpress/html-entities"(exports, module) { 1849 module.exports = window.wp.htmlEntities; 1850 } 1851 }); 1852 1853 // node_modules/fast-memoize/src/index.js 1854 var require_src = __commonJS({ 1855 "node_modules/fast-memoize/src/index.js"(exports, module) { 1856 function memoize4(fn, options2) { 1857 var cache2 = options2 && options2.cache ? options2.cache : cacheDefault; 1858 var serializer = options2 && options2.serializer ? options2.serializer : serializerDefault; 1859 var strategy = options2 && options2.strategy ? options2.strategy : strategyDefault; 1860 return strategy(fn, { 1861 cache: cache2, 1862 serializer 1863 }); 1864 } 1865 function isPrimitive(value) { 1866 return value == null || typeof value === "number" || typeof value === "boolean"; 1867 } 1868 function monadic(fn, cache2, serializer, arg) { 1869 var cacheKey = isPrimitive(arg) ? arg : serializer(arg); 1870 var computedValue = cache2.get(cacheKey); 1871 if (typeof computedValue === "undefined") { 1872 computedValue = fn.call(this, arg); 1873 cache2.set(cacheKey, computedValue); 1874 } 1875 return computedValue; 1876 } 1877 function variadic(fn, cache2, serializer) { 1878 var args = Array.prototype.slice.call(arguments, 3); 1879 var cacheKey = serializer(args); 1880 var computedValue = cache2.get(cacheKey); 1881 if (typeof computedValue === "undefined") { 1882 computedValue = fn.apply(this, args); 1883 cache2.set(cacheKey, computedValue); 1884 } 1885 return computedValue; 1886 } 1887 function assemble(fn, context, strategy, cache2, serialize2) { 1888 return strategy.bind( 1889 context, 1890 fn, 1891 cache2, 1892 serialize2 1893 ); 1894 } 1895 function strategyDefault(fn, options2) { 1896 var strategy = fn.length === 1 ? monadic : variadic; 1897 return assemble( 1898 fn, 1899 this, 1900 strategy, 1901 options2.cache.create(), 1902 options2.serializer 1903 ); 1904 } 1905 function strategyVariadic(fn, options2) { 1906 var strategy = variadic; 1907 return assemble( 1908 fn, 1909 this, 1910 strategy, 1911 options2.cache.create(), 1912 options2.serializer 1913 ); 1914 } 1915 function strategyMonadic(fn, options2) { 1916 var strategy = monadic; 1917 return assemble( 1918 fn, 1919 this, 1920 strategy, 1921 options2.cache.create(), 1922 options2.serializer 1923 ); 1924 } 1925 function serializerDefault() { 1926 return JSON.stringify(arguments); 1927 } 1928 function ObjectWithoutPrototypeCache() { 1929 this.cache = /* @__PURE__ */ Object.create(null); 1930 } 1931 ObjectWithoutPrototypeCache.prototype.has = function(key) { 1932 return key in this.cache; 1933 }; 1934 ObjectWithoutPrototypeCache.prototype.get = function(key) { 1935 return this.cache[key]; 1936 }; 1937 ObjectWithoutPrototypeCache.prototype.set = function(key, value) { 1938 this.cache[key] = value; 1939 }; 1940 var cacheDefault = { 1941 create: function create2() { 1942 return new ObjectWithoutPrototypeCache(); 1943 } 1944 }; 1945 module.exports = memoize4; 1946 module.exports.strategies = { 1947 variadic: strategyVariadic, 1948 monadic: strategyMonadic 1949 }; 1950 } 1951 }); 1952 1953 // package-external:@wordpress/hooks 1954 var require_hooks = __commonJS({ 1955 "package-external:@wordpress/hooks"(exports, module) { 1956 module.exports = window.wp.hooks; 1957 } 1958 }); 1959 1960 // package-external:@wordpress/private-apis 1961 var require_private_apis = __commonJS({ 1962 "package-external:@wordpress/private-apis"(exports, module) { 1963 module.exports = window.wp.privateApis; 1964 } 1965 }); 1966 1967 // packages/components/build-module/index.js 1968 var index_exports = {}; 1969 __export(index_exports, { 1970 AlignmentMatrixControl: () => alignment_matrix_control_default, 1971 AnglePickerControl: () => angle_picker_control_default, 1972 Animate: () => animate_default, 1973 Autocomplete: () => Autocomplete, 1974 BaseControl: () => base_control_default, 1975 BlockQuotation: () => import_primitives36.BlockQuotation, 1976 BorderBoxControl: () => component_default24, 1977 BorderControl: () => component_default21, 1978 BoxControl: () => box_control_default, 1979 Button: () => button_default, 1980 ButtonGroup: () => button_group_default, 1981 Card: () => component_default27, 1982 CardBody: () => component_default29, 1983 CardDivider: () => component_default31, 1984 CardFooter: () => component_default32, 1985 CardHeader: () => component_default33, 1986 CardMedia: () => component_default34, 1987 CheckboxControl: () => checkbox_control_default, 1988 Circle: () => import_primitives36.Circle, 1989 ClipboardButton: () => ClipboardButton, 1990 ColorIndicator: () => color_indicator_default, 1991 ColorPalette: () => color_palette_default, 1992 ColorPicker: () => LegacyAdapter, 1993 ComboboxControl: () => combobox_control_default, 1994 Composite: () => Composite22, 1995 CustomGradientPicker: () => custom_gradient_picker_default, 1996 CustomSelectControl: () => custom_select_control_default, 1997 Dashicon: () => dashicon_default, 1998 DatePicker: () => date_default, 1999 DateTimePicker: () => date_time_default2, 2000 Disabled: () => disabled_default, 2001 Draggable: () => draggable_default, 2002 DropZone: () => drop_zone_default, 2003 DropZoneProvider: () => DropZoneProvider, 2004 Dropdown: () => dropdown_default, 2005 DropdownMenu: () => dropdown_menu_default, 2006 DuotonePicker: () => duotone_picker_default, 2007 DuotoneSwatch: () => duotone_swatch_default, 2008 ExternalLink: () => external_link_default, 2009 Fill: () => Fill3, 2010 Flex: () => component_default3, 2011 FlexBlock: () => component_default5, 2012 FlexItem: () => component_default4, 2013 FocalPointPicker: () => focal_point_picker_default, 2014 FocusReturnProvider: () => Provider3, 2015 FocusableIframe: () => FocusableIframe, 2016 FontSizePicker: () => font_size_picker_default, 2017 FormFileUpload: () => form_file_upload_default, 2018 FormToggle: () => form_toggle_default, 2019 FormTokenField: () => form_token_field_default, 2020 G: () => import_primitives36.G, 2021 GradientPicker: () => gradient_picker_default, 2022 Guide: () => guide_default, 2023 GuidePage: () => GuidePage, 2024 HorizontalRule: () => import_primitives36.HorizontalRule, 2025 Icon: () => icon_default3, 2026 IconButton: () => deprecated_default, 2027 IsolatedEventContainer: () => isolated_event_container_default, 2028 KeyboardShortcuts: () => keyboard_shortcuts_default, 2029 Line: () => import_primitives36.Line, 2030 MenuGroup: () => menu_group_default, 2031 MenuItem: () => menu_item_default, 2032 MenuItemsChoice: () => menu_items_choice_default, 2033 Modal: () => modal_default, 2034 NavigableMenu: () => menu_default2, 2035 Navigator: () => Navigator3, 2036 Notice: () => notice_default, 2037 NoticeList: () => list_default, 2038 Panel: () => panel_default, 2039 PanelBody: () => body_default, 2040 PanelHeader: () => header_default, 2041 PanelRow: () => row_default, 2042 Path: () => import_primitives36.Path, 2043 Placeholder: () => placeholder_default, 2044 Polygon: () => import_primitives36.Polygon, 2045 Popover: () => popover_default, 2046 ProgressBar: () => progress_bar_default, 2047 QueryControls: () => query_controls_default, 2048 RadioControl: () => radio_control_default, 2049 RangeControl: () => range_control_default, 2050 Rect: () => import_primitives36.Rect, 2051 ResizableBox: () => resizable_box_default, 2052 ResponsiveWrapper: () => responsive_wrapper_default, 2053 SVG: () => import_primitives36.SVG, 2054 SandBox: () => sandbox_default, 2055 ScrollLock: () => scroll_lock_default, 2056 SearchControl: () => search_control_default, 2057 SelectControl: () => select_control_default, 2058 Slot: () => Slot3, 2059 SlotFillProvider: () => Provider, 2060 Snackbar: () => snackbar_default, 2061 SnackbarList: () => list_default2, 2062 Spinner: () => spinner_default, 2063 TabPanel: () => tab_panel_default, 2064 TabbableContainer: () => tabbable_default, 2065 TextControl: () => text_control_default, 2066 TextHighlight: () => text_highlight_default, 2067 TextareaControl: () => textarea_control_default, 2068 TimePicker: () => time_default, 2069 Tip: () => tip_default2, 2070 ToggleControl: () => toggle_control_default, 2071 Toolbar: () => toolbar_default, 2072 ToolbarButton: () => toolbar_button_default, 2073 ToolbarDropdownMenu: () => toolbar_dropdown_menu_default, 2074 ToolbarGroup: () => toolbar_group_default, 2075 ToolbarItem: () => toolbar_item_default, 2076 Tooltip: () => tooltip_default, 2077 TreeSelect: () => tree_select_default, 2078 VisuallyHidden: () => component_default2, 2079 __experimentalAlignmentMatrixControl: () => alignment_matrix_control_default, 2080 __experimentalApplyValueToSides: () => applyValueToSides, 2081 __experimentalBorderBoxControl: () => component_default24, 2082 __experimentalBorderControl: () => component_default21, 2083 __experimentalBoxControl: () => box_control_default, 2084 __experimentalConfirmDialog: () => component_default37, 2085 __experimentalDivider: () => component_default30, 2086 __experimentalDropdownContentWrapper: () => dropdown_content_wrapper_default, 2087 __experimentalElevation: () => component_default25, 2088 __experimentalGrid: () => component_default22, 2089 __experimentalHStack: () => component_default9, 2090 __experimentalHasSplitBorders: () => hasSplitBorders, 2091 __experimentalHeading: () => component_default19, 2092 __experimentalInputControl: () => input_control_default, 2093 __experimentalInputControlPrefixWrapper: () => input_prefix_wrapper_default, 2094 __experimentalInputControlSuffixWrapper: () => input_suffix_wrapper_default, 2095 __experimentalIsDefinedBorder: () => isDefinedBorder, 2096 __experimentalIsEmptyBorder: () => isEmptyBorder, 2097 __experimentalItem: () => component_default35, 2098 __experimentalItemGroup: () => component_default36, 2099 __experimentalNavigation: () => navigation_default, 2100 __experimentalNavigationBackButton: () => back_button_default, 2101 __experimentalNavigationGroup: () => group_default, 2102 __experimentalNavigationItem: () => item_default2, 2103 __experimentalNavigationMenu: () => menu_default3, 2104 __experimentalNavigatorBackButton: () => NavigatorBackButton2, 2105 __experimentalNavigatorButton: () => NavigatorButton2, 2106 __experimentalNavigatorProvider: () => NavigatorProvider, 2107 __experimentalNavigatorScreen: () => NavigatorScreen2, 2108 __experimentalNavigatorToParentButton: () => NavigatorToParentButton2, 2109 __experimentalNumberControl: () => number_control_default, 2110 __experimentalPaletteEdit: () => palette_edit_default, 2111 __experimentalParseQuantityAndUnitFromRawValue: () => parseQuantityAndUnitFromRawValue, 2112 __experimentalRadio: () => radio_default, 2113 __experimentalRadioGroup: () => radio_group_default, 2114 __experimentalScrollable: () => component_default28, 2115 __experimentalSpacer: () => component_default6, 2116 __experimentalStyleProvider: () => style_provider_default, 2117 __experimentalSurface: () => component_default26, 2118 __experimentalText: () => component_default8, 2119 __experimentalToggleGroupControl: () => component_default12, 2120 __experimentalToggleGroupControlOption: () => component_default14, 2121 __experimentalToggleGroupControlOptionIcon: () => component_default15, 2122 __experimentalToolbarContext: () => toolbar_context_default, 2123 __experimentalToolsPanel: () => component_default39, 2124 __experimentalToolsPanelContext: () => ToolsPanelContext, 2125 __experimentalToolsPanelItem: () => component_default40, 2126 __experimentalTreeGrid: () => tree_grid_default, 2127 __experimentalTreeGridCell: () => cell_default, 2128 __experimentalTreeGridItem: () => item_default3, 2129 __experimentalTreeGridRow: () => row_default2, 2130 __experimentalTruncate: () => component_default7, 2131 __experimentalUnitControl: () => unit_control_default, 2132 __experimentalUseCustomUnits: () => useCustomUnits, 2133 __experimentalUseNavigator: () => useNavigator, 2134 __experimentalUseSlot: () => useSlot, 2135 __experimentalUseSlotFills: () => useSlotFills, 2136 __experimentalVStack: () => component_default18, 2137 __experimentalView: () => component_default, 2138 __experimentalZStack: () => component_default41, 2139 __unstableAnimatePresence: () => AnimatePresence, 2140 __unstableComposite: () => Composite4, 2141 __unstableCompositeGroup: () => CompositeGroup4, 2142 __unstableCompositeItem: () => CompositeItem4, 2143 __unstableDisclosureContent: () => DisclosureContent22, 2144 __unstableGetAnimateClassName: () => getAnimateClassName, 2145 __unstableMotion: () => motion, 2146 __unstableUseAutocompleteProps: () => useAutocompleteProps, 2147 __unstableUseCompositeState: () => useCompositeState, 2148 __unstableUseNavigateRegions: () => useNavigateRegions, 2149 createSlotFill: () => createSlotFill, 2150 navigateRegions: () => navigate_regions_default, 2151 privateApis: () => privateApis, 2152 useBaseControlProps: () => useBaseControlProps, 2153 useNavigator: () => useNavigator, 2154 withConstrainedTabbing: () => with_constrained_tabbing_default, 2155 withFallbackStyles: () => with_fallback_styles_default, 2156 withFilters: () => withFilters, 2157 withFocusOutside: () => with_focus_outside_default, 2158 withFocusReturn: () => with_focus_return_default, 2159 withNotices: () => with_notices_default, 2160 withSpokenMessages: () => with_spoken_messages_default 2161 }); 2162 var import_primitives36 = __toESM(require_primitives()); 2163 2164 // node_modules/clsx/dist/clsx.mjs 2165 function r(e3) { 2166 var t4, f3, n3 = ""; 2167 if ("string" == typeof e3 || "number" == typeof e3) n3 += e3; 2168 else if ("object" == typeof e3) if (Array.isArray(e3)) { 2169 var o4 = e3.length; 2170 for (t4 = 0; t4 < o4; t4++) e3[t4] && (f3 = r(e3[t4])) && (n3 && (n3 += " "), n3 += f3); 2171 } else for (f3 in e3) e3[f3] && (n3 && (n3 += " "), n3 += f3); 2172 return n3; 2173 } 2174 function clsx() { 2175 for (var e3, t4, f3 = 0, n3 = "", o4 = arguments.length; f3 < o4; f3++) (e3 = arguments[f3]) && (t4 = r(e3)) && (n3 && (n3 += " "), n3 += t4); 2176 return n3; 2177 } 2178 var clsx_default = clsx; 2179 2180 // packages/components/build-module/alignment-matrix-control/index.js 2181 var import_i18n4 = __toESM(require_i18n()); 2182 var import_compose2 = __toESM(require_compose()); 2183 var import_element17 = __toESM(require_element()); 2184 2185 // node_modules/@ariakit/react-core/esm/__chunks/3YLGPPWQ.js 2186 var __defProp2 = Object.defineProperty; 2187 var __defProps = Object.defineProperties; 2188 var __getOwnPropDescs = Object.getOwnPropertyDescriptors; 2189 var __getOwnPropSymbols = Object.getOwnPropertySymbols; 2190 var __hasOwnProp2 = Object.prototype.hasOwnProperty; 2191 var __propIsEnum = Object.prototype.propertyIsEnumerable; 2192 var __defNormalProp = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; 2193 var __spreadValues = (a3, b3) => { 2194 for (var prop in b3 || (b3 = {})) 2195 if (__hasOwnProp2.call(b3, prop)) 2196 __defNormalProp(a3, prop, b3[prop]); 2197 if (__getOwnPropSymbols) 2198 for (var prop of __getOwnPropSymbols(b3)) { 2199 if (__propIsEnum.call(b3, prop)) 2200 __defNormalProp(a3, prop, b3[prop]); 2201 } 2202 return a3; 2203 }; 2204 var __spreadProps = (a3, b3) => __defProps(a3, __getOwnPropDescs(b3)); 2205 var __objRest = (source, exclude) => { 2206 var target = {}; 2207 for (var prop in source) 2208 if (__hasOwnProp2.call(source, prop) && exclude.indexOf(prop) < 0) 2209 target[prop] = source[prop]; 2210 if (source != null && __getOwnPropSymbols) 2211 for (var prop of __getOwnPropSymbols(source)) { 2212 if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) 2213 target[prop] = source[prop]; 2214 } 2215 return target; 2216 }; 2217 2218 // node_modules/@ariakit/core/esm/__chunks/3YLGPPWQ.js 2219 var __defProp3 = Object.defineProperty; 2220 var __defProps2 = Object.defineProperties; 2221 var __getOwnPropDescs2 = Object.getOwnPropertyDescriptors; 2222 var __getOwnPropSymbols2 = Object.getOwnPropertySymbols; 2223 var __hasOwnProp3 = Object.prototype.hasOwnProperty; 2224 var __propIsEnum2 = Object.prototype.propertyIsEnumerable; 2225 var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; 2226 var __spreadValues2 = (a3, b3) => { 2227 for (var prop in b3 || (b3 = {})) 2228 if (__hasOwnProp3.call(b3, prop)) 2229 __defNormalProp2(a3, prop, b3[prop]); 2230 if (__getOwnPropSymbols2) 2231 for (var prop of __getOwnPropSymbols2(b3)) { 2232 if (__propIsEnum2.call(b3, prop)) 2233 __defNormalProp2(a3, prop, b3[prop]); 2234 } 2235 return a3; 2236 }; 2237 var __spreadProps2 = (a3, b3) => __defProps2(a3, __getOwnPropDescs2(b3)); 2238 var __objRest2 = (source, exclude) => { 2239 var target = {}; 2240 for (var prop in source) 2241 if (__hasOwnProp3.call(source, prop) && exclude.indexOf(prop) < 0) 2242 target[prop] = source[prop]; 2243 if (source != null && __getOwnPropSymbols2) 2244 for (var prop of __getOwnPropSymbols2(source)) { 2245 if (exclude.indexOf(prop) < 0 && __propIsEnum2.call(source, prop)) 2246 target[prop] = source[prop]; 2247 } 2248 return target; 2249 }; 2250 2251 // node_modules/@ariakit/core/esm/__chunks/PBFD2E7P.js 2252 function noop(..._) { 2253 } 2254 function shallowEqual(a3, b3) { 2255 if (a3 === b3) return true; 2256 if (!a3) return false; 2257 if (!b3) return false; 2258 if (typeof a3 !== "object") return false; 2259 if (typeof b3 !== "object") return false; 2260 const aKeys = Object.keys(a3); 2261 const bKeys = Object.keys(b3); 2262 const { length: length2 } = aKeys; 2263 if (bKeys.length !== length2) return false; 2264 for (const key of aKeys) { 2265 if (a3[key] !== b3[key]) { 2266 return false; 2267 } 2268 } 2269 return true; 2270 } 2271 function applyState(argument, currentValue) { 2272 if (isUpdater(argument)) { 2273 const value = isLazyValue(currentValue) ? currentValue() : currentValue; 2274 return argument(value); 2275 } 2276 return argument; 2277 } 2278 function isUpdater(argument) { 2279 return typeof argument === "function"; 2280 } 2281 function isLazyValue(value) { 2282 return typeof value === "function"; 2283 } 2284 function hasOwnProperty(object, prop) { 2285 if (typeof Object.hasOwn === "function") { 2286 return Object.hasOwn(object, prop); 2287 } 2288 return Object.prototype.hasOwnProperty.call(object, prop); 2289 } 2290 function chain(...fns) { 2291 return (...args) => { 2292 for (const fn of fns) { 2293 if (typeof fn === "function") { 2294 fn(...args); 2295 } 2296 } 2297 }; 2298 } 2299 function normalizeString(str) { 2300 return str.normalize("NFD").replace(/[\u0300-\u036f]/g, ""); 2301 } 2302 function omit(object, keys) { 2303 const result = __spreadValues2({}, object); 2304 for (const key of keys) { 2305 if (hasOwnProperty(result, key)) { 2306 delete result[key]; 2307 } 2308 } 2309 return result; 2310 } 2311 function pick(object, paths) { 2312 const result = {}; 2313 for (const key of paths) { 2314 if (hasOwnProperty(object, key)) { 2315 result[key] = object[key]; 2316 } 2317 } 2318 return result; 2319 } 2320 function identity(value) { 2321 return value; 2322 } 2323 function invariant(condition, message3) { 2324 if (condition) return; 2325 if (typeof message3 !== "string") throw new Error("Invariant failed"); 2326 throw new Error(message3); 2327 } 2328 function getKeys(obj) { 2329 return Object.keys(obj); 2330 } 2331 function isFalsyBooleanCallback(booleanOrCallback, ...args) { 2332 const result = typeof booleanOrCallback === "function" ? booleanOrCallback(...args) : booleanOrCallback; 2333 if (result == null) return false; 2334 return !result; 2335 } 2336 function disabledFromProps(props) { 2337 return props.disabled || props["aria-disabled"] === true || props["aria-disabled"] === "true"; 2338 } 2339 function removeUndefinedValues(obj) { 2340 const result = {}; 2341 for (const key in obj) { 2342 if (obj[key] !== void 0) { 2343 result[key] = obj[key]; 2344 } 2345 } 2346 return result; 2347 } 2348 function defaultValue(...values) { 2349 for (const value of values) { 2350 if (value !== void 0) return value; 2351 } 2352 return void 0; 2353 } 2354 2355 // node_modules/@ariakit/react-core/esm/__chunks/SK3NAZA3.js 2356 var import_react = __toESM(require_react(), 1); 2357 function setRef(ref, value) { 2358 if (typeof ref === "function") { 2359 ref(value); 2360 } else if (ref) { 2361 ref.current = value; 2362 } 2363 } 2364 function isValidElementWithRef(element) { 2365 if (!element) return false; 2366 if (!(0, import_react.isValidElement)(element)) return false; 2367 if ("ref" in element.props) return true; 2368 if ("ref" in element) return true; 2369 return false; 2370 } 2371 function getRefProperty(element) { 2372 if (!isValidElementWithRef(element)) return null; 2373 const props = __spreadValues({}, element.props); 2374 return props.ref || element.ref; 2375 } 2376 function mergeProps(base, overrides) { 2377 const props = __spreadValues({}, base); 2378 for (const key in overrides) { 2379 if (!hasOwnProperty(overrides, key)) continue; 2380 if (key === "className") { 2381 const prop = "className"; 2382 props[prop] = base[prop] ? `$base[prop]} $overrides[prop]}` : overrides[prop]; 2383 continue; 2384 } 2385 if (key === "style") { 2386 const prop = "style"; 2387 props[prop] = base[prop] ? __spreadValues(__spreadValues({}, base[prop]), overrides[prop]) : overrides[prop]; 2388 continue; 2389 } 2390 const overrideValue = overrides[key]; 2391 if (typeof overrideValue === "function" && key.startsWith("on")) { 2392 const baseValue = base[key]; 2393 if (typeof baseValue === "function") { 2394 props[key] = (...args) => { 2395 overrideValue(...args); 2396 baseValue(...args); 2397 }; 2398 continue; 2399 } 2400 } 2401 props[key] = overrideValue; 2402 } 2403 return props; 2404 } 2405 2406 // node_modules/@ariakit/core/esm/__chunks/DTR5TSDJ.js 2407 var canUseDOM = checkIsBrowser(); 2408 function checkIsBrowser() { 2409 var _a; 2410 return typeof window !== "undefined" && !!((_a = window.document) == null ? void 0 : _a.createElement); 2411 } 2412 function getDocument(node2) { 2413 if (!node2) return document; 2414 if ("self" in node2) return node2.document; 2415 return node2.ownerDocument || document; 2416 } 2417 function getWindow(node2) { 2418 if (!node2) return self; 2419 if ("self" in node2) return node2.self; 2420 return getDocument(node2).defaultView || window; 2421 } 2422 function getActiveElement(node2, activeDescendant = false) { 2423 const { activeElement } = getDocument(node2); 2424 if (!(activeElement == null ? void 0 : activeElement.nodeName)) { 2425 return null; 2426 } 2427 if (isFrame(activeElement) && activeElement.contentDocument) { 2428 return getActiveElement( 2429 activeElement.contentDocument.body, 2430 activeDescendant 2431 ); 2432 } 2433 if (activeDescendant) { 2434 const id3 = activeElement.getAttribute("aria-activedescendant"); 2435 if (id3) { 2436 const element = getDocument(activeElement).getElementById(id3); 2437 if (element) { 2438 return element; 2439 } 2440 } 2441 } 2442 return activeElement; 2443 } 2444 function contains(parent, child) { 2445 return parent === child || parent.contains(child); 2446 } 2447 function isFrame(element) { 2448 return element.tagName === "IFRAME"; 2449 } 2450 function isButton(element) { 2451 const tagName = element.tagName.toLowerCase(); 2452 if (tagName === "button") return true; 2453 if (tagName === "input" && element.type) { 2454 return buttonInputTypes.indexOf(element.type) !== -1; 2455 } 2456 return false; 2457 } 2458 var buttonInputTypes = [ 2459 "button", 2460 "color", 2461 "file", 2462 "image", 2463 "reset", 2464 "submit" 2465 ]; 2466 function isVisible(element) { 2467 if (typeof element.checkVisibility === "function") { 2468 return element.checkVisibility(); 2469 } 2470 const htmlElement = element; 2471 return htmlElement.offsetWidth > 0 || htmlElement.offsetHeight > 0 || element.getClientRects().length > 0; 2472 } 2473 function isTextField(element) { 2474 try { 2475 const isTextInput = element instanceof HTMLInputElement && element.selectionStart !== null; 2476 const isTextArea = element.tagName === "TEXTAREA"; 2477 return isTextInput || isTextArea || false; 2478 } catch (error) { 2479 return false; 2480 } 2481 } 2482 function isTextbox(element) { 2483 return element.isContentEditable || isTextField(element); 2484 } 2485 function getTextboxValue(element) { 2486 if (isTextField(element)) { 2487 return element.value; 2488 } 2489 if (element.isContentEditable) { 2490 const range = getDocument(element).createRange(); 2491 range.selectNodeContents(element); 2492 return range.toString(); 2493 } 2494 return ""; 2495 } 2496 function getTextboxSelection(element) { 2497 let start = 0; 2498 let end = 0; 2499 if (isTextField(element)) { 2500 start = element.selectionStart || 0; 2501 end = element.selectionEnd || 0; 2502 } else if (element.isContentEditable) { 2503 const selection = getDocument(element).getSelection(); 2504 if ((selection == null ? void 0 : selection.rangeCount) && selection.anchorNode && contains(element, selection.anchorNode) && selection.focusNode && contains(element, selection.focusNode)) { 2505 const range = selection.getRangeAt(0); 2506 const nextRange = range.cloneRange(); 2507 nextRange.selectNodeContents(element); 2508 nextRange.setEnd(range.startContainer, range.startOffset); 2509 start = nextRange.toString().length; 2510 nextRange.setEnd(range.endContainer, range.endOffset); 2511 end = nextRange.toString().length; 2512 } 2513 } 2514 return { start, end }; 2515 } 2516 function getPopupRole(element, fallback) { 2517 const allowedPopupRoles = ["dialog", "menu", "listbox", "tree", "grid"]; 2518 const role = element == null ? void 0 : element.getAttribute("role"); 2519 if (role && allowedPopupRoles.indexOf(role) !== -1) { 2520 return role; 2521 } 2522 return fallback; 2523 } 2524 function getPopupItemRole(element, fallback) { 2525 var _a; 2526 const itemRoleByPopupRole = { 2527 menu: "menuitem", 2528 listbox: "option", 2529 tree: "treeitem" 2530 }; 2531 const popupRole = getPopupRole(element); 2532 if (!popupRole) return fallback; 2533 const key = popupRole; 2534 return (_a = itemRoleByPopupRole[key]) != null ? _a : fallback; 2535 } 2536 function getScrollingElement(element) { 2537 if (!element) return null; 2538 const isScrollableOverflow = (overflow) => { 2539 if (overflow === "auto") return true; 2540 if (overflow === "scroll") return true; 2541 return false; 2542 }; 2543 if (element.clientHeight && element.scrollHeight > element.clientHeight) { 2544 const { overflowY } = getComputedStyle(element); 2545 if (isScrollableOverflow(overflowY)) return element; 2546 } else if (element.clientWidth && element.scrollWidth > element.clientWidth) { 2547 const { overflowX } = getComputedStyle(element); 2548 if (isScrollableOverflow(overflowX)) return element; 2549 } 2550 return getScrollingElement(element.parentElement) || document.scrollingElement || document.body; 2551 } 2552 function sortBasedOnDOMPosition(items, getElement) { 2553 const pairs = items.map((item2, index2) => [index2, item2]); 2554 let isOrderDifferent = false; 2555 pairs.sort(([indexA, a3], [indexB, b3]) => { 2556 const elementA = getElement(a3); 2557 const elementB = getElement(b3); 2558 if (elementA === elementB) return 0; 2559 if (!elementA || !elementB) return 0; 2560 if (isElementPreceding(elementA, elementB)) { 2561 if (indexA > indexB) { 2562 isOrderDifferent = true; 2563 } 2564 return -1; 2565 } 2566 if (indexA < indexB) { 2567 isOrderDifferent = true; 2568 } 2569 return 1; 2570 }); 2571 if (isOrderDifferent) { 2572 return pairs.map(([_, item2]) => item2); 2573 } 2574 return items; 2575 } 2576 function isElementPreceding(a3, b3) { 2577 return Boolean( 2578 b3.compareDocumentPosition(a3) & Node.DOCUMENT_POSITION_PRECEDING 2579 ); 2580 } 2581 2582 // node_modules/@ariakit/core/esm/__chunks/QAGXQEUG.js 2583 function isTouchDevice() { 2584 return canUseDOM && !!navigator.maxTouchPoints; 2585 } 2586 function isApple() { 2587 if (!canUseDOM) return false; 2588 return /mac|iphone|ipad|ipod/i.test(navigator.platform); 2589 } 2590 function isSafari() { 2591 return canUseDOM && isApple() && /apple/i.test(navigator.vendor); 2592 } 2593 function isFirefox() { 2594 return canUseDOM && /firefox\//i.test(navigator.userAgent); 2595 } 2596 function isMac() { 2597 return canUseDOM && navigator.platform.startsWith("Mac") && !isTouchDevice(); 2598 } 2599 2600 // node_modules/@ariakit/core/esm/utils/events.js 2601 function isPortalEvent(event) { 2602 return Boolean( 2603 event.currentTarget && !contains(event.currentTarget, event.target) 2604 ); 2605 } 2606 function isSelfTarget(event) { 2607 return event.target === event.currentTarget; 2608 } 2609 function isOpeningInNewTab(event) { 2610 const element = event.currentTarget; 2611 if (!element) return false; 2612 const isAppleDevice = isApple(); 2613 if (isAppleDevice && !event.metaKey) return false; 2614 if (!isAppleDevice && !event.ctrlKey) return false; 2615 const tagName = element.tagName.toLowerCase(); 2616 if (tagName === "a") return true; 2617 if (tagName === "button" && element.type === "submit") return true; 2618 if (tagName === "input" && element.type === "submit") return true; 2619 return false; 2620 } 2621 function isDownloading(event) { 2622 const element = event.currentTarget; 2623 if (!element) return false; 2624 const tagName = element.tagName.toLowerCase(); 2625 if (!event.altKey) return false; 2626 if (tagName === "a") return true; 2627 if (tagName === "button" && element.type === "submit") return true; 2628 if (tagName === "input" && element.type === "submit") return true; 2629 return false; 2630 } 2631 function fireEvent(element, type, eventInit) { 2632 const event = new Event(type, eventInit); 2633 return element.dispatchEvent(event); 2634 } 2635 function fireBlurEvent(element, eventInit) { 2636 const event = new FocusEvent("blur", eventInit); 2637 const defaultAllowed = element.dispatchEvent(event); 2638 const bubbleInit = __spreadProps2(__spreadValues2({}, eventInit), { bubbles: true }); 2639 element.dispatchEvent(new FocusEvent("focusout", bubbleInit)); 2640 return defaultAllowed; 2641 } 2642 function fireKeyboardEvent(element, type, eventInit) { 2643 const event = new KeyboardEvent(type, eventInit); 2644 return element.dispatchEvent(event); 2645 } 2646 function fireClickEvent(element, eventInit) { 2647 const event = new MouseEvent("click", eventInit); 2648 return element.dispatchEvent(event); 2649 } 2650 function isFocusEventOutside(event, container) { 2651 const containerElement = container || event.currentTarget; 2652 const relatedTarget = event.relatedTarget; 2653 return !relatedTarget || !contains(containerElement, relatedTarget); 2654 } 2655 function queueBeforeEvent(element, type, callback, timeout) { 2656 const createTimer = (callback2) => { 2657 if (timeout) { 2658 const timerId2 = setTimeout(callback2, timeout); 2659 return () => clearTimeout(timerId2); 2660 } 2661 const timerId = requestAnimationFrame(callback2); 2662 return () => cancelAnimationFrame(timerId); 2663 }; 2664 const cancelTimer = createTimer(() => { 2665 element.removeEventListener(type, callSync, true); 2666 callback(); 2667 }); 2668 const callSync = () => { 2669 cancelTimer(); 2670 callback(); 2671 }; 2672 element.addEventListener(type, callSync, { once: true, capture: true }); 2673 return cancelTimer; 2674 } 2675 function addGlobalEventListener(type, listener, options2, scope = window) { 2676 const children = []; 2677 try { 2678 scope.document.addEventListener(type, listener, options2); 2679 for (const frame2 of Array.from(scope.frames)) { 2680 children.push(addGlobalEventListener(type, listener, options2, frame2)); 2681 } 2682 } catch (e3) { 2683 } 2684 const removeEventListener = () => { 2685 try { 2686 scope.document.removeEventListener(type, listener, options2); 2687 } catch (e3) { 2688 } 2689 for (const remove of children) { 2690 remove(); 2691 } 2692 }; 2693 return removeEventListener; 2694 } 2695 2696 // node_modules/@ariakit/react-core/esm/__chunks/ABQUS43J.js 2697 var import_react2 = __toESM(require_react(), 1); 2698 var React = __toESM(require_react(), 1); 2699 var _React = __spreadValues({}, React); 2700 var useReactId = _React.useId; 2701 var useReactDeferredValue = _React.useDeferredValue; 2702 var useReactInsertionEffect = _React.useInsertionEffect; 2703 var useSafeLayoutEffect = canUseDOM ? import_react2.useLayoutEffect : import_react2.useEffect; 2704 function useInitialValue(value) { 2705 const [initialValue2] = (0, import_react2.useState)(value); 2706 return initialValue2; 2707 } 2708 function useLiveRef(value) { 2709 const ref = (0, import_react2.useRef)(value); 2710 useSafeLayoutEffect(() => { 2711 ref.current = value; 2712 }); 2713 return ref; 2714 } 2715 function useEvent(callback) { 2716 const ref = (0, import_react2.useRef)(() => { 2717 throw new Error("Cannot call an event handler while rendering."); 2718 }); 2719 if (useReactInsertionEffect) { 2720 useReactInsertionEffect(() => { 2721 ref.current = callback; 2722 }); 2723 } else { 2724 ref.current = callback; 2725 } 2726 return (0, import_react2.useCallback)((...args) => { 2727 var _a; 2728 return (_a = ref.current) == null ? void 0 : _a.call(ref, ...args); 2729 }, []); 2730 } 2731 function useTransactionState(callback) { 2732 const [state, setState] = (0, import_react2.useState)(null); 2733 useSafeLayoutEffect(() => { 2734 if (state == null) return; 2735 if (!callback) return; 2736 let prevState = null; 2737 callback((prev2) => { 2738 prevState = prev2; 2739 return state; 2740 }); 2741 return () => { 2742 callback(prevState); 2743 }; 2744 }, [state, callback]); 2745 return [state, setState]; 2746 } 2747 function useMergeRefs(...refs) { 2748 return (0, import_react2.useMemo)(() => { 2749 if (!refs.some(Boolean)) return; 2750 return (value) => { 2751 for (const ref of refs) { 2752 setRef(ref, value); 2753 } 2754 }; 2755 }, refs); 2756 } 2757 function useId(defaultId) { 2758 if (useReactId) { 2759 const reactId = useReactId(); 2760 if (defaultId) return defaultId; 2761 return reactId; 2762 } 2763 const [id3, setId] = (0, import_react2.useState)(defaultId); 2764 useSafeLayoutEffect(() => { 2765 if (defaultId || id3) return; 2766 const random = Math.random().toString(36).slice(2, 8); 2767 setId(`id-$random}`); 2768 }, [defaultId, id3]); 2769 return defaultId || id3; 2770 } 2771 function useTagName(refOrElement, type) { 2772 const stringOrUndefined = (type2) => { 2773 if (typeof type2 !== "string") return; 2774 return type2; 2775 }; 2776 const [tagName, setTagName] = (0, import_react2.useState)(() => stringOrUndefined(type)); 2777 useSafeLayoutEffect(() => { 2778 const element = refOrElement && "current" in refOrElement ? refOrElement.current : refOrElement; 2779 setTagName((element == null ? void 0 : element.tagName.toLowerCase()) || stringOrUndefined(type)); 2780 }, [refOrElement, type]); 2781 return tagName; 2782 } 2783 function useAttribute(refOrElement, attributeName, defaultValue2) { 2784 const initialValue2 = useInitialValue(defaultValue2); 2785 const [attribute, setAttribute2] = (0, import_react2.useState)(initialValue2); 2786 (0, import_react2.useEffect)(() => { 2787 const element = refOrElement && "current" in refOrElement ? refOrElement.current : refOrElement; 2788 if (!element) return; 2789 const callback = () => { 2790 const value = element.getAttribute(attributeName); 2791 setAttribute2(value == null ? initialValue2 : value); 2792 }; 2793 const observer = new MutationObserver(callback); 2794 observer.observe(element, { attributeFilter: [attributeName] }); 2795 callback(); 2796 return () => observer.disconnect(); 2797 }, [refOrElement, attributeName, initialValue2]); 2798 return attribute; 2799 } 2800 function useUpdateEffect(effect, deps) { 2801 const mounted = (0, import_react2.useRef)(false); 2802 (0, import_react2.useEffect)(() => { 2803 if (mounted.current) { 2804 return effect(); 2805 } 2806 mounted.current = true; 2807 }, deps); 2808 (0, import_react2.useEffect)( 2809 () => () => { 2810 mounted.current = false; 2811 }, 2812 [] 2813 ); 2814 } 2815 function useForceUpdate() { 2816 return (0, import_react2.useReducer)(() => [], []); 2817 } 2818 function useBooleanEvent(booleanOrCallback) { 2819 return useEvent( 2820 typeof booleanOrCallback === "function" ? booleanOrCallback : () => booleanOrCallback 2821 ); 2822 } 2823 function useWrapElement(props, callback, deps = []) { 2824 const wrapElement = (0, import_react2.useCallback)( 2825 (element) => { 2826 if (props.wrapElement) { 2827 element = props.wrapElement(element); 2828 } 2829 return callback(element); 2830 }, 2831 [...deps, props.wrapElement] 2832 ); 2833 return __spreadProps(__spreadValues({}, props), { wrapElement }); 2834 } 2835 function usePortalRef(portalProp = false, portalRefProp) { 2836 const [portalNode, setPortalNode] = (0, import_react2.useState)(null); 2837 const portalRef = useMergeRefs(setPortalNode, portalRefProp); 2838 const domReady = !portalProp || portalNode; 2839 return { portalRef, portalNode, domReady }; 2840 } 2841 function useMetadataProps(props, key, value) { 2842 const parent = props.onLoadedMetadataCapture; 2843 const onLoadedMetadataCapture = (0, import_react2.useMemo)(() => { 2844 return Object.assign(() => { 2845 }, __spreadProps(__spreadValues({}, parent), { [key]: value })); 2846 }, [parent, key, value]); 2847 return [parent == null ? void 0 : parent[key], { onLoadedMetadataCapture }]; 2848 } 2849 function useIsMouseMoving() { 2850 (0, import_react2.useEffect)(() => { 2851 addGlobalEventListener("mousemove", setMouseMoving, true); 2852 addGlobalEventListener("mousedown", resetMouseMoving, true); 2853 addGlobalEventListener("mouseup", resetMouseMoving, true); 2854 addGlobalEventListener("keydown", resetMouseMoving, true); 2855 addGlobalEventListener("scroll", resetMouseMoving, true); 2856 }, []); 2857 const isMouseMoving = useEvent(() => mouseMoving); 2858 return isMouseMoving; 2859 } 2860 var mouseMoving = false; 2861 var previousScreenX = 0; 2862 var previousScreenY = 0; 2863 function hasMouseMovement(event) { 2864 const movementX = event.movementX || event.screenX - previousScreenX; 2865 const movementY = event.movementY || event.screenY - previousScreenY; 2866 previousScreenX = event.screenX; 2867 previousScreenY = event.screenY; 2868 return movementX || movementY || false; 2869 } 2870 function setMouseMoving(event) { 2871 if (!hasMouseMovement(event)) return; 2872 mouseMoving = true; 2873 } 2874 function resetMouseMoving() { 2875 mouseMoving = false; 2876 } 2877 2878 // node_modules/@ariakit/react-core/esm/__chunks/LMDWO4NN.js 2879 var React2 = __toESM(require_react(), 1); 2880 var import_jsx_runtime = __toESM(require_jsx_runtime(), 1); 2881 function forwardRef2(render) { 2882 const Role3 = React2.forwardRef((props, ref) => render(__spreadProps(__spreadValues({}, props), { ref }))); 2883 Role3.displayName = render.displayName || render.name; 2884 return Role3; 2885 } 2886 function memo2(Component9, propsAreEqual) { 2887 return React2.memo(Component9, propsAreEqual); 2888 } 2889 function createElement(Type, props) { 2890 const _a = props, { wrapElement, render } = _a, rest = __objRest(_a, ["wrapElement", "render"]); 2891 const mergedRef = useMergeRefs(props.ref, getRefProperty(render)); 2892 let element; 2893 if (React2.isValidElement(render)) { 2894 const renderProps = __spreadProps(__spreadValues({}, render.props), { ref: mergedRef }); 2895 element = React2.cloneElement(render, mergeProps(rest, renderProps)); 2896 } else if (render) { 2897 element = render(rest); 2898 } else { 2899 element = /* @__PURE__ */ (0, import_jsx_runtime.jsx)(Type, __spreadValues({}, rest)); 2900 } 2901 if (wrapElement) { 2902 return wrapElement(element); 2903 } 2904 return element; 2905 } 2906 function createHook(useProps) { 2907 const useRole3 = (props = {}) => { 2908 return useProps(props); 2909 }; 2910 useRole3.displayName = useProps.name; 2911 return useRole3; 2912 } 2913 function createStoreContext(providers = [], scopedProviders = []) { 2914 const context = React2.createContext(void 0); 2915 const scopedContext = React2.createContext(void 0); 2916 const useContext210 = () => React2.useContext(context); 2917 const useScopedContext = (onlyScoped = false) => { 2918 const scoped = React2.useContext(scopedContext); 2919 const store = useContext210(); 2920 if (onlyScoped) return scoped; 2921 return scoped || store; 2922 }; 2923 const useProviderContext = () => { 2924 const scoped = React2.useContext(scopedContext); 2925 const store = useContext210(); 2926 if (scoped && scoped === store) return; 2927 return store; 2928 }; 2929 const ContextProvider = (props) => { 2930 return providers.reduceRight( 2931 (children, Provider4) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(Provider4, __spreadProps(__spreadValues({}, props), { children })), 2932 /* @__PURE__ */ (0, import_jsx_runtime.jsx)(context.Provider, __spreadValues({}, props)) 2933 ); 2934 }; 2935 const ScopedContextProvider = (props) => { 2936 return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(ContextProvider, __spreadProps(__spreadValues({}, props), { children: scopedProviders.reduceRight( 2937 (children, Provider4) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(Provider4, __spreadProps(__spreadValues({}, props), { children })), 2938 /* @__PURE__ */ (0, import_jsx_runtime.jsx)(scopedContext.Provider, __spreadValues({}, props)) 2939 ) })); 2940 }; 2941 return { 2942 context, 2943 scopedContext, 2944 useContext: useContext210, 2945 useScopedContext, 2946 useProviderContext, 2947 ContextProvider, 2948 ScopedContextProvider 2949 }; 2950 } 2951 2952 // node_modules/@ariakit/react-core/esm/__chunks/VDHZ5F7K.js 2953 var ctx = createStoreContext(); 2954 var useCollectionContext = ctx.useContext; 2955 var useCollectionScopedContext = ctx.useScopedContext; 2956 var useCollectionProviderContext = ctx.useProviderContext; 2957 var CollectionContextProvider = ctx.ContextProvider; 2958 var CollectionScopedContextProvider = ctx.ScopedContextProvider; 2959 2960 // node_modules/@ariakit/react-core/esm/__chunks/P7GR5CS5.js 2961 var import_react3 = __toESM(require_react(), 1); 2962 var ctx2 = createStoreContext( 2963 [CollectionContextProvider], 2964 [CollectionScopedContextProvider] 2965 ); 2966 var useCompositeContext = ctx2.useContext; 2967 var useCompositeScopedContext = ctx2.useScopedContext; 2968 var useCompositeProviderContext = ctx2.useProviderContext; 2969 var CompositeContextProvider = ctx2.ContextProvider; 2970 var CompositeScopedContextProvider = ctx2.ScopedContextProvider; 2971 var CompositeItemContext = (0, import_react3.createContext)( 2972 void 0 2973 ); 2974 var CompositeRowContext = (0, import_react3.createContext)( 2975 void 0 2976 ); 2977 2978 // node_modules/@ariakit/core/esm/__chunks/BCALMBPZ.js 2979 function getInternal(store, key) { 2980 const internals = store.__unstableInternals; 2981 invariant(internals, "Invalid store"); 2982 return internals[key]; 2983 } 2984 function createStore(initialState, ...stores) { 2985 let state = initialState; 2986 let prevStateBatch = state; 2987 let lastUpdate = Symbol(); 2988 let destroy = noop; 2989 const instances = /* @__PURE__ */ new Set(); 2990 const updatedKeys = /* @__PURE__ */ new Set(); 2991 const setups = /* @__PURE__ */ new Set(); 2992 const listeners = /* @__PURE__ */ new Set(); 2993 const batchListeners = /* @__PURE__ */ new Set(); 2994 const disposables = /* @__PURE__ */ new WeakMap(); 2995 const listenerKeys = /* @__PURE__ */ new WeakMap(); 2996 const storeSetup = (callback) => { 2997 setups.add(callback); 2998 return () => setups.delete(callback); 2999 }; 3000 const storeInit = () => { 3001 const initialized = instances.size; 3002 const instance = Symbol(); 3003 instances.add(instance); 3004 const maybeDestroy = () => { 3005 instances.delete(instance); 3006 if (instances.size) return; 3007 destroy(); 3008 }; 3009 if (initialized) return maybeDestroy; 3010 const desyncs = getKeys(state).map( 3011 (key) => chain( 3012 ...stores.map((store) => { 3013 var _a; 3014 const storeState = (_a = store == null ? void 0 : store.getState) == null ? void 0 : _a.call(store); 3015 if (!storeState) return; 3016 if (!hasOwnProperty(storeState, key)) return; 3017 return sync(store, [key], (state2) => { 3018 setState( 3019 key, 3020 state2[key], 3021 // @ts-expect-error - Not public API. This is just to prevent 3022 // infinite loops. 3023 true 3024 ); 3025 }); 3026 }) 3027 ) 3028 ); 3029 const teardowns = []; 3030 for (const setup2 of setups) { 3031 teardowns.push(setup2()); 3032 } 3033 const cleanups2 = stores.map(init); 3034 destroy = chain(...desyncs, ...teardowns, ...cleanups2); 3035 return maybeDestroy; 3036 }; 3037 const sub = (keys, listener, set2 = listeners) => { 3038 set2.add(listener); 3039 listenerKeys.set(listener, keys); 3040 return () => { 3041 var _a; 3042 (_a = disposables.get(listener)) == null ? void 0 : _a(); 3043 disposables.delete(listener); 3044 listenerKeys.delete(listener); 3045 set2.delete(listener); 3046 }; 3047 }; 3048 const storeSubscribe = (keys, listener) => sub(keys, listener); 3049 const storeSync = (keys, listener) => { 3050 disposables.set(listener, listener(state, state)); 3051 return sub(keys, listener); 3052 }; 3053 const storeBatch = (keys, listener) => { 3054 disposables.set(listener, listener(state, prevStateBatch)); 3055 return sub(keys, listener, batchListeners); 3056 }; 3057 const storePick = (keys) => createStore(pick(state, keys), finalStore); 3058 const storeOmit = (keys) => createStore(omit(state, keys), finalStore); 3059 const getState = () => state; 3060 const setState = (key, value, fromStores = false) => { 3061 var _a; 3062 if (!hasOwnProperty(state, key)) return; 3063 const nextValue = applyState(value, state[key]); 3064 if (nextValue === state[key]) return; 3065 if (!fromStores) { 3066 for (const store of stores) { 3067 (_a = store == null ? void 0 : store.setState) == null ? void 0 : _a.call(store, key, nextValue); 3068 } 3069 } 3070 const prevState = state; 3071 state = __spreadProps2(__spreadValues2({}, state), { [key]: nextValue }); 3072 const thisUpdate = Symbol(); 3073 lastUpdate = thisUpdate; 3074 updatedKeys.add(key); 3075 const run = (listener, prev2, uKeys) => { 3076 var _a2; 3077 const keys = listenerKeys.get(listener); 3078 const updated = (k2) => uKeys ? uKeys.has(k2) : k2 === key; 3079 if (!keys || keys.some(updated)) { 3080 (_a2 = disposables.get(listener)) == null ? void 0 : _a2(); 3081 disposables.set(listener, listener(state, prev2)); 3082 } 3083 }; 3084 for (const listener of listeners) { 3085 run(listener, prevState); 3086 } 3087 queueMicrotask(() => { 3088 if (lastUpdate !== thisUpdate) return; 3089 const snapshot = state; 3090 for (const listener of batchListeners) { 3091 run(listener, prevStateBatch, updatedKeys); 3092 } 3093 prevStateBatch = snapshot; 3094 updatedKeys.clear(); 3095 }); 3096 }; 3097 const finalStore = { 3098 getState, 3099 setState, 3100 __unstableInternals: { 3101 setup: storeSetup, 3102 init: storeInit, 3103 subscribe: storeSubscribe, 3104 sync: storeSync, 3105 batch: storeBatch, 3106 pick: storePick, 3107 omit: storeOmit 3108 } 3109 }; 3110 return finalStore; 3111 } 3112 function setup(store, ...args) { 3113 if (!store) return; 3114 return getInternal(store, "setup")(...args); 3115 } 3116 function init(store, ...args) { 3117 if (!store) return; 3118 return getInternal(store, "init")(...args); 3119 } 3120 function subscribe(store, ...args) { 3121 if (!store) return; 3122 return getInternal(store, "subscribe")(...args); 3123 } 3124 function sync(store, ...args) { 3125 if (!store) return; 3126 return getInternal(store, "sync")(...args); 3127 } 3128 function batch(store, ...args) { 3129 if (!store) return; 3130 return getInternal(store, "batch")(...args); 3131 } 3132 function omit2(store, ...args) { 3133 if (!store) return; 3134 return getInternal(store, "omit")(...args); 3135 } 3136 function pick2(store, ...args) { 3137 if (!store) return; 3138 return getInternal(store, "pick")(...args); 3139 } 3140 function mergeStore(...stores) { 3141 const initialState = stores.reduce((state, store2) => { 3142 var _a; 3143 const nextState = (_a = store2 == null ? void 0 : store2.getState) == null ? void 0 : _a.call(store2); 3144 if (!nextState) return state; 3145 return Object.assign(state, nextState); 3146 }, {}); 3147 const store = createStore(initialState, ...stores); 3148 return Object.assign({}, ...stores, store); 3149 } 3150 function throwOnConflictingProps(props, store) { 3151 if (false) return; 3152 if (!store) return; 3153 const defaultKeys = Object.entries(props).filter(([key, value]) => key.startsWith("default") && value !== void 0).map(([key]) => { 3154 var _a; 3155 const stateKey = key.replace("default", ""); 3156 return `${((_a = stateKey[0]) == null ? void 0 : _a.toLowerCase()) || ""}$stateKey.slice(1)}`; 3157 }); 3158 if (!defaultKeys.length) return; 3159 const storeState = store.getState(); 3160 const conflictingProps = defaultKeys.filter( 3161 (key) => hasOwnProperty(storeState, key) 3162 ); 3163 if (!conflictingProps.length) return; 3164 throw new Error( 3165 `Passing a store prop in conjunction with a default state is not supported. 3166 3167 const store = useSelectStore(); 3168 <SelectProvider store={store} defaultValue="Apple" /> 3169 ^ ^ 3170 3171 Instead, pass the default state to the topmost store: 3172 3173 const store = useSelectStore({ defaultValue: "Apple" }); 3174 <SelectProvider store={store} /> 3175 3176 See https://github.com/ariakit/ariakit/pull/2745 for more details. 3177 3178 If there's a particular need for this, please submit a feature request at https://github.com/ariakit/ariakit 3179 ` 3180 ); 3181 } 3182 3183 // node_modules/@ariakit/react-core/esm/__chunks/YV4JVR4I.js 3184 var React3 = __toESM(require_react(), 1); 3185 var import_shim = __toESM(require_shim(), 1); 3186 var { useSyncExternalStore } = import_shim.default; 3187 var noopSubscribe = () => () => { 3188 }; 3189 function useStoreState(store, keyOrSelector = identity) { 3190 const storeSubscribe = React3.useCallback( 3191 (callback) => { 3192 if (!store) return noopSubscribe(); 3193 return subscribe(store, null, callback); 3194 }, 3195 [store] 3196 ); 3197 const getSnapshot = () => { 3198 const key = typeof keyOrSelector === "string" ? keyOrSelector : null; 3199 const selector2 = typeof keyOrSelector === "function" ? keyOrSelector : null; 3200 const state = store == null ? void 0 : store.getState(); 3201 if (selector2) return selector2(state); 3202 if (!state) return; 3203 if (!key) return; 3204 if (!hasOwnProperty(state, key)) return; 3205 return state[key]; 3206 }; 3207 return useSyncExternalStore(storeSubscribe, getSnapshot, getSnapshot); 3208 } 3209 function useStoreStateObject(store, object) { 3210 const objRef = React3.useRef( 3211 {} 3212 ); 3213 const storeSubscribe = React3.useCallback( 3214 (callback) => { 3215 if (!store) return noopSubscribe(); 3216 return subscribe(store, null, callback); 3217 }, 3218 [store] 3219 ); 3220 const getSnapshot = () => { 3221 const state = store == null ? void 0 : store.getState(); 3222 let updated = false; 3223 const obj = objRef.current; 3224 for (const prop in object) { 3225 const keyOrSelector = object[prop]; 3226 if (typeof keyOrSelector === "function") { 3227 const value = keyOrSelector(state); 3228 if (value !== obj[prop]) { 3229 obj[prop] = value; 3230 updated = true; 3231 } 3232 } 3233 if (typeof keyOrSelector === "string") { 3234 if (!state) continue; 3235 if (!hasOwnProperty(state, keyOrSelector)) continue; 3236 const value = state[keyOrSelector]; 3237 if (value !== obj[prop]) { 3238 obj[prop] = value; 3239 updated = true; 3240 } 3241 } 3242 } 3243 if (updated) { 3244 objRef.current = __spreadValues({}, obj); 3245 } 3246 return objRef.current; 3247 }; 3248 return useSyncExternalStore(storeSubscribe, getSnapshot, getSnapshot); 3249 } 3250 function useStoreProps(store, props, key, setKey) { 3251 const value = hasOwnProperty(props, key) ? props[key] : void 0; 3252 const setValue = setKey ? props[setKey] : void 0; 3253 const propsRef = useLiveRef({ value, setValue }); 3254 useSafeLayoutEffect(() => { 3255 return sync(store, [key], (state, prev2) => { 3256 const { value: value2, setValue: setValue2 } = propsRef.current; 3257 if (!setValue2) return; 3258 if (state[key] === prev2[key]) return; 3259 if (state[key] === value2) return; 3260 setValue2(state[key]); 3261 }); 3262 }, [store, key]); 3263 useSafeLayoutEffect(() => { 3264 if (value === void 0) return; 3265 store.setState(key, value); 3266 return batch(store, [key], () => { 3267 if (value === void 0) return; 3268 store.setState(key, value); 3269 }); 3270 }); 3271 } 3272 function useStore(createStore2, props) { 3273 const [store, setStore] = React3.useState(() => createStore2(props)); 3274 useSafeLayoutEffect(() => init(store), [store]); 3275 const useState210 = React3.useCallback( 3276 (keyOrSelector) => useStoreState(store, keyOrSelector), 3277 [store] 3278 ); 3279 const memoizedStore = React3.useMemo( 3280 () => __spreadProps(__spreadValues({}, store), { useState: useState210 }), 3281 [store, useState210] 3282 ); 3283 const updateStore = useEvent(() => { 3284 setStore((store2) => createStore2(__spreadValues(__spreadValues({}, props), store2.getState()))); 3285 }); 3286 return [memoizedStore, updateStore]; 3287 } 3288 3289 // node_modules/@ariakit/core/esm/__chunks/CYQWQL4J.js 3290 function getCommonParent(items) { 3291 var _a; 3292 const firstItem = items.find((item2) => !!item2.element); 3293 const lastItem = [...items].reverse().find((item2) => !!item2.element); 3294 let parentElement = (_a = firstItem == null ? void 0 : firstItem.element) == null ? void 0 : _a.parentElement; 3295 while (parentElement && (lastItem == null ? void 0 : lastItem.element)) { 3296 const parent = parentElement; 3297 if (lastItem && parent.contains(lastItem.element)) { 3298 return parentElement; 3299 } 3300 parentElement = parentElement.parentElement; 3301 } 3302 return getDocument(parentElement).body; 3303 } 3304 function getPrivateStore(store) { 3305 return store == null ? void 0 : store.__unstablePrivateStore; 3306 } 3307 function createCollectionStore(props = {}) { 3308 var _a; 3309 throwOnConflictingProps(props, props.store); 3310 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 3311 const items = defaultValue( 3312 props.items, 3313 syncState == null ? void 0 : syncState.items, 3314 props.defaultItems, 3315 [] 3316 ); 3317 const itemsMap = new Map(items.map((item2) => [item2.id, item2])); 3318 const initialState = { 3319 items, 3320 renderedItems: defaultValue(syncState == null ? void 0 : syncState.renderedItems, []) 3321 }; 3322 const syncPrivateStore = getPrivateStore(props.store); 3323 const privateStore = createStore( 3324 { items, renderedItems: initialState.renderedItems }, 3325 syncPrivateStore 3326 ); 3327 const collection = createStore(initialState, props.store); 3328 const sortItems = (renderedItems) => { 3329 const sortedItems = sortBasedOnDOMPosition(renderedItems, (i3) => i3.element); 3330 privateStore.setState("renderedItems", sortedItems); 3331 collection.setState("renderedItems", sortedItems); 3332 }; 3333 setup(collection, () => init(privateStore)); 3334 setup(privateStore, () => { 3335 return batch(privateStore, ["items"], (state) => { 3336 collection.setState("items", state.items); 3337 }); 3338 }); 3339 setup(privateStore, () => { 3340 return batch(privateStore, ["renderedItems"], (state) => { 3341 let firstRun = true; 3342 let raf = requestAnimationFrame(() => { 3343 const { renderedItems } = collection.getState(); 3344 if (state.renderedItems === renderedItems) return; 3345 sortItems(state.renderedItems); 3346 }); 3347 if (typeof IntersectionObserver !== "function") { 3348 return () => cancelAnimationFrame(raf); 3349 } 3350 const ioCallback = () => { 3351 if (firstRun) { 3352 firstRun = false; 3353 return; 3354 } 3355 cancelAnimationFrame(raf); 3356 raf = requestAnimationFrame(() => sortItems(state.renderedItems)); 3357 }; 3358 const root = getCommonParent(state.renderedItems); 3359 const observer = new IntersectionObserver(ioCallback, { root }); 3360 for (const item2 of state.renderedItems) { 3361 if (!item2.element) continue; 3362 observer.observe(item2.element); 3363 } 3364 return () => { 3365 cancelAnimationFrame(raf); 3366 observer.disconnect(); 3367 }; 3368 }); 3369 }); 3370 const mergeItem = (item2, setItems, canDeleteFromMap = false) => { 3371 let prevItem; 3372 setItems((items2) => { 3373 const index2 = items2.findIndex(({ id: id3 }) => id3 === item2.id); 3374 const nextItems = items2.slice(); 3375 if (index2 !== -1) { 3376 prevItem = items2[index2]; 3377 const nextItem = __spreadValues2(__spreadValues2({}, prevItem), item2); 3378 nextItems[index2] = nextItem; 3379 itemsMap.set(item2.id, nextItem); 3380 } else { 3381 nextItems.push(item2); 3382 itemsMap.set(item2.id, item2); 3383 } 3384 return nextItems; 3385 }); 3386 const unmergeItem = () => { 3387 setItems((items2) => { 3388 if (!prevItem) { 3389 if (canDeleteFromMap) { 3390 itemsMap.delete(item2.id); 3391 } 3392 return items2.filter(({ id: id3 }) => id3 !== item2.id); 3393 } 3394 const index2 = items2.findIndex(({ id: id3 }) => id3 === item2.id); 3395 if (index2 === -1) return items2; 3396 const nextItems = items2.slice(); 3397 nextItems[index2] = prevItem; 3398 itemsMap.set(item2.id, prevItem); 3399 return nextItems; 3400 }); 3401 }; 3402 return unmergeItem; 3403 }; 3404 const registerItem = (item2) => mergeItem( 3405 item2, 3406 (getItems) => privateStore.setState("items", getItems), 3407 true 3408 ); 3409 return __spreadProps2(__spreadValues2({}, collection), { 3410 registerItem, 3411 renderItem: (item2) => chain( 3412 registerItem(item2), 3413 mergeItem( 3414 item2, 3415 (getItems) => privateStore.setState("renderedItems", getItems) 3416 ) 3417 ), 3418 item: (id3) => { 3419 if (!id3) return null; 3420 let item2 = itemsMap.get(id3); 3421 if (!item2) { 3422 const { items: items2 } = privateStore.getState(); 3423 item2 = items2.find((item22) => item22.id === id3); 3424 if (item2) { 3425 itemsMap.set(id3, item2); 3426 } 3427 } 3428 return item2 || null; 3429 }, 3430 // @ts-expect-error Internal 3431 __unstablePrivateStore: privateStore 3432 }); 3433 } 3434 3435 // node_modules/@ariakit/react-core/esm/__chunks/C3IKGW5T.js 3436 function useCollectionStoreProps(store, update, props) { 3437 useUpdateEffect(update, [props.store]); 3438 useStoreProps(store, props, "items", "setItems"); 3439 return store; 3440 } 3441 3442 // node_modules/@ariakit/core/esm/__chunks/7PRQYBBV.js 3443 function toArray(arg) { 3444 if (Array.isArray(arg)) { 3445 return arg; 3446 } 3447 return typeof arg !== "undefined" ? [arg] : []; 3448 } 3449 function flatten2DArray(array) { 3450 const flattened = []; 3451 for (const row of array) { 3452 flattened.push(...row); 3453 } 3454 return flattened; 3455 } 3456 function reverseArray(array) { 3457 return array.slice().reverse(); 3458 } 3459 3460 // node_modules/@ariakit/core/esm/__chunks/AJZ4BYF3.js 3461 var NULL_ITEM = { id: null }; 3462 function findFirstEnabledItem(items, excludeId) { 3463 return items.find((item2) => { 3464 if (excludeId) { 3465 return !item2.disabled && item2.id !== excludeId; 3466 } 3467 return !item2.disabled; 3468 }); 3469 } 3470 function getEnabledItems(items, excludeId) { 3471 return items.filter((item2) => { 3472 if (excludeId) { 3473 return !item2.disabled && item2.id !== excludeId; 3474 } 3475 return !item2.disabled; 3476 }); 3477 } 3478 function getItemsInRow(items, rowId) { 3479 return items.filter((item2) => item2.rowId === rowId); 3480 } 3481 function flipItems(items, activeId, shouldInsertNullItem = false) { 3482 const index2 = items.findIndex((item2) => item2.id === activeId); 3483 return [ 3484 ...items.slice(index2 + 1), 3485 ...shouldInsertNullItem ? [NULL_ITEM] : [], 3486 ...items.slice(0, index2) 3487 ]; 3488 } 3489 function groupItemsByRows(items) { 3490 const rows = []; 3491 for (const item2 of items) { 3492 const row = rows.find((currentRow) => { 3493 var _a; 3494 return ((_a = currentRow[0]) == null ? void 0 : _a.rowId) === item2.rowId; 3495 }); 3496 if (row) { 3497 row.push(item2); 3498 } else { 3499 rows.push([item2]); 3500 } 3501 } 3502 return rows; 3503 } 3504 function getMaxRowLength(array) { 3505 let maxLength = 0; 3506 for (const { length: length2 } of array) { 3507 if (length2 > maxLength) { 3508 maxLength = length2; 3509 } 3510 } 3511 return maxLength; 3512 } 3513 function createEmptyItem(rowId) { 3514 return { 3515 id: "__EMPTY_ITEM__", 3516 disabled: true, 3517 rowId 3518 }; 3519 } 3520 function normalizeRows(rows, activeId, focusShift) { 3521 const maxLength = getMaxRowLength(rows); 3522 for (const row of rows) { 3523 for (let i3 = 0; i3 < maxLength; i3 += 1) { 3524 const item2 = row[i3]; 3525 if (!item2 || focusShift && item2.disabled) { 3526 const isFirst = i3 === 0; 3527 const previousItem = isFirst && focusShift ? findFirstEnabledItem(row) : row[i3 - 1]; 3528 row[i3] = previousItem && activeId !== previousItem.id && focusShift ? previousItem : createEmptyItem(previousItem == null ? void 0 : previousItem.rowId); 3529 } 3530 } 3531 } 3532 return rows; 3533 } 3534 function verticalizeItems(items) { 3535 const rows = groupItemsByRows(items); 3536 const maxLength = getMaxRowLength(rows); 3537 const verticalized = []; 3538 for (let i3 = 0; i3 < maxLength; i3 += 1) { 3539 for (const row of rows) { 3540 const item2 = row[i3]; 3541 if (item2) { 3542 verticalized.push(__spreadProps2(__spreadValues2({}, item2), { 3543 // If there's no rowId, it means that it's not a grid composite, but 3544 // a single row instead. So, instead of verticalizing it, that is, 3545 // assigning a different rowId based on the column index, we keep it 3546 // undefined so they will be part of the same row. This is useful 3547 // when using up/down on one-dimensional composites. 3548 rowId: item2.rowId ? `$i3}` : void 0 3549 })); 3550 } 3551 } 3552 } 3553 return verticalized; 3554 } 3555 function createCompositeStore(props = {}) { 3556 var _a; 3557 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 3558 const collection = createCollectionStore(props); 3559 const activeId = defaultValue( 3560 props.activeId, 3561 syncState == null ? void 0 : syncState.activeId, 3562 props.defaultActiveId 3563 ); 3564 const initialState = __spreadProps2(__spreadValues2({}, collection.getState()), { 3565 id: defaultValue( 3566 props.id, 3567 syncState == null ? void 0 : syncState.id, 3568 `id-$Math.random().toString(36).slice(2, 8)}` 3569 ), 3570 activeId, 3571 baseElement: defaultValue(syncState == null ? void 0 : syncState.baseElement, null), 3572 includesBaseElement: defaultValue( 3573 props.includesBaseElement, 3574 syncState == null ? void 0 : syncState.includesBaseElement, 3575 activeId === null 3576 ), 3577 moves: defaultValue(syncState == null ? void 0 : syncState.moves, 0), 3578 orientation: defaultValue( 3579 props.orientation, 3580 syncState == null ? void 0 : syncState.orientation, 3581 "both" 3582 ), 3583 rtl: defaultValue(props.rtl, syncState == null ? void 0 : syncState.rtl, false), 3584 virtualFocus: defaultValue( 3585 props.virtualFocus, 3586 syncState == null ? void 0 : syncState.virtualFocus, 3587 false 3588 ), 3589 focusLoop: defaultValue(props.focusLoop, syncState == null ? void 0 : syncState.focusLoop, false), 3590 focusWrap: defaultValue(props.focusWrap, syncState == null ? void 0 : syncState.focusWrap, false), 3591 focusShift: defaultValue(props.focusShift, syncState == null ? void 0 : syncState.focusShift, false) 3592 }); 3593 const composite = createStore(initialState, collection, props.store); 3594 setup( 3595 composite, 3596 () => sync(composite, ["renderedItems", "activeId"], (state) => { 3597 composite.setState("activeId", (activeId2) => { 3598 var _a2; 3599 if (activeId2 !== void 0) return activeId2; 3600 return (_a2 = findFirstEnabledItem(state.renderedItems)) == null ? void 0 : _a2.id; 3601 }); 3602 }) 3603 ); 3604 const getNextId = (direction = "next", options2 = {}) => { 3605 var _a2, _b; 3606 const defaultState = composite.getState(); 3607 const { 3608 skip = 0, 3609 activeId: activeId2 = defaultState.activeId, 3610 focusShift = defaultState.focusShift, 3611 focusLoop = defaultState.focusLoop, 3612 focusWrap = defaultState.focusWrap, 3613 includesBaseElement = defaultState.includesBaseElement, 3614 renderedItems = defaultState.renderedItems, 3615 rtl: rtl2 = defaultState.rtl 3616 } = options2; 3617 const isVerticalDirection = direction === "up" || direction === "down"; 3618 const isNextDirection = direction === "next" || direction === "down"; 3619 const canReverse = isNextDirection ? rtl2 && !isVerticalDirection : !rtl2 || isVerticalDirection; 3620 const canShift = focusShift && !skip; 3621 let items = !isVerticalDirection ? renderedItems : flatten2DArray( 3622 normalizeRows(groupItemsByRows(renderedItems), activeId2, canShift) 3623 ); 3624 items = canReverse ? reverseArray(items) : items; 3625 items = isVerticalDirection ? verticalizeItems(items) : items; 3626 if (activeId2 == null) { 3627 return (_a2 = findFirstEnabledItem(items)) == null ? void 0 : _a2.id; 3628 } 3629 const activeItem = items.find((item2) => item2.id === activeId2); 3630 if (!activeItem) { 3631 return (_b = findFirstEnabledItem(items)) == null ? void 0 : _b.id; 3632 } 3633 const isGrid2 = items.some((item2) => item2.rowId); 3634 const activeIndex = items.indexOf(activeItem); 3635 const nextItems = items.slice(activeIndex + 1); 3636 const nextItemsInRow = getItemsInRow(nextItems, activeItem.rowId); 3637 if (skip) { 3638 const nextEnabledItemsInRow = getEnabledItems(nextItemsInRow, activeId2); 3639 const nextItem2 = nextEnabledItemsInRow.slice(skip)[0] || // If we can't find an item, just return the last one. 3640 nextEnabledItemsInRow[nextEnabledItemsInRow.length - 1]; 3641 return nextItem2 == null ? void 0 : nextItem2.id; 3642 } 3643 const canLoop = focusLoop && (isVerticalDirection ? focusLoop !== "horizontal" : focusLoop !== "vertical"); 3644 const canWrap = isGrid2 && focusWrap && (isVerticalDirection ? focusWrap !== "horizontal" : focusWrap !== "vertical"); 3645 const hasNullItem = isNextDirection ? (!isGrid2 || isVerticalDirection) && canLoop && includesBaseElement : isVerticalDirection ? includesBaseElement : false; 3646 if (canLoop) { 3647 const loopItems = canWrap && !hasNullItem ? items : getItemsInRow(items, activeItem.rowId); 3648 const sortedItems = flipItems(loopItems, activeId2, hasNullItem); 3649 const nextItem2 = findFirstEnabledItem(sortedItems, activeId2); 3650 return nextItem2 == null ? void 0 : nextItem2.id; 3651 } 3652 if (canWrap) { 3653 const nextItem2 = findFirstEnabledItem( 3654 // We can use nextItems, which contains all the next items, including 3655 // items from other rows, to wrap between rows. However, if there is a 3656 // null item (the composite container), we'll only use the next items in 3657 // the row. So moving next from the last item will focus on the 3658 // composite container. On grid composites, horizontal navigation never 3659 // focuses on the composite container, only vertical. 3660 hasNullItem ? nextItemsInRow : nextItems, 3661 activeId2 3662 ); 3663 const nextId = hasNullItem ? (nextItem2 == null ? void 0 : nextItem2.id) || null : nextItem2 == null ? void 0 : nextItem2.id; 3664 return nextId; 3665 } 3666 const nextItem = findFirstEnabledItem(nextItemsInRow, activeId2); 3667 if (!nextItem && hasNullItem) { 3668 return null; 3669 } 3670 return nextItem == null ? void 0 : nextItem.id; 3671 }; 3672 return __spreadProps2(__spreadValues2(__spreadValues2({}, collection), composite), { 3673 setBaseElement: (element) => composite.setState("baseElement", element), 3674 setActiveId: (id3) => composite.setState("activeId", id3), 3675 move: (id3) => { 3676 if (id3 === void 0) return; 3677 composite.setState("activeId", id3); 3678 composite.setState("moves", (moves) => moves + 1); 3679 }, 3680 first: () => { 3681 var _a2; 3682 return (_a2 = findFirstEnabledItem(composite.getState().renderedItems)) == null ? void 0 : _a2.id; 3683 }, 3684 last: () => { 3685 var _a2; 3686 return (_a2 = findFirstEnabledItem(reverseArray(composite.getState().renderedItems))) == null ? void 0 : _a2.id; 3687 }, 3688 next: (options2) => { 3689 if (options2 !== void 0 && typeof options2 === "number") { 3690 options2 = { skip: options2 }; 3691 } 3692 return getNextId("next", options2); 3693 }, 3694 previous: (options2) => { 3695 if (options2 !== void 0 && typeof options2 === "number") { 3696 options2 = { skip: options2 }; 3697 } 3698 return getNextId("previous", options2); 3699 }, 3700 down: (options2) => { 3701 if (options2 !== void 0 && typeof options2 === "number") { 3702 options2 = { skip: options2 }; 3703 } 3704 return getNextId("down", options2); 3705 }, 3706 up: (options2) => { 3707 if (options2 !== void 0 && typeof options2 === "number") { 3708 options2 = { skip: options2 }; 3709 } 3710 return getNextId("up", options2); 3711 } 3712 }); 3713 } 3714 3715 // node_modules/@ariakit/react-core/esm/__chunks/4CMBR7SL.js 3716 function useCompositeStoreOptions(props) { 3717 const id3 = useId(props.id); 3718 return __spreadValues({ id: id3 }, props); 3719 } 3720 function useCompositeStoreProps(store, update, props) { 3721 store = useCollectionStoreProps(store, update, props); 3722 useStoreProps(store, props, "activeId", "setActiveId"); 3723 useStoreProps(store, props, "includesBaseElement"); 3724 useStoreProps(store, props, "virtualFocus"); 3725 useStoreProps(store, props, "orientation"); 3726 useStoreProps(store, props, "rtl"); 3727 useStoreProps(store, props, "focusLoop"); 3728 useStoreProps(store, props, "focusWrap"); 3729 useStoreProps(store, props, "focusShift"); 3730 return store; 3731 } 3732 function useCompositeStore(props = {}) { 3733 props = useCompositeStoreOptions(props); 3734 const [store, update] = useStore(createCompositeStore, props); 3735 return useCompositeStoreProps(store, update, props); 3736 } 3737 3738 // node_modules/@ariakit/core/esm/__chunks/RCQ5P4YE.js 3739 function createDisclosureStore(props = {}) { 3740 const store = mergeStore( 3741 props.store, 3742 omit2(props.disclosure, ["contentElement", "disclosureElement"]) 3743 ); 3744 throwOnConflictingProps(props, store); 3745 const syncState = store == null ? void 0 : store.getState(); 3746 const open = defaultValue( 3747 props.open, 3748 syncState == null ? void 0 : syncState.open, 3749 props.defaultOpen, 3750 false 3751 ); 3752 const animated = defaultValue(props.animated, syncState == null ? void 0 : syncState.animated, false); 3753 const initialState = { 3754 open, 3755 animated, 3756 animating: !!animated && open, 3757 mounted: open, 3758 contentElement: defaultValue(syncState == null ? void 0 : syncState.contentElement, null), 3759 disclosureElement: defaultValue(syncState == null ? void 0 : syncState.disclosureElement, null) 3760 }; 3761 const disclosure = createStore(initialState, store); 3762 setup( 3763 disclosure, 3764 () => sync(disclosure, ["animated", "animating"], (state) => { 3765 if (state.animated) return; 3766 disclosure.setState("animating", false); 3767 }) 3768 ); 3769 setup( 3770 disclosure, 3771 () => subscribe(disclosure, ["open"], () => { 3772 if (!disclosure.getState().animated) return; 3773 disclosure.setState("animating", true); 3774 }) 3775 ); 3776 setup( 3777 disclosure, 3778 () => sync(disclosure, ["open", "animating"], (state) => { 3779 disclosure.setState("mounted", state.open || state.animating); 3780 }) 3781 ); 3782 return __spreadProps2(__spreadValues2({}, disclosure), { 3783 disclosure: props.disclosure, 3784 setOpen: (value) => disclosure.setState("open", value), 3785 show: () => disclosure.setState("open", true), 3786 hide: () => disclosure.setState("open", false), 3787 toggle: () => disclosure.setState("open", (open2) => !open2), 3788 stopAnimation: () => disclosure.setState("animating", false), 3789 setContentElement: (value) => disclosure.setState("contentElement", value), 3790 setDisclosureElement: (value) => disclosure.setState("disclosureElement", value) 3791 }); 3792 } 3793 3794 // node_modules/@ariakit/react-core/esm/__chunks/WYCIER3C.js 3795 function useDisclosureStoreProps(store, update, props) { 3796 useUpdateEffect(update, [props.store, props.disclosure]); 3797 useStoreProps(store, props, "open", "setOpen"); 3798 useStoreProps(store, props, "mounted", "setMounted"); 3799 useStoreProps(store, props, "animated"); 3800 return Object.assign(store, { disclosure: props.disclosure }); 3801 } 3802 function useDisclosureStore(props = {}) { 3803 const [store, update] = useStore(createDisclosureStore, props); 3804 return useDisclosureStoreProps(store, update, props); 3805 } 3806 3807 // node_modules/@ariakit/core/esm/__chunks/FZZ2AVHF.js 3808 function createDialogStore(props = {}) { 3809 return createDisclosureStore(props); 3810 } 3811 3812 // node_modules/@ariakit/react-core/esm/__chunks/BM6PGYQY.js 3813 function useDialogStoreProps(store, update, props) { 3814 return useDisclosureStoreProps(store, update, props); 3815 } 3816 function useDialogStore(props = {}) { 3817 const [store, update] = useStore(createDialogStore, props); 3818 return useDialogStoreProps(store, update, props); 3819 } 3820 3821 // node_modules/@ariakit/core/esm/__chunks/ME2CUF3F.js 3822 function createPopoverStore(_a = {}) { 3823 var _b = _a, { 3824 popover: otherPopover 3825 } = _b, props = __objRest2(_b, [ 3826 "popover" 3827 ]); 3828 const store = mergeStore( 3829 props.store, 3830 omit2(otherPopover, [ 3831 "arrowElement", 3832 "anchorElement", 3833 "contentElement", 3834 "popoverElement", 3835 "disclosureElement" 3836 ]) 3837 ); 3838 throwOnConflictingProps(props, store); 3839 const syncState = store == null ? void 0 : store.getState(); 3840 const dialog = createDialogStore(__spreadProps2(__spreadValues2({}, props), { store })); 3841 const placement = defaultValue( 3842 props.placement, 3843 syncState == null ? void 0 : syncState.placement, 3844 "bottom" 3845 ); 3846 const initialState = __spreadProps2(__spreadValues2({}, dialog.getState()), { 3847 placement, 3848 currentPlacement: placement, 3849 anchorElement: defaultValue(syncState == null ? void 0 : syncState.anchorElement, null), 3850 popoverElement: defaultValue(syncState == null ? void 0 : syncState.popoverElement, null), 3851 arrowElement: defaultValue(syncState == null ? void 0 : syncState.arrowElement, null), 3852 rendered: Symbol("rendered") 3853 }); 3854 const popover = createStore(initialState, dialog, store); 3855 return __spreadProps2(__spreadValues2(__spreadValues2({}, dialog), popover), { 3856 setAnchorElement: (element) => popover.setState("anchorElement", element), 3857 setPopoverElement: (element) => popover.setState("popoverElement", element), 3858 setArrowElement: (element) => popover.setState("arrowElement", element), 3859 render: () => popover.setState("rendered", Symbol("rendered")) 3860 }); 3861 } 3862 3863 // node_modules/@ariakit/react-core/esm/__chunks/O2PQ2652.js 3864 function usePopoverStoreProps(store, update, props) { 3865 useUpdateEffect(update, [props.popover]); 3866 useStoreProps(store, props, "placement"); 3867 return useDialogStoreProps(store, update, props); 3868 } 3869 3870 // node_modules/@ariakit/react-core/esm/__chunks/S6EF7IVO.js 3871 var ctx3 = createStoreContext(); 3872 var useDisclosureContext = ctx3.useContext; 3873 var useDisclosureScopedContext = ctx3.useScopedContext; 3874 var useDisclosureProviderContext = ctx3.useProviderContext; 3875 var DisclosureContextProvider = ctx3.ContextProvider; 3876 var DisclosureScopedContextProvider = ctx3.ScopedContextProvider; 3877 3878 // node_modules/@ariakit/react-core/esm/__chunks/RS7LB2H4.js 3879 var import_react4 = __toESM(require_react(), 1); 3880 var ctx4 = createStoreContext( 3881 [DisclosureContextProvider], 3882 [DisclosureScopedContextProvider] 3883 ); 3884 var useDialogContext = ctx4.useContext; 3885 var useDialogScopedContext = ctx4.useScopedContext; 3886 var useDialogProviderContext = ctx4.useProviderContext; 3887 var DialogContextProvider = ctx4.ContextProvider; 3888 var DialogScopedContextProvider = ctx4.ScopedContextProvider; 3889 var DialogHeadingContext = (0, import_react4.createContext)(void 0); 3890 var DialogDescriptionContext = (0, import_react4.createContext)(void 0); 3891 3892 // node_modules/@ariakit/react-core/esm/__chunks/MTZPJQMC.js 3893 var ctx5 = createStoreContext( 3894 [DialogContextProvider], 3895 [DialogScopedContextProvider] 3896 ); 3897 var usePopoverContext = ctx5.useContext; 3898 var usePopoverScopedContext = ctx5.useScopedContext; 3899 var usePopoverProviderContext = ctx5.useProviderContext; 3900 var PopoverContextProvider = ctx5.ContextProvider; 3901 var PopoverScopedContextProvider = ctx5.ScopedContextProvider; 3902 3903 // node_modules/@ariakit/react-core/esm/__chunks/VEVQD5MH.js 3904 var import_react5 = __toESM(require_react(), 1); 3905 var ComboboxListRoleContext = (0, import_react5.createContext)( 3906 void 0 3907 ); 3908 var ctx6 = createStoreContext( 3909 [PopoverContextProvider, CompositeContextProvider], 3910 [PopoverScopedContextProvider, CompositeScopedContextProvider] 3911 ); 3912 var useComboboxContext = ctx6.useContext; 3913 var useComboboxScopedContext = ctx6.useScopedContext; 3914 var useComboboxProviderContext = ctx6.useProviderContext; 3915 var ComboboxContextProvider = ctx6.ContextProvider; 3916 var ComboboxScopedContextProvider = ctx6.ScopedContextProvider; 3917 var ComboboxItemValueContext = (0, import_react5.createContext)( 3918 void 0 3919 ); 3920 var ComboboxItemCheckedContext = (0, import_react5.createContext)(false); 3921 3922 // node_modules/@ariakit/react-core/esm/__chunks/OMU7RWRV.js 3923 var TagName = "div"; 3924 var usePopoverAnchor = createHook( 3925 function usePopoverAnchor2(_a) { 3926 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 3927 const context = usePopoverProviderContext(); 3928 store = store || context; 3929 props = __spreadProps(__spreadValues({}, props), { 3930 ref: useMergeRefs(store == null ? void 0 : store.setAnchorElement, props.ref) 3931 }); 3932 return props; 3933 } 3934 ); 3935 var PopoverAnchor = forwardRef2(function PopoverAnchor2(props) { 3936 const htmlProps = usePopoverAnchor(props); 3937 return createElement(TagName, htmlProps); 3938 }); 3939 3940 // node_modules/@ariakit/react-core/esm/__chunks/5VQZOHHZ.js 3941 var NULL_ITEM2 = { id: null }; 3942 function flipItems2(items, activeId, shouldInsertNullItem = false) { 3943 const index2 = items.findIndex((item2) => item2.id === activeId); 3944 return [ 3945 ...items.slice(index2 + 1), 3946 ...shouldInsertNullItem ? [NULL_ITEM2] : [], 3947 ...items.slice(0, index2) 3948 ]; 3949 } 3950 function findFirstEnabledItem2(items, excludeId) { 3951 return items.find((item2) => { 3952 if (excludeId) { 3953 return !item2.disabled && item2.id !== excludeId; 3954 } 3955 return !item2.disabled; 3956 }); 3957 } 3958 function getEnabledItem(store, id3) { 3959 if (!id3) return null; 3960 return store.item(id3) || null; 3961 } 3962 function groupItemsByRows2(items) { 3963 const rows = []; 3964 for (const item2 of items) { 3965 const row = rows.find((currentRow) => { 3966 var _a; 3967 return ((_a = currentRow[0]) == null ? void 0 : _a.rowId) === item2.rowId; 3968 }); 3969 if (row) { 3970 row.push(item2); 3971 } else { 3972 rows.push([item2]); 3973 } 3974 } 3975 return rows; 3976 } 3977 function selectTextField(element, collapseToEnd = false) { 3978 if (isTextField(element)) { 3979 element.setSelectionRange( 3980 collapseToEnd ? element.value.length : 0, 3981 element.value.length 3982 ); 3983 } else if (element.isContentEditable) { 3984 const selection = getDocument(element).getSelection(); 3985 selection == null ? void 0 : selection.selectAllChildren(element); 3986 if (collapseToEnd) { 3987 selection == null ? void 0 : selection.collapseToEnd(); 3988 } 3989 } 3990 } 3991 var FOCUS_SILENTLY = Symbol("FOCUS_SILENTLY"); 3992 function focusSilently(element) { 3993 element[FOCUS_SILENTLY] = true; 3994 element.focus({ preventScroll: true }); 3995 } 3996 function silentlyFocused(element) { 3997 const isSilentlyFocused = element[FOCUS_SILENTLY]; 3998 delete element[FOCUS_SILENTLY]; 3999 return isSilentlyFocused; 4000 } 4001 function isItem(store, element, exclude) { 4002 if (!element) return false; 4003 if (element === exclude) return false; 4004 const item2 = store.item(element.id); 4005 if (!item2) return false; 4006 if (exclude && item2.element === exclude) return false; 4007 return true; 4008 } 4009 4010 // node_modules/@ariakit/react-core/esm/__chunks/SWN3JYXT.js 4011 var import_react6 = __toESM(require_react(), 1); 4012 var FocusableContext = (0, import_react6.createContext)(true); 4013 4014 // node_modules/@ariakit/core/esm/utils/focus.js 4015 var selector = "input:not([type='hidden']):not([disabled]), select:not([disabled]), textarea:not([disabled]), a[href], button:not([disabled]), [tabindex], summary, iframe, object, embed, area[href], audio[controls], video[controls], [contenteditable]:not([contenteditable='false'])"; 4016 function hasNegativeTabIndex(element) { 4017 const tabIndex = Number.parseInt(element.getAttribute("tabindex") || "0", 10); 4018 return tabIndex < 0; 4019 } 4020 function isFocusable(element) { 4021 if (!element.matches(selector)) return false; 4022 if (!isVisible(element)) return false; 4023 if (element.closest("[inert]")) return false; 4024 return true; 4025 } 4026 function isTabbable(element) { 4027 if (!isFocusable(element)) return false; 4028 if (hasNegativeTabIndex(element)) return false; 4029 if (!("form" in element)) return true; 4030 if (!element.form) return true; 4031 if (element.checked) return true; 4032 if (element.type !== "radio") return true; 4033 const radioGroup = element.form.elements.namedItem(element.name); 4034 if (!radioGroup) return true; 4035 if (!("length" in radioGroup)) return true; 4036 const activeElement = getActiveElement(element); 4037 if (!activeElement) return true; 4038 if (activeElement === element) return true; 4039 if (!("form" in activeElement)) return true; 4040 if (activeElement.form !== element.form) return true; 4041 if (activeElement.name !== element.name) return true; 4042 return false; 4043 } 4044 function getAllFocusableIn(container, includeContainer) { 4045 const elements2 = Array.from( 4046 container.querySelectorAll(selector) 4047 ); 4048 if (includeContainer) { 4049 elements2.unshift(container); 4050 } 4051 const focusableElements2 = elements2.filter(isFocusable); 4052 focusableElements2.forEach((element, i3) => { 4053 if (isFrame(element) && element.contentDocument) { 4054 const frameBody = element.contentDocument.body; 4055 focusableElements2.splice(i3, 1, ...getAllFocusableIn(frameBody)); 4056 } 4057 }); 4058 return focusableElements2; 4059 } 4060 function getAllTabbableIn(container, includeContainer, fallbackToFocusable) { 4061 const elements2 = Array.from( 4062 container.querySelectorAll(selector) 4063 ); 4064 const tabbableElements = elements2.filter(isTabbable); 4065 if (includeContainer && isTabbable(container)) { 4066 tabbableElements.unshift(container); 4067 } 4068 tabbableElements.forEach((element, i3) => { 4069 if (isFrame(element) && element.contentDocument) { 4070 const frameBody = element.contentDocument.body; 4071 const allFrameTabbable = getAllTabbableIn( 4072 frameBody, 4073 false, 4074 fallbackToFocusable 4075 ); 4076 tabbableElements.splice(i3, 1, ...allFrameTabbable); 4077 } 4078 }); 4079 if (!tabbableElements.length && fallbackToFocusable) { 4080 return elements2; 4081 } 4082 return tabbableElements; 4083 } 4084 function getFirstTabbableIn(container, includeContainer, fallbackToFocusable) { 4085 const [first] = getAllTabbableIn( 4086 container, 4087 includeContainer, 4088 fallbackToFocusable 4089 ); 4090 return first || null; 4091 } 4092 function getNextTabbableIn(container, includeContainer, fallbackToFirst, fallbackToFocusable) { 4093 const activeElement = getActiveElement(container); 4094 const allFocusable = getAllFocusableIn(container, includeContainer); 4095 const activeIndex = allFocusable.indexOf(activeElement); 4096 const nextFocusableElements = allFocusable.slice(activeIndex + 1); 4097 return nextFocusableElements.find(isTabbable) || (fallbackToFirst ? allFocusable.find(isTabbable) : null) || (fallbackToFocusable ? nextFocusableElements[0] : null) || null; 4098 } 4099 function getNextTabbable(fallbackToFirst, fallbackToFocusable) { 4100 return getNextTabbableIn( 4101 document.body, 4102 false, 4103 fallbackToFirst, 4104 fallbackToFocusable 4105 ); 4106 } 4107 function getPreviousTabbableIn(container, includeContainer, fallbackToLast, fallbackToFocusable) { 4108 const activeElement = getActiveElement(container); 4109 const allFocusable = getAllFocusableIn(container, includeContainer).reverse(); 4110 const activeIndex = allFocusable.indexOf(activeElement); 4111 const previousFocusableElements = allFocusable.slice(activeIndex + 1); 4112 return previousFocusableElements.find(isTabbable) || (fallbackToLast ? allFocusable.find(isTabbable) : null) || (fallbackToFocusable ? previousFocusableElements[0] : null) || null; 4113 } 4114 function getPreviousTabbable(fallbackToFirst, fallbackToFocusable) { 4115 return getPreviousTabbableIn( 4116 document.body, 4117 false, 4118 fallbackToFirst, 4119 fallbackToFocusable 4120 ); 4121 } 4122 function getClosestFocusable(element) { 4123 while (element && !isFocusable(element)) { 4124 element = element.closest(selector); 4125 } 4126 return element || null; 4127 } 4128 function hasFocus(element) { 4129 const activeElement = getActiveElement(element); 4130 if (!activeElement) return false; 4131 if (activeElement === element) return true; 4132 const activeDescendant = activeElement.getAttribute("aria-activedescendant"); 4133 if (!activeDescendant) return false; 4134 return activeDescendant === element.id; 4135 } 4136 function hasFocusWithin(element) { 4137 const activeElement = getActiveElement(element); 4138 if (!activeElement) return false; 4139 if (contains(element, activeElement)) return true; 4140 const activeDescendant = activeElement.getAttribute("aria-activedescendant"); 4141 if (!activeDescendant) return false; 4142 if (!("id" in element)) return false; 4143 if (activeDescendant === element.id) return true; 4144 return !!element.querySelector(`#$CSS.escape(activeDescendant)}`); 4145 } 4146 function focusIfNeeded(element) { 4147 if (!hasFocusWithin(element) && isFocusable(element)) { 4148 element.focus(); 4149 } 4150 } 4151 function disableFocus(element) { 4152 var _a; 4153 const currentTabindex = (_a = element.getAttribute("tabindex")) != null ? _a : ""; 4154 element.setAttribute("data-tabindex", currentTabindex); 4155 element.setAttribute("tabindex", "-1"); 4156 } 4157 function disableFocusIn(container, includeContainer) { 4158 const tabbableElements = getAllTabbableIn(container, includeContainer); 4159 for (const element of tabbableElements) { 4160 disableFocus(element); 4161 } 4162 } 4163 function restoreFocusIn(container) { 4164 const elements2 = container.querySelectorAll("[data-tabindex]"); 4165 const restoreTabIndex = (element) => { 4166 const tabindex = element.getAttribute("data-tabindex"); 4167 element.removeAttribute("data-tabindex"); 4168 if (tabindex) { 4169 element.setAttribute("tabindex", tabindex); 4170 } else { 4171 element.removeAttribute("tabindex"); 4172 } 4173 }; 4174 if (container.hasAttribute("data-tabindex")) { 4175 restoreTabIndex(container); 4176 } 4177 for (const element of elements2) { 4178 restoreTabIndex(element); 4179 } 4180 } 4181 function focusIntoView(element, options2) { 4182 if (!("scrollIntoView" in element)) { 4183 element.focus(); 4184 } else { 4185 element.focus({ preventScroll: true }); 4186 element.scrollIntoView(__spreadValues2({ block: "nearest", inline: "nearest" }, options2)); 4187 } 4188 } 4189 4190 // node_modules/@ariakit/react-core/esm/__chunks/LVA2YJMS.js 4191 var import_react7 = __toESM(require_react(), 1); 4192 var TagName2 = "div"; 4193 var isSafariBrowser = isSafari(); 4194 var alwaysFocusVisibleInputTypes = [ 4195 "text", 4196 "search", 4197 "url", 4198 "tel", 4199 "email", 4200 "password", 4201 "number", 4202 "date", 4203 "month", 4204 "week", 4205 "time", 4206 "datetime", 4207 "datetime-local" 4208 ]; 4209 var safariFocusAncestorSymbol = Symbol("safariFocusAncestor"); 4210 function isSafariFocusAncestor(element) { 4211 if (!element) return false; 4212 return !!element[safariFocusAncestorSymbol]; 4213 } 4214 function markSafariFocusAncestor(element, value) { 4215 if (!element) return; 4216 element[safariFocusAncestorSymbol] = value; 4217 } 4218 function isAlwaysFocusVisible(element) { 4219 const { tagName, readOnly, type } = element; 4220 if (tagName === "TEXTAREA" && !readOnly) return true; 4221 if (tagName === "SELECT" && !readOnly) return true; 4222 if (tagName === "INPUT" && !readOnly) { 4223 return alwaysFocusVisibleInputTypes.includes(type); 4224 } 4225 if (element.isContentEditable) return true; 4226 const role = element.getAttribute("role"); 4227 if (role === "combobox" && element.dataset.name) { 4228 return true; 4229 } 4230 return false; 4231 } 4232 function getLabels(element) { 4233 if ("labels" in element) { 4234 return element.labels; 4235 } 4236 return null; 4237 } 4238 function isNativeCheckboxOrRadio(element) { 4239 const tagName = element.tagName.toLowerCase(); 4240 if (tagName === "input" && element.type) { 4241 return element.type === "radio" || element.type === "checkbox"; 4242 } 4243 return false; 4244 } 4245 function isNativeTabbable(tagName) { 4246 if (!tagName) return true; 4247 return tagName === "button" || tagName === "summary" || tagName === "input" || tagName === "select" || tagName === "textarea" || tagName === "a"; 4248 } 4249 function supportsDisabledAttribute(tagName) { 4250 if (!tagName) return true; 4251 return tagName === "button" || tagName === "input" || tagName === "select" || tagName === "textarea"; 4252 } 4253 function getTabIndex(focusable, trulyDisabled, nativeTabbable, supportsDisabled, tabIndexProp) { 4254 if (!focusable) { 4255 return tabIndexProp; 4256 } 4257 if (trulyDisabled) { 4258 if (nativeTabbable && !supportsDisabled) { 4259 return -1; 4260 } 4261 return; 4262 } 4263 if (nativeTabbable) { 4264 return tabIndexProp; 4265 } 4266 return tabIndexProp || 0; 4267 } 4268 function useDisableEvent(onEvent, disabled) { 4269 return useEvent((event) => { 4270 onEvent == null ? void 0 : onEvent(event); 4271 if (event.defaultPrevented) return; 4272 if (disabled) { 4273 event.stopPropagation(); 4274 event.preventDefault(); 4275 } 4276 }); 4277 } 4278 var isKeyboardModality = true; 4279 function onGlobalMouseDown(event) { 4280 const target = event.target; 4281 if (target && "hasAttribute" in target) { 4282 if (!target.hasAttribute("data-focus-visible")) { 4283 isKeyboardModality = false; 4284 } 4285 } 4286 } 4287 function onGlobalKeyDown(event) { 4288 if (event.metaKey) return; 4289 if (event.ctrlKey) return; 4290 if (event.altKey) return; 4291 isKeyboardModality = true; 4292 } 4293 var useFocusable = createHook( 4294 function useFocusable2(_a) { 4295 var _b = _a, { 4296 focusable = true, 4297 accessibleWhenDisabled, 4298 autoFocus, 4299 onFocusVisible 4300 } = _b, props = __objRest(_b, [ 4301 "focusable", 4302 "accessibleWhenDisabled", 4303 "autoFocus", 4304 "onFocusVisible" 4305 ]); 4306 const ref = (0, import_react7.useRef)(null); 4307 (0, import_react7.useEffect)(() => { 4308 if (!focusable) return; 4309 addGlobalEventListener("mousedown", onGlobalMouseDown, true); 4310 addGlobalEventListener("keydown", onGlobalKeyDown, true); 4311 }, [focusable]); 4312 if (isSafariBrowser) { 4313 (0, import_react7.useEffect)(() => { 4314 if (!focusable) return; 4315 const element = ref.current; 4316 if (!element) return; 4317 if (!isNativeCheckboxOrRadio(element)) return; 4318 const labels = getLabels(element); 4319 if (!labels) return; 4320 const onMouseUp = () => queueMicrotask(() => element.focus()); 4321 for (const label of labels) { 4322 label.addEventListener("mouseup", onMouseUp); 4323 } 4324 return () => { 4325 for (const label of labels) { 4326 label.removeEventListener("mouseup", onMouseUp); 4327 } 4328 }; 4329 }, [focusable]); 4330 } 4331 const disabled = focusable && disabledFromProps(props); 4332 const trulyDisabled = !!disabled && !accessibleWhenDisabled; 4333 const [focusVisible, setFocusVisible] = (0, import_react7.useState)(false); 4334 (0, import_react7.useEffect)(() => { 4335 if (!focusable) return; 4336 if (trulyDisabled && focusVisible) { 4337 setFocusVisible(false); 4338 } 4339 }, [focusable, trulyDisabled, focusVisible]); 4340 (0, import_react7.useEffect)(() => { 4341 if (!focusable) return; 4342 if (!focusVisible) return; 4343 const element = ref.current; 4344 if (!element) return; 4345 if (typeof IntersectionObserver === "undefined") return; 4346 const observer = new IntersectionObserver(() => { 4347 if (!isFocusable(element)) { 4348 setFocusVisible(false); 4349 } 4350 }); 4351 observer.observe(element); 4352 return () => observer.disconnect(); 4353 }, [focusable, focusVisible]); 4354 const onKeyPressCapture = useDisableEvent( 4355 props.onKeyPressCapture, 4356 disabled 4357 ); 4358 const onMouseDownCapture = useDisableEvent( 4359 props.onMouseDownCapture, 4360 disabled 4361 ); 4362 const onClickCapture = useDisableEvent(props.onClickCapture, disabled); 4363 const onMouseDownProp = props.onMouseDown; 4364 const onMouseDown = useEvent((event) => { 4365 onMouseDownProp == null ? void 0 : onMouseDownProp(event); 4366 if (event.defaultPrevented) return; 4367 if (!focusable) return; 4368 const element = event.currentTarget; 4369 if (!isSafariBrowser) return; 4370 if (isPortalEvent(event)) return; 4371 if (!isButton(element) && !isNativeCheckboxOrRadio(element)) return; 4372 let receivedFocus = false; 4373 const onFocus = () => { 4374 receivedFocus = true; 4375 }; 4376 const options2 = { capture: true, once: true }; 4377 element.addEventListener("focusin", onFocus, options2); 4378 const focusableContainer = getClosestFocusable(element.parentElement); 4379 markSafariFocusAncestor(focusableContainer, true); 4380 queueBeforeEvent(element, "mouseup", () => { 4381 element.removeEventListener("focusin", onFocus, true); 4382 markSafariFocusAncestor(focusableContainer, false); 4383 if (receivedFocus) return; 4384 focusIfNeeded(element); 4385 }); 4386 }); 4387 const handleFocusVisible = (event, currentTarget) => { 4388 if (currentTarget) { 4389 event.currentTarget = currentTarget; 4390 } 4391 if (!focusable) return; 4392 const element = event.currentTarget; 4393 if (!element) return; 4394 if (!hasFocus(element)) return; 4395 onFocusVisible == null ? void 0 : onFocusVisible(event); 4396 if (event.defaultPrevented) return; 4397 element.dataset.focusVisible = "true"; 4398 setFocusVisible(true); 4399 }; 4400 const onKeyDownCaptureProp = props.onKeyDownCapture; 4401 const onKeyDownCapture = useEvent((event) => { 4402 onKeyDownCaptureProp == null ? void 0 : onKeyDownCaptureProp(event); 4403 if (event.defaultPrevented) return; 4404 if (!focusable) return; 4405 if (focusVisible) return; 4406 if (event.metaKey) return; 4407 if (event.altKey) return; 4408 if (event.ctrlKey) return; 4409 if (!isSelfTarget(event)) return; 4410 const element = event.currentTarget; 4411 const applyFocusVisible = () => handleFocusVisible(event, element); 4412 queueBeforeEvent(element, "focusout", applyFocusVisible); 4413 }); 4414 const onFocusCaptureProp = props.onFocusCapture; 4415 const onFocusCapture = useEvent((event) => { 4416 onFocusCaptureProp == null ? void 0 : onFocusCaptureProp(event); 4417 if (event.defaultPrevented) return; 4418 if (!focusable) return; 4419 if (!isSelfTarget(event)) { 4420 setFocusVisible(false); 4421 return; 4422 } 4423 const element = event.currentTarget; 4424 const applyFocusVisible = () => handleFocusVisible(event, element); 4425 if (isKeyboardModality || isAlwaysFocusVisible(event.target)) { 4426 queueBeforeEvent(event.target, "focusout", applyFocusVisible); 4427 } else { 4428 setFocusVisible(false); 4429 } 4430 }); 4431 const onBlurProp = props.onBlur; 4432 const onBlur = useEvent((event) => { 4433 onBlurProp == null ? void 0 : onBlurProp(event); 4434 if (!focusable) return; 4435 if (!isFocusEventOutside(event)) return; 4436 setFocusVisible(false); 4437 }); 4438 const autoFocusOnShow = (0, import_react7.useContext)(FocusableContext); 4439 const autoFocusRef = useEvent((element) => { 4440 if (!focusable) return; 4441 if (!autoFocus) return; 4442 if (!element) return; 4443 if (!autoFocusOnShow) return; 4444 queueMicrotask(() => { 4445 if (hasFocus(element)) return; 4446 if (!isFocusable(element)) return; 4447 element.focus(); 4448 }); 4449 }); 4450 const tagName = useTagName(ref); 4451 const nativeTabbable = focusable && isNativeTabbable(tagName); 4452 const supportsDisabled = focusable && supportsDisabledAttribute(tagName); 4453 const styleProp = props.style; 4454 const style2 = (0, import_react7.useMemo)(() => { 4455 if (trulyDisabled) { 4456 return __spreadValues({ pointerEvents: "none" }, styleProp); 4457 } 4458 return styleProp; 4459 }, [trulyDisabled, styleProp]); 4460 props = __spreadProps(__spreadValues({ 4461 "data-focus-visible": focusable && focusVisible || void 0, 4462 "data-autofocus": autoFocus || void 0, 4463 "aria-disabled": disabled || void 0 4464 }, props), { 4465 ref: useMergeRefs(ref, autoFocusRef, props.ref), 4466 style: style2, 4467 tabIndex: getTabIndex( 4468 focusable, 4469 trulyDisabled, 4470 nativeTabbable, 4471 supportsDisabled, 4472 props.tabIndex 4473 ), 4474 disabled: supportsDisabled && trulyDisabled ? true : void 0, 4475 // TODO: Test Focusable contentEditable. 4476 contentEditable: disabled ? void 0 : props.contentEditable, 4477 onKeyPressCapture, 4478 onClickCapture, 4479 onMouseDownCapture, 4480 onMouseDown, 4481 onKeyDownCapture, 4482 onFocusCapture, 4483 onBlur 4484 }); 4485 return removeUndefinedValues(props); 4486 } 4487 ); 4488 var Focusable = forwardRef2(function Focusable2(props) { 4489 const htmlProps = useFocusable(props); 4490 return createElement(TagName2, htmlProps); 4491 }); 4492 4493 // node_modules/@ariakit/react-core/esm/__chunks/ITI7HKP4.js 4494 var import_react8 = __toESM(require_react(), 1); 4495 var import_jsx_runtime2 = __toESM(require_jsx_runtime(), 1); 4496 var TagName3 = "div"; 4497 function isGrid(items) { 4498 return items.some((item2) => !!item2.rowId); 4499 } 4500 function isPrintableKey(event) { 4501 const target = event.target; 4502 if (target && !isTextField(target)) return false; 4503 return event.key.length === 1 && !event.ctrlKey && !event.metaKey; 4504 } 4505 function isModifierKey(event) { 4506 return event.key === "Shift" || event.key === "Control" || event.key === "Alt" || event.key === "Meta"; 4507 } 4508 function useKeyboardEventProxy(store, onKeyboardEvent, previousElementRef) { 4509 return useEvent((event) => { 4510 var _a; 4511 onKeyboardEvent == null ? void 0 : onKeyboardEvent(event); 4512 if (event.defaultPrevented) return; 4513 if (event.isPropagationStopped()) return; 4514 if (!isSelfTarget(event)) return; 4515 if (isModifierKey(event)) return; 4516 if (isPrintableKey(event)) return; 4517 const state = store.getState(); 4518 const activeElement = (_a = getEnabledItem(store, state.activeId)) == null ? void 0 : _a.element; 4519 if (!activeElement) return; 4520 const _b = event, { view } = _b, eventInit = __objRest(_b, ["view"]); 4521 const previousElement = previousElementRef == null ? void 0 : previousElementRef.current; 4522 if (activeElement !== previousElement) { 4523 activeElement.focus(); 4524 } 4525 if (!fireKeyboardEvent(activeElement, event.type, eventInit)) { 4526 event.preventDefault(); 4527 } 4528 if (event.currentTarget.contains(activeElement)) { 4529 event.stopPropagation(); 4530 } 4531 }); 4532 } 4533 function findFirstEnabledItemInTheLastRow(items) { 4534 return findFirstEnabledItem2( 4535 flatten2DArray(reverseArray(groupItemsByRows2(items))) 4536 ); 4537 } 4538 function useScheduleFocus(store) { 4539 const [scheduled, setScheduled] = (0, import_react8.useState)(false); 4540 const schedule = (0, import_react8.useCallback)(() => setScheduled(true), []); 4541 const activeItem = store.useState( 4542 (state) => getEnabledItem(store, state.activeId) 4543 ); 4544 (0, import_react8.useEffect)(() => { 4545 const activeElement = activeItem == null ? void 0 : activeItem.element; 4546 if (!scheduled) return; 4547 if (!activeElement) return; 4548 setScheduled(false); 4549 activeElement.focus({ preventScroll: true }); 4550 }, [activeItem, scheduled]); 4551 return schedule; 4552 } 4553 var useComposite = createHook( 4554 function useComposite2(_a) { 4555 var _b = _a, { 4556 store, 4557 composite = true, 4558 focusOnMove = composite, 4559 moveOnKeyPress = true 4560 } = _b, props = __objRest(_b, [ 4561 "store", 4562 "composite", 4563 "focusOnMove", 4564 "moveOnKeyPress" 4565 ]); 4566 const context = useCompositeProviderContext(); 4567 store = store || context; 4568 invariant( 4569 store, 4570 "Composite must receive a `store` prop or be wrapped in a CompositeProvider component." 4571 ); 4572 const ref = (0, import_react8.useRef)(null); 4573 const previousElementRef = (0, import_react8.useRef)(null); 4574 const scheduleFocus = useScheduleFocus(store); 4575 const moves = store.useState("moves"); 4576 const [, setBaseElement] = useTransactionState( 4577 composite ? store.setBaseElement : null 4578 ); 4579 (0, import_react8.useEffect)(() => { 4580 var _a2; 4581 if (!store) return; 4582 if (!moves) return; 4583 if (!composite) return; 4584 if (!focusOnMove) return; 4585 const { activeId: activeId2 } = store.getState(); 4586 const itemElement = (_a2 = getEnabledItem(store, activeId2)) == null ? void 0 : _a2.element; 4587 if (!itemElement) return; 4588 focusIntoView(itemElement); 4589 }, [store, moves, composite, focusOnMove]); 4590 useSafeLayoutEffect(() => { 4591 if (!store) return; 4592 if (!moves) return; 4593 if (!composite) return; 4594 const { baseElement, activeId: activeId2 } = store.getState(); 4595 const isSelfAcive = activeId2 === null; 4596 if (!isSelfAcive) return; 4597 if (!baseElement) return; 4598 const previousElement = previousElementRef.current; 4599 previousElementRef.current = null; 4600 if (previousElement) { 4601 fireBlurEvent(previousElement, { relatedTarget: baseElement }); 4602 } 4603 if (!hasFocus(baseElement)) { 4604 baseElement.focus(); 4605 } 4606 }, [store, moves, composite]); 4607 const activeId = store.useState("activeId"); 4608 const virtualFocus = store.useState("virtualFocus"); 4609 useSafeLayoutEffect(() => { 4610 var _a2; 4611 if (!store) return; 4612 if (!composite) return; 4613 if (!virtualFocus) return; 4614 const previousElement = previousElementRef.current; 4615 previousElementRef.current = null; 4616 if (!previousElement) return; 4617 const activeElement = (_a2 = getEnabledItem(store, activeId)) == null ? void 0 : _a2.element; 4618 const relatedTarget = activeElement || getActiveElement(previousElement); 4619 if (relatedTarget === previousElement) return; 4620 fireBlurEvent(previousElement, { relatedTarget }); 4621 }, [store, activeId, virtualFocus, composite]); 4622 const onKeyDownCapture = useKeyboardEventProxy( 4623 store, 4624 props.onKeyDownCapture, 4625 previousElementRef 4626 ); 4627 const onKeyUpCapture = useKeyboardEventProxy( 4628 store, 4629 props.onKeyUpCapture, 4630 previousElementRef 4631 ); 4632 const onFocusCaptureProp = props.onFocusCapture; 4633 const onFocusCapture = useEvent((event) => { 4634 onFocusCaptureProp == null ? void 0 : onFocusCaptureProp(event); 4635 if (event.defaultPrevented) return; 4636 if (!store) return; 4637 const { virtualFocus: virtualFocus2 } = store.getState(); 4638 if (!virtualFocus2) return; 4639 const previousActiveElement = event.relatedTarget; 4640 const isSilentlyFocused = silentlyFocused(event.currentTarget); 4641 if (isSelfTarget(event) && isSilentlyFocused) { 4642 event.stopPropagation(); 4643 previousElementRef.current = previousActiveElement; 4644 } 4645 }); 4646 const onFocusProp = props.onFocus; 4647 const onFocus = useEvent((event) => { 4648 onFocusProp == null ? void 0 : onFocusProp(event); 4649 if (event.defaultPrevented) return; 4650 if (!composite) return; 4651 if (!store) return; 4652 const { relatedTarget } = event; 4653 const { virtualFocus: virtualFocus2 } = store.getState(); 4654 if (virtualFocus2) { 4655 if (isSelfTarget(event) && !isItem(store, relatedTarget)) { 4656 queueMicrotask(scheduleFocus); 4657 } 4658 } else if (isSelfTarget(event)) { 4659 store.setActiveId(null); 4660 } 4661 }); 4662 const onBlurCaptureProp = props.onBlurCapture; 4663 const onBlurCapture = useEvent((event) => { 4664 var _a2; 4665 onBlurCaptureProp == null ? void 0 : onBlurCaptureProp(event); 4666 if (event.defaultPrevented) return; 4667 if (!store) return; 4668 const { virtualFocus: virtualFocus2, activeId: activeId2 } = store.getState(); 4669 if (!virtualFocus2) return; 4670 const activeElement = (_a2 = getEnabledItem(store, activeId2)) == null ? void 0 : _a2.element; 4671 const nextActiveElement = event.relatedTarget; 4672 const nextActiveElementIsItem = isItem(store, nextActiveElement); 4673 const previousElement = previousElementRef.current; 4674 previousElementRef.current = null; 4675 if (isSelfTarget(event) && nextActiveElementIsItem) { 4676 if (nextActiveElement === activeElement) { 4677 if (previousElement && previousElement !== nextActiveElement) { 4678 fireBlurEvent(previousElement, event); 4679 } 4680 } else if (activeElement) { 4681 fireBlurEvent(activeElement, event); 4682 } else if (previousElement) { 4683 fireBlurEvent(previousElement, event); 4684 } 4685 event.stopPropagation(); 4686 } else { 4687 const targetIsItem = isItem(store, event.target); 4688 if (!targetIsItem && activeElement) { 4689 fireBlurEvent(activeElement, event); 4690 } 4691 } 4692 }); 4693 const onKeyDownProp = props.onKeyDown; 4694 const moveOnKeyPressProp = useBooleanEvent(moveOnKeyPress); 4695 const onKeyDown = useEvent((event) => { 4696 var _a2; 4697 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 4698 if (event.defaultPrevented) return; 4699 if (!store) return; 4700 if (!isSelfTarget(event)) return; 4701 const { orientation, renderedItems, activeId: activeId2 } = store.getState(); 4702 const activeItem = getEnabledItem(store, activeId2); 4703 if ((_a2 = activeItem == null ? void 0 : activeItem.element) == null ? void 0 : _a2.isConnected) return; 4704 const isVertical = orientation !== "horizontal"; 4705 const isHorizontal = orientation !== "vertical"; 4706 const grid = isGrid(renderedItems); 4707 const isHorizontalKey = event.key === "ArrowLeft" || event.key === "ArrowRight" || event.key === "Home" || event.key === "End"; 4708 if (isHorizontalKey && isTextField(event.currentTarget)) return; 4709 const up = () => { 4710 if (grid) { 4711 const item2 = findFirstEnabledItemInTheLastRow(renderedItems); 4712 return item2 == null ? void 0 : item2.id; 4713 } 4714 return store == null ? void 0 : store.last(); 4715 }; 4716 const keyMap = { 4717 ArrowUp: (grid || isVertical) && up, 4718 ArrowRight: (grid || isHorizontal) && store.first, 4719 ArrowDown: (grid || isVertical) && store.first, 4720 ArrowLeft: (grid || isHorizontal) && store.last, 4721 Home: store.first, 4722 End: store.last, 4723 PageUp: store.first, 4724 PageDown: store.last 4725 }; 4726 const action = keyMap[event.key]; 4727 if (action) { 4728 const id3 = action(); 4729 if (id3 !== void 0) { 4730 if (!moveOnKeyPressProp(event)) return; 4731 event.preventDefault(); 4732 store.move(id3); 4733 } 4734 } 4735 }); 4736 props = useWrapElement( 4737 props, 4738 (element) => /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(CompositeContextProvider, { value: store, children: element }), 4739 [store] 4740 ); 4741 const activeDescendant = store.useState((state) => { 4742 var _a2; 4743 if (!store) return; 4744 if (!composite) return; 4745 if (!state.virtualFocus) return; 4746 return (_a2 = getEnabledItem(store, state.activeId)) == null ? void 0 : _a2.id; 4747 }); 4748 props = __spreadProps(__spreadValues({ 4749 "aria-activedescendant": activeDescendant 4750 }, props), { 4751 ref: useMergeRefs(ref, setBaseElement, props.ref), 4752 onKeyDownCapture, 4753 onKeyUpCapture, 4754 onFocusCapture, 4755 onFocus, 4756 onBlurCapture, 4757 onKeyDown 4758 }); 4759 const focusable = store.useState( 4760 (state) => composite && (state.virtualFocus || state.activeId === null) 4761 ); 4762 props = useFocusable(__spreadValues({ focusable }, props)); 4763 return props; 4764 } 4765 ); 4766 var Composite = forwardRef2(function Composite2(props) { 4767 const htmlProps = useComposite(props); 4768 return createElement(TagName3, htmlProps); 4769 }); 4770 4771 // node_modules/@ariakit/react-core/esm/__chunks/KUU7WJ55.js 4772 var import_react9 = __toESM(require_react(), 1); 4773 var TagName4 = "button"; 4774 function isNativeClick(event) { 4775 if (!event.isTrusted) return false; 4776 const element = event.currentTarget; 4777 if (event.key === "Enter") { 4778 return isButton(element) || element.tagName === "SUMMARY" || element.tagName === "A"; 4779 } 4780 if (event.key === " ") { 4781 return isButton(element) || element.tagName === "SUMMARY" || element.tagName === "INPUT" || element.tagName === "SELECT"; 4782 } 4783 return false; 4784 } 4785 var symbol = Symbol("command"); 4786 var useCommand = createHook( 4787 function useCommand2(_a) { 4788 var _b = _a, { clickOnEnter = true, clickOnSpace = true } = _b, props = __objRest(_b, ["clickOnEnter", "clickOnSpace"]); 4789 const ref = (0, import_react9.useRef)(null); 4790 const [isNativeButton, setIsNativeButton] = (0, import_react9.useState)(false); 4791 (0, import_react9.useEffect)(() => { 4792 if (!ref.current) return; 4793 setIsNativeButton(isButton(ref.current)); 4794 }, []); 4795 const [active, setActive] = (0, import_react9.useState)(false); 4796 const activeRef = (0, import_react9.useRef)(false); 4797 const disabled = disabledFromProps(props); 4798 const [isDuplicate, metadataProps] = useMetadataProps(props, symbol, true); 4799 const onKeyDownProp = props.onKeyDown; 4800 const onKeyDown = useEvent((event) => { 4801 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 4802 const element = event.currentTarget; 4803 if (event.defaultPrevented) return; 4804 if (isDuplicate) return; 4805 if (disabled) return; 4806 if (!isSelfTarget(event)) return; 4807 if (isTextField(element)) return; 4808 if (element.isContentEditable) return; 4809 const isEnter = clickOnEnter && event.key === "Enter"; 4810 const isSpace = clickOnSpace && event.key === " "; 4811 const shouldPreventEnter = event.key === "Enter" && !clickOnEnter; 4812 const shouldPreventSpace = event.key === " " && !clickOnSpace; 4813 if (shouldPreventEnter || shouldPreventSpace) { 4814 event.preventDefault(); 4815 return; 4816 } 4817 if (isEnter || isSpace) { 4818 const nativeClick = isNativeClick(event); 4819 if (isEnter) { 4820 if (!nativeClick) { 4821 event.preventDefault(); 4822 const _a2 = event, { view } = _a2, eventInit = __objRest(_a2, ["view"]); 4823 const click = () => fireClickEvent(element, eventInit); 4824 if (isFirefox()) { 4825 queueBeforeEvent(element, "keyup", click); 4826 } else { 4827 queueMicrotask(click); 4828 } 4829 } 4830 } else if (isSpace) { 4831 activeRef.current = true; 4832 if (!nativeClick) { 4833 event.preventDefault(); 4834 setActive(true); 4835 } 4836 } 4837 } 4838 }); 4839 const onKeyUpProp = props.onKeyUp; 4840 const onKeyUp = useEvent((event) => { 4841 onKeyUpProp == null ? void 0 : onKeyUpProp(event); 4842 if (event.defaultPrevented) return; 4843 if (isDuplicate) return; 4844 if (disabled) return; 4845 if (event.metaKey) return; 4846 const isSpace = clickOnSpace && event.key === " "; 4847 if (activeRef.current && isSpace) { 4848 activeRef.current = false; 4849 if (!isNativeClick(event)) { 4850 event.preventDefault(); 4851 setActive(false); 4852 const element = event.currentTarget; 4853 const _a2 = event, { view } = _a2, eventInit = __objRest(_a2, ["view"]); 4854 queueMicrotask(() => fireClickEvent(element, eventInit)); 4855 } 4856 } 4857 }); 4858 props = __spreadProps(__spreadValues(__spreadValues({ 4859 "data-active": active || void 0, 4860 type: isNativeButton ? "button" : void 0 4861 }, metadataProps), props), { 4862 ref: useMergeRefs(ref, props.ref), 4863 onKeyDown, 4864 onKeyUp 4865 }); 4866 props = useFocusable(props); 4867 return props; 4868 } 4869 ); 4870 var Command = forwardRef2(function Command2(props) { 4871 const htmlProps = useCommand(props); 4872 return createElement(TagName4, htmlProps); 4873 }); 4874 4875 // node_modules/@ariakit/react-core/esm/__chunks/X5NMLKT6.js 4876 var import_react10 = __toESM(require_react(), 1); 4877 var TagName5 = "button"; 4878 var useButton = createHook( 4879 function useButton2(props) { 4880 const ref = (0, import_react10.useRef)(null); 4881 const tagName = useTagName(ref, TagName5); 4882 const [isNativeButton, setIsNativeButton] = (0, import_react10.useState)( 4883 () => !!tagName && isButton({ tagName, type: props.type }) 4884 ); 4885 (0, import_react10.useEffect)(() => { 4886 if (!ref.current) return; 4887 setIsNativeButton(isButton(ref.current)); 4888 }, []); 4889 props = __spreadProps(__spreadValues({ 4890 role: !isNativeButton && tagName !== "a" ? "button" : void 0 4891 }, props), { 4892 ref: useMergeRefs(ref, props.ref) 4893 }); 4894 props = useCommand(props); 4895 return props; 4896 } 4897 ); 4898 var Button = forwardRef2(function Button2(props) { 4899 const htmlProps = useButton(props); 4900 return createElement(TagName5, htmlProps); 4901 }); 4902 4903 // node_modules/@ariakit/react-core/esm/__chunks/P4IRICAX.js 4904 var import_react11 = __toESM(require_react(), 1); 4905 var TagName6 = "button"; 4906 var symbol2 = Symbol("disclosure"); 4907 var useDisclosure = createHook( 4908 function useDisclosure2(_a) { 4909 var _b = _a, { store, toggleOnClick = true } = _b, props = __objRest(_b, ["store", "toggleOnClick"]); 4910 const context = useDisclosureProviderContext(); 4911 store = store || context; 4912 invariant( 4913 store, 4914 "Disclosure must receive a `store` prop or be wrapped in a DisclosureProvider component." 4915 ); 4916 const ref = (0, import_react11.useRef)(null); 4917 const [expanded, setExpanded] = (0, import_react11.useState)(false); 4918 const disclosureElement = store.useState("disclosureElement"); 4919 const open = store.useState("open"); 4920 (0, import_react11.useEffect)(() => { 4921 let isCurrentDisclosure = disclosureElement === ref.current; 4922 if (!(disclosureElement == null ? void 0 : disclosureElement.isConnected)) { 4923 store == null ? void 0 : store.setDisclosureElement(ref.current); 4924 isCurrentDisclosure = true; 4925 } 4926 setExpanded(open && isCurrentDisclosure); 4927 }, [disclosureElement, store, open]); 4928 const onClickProp = props.onClick; 4929 const toggleOnClickProp = useBooleanEvent(toggleOnClick); 4930 const [isDuplicate, metadataProps] = useMetadataProps(props, symbol2, true); 4931 const onClick = useEvent((event) => { 4932 onClickProp == null ? void 0 : onClickProp(event); 4933 if (event.defaultPrevented) return; 4934 if (isDuplicate) return; 4935 if (!toggleOnClickProp(event)) return; 4936 store == null ? void 0 : store.setDisclosureElement(event.currentTarget); 4937 store == null ? void 0 : store.toggle(); 4938 }); 4939 const contentElement = store.useState("contentElement"); 4940 props = __spreadProps(__spreadValues(__spreadValues({ 4941 "aria-expanded": expanded, 4942 "aria-controls": contentElement == null ? void 0 : contentElement.id 4943 }, metadataProps), props), { 4944 ref: useMergeRefs(ref, props.ref), 4945 onClick 4946 }); 4947 props = useButton(props); 4948 return props; 4949 } 4950 ); 4951 var Disclosure = forwardRef2(function Disclosure2(props) { 4952 const htmlProps = useDisclosure(props); 4953 return createElement(TagName6, htmlProps); 4954 }); 4955 4956 // node_modules/@ariakit/react-core/esm/__chunks/AXB53BZF.js 4957 var TagName7 = "button"; 4958 var useDialogDisclosure = createHook( 4959 function useDialogDisclosure2(_a) { 4960 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 4961 const context = useDialogProviderContext(); 4962 store = store || context; 4963 invariant( 4964 store, 4965 "DialogDisclosure must receive a `store` prop or be wrapped in a DialogProvider component." 4966 ); 4967 const contentElement = store.useState("contentElement"); 4968 props = __spreadValues({ 4969 "aria-haspopup": getPopupRole(contentElement, "dialog") 4970 }, props); 4971 props = useDisclosure(__spreadValues({ store }, props)); 4972 return props; 4973 } 4974 ); 4975 var DialogDisclosure = forwardRef2(function DialogDisclosure2(props) { 4976 const htmlProps = useDialogDisclosure(props); 4977 return createElement(TagName7, htmlProps); 4978 }); 4979 4980 // node_modules/@ariakit/react-core/esm/__chunks/7HVFURXT.js 4981 var import_react12 = __toESM(require_react(), 1); 4982 var GroupLabelContext = (0, import_react12.createContext)(void 0); 4983 4984 // node_modules/@ariakit/react-core/esm/__chunks/YUOJWFSO.js 4985 var import_react13 = __toESM(require_react(), 1); 4986 var TagName8 = "div"; 4987 var useGroupLabel = createHook( 4988 function useGroupLabel2(props) { 4989 const setLabelId = (0, import_react13.useContext)(GroupLabelContext); 4990 const id3 = useId(props.id); 4991 useSafeLayoutEffect(() => { 4992 setLabelId == null ? void 0 : setLabelId(id3); 4993 return () => setLabelId == null ? void 0 : setLabelId(void 0); 4994 }, [setLabelId, id3]); 4995 props = __spreadValues({ 4996 id: id3, 4997 "aria-hidden": true 4998 }, props); 4999 return removeUndefinedValues(props); 5000 } 5001 ); 5002 var GroupLabel = forwardRef2(function GroupLabel2(props) { 5003 const htmlProps = useGroupLabel(props); 5004 return createElement(TagName8, htmlProps); 5005 }); 5006 5007 // node_modules/@ariakit/react-core/esm/__chunks/SWSPTQMT.js 5008 var TagName9 = "div"; 5009 var useCompositeGroupLabel = createHook(function useCompositeGroupLabel2(_a) { 5010 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 5011 props = useGroupLabel(props); 5012 return props; 5013 }); 5014 var CompositeGroupLabel = forwardRef2(function CompositeGroupLabel2(props) { 5015 const htmlProps = useCompositeGroupLabel(props); 5016 return createElement(TagName9, htmlProps); 5017 }); 5018 5019 // node_modules/@ariakit/react-core/esm/__chunks/36LIF33V.js 5020 var import_react14 = __toESM(require_react(), 1); 5021 var import_jsx_runtime3 = __toESM(require_jsx_runtime(), 1); 5022 var TagName10 = "div"; 5023 var useGroup = createHook( 5024 function useGroup2(props) { 5025 const [labelId, setLabelId] = (0, import_react14.useState)(); 5026 props = useWrapElement( 5027 props, 5028 (element) => /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(GroupLabelContext.Provider, { value: setLabelId, children: element }), 5029 [] 5030 ); 5031 props = __spreadValues({ 5032 role: "group", 5033 "aria-labelledby": labelId 5034 }, props); 5035 return removeUndefinedValues(props); 5036 } 5037 ); 5038 var Group = forwardRef2(function Group2(props) { 5039 const htmlProps = useGroup(props); 5040 return createElement(TagName10, htmlProps); 5041 }); 5042 5043 // node_modules/@ariakit/react-core/esm/__chunks/YORGHBM4.js 5044 var TagName11 = "div"; 5045 var useCompositeGroup = createHook( 5046 function useCompositeGroup2(_a) { 5047 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 5048 props = useGroup(props); 5049 return props; 5050 } 5051 ); 5052 var CompositeGroup = forwardRef2(function CompositeGroup2(props) { 5053 const htmlProps = useCompositeGroup(props); 5054 return createElement(TagName11, htmlProps); 5055 }); 5056 5057 // node_modules/@ariakit/react-core/esm/__chunks/EYKMH5G5.js 5058 var import_react15 = __toESM(require_react(), 1); 5059 var CheckboxCheckedContext = (0, import_react15.createContext)(false); 5060 5061 // node_modules/@ariakit/react-core/esm/__chunks/5JCRYSSV.js 5062 var import_react16 = __toESM(require_react(), 1); 5063 var import_jsx_runtime4 = __toESM(require_jsx_runtime(), 1); 5064 var TagName12 = "span"; 5065 var checkmark = /* @__PURE__ */ (0, import_jsx_runtime4.jsx)( 5066 "svg", 5067 { 5068 display: "block", 5069 fill: "none", 5070 stroke: "currentColor", 5071 strokeLinecap: "round", 5072 strokeLinejoin: "round", 5073 strokeWidth: 1.5, 5074 viewBox: "0 0 16 16", 5075 height: "1em", 5076 width: "1em", 5077 children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("polyline", { points: "4,8 7,12 12,4" }) 5078 } 5079 ); 5080 function getChildren(props) { 5081 if (props.checked) { 5082 return props.children || checkmark; 5083 } 5084 if (typeof props.children === "function") { 5085 return props.children; 5086 } 5087 return null; 5088 } 5089 var useCheckboxCheck = createHook( 5090 function useCheckboxCheck2(_a) { 5091 var _b = _a, { store, checked } = _b, props = __objRest(_b, ["store", "checked"]); 5092 const context = (0, import_react16.useContext)(CheckboxCheckedContext); 5093 checked = checked != null ? checked : context; 5094 const children = getChildren({ checked, children: props.children }); 5095 props = __spreadProps(__spreadValues({ 5096 "aria-hidden": true 5097 }, props), { 5098 children, 5099 style: __spreadValues({ 5100 width: "1em", 5101 height: "1em", 5102 pointerEvents: "none" 5103 }, props.style) 5104 }); 5105 return removeUndefinedValues(props); 5106 } 5107 ); 5108 var CheckboxCheck = forwardRef2(function CheckboxCheck2(props) { 5109 const htmlProps = useCheckboxCheck(props); 5110 return createElement(TagName12, htmlProps); 5111 }); 5112 5113 // node_modules/@ariakit/react-core/esm/__chunks/UQQRIHDV.js 5114 var import_react17 = __toESM(require_react(), 1); 5115 var TagName13 = "div"; 5116 function getMouseDestination(event) { 5117 const relatedTarget = event.relatedTarget; 5118 if ((relatedTarget == null ? void 0 : relatedTarget.nodeType) === Node.ELEMENT_NODE) { 5119 return relatedTarget; 5120 } 5121 return null; 5122 } 5123 function hoveringInside(event) { 5124 const nextElement = getMouseDestination(event); 5125 if (!nextElement) return false; 5126 return contains(event.currentTarget, nextElement); 5127 } 5128 var symbol3 = Symbol("composite-hover"); 5129 function movingToAnotherItem(event) { 5130 let dest = getMouseDestination(event); 5131 if (!dest) return false; 5132 do { 5133 if (hasOwnProperty(dest, symbol3) && dest[symbol3]) return true; 5134 dest = dest.parentElement; 5135 } while (dest); 5136 return false; 5137 } 5138 var useCompositeHover = createHook( 5139 function useCompositeHover2(_a) { 5140 var _b = _a, { 5141 store, 5142 focusOnHover = true, 5143 blurOnHoverEnd = !!focusOnHover 5144 } = _b, props = __objRest(_b, [ 5145 "store", 5146 "focusOnHover", 5147 "blurOnHoverEnd" 5148 ]); 5149 const context = useCompositeContext(); 5150 store = store || context; 5151 invariant( 5152 store, 5153 "CompositeHover must be wrapped in a Composite component." 5154 ); 5155 const isMouseMoving = useIsMouseMoving(); 5156 const onMouseMoveProp = props.onMouseMove; 5157 const focusOnHoverProp = useBooleanEvent(focusOnHover); 5158 const onMouseMove = useEvent((event) => { 5159 onMouseMoveProp == null ? void 0 : onMouseMoveProp(event); 5160 if (event.defaultPrevented) return; 5161 if (!isMouseMoving()) return; 5162 if (!focusOnHoverProp(event)) return; 5163 if (!hasFocusWithin(event.currentTarget)) { 5164 const baseElement = store == null ? void 0 : store.getState().baseElement; 5165 if (baseElement && !hasFocus(baseElement)) { 5166 baseElement.focus(); 5167 } 5168 } 5169 store == null ? void 0 : store.setActiveId(event.currentTarget.id); 5170 }); 5171 const onMouseLeaveProp = props.onMouseLeave; 5172 const blurOnHoverEndProp = useBooleanEvent(blurOnHoverEnd); 5173 const onMouseLeave = useEvent((event) => { 5174 var _a2; 5175 onMouseLeaveProp == null ? void 0 : onMouseLeaveProp(event); 5176 if (event.defaultPrevented) return; 5177 if (!isMouseMoving()) return; 5178 if (hoveringInside(event)) return; 5179 if (movingToAnotherItem(event)) return; 5180 if (!focusOnHoverProp(event)) return; 5181 if (!blurOnHoverEndProp(event)) return; 5182 store == null ? void 0 : store.setActiveId(null); 5183 (_a2 = store == null ? void 0 : store.getState().baseElement) == null ? void 0 : _a2.focus(); 5184 }); 5185 const ref = (0, import_react17.useCallback)((element) => { 5186 if (!element) return; 5187 element[symbol3] = true; 5188 }, []); 5189 props = __spreadProps(__spreadValues({}, props), { 5190 ref: useMergeRefs(ref, props.ref), 5191 onMouseMove, 5192 onMouseLeave 5193 }); 5194 return removeUndefinedValues(props); 5195 } 5196 ); 5197 var CompositeHover = memo2( 5198 forwardRef2(function CompositeHover2(props) { 5199 const htmlProps = useCompositeHover(props); 5200 return createElement(TagName13, htmlProps); 5201 }) 5202 ); 5203 5204 // node_modules/@ariakit/react-core/esm/__chunks/RZ4GPYOB.js 5205 var import_react18 = __toESM(require_react(), 1); 5206 var TagName14 = "div"; 5207 var useCollectionItem = createHook( 5208 function useCollectionItem2(_a) { 5209 var _b = _a, { 5210 store, 5211 shouldRegisterItem = true, 5212 getItem = identity, 5213 element 5214 } = _b, props = __objRest(_b, [ 5215 "store", 5216 "shouldRegisterItem", 5217 "getItem", 5218 // @ts-expect-error This prop may come from a collection renderer. 5219 "element" 5220 ]); 5221 const context = useCollectionContext(); 5222 store = store || context; 5223 const id3 = useId(props.id); 5224 const ref = (0, import_react18.useRef)(element); 5225 (0, import_react18.useEffect)(() => { 5226 const element2 = ref.current; 5227 if (!id3) return; 5228 if (!element2) return; 5229 if (!shouldRegisterItem) return; 5230 const item2 = getItem({ id: id3, element: element2 }); 5231 return store == null ? void 0 : store.renderItem(item2); 5232 }, [id3, shouldRegisterItem, getItem, store]); 5233 props = __spreadProps(__spreadValues({}, props), { 5234 ref: useMergeRefs(ref, props.ref) 5235 }); 5236 return removeUndefinedValues(props); 5237 } 5238 ); 5239 var CollectionItem = forwardRef2(function CollectionItem2(props) { 5240 const htmlProps = useCollectionItem(props); 5241 return createElement(TagName14, htmlProps); 5242 }); 5243 5244 // node_modules/@ariakit/react-core/esm/__chunks/P2CTZE2T.js 5245 var import_react19 = __toESM(require_react(), 1); 5246 var import_jsx_runtime5 = __toESM(require_jsx_runtime(), 1); 5247 var TagName15 = "button"; 5248 function isEditableElement(element) { 5249 if (isTextbox(element)) return true; 5250 return element.tagName === "INPUT" && !isButton(element); 5251 } 5252 function getNextPageOffset(scrollingElement, pageUp = false) { 5253 const height = scrollingElement.clientHeight; 5254 const { top } = scrollingElement.getBoundingClientRect(); 5255 const pageSize = Math.max(height * 0.875, height - 40) * 1.5; 5256 const pageOffset = pageUp ? height - pageSize + top : pageSize + top; 5257 if (scrollingElement.tagName === "HTML") { 5258 return pageOffset + scrollingElement.scrollTop; 5259 } 5260 return pageOffset; 5261 } 5262 function getItemOffset(itemElement, pageUp = false) { 5263 const { top } = itemElement.getBoundingClientRect(); 5264 if (pageUp) { 5265 return top + itemElement.clientHeight; 5266 } 5267 return top; 5268 } 5269 function findNextPageItemId(element, store, next2, pageUp = false) { 5270 var _a; 5271 if (!store) return; 5272 if (!next2) return; 5273 const { renderedItems } = store.getState(); 5274 const scrollingElement = getScrollingElement(element); 5275 if (!scrollingElement) return; 5276 const nextPageOffset = getNextPageOffset(scrollingElement, pageUp); 5277 let id3; 5278 let prevDifference; 5279 for (let i3 = 0; i3 < renderedItems.length; i3 += 1) { 5280 const previousId = id3; 5281 id3 = next2(i3); 5282 if (!id3) break; 5283 if (id3 === previousId) continue; 5284 const itemElement = (_a = getEnabledItem(store, id3)) == null ? void 0 : _a.element; 5285 if (!itemElement) continue; 5286 const itemOffset = getItemOffset(itemElement, pageUp); 5287 const difference = itemOffset - nextPageOffset; 5288 const absDifference = Math.abs(difference); 5289 if (pageUp && difference <= 0 || !pageUp && difference >= 0) { 5290 if (prevDifference !== void 0 && prevDifference < absDifference) { 5291 id3 = previousId; 5292 } 5293 break; 5294 } 5295 prevDifference = absDifference; 5296 } 5297 return id3; 5298 } 5299 function targetIsAnotherItem(event, store) { 5300 if (isSelfTarget(event)) return false; 5301 return isItem(store, event.target); 5302 } 5303 var useCompositeItem = createHook( 5304 function useCompositeItem2(_a) { 5305 var _b = _a, { 5306 store, 5307 rowId: rowIdProp, 5308 preventScrollOnKeyDown = false, 5309 moveOnKeyPress = true, 5310 tabbable = false, 5311 getItem: getItemProp, 5312 "aria-setsize": ariaSetSizeProp, 5313 "aria-posinset": ariaPosInSetProp 5314 } = _b, props = __objRest(_b, [ 5315 "store", 5316 "rowId", 5317 "preventScrollOnKeyDown", 5318 "moveOnKeyPress", 5319 "tabbable", 5320 "getItem", 5321 "aria-setsize", 5322 "aria-posinset" 5323 ]); 5324 const context = useCompositeContext(); 5325 store = store || context; 5326 const id3 = useId(props.id); 5327 const ref = (0, import_react19.useRef)(null); 5328 const row = (0, import_react19.useContext)(CompositeRowContext); 5329 const disabled = disabledFromProps(props); 5330 const trulyDisabled = disabled && !props.accessibleWhenDisabled; 5331 const { 5332 rowId, 5333 baseElement, 5334 isActiveItem, 5335 ariaSetSize, 5336 ariaPosInSet, 5337 isTabbable: isTabbable2 5338 } = useStoreStateObject(store, { 5339 rowId(state) { 5340 if (rowIdProp) return rowIdProp; 5341 if (!state) return; 5342 if (!(row == null ? void 0 : row.baseElement)) return; 5343 if (row.baseElement !== state.baseElement) return; 5344 return row.id; 5345 }, 5346 baseElement(state) { 5347 return (state == null ? void 0 : state.baseElement) || void 0; 5348 }, 5349 isActiveItem(state) { 5350 return !!state && state.activeId === id3; 5351 }, 5352 ariaSetSize(state) { 5353 if (ariaSetSizeProp != null) return ariaSetSizeProp; 5354 if (!state) return; 5355 if (!(row == null ? void 0 : row.ariaSetSize)) return; 5356 if (row.baseElement !== state.baseElement) return; 5357 return row.ariaSetSize; 5358 }, 5359 ariaPosInSet(state) { 5360 if (ariaPosInSetProp != null) return ariaPosInSetProp; 5361 if (!state) return; 5362 if (!(row == null ? void 0 : row.ariaPosInSet)) return; 5363 if (row.baseElement !== state.baseElement) return; 5364 const itemsInRow = state.renderedItems.filter( 5365 (item2) => item2.rowId === rowId 5366 ); 5367 return row.ariaPosInSet + itemsInRow.findIndex((item2) => item2.id === id3); 5368 }, 5369 isTabbable(state) { 5370 if (!(state == null ? void 0 : state.renderedItems.length)) return true; 5371 if (state.virtualFocus) return false; 5372 if (tabbable) return true; 5373 if (state.activeId === null) return false; 5374 const item2 = store == null ? void 0 : store.item(state.activeId); 5375 if (item2 == null ? void 0 : item2.disabled) return true; 5376 if (!(item2 == null ? void 0 : item2.element)) return true; 5377 return state.activeId === id3; 5378 } 5379 }); 5380 const getItem = (0, import_react19.useCallback)( 5381 (item2) => { 5382 var _a2; 5383 const nextItem = __spreadProps(__spreadValues({}, item2), { 5384 id: id3 || item2.id, 5385 rowId, 5386 disabled: !!trulyDisabled, 5387 children: (_a2 = item2.element) == null ? void 0 : _a2.textContent 5388 }); 5389 if (getItemProp) { 5390 return getItemProp(nextItem); 5391 } 5392 return nextItem; 5393 }, 5394 [id3, rowId, trulyDisabled, getItemProp] 5395 ); 5396 const onFocusProp = props.onFocus; 5397 const hasFocusedComposite = (0, import_react19.useRef)(false); 5398 const onFocus = useEvent((event) => { 5399 onFocusProp == null ? void 0 : onFocusProp(event); 5400 if (event.defaultPrevented) return; 5401 if (isPortalEvent(event)) return; 5402 if (!id3) return; 5403 if (!store) return; 5404 if (targetIsAnotherItem(event, store)) return; 5405 const { virtualFocus, baseElement: baseElement2 } = store.getState(); 5406 store.setActiveId(id3); 5407 if (isTextbox(event.currentTarget)) { 5408 selectTextField(event.currentTarget); 5409 } 5410 if (!virtualFocus) return; 5411 if (!isSelfTarget(event)) return; 5412 if (isEditableElement(event.currentTarget)) return; 5413 if (!(baseElement2 == null ? void 0 : baseElement2.isConnected)) return; 5414 if (isSafari() && event.currentTarget.hasAttribute("data-autofocus")) { 5415 event.currentTarget.scrollIntoView({ 5416 block: "nearest", 5417 inline: "nearest" 5418 }); 5419 } 5420 hasFocusedComposite.current = true; 5421 const fromComposite = event.relatedTarget === baseElement2 || isItem(store, event.relatedTarget); 5422 if (fromComposite) { 5423 focusSilently(baseElement2); 5424 } else { 5425 baseElement2.focus(); 5426 } 5427 }); 5428 const onBlurCaptureProp = props.onBlurCapture; 5429 const onBlurCapture = useEvent((event) => { 5430 onBlurCaptureProp == null ? void 0 : onBlurCaptureProp(event); 5431 if (event.defaultPrevented) return; 5432 const state = store == null ? void 0 : store.getState(); 5433 if ((state == null ? void 0 : state.virtualFocus) && hasFocusedComposite.current) { 5434 hasFocusedComposite.current = false; 5435 event.preventDefault(); 5436 event.stopPropagation(); 5437 } 5438 }); 5439 const onKeyDownProp = props.onKeyDown; 5440 const preventScrollOnKeyDownProp = useBooleanEvent(preventScrollOnKeyDown); 5441 const moveOnKeyPressProp = useBooleanEvent(moveOnKeyPress); 5442 const onKeyDown = useEvent((event) => { 5443 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 5444 if (event.defaultPrevented) return; 5445 if (!isSelfTarget(event)) return; 5446 if (!store) return; 5447 const { currentTarget } = event; 5448 const state = store.getState(); 5449 const item2 = store.item(id3); 5450 const isGrid2 = !!(item2 == null ? void 0 : item2.rowId); 5451 const isVertical = state.orientation !== "horizontal"; 5452 const isHorizontal = state.orientation !== "vertical"; 5453 const canHomeEnd = () => { 5454 if (isGrid2) return true; 5455 if (isHorizontal) return true; 5456 if (!state.baseElement) return true; 5457 if (!isTextField(state.baseElement)) return true; 5458 return false; 5459 }; 5460 const keyMap = { 5461 ArrowUp: (isGrid2 || isVertical) && store.up, 5462 ArrowRight: (isGrid2 || isHorizontal) && store.next, 5463 ArrowDown: (isGrid2 || isVertical) && store.down, 5464 ArrowLeft: (isGrid2 || isHorizontal) && store.previous, 5465 Home: () => { 5466 if (!canHomeEnd()) return; 5467 if (!isGrid2 || event.ctrlKey) { 5468 return store == null ? void 0 : store.first(); 5469 } 5470 return store == null ? void 0 : store.previous(-1); 5471 }, 5472 End: () => { 5473 if (!canHomeEnd()) return; 5474 if (!isGrid2 || event.ctrlKey) { 5475 return store == null ? void 0 : store.last(); 5476 } 5477 return store == null ? void 0 : store.next(-1); 5478 }, 5479 PageUp: () => { 5480 return findNextPageItemId(currentTarget, store, store == null ? void 0 : store.up, true); 5481 }, 5482 PageDown: () => { 5483 return findNextPageItemId(currentTarget, store, store == null ? void 0 : store.down); 5484 } 5485 }; 5486 const action = keyMap[event.key]; 5487 if (action) { 5488 if (isTextbox(currentTarget)) { 5489 const selection = getTextboxSelection(currentTarget); 5490 const isLeft = isHorizontal && event.key === "ArrowLeft"; 5491 const isRight = isHorizontal && event.key === "ArrowRight"; 5492 const isUp = isVertical && event.key === "ArrowUp"; 5493 const isDown = isVertical && event.key === "ArrowDown"; 5494 if (isRight || isDown) { 5495 const { length: valueLength } = getTextboxValue(currentTarget); 5496 if (selection.end !== valueLength) return; 5497 } else if ((isLeft || isUp) && selection.start !== 0) return; 5498 } 5499 const nextId = action(); 5500 if (preventScrollOnKeyDownProp(event) || nextId !== void 0) { 5501 if (!moveOnKeyPressProp(event)) return; 5502 event.preventDefault(); 5503 store.move(nextId); 5504 } 5505 } 5506 }); 5507 const providerValue = (0, import_react19.useMemo)( 5508 () => ({ id: id3, baseElement }), 5509 [id3, baseElement] 5510 ); 5511 props = useWrapElement( 5512 props, 5513 (element) => /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(CompositeItemContext.Provider, { value: providerValue, children: element }), 5514 [providerValue] 5515 ); 5516 props = __spreadProps(__spreadValues({ 5517 id: id3, 5518 "data-active-item": isActiveItem || void 0 5519 }, props), { 5520 ref: useMergeRefs(ref, props.ref), 5521 tabIndex: isTabbable2 ? props.tabIndex : -1, 5522 onFocus, 5523 onBlurCapture, 5524 onKeyDown 5525 }); 5526 props = useCommand(props); 5527 props = useCollectionItem(__spreadProps(__spreadValues({ 5528 store 5529 }, props), { 5530 getItem, 5531 shouldRegisterItem: id3 ? props.shouldRegisterItem : false 5532 })); 5533 return removeUndefinedValues(__spreadProps(__spreadValues({}, props), { 5534 "aria-setsize": ariaSetSize, 5535 "aria-posinset": ariaPosInSet 5536 })); 5537 } 5538 ); 5539 var CompositeItem = memo2( 5540 forwardRef2(function CompositeItem2(props) { 5541 const htmlProps = useCompositeItem(props); 5542 return createElement(TagName15, htmlProps); 5543 }) 5544 ); 5545 5546 // node_modules/@ariakit/react-core/esm/__chunks/VGCJ63VH.js 5547 var import_react20 = __toESM(require_react(), 1); 5548 var import_react_dom = __toESM(require_react_dom(), 1); 5549 var import_jsx_runtime6 = __toESM(require_jsx_runtime(), 1); 5550 var TagName16 = "div"; 5551 function afterTimeout(timeoutMs, cb) { 5552 const timeoutId = setTimeout(cb, timeoutMs); 5553 return () => clearTimeout(timeoutId); 5554 } 5555 function afterPaint2(cb) { 5556 let raf = requestAnimationFrame(() => { 5557 raf = requestAnimationFrame(cb); 5558 }); 5559 return () => cancelAnimationFrame(raf); 5560 } 5561 function parseCSSTime(...times) { 5562 return times.join(", ").split(", ").reduce((longestTime, currentTimeString) => { 5563 const multiplier = currentTimeString.endsWith("ms") ? 1 : 1e3; 5564 const currentTime = Number.parseFloat(currentTimeString || "0s") * multiplier; 5565 if (currentTime > longestTime) return currentTime; 5566 return longestTime; 5567 }, 0); 5568 } 5569 function isHidden(mounted, hidden, alwaysVisible) { 5570 return !alwaysVisible && hidden !== false && (!mounted || !!hidden); 5571 } 5572 var useDisclosureContent = createHook(function useDisclosureContent2(_a) { 5573 var _b = _a, { store, alwaysVisible } = _b, props = __objRest(_b, ["store", "alwaysVisible"]); 5574 const context = useDisclosureProviderContext(); 5575 store = store || context; 5576 invariant( 5577 store, 5578 "DisclosureContent must receive a `store` prop or be wrapped in a DisclosureProvider component." 5579 ); 5580 const ref = (0, import_react20.useRef)(null); 5581 const id3 = useId(props.id); 5582 const [transition, setTransition] = (0, import_react20.useState)(null); 5583 const open = store.useState("open"); 5584 const mounted = store.useState("mounted"); 5585 const animated = store.useState("animated"); 5586 const contentElement = store.useState("contentElement"); 5587 const otherElement = useStoreState(store.disclosure, "contentElement"); 5588 useSafeLayoutEffect(() => { 5589 if (!ref.current) return; 5590 store == null ? void 0 : store.setContentElement(ref.current); 5591 }, [store]); 5592 useSafeLayoutEffect(() => { 5593 let previousAnimated; 5594 store == null ? void 0 : store.setState("animated", (animated2) => { 5595 previousAnimated = animated2; 5596 return true; 5597 }); 5598 return () => { 5599 if (previousAnimated === void 0) return; 5600 store == null ? void 0 : store.setState("animated", previousAnimated); 5601 }; 5602 }, [store]); 5603 useSafeLayoutEffect(() => { 5604 if (!animated) return; 5605 if (!(contentElement == null ? void 0 : contentElement.isConnected)) { 5606 setTransition(null); 5607 return; 5608 } 5609 return afterPaint2(() => { 5610 setTransition(open ? "enter" : mounted ? "leave" : null); 5611 }); 5612 }, [animated, contentElement, open, mounted]); 5613 useSafeLayoutEffect(() => { 5614 if (!store) return; 5615 if (!animated) return; 5616 if (!transition) return; 5617 if (!contentElement) return; 5618 const stopAnimation = () => store == null ? void 0 : store.setState("animating", false); 5619 const stopAnimationSync = () => (0, import_react_dom.flushSync)(stopAnimation); 5620 if (transition === "leave" && open) return; 5621 if (transition === "enter" && !open) return; 5622 if (typeof animated === "number") { 5623 const timeout2 = animated; 5624 return afterTimeout(timeout2, stopAnimationSync); 5625 } 5626 const { 5627 transitionDuration, 5628 animationDuration, 5629 transitionDelay, 5630 animationDelay 5631 } = getComputedStyle(contentElement); 5632 const { 5633 transitionDuration: transitionDuration2 = "0", 5634 animationDuration: animationDuration2 = "0", 5635 transitionDelay: transitionDelay2 = "0", 5636 animationDelay: animationDelay2 = "0" 5637 } = otherElement ? getComputedStyle(otherElement) : {}; 5638 const delay2 = parseCSSTime( 5639 transitionDelay, 5640 animationDelay, 5641 transitionDelay2, 5642 animationDelay2 5643 ); 5644 const duration = parseCSSTime( 5645 transitionDuration, 5646 animationDuration, 5647 transitionDuration2, 5648 animationDuration2 5649 ); 5650 const timeout = delay2 + duration; 5651 if (!timeout) { 5652 if (transition === "enter") { 5653 store.setState("animated", false); 5654 } 5655 stopAnimation(); 5656 return; 5657 } 5658 const frameRate = 1e3 / 60; 5659 const maxTimeout = Math.max(timeout - frameRate, 0); 5660 return afterTimeout(maxTimeout, stopAnimationSync); 5661 }, [store, animated, contentElement, otherElement, open, transition]); 5662 props = useWrapElement( 5663 props, 5664 (element) => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(DialogScopedContextProvider, { value: store, children: element }), 5665 [store] 5666 ); 5667 const hidden = isHidden(mounted, props.hidden, alwaysVisible); 5668 const styleProp = props.style; 5669 const style2 = (0, import_react20.useMemo)(() => { 5670 if (hidden) { 5671 return __spreadProps(__spreadValues({}, styleProp), { display: "none" }); 5672 } 5673 return styleProp; 5674 }, [hidden, styleProp]); 5675 props = __spreadProps(__spreadValues({ 5676 id: id3, 5677 "data-open": open || void 0, 5678 "data-enter": transition === "enter" || void 0, 5679 "data-leave": transition === "leave" || void 0, 5680 hidden 5681 }, props), { 5682 ref: useMergeRefs(id3 ? store.setContentElement : null, ref, props.ref), 5683 style: style2 5684 }); 5685 return removeUndefinedValues(props); 5686 }); 5687 var DisclosureContentImpl = forwardRef2(function DisclosureContentImpl2(props) { 5688 const htmlProps = useDisclosureContent(props); 5689 return createElement(TagName16, htmlProps); 5690 }); 5691 var DisclosureContent = forwardRef2(function DisclosureContent2(_a) { 5692 var _b = _a, { 5693 unmountOnHide 5694 } = _b, props = __objRest(_b, [ 5695 "unmountOnHide" 5696 ]); 5697 const context = useDisclosureProviderContext(); 5698 const store = props.store || context; 5699 const mounted = useStoreState( 5700 store, 5701 (state) => !unmountOnHide || (state == null ? void 0 : state.mounted) 5702 ); 5703 if (mounted === false) return null; 5704 return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(DisclosureContentImpl, __spreadValues({}, props)); 5705 }); 5706 5707 // node_modules/@ariakit/react-core/esm/__chunks/63XF7ACK.js 5708 function isBackdrop(element, ...ids) { 5709 if (!element) return false; 5710 const backdrop = element.getAttribute("data-backdrop"); 5711 if (backdrop == null) return false; 5712 if (backdrop === "") return true; 5713 if (backdrop === "true") return true; 5714 if (!ids.length) return true; 5715 return ids.some((id3) => backdrop === id3); 5716 } 5717 5718 // node_modules/@ariakit/react-core/esm/__chunks/K2ZF5NU7.js 5719 var cleanups = /* @__PURE__ */ new WeakMap(); 5720 function orchestrate(element, key, setup2) { 5721 if (!cleanups.has(element)) { 5722 cleanups.set(element, /* @__PURE__ */ new Map()); 5723 } 5724 const elementCleanups = cleanups.get(element); 5725 const prevCleanup = elementCleanups.get(key); 5726 if (!prevCleanup) { 5727 elementCleanups.set(key, setup2()); 5728 return () => { 5729 var _a; 5730 (_a = elementCleanups.get(key)) == null ? void 0 : _a(); 5731 elementCleanups.delete(key); 5732 }; 5733 } 5734 const cleanup = setup2(); 5735 const nextCleanup = () => { 5736 cleanup(); 5737 prevCleanup(); 5738 elementCleanups.delete(key); 5739 }; 5740 elementCleanups.set(key, nextCleanup); 5741 return () => { 5742 const isCurrent = elementCleanups.get(key) === nextCleanup; 5743 if (!isCurrent) return; 5744 cleanup(); 5745 elementCleanups.set(key, prevCleanup); 5746 }; 5747 } 5748 function setAttribute(element, attr, value) { 5749 const setup2 = () => { 5750 const previousValue = element.getAttribute(attr); 5751 element.setAttribute(attr, value); 5752 return () => { 5753 if (previousValue == null) { 5754 element.removeAttribute(attr); 5755 } else { 5756 element.setAttribute(attr, previousValue); 5757 } 5758 }; 5759 }; 5760 return orchestrate(element, attr, setup2); 5761 } 5762 function setProperty(element, property, value) { 5763 const setup2 = () => { 5764 const exists = property in element; 5765 const previousValue = element[property]; 5766 element[property] = value; 5767 return () => { 5768 if (!exists) { 5769 delete element[property]; 5770 } else { 5771 element[property] = previousValue; 5772 } 5773 }; 5774 }; 5775 return orchestrate(element, property, setup2); 5776 } 5777 function assignStyle(element, style2) { 5778 if (!element) return () => { 5779 }; 5780 const setup2 = () => { 5781 const prevStyle = element.style.cssText; 5782 Object.assign(element.style, style2); 5783 return () => { 5784 element.style.cssText = prevStyle; 5785 }; 5786 }; 5787 return orchestrate(element, "style", setup2); 5788 } 5789 function setCSSProperty(element, property, value) { 5790 if (!element) return () => { 5791 }; 5792 const setup2 = () => { 5793 const previousValue = element.style.getPropertyValue(property); 5794 element.style.setProperty(property, value); 5795 return () => { 5796 if (previousValue) { 5797 element.style.setProperty(property, previousValue); 5798 } else { 5799 element.style.removeProperty(property); 5800 } 5801 }; 5802 }; 5803 return orchestrate(element, property, setup2); 5804 } 5805 5806 // node_modules/@ariakit/react-core/esm/__chunks/AOUGVQZ3.js 5807 var ignoreTags = ["SCRIPT", "STYLE"]; 5808 function getSnapshotPropertyName(id3) { 5809 return `__ariakit-dialog-snapshot-$id3}`; 5810 } 5811 function inSnapshot(id3, element) { 5812 const doc = getDocument(element); 5813 const propertyName = getSnapshotPropertyName(id3); 5814 if (!doc.body[propertyName]) return true; 5815 do { 5816 if (element === doc.body) return false; 5817 if (element[propertyName]) return true; 5818 if (!element.parentElement) return false; 5819 element = element.parentElement; 5820 } while (true); 5821 } 5822 function isValidElement3(id3, element, ignoredElements) { 5823 if (ignoreTags.includes(element.tagName)) return false; 5824 if (!inSnapshot(id3, element)) return false; 5825 return !ignoredElements.some( 5826 (enabledElement) => enabledElement && contains(element, enabledElement) 5827 ); 5828 } 5829 function walkTreeOutside(id3, elements2, callback, ancestorCallback) { 5830 for (let element of elements2) { 5831 if (!(element == null ? void 0 : element.isConnected)) continue; 5832 const hasAncestorAlready = elements2.some((maybeAncestor) => { 5833 if (!maybeAncestor) return false; 5834 if (maybeAncestor === element) return false; 5835 return maybeAncestor.contains(element); 5836 }); 5837 const doc = getDocument(element); 5838 const originalElement = element; 5839 while (element.parentElement && element !== doc.body) { 5840 ancestorCallback == null ? void 0 : ancestorCallback(element.parentElement, originalElement); 5841 if (!hasAncestorAlready) { 5842 for (const child of element.parentElement.children) { 5843 if (isValidElement3(id3, child, elements2)) { 5844 callback(child, originalElement); 5845 } 5846 } 5847 } 5848 element = element.parentElement; 5849 } 5850 } 5851 } 5852 function createWalkTreeSnapshot(id3, elements2) { 5853 const { body } = getDocument(elements2[0]); 5854 const cleanups2 = []; 5855 const markElement2 = (element) => { 5856 cleanups2.push(setProperty(element, getSnapshotPropertyName(id3), true)); 5857 }; 5858 walkTreeOutside(id3, elements2, markElement2); 5859 return chain(setProperty(body, getSnapshotPropertyName(id3), true), () => { 5860 for (const cleanup of cleanups2) { 5861 cleanup(); 5862 } 5863 }); 5864 } 5865 5866 // node_modules/@ariakit/react-core/esm/__chunks/2PGBN2Y4.js 5867 function getPropertyName(id3 = "", ancestor = false) { 5868 return `__ariakit-dialog-$ancestor ? "ancestor" : "outside"}$id3 ? `-$id3}` : ""}`; 5869 } 5870 function markElement(element, id3 = "") { 5871 return chain( 5872 setProperty(element, getPropertyName(), true), 5873 setProperty(element, getPropertyName(id3), true) 5874 ); 5875 } 5876 function markAncestor(element, id3 = "") { 5877 return chain( 5878 setProperty(element, getPropertyName("", true), true), 5879 setProperty(element, getPropertyName(id3, true), true) 5880 ); 5881 } 5882 function isElementMarked(element, id3) { 5883 const ancestorProperty = getPropertyName(id3, true); 5884 if (element[ancestorProperty]) return true; 5885 const elementProperty = getPropertyName(id3); 5886 do { 5887 if (element[elementProperty]) return true; 5888 if (!element.parentElement) return false; 5889 element = element.parentElement; 5890 } while (true); 5891 } 5892 function markTreeOutside(id3, elements2) { 5893 const cleanups2 = []; 5894 const ids = elements2.map((el) => el == null ? void 0 : el.id); 5895 walkTreeOutside( 5896 id3, 5897 elements2, 5898 (element) => { 5899 if (isBackdrop(element, ...ids)) return; 5900 cleanups2.unshift(markElement(element, id3)); 5901 }, 5902 (ancestor, element) => { 5903 const isAnotherDialogAncestor = element.hasAttribute("data-dialog") && element.id !== id3; 5904 if (isAnotherDialogAncestor) return; 5905 cleanups2.unshift(markAncestor(ancestor, id3)); 5906 } 5907 ); 5908 const restoreAccessibilityTree = () => { 5909 for (const cleanup of cleanups2) { 5910 cleanup(); 5911 } 5912 }; 5913 return restoreAccessibilityTree; 5914 } 5915 5916 // node_modules/@ariakit/react-core/esm/__chunks/XL7CSKGW.js 5917 var TagName17 = "div"; 5918 var elements = [ 5919 "a", 5920 "button", 5921 "details", 5922 "dialog", 5923 "div", 5924 "form", 5925 "h1", 5926 "h2", 5927 "h3", 5928 "h4", 5929 "h5", 5930 "h6", 5931 "header", 5932 "img", 5933 "input", 5934 "label", 5935 "li", 5936 "nav", 5937 "ol", 5938 "p", 5939 "section", 5940 "select", 5941 "span", 5942 "summary", 5943 "textarea", 5944 "ul", 5945 "svg" 5946 ]; 5947 var useRole = createHook( 5948 function useRole2(props) { 5949 return props; 5950 } 5951 ); 5952 var Role = forwardRef2( 5953 // @ts-expect-error 5954 function Role2(props) { 5955 return createElement(TagName17, props); 5956 } 5957 ); 5958 Object.assign( 5959 Role, 5960 elements.reduce((acc, element) => { 5961 acc[element] = forwardRef2(function Role3(props) { 5962 return createElement(element, props); 5963 }); 5964 return acc; 5965 }, {}) 5966 ); 5967 5968 // node_modules/@ariakit/react-core/esm/__chunks/63FEHJZV.js 5969 var import_react21 = __toESM(require_react(), 1); 5970 var import_jsx_runtime7 = __toESM(require_jsx_runtime(), 1); 5971 function DialogBackdrop({ 5972 store, 5973 backdrop, 5974 alwaysVisible, 5975 hidden 5976 }) { 5977 const ref = (0, import_react21.useRef)(null); 5978 const disclosure = useDisclosureStore({ disclosure: store }); 5979 const contentElement = useStoreState(store, "contentElement"); 5980 (0, import_react21.useEffect)(() => { 5981 const backdrop2 = ref.current; 5982 const dialog = contentElement; 5983 if (!backdrop2) return; 5984 if (!dialog) return; 5985 backdrop2.style.zIndex = getComputedStyle(dialog).zIndex; 5986 }, [contentElement]); 5987 useSafeLayoutEffect(() => { 5988 const id3 = contentElement == null ? void 0 : contentElement.id; 5989 if (!id3) return; 5990 const backdrop2 = ref.current; 5991 if (!backdrop2) return; 5992 return markAncestor(backdrop2, id3); 5993 }, [contentElement]); 5994 const props = useDisclosureContent({ 5995 ref, 5996 store: disclosure, 5997 role: "presentation", 5998 "data-backdrop": (contentElement == null ? void 0 : contentElement.id) || "", 5999 alwaysVisible, 6000 hidden: hidden != null ? hidden : void 0, 6001 style: { 6002 position: "fixed", 6003 top: 0, 6004 right: 0, 6005 bottom: 0, 6006 left: 0 6007 } 6008 }); 6009 if (!backdrop) return null; 6010 if ((0, import_react21.isValidElement)(backdrop)) { 6011 return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(Role, __spreadProps(__spreadValues({}, props), { render: backdrop })); 6012 } 6013 const Component9 = typeof backdrop !== "boolean" ? backdrop : "div"; 6014 return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(Role, __spreadProps(__spreadValues({}, props), { render: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(Component9, {}) })); 6015 } 6016 6017 // node_modules/@ariakit/react-core/esm/__chunks/IGR4SXG2.js 6018 function isFocusTrap(element, ...ids) { 6019 if (!element) return false; 6020 const attr = element.getAttribute("data-focus-trap"); 6021 if (attr == null) return false; 6022 if (!ids.length) return true; 6023 if (attr === "") return false; 6024 return ids.some((id3) => attr === id3); 6025 } 6026 6027 // node_modules/@ariakit/react-core/esm/__chunks/ESSM74HH.js 6028 function hideElementFromAccessibilityTree(element) { 6029 return setAttribute(element, "aria-hidden", "true"); 6030 } 6031 6032 // node_modules/@ariakit/react-core/esm/__chunks/677M2CI3.js 6033 function supportsInert() { 6034 return "inert" in HTMLElement.prototype; 6035 } 6036 6037 // node_modules/@ariakit/react-core/esm/__chunks/KZAQFFOU.js 6038 function disableTree(element, ignoredElements) { 6039 if (!("style" in element)) return noop; 6040 if (supportsInert()) { 6041 return setProperty(element, "inert", true); 6042 } 6043 const tabbableElements = getAllTabbableIn(element, true); 6044 const enableElements = tabbableElements.map((element2) => { 6045 if (ignoredElements == null ? void 0 : ignoredElements.some((el) => el && contains(el, element2))) return noop; 6046 const restoreFocusMethod = orchestrate(element2, "focus", () => { 6047 element2.focus = noop; 6048 return () => { 6049 delete element2.focus; 6050 }; 6051 }); 6052 return chain(setAttribute(element2, "tabindex", "-1"), restoreFocusMethod); 6053 }); 6054 return chain( 6055 ...enableElements, 6056 hideElementFromAccessibilityTree(element), 6057 assignStyle(element, { 6058 pointerEvents: "none", 6059 userSelect: "none", 6060 cursor: "default" 6061 }) 6062 ); 6063 } 6064 function disableTreeOutside(id3, elements2) { 6065 const cleanups2 = []; 6066 const ids = elements2.map((el) => el == null ? void 0 : el.id); 6067 walkTreeOutside( 6068 id3, 6069 elements2, 6070 (element) => { 6071 if (isBackdrop(element, ...ids)) return; 6072 if (isFocusTrap(element, ...ids)) return; 6073 cleanups2.unshift(disableTree(element, elements2)); 6074 }, 6075 (element) => { 6076 if (!element.hasAttribute("role")) return; 6077 if (elements2.some((el) => el && contains(el, element))) return; 6078 cleanups2.unshift(setAttribute(element, "role", "none")); 6079 } 6080 ); 6081 const restoreTreeOutside = () => { 6082 for (const cleanup of cleanups2) { 6083 cleanup(); 6084 } 6085 }; 6086 return restoreTreeOutside; 6087 } 6088 6089 // node_modules/@ariakit/react-core/esm/__chunks/YKJECYU7.js 6090 var import_react22 = __toESM(require_react(), 1); 6091 var import_react_dom2 = __toESM(require_react_dom(), 1); 6092 function useRootDialog({ 6093 attribute, 6094 contentId, 6095 contentElement, 6096 enabled 6097 }) { 6098 const [updated, retry] = useForceUpdate(); 6099 const isRootDialog = (0, import_react22.useCallback)(() => { 6100 if (!enabled) return false; 6101 if (!contentElement) return false; 6102 const { body } = getDocument(contentElement); 6103 const id3 = body.getAttribute(attribute); 6104 return !id3 || id3 === contentId; 6105 }, [updated, enabled, contentElement, attribute, contentId]); 6106 (0, import_react22.useEffect)(() => { 6107 if (!enabled) return; 6108 if (!contentId) return; 6109 if (!contentElement) return; 6110 const { body } = getDocument(contentElement); 6111 if (isRootDialog()) { 6112 body.setAttribute(attribute, contentId); 6113 return () => body.removeAttribute(attribute); 6114 } 6115 const observer = new MutationObserver(() => (0, import_react_dom2.flushSync)(retry)); 6116 observer.observe(body, { attributeFilter: [attribute] }); 6117 return () => observer.disconnect(); 6118 }, [updated, enabled, contentId, contentElement, isRootDialog, attribute]); 6119 return isRootDialog; 6120 } 6121 6122 // node_modules/@ariakit/react-core/esm/__chunks/BGQ3KQ5M.js 6123 var import_react23 = __toESM(require_react(), 1); 6124 function getPaddingProperty(documentElement) { 6125 const documentLeft = documentElement.getBoundingClientRect().left; 6126 const scrollbarX = Math.round(documentLeft) + documentElement.scrollLeft; 6127 return scrollbarX ? "paddingLeft" : "paddingRight"; 6128 } 6129 function usePreventBodyScroll(contentElement, contentId, enabled) { 6130 const isRootDialog = useRootDialog({ 6131 attribute: "data-dialog-prevent-body-scroll", 6132 contentElement, 6133 contentId, 6134 enabled 6135 }); 6136 (0, import_react23.useEffect)(() => { 6137 if (!isRootDialog()) return; 6138 if (!contentElement) return; 6139 const doc = getDocument(contentElement); 6140 const win = getWindow(contentElement); 6141 const { documentElement, body } = doc; 6142 const cssScrollbarWidth = documentElement.style.getPropertyValue("--scrollbar-width"); 6143 const scrollbarWidth = cssScrollbarWidth ? Number.parseInt(cssScrollbarWidth) : win.innerWidth - documentElement.clientWidth; 6144 const setScrollbarWidthProperty = () => setCSSProperty( 6145 documentElement, 6146 "--scrollbar-width", 6147 `$scrollbarWidth}px` 6148 ); 6149 const paddingProperty = getPaddingProperty(documentElement); 6150 const setStyle = () => assignStyle(body, { 6151 overflow: "hidden", 6152 [paddingProperty]: `$scrollbarWidth}px` 6153 }); 6154 const setIOSStyle = () => { 6155 var _a, _b; 6156 const { scrollX: scrollX2, scrollY: scrollY2, visualViewport } = win; 6157 const offsetLeft = (_a = visualViewport == null ? void 0 : visualViewport.offsetLeft) != null ? _a : 0; 6158 const offsetTop = (_b = visualViewport == null ? void 0 : visualViewport.offsetTop) != null ? _b : 0; 6159 const restoreStyle = assignStyle(body, { 6160 position: "fixed", 6161 overflow: "hidden", 6162 top: `${-(scrollY2 - Math.floor(offsetTop))}px`, 6163 left: `${-(scrollX2 - Math.floor(offsetLeft))}px`, 6164 right: "0", 6165 [paddingProperty]: `$scrollbarWidth}px` 6166 }); 6167 return () => { 6168 restoreStyle(); 6169 if (true) { 6170 win.scrollTo({ left: scrollX2, top: scrollY2, behavior: "instant" }); 6171 } 6172 }; 6173 }; 6174 const isIOS = isApple() && !isMac(); 6175 return chain( 6176 setScrollbarWidthProperty(), 6177 isIOS ? setIOSStyle() : setStyle() 6178 ); 6179 }, [isRootDialog, contentElement]); 6180 } 6181 6182 // node_modules/@ariakit/react-core/esm/__chunks/TOU75OXH.js 6183 var import_react24 = __toESM(require_react(), 1); 6184 var import_jsx_runtime8 = __toESM(require_jsx_runtime(), 1); 6185 var NestedDialogsContext = (0, import_react24.createContext)({}); 6186 function useNestedDialogs(store) { 6187 const context = (0, import_react24.useContext)(NestedDialogsContext); 6188 const [dialogs, setDialogs] = (0, import_react24.useState)([]); 6189 const add2 = (0, import_react24.useCallback)( 6190 (dialog) => { 6191 var _a; 6192 setDialogs((dialogs2) => [...dialogs2, dialog]); 6193 return chain((_a = context.add) == null ? void 0 : _a.call(context, dialog), () => { 6194 setDialogs((dialogs2) => dialogs2.filter((d3) => d3 !== dialog)); 6195 }); 6196 }, 6197 [context] 6198 ); 6199 useSafeLayoutEffect(() => { 6200 return sync(store, ["open", "contentElement"], (state) => { 6201 var _a; 6202 if (!state.open) return; 6203 if (!state.contentElement) return; 6204 return (_a = context.add) == null ? void 0 : _a.call(context, store); 6205 }); 6206 }, [store, context]); 6207 const providerValue = (0, import_react24.useMemo)(() => ({ store, add: add2 }), [store, add2]); 6208 const wrapElement = (0, import_react24.useCallback)( 6209 (element) => /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(NestedDialogsContext.Provider, { value: providerValue, children: element }), 6210 [providerValue] 6211 ); 6212 return { wrapElement, nestedDialogs: dialogs }; 6213 } 6214 6215 // node_modules/@ariakit/react-core/esm/__chunks/HLTQOHKZ.js 6216 var import_react25 = __toESM(require_react(), 1); 6217 function usePreviousMouseDownRef(enabled) { 6218 const previousMouseDownRef = (0, import_react25.useRef)(); 6219 (0, import_react25.useEffect)(() => { 6220 if (!enabled) { 6221 previousMouseDownRef.current = null; 6222 return; 6223 } 6224 const onMouseDown = (event) => { 6225 previousMouseDownRef.current = event.target; 6226 }; 6227 return addGlobalEventListener("mousedown", onMouseDown, true); 6228 }, [enabled]); 6229 return previousMouseDownRef; 6230 } 6231 6232 // node_modules/@ariakit/react-core/esm/__chunks/WBDYNH73.js 6233 var import_react26 = __toESM(require_react(), 1); 6234 function isInDocument(target) { 6235 if (target.tagName === "HTML") return true; 6236 return contains(getDocument(target).body, target); 6237 } 6238 function isDisclosure(disclosure, target) { 6239 if (!disclosure) return false; 6240 if (contains(disclosure, target)) return true; 6241 const activeId = target.getAttribute("aria-activedescendant"); 6242 if (activeId) { 6243 const activeElement = getDocument(disclosure).getElementById(activeId); 6244 if (activeElement) { 6245 return contains(disclosure, activeElement); 6246 } 6247 } 6248 return false; 6249 } 6250 function isMouseEventOnDialog(event, dialog) { 6251 if (!("clientY" in event)) return false; 6252 const rect = dialog.getBoundingClientRect(); 6253 if (rect.width === 0 || rect.height === 0) return false; 6254 return rect.top <= event.clientY && event.clientY <= rect.top + rect.height && rect.left <= event.clientX && event.clientX <= rect.left + rect.width; 6255 } 6256 function useEventOutside({ 6257 store, 6258 type, 6259 listener, 6260 capture, 6261 domReady 6262 }) { 6263 const callListener = useEvent(listener); 6264 const open = useStoreState(store, "open"); 6265 const focusedRef = (0, import_react26.useRef)(false); 6266 useSafeLayoutEffect(() => { 6267 if (!open) return; 6268 if (!domReady) return; 6269 const { contentElement } = store.getState(); 6270 if (!contentElement) return; 6271 const onFocus = () => { 6272 focusedRef.current = true; 6273 }; 6274 contentElement.addEventListener("focusin", onFocus, true); 6275 return () => contentElement.removeEventListener("focusin", onFocus, true); 6276 }, [store, open, domReady]); 6277 (0, import_react26.useEffect)(() => { 6278 if (!open) return; 6279 const onEvent = (event) => { 6280 const { contentElement, disclosureElement } = store.getState(); 6281 const target = event.target; 6282 if (!contentElement) return; 6283 if (!target) return; 6284 if (!isInDocument(target)) return; 6285 if (contains(contentElement, target)) return; 6286 if (isDisclosure(disclosureElement, target)) return; 6287 if (target.hasAttribute("data-focus-trap")) return; 6288 if (isMouseEventOnDialog(event, contentElement)) return; 6289 const focused = focusedRef.current; 6290 if (focused && !isElementMarked(target, contentElement.id)) return; 6291 if (isSafariFocusAncestor(target)) return; 6292 callListener(event); 6293 }; 6294 return addGlobalEventListener(type, onEvent, capture); 6295 }, [open, capture]); 6296 } 6297 function shouldHideOnInteractOutside(hideOnInteractOutside, event) { 6298 if (typeof hideOnInteractOutside === "function") { 6299 return hideOnInteractOutside(event); 6300 } 6301 return !!hideOnInteractOutside; 6302 } 6303 function useHideOnInteractOutside(store, hideOnInteractOutside, domReady) { 6304 const open = useStoreState(store, "open"); 6305 const previousMouseDownRef = usePreviousMouseDownRef(open); 6306 const props = { store, domReady, capture: true }; 6307 useEventOutside(__spreadProps(__spreadValues({}, props), { 6308 type: "click", 6309 listener: (event) => { 6310 const { contentElement } = store.getState(); 6311 const previousMouseDown = previousMouseDownRef.current; 6312 if (!previousMouseDown) return; 6313 if (!isVisible(previousMouseDown)) return; 6314 if (!isElementMarked(previousMouseDown, contentElement == null ? void 0 : contentElement.id)) return; 6315 if (!shouldHideOnInteractOutside(hideOnInteractOutside, event)) return; 6316 store.hide(); 6317 } 6318 })); 6319 useEventOutside(__spreadProps(__spreadValues({}, props), { 6320 type: "focusin", 6321 listener: (event) => { 6322 const { contentElement } = store.getState(); 6323 if (!contentElement) return; 6324 if (event.target === getDocument(contentElement)) return; 6325 if (!shouldHideOnInteractOutside(hideOnInteractOutside, event)) return; 6326 store.hide(); 6327 } 6328 })); 6329 useEventOutside(__spreadProps(__spreadValues({}, props), { 6330 type: "contextmenu", 6331 listener: (event) => { 6332 if (!shouldHideOnInteractOutside(hideOnInteractOutside, event)) return; 6333 store.hide(); 6334 } 6335 })); 6336 } 6337 6338 // node_modules/@ariakit/react-core/esm/__chunks/6GXEOXGT.js 6339 function prependHiddenDismiss(container, onClick) { 6340 const document2 = getDocument(container); 6341 const button = document2.createElement("button"); 6342 button.type = "button"; 6343 button.tabIndex = -1; 6344 button.textContent = "Dismiss popup"; 6345 Object.assign(button.style, { 6346 border: "0px", 6347 clip: "rect(0 0 0 0)", 6348 height: "1px", 6349 margin: "-1px", 6350 overflow: "hidden", 6351 padding: "0px", 6352 position: "absolute", 6353 whiteSpace: "nowrap", 6354 width: "1px" 6355 }); 6356 button.addEventListener("click", onClick); 6357 container.prepend(button); 6358 const removeHiddenDismiss = () => { 6359 button.removeEventListener("click", onClick); 6360 button.remove(); 6361 }; 6362 return removeHiddenDismiss; 6363 } 6364 6365 // node_modules/@ariakit/react-core/esm/__chunks/ZWYATQFU.js 6366 var import_jsx_runtime9 = __toESM(require_jsx_runtime(), 1); 6367 var TagName18 = "div"; 6368 var useFocusableContainer = createHook(function useFocusableContainer2(_a) { 6369 var _b = _a, { autoFocusOnShow = true } = _b, props = __objRest(_b, ["autoFocusOnShow"]); 6370 props = useWrapElement( 6371 props, 6372 (element) => /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(FocusableContext.Provider, { value: autoFocusOnShow, children: element }), 6373 [autoFocusOnShow] 6374 ); 6375 return props; 6376 }); 6377 var FocusableContainer = forwardRef2(function FocusableContainer2(props) { 6378 const htmlProps = useFocusableContainer(props); 6379 return createElement(TagName18, htmlProps); 6380 }); 6381 6382 // node_modules/@ariakit/react-core/esm/__chunks/CZ4GFWYL.js 6383 var import_react27 = __toESM(require_react(), 1); 6384 var HeadingContext = (0, import_react27.createContext)(0); 6385 6386 // node_modules/@ariakit/react-core/esm/__chunks/5M6RIVE2.js 6387 var import_react28 = __toESM(require_react(), 1); 6388 var import_jsx_runtime10 = __toESM(require_jsx_runtime(), 1); 6389 function HeadingLevel({ level, children }) { 6390 const contextLevel = (0, import_react28.useContext)(HeadingContext); 6391 const nextLevel = Math.max( 6392 Math.min(level || contextLevel + 1, 6), 6393 1 6394 ); 6395 return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(HeadingContext.Provider, { value: nextLevel, children }); 6396 } 6397 6398 // node_modules/@ariakit/react-core/esm/__chunks/XX67R432.js 6399 var TagName19 = "span"; 6400 var useVisuallyHidden = createHook( 6401 function useVisuallyHidden2(props) { 6402 props = __spreadProps(__spreadValues({}, props), { 6403 style: __spreadValues({ 6404 border: 0, 6405 clip: "rect(0 0 0 0)", 6406 height: "1px", 6407 margin: "-1px", 6408 overflow: "hidden", 6409 padding: 0, 6410 position: "absolute", 6411 whiteSpace: "nowrap", 6412 width: "1px" 6413 }, props.style) 6414 }); 6415 return props; 6416 } 6417 ); 6418 var VisuallyHidden = forwardRef2(function VisuallyHidden2(props) { 6419 const htmlProps = useVisuallyHidden(props); 6420 return createElement(TagName19, htmlProps); 6421 }); 6422 6423 // node_modules/@ariakit/react-core/esm/__chunks/W3VI7GFU.js 6424 var TagName20 = "span"; 6425 var useFocusTrap = createHook( 6426 function useFocusTrap2(props) { 6427 props = __spreadProps(__spreadValues({ 6428 "data-focus-trap": "", 6429 tabIndex: 0, 6430 "aria-hidden": true 6431 }, props), { 6432 style: __spreadValues({ 6433 // Prevents unintended scroll jumps. 6434 position: "fixed", 6435 top: 0, 6436 left: 0 6437 }, props.style) 6438 }); 6439 props = useVisuallyHidden(props); 6440 return props; 6441 } 6442 ); 6443 var FocusTrap = forwardRef2(function FocusTrap2(props) { 6444 const htmlProps = useFocusTrap(props); 6445 return createElement(TagName20, htmlProps); 6446 }); 6447 6448 // node_modules/@ariakit/react-core/esm/__chunks/AOQQTIBO.js 6449 var import_react29 = __toESM(require_react(), 1); 6450 var PortalContext = (0, import_react29.createContext)(null); 6451 6452 // node_modules/@ariakit/react-core/esm/__chunks/O37CNYMR.js 6453 var import_react30 = __toESM(require_react(), 1); 6454 var import_react_dom3 = __toESM(require_react_dom(), 1); 6455 var import_jsx_runtime11 = __toESM(require_jsx_runtime(), 1); 6456 var TagName21 = "div"; 6457 function getRootElement(element) { 6458 return getDocument(element).body; 6459 } 6460 function getPortalElement(element, portalElement) { 6461 if (!portalElement) { 6462 return getDocument(element).createElement("div"); 6463 } 6464 if (typeof portalElement === "function") { 6465 return portalElement(element); 6466 } 6467 return portalElement; 6468 } 6469 function getRandomId(prefix2 = "id") { 6470 return `$prefix2 ? `$prefix2}-` : ""}$Math.random().toString(36).slice(2, 8)}`; 6471 } 6472 function queueFocus(element) { 6473 queueMicrotask(() => { 6474 element == null ? void 0 : element.focus(); 6475 }); 6476 } 6477 var usePortal = createHook(function usePortal2(_a) { 6478 var _b = _a, { 6479 preserveTabOrder, 6480 preserveTabOrderAnchor, 6481 portalElement, 6482 portalRef, 6483 portal = true 6484 } = _b, props = __objRest(_b, [ 6485 "preserveTabOrder", 6486 "preserveTabOrderAnchor", 6487 "portalElement", 6488 "portalRef", 6489 "portal" 6490 ]); 6491 const ref = (0, import_react30.useRef)(null); 6492 const refProp = useMergeRefs(ref, props.ref); 6493 const context = (0, import_react30.useContext)(PortalContext); 6494 const [portalNode, setPortalNode] = (0, import_react30.useState)(null); 6495 const [anchorPortalNode, setAnchorPortalNode] = (0, import_react30.useState)( 6496 null 6497 ); 6498 const outerBeforeRef = (0, import_react30.useRef)(null); 6499 const innerBeforeRef = (0, import_react30.useRef)(null); 6500 const innerAfterRef = (0, import_react30.useRef)(null); 6501 const outerAfterRef = (0, import_react30.useRef)(null); 6502 useSafeLayoutEffect(() => { 6503 const element = ref.current; 6504 if (!element || !portal) { 6505 setPortalNode(null); 6506 return; 6507 } 6508 const portalEl = getPortalElement(element, portalElement); 6509 if (!portalEl) { 6510 setPortalNode(null); 6511 return; 6512 } 6513 const isPortalInDocument = portalEl.isConnected; 6514 if (!isPortalInDocument) { 6515 const rootElement = context || getRootElement(element); 6516 rootElement.appendChild(portalEl); 6517 } 6518 if (!portalEl.id) { 6519 portalEl.id = element.id ? `portal/$element.id}` : getRandomId(); 6520 } 6521 setPortalNode(portalEl); 6522 setRef(portalRef, portalEl); 6523 if (isPortalInDocument) return; 6524 return () => { 6525 portalEl.remove(); 6526 setRef(portalRef, null); 6527 }; 6528 }, [portal, portalElement, context, portalRef]); 6529 useSafeLayoutEffect(() => { 6530 if (!portal) return; 6531 if (!preserveTabOrder) return; 6532 if (!preserveTabOrderAnchor) return; 6533 const doc = getDocument(preserveTabOrderAnchor); 6534 const element = doc.createElement("span"); 6535 element.style.position = "fixed"; 6536 preserveTabOrderAnchor.insertAdjacentElement("afterend", element); 6537 setAnchorPortalNode(element); 6538 return () => { 6539 element.remove(); 6540 setAnchorPortalNode(null); 6541 }; 6542 }, [portal, preserveTabOrder, preserveTabOrderAnchor]); 6543 (0, import_react30.useEffect)(() => { 6544 if (!portalNode) return; 6545 if (!preserveTabOrder) return; 6546 let raf = 0; 6547 const onFocus = (event) => { 6548 if (!isFocusEventOutside(event)) return; 6549 const focusing = event.type === "focusin"; 6550 cancelAnimationFrame(raf); 6551 if (focusing) { 6552 return restoreFocusIn(portalNode); 6553 } 6554 raf = requestAnimationFrame(() => { 6555 disableFocusIn(portalNode, true); 6556 }); 6557 }; 6558 portalNode.addEventListener("focusin", onFocus, true); 6559 portalNode.addEventListener("focusout", onFocus, true); 6560 return () => { 6561 cancelAnimationFrame(raf); 6562 portalNode.removeEventListener("focusin", onFocus, true); 6563 portalNode.removeEventListener("focusout", onFocus, true); 6564 }; 6565 }, [portalNode, preserveTabOrder]); 6566 props = useWrapElement( 6567 props, 6568 (element) => { 6569 element = // While the portal node is not in the DOM, we need to pass the 6570 // current context to the portal context, otherwise it's going to 6571 // reset to the body element on nested portals. 6572 /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(PortalContext.Provider, { value: portalNode || context, children: element }); 6573 if (!portal) return element; 6574 if (!portalNode) { 6575 return /* @__PURE__ */ (0, import_jsx_runtime11.jsx)( 6576 "span", 6577 { 6578 ref: refProp, 6579 id: props.id, 6580 style: { position: "fixed" }, 6581 hidden: true 6582 } 6583 ); 6584 } 6585 element = /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_jsx_runtime11.Fragment, { children: [ 6586 preserveTabOrder && portalNode && /* @__PURE__ */ (0, import_jsx_runtime11.jsx)( 6587 FocusTrap, 6588 { 6589 ref: innerBeforeRef, 6590 "data-focus-trap": props.id, 6591 className: "__focus-trap-inner-before", 6592 onFocus: (event) => { 6593 if (isFocusEventOutside(event, portalNode)) { 6594 queueFocus(getNextTabbable()); 6595 } else { 6596 queueFocus(outerBeforeRef.current); 6597 } 6598 } 6599 } 6600 ), 6601 element, 6602 preserveTabOrder && portalNode && /* @__PURE__ */ (0, import_jsx_runtime11.jsx)( 6603 FocusTrap, 6604 { 6605 ref: innerAfterRef, 6606 "data-focus-trap": props.id, 6607 className: "__focus-trap-inner-after", 6608 onFocus: (event) => { 6609 if (isFocusEventOutside(event, portalNode)) { 6610 queueFocus(getPreviousTabbable()); 6611 } else { 6612 queueFocus(outerAfterRef.current); 6613 } 6614 } 6615 } 6616 ) 6617 ] }); 6618 if (portalNode) { 6619 element = (0, import_react_dom3.createPortal)(element, portalNode); 6620 } 6621 let preserveTabOrderElement = /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_jsx_runtime11.Fragment, { children: [ 6622 preserveTabOrder && portalNode && /* @__PURE__ */ (0, import_jsx_runtime11.jsx)( 6623 FocusTrap, 6624 { 6625 ref: outerBeforeRef, 6626 "data-focus-trap": props.id, 6627 className: "__focus-trap-outer-before", 6628 onFocus: (event) => { 6629 const fromOuter = event.relatedTarget === outerAfterRef.current; 6630 if (!fromOuter && isFocusEventOutside(event, portalNode)) { 6631 queueFocus(innerBeforeRef.current); 6632 } else { 6633 queueFocus(getPreviousTabbable()); 6634 } 6635 } 6636 } 6637 ), 6638 preserveTabOrder && // We're using position: fixed here so that the browser doesn't 6639 // add margin to the element when setting gap on a parent element. 6640 /* @__PURE__ */ (0, import_jsx_runtime11.jsx)("span", { "aria-owns": portalNode == null ? void 0 : portalNode.id, style: { position: "fixed" } }), 6641 preserveTabOrder && portalNode && /* @__PURE__ */ (0, import_jsx_runtime11.jsx)( 6642 FocusTrap, 6643 { 6644 ref: outerAfterRef, 6645 "data-focus-trap": props.id, 6646 className: "__focus-trap-outer-after", 6647 onFocus: (event) => { 6648 if (isFocusEventOutside(event, portalNode)) { 6649 queueFocus(innerAfterRef.current); 6650 } else { 6651 const nextTabbable = getNextTabbable(); 6652 if (nextTabbable === innerBeforeRef.current) { 6653 requestAnimationFrame(() => { 6654 var _a2; 6655 return (_a2 = getNextTabbable()) == null ? void 0 : _a2.focus(); 6656 }); 6657 return; 6658 } 6659 queueFocus(nextTabbable); 6660 } 6661 } 6662 } 6663 ) 6664 ] }); 6665 if (anchorPortalNode && preserveTabOrder) { 6666 preserveTabOrderElement = (0, import_react_dom3.createPortal)( 6667 preserveTabOrderElement, 6668 anchorPortalNode 6669 ); 6670 } 6671 return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_jsx_runtime11.Fragment, { children: [ 6672 preserveTabOrderElement, 6673 element 6674 ] }); 6675 }, 6676 [portalNode, context, portal, props.id, preserveTabOrder, anchorPortalNode] 6677 ); 6678 props = __spreadProps(__spreadValues({}, props), { 6679 ref: refProp 6680 }); 6681 return props; 6682 }); 6683 var Portal = forwardRef2(function Portal2(props) { 6684 const htmlProps = usePortal(props); 6685 return createElement(TagName21, htmlProps); 6686 }); 6687 6688 // node_modules/@ariakit/react-core/esm/__chunks/JC64G2H7.js 6689 var import_react31 = __toESM(require_react(), 1); 6690 var import_jsx_runtime12 = __toESM(require_jsx_runtime(), 1); 6691 var TagName22 = "div"; 6692 var isSafariBrowser2 = isSafari(); 6693 function isAlreadyFocusingAnotherElement(dialog) { 6694 const activeElement = getActiveElement(); 6695 if (!activeElement) return false; 6696 if (dialog && contains(dialog, activeElement)) return false; 6697 if (isFocusable(activeElement)) return true; 6698 return false; 6699 } 6700 function getElementFromProp(prop, focusable = false) { 6701 if (!prop) return null; 6702 const element = "current" in prop ? prop.current : prop; 6703 if (!element) return null; 6704 if (focusable) return isFocusable(element) ? element : null; 6705 return element; 6706 } 6707 var useDialog = createHook(function useDialog2(_a) { 6708 var _b = _a, { 6709 store: storeProp, 6710 open: openProp, 6711 onClose, 6712 focusable = true, 6713 modal = true, 6714 portal = !!modal, 6715 backdrop = !!modal, 6716 hideOnEscape = true, 6717 hideOnInteractOutside = true, 6718 getPersistentElements, 6719 preventBodyScroll = !!modal, 6720 autoFocusOnShow = true, 6721 autoFocusOnHide = true, 6722 initialFocus, 6723 finalFocus, 6724 unmountOnHide, 6725 unstable_treeSnapshotKey 6726 } = _b, props = __objRest(_b, [ 6727 "store", 6728 "open", 6729 "onClose", 6730 "focusable", 6731 "modal", 6732 "portal", 6733 "backdrop", 6734 "hideOnEscape", 6735 "hideOnInteractOutside", 6736 "getPersistentElements", 6737 "preventBodyScroll", 6738 "autoFocusOnShow", 6739 "autoFocusOnHide", 6740 "initialFocus", 6741 "finalFocus", 6742 "unmountOnHide", 6743 "unstable_treeSnapshotKey" 6744 ]); 6745 const context = useDialogProviderContext(); 6746 const ref = (0, import_react31.useRef)(null); 6747 const store = useDialogStore({ 6748 store: storeProp || context, 6749 open: openProp, 6750 setOpen(open2) { 6751 if (open2) return; 6752 const dialog = ref.current; 6753 if (!dialog) return; 6754 const event = new Event("close", { bubbles: false, cancelable: true }); 6755 if (onClose) { 6756 dialog.addEventListener("close", onClose, { once: true }); 6757 } 6758 dialog.dispatchEvent(event); 6759 if (!event.defaultPrevented) return; 6760 store.setOpen(true); 6761 } 6762 }); 6763 const { portalRef, domReady } = usePortalRef(portal, props.portalRef); 6764 const preserveTabOrderProp = props.preserveTabOrder; 6765 const preserveTabOrder = useStoreState( 6766 store, 6767 (state) => preserveTabOrderProp && !modal && state.mounted 6768 ); 6769 const id3 = useId(props.id); 6770 const open = useStoreState(store, "open"); 6771 const mounted = useStoreState(store, "mounted"); 6772 const contentElement = useStoreState(store, "contentElement"); 6773 const hidden = isHidden(mounted, props.hidden, props.alwaysVisible); 6774 usePreventBodyScroll(contentElement, id3, preventBodyScroll && !hidden); 6775 useHideOnInteractOutside(store, hideOnInteractOutside, domReady); 6776 const { wrapElement, nestedDialogs } = useNestedDialogs(store); 6777 props = useWrapElement(props, wrapElement, [wrapElement]); 6778 useSafeLayoutEffect(() => { 6779 if (!open) return; 6780 const dialog = ref.current; 6781 const activeElement = getActiveElement(dialog, true); 6782 if (!activeElement) return; 6783 if (activeElement.tagName === "BODY") return; 6784 if (dialog && contains(dialog, activeElement)) return; 6785 store.setDisclosureElement(activeElement); 6786 }, [store, open]); 6787 if (isSafariBrowser2) { 6788 (0, import_react31.useEffect)(() => { 6789 if (!mounted) return; 6790 const { disclosureElement } = store.getState(); 6791 if (!disclosureElement) return; 6792 if (!isButton(disclosureElement)) return; 6793 const onMouseDown = () => { 6794 let receivedFocus = false; 6795 const onFocus = () => { 6796 receivedFocus = true; 6797 }; 6798 const options2 = { capture: true, once: true }; 6799 disclosureElement.addEventListener("focusin", onFocus, options2); 6800 queueBeforeEvent(disclosureElement, "mouseup", () => { 6801 disclosureElement.removeEventListener("focusin", onFocus, true); 6802 if (receivedFocus) return; 6803 focusIfNeeded(disclosureElement); 6804 }); 6805 }; 6806 disclosureElement.addEventListener("mousedown", onMouseDown); 6807 return () => { 6808 disclosureElement.removeEventListener("mousedown", onMouseDown); 6809 }; 6810 }, [store, mounted]); 6811 } 6812 (0, import_react31.useEffect)(() => { 6813 if (!mounted) return; 6814 if (!domReady) return; 6815 const dialog = ref.current; 6816 if (!dialog) return; 6817 const win = getWindow(dialog); 6818 const viewport = win.visualViewport || win; 6819 const setViewportHeight = () => { 6820 var _a2, _b2; 6821 const height = (_b2 = (_a2 = win.visualViewport) == null ? void 0 : _a2.height) != null ? _b2 : win.innerHeight; 6822 dialog.style.setProperty("--dialog-viewport-height", `$height}px`); 6823 }; 6824 setViewportHeight(); 6825 viewport.addEventListener("resize", setViewportHeight); 6826 return () => { 6827 viewport.removeEventListener("resize", setViewportHeight); 6828 }; 6829 }, [mounted, domReady]); 6830 (0, import_react31.useEffect)(() => { 6831 if (!modal) return; 6832 if (!mounted) return; 6833 if (!domReady) return; 6834 const dialog = ref.current; 6835 if (!dialog) return; 6836 const existingDismiss = dialog.querySelector("[data-dialog-dismiss]"); 6837 if (existingDismiss) return; 6838 return prependHiddenDismiss(dialog, store.hide); 6839 }, [store, modal, mounted, domReady]); 6840 useSafeLayoutEffect(() => { 6841 if (!supportsInert()) return; 6842 if (open) return; 6843 if (!mounted) return; 6844 if (!domReady) return; 6845 const dialog = ref.current; 6846 if (!dialog) return; 6847 return disableTree(dialog); 6848 }, [open, mounted, domReady]); 6849 const canTakeTreeSnapshot = open && domReady; 6850 useSafeLayoutEffect(() => { 6851 if (!id3) return; 6852 if (!canTakeTreeSnapshot) return; 6853 const dialog = ref.current; 6854 return createWalkTreeSnapshot(id3, [dialog]); 6855 }, [id3, canTakeTreeSnapshot, unstable_treeSnapshotKey]); 6856 const getPersistentElementsProp = useEvent(getPersistentElements); 6857 useSafeLayoutEffect(() => { 6858 if (!id3) return; 6859 if (!canTakeTreeSnapshot) return; 6860 const { disclosureElement } = store.getState(); 6861 const dialog = ref.current; 6862 const persistentElements = getPersistentElementsProp() || []; 6863 const allElements = [ 6864 dialog, 6865 ...persistentElements, 6866 ...nestedDialogs.map((dialog2) => dialog2.getState().contentElement) 6867 ]; 6868 if (modal) { 6869 return chain( 6870 markTreeOutside(id3, allElements), 6871 disableTreeOutside(id3, allElements) 6872 ); 6873 } 6874 return markTreeOutside(id3, [disclosureElement, ...allElements]); 6875 }, [ 6876 id3, 6877 store, 6878 canTakeTreeSnapshot, 6879 getPersistentElementsProp, 6880 nestedDialogs, 6881 modal, 6882 unstable_treeSnapshotKey 6883 ]); 6884 const mayAutoFocusOnShow = !!autoFocusOnShow; 6885 const autoFocusOnShowProp = useBooleanEvent(autoFocusOnShow); 6886 const [autoFocusEnabled, setAutoFocusEnabled] = (0, import_react31.useState)(false); 6887 (0, import_react31.useEffect)(() => { 6888 if (!open) return; 6889 if (!mayAutoFocusOnShow) return; 6890 if (!domReady) return; 6891 if (!(contentElement == null ? void 0 : contentElement.isConnected)) return; 6892 const element = getElementFromProp(initialFocus, true) || // If no initial focus is specified, we try to focus the first element 6893 // with the autofocus attribute. If it's an Ariakit component, the 6894 // Focusable component will consume the autoFocus prop and add the 6895 // data-autofocus attribute to the element instead. 6896 contentElement.querySelector( 6897 "[data-autofocus=true],[autofocus]" 6898 ) || // We have to fallback to the first focusable element otherwise portaled 6899 // dialogs with preserveTabOrder set to true will not receive focus 6900 // properly because the elements aren't tabbable until the dialog receives 6901 // focus. 6902 getFirstTabbableIn(contentElement, true, portal && preserveTabOrder) || // Finally, we fallback to the dialog element itself. 6903 contentElement; 6904 const isElementFocusable = isFocusable(element); 6905 if (!autoFocusOnShowProp(isElementFocusable ? element : null)) return; 6906 setAutoFocusEnabled(true); 6907 queueMicrotask(() => { 6908 element.focus(); 6909 if (!isSafariBrowser2) return; 6910 element.scrollIntoView({ block: "nearest", inline: "nearest" }); 6911 }); 6912 }, [ 6913 open, 6914 mayAutoFocusOnShow, 6915 domReady, 6916 contentElement, 6917 initialFocus, 6918 portal, 6919 preserveTabOrder, 6920 autoFocusOnShowProp 6921 ]); 6922 const mayAutoFocusOnHide = !!autoFocusOnHide; 6923 const autoFocusOnHideProp = useBooleanEvent(autoFocusOnHide); 6924 const [hasOpened, setHasOpened] = (0, import_react31.useState)(false); 6925 (0, import_react31.useEffect)(() => { 6926 if (!open) return; 6927 setHasOpened(true); 6928 return () => setHasOpened(false); 6929 }, [open]); 6930 const focusOnHide = (0, import_react31.useCallback)( 6931 (dialog, retry = true) => { 6932 const { disclosureElement } = store.getState(); 6933 if (isAlreadyFocusingAnotherElement(dialog)) return; 6934 let element = getElementFromProp(finalFocus) || disclosureElement; 6935 if (element == null ? void 0 : element.id) { 6936 const doc = getDocument(element); 6937 const selector2 = `[aria-activedescendant="$element.id}"]`; 6938 const composite = doc.querySelector(selector2); 6939 if (composite) { 6940 element = composite; 6941 } 6942 } 6943 if (element && !isFocusable(element)) { 6944 const maybeParentDialog = element.closest("[data-dialog]"); 6945 if (maybeParentDialog == null ? void 0 : maybeParentDialog.id) { 6946 const doc = getDocument(maybeParentDialog); 6947 const selector2 = `[aria-controls~="$maybeParentDialog.id}"]`; 6948 const control = doc.querySelector(selector2); 6949 if (control) { 6950 element = control; 6951 } 6952 } 6953 } 6954 const isElementFocusable = element && isFocusable(element); 6955 if (!isElementFocusable && retry) { 6956 requestAnimationFrame(() => focusOnHide(dialog, false)); 6957 return; 6958 } 6959 if (!autoFocusOnHideProp(isElementFocusable ? element : null)) return; 6960 if (!isElementFocusable) return; 6961 element == null ? void 0 : element.focus(); 6962 }, 6963 [store, finalFocus, autoFocusOnHideProp] 6964 ); 6965 const focusedOnHideRef = (0, import_react31.useRef)(false); 6966 useSafeLayoutEffect(() => { 6967 if (open) return; 6968 if (!hasOpened) return; 6969 if (!mayAutoFocusOnHide) return; 6970 const dialog = ref.current; 6971 focusedOnHideRef.current = true; 6972 focusOnHide(dialog); 6973 }, [open, hasOpened, domReady, mayAutoFocusOnHide, focusOnHide]); 6974 (0, import_react31.useEffect)(() => { 6975 if (!hasOpened) return; 6976 if (!mayAutoFocusOnHide) return; 6977 const dialog = ref.current; 6978 return () => { 6979 if (focusedOnHideRef.current) { 6980 focusedOnHideRef.current = false; 6981 return; 6982 } 6983 focusOnHide(dialog); 6984 }; 6985 }, [hasOpened, mayAutoFocusOnHide, focusOnHide]); 6986 const hideOnEscapeProp = useBooleanEvent(hideOnEscape); 6987 (0, import_react31.useEffect)(() => { 6988 if (!domReady) return; 6989 if (!mounted) return; 6990 const onKeyDown = (event) => { 6991 if (event.key !== "Escape") return; 6992 if (event.defaultPrevented) return; 6993 const dialog = ref.current; 6994 if (!dialog) return; 6995 if (isElementMarked(dialog)) return; 6996 const target = event.target; 6997 if (!target) return; 6998 const { disclosureElement } = store.getState(); 6999 const isValidTarget = () => { 7000 if (target.tagName === "BODY") return true; 7001 if (contains(dialog, target)) return true; 7002 if (!disclosureElement) return true; 7003 if (contains(disclosureElement, target)) return true; 7004 return false; 7005 }; 7006 if (!isValidTarget()) return; 7007 if (!hideOnEscapeProp(event)) return; 7008 store.hide(); 7009 }; 7010 return addGlobalEventListener("keydown", onKeyDown, true); 7011 }, [store, domReady, mounted, hideOnEscapeProp]); 7012 props = useWrapElement( 7013 props, 7014 (element) => /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(HeadingLevel, { level: modal ? 1 : void 0, children: element }), 7015 [modal] 7016 ); 7017 const hiddenProp = props.hidden; 7018 const alwaysVisible = props.alwaysVisible; 7019 props = useWrapElement( 7020 props, 7021 (element) => { 7022 if (!backdrop) return element; 7023 return /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)(import_jsx_runtime12.Fragment, { children: [ 7024 /* @__PURE__ */ (0, import_jsx_runtime12.jsx)( 7025 DialogBackdrop, 7026 { 7027 store, 7028 backdrop, 7029 hidden: hiddenProp, 7030 alwaysVisible 7031 } 7032 ), 7033 element 7034 ] }); 7035 }, 7036 [store, backdrop, hiddenProp, alwaysVisible] 7037 ); 7038 const [headingId, setHeadingId] = (0, import_react31.useState)(); 7039 const [descriptionId, setDescriptionId] = (0, import_react31.useState)(); 7040 props = useWrapElement( 7041 props, 7042 (element) => /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(DialogScopedContextProvider, { value: store, children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(DialogHeadingContext.Provider, { value: setHeadingId, children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(DialogDescriptionContext.Provider, { value: setDescriptionId, children: element }) }) }), 7043 [store] 7044 ); 7045 props = __spreadProps(__spreadValues({ 7046 id: id3, 7047 "data-dialog": "", 7048 role: "dialog", 7049 tabIndex: focusable ? -1 : void 0, 7050 "aria-labelledby": headingId, 7051 "aria-describedby": descriptionId 7052 }, props), { 7053 ref: useMergeRefs(ref, props.ref) 7054 }); 7055 props = useFocusableContainer(__spreadProps(__spreadValues({}, props), { 7056 autoFocusOnShow: autoFocusEnabled 7057 })); 7058 props = useDisclosureContent(__spreadValues({ store }, props)); 7059 props = useFocusable(__spreadProps(__spreadValues({}, props), { focusable })); 7060 props = usePortal(__spreadProps(__spreadValues({ portal }, props), { portalRef, preserveTabOrder })); 7061 return props; 7062 }); 7063 function createDialogComponent(Component9, useProviderContext = useDialogProviderContext) { 7064 return forwardRef2(function DialogComponent(props) { 7065 const context = useProviderContext(); 7066 const store = props.store || context; 7067 const mounted = useStoreState( 7068 store, 7069 (state) => !props.unmountOnHide || (state == null ? void 0 : state.mounted) || !!props.open 7070 ); 7071 if (!mounted) return null; 7072 return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(Component9, __spreadValues({}, props)); 7073 }); 7074 } 7075 var Dialog = createDialogComponent( 7076 forwardRef2(function Dialog2(props) { 7077 const htmlProps = useDialog(props); 7078 return createElement(TagName22, htmlProps); 7079 }), 7080 useDialogProviderContext 7081 ); 7082 7083 // node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs 7084 var min = Math.min; 7085 var max = Math.max; 7086 var round = Math.round; 7087 var floor = Math.floor; 7088 var createCoords = (v3) => ({ 7089 x: v3, 7090 y: v3 7091 }); 7092 var oppositeSideMap = { 7093 left: "right", 7094 right: "left", 7095 bottom: "top", 7096 top: "bottom" 7097 }; 7098 var oppositeAlignmentMap = { 7099 start: "end", 7100 end: "start" 7101 }; 7102 function clamp(start, value, end) { 7103 return max(start, min(value, end)); 7104 } 7105 function evaluate(value, param) { 7106 return typeof value === "function" ? value(param) : value; 7107 } 7108 function getSide(placement) { 7109 return placement.split("-")[0]; 7110 } 7111 function getAlignment(placement) { 7112 return placement.split("-")[1]; 7113 } 7114 function getOppositeAxis(axis) { 7115 return axis === "x" ? "y" : "x"; 7116 } 7117 function getAxisLength(axis) { 7118 return axis === "y" ? "height" : "width"; 7119 } 7120 var yAxisSides = /* @__PURE__ */ new Set(["top", "bottom"]); 7121 function getSideAxis(placement) { 7122 return yAxisSides.has(getSide(placement)) ? "y" : "x"; 7123 } 7124 function getAlignmentAxis(placement) { 7125 return getOppositeAxis(getSideAxis(placement)); 7126 } 7127 function getAlignmentSides(placement, rects, rtl2) { 7128 if (rtl2 === void 0) { 7129 rtl2 = false; 7130 } 7131 const alignment = getAlignment(placement); 7132 const alignmentAxis = getAlignmentAxis(placement); 7133 const length2 = getAxisLength(alignmentAxis); 7134 let mainAlignmentSide = alignmentAxis === "x" ? alignment === (rtl2 ? "end" : "start") ? "right" : "left" : alignment === "start" ? "bottom" : "top"; 7135 if (rects.reference[length2] > rects.floating[length2]) { 7136 mainAlignmentSide = getOppositePlacement(mainAlignmentSide); 7137 } 7138 return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)]; 7139 } 7140 function getExpandedPlacements(placement) { 7141 const oppositePlacement = getOppositePlacement(placement); 7142 return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)]; 7143 } 7144 function getOppositeAlignmentPlacement(placement) { 7145 return placement.replace(/start|end/g, (alignment) => oppositeAlignmentMap[alignment]); 7146 } 7147 var lrPlacement = ["left", "right"]; 7148 var rlPlacement = ["right", "left"]; 7149 var tbPlacement = ["top", "bottom"]; 7150 var btPlacement = ["bottom", "top"]; 7151 function getSideList(side, isStart, rtl2) { 7152 switch (side) { 7153 case "top": 7154 case "bottom": 7155 if (rtl2) return isStart ? rlPlacement : lrPlacement; 7156 return isStart ? lrPlacement : rlPlacement; 7157 case "left": 7158 case "right": 7159 return isStart ? tbPlacement : btPlacement; 7160 default: 7161 return []; 7162 } 7163 } 7164 function getOppositeAxisPlacements(placement, flipAlignment, direction, rtl2) { 7165 const alignment = getAlignment(placement); 7166 let list = getSideList(getSide(placement), direction === "start", rtl2); 7167 if (alignment) { 7168 list = list.map((side) => side + "-" + alignment); 7169 if (flipAlignment) { 7170 list = list.concat(list.map(getOppositeAlignmentPlacement)); 7171 } 7172 } 7173 return list; 7174 } 7175 function getOppositePlacement(placement) { 7176 return placement.replace(/left|right|bottom|top/g, (side) => oppositeSideMap[side]); 7177 } 7178 function expandPaddingObject(padding2) { 7179 return { 7180 top: 0, 7181 right: 0, 7182 bottom: 0, 7183 left: 0, 7184 ...padding2 7185 }; 7186 } 7187 function getPaddingObject(padding2) { 7188 return typeof padding2 !== "number" ? expandPaddingObject(padding2) : { 7189 top: padding2, 7190 right: padding2, 7191 bottom: padding2, 7192 left: padding2 7193 }; 7194 } 7195 function rectToClientRect(rect) { 7196 const { 7197 x: x2, 7198 y: y3, 7199 width, 7200 height 7201 } = rect; 7202 return { 7203 width, 7204 height, 7205 top: y3, 7206 left: x2, 7207 right: x2 + width, 7208 bottom: y3 + height, 7209 x: x2, 7210 y: y3 7211 }; 7212 } 7213 7214 // node_modules/@floating-ui/core/dist/floating-ui.core.mjs 7215 function computeCoordsFromPlacement(_ref11, placement, rtl2) { 7216 let { 7217 reference, 7218 floating 7219 } = _ref11; 7220 const sideAxis = getSideAxis(placement); 7221 const alignmentAxis = getAlignmentAxis(placement); 7222 const alignLength = getAxisLength(alignmentAxis); 7223 const side = getSide(placement); 7224 const isVertical = sideAxis === "y"; 7225 const commonX = reference.x + reference.width / 2 - floating.width / 2; 7226 const commonY = reference.y + reference.height / 2 - floating.height / 2; 7227 const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2; 7228 let coords; 7229 switch (side) { 7230 case "top": 7231 coords = { 7232 x: commonX, 7233 y: reference.y - floating.height 7234 }; 7235 break; 7236 case "bottom": 7237 coords = { 7238 x: commonX, 7239 y: reference.y + reference.height 7240 }; 7241 break; 7242 case "right": 7243 coords = { 7244 x: reference.x + reference.width, 7245 y: commonY 7246 }; 7247 break; 7248 case "left": 7249 coords = { 7250 x: reference.x - floating.width, 7251 y: commonY 7252 }; 7253 break; 7254 default: 7255 coords = { 7256 x: reference.x, 7257 y: reference.y 7258 }; 7259 } 7260 switch (getAlignment(placement)) { 7261 case "start": 7262 coords[alignmentAxis] -= commonAlign * (rtl2 && isVertical ? -1 : 1); 7263 break; 7264 case "end": 7265 coords[alignmentAxis] += commonAlign * (rtl2 && isVertical ? -1 : 1); 7266 break; 7267 } 7268 return coords; 7269 } 7270 var computePosition = async (reference, floating, config) => { 7271 const { 7272 placement = "bottom", 7273 strategy = "absolute", 7274 middleware: middleware2 = [], 7275 platform: platform2 7276 } = config; 7277 const validMiddleware = middleware2.filter(Boolean); 7278 const rtl2 = await (platform2.isRTL == null ? void 0 : platform2.isRTL(floating)); 7279 let rects = await platform2.getElementRects({ 7280 reference, 7281 floating, 7282 strategy 7283 }); 7284 let { 7285 x: x2, 7286 y: y3 7287 } = computeCoordsFromPlacement(rects, placement, rtl2); 7288 let statefulPlacement = placement; 7289 let middlewareData = {}; 7290 let resetCount = 0; 7291 for (let i3 = 0; i3 < validMiddleware.length; i3++) { 7292 const { 7293 name, 7294 fn 7295 } = validMiddleware[i3]; 7296 const { 7297 x: nextX, 7298 y: nextY, 7299 data, 7300 reset 7301 } = await fn({ 7302 x: x2, 7303 y: y3, 7304 initialPlacement: placement, 7305 placement: statefulPlacement, 7306 strategy, 7307 middlewareData, 7308 rects, 7309 platform: platform2, 7310 elements: { 7311 reference, 7312 floating 7313 } 7314 }); 7315 x2 = nextX != null ? nextX : x2; 7316 y3 = nextY != null ? nextY : y3; 7317 middlewareData = { 7318 ...middlewareData, 7319 [name]: { 7320 ...middlewareData[name], 7321 ...data 7322 } 7323 }; 7324 if (reset && resetCount <= 50) { 7325 resetCount++; 7326 if (typeof reset === "object") { 7327 if (reset.placement) { 7328 statefulPlacement = reset.placement; 7329 } 7330 if (reset.rects) { 7331 rects = reset.rects === true ? await platform2.getElementRects({ 7332 reference, 7333 floating, 7334 strategy 7335 }) : reset.rects; 7336 } 7337 ({ 7338 x: x2, 7339 y: y3 7340 } = computeCoordsFromPlacement(rects, statefulPlacement, rtl2)); 7341 } 7342 i3 = -1; 7343 } 7344 } 7345 return { 7346 x: x2, 7347 y: y3, 7348 placement: statefulPlacement, 7349 strategy, 7350 middlewareData 7351 }; 7352 }; 7353 async function detectOverflow(state, options2) { 7354 var _await$platform$isEle; 7355 if (options2 === void 0) { 7356 options2 = {}; 7357 } 7358 const { 7359 x: x2, 7360 y: y3, 7361 platform: platform2, 7362 rects, 7363 elements: elements2, 7364 strategy 7365 } = state; 7366 const { 7367 boundary = "clippingAncestors", 7368 rootBoundary = "viewport", 7369 elementContext = "floating", 7370 altBoundary = false, 7371 padding: padding2 = 0 7372 } = evaluate(options2, state); 7373 const paddingObject = getPaddingObject(padding2); 7374 const altContext = elementContext === "floating" ? "reference" : "floating"; 7375 const element = elements2[altBoundary ? altContext : elementContext]; 7376 const clippingClientRect = rectToClientRect(await platform2.getClippingRect({ 7377 element: ((_await$platform$isEle = await (platform2.isElement == null ? void 0 : platform2.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || await (platform2.getDocumentElement == null ? void 0 : platform2.getDocumentElement(elements2.floating)), 7378 boundary, 7379 rootBoundary, 7380 strategy 7381 })); 7382 const rect = elementContext === "floating" ? { 7383 x: x2, 7384 y: y3, 7385 width: rects.floating.width, 7386 height: rects.floating.height 7387 } : rects.reference; 7388 const offsetParent = await (platform2.getOffsetParent == null ? void 0 : platform2.getOffsetParent(elements2.floating)); 7389 const offsetScale = await (platform2.isElement == null ? void 0 : platform2.isElement(offsetParent)) ? await (platform2.getScale == null ? void 0 : platform2.getScale(offsetParent)) || { 7390 x: 1, 7391 y: 1 7392 } : { 7393 x: 1, 7394 y: 1 7395 }; 7396 const elementClientRect = rectToClientRect(platform2.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform2.convertOffsetParentRelativeRectToViewportRelativeRect({ 7397 elements: elements2, 7398 rect, 7399 offsetParent, 7400 strategy 7401 }) : rect); 7402 return { 7403 top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y, 7404 bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y, 7405 left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x, 7406 right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x 7407 }; 7408 } 7409 var arrow = (options2) => ({ 7410 name: "arrow", 7411 options: options2, 7412 async fn(state) { 7413 const { 7414 x: x2, 7415 y: y3, 7416 placement, 7417 rects, 7418 platform: platform2, 7419 elements: elements2, 7420 middlewareData 7421 } = state; 7422 const { 7423 element, 7424 padding: padding2 = 0 7425 } = evaluate(options2, state) || {}; 7426 if (element == null) { 7427 return {}; 7428 } 7429 const paddingObject = getPaddingObject(padding2); 7430 const coords = { 7431 x: x2, 7432 y: y3 7433 }; 7434 const axis = getAlignmentAxis(placement); 7435 const length2 = getAxisLength(axis); 7436 const arrowDimensions = await platform2.getDimensions(element); 7437 const isYAxis = axis === "y"; 7438 const minProp = isYAxis ? "top" : "left"; 7439 const maxProp = isYAxis ? "bottom" : "right"; 7440 const clientProp = isYAxis ? "clientHeight" : "clientWidth"; 7441 const endDiff = rects.reference[length2] + rects.reference[axis] - coords[axis] - rects.floating[length2]; 7442 const startDiff = coords[axis] - rects.reference[axis]; 7443 const arrowOffsetParent = await (platform2.getOffsetParent == null ? void 0 : platform2.getOffsetParent(element)); 7444 let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0; 7445 if (!clientSize || !await (platform2.isElement == null ? void 0 : platform2.isElement(arrowOffsetParent))) { 7446 clientSize = elements2.floating[clientProp] || rects.floating[length2]; 7447 } 7448 const centerToReference = endDiff / 2 - startDiff / 2; 7449 const largestPossiblePadding = clientSize / 2 - arrowDimensions[length2] / 2 - 1; 7450 const minPadding = min(paddingObject[minProp], largestPossiblePadding); 7451 const maxPadding = min(paddingObject[maxProp], largestPossiblePadding); 7452 const min$1 = minPadding; 7453 const max3 = clientSize - arrowDimensions[length2] - maxPadding; 7454 const center = clientSize / 2 - arrowDimensions[length2] / 2 + centerToReference; 7455 const offset3 = clamp(min$1, center, max3); 7456 const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset3 && rects.reference[length2] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length2] / 2 < 0; 7457 const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max3 : 0; 7458 return { 7459 [axis]: coords[axis] + alignmentOffset, 7460 data: { 7461 [axis]: offset3, 7462 centerOffset: center - offset3 - alignmentOffset, 7463 ...shouldAddOffset && { 7464 alignmentOffset 7465 } 7466 }, 7467 reset: shouldAddOffset 7468 }; 7469 } 7470 }); 7471 var flip = function(options2) { 7472 if (options2 === void 0) { 7473 options2 = {}; 7474 } 7475 return { 7476 name: "flip", 7477 options: options2, 7478 async fn(state) { 7479 var _middlewareData$arrow, _middlewareData$flip; 7480 const { 7481 placement, 7482 middlewareData, 7483 rects, 7484 initialPlacement, 7485 platform: platform2, 7486 elements: elements2 7487 } = state; 7488 const { 7489 mainAxis: checkMainAxis = true, 7490 crossAxis: checkCrossAxis = true, 7491 fallbackPlacements: specifiedFallbackPlacements, 7492 fallbackStrategy = "bestFit", 7493 fallbackAxisSideDirection = "none", 7494 flipAlignment = true, 7495 ...detectOverflowOptions 7496 } = evaluate(options2, state); 7497 if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) { 7498 return {}; 7499 } 7500 const side = getSide(placement); 7501 const initialSideAxis = getSideAxis(initialPlacement); 7502 const isBasePlacement = getSide(initialPlacement) === initialPlacement; 7503 const rtl2 = await (platform2.isRTL == null ? void 0 : platform2.isRTL(elements2.floating)); 7504 const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement)); 7505 const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== "none"; 7506 if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) { 7507 fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl2)); 7508 } 7509 const placements2 = [initialPlacement, ...fallbackPlacements]; 7510 const overflow = await detectOverflow(state, detectOverflowOptions); 7511 const overflows = []; 7512 let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || []; 7513 if (checkMainAxis) { 7514 overflows.push(overflow[side]); 7515 } 7516 if (checkCrossAxis) { 7517 const sides3 = getAlignmentSides(placement, rects, rtl2); 7518 overflows.push(overflow[sides3[0]], overflow[sides3[1]]); 7519 } 7520 overflowsData = [...overflowsData, { 7521 placement, 7522 overflows 7523 }]; 7524 if (!overflows.every((side2) => side2 <= 0)) { 7525 var _middlewareData$flip2, _overflowsData$filter; 7526 const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1; 7527 const nextPlacement = placements2[nextIndex]; 7528 if (nextPlacement) { 7529 const ignoreCrossAxisOverflow = checkCrossAxis === "alignment" ? initialSideAxis !== getSideAxis(nextPlacement) : false; 7530 if (!ignoreCrossAxisOverflow || // We leave the current main axis only if every placement on that axis 7531 // overflows the main axis. 7532 overflowsData.every((d3) => d3.overflows[0] > 0 && getSideAxis(d3.placement) === initialSideAxis)) { 7533 return { 7534 data: { 7535 index: nextIndex, 7536 overflows: overflowsData 7537 }, 7538 reset: { 7539 placement: nextPlacement 7540 } 7541 }; 7542 } 7543 } 7544 let resetPlacement = (_overflowsData$filter = overflowsData.filter((d3) => d3.overflows[0] <= 0).sort((a3, b3) => a3.overflows[1] - b3.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement; 7545 if (!resetPlacement) { 7546 switch (fallbackStrategy) { 7547 case "bestFit": { 7548 var _overflowsData$filter2; 7549 const placement2 = (_overflowsData$filter2 = overflowsData.filter((d3) => { 7550 if (hasFallbackAxisSideDirection) { 7551 const currentSideAxis = getSideAxis(d3.placement); 7552 return currentSideAxis === initialSideAxis || // Create a bias to the `y` side axis due to horizontal 7553 // reading directions favoring greater width. 7554 currentSideAxis === "y"; 7555 } 7556 return true; 7557 }).map((d3) => [d3.placement, d3.overflows.filter((overflow2) => overflow2 > 0).reduce((acc, overflow2) => acc + overflow2, 0)]).sort((a3, b3) => a3[1] - b3[1])[0]) == null ? void 0 : _overflowsData$filter2[0]; 7558 if (placement2) { 7559 resetPlacement = placement2; 7560 } 7561 break; 7562 } 7563 case "initialPlacement": 7564 resetPlacement = initialPlacement; 7565 break; 7566 } 7567 } 7568 if (placement !== resetPlacement) { 7569 return { 7570 reset: { 7571 placement: resetPlacement 7572 } 7573 }; 7574 } 7575 } 7576 return {}; 7577 } 7578 }; 7579 }; 7580 var originSides = /* @__PURE__ */ new Set(["left", "top"]); 7581 async function convertValueToCoords(state, options2) { 7582 const { 7583 placement, 7584 platform: platform2, 7585 elements: elements2 7586 } = state; 7587 const rtl2 = await (platform2.isRTL == null ? void 0 : platform2.isRTL(elements2.floating)); 7588 const side = getSide(placement); 7589 const alignment = getAlignment(placement); 7590 const isVertical = getSideAxis(placement) === "y"; 7591 const mainAxisMulti = originSides.has(side) ? -1 : 1; 7592 const crossAxisMulti = rtl2 && isVertical ? -1 : 1; 7593 const rawValue = evaluate(options2, state); 7594 let { 7595 mainAxis, 7596 crossAxis, 7597 alignmentAxis 7598 } = typeof rawValue === "number" ? { 7599 mainAxis: rawValue, 7600 crossAxis: 0, 7601 alignmentAxis: null 7602 } : { 7603 mainAxis: rawValue.mainAxis || 0, 7604 crossAxis: rawValue.crossAxis || 0, 7605 alignmentAxis: rawValue.alignmentAxis 7606 }; 7607 if (alignment && typeof alignmentAxis === "number") { 7608 crossAxis = alignment === "end" ? alignmentAxis * -1 : alignmentAxis; 7609 } 7610 return isVertical ? { 7611 x: crossAxis * crossAxisMulti, 7612 y: mainAxis * mainAxisMulti 7613 } : { 7614 x: mainAxis * mainAxisMulti, 7615 y: crossAxis * crossAxisMulti 7616 }; 7617 } 7618 var offset = function(options2) { 7619 if (options2 === void 0) { 7620 options2 = 0; 7621 } 7622 return { 7623 name: "offset", 7624 options: options2, 7625 async fn(state) { 7626 var _middlewareData$offse, _middlewareData$arrow; 7627 const { 7628 x: x2, 7629 y: y3, 7630 placement, 7631 middlewareData 7632 } = state; 7633 const diffCoords = await convertValueToCoords(state, options2); 7634 if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) { 7635 return {}; 7636 } 7637 return { 7638 x: x2 + diffCoords.x, 7639 y: y3 + diffCoords.y, 7640 data: { 7641 ...diffCoords, 7642 placement 7643 } 7644 }; 7645 } 7646 }; 7647 }; 7648 var shift = function(options2) { 7649 if (options2 === void 0) { 7650 options2 = {}; 7651 } 7652 return { 7653 name: "shift", 7654 options: options2, 7655 async fn(state) { 7656 const { 7657 x: x2, 7658 y: y3, 7659 placement 7660 } = state; 7661 const { 7662 mainAxis: checkMainAxis = true, 7663 crossAxis: checkCrossAxis = false, 7664 limiter = { 7665 fn: (_ref11) => { 7666 let { 7667 x: x3, 7668 y: y4 7669 } = _ref11; 7670 return { 7671 x: x3, 7672 y: y4 7673 }; 7674 } 7675 }, 7676 ...detectOverflowOptions 7677 } = evaluate(options2, state); 7678 const coords = { 7679 x: x2, 7680 y: y3 7681 }; 7682 const overflow = await detectOverflow(state, detectOverflowOptions); 7683 const crossAxis = getSideAxis(getSide(placement)); 7684 const mainAxis = getOppositeAxis(crossAxis); 7685 let mainAxisCoord = coords[mainAxis]; 7686 let crossAxisCoord = coords[crossAxis]; 7687 if (checkMainAxis) { 7688 const minSide = mainAxis === "y" ? "top" : "left"; 7689 const maxSide = mainAxis === "y" ? "bottom" : "right"; 7690 const min3 = mainAxisCoord + overflow[minSide]; 7691 const max3 = mainAxisCoord - overflow[maxSide]; 7692 mainAxisCoord = clamp(min3, mainAxisCoord, max3); 7693 } 7694 if (checkCrossAxis) { 7695 const minSide = crossAxis === "y" ? "top" : "left"; 7696 const maxSide = crossAxis === "y" ? "bottom" : "right"; 7697 const min3 = crossAxisCoord + overflow[minSide]; 7698 const max3 = crossAxisCoord - overflow[maxSide]; 7699 crossAxisCoord = clamp(min3, crossAxisCoord, max3); 7700 } 7701 const limitedCoords = limiter.fn({ 7702 ...state, 7703 [mainAxis]: mainAxisCoord, 7704 [crossAxis]: crossAxisCoord 7705 }); 7706 return { 7707 ...limitedCoords, 7708 data: { 7709 x: limitedCoords.x - x2, 7710 y: limitedCoords.y - y3, 7711 enabled: { 7712 [mainAxis]: checkMainAxis, 7713 [crossAxis]: checkCrossAxis 7714 } 7715 } 7716 }; 7717 } 7718 }; 7719 }; 7720 var limitShift = function(options2) { 7721 if (options2 === void 0) { 7722 options2 = {}; 7723 } 7724 return { 7725 options: options2, 7726 fn(state) { 7727 const { 7728 x: x2, 7729 y: y3, 7730 placement, 7731 rects, 7732 middlewareData 7733 } = state; 7734 const { 7735 offset: offset3 = 0, 7736 mainAxis: checkMainAxis = true, 7737 crossAxis: checkCrossAxis = true 7738 } = evaluate(options2, state); 7739 const coords = { 7740 x: x2, 7741 y: y3 7742 }; 7743 const crossAxis = getSideAxis(placement); 7744 const mainAxis = getOppositeAxis(crossAxis); 7745 let mainAxisCoord = coords[mainAxis]; 7746 let crossAxisCoord = coords[crossAxis]; 7747 const rawOffset = evaluate(offset3, state); 7748 const computedOffset = typeof rawOffset === "number" ? { 7749 mainAxis: rawOffset, 7750 crossAxis: 0 7751 } : { 7752 mainAxis: 0, 7753 crossAxis: 0, 7754 ...rawOffset 7755 }; 7756 if (checkMainAxis) { 7757 const len = mainAxis === "y" ? "height" : "width"; 7758 const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis; 7759 const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis; 7760 if (mainAxisCoord < limitMin) { 7761 mainAxisCoord = limitMin; 7762 } else if (mainAxisCoord > limitMax) { 7763 mainAxisCoord = limitMax; 7764 } 7765 } 7766 if (checkCrossAxis) { 7767 var _middlewareData$offse, _middlewareData$offse2; 7768 const len = mainAxis === "y" ? "width" : "height"; 7769 const isOriginSide = originSides.has(getSide(placement)); 7770 const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis); 7771 const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0); 7772 if (crossAxisCoord < limitMin) { 7773 crossAxisCoord = limitMin; 7774 } else if (crossAxisCoord > limitMax) { 7775 crossAxisCoord = limitMax; 7776 } 7777 } 7778 return { 7779 [mainAxis]: mainAxisCoord, 7780 [crossAxis]: crossAxisCoord 7781 }; 7782 } 7783 }; 7784 }; 7785 var size = function(options2) { 7786 if (options2 === void 0) { 7787 options2 = {}; 7788 } 7789 return { 7790 name: "size", 7791 options: options2, 7792 async fn(state) { 7793 var _state$middlewareData, _state$middlewareData2; 7794 const { 7795 placement, 7796 rects, 7797 platform: platform2, 7798 elements: elements2 7799 } = state; 7800 const { 7801 apply = () => { 7802 }, 7803 ...detectOverflowOptions 7804 } = evaluate(options2, state); 7805 const overflow = await detectOverflow(state, detectOverflowOptions); 7806 const side = getSide(placement); 7807 const alignment = getAlignment(placement); 7808 const isYAxis = getSideAxis(placement) === "y"; 7809 const { 7810 width, 7811 height 7812 } = rects.floating; 7813 let heightSide; 7814 let widthSide; 7815 if (side === "top" || side === "bottom") { 7816 heightSide = side; 7817 widthSide = alignment === (await (platform2.isRTL == null ? void 0 : platform2.isRTL(elements2.floating)) ? "start" : "end") ? "left" : "right"; 7818 } else { 7819 widthSide = side; 7820 heightSide = alignment === "end" ? "top" : "bottom"; 7821 } 7822 const maximumClippingHeight = height - overflow.top - overflow.bottom; 7823 const maximumClippingWidth = width - overflow.left - overflow.right; 7824 const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight); 7825 const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth); 7826 const noShift = !state.middlewareData.shift; 7827 let availableHeight = overflowAvailableHeight; 7828 let availableWidth = overflowAvailableWidth; 7829 if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) { 7830 availableWidth = maximumClippingWidth; 7831 } 7832 if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) { 7833 availableHeight = maximumClippingHeight; 7834 } 7835 if (noShift && !alignment) { 7836 const xMin = max(overflow.left, 0); 7837 const xMax = max(overflow.right, 0); 7838 const yMin = max(overflow.top, 0); 7839 const yMax = max(overflow.bottom, 0); 7840 if (isYAxis) { 7841 availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right)); 7842 } else { 7843 availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom)); 7844 } 7845 } 7846 await apply({ 7847 ...state, 7848 availableWidth, 7849 availableHeight 7850 }); 7851 const nextDimensions = await platform2.getDimensions(elements2.floating); 7852 if (width !== nextDimensions.width || height !== nextDimensions.height) { 7853 return { 7854 reset: { 7855 rects: true 7856 } 7857 }; 7858 } 7859 return {}; 7860 } 7861 }; 7862 }; 7863 7864 // node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs 7865 function hasWindow() { 7866 return typeof window !== "undefined"; 7867 } 7868 function getNodeName(node2) { 7869 if (isNode(node2)) { 7870 return (node2.nodeName || "").toLowerCase(); 7871 } 7872 return "#document"; 7873 } 7874 function getWindow2(node2) { 7875 var _node$ownerDocument; 7876 return (node2 == null || (_node$ownerDocument = node2.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window; 7877 } 7878 function getDocumentElement(node2) { 7879 var _ref11; 7880 return (_ref11 = (isNode(node2) ? node2.ownerDocument : node2.document) || window.document) == null ? void 0 : _ref11.documentElement; 7881 } 7882 function isNode(value) { 7883 if (!hasWindow()) { 7884 return false; 7885 } 7886 return value instanceof Node || value instanceof getWindow2(value).Node; 7887 } 7888 function isElement(value) { 7889 if (!hasWindow()) { 7890 return false; 7891 } 7892 return value instanceof Element || value instanceof getWindow2(value).Element; 7893 } 7894 function isHTMLElement(value) { 7895 if (!hasWindow()) { 7896 return false; 7897 } 7898 return value instanceof HTMLElement || value instanceof getWindow2(value).HTMLElement; 7899 } 7900 function isShadowRoot(value) { 7901 if (!hasWindow() || typeof ShadowRoot === "undefined") { 7902 return false; 7903 } 7904 return value instanceof ShadowRoot || value instanceof getWindow2(value).ShadowRoot; 7905 } 7906 var invalidOverflowDisplayValues = /* @__PURE__ */ new Set(["inline", "contents"]); 7907 function isOverflowElement(element) { 7908 const { 7909 overflow, 7910 overflowX, 7911 overflowY, 7912 display 7913 } = getComputedStyle2(element); 7914 return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !invalidOverflowDisplayValues.has(display); 7915 } 7916 var tableElements = /* @__PURE__ */ new Set(["table", "td", "th"]); 7917 function isTableElement(element) { 7918 return tableElements.has(getNodeName(element)); 7919 } 7920 var topLayerSelectors = [":popover-open", ":modal"]; 7921 function isTopLayer(element) { 7922 return topLayerSelectors.some((selector2) => { 7923 try { 7924 return element.matches(selector2); 7925 } catch (_e2) { 7926 return false; 7927 } 7928 }); 7929 } 7930 var transformProperties = ["transform", "translate", "scale", "rotate", "perspective"]; 7931 var willChangeValues = ["transform", "translate", "scale", "rotate", "perspective", "filter"]; 7932 var containValues = ["paint", "layout", "strict", "content"]; 7933 function isContainingBlock(elementOrCss) { 7934 const webkit = isWebKit(); 7935 const css6 = isElement(elementOrCss) ? getComputedStyle2(elementOrCss) : elementOrCss; 7936 return transformProperties.some((value) => css6[value] ? css6[value] !== "none" : false) || (css6.containerType ? css6.containerType !== "normal" : false) || !webkit && (css6.backdropFilter ? css6.backdropFilter !== "none" : false) || !webkit && (css6.filter ? css6.filter !== "none" : false) || willChangeValues.some((value) => (css6.willChange || "").includes(value)) || containValues.some((value) => (css6.contain || "").includes(value)); 7937 } 7938 function getContainingBlock(element) { 7939 let currentNode = getParentNode(element); 7940 while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) { 7941 if (isContainingBlock(currentNode)) { 7942 return currentNode; 7943 } else if (isTopLayer(currentNode)) { 7944 return null; 7945 } 7946 currentNode = getParentNode(currentNode); 7947 } 7948 return null; 7949 } 7950 function isWebKit() { 7951 if (typeof CSS === "undefined" || !CSS.supports) return false; 7952 return CSS.supports("-webkit-backdrop-filter", "none"); 7953 } 7954 var lastTraversableNodeNames = /* @__PURE__ */ new Set(["html", "body", "#document"]); 7955 function isLastTraversableNode(node2) { 7956 return lastTraversableNodeNames.has(getNodeName(node2)); 7957 } 7958 function getComputedStyle2(element) { 7959 return getWindow2(element).getComputedStyle(element); 7960 } 7961 function getNodeScroll(element) { 7962 if (isElement(element)) { 7963 return { 7964 scrollLeft: element.scrollLeft, 7965 scrollTop: element.scrollTop 7966 }; 7967 } 7968 return { 7969 scrollLeft: element.scrollX, 7970 scrollTop: element.scrollY 7971 }; 7972 } 7973 function getParentNode(node2) { 7974 if (getNodeName(node2) === "html") { 7975 return node2; 7976 } 7977 const result = ( 7978 // Step into the shadow DOM of the parent of a slotted node. 7979 node2.assignedSlot || // DOM Element detected. 7980 node2.parentNode || // ShadowRoot detected. 7981 isShadowRoot(node2) && node2.host || // Fallback. 7982 getDocumentElement(node2) 7983 ); 7984 return isShadowRoot(result) ? result.host : result; 7985 } 7986 function getNearestOverflowAncestor(node2) { 7987 const parentNode = getParentNode(node2); 7988 if (isLastTraversableNode(parentNode)) { 7989 return node2.ownerDocument ? node2.ownerDocument.body : node2.body; 7990 } 7991 if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) { 7992 return parentNode; 7993 } 7994 return getNearestOverflowAncestor(parentNode); 7995 } 7996 function getOverflowAncestors(node2, list, traverseIframes) { 7997 var _node$ownerDocument2; 7998 if (list === void 0) { 7999 list = []; 8000 } 8001 if (traverseIframes === void 0) { 8002 traverseIframes = true; 8003 } 8004 const scrollableAncestor = getNearestOverflowAncestor(node2); 8005 const isBody = scrollableAncestor === ((_node$ownerDocument2 = node2.ownerDocument) == null ? void 0 : _node$ownerDocument2.body); 8006 const win = getWindow2(scrollableAncestor); 8007 if (isBody) { 8008 const frameElement = getFrameElement(win); 8009 return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []); 8010 } 8011 return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes)); 8012 } 8013 function getFrameElement(win) { 8014 return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null; 8015 } 8016 8017 // node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs 8018 function getCssDimensions(element) { 8019 const css6 = getComputedStyle2(element); 8020 let width = parseFloat(css6.width) || 0; 8021 let height = parseFloat(css6.height) || 0; 8022 const hasOffset = isHTMLElement(element); 8023 const offsetWidth = hasOffset ? element.offsetWidth : width; 8024 const offsetHeight = hasOffset ? element.offsetHeight : height; 8025 const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight; 8026 if (shouldFallback) { 8027 width = offsetWidth; 8028 height = offsetHeight; 8029 } 8030 return { 8031 width, 8032 height, 8033 $: shouldFallback 8034 }; 8035 } 8036 function unwrapElement(element) { 8037 return !isElement(element) ? element.contextElement : element; 8038 } 8039 function getScale(element) { 8040 const domElement = unwrapElement(element); 8041 if (!isHTMLElement(domElement)) { 8042 return createCoords(1); 8043 } 8044 const rect = domElement.getBoundingClientRect(); 8045 const { 8046 width, 8047 height, 8048 $: $3 8049 } = getCssDimensions(domElement); 8050 let x2 = ($3 ? round(rect.width) : rect.width) / width; 8051 let y3 = ($3 ? round(rect.height) : rect.height) / height; 8052 if (!x2 || !Number.isFinite(x2)) { 8053 x2 = 1; 8054 } 8055 if (!y3 || !Number.isFinite(y3)) { 8056 y3 = 1; 8057 } 8058 return { 8059 x: x2, 8060 y: y3 8061 }; 8062 } 8063 var noOffsets = /* @__PURE__ */ createCoords(0); 8064 function getVisualOffsets(element) { 8065 const win = getWindow2(element); 8066 if (!isWebKit() || !win.visualViewport) { 8067 return noOffsets; 8068 } 8069 return { 8070 x: win.visualViewport.offsetLeft, 8071 y: win.visualViewport.offsetTop 8072 }; 8073 } 8074 function shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) { 8075 if (isFixed === void 0) { 8076 isFixed = false; 8077 } 8078 if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow2(element)) { 8079 return false; 8080 } 8081 return isFixed; 8082 } 8083 function getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) { 8084 if (includeScale === void 0) { 8085 includeScale = false; 8086 } 8087 if (isFixedStrategy === void 0) { 8088 isFixedStrategy = false; 8089 } 8090 const clientRect = element.getBoundingClientRect(); 8091 const domElement = unwrapElement(element); 8092 let scale2 = createCoords(1); 8093 if (includeScale) { 8094 if (offsetParent) { 8095 if (isElement(offsetParent)) { 8096 scale2 = getScale(offsetParent); 8097 } 8098 } else { 8099 scale2 = getScale(element); 8100 } 8101 } 8102 const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0); 8103 let x2 = (clientRect.left + visualOffsets.x) / scale2.x; 8104 let y3 = (clientRect.top + visualOffsets.y) / scale2.y; 8105 let width = clientRect.width / scale2.x; 8106 let height = clientRect.height / scale2.y; 8107 if (domElement) { 8108 const win = getWindow2(domElement); 8109 const offsetWin = offsetParent && isElement(offsetParent) ? getWindow2(offsetParent) : offsetParent; 8110 let currentWin = win; 8111 let currentIFrame = getFrameElement(currentWin); 8112 while (currentIFrame && offsetParent && offsetWin !== currentWin) { 8113 const iframeScale = getScale(currentIFrame); 8114 const iframeRect = currentIFrame.getBoundingClientRect(); 8115 const css6 = getComputedStyle2(currentIFrame); 8116 const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css6.paddingLeft)) * iframeScale.x; 8117 const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css6.paddingTop)) * iframeScale.y; 8118 x2 *= iframeScale.x; 8119 y3 *= iframeScale.y; 8120 width *= iframeScale.x; 8121 height *= iframeScale.y; 8122 x2 += left; 8123 y3 += top; 8124 currentWin = getWindow2(currentIFrame); 8125 currentIFrame = getFrameElement(currentWin); 8126 } 8127 } 8128 return rectToClientRect({ 8129 width, 8130 height, 8131 x: x2, 8132 y: y3 8133 }); 8134 } 8135 function getWindowScrollBarX(element, rect) { 8136 const leftScroll = getNodeScroll(element).scrollLeft; 8137 if (!rect) { 8138 return getBoundingClientRect(getDocumentElement(element)).left + leftScroll; 8139 } 8140 return rect.left + leftScroll; 8141 } 8142 function getHTMLOffset(documentElement, scroll, ignoreScrollbarX) { 8143 if (ignoreScrollbarX === void 0) { 8144 ignoreScrollbarX = false; 8145 } 8146 const htmlRect = documentElement.getBoundingClientRect(); 8147 const x2 = htmlRect.left + scroll.scrollLeft - (ignoreScrollbarX ? 0 : ( 8148 // RTL <body> scrollbar. 8149 getWindowScrollBarX(documentElement, htmlRect) 8150 )); 8151 const y3 = htmlRect.top + scroll.scrollTop; 8152 return { 8153 x: x2, 8154 y: y3 8155 }; 8156 } 8157 function convertOffsetParentRelativeRectToViewportRelativeRect(_ref11) { 8158 let { 8159 elements: elements2, 8160 rect, 8161 offsetParent, 8162 strategy 8163 } = _ref11; 8164 const isFixed = strategy === "fixed"; 8165 const documentElement = getDocumentElement(offsetParent); 8166 const topLayer = elements2 ? isTopLayer(elements2.floating) : false; 8167 if (offsetParent === documentElement || topLayer && isFixed) { 8168 return rect; 8169 } 8170 let scroll = { 8171 scrollLeft: 0, 8172 scrollTop: 0 8173 }; 8174 let scale2 = createCoords(1); 8175 const offsets = createCoords(0); 8176 const isOffsetParentAnElement = isHTMLElement(offsetParent); 8177 if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { 8178 if (getNodeName(offsetParent) !== "body" || isOverflowElement(documentElement)) { 8179 scroll = getNodeScroll(offsetParent); 8180 } 8181 if (isHTMLElement(offsetParent)) { 8182 const offsetRect = getBoundingClientRect(offsetParent); 8183 scale2 = getScale(offsetParent); 8184 offsets.x = offsetRect.x + offsetParent.clientLeft; 8185 offsets.y = offsetRect.y + offsetParent.clientTop; 8186 } 8187 } 8188 const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll, true) : createCoords(0); 8189 return { 8190 width: rect.width * scale2.x, 8191 height: rect.height * scale2.y, 8192 x: rect.x * scale2.x - scroll.scrollLeft * scale2.x + offsets.x + htmlOffset.x, 8193 y: rect.y * scale2.y - scroll.scrollTop * scale2.y + offsets.y + htmlOffset.y 8194 }; 8195 } 8196 function getClientRects(element) { 8197 return Array.from(element.getClientRects()); 8198 } 8199 function getDocumentRect(element) { 8200 const html = getDocumentElement(element); 8201 const scroll = getNodeScroll(element); 8202 const body = element.ownerDocument.body; 8203 const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth); 8204 const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight); 8205 let x2 = -scroll.scrollLeft + getWindowScrollBarX(element); 8206 const y3 = -scroll.scrollTop; 8207 if (getComputedStyle2(body).direction === "rtl") { 8208 x2 += max(html.clientWidth, body.clientWidth) - width; 8209 } 8210 return { 8211 width, 8212 height, 8213 x: x2, 8214 y: y3 8215 }; 8216 } 8217 function getViewportRect(element, strategy) { 8218 const win = getWindow2(element); 8219 const html = getDocumentElement(element); 8220 const visualViewport = win.visualViewport; 8221 let width = html.clientWidth; 8222 let height = html.clientHeight; 8223 let x2 = 0; 8224 let y3 = 0; 8225 if (visualViewport) { 8226 width = visualViewport.width; 8227 height = visualViewport.height; 8228 const visualViewportBased = isWebKit(); 8229 if (!visualViewportBased || visualViewportBased && strategy === "fixed") { 8230 x2 = visualViewport.offsetLeft; 8231 y3 = visualViewport.offsetTop; 8232 } 8233 } 8234 return { 8235 width, 8236 height, 8237 x: x2, 8238 y: y3 8239 }; 8240 } 8241 var absoluteOrFixed = /* @__PURE__ */ new Set(["absolute", "fixed"]); 8242 function getInnerBoundingClientRect(element, strategy) { 8243 const clientRect = getBoundingClientRect(element, true, strategy === "fixed"); 8244 const top = clientRect.top + element.clientTop; 8245 const left = clientRect.left + element.clientLeft; 8246 const scale2 = isHTMLElement(element) ? getScale(element) : createCoords(1); 8247 const width = element.clientWidth * scale2.x; 8248 const height = element.clientHeight * scale2.y; 8249 const x2 = left * scale2.x; 8250 const y3 = top * scale2.y; 8251 return { 8252 width, 8253 height, 8254 x: x2, 8255 y: y3 8256 }; 8257 } 8258 function getClientRectFromClippingAncestor(element, clippingAncestor, strategy) { 8259 let rect; 8260 if (clippingAncestor === "viewport") { 8261 rect = getViewportRect(element, strategy); 8262 } else if (clippingAncestor === "document") { 8263 rect = getDocumentRect(getDocumentElement(element)); 8264 } else if (isElement(clippingAncestor)) { 8265 rect = getInnerBoundingClientRect(clippingAncestor, strategy); 8266 } else { 8267 const visualOffsets = getVisualOffsets(element); 8268 rect = { 8269 x: clippingAncestor.x - visualOffsets.x, 8270 y: clippingAncestor.y - visualOffsets.y, 8271 width: clippingAncestor.width, 8272 height: clippingAncestor.height 8273 }; 8274 } 8275 return rectToClientRect(rect); 8276 } 8277 function hasFixedPositionAncestor(element, stopNode) { 8278 const parentNode = getParentNode(element); 8279 if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) { 8280 return false; 8281 } 8282 return getComputedStyle2(parentNode).position === "fixed" || hasFixedPositionAncestor(parentNode, stopNode); 8283 } 8284 function getClippingElementAncestors(element, cache2) { 8285 const cachedResult = cache2.get(element); 8286 if (cachedResult) { 8287 return cachedResult; 8288 } 8289 let result = getOverflowAncestors(element, [], false).filter((el) => isElement(el) && getNodeName(el) !== "body"); 8290 let currentContainingBlockComputedStyle = null; 8291 const elementIsFixed = getComputedStyle2(element).position === "fixed"; 8292 let currentNode = elementIsFixed ? getParentNode(element) : element; 8293 while (isElement(currentNode) && !isLastTraversableNode(currentNode)) { 8294 const computedStyle = getComputedStyle2(currentNode); 8295 const currentNodeIsContaining = isContainingBlock(currentNode); 8296 if (!currentNodeIsContaining && computedStyle.position === "fixed") { 8297 currentContainingBlockComputedStyle = null; 8298 } 8299 const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === "static" && !!currentContainingBlockComputedStyle && absoluteOrFixed.has(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode); 8300 if (shouldDropCurrentNode) { 8301 result = result.filter((ancestor) => ancestor !== currentNode); 8302 } else { 8303 currentContainingBlockComputedStyle = computedStyle; 8304 } 8305 currentNode = getParentNode(currentNode); 8306 } 8307 cache2.set(element, result); 8308 return result; 8309 } 8310 function getClippingRect(_ref11) { 8311 let { 8312 element, 8313 boundary, 8314 rootBoundary, 8315 strategy 8316 } = _ref11; 8317 const elementClippingAncestors = boundary === "clippingAncestors" ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary); 8318 const clippingAncestors = [...elementClippingAncestors, rootBoundary]; 8319 const firstClippingAncestor = clippingAncestors[0]; 8320 const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => { 8321 const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy); 8322 accRect.top = max(rect.top, accRect.top); 8323 accRect.right = min(rect.right, accRect.right); 8324 accRect.bottom = min(rect.bottom, accRect.bottom); 8325 accRect.left = max(rect.left, accRect.left); 8326 return accRect; 8327 }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy)); 8328 return { 8329 width: clippingRect.right - clippingRect.left, 8330 height: clippingRect.bottom - clippingRect.top, 8331 x: clippingRect.left, 8332 y: clippingRect.top 8333 }; 8334 } 8335 function getDimensions(element) { 8336 const { 8337 width, 8338 height 8339 } = getCssDimensions(element); 8340 return { 8341 width, 8342 height 8343 }; 8344 } 8345 function getRectRelativeToOffsetParent(element, offsetParent, strategy) { 8346 const isOffsetParentAnElement = isHTMLElement(offsetParent); 8347 const documentElement = getDocumentElement(offsetParent); 8348 const isFixed = strategy === "fixed"; 8349 const rect = getBoundingClientRect(element, true, isFixed, offsetParent); 8350 let scroll = { 8351 scrollLeft: 0, 8352 scrollTop: 0 8353 }; 8354 const offsets = createCoords(0); 8355 function setLeftRTLScrollbarOffset() { 8356 offsets.x = getWindowScrollBarX(documentElement); 8357 } 8358 if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { 8359 if (getNodeName(offsetParent) !== "body" || isOverflowElement(documentElement)) { 8360 scroll = getNodeScroll(offsetParent); 8361 } 8362 if (isOffsetParentAnElement) { 8363 const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent); 8364 offsets.x = offsetRect.x + offsetParent.clientLeft; 8365 offsets.y = offsetRect.y + offsetParent.clientTop; 8366 } else if (documentElement) { 8367 setLeftRTLScrollbarOffset(); 8368 } 8369 } 8370 if (isFixed && !isOffsetParentAnElement && documentElement) { 8371 setLeftRTLScrollbarOffset(); 8372 } 8373 const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0); 8374 const x2 = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x; 8375 const y3 = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y; 8376 return { 8377 x: x2, 8378 y: y3, 8379 width: rect.width, 8380 height: rect.height 8381 }; 8382 } 8383 function isStaticPositioned(element) { 8384 return getComputedStyle2(element).position === "static"; 8385 } 8386 function getTrueOffsetParent(element, polyfill) { 8387 if (!isHTMLElement(element) || getComputedStyle2(element).position === "fixed") { 8388 return null; 8389 } 8390 if (polyfill) { 8391 return polyfill(element); 8392 } 8393 let rawOffsetParent = element.offsetParent; 8394 if (getDocumentElement(element) === rawOffsetParent) { 8395 rawOffsetParent = rawOffsetParent.ownerDocument.body; 8396 } 8397 return rawOffsetParent; 8398 } 8399 function getOffsetParent(element, polyfill) { 8400 const win = getWindow2(element); 8401 if (isTopLayer(element)) { 8402 return win; 8403 } 8404 if (!isHTMLElement(element)) { 8405 let svgOffsetParent = getParentNode(element); 8406 while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) { 8407 if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) { 8408 return svgOffsetParent; 8409 } 8410 svgOffsetParent = getParentNode(svgOffsetParent); 8411 } 8412 return win; 8413 } 8414 let offsetParent = getTrueOffsetParent(element, polyfill); 8415 while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) { 8416 offsetParent = getTrueOffsetParent(offsetParent, polyfill); 8417 } 8418 if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) { 8419 return win; 8420 } 8421 return offsetParent || getContainingBlock(element) || win; 8422 } 8423 var getElementRects = async function(data) { 8424 const getOffsetParentFn = this.getOffsetParent || getOffsetParent; 8425 const getDimensionsFn = this.getDimensions; 8426 const floatingDimensions = await getDimensionsFn(data.floating); 8427 return { 8428 reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy), 8429 floating: { 8430 x: 0, 8431 y: 0, 8432 width: floatingDimensions.width, 8433 height: floatingDimensions.height 8434 } 8435 }; 8436 }; 8437 function isRTL(element) { 8438 return getComputedStyle2(element).direction === "rtl"; 8439 } 8440 var platform = { 8441 convertOffsetParentRelativeRectToViewportRelativeRect, 8442 getDocumentElement, 8443 getClippingRect, 8444 getOffsetParent, 8445 getElementRects, 8446 getClientRects, 8447 getDimensions, 8448 getScale, 8449 isElement, 8450 isRTL 8451 }; 8452 function rectsAreEqual(a3, b3) { 8453 return a3.x === b3.x && a3.y === b3.y && a3.width === b3.width && a3.height === b3.height; 8454 } 8455 function observeMove(element, onMove) { 8456 let io = null; 8457 let timeoutId; 8458 const root = getDocumentElement(element); 8459 function cleanup() { 8460 var _io; 8461 clearTimeout(timeoutId); 8462 (_io = io) == null || _io.disconnect(); 8463 io = null; 8464 } 8465 function refresh(skip, threshold) { 8466 if (skip === void 0) { 8467 skip = false; 8468 } 8469 if (threshold === void 0) { 8470 threshold = 1; 8471 } 8472 cleanup(); 8473 const elementRectForRootMargin = element.getBoundingClientRect(); 8474 const { 8475 left, 8476 top, 8477 width, 8478 height 8479 } = elementRectForRootMargin; 8480 if (!skip) { 8481 onMove(); 8482 } 8483 if (!width || !height) { 8484 return; 8485 } 8486 const insetTop = floor(top); 8487 const insetRight = floor(root.clientWidth - (left + width)); 8488 const insetBottom = floor(root.clientHeight - (top + height)); 8489 const insetLeft = floor(left); 8490 const rootMargin = -insetTop + "px " + -insetRight + "px " + -insetBottom + "px " + -insetLeft + "px"; 8491 const options2 = { 8492 rootMargin, 8493 threshold: max(0, min(1, threshold)) || 1 8494 }; 8495 let isFirstUpdate = true; 8496 function handleObserve(entries) { 8497 const ratio = entries[0].intersectionRatio; 8498 if (ratio !== threshold) { 8499 if (!isFirstUpdate) { 8500 return refresh(); 8501 } 8502 if (!ratio) { 8503 timeoutId = setTimeout(() => { 8504 refresh(false, 1e-7); 8505 }, 1e3); 8506 } else { 8507 refresh(false, ratio); 8508 } 8509 } 8510 if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) { 8511 refresh(); 8512 } 8513 isFirstUpdate = false; 8514 } 8515 try { 8516 io = new IntersectionObserver(handleObserve, { 8517 ...options2, 8518 // Handle <iframe>s 8519 root: root.ownerDocument 8520 }); 8521 } catch (_e2) { 8522 io = new IntersectionObserver(handleObserve, options2); 8523 } 8524 io.observe(element); 8525 } 8526 refresh(true); 8527 return cleanup; 8528 } 8529 function autoUpdate(reference, floating, update, options2) { 8530 if (options2 === void 0) { 8531 options2 = {}; 8532 } 8533 const { 8534 ancestorScroll = true, 8535 ancestorResize = true, 8536 elementResize = typeof ResizeObserver === "function", 8537 layoutShift = typeof IntersectionObserver === "function", 8538 animationFrame = false 8539 } = options2; 8540 const referenceEl = unwrapElement(reference); 8541 const ancestors = ancestorScroll || ancestorResize ? [...referenceEl ? getOverflowAncestors(referenceEl) : [], ...getOverflowAncestors(floating)] : []; 8542 ancestors.forEach((ancestor) => { 8543 ancestorScroll && ancestor.addEventListener("scroll", update, { 8544 passive: true 8545 }); 8546 ancestorResize && ancestor.addEventListener("resize", update); 8547 }); 8548 const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null; 8549 let reobserveFrame = -1; 8550 let resizeObserver = null; 8551 if (elementResize) { 8552 resizeObserver = new ResizeObserver((_ref11) => { 8553 let [firstEntry] = _ref11; 8554 if (firstEntry && firstEntry.target === referenceEl && resizeObserver) { 8555 resizeObserver.unobserve(floating); 8556 cancelAnimationFrame(reobserveFrame); 8557 reobserveFrame = requestAnimationFrame(() => { 8558 var _resizeObserver; 8559 (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating); 8560 }); 8561 } 8562 update(); 8563 }); 8564 if (referenceEl && !animationFrame) { 8565 resizeObserver.observe(referenceEl); 8566 } 8567 resizeObserver.observe(floating); 8568 } 8569 let frameId; 8570 let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null; 8571 if (animationFrame) { 8572 frameLoop(); 8573 } 8574 function frameLoop() { 8575 const nextRefRect = getBoundingClientRect(reference); 8576 if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) { 8577 update(); 8578 } 8579 prevRefRect = nextRefRect; 8580 frameId = requestAnimationFrame(frameLoop); 8581 } 8582 update(); 8583 return () => { 8584 var _resizeObserver2; 8585 ancestors.forEach((ancestor) => { 8586 ancestorScroll && ancestor.removeEventListener("scroll", update); 8587 ancestorResize && ancestor.removeEventListener("resize", update); 8588 }); 8589 cleanupIo == null || cleanupIo(); 8590 (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect(); 8591 resizeObserver = null; 8592 if (animationFrame) { 8593 cancelAnimationFrame(frameId); 8594 } 8595 }; 8596 } 8597 var offset2 = offset; 8598 var shift2 = shift; 8599 var flip2 = flip; 8600 var size2 = size; 8601 var arrow2 = arrow; 8602 var limitShift2 = limitShift; 8603 var computePosition2 = (reference, floating, options2) => { 8604 const cache2 = /* @__PURE__ */ new Map(); 8605 const mergedOptions = { 8606 platform, 8607 ...options2 8608 }; 8609 const platformWithCache = { 8610 ...mergedOptions.platform, 8611 _c: cache2 8612 }; 8613 return computePosition(reference, floating, { 8614 ...mergedOptions, 8615 platform: platformWithCache 8616 }); 8617 }; 8618 8619 // node_modules/@ariakit/react-core/esm/__chunks/T6C2RYFI.js 8620 var import_react32 = __toESM(require_react(), 1); 8621 var import_jsx_runtime13 = __toESM(require_jsx_runtime(), 1); 8622 var TagName23 = "div"; 8623 function createDOMRect(x2 = 0, y3 = 0, width = 0, height = 0) { 8624 if (typeof DOMRect === "function") { 8625 return new DOMRect(x2, y3, width, height); 8626 } 8627 const rect = { 8628 x: x2, 8629 y: y3, 8630 width, 8631 height, 8632 top: y3, 8633 right: x2 + width, 8634 bottom: y3 + height, 8635 left: x2 8636 }; 8637 return __spreadProps(__spreadValues({}, rect), { toJSON: () => rect }); 8638 } 8639 function getDOMRect(anchorRect) { 8640 if (!anchorRect) return createDOMRect(); 8641 const { x: x2, y: y3, width, height } = anchorRect; 8642 return createDOMRect(x2, y3, width, height); 8643 } 8644 function getAnchorElement(anchorElement, getAnchorRect) { 8645 const contextElement = anchorElement || void 0; 8646 return { 8647 contextElement, 8648 getBoundingClientRect: () => { 8649 const anchor = anchorElement; 8650 const anchorRect = getAnchorRect == null ? void 0 : getAnchorRect(anchor); 8651 if (anchorRect || !anchor) { 8652 return getDOMRect(anchorRect); 8653 } 8654 return anchor.getBoundingClientRect(); 8655 } 8656 }; 8657 } 8658 function isValidPlacement(flip22) { 8659 return /^(?:top|bottom|left|right)(?:-(?:start|end))?$/.test(flip22); 8660 } 8661 function roundByDPR(value) { 8662 const dpr = window.devicePixelRatio || 1; 8663 return Math.round(value * dpr) / dpr; 8664 } 8665 function getOffsetMiddleware(arrowElement, props) { 8666 return offset2(({ placement }) => { 8667 var _a; 8668 const arrowOffset = ((arrowElement == null ? void 0 : arrowElement.clientHeight) || 0) / 2; 8669 const finalGutter = typeof props.gutter === "number" ? props.gutter + arrowOffset : (_a = props.gutter) != null ? _a : arrowOffset; 8670 const hasAlignment = !!placement.split("-")[1]; 8671 return { 8672 crossAxis: !hasAlignment ? props.shift : void 0, 8673 mainAxis: finalGutter, 8674 alignmentAxis: props.shift 8675 }; 8676 }); 8677 } 8678 function getFlipMiddleware(props) { 8679 if (props.flip === false) return; 8680 const fallbackPlacements = typeof props.flip === "string" ? props.flip.split(" ") : void 0; 8681 invariant( 8682 !fallbackPlacements || fallbackPlacements.every(isValidPlacement), 8683 "`flip` expects a spaced-delimited list of placements" 8684 ); 8685 return flip2({ 8686 padding: props.overflowPadding, 8687 fallbackPlacements 8688 }); 8689 } 8690 function getShiftMiddleware(props) { 8691 if (!props.slide && !props.overlap) return; 8692 return shift2({ 8693 mainAxis: props.slide, 8694 crossAxis: props.overlap, 8695 padding: props.overflowPadding, 8696 limiter: limitShift2() 8697 }); 8698 } 8699 function getSizeMiddleware(props) { 8700 return size2({ 8701 padding: props.overflowPadding, 8702 apply({ elements: elements2, availableWidth, availableHeight, rects }) { 8703 const wrapper3 = elements2.floating; 8704 const referenceWidth = Math.round(rects.reference.width); 8705 availableWidth = Math.floor(availableWidth); 8706 availableHeight = Math.floor(availableHeight); 8707 wrapper3.style.setProperty( 8708 "--popover-anchor-width", 8709 `$referenceWidth}px` 8710 ); 8711 wrapper3.style.setProperty( 8712 "--popover-available-width", 8713 `$availableWidth}px` 8714 ); 8715 wrapper3.style.setProperty( 8716 "--popover-available-height", 8717 `$availableHeight}px` 8718 ); 8719 if (props.sameWidth) { 8720 wrapper3.style.width = `$referenceWidth}px`; 8721 } 8722 if (props.fitViewport) { 8723 wrapper3.style.maxWidth = `$availableWidth}px`; 8724 wrapper3.style.maxHeight = `$availableHeight}px`; 8725 } 8726 } 8727 }); 8728 } 8729 function getArrowMiddleware(arrowElement, props) { 8730 if (!arrowElement) return; 8731 return arrow2({ 8732 element: arrowElement, 8733 padding: props.arrowPadding 8734 }); 8735 } 8736 var usePopover = createHook( 8737 function usePopover2(_a) { 8738 var _b = _a, { 8739 store, 8740 modal = false, 8741 portal = !!modal, 8742 preserveTabOrder = true, 8743 autoFocusOnShow = true, 8744 wrapperProps, 8745 fixed = false, 8746 flip: flip22 = true, 8747 shift: shift22 = 0, 8748 slide = true, 8749 overlap = false, 8750 sameWidth = false, 8751 fitViewport = false, 8752 gutter, 8753 arrowPadding = 4, 8754 overflowPadding = 8, 8755 getAnchorRect, 8756 updatePosition 8757 } = _b, props = __objRest(_b, [ 8758 "store", 8759 "modal", 8760 "portal", 8761 "preserveTabOrder", 8762 "autoFocusOnShow", 8763 "wrapperProps", 8764 "fixed", 8765 "flip", 8766 "shift", 8767 "slide", 8768 "overlap", 8769 "sameWidth", 8770 "fitViewport", 8771 "gutter", 8772 "arrowPadding", 8773 "overflowPadding", 8774 "getAnchorRect", 8775 "updatePosition" 8776 ]); 8777 const context = usePopoverProviderContext(); 8778 store = store || context; 8779 invariant( 8780 store, 8781 "Popover must receive a `store` prop or be wrapped in a PopoverProvider component." 8782 ); 8783 const arrowElement = store.useState("arrowElement"); 8784 const anchorElement = store.useState("anchorElement"); 8785 const disclosureElement = store.useState("disclosureElement"); 8786 const popoverElement = store.useState("popoverElement"); 8787 const contentElement = store.useState("contentElement"); 8788 const placement = store.useState("placement"); 8789 const mounted = store.useState("mounted"); 8790 const rendered = store.useState("rendered"); 8791 const defaultArrowElementRef = (0, import_react32.useRef)(null); 8792 const [positioned, setPositioned] = (0, import_react32.useState)(false); 8793 const { portalRef, domReady } = usePortalRef(portal, props.portalRef); 8794 const getAnchorRectProp = useEvent(getAnchorRect); 8795 const updatePositionProp = useEvent(updatePosition); 8796 const hasCustomUpdatePosition = !!updatePosition; 8797 useSafeLayoutEffect(() => { 8798 if (!(popoverElement == null ? void 0 : popoverElement.isConnected)) return; 8799 popoverElement.style.setProperty( 8800 "--popover-overflow-padding", 8801 `$overflowPadding}px` 8802 ); 8803 const anchor = getAnchorElement(anchorElement, getAnchorRectProp); 8804 const updatePosition2 = async () => { 8805 if (!mounted) return; 8806 if (!arrowElement) { 8807 defaultArrowElementRef.current = defaultArrowElementRef.current || document.createElement("div"); 8808 } 8809 const arrow22 = arrowElement || defaultArrowElementRef.current; 8810 const middleware2 = [ 8811 getOffsetMiddleware(arrow22, { gutter, shift: shift22 }), 8812 getFlipMiddleware({ flip: flip22, overflowPadding }), 8813 getShiftMiddleware({ slide, shift: shift22, overlap, overflowPadding }), 8814 getArrowMiddleware(arrow22, { arrowPadding }), 8815 getSizeMiddleware({ 8816 sameWidth, 8817 fitViewport, 8818 overflowPadding 8819 }) 8820 ]; 8821 const pos = await computePosition2(anchor, popoverElement, { 8822 placement, 8823 strategy: fixed ? "fixed" : "absolute", 8824 middleware: middleware2 8825 }); 8826 store == null ? void 0 : store.setState("currentPlacement", pos.placement); 8827 setPositioned(true); 8828 const x2 = roundByDPR(pos.x); 8829 const y3 = roundByDPR(pos.y); 8830 Object.assign(popoverElement.style, { 8831 top: "0", 8832 left: "0", 8833 transform: `translate3d($x2}px,$y3}px,0)` 8834 }); 8835 if (arrow22 && pos.middlewareData.arrow) { 8836 const { x: arrowX, y: arrowY } = pos.middlewareData.arrow; 8837 const side = pos.placement.split("-")[0]; 8838 const centerX = arrow22.clientWidth / 2; 8839 const centerY = arrow22.clientHeight / 2; 8840 const originX = arrowX != null ? arrowX + centerX : -centerX; 8841 const originY = arrowY != null ? arrowY + centerY : -centerY; 8842 popoverElement.style.setProperty( 8843 "--popover-transform-origin", 8844 { 8845 top: `$originX}px calc(100% + $centerY}px)`, 8846 bottom: `$originX}px ${-centerY}px`, 8847 left: `calc(100% + $centerX}px) $originY}px`, 8848 right: `${-centerX}px $originY}px` 8849 }[side] 8850 ); 8851 Object.assign(arrow22.style, { 8852 left: arrowX != null ? `$arrowX}px` : "", 8853 top: arrowY != null ? `$arrowY}px` : "", 8854 [side]: "100%" 8855 }); 8856 } 8857 }; 8858 const update = async () => { 8859 if (hasCustomUpdatePosition) { 8860 await updatePositionProp({ updatePosition: updatePosition2 }); 8861 setPositioned(true); 8862 } else { 8863 await updatePosition2(); 8864 } 8865 }; 8866 const cancelAutoUpdate = autoUpdate(anchor, popoverElement, update, { 8867 // JSDOM doesn't support ResizeObserver 8868 elementResize: typeof ResizeObserver === "function" 8869 }); 8870 return () => { 8871 setPositioned(false); 8872 cancelAutoUpdate(); 8873 }; 8874 }, [ 8875 store, 8876 rendered, 8877 popoverElement, 8878 arrowElement, 8879 anchorElement, 8880 popoverElement, 8881 placement, 8882 mounted, 8883 domReady, 8884 fixed, 8885 flip22, 8886 shift22, 8887 slide, 8888 overlap, 8889 sameWidth, 8890 fitViewport, 8891 gutter, 8892 arrowPadding, 8893 overflowPadding, 8894 getAnchorRectProp, 8895 hasCustomUpdatePosition, 8896 updatePositionProp 8897 ]); 8898 useSafeLayoutEffect(() => { 8899 if (!mounted) return; 8900 if (!domReady) return; 8901 if (!(popoverElement == null ? void 0 : popoverElement.isConnected)) return; 8902 if (!(contentElement == null ? void 0 : contentElement.isConnected)) return; 8903 const applyZIndex = () => { 8904 popoverElement.style.zIndex = getComputedStyle(contentElement).zIndex; 8905 }; 8906 applyZIndex(); 8907 let raf = requestAnimationFrame(() => { 8908 raf = requestAnimationFrame(applyZIndex); 8909 }); 8910 return () => cancelAnimationFrame(raf); 8911 }, [mounted, domReady, popoverElement, contentElement]); 8912 const position2 = fixed ? "fixed" : "absolute"; 8913 props = useWrapElement( 8914 props, 8915 (element) => /* @__PURE__ */ (0, import_jsx_runtime13.jsx)( 8916 "div", 8917 __spreadProps(__spreadValues({}, wrapperProps), { 8918 style: __spreadValues({ 8919 // https://floating-ui.com/docs/computeposition#initial-layout 8920 position: position2, 8921 top: 0, 8922 left: 0, 8923 width: "max-content" 8924 }, wrapperProps == null ? void 0 : wrapperProps.style), 8925 ref: store == null ? void 0 : store.setPopoverElement, 8926 children: element 8927 }) 8928 ), 8929 [store, position2, wrapperProps] 8930 ); 8931 props = useWrapElement( 8932 props, 8933 (element) => /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(PopoverScopedContextProvider, { value: store, children: element }), 8934 [store] 8935 ); 8936 props = __spreadProps(__spreadValues({ 8937 // data-placing is not part of the public API. We're setting this here so 8938 // we can wait for the popover to be positioned before other components 8939 // move focus into it. For example, this attribute is observed by the 8940 // Combobox component with the autoSelect behavior. 8941 "data-placing": !positioned || void 0 8942 }, props), { 8943 style: __spreadValues({ 8944 position: "relative" 8945 }, props.style) 8946 }); 8947 props = useDialog(__spreadProps(__spreadValues({ 8948 store, 8949 modal, 8950 portal, 8951 preserveTabOrder, 8952 preserveTabOrderAnchor: disclosureElement || anchorElement, 8953 autoFocusOnShow: positioned && autoFocusOnShow 8954 }, props), { 8955 portalRef 8956 })); 8957 return props; 8958 } 8959 ); 8960 var Popover = createDialogComponent( 8961 forwardRef2(function Popover2(props) { 8962 const htmlProps = usePopover(props); 8963 return createElement(TagName23, htmlProps); 8964 }), 8965 usePopoverProviderContext 8966 ); 8967 8968 // node_modules/@ariakit/react-core/esm/__chunks/J2LQO3EC.js 8969 var import_react33 = __toESM(require_react(), 1); 8970 var import_jsx_runtime14 = __toESM(require_jsx_runtime(), 1); 8971 var TagName24 = "div"; 8972 var useCompositeRow = createHook( 8973 function useCompositeRow2(_a) { 8974 var _b = _a, { 8975 store, 8976 "aria-setsize": ariaSetSize, 8977 "aria-posinset": ariaPosInSet 8978 } = _b, props = __objRest(_b, [ 8979 "store", 8980 "aria-setsize", 8981 "aria-posinset" 8982 ]); 8983 const context = useCompositeContext(); 8984 store = store || context; 8985 invariant( 8986 store, 8987 "CompositeRow must be wrapped in a Composite component." 8988 ); 8989 const id3 = useId(props.id); 8990 const baseElement = store.useState( 8991 (state) => state.baseElement || void 0 8992 ); 8993 const providerValue = (0, import_react33.useMemo)( 8994 () => ({ id: id3, baseElement, ariaSetSize, ariaPosInSet }), 8995 [id3, baseElement, ariaSetSize, ariaPosInSet] 8996 ); 8997 props = useWrapElement( 8998 props, 8999 (element) => /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(CompositeRowContext.Provider, { value: providerValue, children: element }), 9000 [providerValue] 9001 ); 9002 props = __spreadValues({ id: id3 }, props); 9003 return removeUndefinedValues(props); 9004 } 9005 ); 9006 var CompositeRow = forwardRef2(function CompositeRow2(props) { 9007 const htmlProps = useCompositeRow(props); 9008 return createElement(TagName24, htmlProps); 9009 }); 9010 9011 // node_modules/@ariakit/react-core/esm/__chunks/A3CZKICO.js 9012 var TagName25 = "hr"; 9013 var useSeparator = createHook( 9014 function useSeparator2(_a) { 9015 var _b = _a, { orientation = "horizontal" } = _b, props = __objRest(_b, ["orientation"]); 9016 props = __spreadValues({ 9017 role: "separator", 9018 "aria-orientation": orientation 9019 }, props); 9020 return props; 9021 } 9022 ); 9023 var Separator = forwardRef2(function Separator2(props) { 9024 const htmlProps = useSeparator(props); 9025 return createElement(TagName25, htmlProps); 9026 }); 9027 9028 // node_modules/@ariakit/react-core/esm/__chunks/TP7N7UIH.js 9029 var TagName26 = "hr"; 9030 var useCompositeSeparator = createHook(function useCompositeSeparator2(_a) { 9031 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 9032 const context = useCompositeContext(); 9033 store = store || context; 9034 invariant( 9035 store, 9036 "CompositeSeparator must be wrapped in a Composite component." 9037 ); 9038 const orientation = store.useState( 9039 (state) => state.orientation === "horizontal" ? "vertical" : "horizontal" 9040 ); 9041 props = useSeparator(__spreadProps(__spreadValues({}, props), { orientation })); 9042 return props; 9043 }); 9044 var CompositeSeparator = forwardRef2(function CompositeSeparator2(props) { 9045 const htmlProps = useCompositeSeparator(props); 9046 return createElement(TagName26, htmlProps); 9047 }); 9048 9049 // node_modules/@ariakit/core/esm/checkbox/checkbox-store.js 9050 function createCheckboxStore(props = {}) { 9051 var _a; 9052 throwOnConflictingProps(props, props.store); 9053 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 9054 const initialState = { 9055 value: defaultValue( 9056 props.value, 9057 syncState == null ? void 0 : syncState.value, 9058 props.defaultValue, 9059 false 9060 ) 9061 }; 9062 const checkbox = createStore(initialState, props.store); 9063 return __spreadProps2(__spreadValues2({}, checkbox), { 9064 setValue: (value) => checkbox.setState("value", value) 9065 }); 9066 } 9067 9068 // node_modules/@ariakit/react-core/esm/__chunks/HAVBGUA3.js 9069 function useCheckboxStoreProps(store, update, props) { 9070 useUpdateEffect(update, [props.store]); 9071 useStoreProps(store, props, "value", "setValue"); 9072 return store; 9073 } 9074 function useCheckboxStore(props = {}) { 9075 const [store, update] = useStore(createCheckboxStore, props); 9076 return useCheckboxStoreProps(store, update, props); 9077 } 9078 9079 // node_modules/@ariakit/react-core/esm/__chunks/RNCDFVMF.js 9080 var ctx7 = createStoreContext(); 9081 var useCheckboxContext = ctx7.useContext; 9082 var useCheckboxScopedContext = ctx7.useScopedContext; 9083 var useCheckboxProviderContext = ctx7.useProviderContext; 9084 var CheckboxContextProvider = ctx7.ContextProvider; 9085 var CheckboxScopedContextProvider = ctx7.ScopedContextProvider; 9086 9087 // node_modules/@ariakit/react-core/esm/__chunks/ASMQKSDT.js 9088 var import_react34 = __toESM(require_react(), 1); 9089 var import_jsx_runtime15 = __toESM(require_jsx_runtime(), 1); 9090 var TagName27 = "input"; 9091 function setMixed(element, mixed) { 9092 if (mixed) { 9093 element.indeterminate = true; 9094 } else if (element.indeterminate) { 9095 element.indeterminate = false; 9096 } 9097 } 9098 function isNativeCheckbox(tagName, type) { 9099 return tagName === "input" && (!type || type === "checkbox"); 9100 } 9101 function getPrimitiveValue(value) { 9102 if (Array.isArray(value)) { 9103 return value.toString(); 9104 } 9105 return value; 9106 } 9107 var useCheckbox = createHook( 9108 function useCheckbox2(_a) { 9109 var _b = _a, { 9110 store, 9111 name, 9112 value: valueProp, 9113 checked: checkedProp, 9114 defaultChecked 9115 } = _b, props = __objRest(_b, [ 9116 "store", 9117 "name", 9118 "value", 9119 "checked", 9120 "defaultChecked" 9121 ]); 9122 const context = useCheckboxContext(); 9123 store = store || context; 9124 const [_checked, setChecked] = (0, import_react34.useState)(defaultChecked != null ? defaultChecked : false); 9125 const checked = useStoreState(store, (state) => { 9126 if (checkedProp !== void 0) return checkedProp; 9127 if ((state == null ? void 0 : state.value) === void 0) return _checked; 9128 if (valueProp != null) { 9129 if (Array.isArray(state.value)) { 9130 const primitiveValue = getPrimitiveValue(valueProp); 9131 return state.value.includes(primitiveValue); 9132 } 9133 return state.value === valueProp; 9134 } 9135 if (Array.isArray(state.value)) return false; 9136 if (typeof state.value === "boolean") return state.value; 9137 return false; 9138 }); 9139 const ref = (0, import_react34.useRef)(null); 9140 const tagName = useTagName(ref, TagName27); 9141 const nativeCheckbox = isNativeCheckbox(tagName, props.type); 9142 const mixed = checked ? checked === "mixed" : void 0; 9143 const isChecked = checked === "mixed" ? false : checked; 9144 const disabled = disabledFromProps(props); 9145 const [propertyUpdated, schedulePropertyUpdate] = useForceUpdate(); 9146 (0, import_react34.useEffect)(() => { 9147 const element = ref.current; 9148 if (!element) return; 9149 setMixed(element, mixed); 9150 if (nativeCheckbox) return; 9151 element.checked = isChecked; 9152 if (name !== void 0) { 9153 element.name = name; 9154 } 9155 if (valueProp !== void 0) { 9156 element.value = `$valueProp}`; 9157 } 9158 }, [propertyUpdated, mixed, nativeCheckbox, isChecked, name, valueProp]); 9159 const onChangeProp = props.onChange; 9160 const onChange = useEvent((event) => { 9161 if (disabled) { 9162 event.stopPropagation(); 9163 event.preventDefault(); 9164 return; 9165 } 9166 setMixed(event.currentTarget, mixed); 9167 if (!nativeCheckbox) { 9168 event.currentTarget.checked = !event.currentTarget.checked; 9169 schedulePropertyUpdate(); 9170 } 9171 onChangeProp == null ? void 0 : onChangeProp(event); 9172 if (event.defaultPrevented) return; 9173 const elementChecked = event.currentTarget.checked; 9174 setChecked(elementChecked); 9175 store == null ? void 0 : store.setValue((prevValue) => { 9176 if (valueProp == null) return elementChecked; 9177 const primitiveValue = getPrimitiveValue(valueProp); 9178 if (!Array.isArray(prevValue)) { 9179 return prevValue === primitiveValue ? false : primitiveValue; 9180 } 9181 if (elementChecked) { 9182 if (prevValue.includes(primitiveValue)) { 9183 return prevValue; 9184 } 9185 return [...prevValue, primitiveValue]; 9186 } 9187 return prevValue.filter((v3) => v3 !== primitiveValue); 9188 }); 9189 }); 9190 const onClickProp = props.onClick; 9191 const onClick = useEvent((event) => { 9192 onClickProp == null ? void 0 : onClickProp(event); 9193 if (event.defaultPrevented) return; 9194 if (nativeCheckbox) return; 9195 onChange(event); 9196 }); 9197 props = useWrapElement( 9198 props, 9199 (element) => /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(CheckboxCheckedContext.Provider, { value: isChecked, children: element }), 9200 [isChecked] 9201 ); 9202 props = __spreadProps(__spreadValues({ 9203 role: !nativeCheckbox ? "checkbox" : void 0, 9204 type: nativeCheckbox ? "checkbox" : void 0, 9205 "aria-checked": checked 9206 }, props), { 9207 ref: useMergeRefs(ref, props.ref), 9208 onChange, 9209 onClick 9210 }); 9211 props = useCommand(__spreadValues({ clickOnEnter: !nativeCheckbox }, props)); 9212 return removeUndefinedValues(__spreadValues({ 9213 name: nativeCheckbox ? name : void 0, 9214 value: nativeCheckbox ? valueProp : void 0, 9215 checked: isChecked 9216 }, props)); 9217 } 9218 ); 9219 var Checkbox = forwardRef2(function Checkbox2(props) { 9220 const htmlProps = useCheckbox(props); 9221 return createElement(TagName27, htmlProps); 9222 }); 9223 9224 // node_modules/@ariakit/react-core/esm/__chunks/UVUMR3WP.js 9225 var ctx8 = createStoreContext( 9226 [CompositeContextProvider], 9227 [CompositeScopedContextProvider] 9228 ); 9229 var useRadioContext = ctx8.useContext; 9230 var useRadioScopedContext = ctx8.useScopedContext; 9231 var useRadioProviderContext = ctx8.useProviderContext; 9232 var RadioContextProvider = ctx8.ContextProvider; 9233 var RadioScopedContextProvider = ctx8.ScopedContextProvider; 9234 9235 // node_modules/@ariakit/react-core/esm/__chunks/NLEBE274.js 9236 var import_react35 = __toESM(require_react(), 1); 9237 var TagName28 = "input"; 9238 function getIsChecked(value, storeValue) { 9239 if (storeValue === void 0) return; 9240 if (value != null && storeValue != null) { 9241 return storeValue === value; 9242 } 9243 return !!storeValue; 9244 } 9245 function isNativeRadio(tagName, type) { 9246 return tagName === "input" && (!type || type === "radio"); 9247 } 9248 var useRadio = createHook(function useRadio2(_a) { 9249 var _b = _a, { 9250 store, 9251 name, 9252 value, 9253 checked 9254 } = _b, props = __objRest(_b, [ 9255 "store", 9256 "name", 9257 "value", 9258 "checked" 9259 ]); 9260 const context = useRadioContext(); 9261 store = store || context; 9262 const id3 = useId(props.id); 9263 const ref = (0, import_react35.useRef)(null); 9264 const isChecked = useStoreState( 9265 store, 9266 (state) => checked != null ? checked : getIsChecked(value, state == null ? void 0 : state.value) 9267 ); 9268 (0, import_react35.useEffect)(() => { 9269 if (!id3) return; 9270 if (!isChecked) return; 9271 const isActiveItem = (store == null ? void 0 : store.getState().activeId) === id3; 9272 if (isActiveItem) return; 9273 store == null ? void 0 : store.setActiveId(id3); 9274 }, [store, isChecked, id3]); 9275 const onChangeProp = props.onChange; 9276 const tagName = useTagName(ref, TagName28); 9277 const nativeRadio = isNativeRadio(tagName, props.type); 9278 const disabled = disabledFromProps(props); 9279 const [propertyUpdated, schedulePropertyUpdate] = useForceUpdate(); 9280 (0, import_react35.useEffect)(() => { 9281 const element = ref.current; 9282 if (!element) return; 9283 if (nativeRadio) return; 9284 if (isChecked !== void 0) { 9285 element.checked = isChecked; 9286 } 9287 if (name !== void 0) { 9288 element.name = name; 9289 } 9290 if (value !== void 0) { 9291 element.value = `$value}`; 9292 } 9293 }, [propertyUpdated, nativeRadio, isChecked, name, value]); 9294 const onChange = useEvent((event) => { 9295 if (disabled) { 9296 event.preventDefault(); 9297 event.stopPropagation(); 9298 return; 9299 } 9300 if ((store == null ? void 0 : store.getState().value) === value) return; 9301 if (!nativeRadio) { 9302 event.currentTarget.checked = true; 9303 schedulePropertyUpdate(); 9304 } 9305 onChangeProp == null ? void 0 : onChangeProp(event); 9306 if (event.defaultPrevented) return; 9307 store == null ? void 0 : store.setValue(value); 9308 }); 9309 const onClickProp = props.onClick; 9310 const onClick = useEvent((event) => { 9311 onClickProp == null ? void 0 : onClickProp(event); 9312 if (event.defaultPrevented) return; 9313 if (nativeRadio) return; 9314 onChange(event); 9315 }); 9316 const onFocusProp = props.onFocus; 9317 const onFocus = useEvent((event) => { 9318 onFocusProp == null ? void 0 : onFocusProp(event); 9319 if (event.defaultPrevented) return; 9320 if (!nativeRadio) return; 9321 if (!store) return; 9322 const { moves, activeId } = store.getState(); 9323 if (!moves) return; 9324 if (id3 && activeId !== id3) return; 9325 onChange(event); 9326 }); 9327 props = __spreadProps(__spreadValues({ 9328 id: id3, 9329 role: !nativeRadio ? "radio" : void 0, 9330 type: nativeRadio ? "radio" : void 0, 9331 "aria-checked": isChecked 9332 }, props), { 9333 ref: useMergeRefs(ref, props.ref), 9334 onChange, 9335 onClick, 9336 onFocus 9337 }); 9338 props = useCompositeItem(__spreadValues({ 9339 store, 9340 clickOnEnter: !nativeRadio 9341 }, props)); 9342 return removeUndefinedValues(__spreadValues({ 9343 name: nativeRadio ? name : void 0, 9344 value: nativeRadio ? value : void 0, 9345 checked: isChecked 9346 }, props)); 9347 }); 9348 var Radio = memo2( 9349 forwardRef2(function Radio2(props) { 9350 const htmlProps = useRadio(props); 9351 return createElement(TagName28, htmlProps); 9352 }) 9353 ); 9354 9355 // node_modules/@ariakit/react-core/esm/__chunks/T7VMP3TM.js 9356 var import_react36 = __toESM(require_react(), 1); 9357 var TagName29 = "div"; 9358 var chars = ""; 9359 function clearChars() { 9360 chars = ""; 9361 } 9362 function isValidTypeaheadEvent(event) { 9363 const target = event.target; 9364 if (target && isTextField(target)) return false; 9365 if (event.key === " " && chars.length) return true; 9366 return event.key.length === 1 && !event.ctrlKey && !event.altKey && !event.metaKey && /^[\p{Letter}\p{Number}]$/u.test(event.key); 9367 } 9368 function isSelfTargetOrItem(event, items) { 9369 if (isSelfTarget(event)) return true; 9370 const target = event.target; 9371 if (!target) return false; 9372 const isItem2 = items.some((item2) => item2.element === target); 9373 return isItem2; 9374 } 9375 function getEnabledItems2(items) { 9376 return items.filter((item2) => !item2.disabled); 9377 } 9378 function itemTextStartsWith(item2, text) { 9379 var _a; 9380 const itemText = ((_a = item2.element) == null ? void 0 : _a.textContent) || item2.children || // The composite item object itself doesn't include a value property, but 9381 // other components like Select do. Since CompositeTypeahead is a generic 9382 // component that can be used with those as well, we also consider the value 9383 // property as a fallback for the typeahead text content. 9384 "value" in item2 && item2.value; 9385 if (!itemText) return false; 9386 return normalizeString(itemText).trim().toLowerCase().startsWith(text.toLowerCase()); 9387 } 9388 function getSameInitialItems(items, char2, activeId) { 9389 if (!activeId) return items; 9390 const activeItem = items.find((item2) => item2.id === activeId); 9391 if (!activeItem) return items; 9392 if (!itemTextStartsWith(activeItem, char2)) return items; 9393 if (chars !== char2 && itemTextStartsWith(activeItem, chars)) return items; 9394 chars = char2; 9395 return flipItems2( 9396 items.filter((item2) => itemTextStartsWith(item2, chars)), 9397 activeId 9398 ).filter((item2) => item2.id !== activeId); 9399 } 9400 var useCompositeTypeahead = createHook(function useCompositeTypeahead2(_a) { 9401 var _b = _a, { store, typeahead = true } = _b, props = __objRest(_b, ["store", "typeahead"]); 9402 const context = useCompositeContext(); 9403 store = store || context; 9404 invariant( 9405 store, 9406 "CompositeTypeahead must be a Composite component" 9407 ); 9408 const onKeyDownCaptureProp = props.onKeyDownCapture; 9409 const cleanupTimeoutRef = (0, import_react36.useRef)(0); 9410 const onKeyDownCapture = useEvent((event) => { 9411 onKeyDownCaptureProp == null ? void 0 : onKeyDownCaptureProp(event); 9412 if (event.defaultPrevented) return; 9413 if (!typeahead) return; 9414 if (!store) return; 9415 if (!isValidTypeaheadEvent(event)) { 9416 return clearChars(); 9417 } 9418 const { renderedItems, items, activeId, id: id3 } = store.getState(); 9419 let enabledItems = getEnabledItems2( 9420 items.length > renderedItems.length ? items : renderedItems 9421 ); 9422 const document2 = getDocument(event.currentTarget); 9423 const selector2 = `[data-offscreen-id="$id3}"]`; 9424 const offscreenItems = document2.querySelectorAll(selector2); 9425 for (const element of offscreenItems) { 9426 const disabled = element.ariaDisabled === "true" || "disabled" in element && !!element.disabled; 9427 enabledItems.push({ id: element.id, element, disabled }); 9428 } 9429 if (offscreenItems.length) { 9430 enabledItems = sortBasedOnDOMPosition(enabledItems, (i3) => i3.element); 9431 } 9432 if (!isSelfTargetOrItem(event, enabledItems)) return clearChars(); 9433 event.preventDefault(); 9434 window.clearTimeout(cleanupTimeoutRef.current); 9435 cleanupTimeoutRef.current = window.setTimeout(() => { 9436 chars = ""; 9437 }, 500); 9438 const char2 = event.key.toLowerCase(); 9439 chars += char2; 9440 enabledItems = getSameInitialItems(enabledItems, char2, activeId); 9441 const item2 = enabledItems.find((item22) => itemTextStartsWith(item22, chars)); 9442 if (item2) { 9443 store.move(item2.id); 9444 } else { 9445 clearChars(); 9446 } 9447 }); 9448 props = __spreadProps(__spreadValues({}, props), { 9449 onKeyDownCapture 9450 }); 9451 return removeUndefinedValues(props); 9452 }); 9453 var CompositeTypeahead = forwardRef2(function CompositeTypeahead2(props) { 9454 const htmlProps = useCompositeTypeahead(props); 9455 return createElement(TagName29, htmlProps); 9456 }); 9457 9458 // node_modules/@ariakit/core/esm/radio/radio-store.js 9459 function createRadioStore(_a = {}) { 9460 var props = __objRest2(_a, []); 9461 var _a2; 9462 const syncState = (_a2 = props.store) == null ? void 0 : _a2.getState(); 9463 const composite = createCompositeStore(__spreadProps2(__spreadValues2({}, props), { 9464 focusLoop: defaultValue(props.focusLoop, syncState == null ? void 0 : syncState.focusLoop, true) 9465 })); 9466 const initialState = __spreadProps2(__spreadValues2({}, composite.getState()), { 9467 value: defaultValue( 9468 props.value, 9469 syncState == null ? void 0 : syncState.value, 9470 props.defaultValue, 9471 null 9472 ) 9473 }); 9474 const radio = createStore(initialState, composite, props.store); 9475 return __spreadProps2(__spreadValues2(__spreadValues2({}, composite), radio), { 9476 setValue: (value) => radio.setState("value", value) 9477 }); 9478 } 9479 9480 // node_modules/@ariakit/react-core/esm/__chunks/4BXJGRNH.js 9481 function useRadioStoreProps(store, update, props) { 9482 store = useCompositeStoreProps(store, update, props); 9483 useStoreProps(store, props, "value", "setValue"); 9484 return store; 9485 } 9486 function useRadioStore(props = {}) { 9487 const [store, update] = useStore(createRadioStore, props); 9488 return useRadioStoreProps(store, update, props); 9489 } 9490 9491 // node_modules/@ariakit/react-core/esm/radio/radio-group.js 9492 var import_jsx_runtime16 = __toESM(require_jsx_runtime(), 1); 9493 var TagName30 = "div"; 9494 var useRadioGroup = createHook( 9495 function useRadioGroup2(_a) { 9496 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 9497 const context = useRadioProviderContext(); 9498 store = store || context; 9499 invariant( 9500 store, 9501 "RadioGroup must receive a `store` prop or be wrapped in a RadioProvider component." 9502 ); 9503 props = useWrapElement( 9504 props, 9505 (element) => /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(RadioScopedContextProvider, { value: store, children: element }), 9506 [store] 9507 ); 9508 props = __spreadValues({ 9509 role: "radiogroup" 9510 }, props); 9511 props = useComposite(__spreadValues({ store }, props)); 9512 return props; 9513 } 9514 ); 9515 var RadioGroup = forwardRef2(function RadioGroup2(props) { 9516 const htmlProps = useRadioGroup(props); 9517 return createElement(TagName30, htmlProps); 9518 }); 9519 9520 // node_modules/@ariakit/react-core/esm/__chunks/DR55NYVS.js 9521 var import_react37 = __toESM(require_react(), 1); 9522 var import_jsx_runtime17 = __toESM(require_jsx_runtime(), 1); 9523 var TagName31 = "span"; 9524 var pointsMap = { 9525 top: "4,10 8,6 12,10", 9526 right: "6,4 10,8 6,12", 9527 bottom: "4,6 8,10 12,6", 9528 left: "10,4 6,8 10,12" 9529 }; 9530 var usePopoverDisclosureArrow = createHook(function usePopoverDisclosureArrow2(_a) { 9531 var _b = _a, { store, placement } = _b, props = __objRest(_b, ["store", "placement"]); 9532 const context = usePopoverContext(); 9533 store = store || context; 9534 invariant( 9535 store, 9536 "PopoverDisclosureArrow must be wrapped in a PopoverDisclosure component." 9537 ); 9538 const position2 = store.useState((state) => placement || state.placement); 9539 const dir = position2.split("-")[0]; 9540 const points = pointsMap[dir]; 9541 const children = (0, import_react37.useMemo)( 9542 () => /* @__PURE__ */ (0, import_jsx_runtime17.jsx)( 9543 "svg", 9544 { 9545 display: "block", 9546 fill: "none", 9547 stroke: "currentColor", 9548 strokeLinecap: "round", 9549 strokeLinejoin: "round", 9550 strokeWidth: 1.5, 9551 viewBox: "0 0 16 16", 9552 height: "1em", 9553 width: "1em", 9554 children: /* @__PURE__ */ (0, import_jsx_runtime17.jsx)("polyline", { points }) 9555 } 9556 ), 9557 [points] 9558 ); 9559 props = __spreadProps(__spreadValues({ 9560 children, 9561 "aria-hidden": true 9562 }, props), { 9563 style: __spreadValues({ 9564 width: "1em", 9565 height: "1em", 9566 pointerEvents: "none" 9567 }, props.style) 9568 }); 9569 return removeUndefinedValues(props); 9570 }); 9571 var PopoverDisclosureArrow = forwardRef2( 9572 function PopoverDisclosureArrow2(props) { 9573 const htmlProps = usePopoverDisclosureArrow(props); 9574 return createElement(TagName31, htmlProps); 9575 } 9576 ); 9577 9578 // node_modules/@ariakit/react-core/esm/__chunks/QYJ6MIDR.js 9579 var import_jsx_runtime18 = __toESM(require_jsx_runtime(), 1); 9580 var TagName32 = "button"; 9581 var usePopoverDisclosure = createHook(function usePopoverDisclosure2(_a) { 9582 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 9583 const context = usePopoverProviderContext(); 9584 store = store || context; 9585 invariant( 9586 store, 9587 "PopoverDisclosure must receive a `store` prop or be wrapped in a PopoverProvider component." 9588 ); 9589 const onClickProp = props.onClick; 9590 const onClick = useEvent((event) => { 9591 store == null ? void 0 : store.setAnchorElement(event.currentTarget); 9592 onClickProp == null ? void 0 : onClickProp(event); 9593 }); 9594 props = useWrapElement( 9595 props, 9596 (element) => /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(PopoverScopedContextProvider, { value: store, children: element }), 9597 [store] 9598 ); 9599 props = __spreadProps(__spreadValues({}, props), { 9600 onClick 9601 }); 9602 props = usePopoverAnchor(__spreadValues({ store }, props)); 9603 props = useDialogDisclosure(__spreadValues({ store }, props)); 9604 return props; 9605 }); 9606 var PopoverDisclosure = forwardRef2(function PopoverDisclosure2(props) { 9607 const htmlProps = usePopoverDisclosure(props); 9608 return createElement(TagName32, htmlProps); 9609 }); 9610 9611 // node_modules/@ariakit/react-core/esm/__chunks/62UHHO2X.js 9612 var import_react38 = __toESM(require_react(), 1); 9613 var menubar = createStoreContext( 9614 [CompositeContextProvider], 9615 [CompositeScopedContextProvider] 9616 ); 9617 var useMenubarContext = menubar.useContext; 9618 var useMenubarScopedContext = menubar.useScopedContext; 9619 var useMenubarProviderContext = menubar.useProviderContext; 9620 var MenubarContextProvider = menubar.ContextProvider; 9621 var MenubarScopedContextProvider = menubar.ScopedContextProvider; 9622 var MenuItemCheckedContext = (0, import_react38.createContext)( 9623 void 0 9624 ); 9625 9626 // node_modules/@ariakit/react-core/esm/__chunks/EM5CXX6A.js 9627 var ctx9 = createStoreContext( 9628 [PopoverContextProvider], 9629 [PopoverScopedContextProvider] 9630 ); 9631 var useHovercardContext = ctx9.useContext; 9632 var useHovercardScopedContext = ctx9.useScopedContext; 9633 var useHovercardProviderContext = ctx9.useProviderContext; 9634 var HovercardContextProvider = ctx9.ContextProvider; 9635 var HovercardScopedContextProvider = ctx9.ScopedContextProvider; 9636 9637 // node_modules/@ariakit/react-core/esm/__chunks/B2J376ND.js 9638 var import_react39 = __toESM(require_react(), 1); 9639 var menu = createStoreContext( 9640 [CompositeContextProvider, HovercardContextProvider], 9641 [CompositeScopedContextProvider, HovercardScopedContextProvider] 9642 ); 9643 var useMenuContext = menu.useContext; 9644 var useMenuScopedContext = menu.useScopedContext; 9645 var useMenuProviderContext = menu.useProviderContext; 9646 var MenuContextProvider = menu.ContextProvider; 9647 var MenuScopedContextProvider = menu.ScopedContextProvider; 9648 var MenuItemCheckedContext2 = (0, import_react39.createContext)( 9649 void 0 9650 ); 9651 9652 // node_modules/@ariakit/core/esm/__chunks/JTLIIJ4U.js 9653 function createHovercardStore(props = {}) { 9654 var _a; 9655 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 9656 const popover = createPopoverStore(__spreadProps2(__spreadValues2({}, props), { 9657 placement: defaultValue( 9658 props.placement, 9659 syncState == null ? void 0 : syncState.placement, 9660 "bottom" 9661 ) 9662 })); 9663 const timeout = defaultValue(props.timeout, syncState == null ? void 0 : syncState.timeout, 500); 9664 const initialState = __spreadProps2(__spreadValues2({}, popover.getState()), { 9665 timeout, 9666 showTimeout: defaultValue(props.showTimeout, syncState == null ? void 0 : syncState.showTimeout), 9667 hideTimeout: defaultValue(props.hideTimeout, syncState == null ? void 0 : syncState.hideTimeout), 9668 autoFocusOnShow: defaultValue(syncState == null ? void 0 : syncState.autoFocusOnShow, false) 9669 }); 9670 const hovercard = createStore(initialState, popover, props.store); 9671 return __spreadProps2(__spreadValues2(__spreadValues2({}, popover), hovercard), { 9672 setAutoFocusOnShow: (value) => hovercard.setState("autoFocusOnShow", value) 9673 }); 9674 } 9675 9676 // node_modules/@ariakit/react-core/esm/__chunks/FTXTWCCT.js 9677 function useHovercardStoreProps(store, update, props) { 9678 useStoreProps(store, props, "timeout"); 9679 useStoreProps(store, props, "showTimeout"); 9680 useStoreProps(store, props, "hideTimeout"); 9681 return usePopoverStoreProps(store, update, props); 9682 } 9683 9684 // node_modules/@ariakit/core/esm/menu/menu-store.js 9685 function createMenuStore(_a = {}) { 9686 var _b = _a, { 9687 combobox, 9688 parent, 9689 menubar: menubar2 9690 } = _b, props = __objRest2(_b, [ 9691 "combobox", 9692 "parent", 9693 "menubar" 9694 ]); 9695 const parentIsMenubar = !!menubar2 && !parent; 9696 const store = mergeStore( 9697 props.store, 9698 pick2(parent, ["values"]), 9699 omit2(combobox, [ 9700 "arrowElement", 9701 "anchorElement", 9702 "contentElement", 9703 "popoverElement", 9704 "disclosureElement" 9705 ]) 9706 ); 9707 throwOnConflictingProps(props, store); 9708 const syncState = store.getState(); 9709 const composite = createCompositeStore(__spreadProps2(__spreadValues2({}, props), { 9710 store, 9711 orientation: defaultValue( 9712 props.orientation, 9713 syncState.orientation, 9714 "vertical" 9715 ) 9716 })); 9717 const hovercard = createHovercardStore(__spreadProps2(__spreadValues2({}, props), { 9718 store, 9719 placement: defaultValue( 9720 props.placement, 9721 syncState.placement, 9722 "bottom-start" 9723 ), 9724 timeout: defaultValue( 9725 props.timeout, 9726 syncState.timeout, 9727 parentIsMenubar ? 0 : 150 9728 ), 9729 hideTimeout: defaultValue(props.hideTimeout, syncState.hideTimeout, 0) 9730 })); 9731 const initialState = __spreadProps2(__spreadValues2(__spreadValues2({}, composite.getState()), hovercard.getState()), { 9732 initialFocus: defaultValue(syncState.initialFocus, "container"), 9733 values: defaultValue( 9734 props.values, 9735 syncState.values, 9736 props.defaultValues, 9737 {} 9738 ) 9739 }); 9740 const menu2 = createStore(initialState, composite, hovercard, store); 9741 setup( 9742 menu2, 9743 () => sync(menu2, ["mounted"], (state) => { 9744 if (state.mounted) return; 9745 menu2.setState("activeId", null); 9746 }) 9747 ); 9748 setup( 9749 menu2, 9750 () => sync(parent, ["orientation"], (state) => { 9751 menu2.setState( 9752 "placement", 9753 state.orientation === "vertical" ? "right-start" : "bottom-start" 9754 ); 9755 }) 9756 ); 9757 return __spreadProps2(__spreadValues2(__spreadValues2(__spreadValues2({}, composite), hovercard), menu2), { 9758 combobox, 9759 parent, 9760 menubar: menubar2, 9761 hideAll: () => { 9762 hovercard.hide(); 9763 parent == null ? void 0 : parent.hideAll(); 9764 }, 9765 setInitialFocus: (value) => menu2.setState("initialFocus", value), 9766 setValues: (values) => menu2.setState("values", values), 9767 setValue: (name, value) => { 9768 if (name === "__proto__") return; 9769 if (name === "constructor") return; 9770 if (Array.isArray(name)) return; 9771 menu2.setState("values", (values) => { 9772 const prevValue = values[name]; 9773 const nextValue = applyState(value, prevValue); 9774 if (nextValue === prevValue) return values; 9775 return __spreadProps2(__spreadValues2({}, values), { 9776 [name]: nextValue !== void 0 && nextValue 9777 }); 9778 }); 9779 } 9780 }); 9781 } 9782 9783 // node_modules/@ariakit/react-core/esm/__chunks/MRTXKBQF.js 9784 function useMenuStoreProps(store, update, props) { 9785 useUpdateEffect(update, [props.combobox, props.parent, props.menubar]); 9786 useStoreProps(store, props, "values", "setValues"); 9787 return Object.assign( 9788 useHovercardStoreProps( 9789 useCompositeStoreProps(store, update, props), 9790 update, 9791 props 9792 ), 9793 { 9794 combobox: props.combobox, 9795 parent: props.parent, 9796 menubar: props.menubar 9797 } 9798 ); 9799 } 9800 function useMenuStore(props = {}) { 9801 const parent = useMenuContext(); 9802 const menubar2 = useMenubarContext(); 9803 const combobox = useComboboxProviderContext(); 9804 props = __spreadProps(__spreadValues({}, props), { 9805 parent: props.parent !== void 0 ? props.parent : parent, 9806 menubar: props.menubar !== void 0 ? props.menubar : menubar2, 9807 combobox: props.combobox !== void 0 ? props.combobox : combobox 9808 }); 9809 const [store, update] = useStore(createMenuStore, props); 9810 return useMenuStoreProps(store, update, props); 9811 } 9812 9813 // node_modules/@ariakit/react-core/esm/__chunks/ASGALOAX.js 9814 var import_react40 = __toESM(require_react(), 1); 9815 var import_jsx_runtime19 = __toESM(require_jsx_runtime(), 1); 9816 var TagName33 = "div"; 9817 function useAriaLabelledBy(_a) { 9818 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 9819 const [id3, setId] = (0, import_react40.useState)(void 0); 9820 const label = props["aria-label"]; 9821 const disclosureElement = useStoreState(store, "disclosureElement"); 9822 const contentElement = useStoreState(store, "contentElement"); 9823 (0, import_react40.useEffect)(() => { 9824 const disclosure = disclosureElement; 9825 if (!disclosure) return; 9826 const menu2 = contentElement; 9827 if (!menu2) return; 9828 const menuLabel = label || menu2.hasAttribute("aria-label"); 9829 if (menuLabel) { 9830 setId(void 0); 9831 } else if (disclosure.id) { 9832 setId(disclosure.id); 9833 } 9834 }, [label, disclosureElement, contentElement]); 9835 return id3; 9836 } 9837 var useMenuList = createHook( 9838 function useMenuList2(_a) { 9839 var _b = _a, { store, alwaysVisible, composite } = _b, props = __objRest(_b, ["store", "alwaysVisible", "composite"]); 9840 const context = useMenuProviderContext(); 9841 store = store || context; 9842 invariant( 9843 store, 9844 "MenuList must receive a `store` prop or be wrapped in a MenuProvider component." 9845 ); 9846 const parentMenu = store.parent; 9847 const parentMenubar = store.menubar; 9848 const hasParentMenu = !!parentMenu; 9849 const id3 = useId(props.id); 9850 const onKeyDownProp = props.onKeyDown; 9851 const dir = store.useState( 9852 (state) => state.placement.split("-")[0] 9853 ); 9854 const orientation = store.useState( 9855 (state) => state.orientation === "both" ? void 0 : state.orientation 9856 ); 9857 const isHorizontal = orientation !== "vertical"; 9858 const isMenubarHorizontal = useStoreState( 9859 parentMenubar, 9860 (state) => !!state && state.orientation !== "vertical" 9861 ); 9862 const onKeyDown = useEvent((event) => { 9863 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 9864 if (event.defaultPrevented) return; 9865 if (hasParentMenu || parentMenubar && !isHorizontal) { 9866 const hideMap = { 9867 ArrowRight: () => dir === "left" && !isHorizontal, 9868 ArrowLeft: () => dir === "right" && !isHorizontal, 9869 ArrowUp: () => dir === "bottom" && isHorizontal, 9870 ArrowDown: () => dir === "top" && isHorizontal 9871 }; 9872 const action = hideMap[event.key]; 9873 if (action == null ? void 0 : action()) { 9874 event.stopPropagation(); 9875 event.preventDefault(); 9876 return store == null ? void 0 : store.hide(); 9877 } 9878 } 9879 if (parentMenubar) { 9880 const keyMap = { 9881 ArrowRight: () => { 9882 if (!isMenubarHorizontal) return; 9883 return parentMenubar.next(); 9884 }, 9885 ArrowLeft: () => { 9886 if (!isMenubarHorizontal) return; 9887 return parentMenubar.previous(); 9888 }, 9889 ArrowDown: () => { 9890 if (isMenubarHorizontal) return; 9891 return parentMenubar.next(); 9892 }, 9893 ArrowUp: () => { 9894 if (isMenubarHorizontal) return; 9895 return parentMenubar.previous(); 9896 } 9897 }; 9898 const action = keyMap[event.key]; 9899 const id22 = action == null ? void 0 : action(); 9900 if (id22 !== void 0) { 9901 event.stopPropagation(); 9902 event.preventDefault(); 9903 parentMenubar.move(id22); 9904 } 9905 } 9906 }); 9907 props = useWrapElement( 9908 props, 9909 (element) => /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(MenuScopedContextProvider, { value: store, children: element }), 9910 [store] 9911 ); 9912 const ariaLabelledBy = useAriaLabelledBy(__spreadValues({ store }, props)); 9913 const mounted = store.useState("mounted"); 9914 const hidden = isHidden(mounted, props.hidden, alwaysVisible); 9915 const style2 = hidden ? __spreadProps(__spreadValues({}, props.style), { display: "none" }) : props.style; 9916 props = __spreadProps(__spreadValues({ 9917 id: id3, 9918 "aria-labelledby": ariaLabelledBy, 9919 hidden 9920 }, props), { 9921 ref: useMergeRefs(id3 ? store.setContentElement : null, props.ref), 9922 style: style2, 9923 onKeyDown 9924 }); 9925 const hasCombobox = !!store.combobox; 9926 composite = composite != null ? composite : !hasCombobox; 9927 if (composite) { 9928 props = __spreadValues({ 9929 role: "menu", 9930 "aria-orientation": orientation 9931 }, props); 9932 } 9933 props = useComposite(__spreadValues({ store, composite }, props)); 9934 props = useCompositeTypeahead(__spreadValues({ store, typeahead: !hasCombobox }, props)); 9935 return props; 9936 } 9937 ); 9938 var MenuList = forwardRef2(function MenuList2(props) { 9939 const htmlProps = useMenuList(props); 9940 return createElement(TagName33, htmlProps); 9941 }); 9942 9943 // node_modules/@ariakit/react-core/esm/__chunks/X7QOZUD3.js 9944 function getEventPoint(event) { 9945 return [event.clientX, event.clientY]; 9946 } 9947 function isPointInPolygon(point, polygon) { 9948 const [x2, y3] = point; 9949 let inside = false; 9950 const length2 = polygon.length; 9951 for (let l3 = length2, i3 = 0, j2 = l3 - 1; i3 < l3; j2 = i3++) { 9952 const [xi, yi] = polygon[i3]; 9953 const [xj, yj] = polygon[j2]; 9954 const [, vy] = polygon[j2 === 0 ? l3 - 1 : j2 - 1] || [0, 0]; 9955 const where = (yi - yj) * (x2 - xi) - (xi - xj) * (y3 - yi); 9956 if (yj < yi) { 9957 if (y3 >= yj && y3 < yi) { 9958 if (where === 0) return true; 9959 if (where > 0) { 9960 if (y3 === yj) { 9961 if (y3 > vy) { 9962 inside = !inside; 9963 } 9964 } else { 9965 inside = !inside; 9966 } 9967 } 9968 } 9969 } else if (yi < yj) { 9970 if (y3 > yi && y3 <= yj) { 9971 if (where === 0) return true; 9972 if (where < 0) { 9973 if (y3 === yj) { 9974 if (y3 < vy) { 9975 inside = !inside; 9976 } 9977 } else { 9978 inside = !inside; 9979 } 9980 } 9981 } 9982 } else if (y3 === yi && (x2 >= xj && x2 <= xi || x2 >= xi && x2 <= xj)) { 9983 return true; 9984 } 9985 } 9986 return inside; 9987 } 9988 function getEnterPointPlacement(enterPoint, rect) { 9989 const { top, right, bottom, left } = rect; 9990 const [x2, y3] = enterPoint; 9991 const placementX = x2 < left ? "left" : x2 > right ? "right" : null; 9992 const placementY = y3 < top ? "top" : y3 > bottom ? "bottom" : null; 9993 return [placementX, placementY]; 9994 } 9995 function getElementPolygon(element, enterPoint) { 9996 const rect = element.getBoundingClientRect(); 9997 const { top, right, bottom, left } = rect; 9998 const [x2, y3] = getEnterPointPlacement(enterPoint, rect); 9999 const polygon = [enterPoint]; 10000 if (x2) { 10001 if (y3 !== "top") { 10002 polygon.push([x2 === "left" ? left : right, top]); 10003 } 10004 polygon.push([x2 === "left" ? right : left, top]); 10005 polygon.push([x2 === "left" ? right : left, bottom]); 10006 if (y3 !== "bottom") { 10007 polygon.push([x2 === "left" ? left : right, bottom]); 10008 } 10009 } else if (y3 === "top") { 10010 polygon.push([left, top]); 10011 polygon.push([left, bottom]); 10012 polygon.push([right, bottom]); 10013 polygon.push([right, top]); 10014 } else { 10015 polygon.push([left, bottom]); 10016 polygon.push([left, top]); 10017 polygon.push([right, top]); 10018 polygon.push([right, bottom]); 10019 } 10020 return polygon; 10021 } 10022 10023 // node_modules/@ariakit/react-core/esm/__chunks/KQKDTOT4.js 10024 var import_react41 = __toESM(require_react(), 1); 10025 var import_jsx_runtime20 = __toESM(require_jsx_runtime(), 1); 10026 var TagName34 = "div"; 10027 function isMovingOnHovercard(target, card, anchor, nested) { 10028 if (hasFocusWithin(card)) return true; 10029 if (!target) return false; 10030 if (contains(card, target)) return true; 10031 if (anchor && contains(anchor, target)) return true; 10032 if (nested == null ? void 0 : nested.some((card2) => isMovingOnHovercard(target, card2, anchor))) { 10033 return true; 10034 } 10035 return false; 10036 } 10037 function useAutoFocusOnHide(_a) { 10038 var _b = _a, { 10039 store 10040 } = _b, props = __objRest(_b, [ 10041 "store" 10042 ]); 10043 const [autoFocusOnHide, setAutoFocusOnHide] = (0, import_react41.useState)(false); 10044 const mounted = store.useState("mounted"); 10045 (0, import_react41.useEffect)(() => { 10046 if (!mounted) { 10047 setAutoFocusOnHide(false); 10048 } 10049 }, [mounted]); 10050 const onFocusProp = props.onFocus; 10051 const onFocus = useEvent((event) => { 10052 onFocusProp == null ? void 0 : onFocusProp(event); 10053 if (event.defaultPrevented) return; 10054 setAutoFocusOnHide(true); 10055 }); 10056 const finalFocusRef = (0, import_react41.useRef)(null); 10057 (0, import_react41.useEffect)(() => { 10058 return sync(store, ["anchorElement"], (state) => { 10059 finalFocusRef.current = state.anchorElement; 10060 }); 10061 }, []); 10062 props = __spreadProps(__spreadValues({ 10063 autoFocusOnHide, 10064 finalFocus: finalFocusRef 10065 }, props), { 10066 onFocus 10067 }); 10068 return props; 10069 } 10070 var NestedHovercardContext = (0, import_react41.createContext)(null); 10071 var useHovercard = createHook( 10072 function useHovercard2(_a) { 10073 var _b = _a, { 10074 store, 10075 modal = false, 10076 portal = !!modal, 10077 hideOnEscape = true, 10078 hideOnHoverOutside = true, 10079 disablePointerEventsOnApproach = !!hideOnHoverOutside 10080 } = _b, props = __objRest(_b, [ 10081 "store", 10082 "modal", 10083 "portal", 10084 "hideOnEscape", 10085 "hideOnHoverOutside", 10086 "disablePointerEventsOnApproach" 10087 ]); 10088 const context = useHovercardProviderContext(); 10089 store = store || context; 10090 invariant( 10091 store, 10092 "Hovercard must receive a `store` prop or be wrapped in a HovercardProvider component." 10093 ); 10094 const ref = (0, import_react41.useRef)(null); 10095 const [nestedHovercards, setNestedHovercards] = (0, import_react41.useState)([]); 10096 const hideTimeoutRef = (0, import_react41.useRef)(0); 10097 const enterPointRef = (0, import_react41.useRef)(null); 10098 const { portalRef, domReady } = usePortalRef(portal, props.portalRef); 10099 const isMouseMoving = useIsMouseMoving(); 10100 const mayHideOnHoverOutside = !!hideOnHoverOutside; 10101 const hideOnHoverOutsideProp = useBooleanEvent(hideOnHoverOutside); 10102 const mayDisablePointerEvents = !!disablePointerEventsOnApproach; 10103 const disablePointerEventsProp = useBooleanEvent( 10104 disablePointerEventsOnApproach 10105 ); 10106 const open = store.useState("open"); 10107 const mounted = store.useState("mounted"); 10108 (0, import_react41.useEffect)(() => { 10109 if (!domReady) return; 10110 if (!mounted) return; 10111 if (!mayHideOnHoverOutside && !mayDisablePointerEvents) return; 10112 const element = ref.current; 10113 if (!element) return; 10114 const onMouseMove = (event) => { 10115 if (!store) return; 10116 if (!isMouseMoving()) return; 10117 const { anchorElement, hideTimeout, timeout } = store.getState(); 10118 const enterPoint = enterPointRef.current; 10119 const [target] = event.composedPath(); 10120 const anchor = anchorElement; 10121 if (isMovingOnHovercard(target, element, anchor, nestedHovercards)) { 10122 enterPointRef.current = target && anchor && contains(anchor, target) ? getEventPoint(event) : null; 10123 window.clearTimeout(hideTimeoutRef.current); 10124 hideTimeoutRef.current = 0; 10125 return; 10126 } 10127 if (hideTimeoutRef.current) return; 10128 if (enterPoint) { 10129 const currentPoint = getEventPoint(event); 10130 const polygon = getElementPolygon(element, enterPoint); 10131 if (isPointInPolygon(currentPoint, polygon)) { 10132 enterPointRef.current = currentPoint; 10133 if (!disablePointerEventsProp(event)) return; 10134 event.preventDefault(); 10135 event.stopPropagation(); 10136 return; 10137 } 10138 } 10139 if (!hideOnHoverOutsideProp(event)) return; 10140 hideTimeoutRef.current = window.setTimeout(() => { 10141 hideTimeoutRef.current = 0; 10142 store == null ? void 0 : store.hide(); 10143 }, hideTimeout != null ? hideTimeout : timeout); 10144 }; 10145 return chain( 10146 addGlobalEventListener("mousemove", onMouseMove, true), 10147 () => clearTimeout(hideTimeoutRef.current) 10148 ); 10149 }, [ 10150 store, 10151 isMouseMoving, 10152 domReady, 10153 mounted, 10154 mayHideOnHoverOutside, 10155 mayDisablePointerEvents, 10156 nestedHovercards, 10157 disablePointerEventsProp, 10158 hideOnHoverOutsideProp 10159 ]); 10160 (0, import_react41.useEffect)(() => { 10161 if (!domReady) return; 10162 if (!mounted) return; 10163 if (!mayDisablePointerEvents) return; 10164 const disableEvent = (event) => { 10165 const element = ref.current; 10166 if (!element) return; 10167 const enterPoint = enterPointRef.current; 10168 if (!enterPoint) return; 10169 const polygon = getElementPolygon(element, enterPoint); 10170 if (isPointInPolygon(getEventPoint(event), polygon)) { 10171 if (!disablePointerEventsProp(event)) return; 10172 event.preventDefault(); 10173 event.stopPropagation(); 10174 } 10175 }; 10176 return chain( 10177 // Note: we may need to add pointer events here in the future. 10178 addGlobalEventListener("mouseenter", disableEvent, true), 10179 addGlobalEventListener("mouseover", disableEvent, true), 10180 addGlobalEventListener("mouseout", disableEvent, true), 10181 addGlobalEventListener("mouseleave", disableEvent, true) 10182 ); 10183 }, [domReady, mounted, mayDisablePointerEvents, disablePointerEventsProp]); 10184 (0, import_react41.useEffect)(() => { 10185 if (!domReady) return; 10186 if (open) return; 10187 store == null ? void 0 : store.setAutoFocusOnShow(false); 10188 }, [store, domReady, open]); 10189 const openRef = useLiveRef(open); 10190 (0, import_react41.useEffect)(() => { 10191 if (!domReady) return; 10192 return () => { 10193 if (!openRef.current) { 10194 store == null ? void 0 : store.setAutoFocusOnShow(false); 10195 } 10196 }; 10197 }, [store, domReady]); 10198 const registerOnParent = (0, import_react41.useContext)(NestedHovercardContext); 10199 useSafeLayoutEffect(() => { 10200 if (modal) return; 10201 if (!portal) return; 10202 if (!mounted) return; 10203 if (!domReady) return; 10204 const element = ref.current; 10205 if (!element) return; 10206 return registerOnParent == null ? void 0 : registerOnParent(element); 10207 }, [modal, portal, mounted, domReady]); 10208 const registerNestedHovercard = (0, import_react41.useCallback)( 10209 (element) => { 10210 setNestedHovercards((prevElements) => [...prevElements, element]); 10211 const parentUnregister = registerOnParent == null ? void 0 : registerOnParent(element); 10212 return () => { 10213 setNestedHovercards( 10214 (prevElements) => prevElements.filter((item2) => item2 !== element) 10215 ); 10216 parentUnregister == null ? void 0 : parentUnregister(); 10217 }; 10218 }, 10219 [registerOnParent] 10220 ); 10221 props = useWrapElement( 10222 props, 10223 (element) => /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(HovercardScopedContextProvider, { value: store, children: /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(NestedHovercardContext.Provider, { value: registerNestedHovercard, children: element }) }), 10224 [store, registerNestedHovercard] 10225 ); 10226 props = __spreadProps(__spreadValues({}, props), { 10227 ref: useMergeRefs(ref, props.ref) 10228 }); 10229 props = useAutoFocusOnHide(__spreadValues({ store }, props)); 10230 const autoFocusOnShow = store.useState( 10231 (state) => modal || state.autoFocusOnShow 10232 ); 10233 props = usePopover(__spreadProps(__spreadValues({ 10234 store, 10235 modal, 10236 portal, 10237 autoFocusOnShow 10238 }, props), { 10239 portalRef, 10240 hideOnEscape(event) { 10241 if (isFalsyBooleanCallback(hideOnEscape, event)) return false; 10242 requestAnimationFrame(() => { 10243 requestAnimationFrame(() => { 10244 store == null ? void 0 : store.hide(); 10245 }); 10246 }); 10247 return true; 10248 } 10249 })); 10250 return props; 10251 } 10252 ); 10253 var Hovercard = createDialogComponent( 10254 forwardRef2(function Hovercard2(props) { 10255 const htmlProps = useHovercard(props); 10256 return createElement(TagName34, htmlProps); 10257 }), 10258 useHovercardProviderContext 10259 ); 10260 10261 // node_modules/@ariakit/react-core/esm/menu/menu.js 10262 var import_react42 = __toESM(require_react(), 1); 10263 var TagName35 = "div"; 10264 var useMenu = createHook(function useMenu2(_a) { 10265 var _b = _a, { 10266 store, 10267 modal: modalProp = false, 10268 portal = !!modalProp, 10269 hideOnEscape = true, 10270 autoFocusOnShow = true, 10271 hideOnHoverOutside, 10272 alwaysVisible 10273 } = _b, props = __objRest(_b, [ 10274 "store", 10275 "modal", 10276 "portal", 10277 "hideOnEscape", 10278 "autoFocusOnShow", 10279 "hideOnHoverOutside", 10280 "alwaysVisible" 10281 ]); 10282 const context = useMenuProviderContext(); 10283 store = store || context; 10284 invariant( 10285 store, 10286 "Menu must receive a `store` prop or be wrapped in a MenuProvider component." 10287 ); 10288 const ref = (0, import_react42.useRef)(null); 10289 const parentMenu = store.parent; 10290 const parentMenubar = store.menubar; 10291 const hasParentMenu = !!parentMenu; 10292 const parentIsMenubar = !!parentMenubar && !hasParentMenu; 10293 props = __spreadProps(__spreadValues({}, props), { 10294 ref: useMergeRefs(ref, props.ref) 10295 }); 10296 const _a2 = useMenuList(__spreadValues({ 10297 store, 10298 alwaysVisible 10299 }, props)), { "aria-labelledby": ariaLabelledBy } = _a2, menuListProps = __objRest(_a2, ["aria-labelledby"]); 10300 props = menuListProps; 10301 const [initialFocusRef, setInitialFocusRef] = (0, import_react42.useState)(); 10302 const autoFocusOnShowState = store.useState("autoFocusOnShow"); 10303 const initialFocus = store.useState("initialFocus"); 10304 const baseElement = store.useState("baseElement"); 10305 const items = store.useState("renderedItems"); 10306 (0, import_react42.useEffect)(() => { 10307 let cleaning = false; 10308 setInitialFocusRef((prevInitialFocusRef) => { 10309 var _a3, _b2, _c; 10310 if (cleaning) return; 10311 if (!autoFocusOnShowState) return; 10312 if ((_a3 = prevInitialFocusRef == null ? void 0 : prevInitialFocusRef.current) == null ? void 0 : _a3.isConnected) return prevInitialFocusRef; 10313 const ref2 = (0, import_react42.createRef)(); 10314 switch (initialFocus) { 10315 case "first": 10316 ref2.current = ((_b2 = items.find((item2) => !item2.disabled && item2.element)) == null ? void 0 : _b2.element) || null; 10317 break; 10318 case "last": 10319 ref2.current = ((_c = [...items].reverse().find((item2) => !item2.disabled && item2.element)) == null ? void 0 : _c.element) || null; 10320 break; 10321 default: 10322 ref2.current = baseElement; 10323 } 10324 return ref2; 10325 }); 10326 return () => { 10327 cleaning = true; 10328 }; 10329 }, [store, autoFocusOnShowState, initialFocus, items, baseElement]); 10330 const modal = hasParentMenu ? false : modalProp; 10331 const mayAutoFocusOnShow = !!autoFocusOnShow; 10332 const canAutoFocusOnShow = !!initialFocusRef || !!props.initialFocus || !!modal; 10333 const contentElement = useStoreState( 10334 store.combobox || store, 10335 "contentElement" 10336 ); 10337 const parentContentElement = useStoreState( 10338 (parentMenu == null ? void 0 : parentMenu.combobox) || parentMenu, 10339 "contentElement" 10340 ); 10341 const preserveTabOrderAnchor = (0, import_react42.useMemo)(() => { 10342 if (!parentContentElement) return; 10343 if (!contentElement) return; 10344 const role = contentElement.getAttribute("role"); 10345 const parentRole = parentContentElement.getAttribute("role"); 10346 const parentIsMenuOrMenubar = parentRole === "menu" || parentRole === "menubar"; 10347 if (parentIsMenuOrMenubar && role === "menu") return; 10348 return parentContentElement; 10349 }, [contentElement, parentContentElement]); 10350 if (preserveTabOrderAnchor !== void 0) { 10351 props = __spreadValues({ 10352 preserveTabOrderAnchor 10353 }, props); 10354 } 10355 props = useHovercard(__spreadProps(__spreadValues({ 10356 store, 10357 alwaysVisible, 10358 initialFocus: initialFocusRef, 10359 autoFocusOnShow: mayAutoFocusOnShow ? canAutoFocusOnShow && autoFocusOnShow : autoFocusOnShowState || !!modal 10360 }, props), { 10361 hideOnEscape(event) { 10362 if (isFalsyBooleanCallback(hideOnEscape, event)) return false; 10363 store == null ? void 0 : store.hideAll(); 10364 return true; 10365 }, 10366 hideOnHoverOutside(event) { 10367 const disclosureElement = store == null ? void 0 : store.getState().disclosureElement; 10368 const getHideOnHoverOutside = () => { 10369 if (typeof hideOnHoverOutside === "function") { 10370 return hideOnHoverOutside(event); 10371 } 10372 if (hideOnHoverOutside != null) return hideOnHoverOutside; 10373 if (hasParentMenu) return true; 10374 if (!parentIsMenubar) return false; 10375 if (!disclosureElement) return true; 10376 if (hasFocusWithin(disclosureElement)) return false; 10377 return true; 10378 }; 10379 if (!getHideOnHoverOutside()) return false; 10380 if (event.defaultPrevented) return true; 10381 if (!hasParentMenu) return true; 10382 if (!disclosureElement) return true; 10383 fireEvent(disclosureElement, "mouseout", event); 10384 if (!hasFocusWithin(disclosureElement)) return true; 10385 requestAnimationFrame(() => { 10386 if (hasFocusWithin(disclosureElement)) return; 10387 store == null ? void 0 : store.hide(); 10388 }); 10389 return false; 10390 }, 10391 modal, 10392 portal, 10393 backdrop: hasParentMenu ? false : props.backdrop 10394 })); 10395 props = __spreadValues({ 10396 "aria-labelledby": ariaLabelledBy 10397 }, props); 10398 return props; 10399 }); 10400 var Menu = createDialogComponent( 10401 forwardRef2(function Menu2(props) { 10402 const htmlProps = useMenu(props); 10403 return createElement(TagName35, htmlProps); 10404 }), 10405 useMenuProviderContext 10406 ); 10407 10408 // node_modules/@ariakit/react-core/esm/__chunks/BYC7LY2E.js 10409 var import_react43 = __toESM(require_react(), 1); 10410 var TagName36 = "a"; 10411 var useHovercardAnchor = createHook( 10412 function useHovercardAnchor2(_a) { 10413 var _b = _a, { store, showOnHover = true } = _b, props = __objRest(_b, ["store", "showOnHover"]); 10414 const context = useHovercardProviderContext(); 10415 store = store || context; 10416 invariant( 10417 store, 10418 "HovercardAnchor must receive a `store` prop or be wrapped in a HovercardProvider component." 10419 ); 10420 const disabled = disabledFromProps(props); 10421 const showTimeoutRef = (0, import_react43.useRef)(0); 10422 (0, import_react43.useEffect)(() => () => window.clearTimeout(showTimeoutRef.current), []); 10423 (0, import_react43.useEffect)(() => { 10424 const onMouseLeave = (event) => { 10425 if (!store) return; 10426 const { anchorElement } = store.getState(); 10427 if (!anchorElement) return; 10428 if (event.target !== anchorElement) return; 10429 window.clearTimeout(showTimeoutRef.current); 10430 showTimeoutRef.current = 0; 10431 }; 10432 return addGlobalEventListener("mouseleave", onMouseLeave, true); 10433 }, [store]); 10434 const onMouseMoveProp = props.onMouseMove; 10435 const showOnHoverProp = useBooleanEvent(showOnHover); 10436 const isMouseMoving = useIsMouseMoving(); 10437 const onMouseMove = useEvent((event) => { 10438 onMouseMoveProp == null ? void 0 : onMouseMoveProp(event); 10439 if (disabled) return; 10440 if (!store) return; 10441 if (event.defaultPrevented) return; 10442 if (showTimeoutRef.current) return; 10443 if (!isMouseMoving()) return; 10444 if (!showOnHoverProp(event)) return; 10445 const element = event.currentTarget; 10446 store.setAnchorElement(element); 10447 store.setDisclosureElement(element); 10448 const { showTimeout, timeout } = store.getState(); 10449 const showHovercard = () => { 10450 showTimeoutRef.current = 0; 10451 if (!isMouseMoving()) return; 10452 store == null ? void 0 : store.setAnchorElement(element); 10453 store == null ? void 0 : store.show(); 10454 queueMicrotask(() => { 10455 store == null ? void 0 : store.setDisclosureElement(element); 10456 }); 10457 }; 10458 const timeoutMs = showTimeout != null ? showTimeout : timeout; 10459 if (timeoutMs === 0) { 10460 showHovercard(); 10461 } else { 10462 showTimeoutRef.current = window.setTimeout(showHovercard, timeoutMs); 10463 } 10464 }); 10465 const onClickProp = props.onClick; 10466 const onClick = useEvent((event) => { 10467 onClickProp == null ? void 0 : onClickProp(event); 10468 if (!store) return; 10469 window.clearTimeout(showTimeoutRef.current); 10470 showTimeoutRef.current = 0; 10471 }); 10472 const ref = (0, import_react43.useCallback)( 10473 (element) => { 10474 if (!store) return; 10475 const { anchorElement } = store.getState(); 10476 if (anchorElement == null ? void 0 : anchorElement.isConnected) return; 10477 store.setAnchorElement(element); 10478 }, 10479 [store] 10480 ); 10481 props = __spreadProps(__spreadValues({}, props), { 10482 ref: useMergeRefs(ref, props.ref), 10483 onMouseMove, 10484 onClick 10485 }); 10486 props = useFocusable(props); 10487 return props; 10488 } 10489 ); 10490 var HovercardAnchor = forwardRef2(function HovercardAnchor2(props) { 10491 const htmlProps = useHovercardAnchor(props); 10492 return createElement(TagName36, htmlProps); 10493 }); 10494 10495 // node_modules/@ariakit/react-core/esm/menu/menu-button.js 10496 var import_react44 = __toESM(require_react(), 1); 10497 var import_jsx_runtime21 = __toESM(require_jsx_runtime(), 1); 10498 var TagName37 = "button"; 10499 function getInitialFocus(event, dir) { 10500 const keyMap = { 10501 ArrowDown: dir === "bottom" || dir === "top" ? "first" : false, 10502 ArrowUp: dir === "bottom" || dir === "top" ? "last" : false, 10503 ArrowRight: dir === "right" ? "first" : false, 10504 ArrowLeft: dir === "left" ? "first" : false 10505 }; 10506 return keyMap[event.key]; 10507 } 10508 function hasActiveItem(items, excludeElement) { 10509 return !!(items == null ? void 0 : items.some((item2) => { 10510 if (!item2.element) return false; 10511 if (item2.element === excludeElement) return false; 10512 return item2.element.getAttribute("aria-expanded") === "true"; 10513 })); 10514 } 10515 var useMenuButton = createHook( 10516 function useMenuButton2(_a) { 10517 var _b = _a, { 10518 store, 10519 focusable, 10520 accessibleWhenDisabled, 10521 showOnHover 10522 } = _b, props = __objRest(_b, [ 10523 "store", 10524 "focusable", 10525 "accessibleWhenDisabled", 10526 "showOnHover" 10527 ]); 10528 const context = useMenuProviderContext(); 10529 store = store || context; 10530 invariant( 10531 store, 10532 "MenuButton must receive a `store` prop or be wrapped in a MenuProvider component." 10533 ); 10534 const ref = (0, import_react44.useRef)(null); 10535 const parentMenu = store.parent; 10536 const parentMenubar = store.menubar; 10537 const hasParentMenu = !!parentMenu; 10538 const parentIsMenubar = !!parentMenubar && !hasParentMenu; 10539 const disabled = disabledFromProps(props); 10540 const showMenu = () => { 10541 const trigger = ref.current; 10542 if (!trigger) return; 10543 store == null ? void 0 : store.setDisclosureElement(trigger); 10544 store == null ? void 0 : store.setAnchorElement(trigger); 10545 store == null ? void 0 : store.show(); 10546 }; 10547 const onFocusProp = props.onFocus; 10548 const onFocus = useEvent((event) => { 10549 onFocusProp == null ? void 0 : onFocusProp(event); 10550 if (disabled) return; 10551 if (event.defaultPrevented) return; 10552 store == null ? void 0 : store.setAutoFocusOnShow(false); 10553 store == null ? void 0 : store.setActiveId(null); 10554 if (!parentMenubar) return; 10555 if (!parentIsMenubar) return; 10556 const { items } = parentMenubar.getState(); 10557 if (hasActiveItem(items, event.currentTarget)) { 10558 showMenu(); 10559 } 10560 }); 10561 const dir = useStoreState( 10562 store, 10563 (state) => state.placement.split("-")[0] 10564 ); 10565 const onKeyDownProp = props.onKeyDown; 10566 const onKeyDown = useEvent((event) => { 10567 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 10568 if (disabled) return; 10569 if (event.defaultPrevented) return; 10570 const initialFocus = getInitialFocus(event, dir); 10571 if (initialFocus) { 10572 event.preventDefault(); 10573 showMenu(); 10574 store == null ? void 0 : store.setAutoFocusOnShow(true); 10575 store == null ? void 0 : store.setInitialFocus(initialFocus); 10576 } 10577 }); 10578 const onClickProp = props.onClick; 10579 const onClick = useEvent((event) => { 10580 onClickProp == null ? void 0 : onClickProp(event); 10581 if (event.defaultPrevented) return; 10582 if (!store) return; 10583 const isKeyboardClick = !event.detail; 10584 const { open } = store.getState(); 10585 if (!open || isKeyboardClick) { 10586 if (!hasParentMenu || isKeyboardClick) { 10587 store.setAutoFocusOnShow(true); 10588 } 10589 store.setInitialFocus(isKeyboardClick ? "first" : "container"); 10590 } 10591 if (hasParentMenu) { 10592 showMenu(); 10593 } 10594 }); 10595 props = useWrapElement( 10596 props, 10597 (element) => /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(MenuContextProvider, { value: store, children: element }), 10598 [store] 10599 ); 10600 if (hasParentMenu) { 10601 props = __spreadProps(__spreadValues({}, props), { 10602 render: /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(Role.div, { render: props.render }) 10603 }); 10604 } 10605 const id3 = useId(props.id); 10606 const parentContentElement = useStoreState( 10607 (parentMenu == null ? void 0 : parentMenu.combobox) || parentMenu, 10608 "contentElement" 10609 ); 10610 const role = hasParentMenu || parentIsMenubar ? getPopupItemRole(parentContentElement, "menuitem") : void 0; 10611 const contentElement = store.useState("contentElement"); 10612 props = __spreadProps(__spreadValues({ 10613 id: id3, 10614 role, 10615 "aria-haspopup": getPopupRole(contentElement, "menu") 10616 }, props), { 10617 ref: useMergeRefs(ref, props.ref), 10618 onFocus, 10619 onKeyDown, 10620 onClick 10621 }); 10622 props = useHovercardAnchor(__spreadProps(__spreadValues({ 10623 store, 10624 focusable, 10625 accessibleWhenDisabled 10626 }, props), { 10627 showOnHover: (event) => { 10628 const getShowOnHover = () => { 10629 if (typeof showOnHover === "function") return showOnHover(event); 10630 if (showOnHover != null) return showOnHover; 10631 if (hasParentMenu) return true; 10632 if (!parentMenubar) return false; 10633 const { items } = parentMenubar.getState(); 10634 return parentIsMenubar && hasActiveItem(items); 10635 }; 10636 const canShowOnHover = getShowOnHover(); 10637 if (!canShowOnHover) return false; 10638 const parent = parentIsMenubar ? parentMenubar : parentMenu; 10639 if (!parent) return true; 10640 parent.setActiveId(event.currentTarget.id); 10641 return true; 10642 } 10643 })); 10644 props = usePopoverDisclosure(__spreadValues({ 10645 store, 10646 toggleOnClick: !hasParentMenu, 10647 focusable, 10648 accessibleWhenDisabled 10649 }, props)); 10650 props = useCompositeTypeahead(__spreadValues({ 10651 store, 10652 typeahead: parentIsMenubar 10653 }, props)); 10654 return props; 10655 } 10656 ); 10657 var MenuButton = forwardRef2(function MenuButton2(props) { 10658 const htmlProps = useMenuButton(props); 10659 return createElement(TagName37, htmlProps); 10660 }); 10661 10662 // node_modules/@ariakit/react-core/esm/menu/menu-group-label.js 10663 var TagName38 = "div"; 10664 var useMenuGroupLabel = createHook( 10665 function useMenuGroupLabel2(props) { 10666 props = useCompositeGroupLabel(props); 10667 return props; 10668 } 10669 ); 10670 var MenuGroupLabel = forwardRef2(function MenuGroupLabel2(props) { 10671 const htmlProps = useMenuGroupLabel(props); 10672 return createElement(TagName38, htmlProps); 10673 }); 10674 10675 // node_modules/@ariakit/react-core/esm/menu/menu-group.js 10676 var TagName39 = "div"; 10677 var useMenuGroup = createHook( 10678 function useMenuGroup2(props) { 10679 props = useCompositeGroup(props); 10680 return props; 10681 } 10682 ); 10683 var MenuGroup = forwardRef2(function MenuGroup2(props) { 10684 const htmlProps = useMenuGroup(props); 10685 return createElement(TagName39, htmlProps); 10686 }); 10687 10688 // node_modules/@ariakit/react-core/esm/menu/menu-item-check.js 10689 var import_react45 = __toESM(require_react(), 1); 10690 var TagName40 = "span"; 10691 var useMenuItemCheck = createHook( 10692 function useMenuItemCheck2(_a) { 10693 var _b = _a, { store, checked } = _b, props = __objRest(_b, ["store", "checked"]); 10694 const context = (0, import_react45.useContext)(MenuItemCheckedContext2); 10695 checked = checked != null ? checked : context; 10696 props = useCheckboxCheck(__spreadProps(__spreadValues({}, props), { checked })); 10697 return props; 10698 } 10699 ); 10700 var MenuItemCheck = forwardRef2(function MenuItemCheck2(props) { 10701 const htmlProps = useMenuItemCheck(props); 10702 return createElement(TagName40, htmlProps); 10703 }); 10704 10705 // node_modules/@ariakit/react-core/esm/__chunks/MVIULMNR.js 10706 var TagName41 = "div"; 10707 function menuHasFocus(baseElement, items, currentTarget) { 10708 var _a; 10709 if (!baseElement) return false; 10710 if (hasFocusWithin(baseElement)) return true; 10711 const expandedItem = items == null ? void 0 : items.find((item2) => { 10712 var _a2; 10713 if (item2.element === currentTarget) return false; 10714 return ((_a2 = item2.element) == null ? void 0 : _a2.getAttribute("aria-expanded")) === "true"; 10715 }); 10716 const expandedMenuId = (_a = expandedItem == null ? void 0 : expandedItem.element) == null ? void 0 : _a.getAttribute("aria-controls"); 10717 if (!expandedMenuId) return false; 10718 const doc = getDocument(baseElement); 10719 const expandedMenu = doc.getElementById(expandedMenuId); 10720 if (!expandedMenu) return false; 10721 if (hasFocusWithin(expandedMenu)) return true; 10722 return !!expandedMenu.querySelector("[role=menuitem][aria-expanded=true]"); 10723 } 10724 var useMenuItem = createHook( 10725 function useMenuItem2(_a) { 10726 var _b = _a, { 10727 store, 10728 hideOnClick = true, 10729 preventScrollOnKeyDown = true, 10730 focusOnHover, 10731 blurOnHoverEnd 10732 } = _b, props = __objRest(_b, [ 10733 "store", 10734 "hideOnClick", 10735 "preventScrollOnKeyDown", 10736 "focusOnHover", 10737 "blurOnHoverEnd" 10738 ]); 10739 const menuContext = useMenuScopedContext(true); 10740 const menubarContext = useMenubarScopedContext(); 10741 store = store || menuContext || menubarContext; 10742 invariant( 10743 store, 10744 "MenuItem must be wrapped in a MenuList, Menu or Menubar component" 10745 ); 10746 const onClickProp = props.onClick; 10747 const hideOnClickProp = useBooleanEvent(hideOnClick); 10748 const hideMenu = "hideAll" in store ? store.hideAll : void 0; 10749 const isWithinMenu = !!hideMenu; 10750 const onClick = useEvent((event) => { 10751 onClickProp == null ? void 0 : onClickProp(event); 10752 if (event.defaultPrevented) return; 10753 if (isDownloading(event)) return; 10754 if (isOpeningInNewTab(event)) return; 10755 if (!hideMenu) return; 10756 const popupType = event.currentTarget.getAttribute("aria-haspopup"); 10757 if (popupType === "menu") return; 10758 if (!hideOnClickProp(event)) return; 10759 hideMenu(); 10760 }); 10761 const contentElement = useStoreState( 10762 store, 10763 (state) => "contentElement" in state ? state.contentElement : null 10764 ); 10765 const role = getPopupItemRole(contentElement, "menuitem"); 10766 props = __spreadProps(__spreadValues({ 10767 role 10768 }, props), { 10769 onClick 10770 }); 10771 props = useCompositeItem(__spreadValues({ 10772 store, 10773 preventScrollOnKeyDown 10774 }, props)); 10775 props = useCompositeHover(__spreadProps(__spreadValues({ 10776 store 10777 }, props), { 10778 focusOnHover(event) { 10779 const getFocusOnHover = () => { 10780 if (typeof focusOnHover === "function") return focusOnHover(event); 10781 if (focusOnHover != null) return focusOnHover; 10782 return true; 10783 }; 10784 if (!store) return false; 10785 if (!getFocusOnHover()) return false; 10786 const { baseElement, items } = store.getState(); 10787 if (isWithinMenu) { 10788 if (event.currentTarget.hasAttribute("aria-expanded")) { 10789 event.currentTarget.focus(); 10790 } 10791 return true; 10792 } 10793 if (menuHasFocus(baseElement, items, event.currentTarget)) { 10794 event.currentTarget.focus(); 10795 return true; 10796 } 10797 return false; 10798 }, 10799 blurOnHoverEnd(event) { 10800 if (typeof blurOnHoverEnd === "function") return blurOnHoverEnd(event); 10801 if (blurOnHoverEnd != null) return blurOnHoverEnd; 10802 return isWithinMenu; 10803 } 10804 })); 10805 return props; 10806 } 10807 ); 10808 var MenuItem = memo2( 10809 forwardRef2(function MenuItem2(props) { 10810 const htmlProps = useMenuItem(props); 10811 return createElement(TagName41, htmlProps); 10812 }) 10813 ); 10814 10815 // node_modules/@ariakit/react-core/esm/menu/menu-item-checkbox.js 10816 var import_react46 = __toESM(require_react(), 1); 10817 var TagName42 = "div"; 10818 function getPrimitiveValue2(value) { 10819 if (Array.isArray(value)) { 10820 return value.toString(); 10821 } 10822 return value; 10823 } 10824 function getValue(storeValue, value, checked) { 10825 if (value === void 0) { 10826 if (Array.isArray(storeValue)) return storeValue; 10827 return !!checked; 10828 } 10829 const primitiveValue = getPrimitiveValue2(value); 10830 if (!Array.isArray(storeValue)) { 10831 if (checked) { 10832 return primitiveValue; 10833 } 10834 return storeValue === primitiveValue ? false : storeValue; 10835 } 10836 if (checked) { 10837 if (storeValue.includes(primitiveValue)) { 10838 return storeValue; 10839 } 10840 return [...storeValue, primitiveValue]; 10841 } 10842 return storeValue.filter((v3) => v3 !== primitiveValue); 10843 } 10844 var useMenuItemCheckbox = createHook( 10845 function useMenuItemCheckbox2(_a) { 10846 var _b = _a, { 10847 store, 10848 name, 10849 value, 10850 checked, 10851 defaultChecked: defaultCheckedProp, 10852 hideOnClick = false 10853 } = _b, props = __objRest(_b, [ 10854 "store", 10855 "name", 10856 "value", 10857 "checked", 10858 "defaultChecked", 10859 "hideOnClick" 10860 ]); 10861 const context = useMenuScopedContext(); 10862 store = store || context; 10863 invariant( 10864 store, 10865 "MenuItemCheckbox must be wrapped in a MenuList or Menu component" 10866 ); 10867 const defaultChecked = useInitialValue(defaultCheckedProp); 10868 (0, import_react46.useEffect)(() => { 10869 store == null ? void 0 : store.setValue(name, (prevValue = []) => { 10870 if (!defaultChecked) return prevValue; 10871 return getValue(prevValue, value, true); 10872 }); 10873 }, [store, name, value, defaultChecked]); 10874 (0, import_react46.useEffect)(() => { 10875 if (checked === void 0) return; 10876 store == null ? void 0 : store.setValue(name, (prevValue) => { 10877 return getValue(prevValue, value, checked); 10878 }); 10879 }, [store, name, value, checked]); 10880 const checkboxStore = useCheckboxStore({ 10881 value: store.useState((state) => state.values[name]), 10882 setValue(internalValue) { 10883 store == null ? void 0 : store.setValue(name, () => { 10884 if (checked === void 0) return internalValue; 10885 const nextValue = getValue(internalValue, value, checked); 10886 if (!Array.isArray(nextValue)) return nextValue; 10887 if (!Array.isArray(internalValue)) return nextValue; 10888 if (shallowEqual(internalValue, nextValue)) return internalValue; 10889 return nextValue; 10890 }); 10891 } 10892 }); 10893 props = __spreadValues({ 10894 role: "menuitemcheckbox" 10895 }, props); 10896 props = useCheckbox(__spreadValues({ 10897 store: checkboxStore, 10898 name, 10899 value, 10900 checked 10901 }, props)); 10902 props = useMenuItem(__spreadValues({ store, hideOnClick }, props)); 10903 return props; 10904 } 10905 ); 10906 var MenuItemCheckbox = memo2( 10907 forwardRef2(function MenuItemCheckbox2(props) { 10908 const htmlProps = useMenuItemCheckbox(props); 10909 return createElement(TagName42, htmlProps); 10910 }) 10911 ); 10912 10913 // node_modules/@ariakit/react-core/esm/menu/menu-item-radio.js 10914 var import_react47 = __toESM(require_react(), 1); 10915 var import_jsx_runtime22 = __toESM(require_jsx_runtime(), 1); 10916 var TagName43 = "div"; 10917 function getValue2(prevValue, value, checked) { 10918 if (checked === void 0) return prevValue; 10919 if (checked) return value; 10920 return prevValue; 10921 } 10922 var useMenuItemRadio = createHook( 10923 function useMenuItemRadio2(_a) { 10924 var _b = _a, { 10925 store, 10926 name, 10927 value, 10928 checked, 10929 onChange: onChangeProp, 10930 hideOnClick = false 10931 } = _b, props = __objRest(_b, [ 10932 "store", 10933 "name", 10934 "value", 10935 "checked", 10936 "onChange", 10937 "hideOnClick" 10938 ]); 10939 const context = useMenuScopedContext(); 10940 store = store || context; 10941 invariant( 10942 store, 10943 "MenuItemRadio must be wrapped in a MenuList or Menu component" 10944 ); 10945 const defaultChecked = useInitialValue(props.defaultChecked); 10946 (0, import_react47.useEffect)(() => { 10947 store == null ? void 0 : store.setValue(name, (prevValue = false) => { 10948 return getValue2(prevValue, value, defaultChecked); 10949 }); 10950 }, [store, name, value, defaultChecked]); 10951 (0, import_react47.useEffect)(() => { 10952 if (checked === void 0) return; 10953 store == null ? void 0 : store.setValue(name, (prevValue) => { 10954 return getValue2(prevValue, value, checked); 10955 }); 10956 }, [store, name, value, checked]); 10957 const isChecked = store.useState((state) => state.values[name] === value); 10958 props = useWrapElement( 10959 props, 10960 (element) => /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(MenuItemCheckedContext2.Provider, { value: !!isChecked, children: element }), 10961 [isChecked] 10962 ); 10963 props = __spreadValues({ 10964 role: "menuitemradio" 10965 }, props); 10966 props = useRadio(__spreadValues({ 10967 name, 10968 value, 10969 checked: isChecked, 10970 onChange(event) { 10971 onChangeProp == null ? void 0 : onChangeProp(event); 10972 if (event.defaultPrevented) return; 10973 const element = event.currentTarget; 10974 store == null ? void 0 : store.setValue(name, (prevValue) => { 10975 return getValue2(prevValue, value, checked != null ? checked : element.checked); 10976 }); 10977 } 10978 }, props)); 10979 props = useMenuItem(__spreadValues({ store, hideOnClick }, props)); 10980 return props; 10981 } 10982 ); 10983 var MenuItemRadio = memo2( 10984 forwardRef2(function MenuItemRadio2(props) { 10985 const htmlProps = useMenuItemRadio(props); 10986 return createElement(TagName43, htmlProps); 10987 }) 10988 ); 10989 10990 // node_modules/@ariakit/react-core/esm/menu/menu-separator.js 10991 var TagName44 = "hr"; 10992 var useMenuSeparator = createHook( 10993 function useMenuSeparator2(_a) { 10994 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 10995 const context = useMenuContext(); 10996 store = store || context; 10997 props = useCompositeSeparator(__spreadValues({ store }, props)); 10998 return props; 10999 } 11000 ); 11001 var MenuSeparator = forwardRef2(function MenuSeparator2(props) { 11002 const htmlProps = useMenuSeparator(props); 11003 return createElement(TagName44, htmlProps); 11004 }); 11005 11006 // node_modules/@ariakit/core/esm/tooltip/tooltip-store.js 11007 function createTooltipStore(props = {}) { 11008 var _a; 11009 if (true) { 11010 if (props.type === "label") { 11011 console.warn( 11012 "The `type` option on the tooltip store is deprecated.", 11013 "Render a visually hidden label or use the `aria-label` or `aria-labelledby` attributes on the anchor element instead.", 11014 "See https://ariakit.org/components/tooltip#tooltip-anchors-must-have-accessible-names" 11015 ); 11016 } 11017 } 11018 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 11019 const hovercard = createHovercardStore(__spreadProps2(__spreadValues2({}, props), { 11020 placement: defaultValue( 11021 props.placement, 11022 syncState == null ? void 0 : syncState.placement, 11023 "top" 11024 ), 11025 hideTimeout: defaultValue(props.hideTimeout, syncState == null ? void 0 : syncState.hideTimeout, 0) 11026 })); 11027 const initialState = __spreadProps2(__spreadValues2({}, hovercard.getState()), { 11028 type: defaultValue(props.type, syncState == null ? void 0 : syncState.type, "description"), 11029 skipTimeout: defaultValue(props.skipTimeout, syncState == null ? void 0 : syncState.skipTimeout, 300) 11030 }); 11031 const tooltip = createStore(initialState, hovercard, props.store); 11032 return __spreadValues2(__spreadValues2({}, hovercard), tooltip); 11033 } 11034 11035 // node_modules/@ariakit/react-core/esm/__chunks/YTDK2NGG.js 11036 function useTooltipStoreProps(store, update, props) { 11037 useStoreProps(store, props, "type"); 11038 useStoreProps(store, props, "skipTimeout"); 11039 return useHovercardStoreProps(store, update, props); 11040 } 11041 function useTooltipStore(props = {}) { 11042 const [store, update] = useStore(createTooltipStore, props); 11043 return useTooltipStoreProps(store, update, props); 11044 } 11045 11046 // node_modules/@ariakit/react-core/esm/__chunks/F4IYJ42G.js 11047 var ctx10 = createStoreContext( 11048 [HovercardContextProvider], 11049 [HovercardScopedContextProvider] 11050 ); 11051 var useTooltipContext = ctx10.useContext; 11052 var useTooltipScopedContext = ctx10.useScopedContext; 11053 var useTooltipProviderContext = ctx10.useProviderContext; 11054 var TooltipContextProvider = ctx10.ContextProvider; 11055 var TooltipScopedContextProvider = ctx10.ScopedContextProvider; 11056 11057 // node_modules/@ariakit/react-core/esm/tooltip/tooltip.js 11058 var import_jsx_runtime23 = __toESM(require_jsx_runtime(), 1); 11059 var TagName45 = "div"; 11060 var useTooltip = createHook( 11061 function useTooltip2(_a) { 11062 var _b = _a, { 11063 store, 11064 portal = true, 11065 gutter = 8, 11066 preserveTabOrder = false, 11067 hideOnHoverOutside = true, 11068 hideOnInteractOutside = true 11069 } = _b, props = __objRest(_b, [ 11070 "store", 11071 "portal", 11072 "gutter", 11073 "preserveTabOrder", 11074 "hideOnHoverOutside", 11075 "hideOnInteractOutside" 11076 ]); 11077 const context = useTooltipProviderContext(); 11078 store = store || context; 11079 invariant( 11080 store, 11081 "Tooltip must receive a `store` prop or be wrapped in a TooltipProvider component." 11082 ); 11083 props = useWrapElement( 11084 props, 11085 (element) => /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(TooltipScopedContextProvider, { value: store, children: element }), 11086 [store] 11087 ); 11088 const role = store.useState( 11089 (state) => state.type === "description" ? "tooltip" : "none" 11090 ); 11091 props = __spreadValues({ role }, props); 11092 props = useHovercard(__spreadProps(__spreadValues({}, props), { 11093 store, 11094 portal, 11095 gutter, 11096 preserveTabOrder, 11097 hideOnHoverOutside(event) { 11098 if (isFalsyBooleanCallback(hideOnHoverOutside, event)) return false; 11099 const anchorElement = store == null ? void 0 : store.getState().anchorElement; 11100 if (!anchorElement) return true; 11101 if ("focusVisible" in anchorElement.dataset) return false; 11102 return true; 11103 }, 11104 hideOnInteractOutside: (event) => { 11105 if (isFalsyBooleanCallback(hideOnInteractOutside, event)) return false; 11106 const anchorElement = store == null ? void 0 : store.getState().anchorElement; 11107 if (!anchorElement) return true; 11108 if (contains(anchorElement, event.target)) return false; 11109 return true; 11110 } 11111 })); 11112 return props; 11113 } 11114 ); 11115 var Tooltip = createDialogComponent( 11116 forwardRef2(function Tooltip2(props) { 11117 const htmlProps = useTooltip(props); 11118 return createElement(TagName45, htmlProps); 11119 }), 11120 useTooltipProviderContext 11121 ); 11122 11123 // node_modules/@ariakit/react-core/esm/tooltip/tooltip-anchor.js 11124 var import_react48 = __toESM(require_react(), 1); 11125 var TagName46 = "div"; 11126 var globalStore = createStore({ 11127 activeStore: null 11128 }); 11129 function createRemoveStoreCallback(store) { 11130 return () => { 11131 const { activeStore } = globalStore.getState(); 11132 if (activeStore !== store) return; 11133 globalStore.setState("activeStore", null); 11134 }; 11135 } 11136 var useTooltipAnchor = createHook( 11137 function useTooltipAnchor2(_a) { 11138 var _b = _a, { store, showOnHover = true } = _b, props = __objRest(_b, ["store", "showOnHover"]); 11139 const context = useTooltipProviderContext(); 11140 store = store || context; 11141 invariant( 11142 store, 11143 "TooltipAnchor must receive a `store` prop or be wrapped in a TooltipProvider component." 11144 ); 11145 const canShowOnHoverRef = (0, import_react48.useRef)(false); 11146 (0, import_react48.useEffect)(() => { 11147 return sync(store, ["mounted"], (state) => { 11148 if (state.mounted) return; 11149 canShowOnHoverRef.current = false; 11150 }); 11151 }, [store]); 11152 (0, import_react48.useEffect)(() => { 11153 if (!store) return; 11154 return chain( 11155 // Immediately remove the current store from the global store when 11156 // the component unmounts. This is useful, for example, to avoid 11157 // showing tooltips immediately on serial tests. 11158 createRemoveStoreCallback(store), 11159 sync(store, ["mounted", "skipTimeout"], (state) => { 11160 if (!store) return; 11161 if (state.mounted) { 11162 const { activeStore } = globalStore.getState(); 11163 if (activeStore !== store) { 11164 activeStore == null ? void 0 : activeStore.hide(); 11165 } 11166 return globalStore.setState("activeStore", store); 11167 } 11168 const id3 = setTimeout( 11169 createRemoveStoreCallback(store), 11170 state.skipTimeout 11171 ); 11172 return () => clearTimeout(id3); 11173 }) 11174 ); 11175 }, [store]); 11176 const onMouseEnterProp = props.onMouseEnter; 11177 const onMouseEnter = useEvent((event) => { 11178 onMouseEnterProp == null ? void 0 : onMouseEnterProp(event); 11179 canShowOnHoverRef.current = true; 11180 }); 11181 const onFocusVisibleProp = props.onFocusVisible; 11182 const onFocusVisible = useEvent((event) => { 11183 onFocusVisibleProp == null ? void 0 : onFocusVisibleProp(event); 11184 if (event.defaultPrevented) return; 11185 store == null ? void 0 : store.setAnchorElement(event.currentTarget); 11186 store == null ? void 0 : store.show(); 11187 }); 11188 const onBlurProp = props.onBlur; 11189 const onBlur = useEvent((event) => { 11190 onBlurProp == null ? void 0 : onBlurProp(event); 11191 if (event.defaultPrevented) return; 11192 const { activeStore } = globalStore.getState(); 11193 canShowOnHoverRef.current = false; 11194 if (activeStore === store) { 11195 globalStore.setState("activeStore", null); 11196 } 11197 }); 11198 const type = store.useState("type"); 11199 const contentId = store.useState((state) => { 11200 var _a2; 11201 return (_a2 = state.contentElement) == null ? void 0 : _a2.id; 11202 }); 11203 props = __spreadProps(__spreadValues({ 11204 "aria-labelledby": type === "label" ? contentId : void 0 11205 }, props), { 11206 onMouseEnter, 11207 onFocusVisible, 11208 onBlur 11209 }); 11210 props = useHovercardAnchor(__spreadValues({ 11211 store, 11212 showOnHover(event) { 11213 if (!canShowOnHoverRef.current) return false; 11214 if (isFalsyBooleanCallback(showOnHover, event)) return false; 11215 const { activeStore } = globalStore.getState(); 11216 if (!activeStore) return true; 11217 store == null ? void 0 : store.show(); 11218 return false; 11219 } 11220 }, props)); 11221 return props; 11222 } 11223 ); 11224 var TooltipAnchor = forwardRef2(function TooltipAnchor2(props) { 11225 const htmlProps = useTooltipAnchor(props); 11226 return createElement(TagName46, htmlProps); 11227 }); 11228 11229 // node_modules/@ariakit/core/esm/toolbar/toolbar-store.js 11230 function createToolbarStore(props = {}) { 11231 var _a; 11232 const syncState = (_a = props.store) == null ? void 0 : _a.getState(); 11233 return createCompositeStore(__spreadProps2(__spreadValues2({}, props), { 11234 orientation: defaultValue( 11235 props.orientation, 11236 syncState == null ? void 0 : syncState.orientation, 11237 "horizontal" 11238 ), 11239 focusLoop: defaultValue(props.focusLoop, syncState == null ? void 0 : syncState.focusLoop, true) 11240 })); 11241 } 11242 11243 // node_modules/@ariakit/react-core/esm/__chunks/7M5THDKH.js 11244 function useToolbarStoreProps(store, update, props) { 11245 return useCompositeStoreProps(store, update, props); 11246 } 11247 function useToolbarStore(props = {}) { 11248 const [store, update] = useStore(createToolbarStore, props); 11249 return useToolbarStoreProps(store, update, props); 11250 } 11251 11252 // node_modules/@ariakit/react-core/esm/__chunks/A3WPL2ZJ.js 11253 var ctx11 = createStoreContext( 11254 [CompositeContextProvider], 11255 [CompositeScopedContextProvider] 11256 ); 11257 var useToolbarContext = ctx11.useContext; 11258 var useToolbarScopedContext = ctx11.useScopedContext; 11259 var useToolbarProviderContext = ctx11.useProviderContext; 11260 var ToolbarContextProvider = ctx11.ContextProvider; 11261 var ToolbarScopedContextProvider = ctx11.ScopedContextProvider; 11262 11263 // node_modules/@ariakit/react-core/esm/toolbar/toolbar.js 11264 var import_jsx_runtime24 = __toESM(require_jsx_runtime(), 1); 11265 var TagName47 = "div"; 11266 var useToolbar = createHook( 11267 function useToolbar2(_a) { 11268 var _b = _a, { 11269 store: storeProp, 11270 orientation: orientationProp, 11271 virtualFocus, 11272 focusLoop, 11273 rtl: rtl2 11274 } = _b, props = __objRest(_b, [ 11275 "store", 11276 "orientation", 11277 "virtualFocus", 11278 "focusLoop", 11279 "rtl" 11280 ]); 11281 const context = useToolbarProviderContext(); 11282 storeProp = storeProp || context; 11283 const store = useToolbarStore({ 11284 store: storeProp, 11285 orientation: orientationProp, 11286 virtualFocus, 11287 focusLoop, 11288 rtl: rtl2 11289 }); 11290 const orientation = store.useState( 11291 (state) => state.orientation === "both" ? void 0 : state.orientation 11292 ); 11293 props = useWrapElement( 11294 props, 11295 (element) => /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(ToolbarScopedContextProvider, { value: store, children: element }), 11296 [store] 11297 ); 11298 props = __spreadValues({ 11299 role: "toolbar", 11300 "aria-orientation": orientation 11301 }, props); 11302 props = useComposite(__spreadValues({ store }, props)); 11303 return props; 11304 } 11305 ); 11306 var Toolbar = forwardRef2(function Toolbar2(props) { 11307 const htmlProps = useToolbar(props); 11308 return createElement(TagName47, htmlProps); 11309 }); 11310 11311 // node_modules/@ariakit/react-core/esm/__chunks/BOLVLGVE.js 11312 var TagName48 = "button"; 11313 var useToolbarItem = createHook( 11314 function useToolbarItem2(_a) { 11315 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 11316 const context = useToolbarContext(); 11317 store = store || context; 11318 props = useCompositeItem(__spreadValues({ store }, props)); 11319 return props; 11320 } 11321 ); 11322 var ToolbarItem = memo2( 11323 forwardRef2(function ToolbarItem2(props) { 11324 const htmlProps = useToolbarItem(props); 11325 return createElement(TagName48, htmlProps); 11326 }) 11327 ); 11328 11329 // node_modules/@ariakit/react-core/esm/__chunks/KPEX55MY.js 11330 var import_react49 = __toESM(require_react(), 1); 11331 var ctx12 = createStoreContext( 11332 [PopoverContextProvider, CompositeContextProvider], 11333 [PopoverScopedContextProvider, CompositeScopedContextProvider] 11334 ); 11335 var useSelectContext = ctx12.useContext; 11336 var useSelectScopedContext = ctx12.useScopedContext; 11337 var useSelectProviderContext = ctx12.useProviderContext; 11338 var SelectContextProvider = ctx12.ContextProvider; 11339 var SelectScopedContextProvider = ctx12.ScopedContextProvider; 11340 var SelectItemCheckedContext = (0, import_react49.createContext)(false); 11341 var SelectHeadingContext = (0, import_react49.createContext)(null); 11342 11343 // node_modules/@ariakit/core/esm/tab/tab-store.js 11344 function createTabStore(_a = {}) { 11345 var _b = _a, { 11346 composite: parentComposite, 11347 combobox 11348 } = _b, props = __objRest2(_b, [ 11349 "composite", 11350 "combobox" 11351 ]); 11352 const independentKeys = [ 11353 "items", 11354 "renderedItems", 11355 "moves", 11356 "orientation", 11357 "virtualFocus", 11358 "includesBaseElement", 11359 "baseElement", 11360 "focusLoop", 11361 "focusShift", 11362 "focusWrap" 11363 ]; 11364 const store = mergeStore( 11365 props.store, 11366 omit2(parentComposite, independentKeys), 11367 omit2(combobox, independentKeys) 11368 ); 11369 const syncState = store == null ? void 0 : store.getState(); 11370 const composite = createCompositeStore(__spreadProps2(__spreadValues2({}, props), { 11371 store, 11372 // We need to explicitly set the default value of `includesBaseElement` to 11373 // `false` since we don't want the composite store to default it to `true` 11374 // when the activeId state is null, which could be the case when rendering 11375 // combobox with tab. 11376 includesBaseElement: defaultValue( 11377 props.includesBaseElement, 11378 syncState == null ? void 0 : syncState.includesBaseElement, 11379 false 11380 ), 11381 orientation: defaultValue( 11382 props.orientation, 11383 syncState == null ? void 0 : syncState.orientation, 11384 "horizontal" 11385 ), 11386 focusLoop: defaultValue(props.focusLoop, syncState == null ? void 0 : syncState.focusLoop, true) 11387 })); 11388 const panels = createCollectionStore(); 11389 const initialState = __spreadProps2(__spreadValues2({}, composite.getState()), { 11390 selectedId: defaultValue( 11391 props.selectedId, 11392 syncState == null ? void 0 : syncState.selectedId, 11393 props.defaultSelectedId 11394 ), 11395 selectOnMove: defaultValue( 11396 props.selectOnMove, 11397 syncState == null ? void 0 : syncState.selectOnMove, 11398 true 11399 ) 11400 }); 11401 const tab = createStore(initialState, composite, store); 11402 setup( 11403 tab, 11404 () => sync(tab, ["moves"], () => { 11405 const { activeId, selectOnMove } = tab.getState(); 11406 if (!selectOnMove) return; 11407 if (!activeId) return; 11408 const tabItem = composite.item(activeId); 11409 if (!tabItem) return; 11410 if (tabItem.dimmed) return; 11411 if (tabItem.disabled) return; 11412 tab.setState("selectedId", tabItem.id); 11413 }) 11414 ); 11415 let syncActiveId = true; 11416 setup( 11417 tab, 11418 () => batch(tab, ["selectedId"], (state, prev2) => { 11419 if (!syncActiveId) { 11420 syncActiveId = true; 11421 return; 11422 } 11423 if (parentComposite && state.selectedId === prev2.selectedId) return; 11424 tab.setState("activeId", state.selectedId); 11425 }) 11426 ); 11427 setup( 11428 tab, 11429 () => sync(tab, ["selectedId", "renderedItems"], (state) => { 11430 if (state.selectedId !== void 0) return; 11431 const { activeId, renderedItems } = tab.getState(); 11432 const tabItem = composite.item(activeId); 11433 if (tabItem && !tabItem.disabled && !tabItem.dimmed) { 11434 tab.setState("selectedId", tabItem.id); 11435 } else { 11436 const tabItem2 = renderedItems.find( 11437 (item2) => !item2.disabled && !item2.dimmed 11438 ); 11439 tab.setState("selectedId", tabItem2 == null ? void 0 : tabItem2.id); 11440 } 11441 }) 11442 ); 11443 setup( 11444 tab, 11445 () => sync(tab, ["renderedItems"], (state) => { 11446 const tabs = state.renderedItems; 11447 if (!tabs.length) return; 11448 return sync(panels, ["renderedItems"], (state2) => { 11449 const items = state2.renderedItems; 11450 const hasOrphanPanels = items.some((panel) => !panel.tabId); 11451 if (!hasOrphanPanels) return; 11452 items.forEach((panel, i3) => { 11453 if (panel.tabId) return; 11454 const tabItem = tabs[i3]; 11455 if (!tabItem) return; 11456 panels.renderItem(__spreadProps2(__spreadValues2({}, panel), { tabId: tabItem.id })); 11457 }); 11458 }); 11459 }) 11460 ); 11461 let selectedIdFromSelectedValue = null; 11462 setup(tab, () => { 11463 const backupSelectedId = () => { 11464 selectedIdFromSelectedValue = tab.getState().selectedId; 11465 }; 11466 const restoreSelectedId = () => { 11467 syncActiveId = false; 11468 tab.setState("selectedId", selectedIdFromSelectedValue); 11469 }; 11470 if (parentComposite && "setSelectElement" in parentComposite) { 11471 return chain( 11472 sync(parentComposite, ["value"], backupSelectedId), 11473 sync(parentComposite, ["mounted"], restoreSelectedId) 11474 ); 11475 } 11476 if (!combobox) return; 11477 return chain( 11478 sync(combobox, ["selectedValue"], backupSelectedId), 11479 sync(combobox, ["mounted"], restoreSelectedId) 11480 ); 11481 }); 11482 return __spreadProps2(__spreadValues2(__spreadValues2({}, composite), tab), { 11483 panels, 11484 setSelectedId: (id3) => tab.setState("selectedId", id3), 11485 select: (id3) => { 11486 tab.setState("selectedId", id3); 11487 composite.move(id3); 11488 } 11489 }); 11490 } 11491 11492 // node_modules/@ariakit/react-core/esm/__chunks/PY4NZ6HS.js 11493 var import_react50 = __toESM(require_react(), 1); 11494 function useTabStoreProps(store, update, props) { 11495 useUpdateEffect(update, [props.composite, props.combobox]); 11496 store = useCompositeStoreProps(store, update, props); 11497 useStoreProps(store, props, "selectedId", "setSelectedId"); 11498 useStoreProps(store, props, "selectOnMove"); 11499 const [panels, updatePanels] = useStore(() => store.panels, {}); 11500 useUpdateEffect(updatePanels, [store, updatePanels]); 11501 return Object.assign( 11502 (0, import_react50.useMemo)(() => __spreadProps(__spreadValues({}, store), { panels }), [store, panels]), 11503 { composite: props.composite, combobox: props.combobox } 11504 ); 11505 } 11506 function useTabStore(props = {}) { 11507 const combobox = useComboboxContext(); 11508 const composite = useSelectContext() || combobox; 11509 props = __spreadProps(__spreadValues({}, props), { 11510 composite: props.composite !== void 0 ? props.composite : composite, 11511 combobox: props.combobox !== void 0 ? props.combobox : combobox 11512 }); 11513 const [store, update] = useStore(createTabStore, props); 11514 return useTabStoreProps(store, update, props); 11515 } 11516 11517 // node_modules/@ariakit/react-core/esm/__chunks/UYGDZTLQ.js 11518 var ctx13 = createStoreContext( 11519 [CompositeContextProvider], 11520 [CompositeScopedContextProvider] 11521 ); 11522 var useTabContext = ctx13.useContext; 11523 var useTabScopedContext = ctx13.useScopedContext; 11524 var useTabProviderContext = ctx13.useProviderContext; 11525 var TabContextProvider = ctx13.ContextProvider; 11526 var TabScopedContextProvider = ctx13.ScopedContextProvider; 11527 11528 // node_modules/@ariakit/react-core/esm/tab/tab.js 11529 var import_react51 = __toESM(require_react(), 1); 11530 var import_jsx_runtime25 = __toESM(require_jsx_runtime(), 1); 11531 var TagName49 = "button"; 11532 var useTab = createHook(function useTab2(_a) { 11533 var _b = _a, { 11534 store, 11535 getItem: getItemProp 11536 } = _b, props = __objRest(_b, [ 11537 "store", 11538 "getItem" 11539 ]); 11540 var _a2; 11541 const context = useTabScopedContext(); 11542 store = store || context; 11543 invariant( 11544 store, 11545 "Tab must be wrapped in a TabList component." 11546 ); 11547 const defaultId = useId(); 11548 const id3 = props.id || defaultId; 11549 const dimmed = disabledFromProps(props); 11550 const getItem = (0, import_react51.useCallback)( 11551 (item2) => { 11552 const nextItem = __spreadProps(__spreadValues({}, item2), { dimmed }); 11553 if (getItemProp) { 11554 return getItemProp(nextItem); 11555 } 11556 return nextItem; 11557 }, 11558 [dimmed, getItemProp] 11559 ); 11560 const onClickProp = props.onClick; 11561 const onClick = useEvent((event) => { 11562 onClickProp == null ? void 0 : onClickProp(event); 11563 if (event.defaultPrevented) return; 11564 store == null ? void 0 : store.setSelectedId(id3); 11565 }); 11566 const panelId = store.panels.useState( 11567 (state) => { 11568 var _a3; 11569 return (_a3 = state.items.find((item2) => item2.tabId === id3)) == null ? void 0 : _a3.id; 11570 } 11571 ); 11572 const shouldRegisterItem = defaultId ? props.shouldRegisterItem : false; 11573 const isActive = store.useState((state) => !!id3 && state.activeId === id3); 11574 const selected = store.useState((state) => !!id3 && state.selectedId === id3); 11575 const hasActiveItem2 = store.useState((state) => !!store.item(state.activeId)); 11576 const canRegisterComposedItem = isActive || selected && !hasActiveItem2; 11577 const accessibleWhenDisabled = selected || ((_a2 = props.accessibleWhenDisabled) != null ? _a2 : true); 11578 const isWithinVirtualFocusComposite = useStoreState( 11579 store.combobox || store.composite, 11580 "virtualFocus" 11581 ); 11582 if (isWithinVirtualFocusComposite) { 11583 props = __spreadProps(__spreadValues({}, props), { 11584 tabIndex: -1 11585 }); 11586 } 11587 props = __spreadProps(__spreadValues({ 11588 id: id3, 11589 role: "tab", 11590 "aria-selected": selected, 11591 "aria-controls": panelId || void 0 11592 }, props), { 11593 onClick 11594 }); 11595 if (store.composite) { 11596 const defaultProps = { 11597 id: id3, 11598 accessibleWhenDisabled, 11599 store: store.composite, 11600 shouldRegisterItem: canRegisterComposedItem && shouldRegisterItem, 11601 rowId: props.rowId, 11602 render: props.render 11603 }; 11604 props = __spreadProps(__spreadValues({}, props), { 11605 render: /* @__PURE__ */ (0, import_jsx_runtime25.jsx)( 11606 CompositeItem, 11607 __spreadProps(__spreadValues({}, defaultProps), { 11608 render: store.combobox && store.composite !== store.combobox ? /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(CompositeItem, __spreadProps(__spreadValues({}, defaultProps), { store: store.combobox })) : defaultProps.render 11609 }) 11610 ) 11611 }); 11612 } 11613 props = useCompositeItem(__spreadProps(__spreadValues({ 11614 store 11615 }, props), { 11616 accessibleWhenDisabled, 11617 getItem, 11618 shouldRegisterItem 11619 })); 11620 return props; 11621 }); 11622 var Tab = memo2( 11623 forwardRef2(function Tab2(props) { 11624 const htmlProps = useTab(props); 11625 return createElement(TagName49, htmlProps); 11626 }) 11627 ); 11628 11629 // node_modules/@ariakit/react-core/esm/tab/tab-list.js 11630 var import_jsx_runtime26 = __toESM(require_jsx_runtime(), 1); 11631 var TagName50 = "div"; 11632 var useTabList = createHook( 11633 function useTabList2(_a) { 11634 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 11635 const context = useTabProviderContext(); 11636 store = store || context; 11637 invariant( 11638 store, 11639 "TabList must receive a `store` prop or be wrapped in a TabProvider component." 11640 ); 11641 const orientation = store.useState( 11642 (state) => state.orientation === "both" ? void 0 : state.orientation 11643 ); 11644 props = useWrapElement( 11645 props, 11646 (element) => /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(TabScopedContextProvider, { value: store, children: element }), 11647 [store] 11648 ); 11649 if (store.composite) { 11650 props = __spreadValues({ 11651 focusable: false 11652 }, props); 11653 } 11654 props = __spreadValues({ 11655 role: "tablist", 11656 "aria-orientation": orientation 11657 }, props); 11658 props = useComposite(__spreadValues({ store }, props)); 11659 return props; 11660 } 11661 ); 11662 var TabList = forwardRef2(function TabList2(props) { 11663 const htmlProps = useTabList(props); 11664 return createElement(TagName50, htmlProps); 11665 }); 11666 11667 // node_modules/@ariakit/react-core/esm/tab/tab-panel.js 11668 var import_react52 = __toESM(require_react(), 1); 11669 var import_jsx_runtime27 = __toESM(require_jsx_runtime(), 1); 11670 var TagName51 = "div"; 11671 var useTabPanel = createHook( 11672 function useTabPanel2(_a) { 11673 var _b = _a, { 11674 store, 11675 unmountOnHide, 11676 tabId: tabIdProp, 11677 getItem: getItemProp, 11678 scrollRestoration, 11679 scrollElement 11680 } = _b, props = __objRest(_b, [ 11681 "store", 11682 "unmountOnHide", 11683 "tabId", 11684 "getItem", 11685 "scrollRestoration", 11686 "scrollElement" 11687 ]); 11688 const context = useTabProviderContext(); 11689 store = store || context; 11690 invariant( 11691 store, 11692 "TabPanel must receive a `store` prop or be wrapped in a TabProvider component." 11693 ); 11694 const ref = (0, import_react52.useRef)(null); 11695 const id3 = useId(props.id); 11696 const tabId = useStoreState( 11697 store.panels, 11698 () => { 11699 var _a2; 11700 return tabIdProp || ((_a2 = store == null ? void 0 : store.panels.item(id3)) == null ? void 0 : _a2.tabId); 11701 } 11702 ); 11703 const open = useStoreState( 11704 store, 11705 (state) => !!tabId && state.selectedId === tabId 11706 ); 11707 const disclosure = useDisclosureStore({ open }); 11708 const mounted = useStoreState(disclosure, "mounted"); 11709 const scrollPositionRef = (0, import_react52.useRef)( 11710 /* @__PURE__ */ new Map() 11711 ); 11712 const getScrollElement = useEvent(() => { 11713 const panelElement = ref.current; 11714 if (!panelElement) return null; 11715 if (!scrollElement) return panelElement; 11716 if (typeof scrollElement === "function") { 11717 return scrollElement(panelElement); 11718 } 11719 if ("current" in scrollElement) { 11720 return scrollElement.current; 11721 } 11722 return scrollElement; 11723 }); 11724 (0, import_react52.useEffect)(() => { 11725 var _a2, _b2; 11726 if (!scrollRestoration) return; 11727 if (!mounted) return; 11728 const element = getScrollElement(); 11729 if (!element) return; 11730 if (scrollRestoration === "reset") { 11731 element.scroll(0, 0); 11732 return; 11733 } 11734 if (!tabId) return; 11735 const position2 = scrollPositionRef.current.get(tabId); 11736 element.scroll((_a2 = position2 == null ? void 0 : position2.x) != null ? _a2 : 0, (_b2 = position2 == null ? void 0 : position2.y) != null ? _b2 : 0); 11737 const onScroll = () => { 11738 scrollPositionRef.current.set(tabId, { 11739 x: element.scrollLeft, 11740 y: element.scrollTop 11741 }); 11742 }; 11743 element.addEventListener("scroll", onScroll); 11744 return () => { 11745 element.removeEventListener("scroll", onScroll); 11746 }; 11747 }, [scrollRestoration, mounted, tabId, getScrollElement, store]); 11748 const [hasTabbableChildren, setHasTabbableChildren] = (0, import_react52.useState)(false); 11749 (0, import_react52.useEffect)(() => { 11750 const element = ref.current; 11751 if (!element) return; 11752 const tabbable = getAllTabbableIn(element); 11753 setHasTabbableChildren(!!tabbable.length); 11754 }, []); 11755 const getItem = (0, import_react52.useCallback)( 11756 (item2) => { 11757 const nextItem = __spreadProps(__spreadValues({}, item2), { id: id3 || item2.id, tabId: tabIdProp }); 11758 if (getItemProp) { 11759 return getItemProp(nextItem); 11760 } 11761 return nextItem; 11762 }, 11763 [id3, tabIdProp, getItemProp] 11764 ); 11765 const onKeyDownProp = props.onKeyDown; 11766 const onKeyDown = useEvent((event) => { 11767 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 11768 if (event.defaultPrevented) return; 11769 if (!(store == null ? void 0 : store.composite)) return; 11770 const keyMap = { 11771 ArrowLeft: store.previous, 11772 ArrowRight: store.next, 11773 Home: store.first, 11774 End: store.last 11775 }; 11776 const action = keyMap[event.key]; 11777 if (!action) return; 11778 const { selectedId } = store.getState(); 11779 const nextId = action({ activeId: selectedId }); 11780 if (!nextId) return; 11781 event.preventDefault(); 11782 store.move(nextId); 11783 }); 11784 props = useWrapElement( 11785 props, 11786 (element) => /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(TabScopedContextProvider, { value: store, children: element }), 11787 [store] 11788 ); 11789 props = __spreadProps(__spreadValues({ 11790 id: id3, 11791 role: "tabpanel", 11792 "aria-labelledby": tabId || void 0 11793 }, props), { 11794 children: unmountOnHide && !mounted ? null : props.children, 11795 ref: useMergeRefs(ref, props.ref), 11796 onKeyDown 11797 }); 11798 props = useFocusable(__spreadValues({ 11799 // If the tab panel is rendered as part of another composite widget such 11800 // as combobox, it should not be focusable. 11801 focusable: !store.composite && !hasTabbableChildren 11802 }, props)); 11803 props = useDisclosureContent(__spreadValues({ store: disclosure }, props)); 11804 props = useCollectionItem(__spreadProps(__spreadValues({ store: store.panels }, props), { getItem })); 11805 return props; 11806 } 11807 ); 11808 var TabPanel = forwardRef2(function TabPanel2(props) { 11809 const htmlProps = useTabPanel(props); 11810 return createElement(TagName51, htmlProps); 11811 }); 11812 11813 // node_modules/@ariakit/core/esm/select/select-store.js 11814 function createSelectStore(_a = {}) { 11815 var _b = _a, { 11816 combobox 11817 } = _b, props = __objRest2(_b, [ 11818 "combobox" 11819 ]); 11820 const store = mergeStore( 11821 props.store, 11822 omit2(combobox, [ 11823 "value", 11824 "items", 11825 "renderedItems", 11826 "baseElement", 11827 "arrowElement", 11828 "anchorElement", 11829 "contentElement", 11830 "popoverElement", 11831 "disclosureElement" 11832 ]) 11833 ); 11834 throwOnConflictingProps(props, store); 11835 const syncState = store.getState(); 11836 const composite = createCompositeStore(__spreadProps2(__spreadValues2({}, props), { 11837 store, 11838 virtualFocus: defaultValue( 11839 props.virtualFocus, 11840 syncState.virtualFocus, 11841 true 11842 ), 11843 includesBaseElement: defaultValue( 11844 props.includesBaseElement, 11845 syncState.includesBaseElement, 11846 false 11847 ), 11848 activeId: defaultValue( 11849 props.activeId, 11850 syncState.activeId, 11851 props.defaultActiveId, 11852 null 11853 ), 11854 orientation: defaultValue( 11855 props.orientation, 11856 syncState.orientation, 11857 "vertical" 11858 ) 11859 })); 11860 const popover = createPopoverStore(__spreadProps2(__spreadValues2({}, props), { 11861 store, 11862 placement: defaultValue( 11863 props.placement, 11864 syncState.placement, 11865 "bottom-start" 11866 ) 11867 })); 11868 const initialValue2 = new String(""); 11869 const initialState = __spreadProps2(__spreadValues2(__spreadValues2({}, composite.getState()), popover.getState()), { 11870 value: defaultValue( 11871 props.value, 11872 syncState.value, 11873 props.defaultValue, 11874 initialValue2 11875 ), 11876 setValueOnMove: defaultValue( 11877 props.setValueOnMove, 11878 syncState.setValueOnMove, 11879 false 11880 ), 11881 labelElement: defaultValue(syncState.labelElement, null), 11882 selectElement: defaultValue(syncState.selectElement, null), 11883 listElement: defaultValue(syncState.listElement, null) 11884 }); 11885 const select = createStore(initialState, composite, popover, store); 11886 setup( 11887 select, 11888 () => sync(select, ["value", "items"], (state) => { 11889 if (state.value !== initialValue2) return; 11890 if (!state.items.length) return; 11891 const item2 = state.items.find( 11892 (item22) => !item22.disabled && item22.value != null 11893 ); 11894 if ((item2 == null ? void 0 : item2.value) == null) return; 11895 select.setState("value", item2.value); 11896 }) 11897 ); 11898 setup( 11899 select, 11900 () => sync(select, ["mounted"], (state) => { 11901 if (state.mounted) return; 11902 select.setState("activeId", initialState.activeId); 11903 }) 11904 ); 11905 setup( 11906 select, 11907 () => sync(select, ["mounted", "items", "value"], (state) => { 11908 if (combobox) return; 11909 if (state.mounted) return; 11910 const values = toArray(state.value); 11911 const lastValue = values[values.length - 1]; 11912 if (lastValue == null) return; 11913 const item2 = state.items.find( 11914 (item22) => !item22.disabled && item22.value === lastValue 11915 ); 11916 if (!item2) return; 11917 select.setState("activeId", item2.id); 11918 }) 11919 ); 11920 setup( 11921 select, 11922 () => batch(select, ["setValueOnMove", "moves"], (state) => { 11923 const { mounted, value, activeId } = select.getState(); 11924 if (!state.setValueOnMove && mounted) return; 11925 if (Array.isArray(value)) return; 11926 if (!state.moves) return; 11927 if (!activeId) return; 11928 const item2 = composite.item(activeId); 11929 if (!item2 || item2.disabled || item2.value == null) return; 11930 select.setState("value", item2.value); 11931 }) 11932 ); 11933 return __spreadProps2(__spreadValues2(__spreadValues2(__spreadValues2({}, composite), popover), select), { 11934 combobox, 11935 setValue: (value) => select.setState("value", value), 11936 setLabelElement: (element) => select.setState("labelElement", element), 11937 setSelectElement: (element) => select.setState("selectElement", element), 11938 setListElement: (element) => select.setState("listElement", element) 11939 }); 11940 } 11941 11942 // node_modules/@ariakit/react-core/esm/__chunks/S5WQ44SQ.js 11943 function useSelectStoreOptions(props) { 11944 const combobox = useComboboxProviderContext(); 11945 props = __spreadProps(__spreadValues({}, props), { 11946 combobox: props.combobox !== void 0 ? props.combobox : combobox 11947 }); 11948 return useCompositeStoreOptions(props); 11949 } 11950 function useSelectStoreProps(store, update, props) { 11951 useUpdateEffect(update, [props.combobox]); 11952 useStoreProps(store, props, "value", "setValue"); 11953 useStoreProps(store, props, "setValueOnMove"); 11954 return Object.assign( 11955 usePopoverStoreProps( 11956 useCompositeStoreProps(store, update, props), 11957 update, 11958 props 11959 ), 11960 { combobox: props.combobox } 11961 ); 11962 } 11963 function useSelectStore(props = {}) { 11964 props = useSelectStoreOptions(props); 11965 const [store, update] = useStore(createSelectStore, props); 11966 return useSelectStoreProps(store, update, props); 11967 } 11968 11969 // node_modules/@ariakit/react-core/esm/__chunks/UD53QJDV.js 11970 var TagName52 = "span"; 11971 var useSelectArrow = createHook( 11972 function useSelectArrow2(_a) { 11973 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 11974 const context = useSelectContext(); 11975 store = store || context; 11976 props = usePopoverDisclosureArrow(__spreadValues({ store }, props)); 11977 return props; 11978 } 11979 ); 11980 var SelectArrow = forwardRef2(function SelectArrow2(props) { 11981 const htmlProps = useSelectArrow(props); 11982 return createElement(TagName52, htmlProps); 11983 }); 11984 11985 // node_modules/@ariakit/react-core/esm/select/select.js 11986 var import_react53 = __toESM(require_react(), 1); 11987 var import_jsx_runtime28 = __toESM(require_jsx_runtime(), 1); 11988 var TagName53 = "button"; 11989 function getSelectedValues(select) { 11990 return Array.from(select.selectedOptions).map((option) => option.value); 11991 } 11992 function nextWithValue(store, next2) { 11993 return () => { 11994 const nextId = next2(); 11995 if (!nextId) return; 11996 let i3 = 0; 11997 let nextItem = store.item(nextId); 11998 const firstItem = nextItem; 11999 while (nextItem && nextItem.value == null) { 12000 const nextId2 = next2(++i3); 12001 if (!nextId2) return; 12002 nextItem = store.item(nextId2); 12003 if (nextItem === firstItem) break; 12004 } 12005 return nextItem == null ? void 0 : nextItem.id; 12006 }; 12007 } 12008 var useSelect = createHook(function useSelect2(_a) { 12009 var _b = _a, { 12010 store, 12011 name, 12012 form, 12013 required, 12014 showOnKeyDown = true, 12015 moveOnKeyDown = true, 12016 toggleOnPress = true, 12017 toggleOnClick = toggleOnPress 12018 } = _b, props = __objRest(_b, [ 12019 "store", 12020 "name", 12021 "form", 12022 "required", 12023 "showOnKeyDown", 12024 "moveOnKeyDown", 12025 "toggleOnPress", 12026 "toggleOnClick" 12027 ]); 12028 const context = useSelectProviderContext(); 12029 store = store || context; 12030 invariant( 12031 store, 12032 "Select must receive a `store` prop or be wrapped in a SelectProvider component." 12033 ); 12034 const onKeyDownProp = props.onKeyDown; 12035 const showOnKeyDownProp = useBooleanEvent(showOnKeyDown); 12036 const moveOnKeyDownProp = useBooleanEvent(moveOnKeyDown); 12037 const placement = store.useState("placement"); 12038 const dir = placement.split("-")[0]; 12039 const value = store.useState("value"); 12040 const multiSelectable = Array.isArray(value); 12041 const onKeyDown = useEvent((event) => { 12042 var _a2; 12043 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 12044 if (event.defaultPrevented) return; 12045 if (!store) return; 12046 const { orientation, items: items2, activeId } = store.getState(); 12047 const isVertical = orientation !== "horizontal"; 12048 const isHorizontal = orientation !== "vertical"; 12049 const isGrid2 = !!((_a2 = items2.find((item2) => !item2.disabled && item2.value != null)) == null ? void 0 : _a2.rowId); 12050 const moveKeyMap = { 12051 ArrowUp: (isGrid2 || isVertical) && nextWithValue(store, store.up), 12052 ArrowRight: (isGrid2 || isHorizontal) && nextWithValue(store, store.next), 12053 ArrowDown: (isGrid2 || isVertical) && nextWithValue(store, store.down), 12054 ArrowLeft: (isGrid2 || isHorizontal) && nextWithValue(store, store.previous) 12055 }; 12056 const getId = moveKeyMap[event.key]; 12057 if (getId && moveOnKeyDownProp(event)) { 12058 event.preventDefault(); 12059 store.move(getId()); 12060 } 12061 const isTopOrBottom = dir === "top" || dir === "bottom"; 12062 const isLeft = dir === "left"; 12063 const isRight = dir === "right"; 12064 const canShowKeyMap = { 12065 ArrowDown: isTopOrBottom, 12066 ArrowUp: isTopOrBottom, 12067 ArrowLeft: isLeft, 12068 ArrowRight: isRight 12069 }; 12070 const canShow = canShowKeyMap[event.key]; 12071 if (canShow && showOnKeyDownProp(event)) { 12072 event.preventDefault(); 12073 store.move(activeId); 12074 queueBeforeEvent(event.currentTarget, "keyup", store.show); 12075 } 12076 }); 12077 props = useWrapElement( 12078 props, 12079 (element) => /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(SelectScopedContextProvider, { value: store, children: element }), 12080 [store] 12081 ); 12082 const [autofill, setAutofill] = (0, import_react53.useState)(false); 12083 const nativeSelectChangedRef = (0, import_react53.useRef)(false); 12084 (0, import_react53.useEffect)(() => { 12085 const nativeSelectChanged = nativeSelectChangedRef.current; 12086 nativeSelectChangedRef.current = false; 12087 if (nativeSelectChanged) return; 12088 setAutofill(false); 12089 }, [value]); 12090 const labelId = store.useState((state) => { 12091 var _a2; 12092 return (_a2 = state.labelElement) == null ? void 0 : _a2.id; 12093 }); 12094 const label = props["aria-label"]; 12095 const labelledBy = props["aria-labelledby"] || labelId; 12096 const items = store.useState((state) => { 12097 if (!name) return; 12098 return state.items; 12099 }); 12100 const values = (0, import_react53.useMemo)(() => { 12101 return [...new Set(items == null ? void 0 : items.map((i3) => i3.value).filter((v3) => v3 != null))]; 12102 }, [items]); 12103 props = useWrapElement( 12104 props, 12105 (element) => { 12106 if (!name) return element; 12107 return /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)(import_jsx_runtime28.Fragment, { children: [ 12108 /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)( 12109 "select", 12110 { 12111 style: { 12112 border: 0, 12113 clip: "rect(0 0 0 0)", 12114 height: "1px", 12115 margin: "-1px", 12116 overflow: "hidden", 12117 padding: 0, 12118 position: "absolute", 12119 whiteSpace: "nowrap", 12120 width: "1px" 12121 }, 12122 tabIndex: -1, 12123 "aria-hidden": true, 12124 "aria-label": label, 12125 "aria-labelledby": labelledBy, 12126 name, 12127 form, 12128 required, 12129 value, 12130 multiple: multiSelectable, 12131 onFocus: () => { 12132 var _a2; 12133 return (_a2 = store == null ? void 0 : store.getState().selectElement) == null ? void 0 : _a2.focus(); 12134 }, 12135 onChange: (event) => { 12136 nativeSelectChangedRef.current = true; 12137 setAutofill(true); 12138 store == null ? void 0 : store.setValue( 12139 multiSelectable ? getSelectedValues(event.target) : event.target.value 12140 ); 12141 }, 12142 children: [ 12143 toArray(value).map((value2) => { 12144 if (value2 == null) return null; 12145 if (values.includes(value2)) return null; 12146 return /* @__PURE__ */ (0, import_jsx_runtime28.jsx)("option", { value: value2, children: value2 }, value2); 12147 }), 12148 values.map((value2) => /* @__PURE__ */ (0, import_jsx_runtime28.jsx)("option", { value: value2, children: value2 }, value2)) 12149 ] 12150 } 12151 ), 12152 element 12153 ] }); 12154 }, 12155 [ 12156 store, 12157 label, 12158 labelledBy, 12159 name, 12160 form, 12161 required, 12162 value, 12163 multiSelectable, 12164 values 12165 ] 12166 ); 12167 const children = /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)(import_jsx_runtime28.Fragment, { children: [ 12168 value, 12169 /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(SelectArrow, {}) 12170 ] }); 12171 const contentElement = store.useState("contentElement"); 12172 props = __spreadProps(__spreadValues({ 12173 role: "combobox", 12174 "aria-autocomplete": "none", 12175 "aria-labelledby": labelId, 12176 "aria-haspopup": getPopupRole(contentElement, "listbox"), 12177 "data-autofill": autofill || void 0, 12178 "data-name": name, 12179 children 12180 }, props), { 12181 ref: useMergeRefs(store.setSelectElement, props.ref), 12182 onKeyDown 12183 }); 12184 props = usePopoverDisclosure(__spreadValues({ store, toggleOnClick }, props)); 12185 props = useCompositeTypeahead(__spreadValues({ store }, props)); 12186 return props; 12187 }); 12188 var Select = forwardRef2(function Select2(props) { 12189 const htmlProps = useSelect(props); 12190 return createElement(TagName53, htmlProps); 12191 }); 12192 12193 // node_modules/@ariakit/react-core/esm/select/select-item-check.js 12194 var import_react54 = __toESM(require_react(), 1); 12195 var TagName54 = "span"; 12196 var useSelectItemCheck = createHook( 12197 function useSelectItemCheck2(_a) { 12198 var _b = _a, { store, checked } = _b, props = __objRest(_b, ["store", "checked"]); 12199 const context = (0, import_react54.useContext)(SelectItemCheckedContext); 12200 checked = checked != null ? checked : context; 12201 props = useCheckboxCheck(__spreadProps(__spreadValues({}, props), { checked })); 12202 return props; 12203 } 12204 ); 12205 var SelectItemCheck = forwardRef2(function SelectItemCheck2(props) { 12206 const htmlProps = useSelectItemCheck(props); 12207 return createElement(TagName54, htmlProps); 12208 }); 12209 12210 // node_modules/@ariakit/react-core/esm/__chunks/YF2ICFG4.js 12211 var import_react55 = __toESM(require_react(), 1); 12212 var import_jsx_runtime29 = __toESM(require_jsx_runtime(), 1); 12213 var TagName55 = "div"; 12214 function isSelected(storeValue, itemValue) { 12215 if (itemValue == null) return; 12216 if (storeValue == null) return false; 12217 if (Array.isArray(storeValue)) { 12218 return storeValue.includes(itemValue); 12219 } 12220 return storeValue === itemValue; 12221 } 12222 var useSelectItem = createHook( 12223 function useSelectItem2(_a) { 12224 var _b = _a, { 12225 store, 12226 value, 12227 getItem: getItemProp, 12228 hideOnClick, 12229 setValueOnClick = value != null, 12230 preventScrollOnKeyDown = true, 12231 focusOnHover = true 12232 } = _b, props = __objRest(_b, [ 12233 "store", 12234 "value", 12235 "getItem", 12236 "hideOnClick", 12237 "setValueOnClick", 12238 "preventScrollOnKeyDown", 12239 "focusOnHover" 12240 ]); 12241 var _a2; 12242 const context = useSelectScopedContext(); 12243 store = store || context; 12244 invariant( 12245 store, 12246 "SelectItem must be wrapped in a SelectList or SelectPopover component." 12247 ); 12248 const id3 = useId(props.id); 12249 const disabled = disabledFromProps(props); 12250 const { listElement, multiSelectable, selected, autoFocus } = useStoreStateObject(store, { 12251 listElement: "listElement", 12252 multiSelectable(state) { 12253 return Array.isArray(state.value); 12254 }, 12255 selected(state) { 12256 return isSelected(state.value, value); 12257 }, 12258 autoFocus(state) { 12259 if (value == null) return false; 12260 if (state.value == null) return false; 12261 if (state.activeId !== id3 && (store == null ? void 0 : store.item(state.activeId))) { 12262 return false; 12263 } 12264 if (Array.isArray(state.value)) { 12265 return state.value[state.value.length - 1] === value; 12266 } 12267 return state.value === value; 12268 } 12269 }); 12270 const getItem = (0, import_react55.useCallback)( 12271 (item2) => { 12272 const nextItem = __spreadProps(__spreadValues({}, item2), { 12273 value: disabled ? void 0 : value, 12274 children: value 12275 }); 12276 if (getItemProp) { 12277 return getItemProp(nextItem); 12278 } 12279 return nextItem; 12280 }, 12281 [disabled, value, getItemProp] 12282 ); 12283 hideOnClick = hideOnClick != null ? hideOnClick : value != null && !multiSelectable; 12284 const onClickProp = props.onClick; 12285 const setValueOnClickProp = useBooleanEvent(setValueOnClick); 12286 const hideOnClickProp = useBooleanEvent(hideOnClick); 12287 const onClick = useEvent((event) => { 12288 onClickProp == null ? void 0 : onClickProp(event); 12289 if (event.defaultPrevented) return; 12290 if (isDownloading(event)) return; 12291 if (isOpeningInNewTab(event)) return; 12292 if (setValueOnClickProp(event) && value != null) { 12293 store == null ? void 0 : store.setValue((prevValue) => { 12294 if (!Array.isArray(prevValue)) return value; 12295 if (prevValue.includes(value)) { 12296 return prevValue.filter((v3) => v3 !== value); 12297 } 12298 return [...prevValue, value]; 12299 }); 12300 } 12301 if (hideOnClickProp(event)) { 12302 store == null ? void 0 : store.hide(); 12303 } 12304 }); 12305 props = useWrapElement( 12306 props, 12307 (element) => /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(SelectItemCheckedContext.Provider, { value: selected != null ? selected : false, children: element }), 12308 [selected] 12309 ); 12310 props = __spreadProps(__spreadValues({ 12311 id: id3, 12312 role: getPopupItemRole(listElement), 12313 "aria-selected": selected, 12314 children: value 12315 }, props), { 12316 autoFocus: (_a2 = props.autoFocus) != null ? _a2 : autoFocus, 12317 onClick 12318 }); 12319 props = useCompositeItem(__spreadValues({ 12320 store, 12321 getItem, 12322 preventScrollOnKeyDown 12323 }, props)); 12324 const focusOnHoverProp = useBooleanEvent(focusOnHover); 12325 props = useCompositeHover(__spreadProps(__spreadValues({ 12326 store 12327 }, props), { 12328 // We have to disable focusOnHover when the popup is closed, otherwise 12329 // the active item will change to null (the container) when the popup is 12330 // closed by clicking on an item. 12331 focusOnHover(event) { 12332 if (!focusOnHoverProp(event)) return false; 12333 const state = store == null ? void 0 : store.getState(); 12334 return !!(state == null ? void 0 : state.open); 12335 } 12336 })); 12337 return props; 12338 } 12339 ); 12340 var SelectItem = memo2( 12341 forwardRef2(function SelectItem2(props) { 12342 const htmlProps = useSelectItem(props); 12343 return createElement(TagName55, htmlProps); 12344 }) 12345 ); 12346 12347 // node_modules/@ariakit/react-core/esm/select/select-label.js 12348 var TagName56 = "div"; 12349 var useSelectLabel = createHook( 12350 function useSelectLabel2(_a) { 12351 var _b = _a, { store } = _b, props = __objRest(_b, ["store"]); 12352 const context = useSelectProviderContext(); 12353 store = store || context; 12354 invariant( 12355 store, 12356 "SelectLabel must receive a `store` prop or be wrapped in a SelectProvider component." 12357 ); 12358 const id3 = useId(props.id); 12359 const onClickProp = props.onClick; 12360 const onClick = useEvent((event) => { 12361 onClickProp == null ? void 0 : onClickProp(event); 12362 if (event.defaultPrevented) return; 12363 queueMicrotask(() => { 12364 const select = store == null ? void 0 : store.getState().selectElement; 12365 select == null ? void 0 : select.focus(); 12366 }); 12367 }); 12368 props = __spreadProps(__spreadValues({ 12369 id: id3 12370 }, props), { 12371 ref: useMergeRefs(store.setLabelElement, props.ref), 12372 onClick, 12373 style: __spreadValues({ 12374 cursor: "default" 12375 }, props.style) 12376 }); 12377 return removeUndefinedValues(props); 12378 } 12379 ); 12380 var SelectLabel = memo2( 12381 forwardRef2(function SelectLabel2(props) { 12382 const htmlProps = useSelectLabel(props); 12383 return createElement(TagName56, htmlProps); 12384 }) 12385 ); 12386 12387 // node_modules/@ariakit/react-core/esm/__chunks/XRBJGF7I.js 12388 var import_react56 = __toESM(require_react(), 1); 12389 var import_jsx_runtime30 = __toESM(require_jsx_runtime(), 1); 12390 var TagName57 = "div"; 12391 var SelectListContext = (0, import_react56.createContext)(null); 12392 var useSelectList = createHook( 12393 function useSelectList2(_a) { 12394 var _b = _a, { 12395 store, 12396 resetOnEscape = true, 12397 hideOnEnter = true, 12398 focusOnMove = true, 12399 composite, 12400 alwaysVisible 12401 } = _b, props = __objRest(_b, [ 12402 "store", 12403 "resetOnEscape", 12404 "hideOnEnter", 12405 "focusOnMove", 12406 "composite", 12407 "alwaysVisible" 12408 ]); 12409 const context = useSelectContext(); 12410 store = store || context; 12411 invariant( 12412 store, 12413 "SelectList must receive a `store` prop or be wrapped in a SelectProvider component." 12414 ); 12415 const id3 = useId(props.id); 12416 const value = store.useState("value"); 12417 const multiSelectable = Array.isArray(value); 12418 const [defaultValue2, setDefaultValue] = (0, import_react56.useState)(value); 12419 const mounted = store.useState("mounted"); 12420 (0, import_react56.useEffect)(() => { 12421 if (mounted) return; 12422 setDefaultValue(value); 12423 }, [mounted, value]); 12424 resetOnEscape = resetOnEscape && !multiSelectable; 12425 const onKeyDownProp = props.onKeyDown; 12426 const resetOnEscapeProp = useBooleanEvent(resetOnEscape); 12427 const hideOnEnterProp = useBooleanEvent(hideOnEnter); 12428 const onKeyDown = useEvent((event) => { 12429 onKeyDownProp == null ? void 0 : onKeyDownProp(event); 12430 if (event.defaultPrevented) return; 12431 if (event.key === "Escape" && resetOnEscapeProp(event)) { 12432 store == null ? void 0 : store.setValue(defaultValue2); 12433 } 12434 if (event.key === " " || event.key === "Enter") { 12435 if (isSelfTarget(event) && hideOnEnterProp(event)) { 12436 event.preventDefault(); 12437 store == null ? void 0 : store.hide(); 12438 } 12439 } 12440 }); 12441 const headingContext = (0, import_react56.useContext)(SelectHeadingContext); 12442 const headingState = (0, import_react56.useState)(); 12443 const [headingId, setHeadingId] = headingContext || headingState; 12444 const headingContextValue = (0, import_react56.useMemo)( 12445 () => [headingId, setHeadingId], 12446 [headingId] 12447 ); 12448 const [childStore, setChildStore] = (0, import_react56.useState)(null); 12449 const setStore = (0, import_react56.useContext)(SelectListContext); 12450 (0, import_react56.useEffect)(() => { 12451 if (!setStore) return; 12452 setStore(store); 12453 return () => setStore(null); 12454 }, [setStore, store]); 12455 props = useWrapElement( 12456 props, 12457 (element2) => /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(SelectScopedContextProvider, { value: store, children: /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(SelectListContext.Provider, { value: setChildStore, children: /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(SelectHeadingContext.Provider, { value: headingContextValue, children: element2 }) }) }), 12458 [store, headingContextValue] 12459 ); 12460 const hasCombobox = !!store.combobox; 12461 composite = composite != null ? composite : !hasCombobox && childStore !== store; 12462 const [element, setElement] = useTransactionState( 12463 composite ? store.setListElement : null 12464 ); 12465 const role = useAttribute(element, "role", props.role); 12466 const isCompositeRole = role === "listbox" || role === "menu" || role === "tree" || role === "grid"; 12467 const ariaMultiSelectable = composite || isCompositeRole ? multiSelectable || void 0 : void 0; 12468 const hidden = isHidden(mounted, props.hidden, alwaysVisible); 12469 const style2 = hidden ? __spreadProps(__spreadValues({}, props.style), { display: "none" }) : props.style; 12470 if (composite) { 12471 props = __spreadValues({ 12472 role: "listbox", 12473 "aria-multiselectable": ariaMultiSelectable 12474 }, props); 12475 } 12476 const labelId = store.useState( 12477 (state) => { 12478 var _a2; 12479 return headingId || ((_a2 = state.labelElement) == null ? void 0 : _a2.id); 12480 } 12481 ); 12482 props = __spreadProps(__spreadValues({ 12483 id: id3, 12484 "aria-labelledby": labelId, 12485 hidden 12486 }, props), { 12487 ref: useMergeRefs(setElement, props.ref), 12488 style: style2, 12489 onKeyDown 12490 }); 12491 props = useComposite(__spreadProps(__spreadValues({ store }, props), { composite })); 12492 props = useCompositeTypeahead(__spreadValues({ store, typeahead: !hasCombobox }, props)); 12493 return props; 12494 } 12495 ); 12496 var SelectList = forwardRef2(function SelectList2(props) { 12497 const htmlProps = useSelectList(props); 12498 return createElement(TagName57, htmlProps); 12499 }); 12500 12501 // node_modules/@ariakit/react-core/esm/select/select-popover.js 12502 var TagName58 = "div"; 12503 var useSelectPopover = createHook( 12504 function useSelectPopover2(_a) { 12505 var _b = _a, { store, alwaysVisible } = _b, props = __objRest(_b, ["store", "alwaysVisible"]); 12506 const context = useSelectProviderContext(); 12507 store = store || context; 12508 props = useSelectList(__spreadValues({ store, alwaysVisible }, props)); 12509 props = usePopover(__spreadValues({ store, alwaysVisible }, props)); 12510 return props; 12511 } 12512 ); 12513 var SelectPopover = createDialogComponent( 12514 forwardRef2(function SelectPopover2(props) { 12515 const htmlProps = useSelectPopover(props); 12516 return createElement(TagName58, htmlProps); 12517 }), 12518 useSelectProviderContext 12519 ); 12520 12521 // packages/components/build-module/composite/index.js 12522 var import_i18n = __toESM(require_i18n()); 12523 var import_element8 = __toESM(require_element()); 12524 12525 // packages/components/build-module/composite/context.js 12526 var import_element = __toESM(require_element()); 12527 var CompositeContext = (0, import_element.createContext)({}); 12528 CompositeContext.displayName = "CompositeContext"; 12529 var useCompositeContext2 = () => (0, import_element.useContext)(CompositeContext); 12530 12531 // packages/components/build-module/composite/group.js 12532 var import_element2 = __toESM(require_element()); 12533 var import_jsx_runtime31 = __toESM(require_jsx_runtime()); 12534 var CompositeGroup22 = (0, import_element2.forwardRef)(function CompositeGroup3(props, ref) { 12535 var _props$store; 12536 const context = useCompositeContext2(); 12537 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12538 return /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(CompositeGroup, { 12539 store, 12540 ...props, 12541 ref 12542 }); 12543 }); 12544 12545 // packages/components/build-module/composite/group-label.js 12546 var import_element3 = __toESM(require_element()); 12547 var import_jsx_runtime32 = __toESM(require_jsx_runtime()); 12548 var CompositeGroupLabel22 = (0, import_element3.forwardRef)(function CompositeGroupLabel3(props, ref) { 12549 var _props$store; 12550 const context = useCompositeContext2(); 12551 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12552 return /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(CompositeGroupLabel, { 12553 store, 12554 ...props, 12555 ref 12556 }); 12557 }); 12558 12559 // packages/components/build-module/composite/hover.js 12560 var import_element4 = __toESM(require_element()); 12561 var import_jsx_runtime33 = __toESM(require_jsx_runtime()); 12562 var CompositeHover22 = (0, import_element4.forwardRef)(function CompositeHover3(props, ref) { 12563 var _props$store; 12564 const context = useCompositeContext2(); 12565 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12566 return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(CompositeHover, { 12567 store, 12568 ...props, 12569 ref 12570 }); 12571 }); 12572 12573 // packages/components/build-module/composite/item.js 12574 var import_element5 = __toESM(require_element()); 12575 var import_jsx_runtime34 = __toESM(require_jsx_runtime()); 12576 var CompositeItem22 = (0, import_element5.forwardRef)(function CompositeItem3(props, ref) { 12577 var _props$store; 12578 const context = useCompositeContext2(); 12579 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12580 return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(CompositeItem, { 12581 store, 12582 ...props, 12583 ref 12584 }); 12585 }); 12586 12587 // packages/components/build-module/composite/row.js 12588 var import_element6 = __toESM(require_element()); 12589 var import_jsx_runtime35 = __toESM(require_jsx_runtime()); 12590 var CompositeRow22 = (0, import_element6.forwardRef)(function CompositeRow3(props, ref) { 12591 var _props$store; 12592 const context = useCompositeContext2(); 12593 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12594 return /* @__PURE__ */ (0, import_jsx_runtime35.jsx)(CompositeRow, { 12595 store, 12596 ...props, 12597 ref 12598 }); 12599 }); 12600 12601 // packages/components/build-module/composite/typeahead.js 12602 var import_element7 = __toESM(require_element()); 12603 var import_jsx_runtime36 = __toESM(require_jsx_runtime()); 12604 var CompositeTypeahead22 = (0, import_element7.forwardRef)(function CompositeTypeahead3(props, ref) { 12605 var _props$store; 12606 const context = useCompositeContext2(); 12607 const store = (_props$store = props.store) !== null && _props$store !== void 0 ? _props$store : context.store; 12608 return /* @__PURE__ */ (0, import_jsx_runtime36.jsx)(CompositeTypeahead, { 12609 store, 12610 ...props, 12611 ref 12612 }); 12613 }); 12614 12615 // packages/components/build-module/composite/index.js 12616 var import_jsx_runtime37 = __toESM(require_jsx_runtime()); 12617 var Composite22 = Object.assign((0, import_element8.forwardRef)(function Composite3({ 12618 // Composite store props 12619 activeId, 12620 defaultActiveId, 12621 setActiveId, 12622 focusLoop = false, 12623 focusWrap = false, 12624 focusShift = false, 12625 virtualFocus = false, 12626 orientation = "both", 12627 rtl: rtl2 = (0, import_i18n.isRTL)(), 12628 // Composite component props 12629 children, 12630 disabled = false, 12631 // Rest props 12632 ...props 12633 }, ref) { 12634 const storeProp = props.store; 12635 const internalStore = useCompositeStore({ 12636 activeId, 12637 defaultActiveId, 12638 setActiveId, 12639 focusLoop, 12640 focusWrap, 12641 focusShift, 12642 virtualFocus, 12643 orientation, 12644 rtl: rtl2 12645 }); 12646 const store = storeProp !== null && storeProp !== void 0 ? storeProp : internalStore; 12647 const contextValue = (0, import_element8.useMemo)(() => ({ 12648 store 12649 }), [store]); 12650 return /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(Composite, { 12651 disabled, 12652 store, 12653 ...props, 12654 ref, 12655 children: /* @__PURE__ */ (0, import_jsx_runtime37.jsx)(CompositeContext.Provider, { 12656 value: contextValue, 12657 children 12658 }) 12659 }); 12660 }), { 12661 /** 12662 * Renders a group element for composite items. 12663 * 12664 * @example 12665 * ```jsx 12666 * import { Composite } from '@wordpress/components'; 12667 * 12668 * <Composite> 12669 * <Composite.Group> 12670 * <Composite.GroupLabel>Label</Composite.GroupLabel> 12671 * <Composite.Item>Item 1</Composite.Item> 12672 * <Composite.Item>Item 2</Composite.Item> 12673 * </CompositeGroup> 12674 * </Composite> 12675 * ``` 12676 */ 12677 Group: Object.assign(CompositeGroup22, { 12678 displayName: "Composite.Group" 12679 }), 12680 /** 12681 * Renders a label in a composite group. This component must be wrapped with 12682 * `Composite.Group` so the `aria-labelledby` prop is properly set on the 12683 * composite group element. 12684 * 12685 * @example 12686 * ```jsx 12687 * import { Composite } from '@wordpress/components'; 12688 * 12689 * <Composite> 12690 * <Composite.Group> 12691 * <Composite.GroupLabel>Label</Composite.GroupLabel> 12692 * <Composite.Item>Item 1</Composite.Item> 12693 * <Composite.Item>Item 2</Composite.Item> 12694 * </CompositeGroup> 12695 * </Composite> 12696 * ``` 12697 */ 12698 GroupLabel: Object.assign(CompositeGroupLabel22, { 12699 displayName: "Composite.GroupLabel" 12700 }), 12701 /** 12702 * Renders a composite item. 12703 * 12704 * @example 12705 * ```jsx 12706 * import { Composite } from '@wordpress/components'; 12707 * 12708 * <Composite> 12709 * <Composite.Item>Item 1</Composite.Item> 12710 * <Composite.Item>Item 2</Composite.Item> 12711 * <Composite.Item>Item 3</Composite.Item> 12712 * </Composite> 12713 * ``` 12714 */ 12715 Item: Object.assign(CompositeItem22, { 12716 displayName: "Composite.Item" 12717 }), 12718 /** 12719 * Renders a composite row. Wrapping `Composite.Item` elements within 12720 * `Composite.Row` will create a two-dimensional composite widget, such as a 12721 * grid. 12722 * 12723 * @example 12724 * ```jsx 12725 * import { Composite } from '@wordpress/components'; 12726 * 12727 * <Composite> 12728 * <Composite.Row> 12729 * <Composite.Item>Item 1.1</Composite.Item> 12730 * <Composite.Item>Item 1.2</Composite.Item> 12731 * <Composite.Item>Item 1.3</Composite.Item> 12732 * </Composite.Row> 12733 * <Composite.Row> 12734 * <Composite.Item>Item 2.1</Composite.Item> 12735 * <Composite.Item>Item 2.2</Composite.Item> 12736 * <Composite.Item>Item 2.3</Composite.Item> 12737 * </Composite.Row> 12738 * </Composite> 12739 * ``` 12740 */ 12741 Row: Object.assign(CompositeRow22, { 12742 displayName: "Composite.Row" 12743 }), 12744 /** 12745 * Renders an element in a composite widget that receives focus on mouse move 12746 * and loses focus to the composite base element on mouse leave. This should 12747 * be combined with the `Composite.Item` component. 12748 * 12749 * @example 12750 * ```jsx 12751 * import { Composite } from '@wordpress/components'; 12752 * 12753 * <Composite> 12754 * <Composite.Hover render={ <Composite.Item /> }> 12755 * Item 1 12756 * </Composite.Hover> 12757 * <Composite.Hover render={ <Composite.Item /> }> 12758 * Item 2 12759 * </Composite.Hover> 12760 * </Composite> 12761 * ``` 12762 */ 12763 Hover: Object.assign(CompositeHover22, { 12764 displayName: "Composite.Hover" 12765 }), 12766 /** 12767 * Renders a component that adds typeahead functionality to composite 12768 * components. Hitting printable character keys will move focus to the next 12769 * composite item that begins with the input characters. 12770 * 12771 * @example 12772 * ```jsx 12773 * import { Composite } from '@wordpress/components'; 12774 * 12775 * <Composite render={ <CompositeTypeahead /> }> 12776 * <Composite.Item>Item 1</Composite.Item> 12777 * <Composite.Item>Item 2</Composite.Item> 12778 * </Composite> 12779 * ``` 12780 */ 12781 Typeahead: Object.assign(CompositeTypeahead22, { 12782 displayName: "Composite.Typeahead" 12783 }), 12784 /** 12785 * The React context used by the composite components. It can be used by 12786 * to access the composite store, and to forward the context when composite 12787 * sub-components are rendered across portals (ie. `SlotFill` components) 12788 * that would not otherwise forward the context to the `Fill` children. 12789 * 12790 * @example 12791 * ```jsx 12792 * import { Composite } from '@wordpress/components'; 12793 * import { useContext } from '@wordpress/element'; 12794 * 12795 * const compositeContext = useContext( Composite.Context ); 12796 * ``` 12797 */ 12798 Context: Object.assign(CompositeContext, { 12799 displayName: "Composite.Context" 12800 }) 12801 }); 12802 12803 // packages/components/build-module/tooltip/index.js 12804 var import_compose = __toESM(require_compose()); 12805 var import_element9 = __toESM(require_element()); 12806 var import_deprecated = __toESM(require_deprecated()); 12807 12808 // packages/components/build-module/shortcut/index.js 12809 var import_jsx_runtime38 = __toESM(require_jsx_runtime()); 12810 function Shortcut(props) { 12811 const { 12812 shortcut, 12813 className: className2 12814 } = props; 12815 if (!shortcut) { 12816 return null; 12817 } 12818 let displayText; 12819 let ariaLabel; 12820 if (typeof shortcut === "string") { 12821 displayText = shortcut; 12822 } 12823 if (shortcut !== null && typeof shortcut === "object") { 12824 displayText = shortcut.display; 12825 ariaLabel = shortcut.ariaLabel; 12826 } 12827 return /* @__PURE__ */ (0, import_jsx_runtime38.jsx)("span", { 12828 className: className2, 12829 "aria-label": ariaLabel, 12830 children: displayText 12831 }); 12832 } 12833 var shortcut_default = Shortcut; 12834 12835 // packages/components/node_modules/framer-motion/dist/es/utils/warn-once.mjs 12836 var warned = /* @__PURE__ */ new Set(); 12837 function warnOnce(condition, message3, element) { 12838 if (condition || warned.has(message3)) 12839 return; 12840 console.warn(message3); 12841 if (element) 12842 console.warn(element); 12843 warned.add(message3); 12844 } 12845 12846 // packages/components/node_modules/framer-motion/dist/es/render/components/create-proxy.mjs 12847 function createDOMMotionComponentProxy(componentFactory) { 12848 if (typeof Proxy === "undefined") { 12849 return componentFactory; 12850 } 12851 const componentCache = /* @__PURE__ */ new Map(); 12852 const deprecatedFactoryFunction = (...args) => { 12853 if (true) { 12854 warnOnce(false, "motion() is deprecated. Use motion.create() instead."); 12855 } 12856 return componentFactory(...args); 12857 }; 12858 return new Proxy(deprecatedFactoryFunction, { 12859 /** 12860 * Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc. 12861 * The prop name is passed through as `key` and we can use that to generate a `motion` 12862 * DOM component with that name. 12863 */ 12864 get: (_target, key) => { 12865 if (key === "create") 12866 return componentFactory; 12867 if (!componentCache.has(key)) { 12868 componentCache.set(key, componentFactory(key)); 12869 } 12870 return componentCache.get(key); 12871 } 12872 }); 12873 } 12874 12875 // packages/components/node_modules/framer-motion/dist/es/animation/utils/is-animation-controls.mjs 12876 function isAnimationControls(v3) { 12877 return v3 !== null && typeof v3 === "object" && typeof v3.start === "function"; 12878 } 12879 12880 // packages/components/node_modules/framer-motion/dist/es/animation/utils/is-keyframes-target.mjs 12881 var isKeyframesTarget = (v3) => { 12882 return Array.isArray(v3); 12883 }; 12884 12885 // packages/components/node_modules/framer-motion/dist/es/utils/shallow-compare.mjs 12886 function shallowCompare(next2, prev2) { 12887 if (!Array.isArray(prev2)) 12888 return false; 12889 const prevLength = prev2.length; 12890 if (prevLength !== next2.length) 12891 return false; 12892 for (let i3 = 0; i3 < prevLength; i3++) { 12893 if (prev2[i3] !== next2[i3]) 12894 return false; 12895 } 12896 return true; 12897 } 12898 12899 // packages/components/node_modules/framer-motion/dist/es/render/utils/is-variant-label.mjs 12900 function isVariantLabel(v3) { 12901 return typeof v3 === "string" || Array.isArray(v3); 12902 } 12903 12904 // packages/components/node_modules/framer-motion/dist/es/render/utils/resolve-variants.mjs 12905 function getValueState(visualElement) { 12906 const state = [{}, {}]; 12907 visualElement === null || visualElement === void 0 ? void 0 : visualElement.values.forEach((value, key) => { 12908 state[0][key] = value.get(); 12909 state[1][key] = value.getVelocity(); 12910 }); 12911 return state; 12912 } 12913 function resolveVariantFromProps(props, definition, custom, visualElement) { 12914 if (typeof definition === "function") { 12915 const [current, velocity] = getValueState(visualElement); 12916 definition = definition(custom !== void 0 ? custom : props.custom, current, velocity); 12917 } 12918 if (typeof definition === "string") { 12919 definition = props.variants && props.variants[definition]; 12920 } 12921 if (typeof definition === "function") { 12922 const [current, velocity] = getValueState(visualElement); 12923 definition = definition(custom !== void 0 ? custom : props.custom, current, velocity); 12924 } 12925 return definition; 12926 } 12927 12928 // packages/components/node_modules/framer-motion/dist/es/render/utils/resolve-dynamic-variants.mjs 12929 function resolveVariant(visualElement, definition, custom) { 12930 const props = visualElement.getProps(); 12931 return resolveVariantFromProps(props, definition, custom !== void 0 ? custom : props.custom, visualElement); 12932 } 12933 12934 // packages/components/node_modules/framer-motion/dist/es/render/utils/variant-props.mjs 12935 var variantPriorityOrder = [ 12936 "animate", 12937 "whileInView", 12938 "whileFocus", 12939 "whileHover", 12940 "whileTap", 12941 "whileDrag", 12942 "exit" 12943 ]; 12944 var variantProps = ["initial", ...variantPriorityOrder]; 12945 12946 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/transform.mjs 12947 var transformPropOrder = [ 12948 "transformPerspective", 12949 "x", 12950 "y", 12951 "z", 12952 "translateX", 12953 "translateY", 12954 "translateZ", 12955 "scale", 12956 "scaleX", 12957 "scaleY", 12958 "rotate", 12959 "rotateX", 12960 "rotateY", 12961 "rotateZ", 12962 "skew", 12963 "skewX", 12964 "skewY" 12965 ]; 12966 var transformProps = new Set(transformPropOrder); 12967 12968 // packages/components/node_modules/framer-motion/dist/es/utils/time-conversion.mjs 12969 var secondsToMilliseconds = (seconds) => seconds * 1e3; 12970 var millisecondsToSeconds = (milliseconds) => milliseconds / 1e3; 12971 12972 // packages/components/node_modules/framer-motion/dist/es/animation/utils/default-transitions.mjs 12973 var underDampedSpring = { 12974 type: "spring", 12975 stiffness: 500, 12976 damping: 25, 12977 restSpeed: 10 12978 }; 12979 var criticallyDampedSpring = (target) => ({ 12980 type: "spring", 12981 stiffness: 550, 12982 damping: target === 0 ? 2 * Math.sqrt(550) : 30, 12983 restSpeed: 10 12984 }); 12985 var keyframesTransition = { 12986 type: "keyframes", 12987 duration: 0.8 12988 }; 12989 var ease = { 12990 type: "keyframes", 12991 ease: [0.25, 0.1, 0.35, 1], 12992 duration: 0.3 12993 }; 12994 var getDefaultTransition = (valueKey, { keyframes: keyframes5 }) => { 12995 if (keyframes5.length > 2) { 12996 return keyframesTransition; 12997 } else if (transformProps.has(valueKey)) { 12998 return valueKey.startsWith("scale") ? criticallyDampedSpring(keyframes5[1]) : underDampedSpring; 12999 } 13000 return ease; 13001 }; 13002 13003 // packages/components/node_modules/framer-motion/dist/es/animation/utils/get-value-transition.mjs 13004 function getValueTransition(transition, key) { 13005 return transition ? transition[key] || transition["default"] || transition : void 0; 13006 } 13007 13008 // packages/components/node_modules/framer-motion/dist/es/utils/GlobalConfig.mjs 13009 var MotionGlobalConfig = { 13010 skipAnimations: false, 13011 useManualTiming: false 13012 }; 13013 13014 // packages/components/node_modules/framer-motion/dist/es/utils/use-instant-transition-state.mjs 13015 var instantAnimationState = { 13016 current: false 13017 }; 13018 13019 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/get-final-keyframe.mjs 13020 var isNotNull = (value) => value !== null; 13021 function getFinalKeyframe(keyframes5, { repeat, repeatType = "loop" }, finalKeyframe) { 13022 const resolvedKeyframes = keyframes5.filter(isNotNull); 13023 const index2 = repeat && repeatType !== "loop" && repeat % 2 === 1 ? 0 : resolvedKeyframes.length - 1; 13024 return !index2 || finalKeyframe === void 0 ? resolvedKeyframes[index2] : finalKeyframe; 13025 } 13026 13027 // node_modules/motion-utils/dist/es/noop.mjs 13028 var noop2 = (any) => any; 13029 13030 // node_modules/motion-utils/dist/es/errors.mjs 13031 var warning = noop2; 13032 var invariant2 = noop2; 13033 if (true) { 13034 warning = (check, message3) => { 13035 if (!check && typeof console !== "undefined") { 13036 console.warn(message3); 13037 } 13038 }; 13039 invariant2 = (check, message3) => { 13040 if (!check) { 13041 throw new Error(message3); 13042 } 13043 }; 13044 } 13045 13046 // packages/components/node_modules/framer-motion/dist/es/frameloop/render-step.mjs 13047 function createRenderStep(runNextFrame) { 13048 let thisFrame = /* @__PURE__ */ new Set(); 13049 let nextFrame = /* @__PURE__ */ new Set(); 13050 let isProcessing = false; 13051 let flushNextFrame = false; 13052 const toKeepAlive = /* @__PURE__ */ new WeakSet(); 13053 let latestFrameData = { 13054 delta: 0, 13055 timestamp: 0, 13056 isProcessing: false 13057 }; 13058 function triggerCallback(callback) { 13059 if (toKeepAlive.has(callback)) { 13060 step.schedule(callback); 13061 runNextFrame(); 13062 } 13063 callback(latestFrameData); 13064 } 13065 const step = { 13066 /** 13067 * Schedule a process to run on the next frame. 13068 */ 13069 schedule: (callback, keepAlive = false, immediate = false) => { 13070 const addToCurrentFrame = immediate && isProcessing; 13071 const queue = addToCurrentFrame ? thisFrame : nextFrame; 13072 if (keepAlive) 13073 toKeepAlive.add(callback); 13074 if (!queue.has(callback)) 13075 queue.add(callback); 13076 return callback; 13077 }, 13078 /** 13079 * Cancel the provided callback from running on the next frame. 13080 */ 13081 cancel: (callback) => { 13082 nextFrame.delete(callback); 13083 toKeepAlive.delete(callback); 13084 }, 13085 /** 13086 * Execute all schedule callbacks. 13087 */ 13088 process: (frameData2) => { 13089 latestFrameData = frameData2; 13090 if (isProcessing) { 13091 flushNextFrame = true; 13092 return; 13093 } 13094 isProcessing = true; 13095 [thisFrame, nextFrame] = [nextFrame, thisFrame]; 13096 thisFrame.forEach(triggerCallback); 13097 thisFrame.clear(); 13098 isProcessing = false; 13099 if (flushNextFrame) { 13100 flushNextFrame = false; 13101 step.process(frameData2); 13102 } 13103 } 13104 }; 13105 return step; 13106 } 13107 13108 // packages/components/node_modules/framer-motion/dist/es/frameloop/batcher.mjs 13109 var stepsOrder = [ 13110 "read", 13111 // Read 13112 "resolveKeyframes", 13113 // Write/Read/Write/Read 13114 "update", 13115 // Compute 13116 "preRender", 13117 // Compute 13118 "render", 13119 // Write 13120 "postRender" 13121 // Compute 13122 ]; 13123 var maxElapsed = 40; 13124 function createRenderBatcher(scheduleNextBatch, allowKeepAlive) { 13125 let runNextFrame = false; 13126 let useDefaultElapsed = true; 13127 const state = { 13128 delta: 0, 13129 timestamp: 0, 13130 isProcessing: false 13131 }; 13132 const flagRunNextFrame = () => runNextFrame = true; 13133 const steps = stepsOrder.reduce((acc, key) => { 13134 acc[key] = createRenderStep(flagRunNextFrame); 13135 return acc; 13136 }, {}); 13137 const { read, resolveKeyframes, update, preRender, render, postRender } = steps; 13138 const processBatch = () => { 13139 const timestamp = MotionGlobalConfig.useManualTiming ? state.timestamp : performance.now(); 13140 runNextFrame = false; 13141 state.delta = useDefaultElapsed ? 1e3 / 60 : Math.max(Math.min(timestamp - state.timestamp, maxElapsed), 1); 13142 state.timestamp = timestamp; 13143 state.isProcessing = true; 13144 read.process(state); 13145 resolveKeyframes.process(state); 13146 update.process(state); 13147 preRender.process(state); 13148 render.process(state); 13149 postRender.process(state); 13150 state.isProcessing = false; 13151 if (runNextFrame && allowKeepAlive) { 13152 useDefaultElapsed = false; 13153 scheduleNextBatch(processBatch); 13154 } 13155 }; 13156 const wake = () => { 13157 runNextFrame = true; 13158 useDefaultElapsed = true; 13159 if (!state.isProcessing) { 13160 scheduleNextBatch(processBatch); 13161 } 13162 }; 13163 const schedule = stepsOrder.reduce((acc, key) => { 13164 const step = steps[key]; 13165 acc[key] = (process2, keepAlive = false, immediate = false) => { 13166 if (!runNextFrame) 13167 wake(); 13168 return step.schedule(process2, keepAlive, immediate); 13169 }; 13170 return acc; 13171 }, {}); 13172 const cancel = (process2) => { 13173 for (let i3 = 0; i3 < stepsOrder.length; i3++) { 13174 steps[stepsOrder[i3]].cancel(process2); 13175 } 13176 }; 13177 return { schedule, cancel, state, steps }; 13178 } 13179 13180 // packages/components/node_modules/framer-motion/dist/es/frameloop/frame.mjs 13181 var { schedule: frame, cancel: cancelFrame, state: frameData, steps: frameSteps } = createRenderBatcher(typeof requestAnimationFrame !== "undefined" ? requestAnimationFrame : noop2, true); 13182 13183 // packages/components/node_modules/framer-motion/dist/es/easing/cubic-bezier.mjs 13184 var calcBezier = (t4, a1, a22) => (((1 - 3 * a22 + 3 * a1) * t4 + (3 * a22 - 6 * a1)) * t4 + 3 * a1) * t4; 13185 var subdivisionPrecision = 1e-7; 13186 var subdivisionMaxIterations = 12; 13187 function binarySubdivide(x2, lowerBound, upperBound, mX1, mX2) { 13188 let currentX; 13189 let currentT; 13190 let i3 = 0; 13191 do { 13192 currentT = lowerBound + (upperBound - lowerBound) / 2; 13193 currentX = calcBezier(currentT, mX1, mX2) - x2; 13194 if (currentX > 0) { 13195 upperBound = currentT; 13196 } else { 13197 lowerBound = currentT; 13198 } 13199 } while (Math.abs(currentX) > subdivisionPrecision && ++i3 < subdivisionMaxIterations); 13200 return currentT; 13201 } 13202 function cubicBezier(mX1, mY1, mX2, mY2) { 13203 if (mX1 === mY1 && mX2 === mY2) 13204 return noop2; 13205 const getTForX = (aX) => binarySubdivide(aX, 0, 1, mX1, mX2); 13206 return (t4) => t4 === 0 || t4 === 1 ? t4 : calcBezier(getTForX(t4), mY1, mY2); 13207 } 13208 13209 // packages/components/node_modules/framer-motion/dist/es/easing/modifiers/mirror.mjs 13210 var mirrorEasing = (easing) => (p3) => p3 <= 0.5 ? easing(2 * p3) / 2 : (2 - easing(2 * (1 - p3))) / 2; 13211 13212 // packages/components/node_modules/framer-motion/dist/es/easing/modifiers/reverse.mjs 13213 var reverseEasing = (easing) => (p3) => 1 - easing(1 - p3); 13214 13215 // packages/components/node_modules/framer-motion/dist/es/easing/back.mjs 13216 var backOut = /* @__PURE__ */ cubicBezier(0.33, 1.53, 0.69, 0.99); 13217 var backIn = /* @__PURE__ */ reverseEasing(backOut); 13218 var backInOut = /* @__PURE__ */ mirrorEasing(backIn); 13219 13220 // packages/components/node_modules/framer-motion/dist/es/easing/anticipate.mjs 13221 var anticipate = (p3) => (p3 *= 2) < 1 ? 0.5 * backIn(p3) : 0.5 * (2 - Math.pow(2, -10 * (p3 - 1))); 13222 13223 // packages/components/node_modules/framer-motion/dist/es/easing/circ.mjs 13224 var circIn = (p3) => 1 - Math.sin(Math.acos(p3)); 13225 var circOut = reverseEasing(circIn); 13226 var circInOut = mirrorEasing(circIn); 13227 13228 // packages/components/node_modules/framer-motion/dist/es/utils/is-zero-value-string.mjs 13229 var isZeroValueString = (v3) => /^0[^.\s]+$/u.test(v3); 13230 13231 // packages/components/node_modules/framer-motion/dist/es/animation/utils/is-none.mjs 13232 function isNone(value) { 13233 if (typeof value === "number") { 13234 return value === 0; 13235 } else if (value !== null) { 13236 return value === "none" || value === "0" || isZeroValueString(value); 13237 } else { 13238 return true; 13239 } 13240 } 13241 13242 // packages/components/node_modules/framer-motion/dist/es/utils/is-numerical-string.mjs 13243 var isNumericalString = (v3) => /^-?(?:\d+(?:\.\d+)?|\.\d+)$/u.test(v3); 13244 13245 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/is-css-variable.mjs 13246 var checkStringStartsWith = (token2) => (key) => typeof key === "string" && key.startsWith(token2); 13247 var isCSSVariableName = /* @__PURE__ */ checkStringStartsWith("--"); 13248 var startsAsVariableToken = /* @__PURE__ */ checkStringStartsWith("var(--"); 13249 var isCSSVariableToken = (value) => { 13250 const startsWithToken = startsAsVariableToken(value); 13251 if (!startsWithToken) 13252 return false; 13253 return singleCssVariableRegex.test(value.split("/*")[0].trim()); 13254 }; 13255 var singleCssVariableRegex = /var\(--(?:[\w-]+\s*|[\w-]+\s*,(?:\s*[^)(\s]|\s*\((?:[^)(]|\([^)(]*\))*\))+\s*)\)$/iu; 13256 13257 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/css-variables-conversion.mjs 13258 var splitCSSVariableRegex = ( 13259 // eslint-disable-next-line redos-detector/no-unsafe-regex -- false positive, as it can match a lot of words 13260 /^var\(--(?:([\w-]+)|([\w-]+), ?([a-zA-Z\d ()%#.,-]+))\)/u 13261 ); 13262 function parseCSSVariable(current) { 13263 const match5 = splitCSSVariableRegex.exec(current); 13264 if (!match5) 13265 return [,]; 13266 const [, token1, token2, fallback] = match5; 13267 return [`--${token1 !== null && token1 !== void 0 ? token1 : token2}`, fallback]; 13268 } 13269 var maxDepth = 4; 13270 function getVariableValue(current, element, depth = 1) { 13271 invariant2(depth <= maxDepth, `Max CSS variable fallback depth detected in property "${current}". This may indicate a circular fallback dependency.`); 13272 const [token2, fallback] = parseCSSVariable(current); 13273 if (!token2) 13274 return; 13275 const resolved = window.getComputedStyle(element).getPropertyValue(token2); 13276 if (resolved) { 13277 const trimmed = resolved.trim(); 13278 return isNumericalString(trimmed) ? parseFloat(trimmed) : trimmed; 13279 } 13280 return isCSSVariableToken(fallback) ? getVariableValue(fallback, element, depth + 1) : fallback; 13281 } 13282 13283 // packages/components/node_modules/framer-motion/dist/es/utils/clamp.mjs 13284 var clamp2 = (min3, max3, v3) => { 13285 if (v3 > max3) 13286 return max3; 13287 if (v3 < min3) 13288 return min3; 13289 return v3; 13290 }; 13291 13292 // packages/components/node_modules/framer-motion/dist/es/value/types/numbers/index.mjs 13293 var number = { 13294 test: (v3) => typeof v3 === "number", 13295 parse: parseFloat, 13296 transform: (v3) => v3 13297 }; 13298 var alpha = { 13299 ...number, 13300 transform: (v3) => clamp2(0, 1, v3) 13301 }; 13302 var scale = { 13303 ...number, 13304 default: 1 13305 }; 13306 13307 // packages/components/node_modules/framer-motion/dist/es/value/types/numbers/units.mjs 13308 var createUnitType = (unit) => ({ 13309 test: (v3) => typeof v3 === "string" && v3.endsWith(unit) && v3.split(" ").length === 1, 13310 parse: parseFloat, 13311 transform: (v3) => `${v3}${unit}` 13312 }); 13313 var degrees = /* @__PURE__ */ createUnitType("deg"); 13314 var percent = /* @__PURE__ */ createUnitType("%"); 13315 var px = /* @__PURE__ */ createUnitType("px"); 13316 var vh = /* @__PURE__ */ createUnitType("vh"); 13317 var vw = /* @__PURE__ */ createUnitType("vw"); 13318 var progressPercentage = { 13319 ...percent, 13320 parse: (v3) => percent.parse(v3) / 100, 13321 transform: (v3) => percent.transform(v3 * 100) 13322 }; 13323 13324 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/unit-conversion.mjs 13325 var positionalKeys = /* @__PURE__ */ new Set([ 13326 "width", 13327 "height", 13328 "top", 13329 "left", 13330 "right", 13331 "bottom", 13332 "x", 13333 "y", 13334 "translateX", 13335 "translateY" 13336 ]); 13337 var isNumOrPxType = (v3) => v3 === number || v3 === px; 13338 var getPosFromMatrix = (matrix, pos) => parseFloat(matrix.split(", ")[pos]); 13339 var getTranslateFromMatrix = (pos2, pos3) => (_bbox, { transform }) => { 13340 if (transform === "none" || !transform) 13341 return 0; 13342 const matrix3d = transform.match(/^matrix3d\((.+)\)$/u); 13343 if (matrix3d) { 13344 return getPosFromMatrix(matrix3d[1], pos3); 13345 } else { 13346 const matrix = transform.match(/^matrix\((.+)\)$/u); 13347 if (matrix) { 13348 return getPosFromMatrix(matrix[1], pos2); 13349 } else { 13350 return 0; 13351 } 13352 } 13353 }; 13354 var transformKeys = /* @__PURE__ */ new Set(["x", "y", "z"]); 13355 var nonTranslationalTransformKeys = transformPropOrder.filter((key) => !transformKeys.has(key)); 13356 function removeNonTranslationalTransform(visualElement) { 13357 const removedTransforms = []; 13358 nonTranslationalTransformKeys.forEach((key) => { 13359 const value = visualElement.getValue(key); 13360 if (value !== void 0) { 13361 removedTransforms.push([key, value.get()]); 13362 value.set(key.startsWith("scale") ? 1 : 0); 13363 } 13364 }); 13365 return removedTransforms; 13366 } 13367 var positionalValues = { 13368 // Dimensions 13369 width: ({ x: x2 }, { paddingLeft = "0", paddingRight = "0" }) => x2.max - x2.min - parseFloat(paddingLeft) - parseFloat(paddingRight), 13370 height: ({ y: y3 }, { paddingTop = "0", paddingBottom = "0" }) => y3.max - y3.min - parseFloat(paddingTop) - parseFloat(paddingBottom), 13371 top: (_bbox, { top }) => parseFloat(top), 13372 left: (_bbox, { left }) => parseFloat(left), 13373 bottom: ({ y: y3 }, { top }) => parseFloat(top) + (y3.max - y3.min), 13374 right: ({ x: x2 }, { left }) => parseFloat(left) + (x2.max - x2.min), 13375 // Transform 13376 x: getTranslateFromMatrix(4, 13), 13377 y: getTranslateFromMatrix(5, 14) 13378 }; 13379 positionalValues.translateX = positionalValues.x; 13380 positionalValues.translateY = positionalValues.y; 13381 13382 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/test.mjs 13383 var testValueType = (v3) => (type) => type.test(v3); 13384 13385 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/type-auto.mjs 13386 var auto = { 13387 test: (v3) => v3 === "auto", 13388 parse: (v3) => v3 13389 }; 13390 13391 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/dimensions.mjs 13392 var dimensionValueTypes = [number, px, percent, degrees, vw, vh, auto]; 13393 var findDimensionValueType = (v3) => dimensionValueTypes.find(testValueType(v3)); 13394 13395 // packages/components/node_modules/framer-motion/dist/es/render/utils/KeyframesResolver.mjs 13396 var toResolve = /* @__PURE__ */ new Set(); 13397 var isScheduled = false; 13398 var anyNeedsMeasurement = false; 13399 function measureAllKeyframes() { 13400 if (anyNeedsMeasurement) { 13401 const resolversToMeasure = Array.from(toResolve).filter((resolver) => resolver.needsMeasurement); 13402 const elementsToMeasure = new Set(resolversToMeasure.map((resolver) => resolver.element)); 13403 const transformsToRestore = /* @__PURE__ */ new Map(); 13404 elementsToMeasure.forEach((element) => { 13405 const removedTransforms = removeNonTranslationalTransform(element); 13406 if (!removedTransforms.length) 13407 return; 13408 transformsToRestore.set(element, removedTransforms); 13409 element.render(); 13410 }); 13411 resolversToMeasure.forEach((resolver) => resolver.measureInitialState()); 13412 elementsToMeasure.forEach((element) => { 13413 element.render(); 13414 const restore = transformsToRestore.get(element); 13415 if (restore) { 13416 restore.forEach(([key, value]) => { 13417 var _a; 13418 (_a = element.getValue(key)) === null || _a === void 0 ? void 0 : _a.set(value); 13419 }); 13420 } 13421 }); 13422 resolversToMeasure.forEach((resolver) => resolver.measureEndState()); 13423 resolversToMeasure.forEach((resolver) => { 13424 if (resolver.suspendedScrollY !== void 0) { 13425 window.scrollTo(0, resolver.suspendedScrollY); 13426 } 13427 }); 13428 } 13429 anyNeedsMeasurement = false; 13430 isScheduled = false; 13431 toResolve.forEach((resolver) => resolver.complete()); 13432 toResolve.clear(); 13433 } 13434 function readAllKeyframes() { 13435 toResolve.forEach((resolver) => { 13436 resolver.readKeyframes(); 13437 if (resolver.needsMeasurement) { 13438 anyNeedsMeasurement = true; 13439 } 13440 }); 13441 } 13442 function flushKeyframeResolvers() { 13443 readAllKeyframes(); 13444 measureAllKeyframes(); 13445 } 13446 var KeyframeResolver = class { 13447 constructor(unresolvedKeyframes, onComplete, name, motionValue2, element, isAsync = false) { 13448 this.isComplete = false; 13449 this.isAsync = false; 13450 this.needsMeasurement = false; 13451 this.isScheduled = false; 13452 this.unresolvedKeyframes = [...unresolvedKeyframes]; 13453 this.onComplete = onComplete; 13454 this.name = name; 13455 this.motionValue = motionValue2; 13456 this.element = element; 13457 this.isAsync = isAsync; 13458 } 13459 scheduleResolve() { 13460 this.isScheduled = true; 13461 if (this.isAsync) { 13462 toResolve.add(this); 13463 if (!isScheduled) { 13464 isScheduled = true; 13465 frame.read(readAllKeyframes); 13466 frame.resolveKeyframes(measureAllKeyframes); 13467 } 13468 } else { 13469 this.readKeyframes(); 13470 this.complete(); 13471 } 13472 } 13473 readKeyframes() { 13474 const { unresolvedKeyframes, name, element, motionValue: motionValue2 } = this; 13475 for (let i3 = 0; i3 < unresolvedKeyframes.length; i3++) { 13476 if (unresolvedKeyframes[i3] === null) { 13477 if (i3 === 0) { 13478 const currentValue = motionValue2 === null || motionValue2 === void 0 ? void 0 : motionValue2.get(); 13479 const finalKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1]; 13480 if (currentValue !== void 0) { 13481 unresolvedKeyframes[0] = currentValue; 13482 } else if (element && name) { 13483 const valueAsRead = element.readValue(name, finalKeyframe); 13484 if (valueAsRead !== void 0 && valueAsRead !== null) { 13485 unresolvedKeyframes[0] = valueAsRead; 13486 } 13487 } 13488 if (unresolvedKeyframes[0] === void 0) { 13489 unresolvedKeyframes[0] = finalKeyframe; 13490 } 13491 if (motionValue2 && currentValue === void 0) { 13492 motionValue2.set(unresolvedKeyframes[0]); 13493 } 13494 } else { 13495 unresolvedKeyframes[i3] = unresolvedKeyframes[i3 - 1]; 13496 } 13497 } 13498 } 13499 } 13500 setFinalKeyframe() { 13501 } 13502 measureInitialState() { 13503 } 13504 renderEndStyles() { 13505 } 13506 measureEndState() { 13507 } 13508 complete() { 13509 this.isComplete = true; 13510 this.onComplete(this.unresolvedKeyframes, this.finalKeyframe); 13511 toResolve.delete(this); 13512 } 13513 cancel() { 13514 if (!this.isComplete) { 13515 this.isScheduled = false; 13516 toResolve.delete(this); 13517 } 13518 } 13519 resume() { 13520 if (!this.isComplete) 13521 this.scheduleResolve(); 13522 } 13523 }; 13524 13525 // packages/components/node_modules/framer-motion/dist/es/value/types/utils/sanitize.mjs 13526 var sanitize = (v3) => Math.round(v3 * 1e5) / 1e5; 13527 13528 // packages/components/node_modules/framer-motion/dist/es/value/types/utils/float-regex.mjs 13529 var floatRegex = /-?(?:\d+(?:\.\d+)?|\.\d+)/gu; 13530 13531 // packages/components/node_modules/framer-motion/dist/es/value/types/utils/is-nullish.mjs 13532 function isNullish(v3) { 13533 return v3 == null; 13534 } 13535 13536 // packages/components/node_modules/framer-motion/dist/es/value/types/utils/single-color-regex.mjs 13537 var singleColorRegex = /^(?:#[\da-f]{3,8}|(?:rgb|hsl)a?\((?:-?[\d.]+%?[,\s]+){2}-?[\d.]+%?\s*(?:[,/]\s*)?(?:\b\d+(?:\.\d+)?|\.\d+)?%?\))$/iu; 13538 13539 // packages/components/node_modules/framer-motion/dist/es/value/types/color/utils.mjs 13540 var isColorString = (type, testProp) => (v3) => { 13541 return Boolean(typeof v3 === "string" && singleColorRegex.test(v3) && v3.startsWith(type) || testProp && !isNullish(v3) && Object.prototype.hasOwnProperty.call(v3, testProp)); 13542 }; 13543 var splitColor = (aName, bName, cName) => (v3) => { 13544 if (typeof v3 !== "string") 13545 return v3; 13546 const [a3, b3, c3, alpha2] = v3.match(floatRegex); 13547 return { 13548 [aName]: parseFloat(a3), 13549 [bName]: parseFloat(b3), 13550 [cName]: parseFloat(c3), 13551 alpha: alpha2 !== void 0 ? parseFloat(alpha2) : 1 13552 }; 13553 }; 13554 13555 // packages/components/node_modules/framer-motion/dist/es/value/types/color/rgba.mjs 13556 var clampRgbUnit = (v3) => clamp2(0, 255, v3); 13557 var rgbUnit = { 13558 ...number, 13559 transform: (v3) => Math.round(clampRgbUnit(v3)) 13560 }; 13561 var rgba = { 13562 test: /* @__PURE__ */ isColorString("rgb", "red"), 13563 parse: /* @__PURE__ */ splitColor("red", "green", "blue"), 13564 transform: ({ red, green, blue, alpha: alpha$1 = 1 }) => "rgba(" + rgbUnit.transform(red) + ", " + rgbUnit.transform(green) + ", " + rgbUnit.transform(blue) + ", " + sanitize(alpha.transform(alpha$1)) + ")" 13565 }; 13566 13567 // packages/components/node_modules/framer-motion/dist/es/value/types/color/hex.mjs 13568 function parseHex(v3) { 13569 let r4 = ""; 13570 let g3 = ""; 13571 let b3 = ""; 13572 let a3 = ""; 13573 if (v3.length > 5) { 13574 r4 = v3.substring(1, 3); 13575 g3 = v3.substring(3, 5); 13576 b3 = v3.substring(5, 7); 13577 a3 = v3.substring(7, 9); 13578 } else { 13579 r4 = v3.substring(1, 2); 13580 g3 = v3.substring(2, 3); 13581 b3 = v3.substring(3, 4); 13582 a3 = v3.substring(4, 5); 13583 r4 += r4; 13584 g3 += g3; 13585 b3 += b3; 13586 a3 += a3; 13587 } 13588 return { 13589 red: parseInt(r4, 16), 13590 green: parseInt(g3, 16), 13591 blue: parseInt(b3, 16), 13592 alpha: a3 ? parseInt(a3, 16) / 255 : 1 13593 }; 13594 } 13595 var hex = { 13596 test: /* @__PURE__ */ isColorString("#"), 13597 parse: parseHex, 13598 transform: rgba.transform 13599 }; 13600 13601 // packages/components/node_modules/framer-motion/dist/es/value/types/color/hsla.mjs 13602 var hsla = { 13603 test: /* @__PURE__ */ isColorString("hsl", "hue"), 13604 parse: /* @__PURE__ */ splitColor("hue", "saturation", "lightness"), 13605 transform: ({ hue, saturation, lightness, alpha: alpha$1 = 1 }) => { 13606 return "hsla(" + Math.round(hue) + ", " + percent.transform(sanitize(saturation)) + ", " + percent.transform(sanitize(lightness)) + ", " + sanitize(alpha.transform(alpha$1)) + ")"; 13607 } 13608 }; 13609 13610 // packages/components/node_modules/framer-motion/dist/es/value/types/color/index.mjs 13611 var color = { 13612 test: (v3) => rgba.test(v3) || hex.test(v3) || hsla.test(v3), 13613 parse: (v3) => { 13614 if (rgba.test(v3)) { 13615 return rgba.parse(v3); 13616 } else if (hsla.test(v3)) { 13617 return hsla.parse(v3); 13618 } else { 13619 return hex.parse(v3); 13620 } 13621 }, 13622 transform: (v3) => { 13623 return typeof v3 === "string" ? v3 : v3.hasOwnProperty("red") ? rgba.transform(v3) : hsla.transform(v3); 13624 } 13625 }; 13626 13627 // packages/components/node_modules/framer-motion/dist/es/value/types/utils/color-regex.mjs 13628 var colorRegex = /(?:#[\da-f]{3,8}|(?:rgb|hsl)a?\((?:-?[\d.]+%?[,\s]+){2}-?[\d.]+%?\s*(?:[,/]\s*)?(?:\b\d+(?:\.\d+)?|\.\d+)?%?\))/giu; 13629 13630 // packages/components/node_modules/framer-motion/dist/es/value/types/complex/index.mjs 13631 function test(v3) { 13632 var _a, _b; 13633 return isNaN(v3) && typeof v3 === "string" && (((_a = v3.match(floatRegex)) === null || _a === void 0 ? void 0 : _a.length) || 0) + (((_b = v3.match(colorRegex)) === null || _b === void 0 ? void 0 : _b.length) || 0) > 0; 13634 } 13635 var NUMBER_TOKEN = "number"; 13636 var COLOR_TOKEN = "color"; 13637 var VAR_TOKEN = "var"; 13638 var VAR_FUNCTION_TOKEN = "var("; 13639 var SPLIT_TOKEN = "${}"; 13640 var complexRegex = /var\s*\(\s*--(?:[\w-]+\s*|[\w-]+\s*,(?:\s*[^)(\s]|\s*\((?:[^)(]|\([^)(]*\))*\))+\s*)\)|#[\da-f]{3,8}|(?:rgb|hsl)a?\((?:-?[\d.]+%?[,\s]+){2}-?[\d.]+%?\s*(?:[,/]\s*)?(?:\b\d+(?:\.\d+)?|\.\d+)?%?\)|-?(?:\d+(?:\.\d+)?|\.\d+)/giu; 13641 function analyseComplexValue(value) { 13642 const originalValue = value.toString(); 13643 const values = []; 13644 const indexes = { 13645 color: [], 13646 number: [], 13647 var: [] 13648 }; 13649 const types = []; 13650 let i3 = 0; 13651 const tokenised = originalValue.replace(complexRegex, (parsedValue) => { 13652 if (color.test(parsedValue)) { 13653 indexes.color.push(i3); 13654 types.push(COLOR_TOKEN); 13655 values.push(color.parse(parsedValue)); 13656 } else if (parsedValue.startsWith(VAR_FUNCTION_TOKEN)) { 13657 indexes.var.push(i3); 13658 types.push(VAR_TOKEN); 13659 values.push(parsedValue); 13660 } else { 13661 indexes.number.push(i3); 13662 types.push(NUMBER_TOKEN); 13663 values.push(parseFloat(parsedValue)); 13664 } 13665 ++i3; 13666 return SPLIT_TOKEN; 13667 }); 13668 const split = tokenised.split(SPLIT_TOKEN); 13669 return { values, split, indexes, types }; 13670 } 13671 function parseComplexValue(v3) { 13672 return analyseComplexValue(v3).values; 13673 } 13674 function createTransformer(source) { 13675 const { split, types } = analyseComplexValue(source); 13676 const numSections = split.length; 13677 return (v3) => { 13678 let output = ""; 13679 for (let i3 = 0; i3 < numSections; i3++) { 13680 output += split[i3]; 13681 if (v3[i3] !== void 0) { 13682 const type = types[i3]; 13683 if (type === NUMBER_TOKEN) { 13684 output += sanitize(v3[i3]); 13685 } else if (type === COLOR_TOKEN) { 13686 output += color.transform(v3[i3]); 13687 } else { 13688 output += v3[i3]; 13689 } 13690 } 13691 } 13692 return output; 13693 }; 13694 } 13695 var convertNumbersToZero = (v3) => typeof v3 === "number" ? 0 : v3; 13696 function getAnimatableNone(v3) { 13697 const parsed = parseComplexValue(v3); 13698 const transformer = createTransformer(v3); 13699 return transformer(parsed.map(convertNumbersToZero)); 13700 } 13701 var complex = { 13702 test, 13703 parse: parseComplexValue, 13704 createTransformer, 13705 getAnimatableNone 13706 }; 13707 13708 // packages/components/node_modules/framer-motion/dist/es/value/types/complex/filter.mjs 13709 var maxDefaults = /* @__PURE__ */ new Set(["brightness", "contrast", "saturate", "opacity"]); 13710 function applyDefaultFilter(v3) { 13711 const [name, value] = v3.slice(0, -1).split("("); 13712 if (name === "drop-shadow") 13713 return v3; 13714 const [number2] = value.match(floatRegex) || []; 13715 if (!number2) 13716 return v3; 13717 const unit = value.replace(number2, ""); 13718 let defaultValue2 = maxDefaults.has(name) ? 1 : 0; 13719 if (number2 !== value) 13720 defaultValue2 *= 100; 13721 return name + "(" + defaultValue2 + unit + ")"; 13722 } 13723 var functionRegex = /\b([a-z-]*)\(.*?\)/gu; 13724 var filter = { 13725 ...complex, 13726 getAnimatableNone: (v3) => { 13727 const functions = v3.match(functionRegex); 13728 return functions ? functions.map(applyDefaultFilter).join(" ") : v3; 13729 } 13730 }; 13731 13732 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/number-browser.mjs 13733 var browserNumberValueTypes = { 13734 // Border props 13735 borderWidth: px, 13736 borderTopWidth: px, 13737 borderRightWidth: px, 13738 borderBottomWidth: px, 13739 borderLeftWidth: px, 13740 borderRadius: px, 13741 radius: px, 13742 borderTopLeftRadius: px, 13743 borderTopRightRadius: px, 13744 borderBottomRightRadius: px, 13745 borderBottomLeftRadius: px, 13746 // Positioning props 13747 width: px, 13748 maxWidth: px, 13749 height: px, 13750 maxHeight: px, 13751 top: px, 13752 right: px, 13753 bottom: px, 13754 left: px, 13755 // Spacing props 13756 padding: px, 13757 paddingTop: px, 13758 paddingRight: px, 13759 paddingBottom: px, 13760 paddingLeft: px, 13761 margin: px, 13762 marginTop: px, 13763 marginRight: px, 13764 marginBottom: px, 13765 marginLeft: px, 13766 // Misc 13767 backgroundPositionX: px, 13768 backgroundPositionY: px 13769 }; 13770 13771 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/transform.mjs 13772 var transformValueTypes = { 13773 rotate: degrees, 13774 rotateX: degrees, 13775 rotateY: degrees, 13776 rotateZ: degrees, 13777 scale, 13778 scaleX: scale, 13779 scaleY: scale, 13780 scaleZ: scale, 13781 skew: degrees, 13782 skewX: degrees, 13783 skewY: degrees, 13784 distance: px, 13785 translateX: px, 13786 translateY: px, 13787 translateZ: px, 13788 x: px, 13789 y: px, 13790 z: px, 13791 perspective: px, 13792 transformPerspective: px, 13793 opacity: alpha, 13794 originX: progressPercentage, 13795 originY: progressPercentage, 13796 originZ: px 13797 }; 13798 13799 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/type-int.mjs 13800 var int = { 13801 ...number, 13802 transform: Math.round 13803 }; 13804 13805 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/number.mjs 13806 var numberValueTypes = { 13807 ...browserNumberValueTypes, 13808 ...transformValueTypes, 13809 zIndex: int, 13810 size: px, 13811 // SVG 13812 fillOpacity: alpha, 13813 strokeOpacity: alpha, 13814 numOctaves: int 13815 }; 13816 13817 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/defaults.mjs 13818 var defaultValueTypes = { 13819 ...numberValueTypes, 13820 // Color props 13821 color, 13822 backgroundColor: color, 13823 outlineColor: color, 13824 fill: color, 13825 stroke: color, 13826 // Border props 13827 borderColor: color, 13828 borderTopColor: color, 13829 borderRightColor: color, 13830 borderBottomColor: color, 13831 borderLeftColor: color, 13832 filter, 13833 WebkitFilter: filter 13834 }; 13835 var getDefaultValueType = (key) => defaultValueTypes[key]; 13836 13837 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/animatable-none.mjs 13838 function getAnimatableNone2(key, value) { 13839 let defaultValueType = getDefaultValueType(key); 13840 if (defaultValueType !== filter) 13841 defaultValueType = complex; 13842 return defaultValueType.getAnimatableNone ? defaultValueType.getAnimatableNone(value) : void 0; 13843 } 13844 13845 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/make-none-animatable.mjs 13846 var invalidTemplates = /* @__PURE__ */ new Set(["auto", "none", "0"]); 13847 function makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name) { 13848 let i3 = 0; 13849 let animatableTemplate = void 0; 13850 while (i3 < unresolvedKeyframes.length && !animatableTemplate) { 13851 const keyframe = unresolvedKeyframes[i3]; 13852 if (typeof keyframe === "string" && !invalidTemplates.has(keyframe) && analyseComplexValue(keyframe).values.length) { 13853 animatableTemplate = unresolvedKeyframes[i3]; 13854 } 13855 i3++; 13856 } 13857 if (animatableTemplate && name) { 13858 for (const noneIndex of noneKeyframeIndexes) { 13859 unresolvedKeyframes[noneIndex] = getAnimatableNone2(name, animatableTemplate); 13860 } 13861 } 13862 } 13863 13864 // packages/components/node_modules/framer-motion/dist/es/render/dom/DOMKeyframesResolver.mjs 13865 var DOMKeyframesResolver = class extends KeyframeResolver { 13866 constructor(unresolvedKeyframes, onComplete, name, motionValue2, element) { 13867 super(unresolvedKeyframes, onComplete, name, motionValue2, element, true); 13868 } 13869 readKeyframes() { 13870 const { unresolvedKeyframes, element, name } = this; 13871 if (!element || !element.current) 13872 return; 13873 super.readKeyframes(); 13874 for (let i3 = 0; i3 < unresolvedKeyframes.length; i3++) { 13875 let keyframe = unresolvedKeyframes[i3]; 13876 if (typeof keyframe === "string") { 13877 keyframe = keyframe.trim(); 13878 if (isCSSVariableToken(keyframe)) { 13879 const resolved = getVariableValue(keyframe, element.current); 13880 if (resolved !== void 0) { 13881 unresolvedKeyframes[i3] = resolved; 13882 } 13883 if (i3 === unresolvedKeyframes.length - 1) { 13884 this.finalKeyframe = keyframe; 13885 } 13886 } 13887 } 13888 } 13889 this.resolveNoneKeyframes(); 13890 if (!positionalKeys.has(name) || unresolvedKeyframes.length !== 2) { 13891 return; 13892 } 13893 const [origin, target] = unresolvedKeyframes; 13894 const originType = findDimensionValueType(origin); 13895 const targetType = findDimensionValueType(target); 13896 if (originType === targetType) 13897 return; 13898 if (isNumOrPxType(originType) && isNumOrPxType(targetType)) { 13899 for (let i3 = 0; i3 < unresolvedKeyframes.length; i3++) { 13900 const value = unresolvedKeyframes[i3]; 13901 if (typeof value === "string") { 13902 unresolvedKeyframes[i3] = parseFloat(value); 13903 } 13904 } 13905 } else { 13906 this.needsMeasurement = true; 13907 } 13908 } 13909 resolveNoneKeyframes() { 13910 const { unresolvedKeyframes, name } = this; 13911 const noneKeyframeIndexes = []; 13912 for (let i3 = 0; i3 < unresolvedKeyframes.length; i3++) { 13913 if (isNone(unresolvedKeyframes[i3])) { 13914 noneKeyframeIndexes.push(i3); 13915 } 13916 } 13917 if (noneKeyframeIndexes.length) { 13918 makeNoneKeyframesAnimatable(unresolvedKeyframes, noneKeyframeIndexes, name); 13919 } 13920 } 13921 measureInitialState() { 13922 const { element, unresolvedKeyframes, name } = this; 13923 if (!element || !element.current) 13924 return; 13925 if (name === "height") { 13926 this.suspendedScrollY = window.pageYOffset; 13927 } 13928 this.measuredOrigin = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current)); 13929 unresolvedKeyframes[0] = this.measuredOrigin; 13930 const measureKeyframe = unresolvedKeyframes[unresolvedKeyframes.length - 1]; 13931 if (measureKeyframe !== void 0) { 13932 element.getValue(name, measureKeyframe).jump(measureKeyframe, false); 13933 } 13934 } 13935 measureEndState() { 13936 var _a; 13937 const { element, name, unresolvedKeyframes } = this; 13938 if (!element || !element.current) 13939 return; 13940 const value = element.getValue(name); 13941 value && value.jump(this.measuredOrigin, false); 13942 const finalKeyframeIndex = unresolvedKeyframes.length - 1; 13943 const finalKeyframe = unresolvedKeyframes[finalKeyframeIndex]; 13944 unresolvedKeyframes[finalKeyframeIndex] = positionalValues[name](element.measureViewportBox(), window.getComputedStyle(element.current)); 13945 if (finalKeyframe !== null && this.finalKeyframe === void 0) { 13946 this.finalKeyframe = finalKeyframe; 13947 } 13948 if ((_a = this.removedTransforms) === null || _a === void 0 ? void 0 : _a.length) { 13949 this.removedTransforms.forEach(([unsetTransformName, unsetTransformValue]) => { 13950 element.getValue(unsetTransformName).set(unsetTransformValue); 13951 }); 13952 } 13953 this.resolveNoneKeyframes(); 13954 } 13955 }; 13956 13957 // packages/components/node_modules/framer-motion/dist/es/animation/generators/utils/is-generator.mjs 13958 function isGenerator(type) { 13959 return typeof type === "function"; 13960 } 13961 13962 // packages/components/node_modules/framer-motion/dist/es/frameloop/sync-time.mjs 13963 var now; 13964 function clearTime() { 13965 now = void 0; 13966 } 13967 var time = { 13968 now: () => { 13969 if (now === void 0) { 13970 time.set(frameData.isProcessing || MotionGlobalConfig.useManualTiming ? frameData.timestamp : performance.now()); 13971 } 13972 return now; 13973 }, 13974 set: (newTime) => { 13975 now = newTime; 13976 queueMicrotask(clearTime); 13977 } 13978 }; 13979 13980 // packages/components/node_modules/framer-motion/dist/es/animation/utils/is-animatable.mjs 13981 var isAnimatable = (value, name) => { 13982 if (name === "zIndex") 13983 return false; 13984 if (typeof value === "number" || Array.isArray(value)) 13985 return true; 13986 if (typeof value === "string" && // It's animatable if we have a string 13987 (complex.test(value) || value === "0") && // And it contains numbers and/or colors 13988 !value.startsWith("url(")) { 13989 return true; 13990 } 13991 return false; 13992 }; 13993 13994 // packages/components/node_modules/framer-motion/dist/es/animation/animators/utils/can-animate.mjs 13995 function hasKeyframesChanged(keyframes5) { 13996 const current = keyframes5[0]; 13997 if (keyframes5.length === 1) 13998 return true; 13999 for (let i3 = 0; i3 < keyframes5.length; i3++) { 14000 if (keyframes5[i3] !== current) 14001 return true; 14002 } 14003 } 14004 function canAnimate(keyframes5, name, type, velocity) { 14005 const originKeyframe = keyframes5[0]; 14006 if (originKeyframe === null) 14007 return false; 14008 if (name === "display" || name === "visibility") 14009 return true; 14010 const targetKeyframe = keyframes5[keyframes5.length - 1]; 14011 const isOriginAnimatable = isAnimatable(originKeyframe, name); 14012 const isTargetAnimatable = isAnimatable(targetKeyframe, name); 14013 warning(isOriginAnimatable === isTargetAnimatable, `You are trying to animate $name} from "$originKeyframe}" to "$targetKeyframe}". $originKeyframe} is not an animatable value - to enable this animation set $originKeyframe} to a value animatable to $targetKeyframe} via the \`style\` property.`); 14014 if (!isOriginAnimatable || !isTargetAnimatable) { 14015 return false; 14016 } 14017 return hasKeyframesChanged(keyframes5) || (type === "spring" || isGenerator(type)) && velocity; 14018 } 14019 14020 // packages/components/node_modules/framer-motion/dist/es/animation/animators/BaseAnimation.mjs 14021 var MAX_RESOLVE_DELAY = 40; 14022 var BaseAnimation = class { 14023 constructor({ autoplay = true, delay: delay2 = 0, type = "keyframes", repeat = 0, repeatDelay = 0, repeatType = "loop", ...options2 }) { 14024 this.isStopped = false; 14025 this.hasAttemptedResolve = false; 14026 this.createdAt = time.now(); 14027 this.options = { 14028 autoplay, 14029 delay: delay2, 14030 type, 14031 repeat, 14032 repeatDelay, 14033 repeatType, 14034 ...options2 14035 }; 14036 this.updateFinishedPromise(); 14037 } 14038 /** 14039 * This method uses the createdAt and resolvedAt to calculate the 14040 * animation startTime. *Ideally*, we would use the createdAt time as t=0 14041 * as the following frame would then be the first frame of the animation in 14042 * progress, which would feel snappier. 14043 * 14044 * However, if there's a delay (main thread work) between the creation of 14045 * the animation and the first commited frame, we prefer to use resolvedAt 14046 * to avoid a sudden jump into the animation. 14047 */ 14048 calcStartTime() { 14049 if (!this.resolvedAt) 14050 return this.createdAt; 14051 return this.resolvedAt - this.createdAt > MAX_RESOLVE_DELAY ? this.resolvedAt : this.createdAt; 14052 } 14053 /** 14054 * A getter for resolved data. If keyframes are not yet resolved, accessing 14055 * this.resolved will synchronously flush all pending keyframe resolvers. 14056 * This is a deoptimisation, but at its worst still batches read/writes. 14057 */ 14058 get resolved() { 14059 if (!this._resolved && !this.hasAttemptedResolve) { 14060 flushKeyframeResolvers(); 14061 } 14062 return this._resolved; 14063 } 14064 /** 14065 * A method to be called when the keyframes resolver completes. This method 14066 * will check if its possible to run the animation and, if not, skip it. 14067 * Otherwise, it will call initPlayback on the implementing class. 14068 */ 14069 onKeyframesResolved(keyframes5, finalKeyframe) { 14070 this.resolvedAt = time.now(); 14071 this.hasAttemptedResolve = true; 14072 const { name, type, velocity, delay: delay2, onComplete, onUpdate, isGenerator: isGenerator2 } = this.options; 14073 if (!isGenerator2 && !canAnimate(keyframes5, name, type, velocity)) { 14074 if (instantAnimationState.current || !delay2) { 14075 onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(getFinalKeyframe(keyframes5, this.options, finalKeyframe)); 14076 onComplete === null || onComplete === void 0 ? void 0 : onComplete(); 14077 this.resolveFinishedPromise(); 14078 return; 14079 } else { 14080 this.options.duration = 0; 14081 } 14082 } 14083 const resolvedAnimation = this.initPlayback(keyframes5, finalKeyframe); 14084 if (resolvedAnimation === false) 14085 return; 14086 this._resolved = { 14087 keyframes: keyframes5, 14088 finalKeyframe, 14089 ...resolvedAnimation 14090 }; 14091 this.onPostResolved(); 14092 } 14093 onPostResolved() { 14094 } 14095 /** 14096 * Allows the returned animation to be awaited or promise-chained. Currently 14097 * resolves when the animation finishes at all but in a future update could/should 14098 * reject if its cancels. 14099 */ 14100 then(resolve, reject) { 14101 return this.currentFinishedPromise.then(resolve, reject); 14102 } 14103 flatten() { 14104 this.options.type = "keyframes"; 14105 this.options.ease = "linear"; 14106 } 14107 updateFinishedPromise() { 14108 this.currentFinishedPromise = new Promise((resolve) => { 14109 this.resolveFinishedPromise = resolve; 14110 }); 14111 } 14112 }; 14113 14114 // packages/components/node_modules/framer-motion/dist/es/utils/progress.mjs 14115 var progress = (from2, to, value) => { 14116 const toFromDifference = to - from2; 14117 return toFromDifference === 0 ? 1 : (value - from2) / toFromDifference; 14118 }; 14119 14120 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/linear.mjs 14121 var generateLinearEasing = (easing, duration, resolution = 10) => { 14122 let points = ""; 14123 const numPoints = Math.max(Math.round(duration / resolution), 2); 14124 for (let i3 = 0; i3 < numPoints; i3++) { 14125 points += easing(progress(0, numPoints - 1, i3)) + ", "; 14126 } 14127 return `linear($points.substring(0, points.length - 2)})`; 14128 }; 14129 14130 // packages/components/node_modules/framer-motion/dist/es/utils/velocity-per-second.mjs 14131 function velocityPerSecond(velocity, frameDuration) { 14132 return frameDuration ? velocity * (1e3 / frameDuration) : 0; 14133 } 14134 14135 // packages/components/node_modules/framer-motion/dist/es/animation/generators/utils/velocity.mjs 14136 var velocitySampleDuration = 5; 14137 function calcGeneratorVelocity(resolveValue, t4, current) { 14138 const prevT = Math.max(t4 - velocitySampleDuration, 0); 14139 return velocityPerSecond(current - resolveValue(prevT), t4 - prevT); 14140 } 14141 14142 // packages/components/node_modules/framer-motion/dist/es/animation/generators/spring/defaults.mjs 14143 var springDefaults = { 14144 // Default spring physics 14145 stiffness: 100, 14146 damping: 10, 14147 mass: 1, 14148 velocity: 0, 14149 // Default duration/bounce-based options 14150 duration: 800, 14151 // in ms 14152 bounce: 0.3, 14153 visualDuration: 0.3, 14154 // in seconds 14155 // Rest thresholds 14156 restSpeed: { 14157 granular: 0.01, 14158 default: 2 14159 }, 14160 restDelta: { 14161 granular: 5e-3, 14162 default: 0.5 14163 }, 14164 // Limits 14165 minDuration: 0.01, 14166 // in seconds 14167 maxDuration: 10, 14168 // in seconds 14169 minDamping: 0.05, 14170 maxDamping: 1 14171 }; 14172 14173 // packages/components/node_modules/framer-motion/dist/es/animation/generators/spring/find.mjs 14174 var safeMin = 1e-3; 14175 function findSpring({ duration = springDefaults.duration, bounce = springDefaults.bounce, velocity = springDefaults.velocity, mass = springDefaults.mass }) { 14176 let envelope; 14177 let derivative; 14178 warning(duration <= secondsToMilliseconds(springDefaults.maxDuration), "Spring duration must be 10 seconds or less"); 14179 let dampingRatio = 1 - bounce; 14180 dampingRatio = clamp2(springDefaults.minDamping, springDefaults.maxDamping, dampingRatio); 14181 duration = clamp2(springDefaults.minDuration, springDefaults.maxDuration, millisecondsToSeconds(duration)); 14182 if (dampingRatio < 1) { 14183 envelope = (undampedFreq2) => { 14184 const exponentialDecay = undampedFreq2 * dampingRatio; 14185 const delta = exponentialDecay * duration; 14186 const a3 = exponentialDecay - velocity; 14187 const b3 = calcAngularFreq(undampedFreq2, dampingRatio); 14188 const c3 = Math.exp(-delta); 14189 return safeMin - a3 / b3 * c3; 14190 }; 14191 derivative = (undampedFreq2) => { 14192 const exponentialDecay = undampedFreq2 * dampingRatio; 14193 const delta = exponentialDecay * duration; 14194 const d3 = delta * velocity + velocity; 14195 const e3 = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq2, 2) * duration; 14196 const f3 = Math.exp(-delta); 14197 const g3 = calcAngularFreq(Math.pow(undampedFreq2, 2), dampingRatio); 14198 const factor = -envelope(undampedFreq2) + safeMin > 0 ? -1 : 1; 14199 return factor * ((d3 - e3) * f3) / g3; 14200 }; 14201 } else { 14202 envelope = (undampedFreq2) => { 14203 const a3 = Math.exp(-undampedFreq2 * duration); 14204 const b3 = (undampedFreq2 - velocity) * duration + 1; 14205 return -safeMin + a3 * b3; 14206 }; 14207 derivative = (undampedFreq2) => { 14208 const a3 = Math.exp(-undampedFreq2 * duration); 14209 const b3 = (velocity - undampedFreq2) * (duration * duration); 14210 return a3 * b3; 14211 }; 14212 } 14213 const initialGuess = 5 / duration; 14214 const undampedFreq = approximateRoot(envelope, derivative, initialGuess); 14215 duration = secondsToMilliseconds(duration); 14216 if (isNaN(undampedFreq)) { 14217 return { 14218 stiffness: springDefaults.stiffness, 14219 damping: springDefaults.damping, 14220 duration 14221 }; 14222 } else { 14223 const stiffness = Math.pow(undampedFreq, 2) * mass; 14224 return { 14225 stiffness, 14226 damping: dampingRatio * 2 * Math.sqrt(mass * stiffness), 14227 duration 14228 }; 14229 } 14230 } 14231 var rootIterations = 12; 14232 function approximateRoot(envelope, derivative, initialGuess) { 14233 let result = initialGuess; 14234 for (let i3 = 1; i3 < rootIterations; i3++) { 14235 result = result - envelope(result) / derivative(result); 14236 } 14237 return result; 14238 } 14239 function calcAngularFreq(undampedFreq, dampingRatio) { 14240 return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio); 14241 } 14242 14243 // packages/components/node_modules/framer-motion/dist/es/animation/generators/utils/calc-duration.mjs 14244 var maxGeneratorDuration = 2e4; 14245 function calcGeneratorDuration(generator) { 14246 let duration = 0; 14247 const timeStep = 50; 14248 let state = generator.next(duration); 14249 while (!state.done && duration < maxGeneratorDuration) { 14250 duration += timeStep; 14251 state = generator.next(duration); 14252 } 14253 return duration >= maxGeneratorDuration ? Infinity : duration; 14254 } 14255 14256 // packages/components/node_modules/framer-motion/dist/es/animation/generators/spring/index.mjs 14257 var durationKeys = ["duration", "bounce"]; 14258 var physicsKeys = ["stiffness", "damping", "mass"]; 14259 function isSpringType(options2, keys) { 14260 return keys.some((key) => options2[key] !== void 0); 14261 } 14262 function getSpringOptions(options2) { 14263 let springOptions = { 14264 velocity: springDefaults.velocity, 14265 stiffness: springDefaults.stiffness, 14266 damping: springDefaults.damping, 14267 mass: springDefaults.mass, 14268 isResolvedFromDuration: false, 14269 ...options2 14270 }; 14271 if (!isSpringType(options2, physicsKeys) && isSpringType(options2, durationKeys)) { 14272 if (options2.visualDuration) { 14273 const visualDuration = options2.visualDuration; 14274 const root = 2 * Math.PI / (visualDuration * 1.2); 14275 const stiffness = root * root; 14276 const damping = 2 * clamp2(0.05, 1, 1 - options2.bounce) * Math.sqrt(stiffness); 14277 springOptions = { 14278 ...springOptions, 14279 mass: springDefaults.mass, 14280 stiffness, 14281 damping 14282 }; 14283 } else { 14284 const derived = findSpring(options2); 14285 springOptions = { 14286 ...springOptions, 14287 ...derived, 14288 mass: springDefaults.mass 14289 }; 14290 springOptions.isResolvedFromDuration = true; 14291 } 14292 } 14293 return springOptions; 14294 } 14295 function spring(optionsOrVisualDuration = springDefaults.visualDuration, bounce = springDefaults.bounce) { 14296 const options2 = typeof optionsOrVisualDuration !== "object" ? { 14297 visualDuration: optionsOrVisualDuration, 14298 keyframes: [0, 1], 14299 bounce 14300 } : optionsOrVisualDuration; 14301 let { restSpeed, restDelta } = options2; 14302 const origin = options2.keyframes[0]; 14303 const target = options2.keyframes[options2.keyframes.length - 1]; 14304 const state = { done: false, value: origin }; 14305 const { stiffness, damping, mass, duration, velocity, isResolvedFromDuration } = getSpringOptions({ 14306 ...options2, 14307 velocity: -millisecondsToSeconds(options2.velocity || 0) 14308 }); 14309 const initialVelocity = velocity || 0; 14310 const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass)); 14311 const initialDelta = target - origin; 14312 const undampedAngularFreq = millisecondsToSeconds(Math.sqrt(stiffness / mass)); 14313 const isGranularScale = Math.abs(initialDelta) < 5; 14314 restSpeed || (restSpeed = isGranularScale ? springDefaults.restSpeed.granular : springDefaults.restSpeed.default); 14315 restDelta || (restDelta = isGranularScale ? springDefaults.restDelta.granular : springDefaults.restDelta.default); 14316 let resolveSpring; 14317 if (dampingRatio < 1) { 14318 const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio); 14319 resolveSpring = (t4) => { 14320 const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t4); 14321 return target - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) / angularFreq * Math.sin(angularFreq * t4) + initialDelta * Math.cos(angularFreq * t4)); 14322 }; 14323 } else if (dampingRatio === 1) { 14324 resolveSpring = (t4) => target - Math.exp(-undampedAngularFreq * t4) * (initialDelta + (initialVelocity + undampedAngularFreq * initialDelta) * t4); 14325 } else { 14326 const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1); 14327 resolveSpring = (t4) => { 14328 const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t4); 14329 const freqForT = Math.min(dampedAngularFreq * t4, 300); 14330 return target - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) * Math.sinh(freqForT) + dampedAngularFreq * initialDelta * Math.cosh(freqForT)) / dampedAngularFreq; 14331 }; 14332 } 14333 const generator = { 14334 calculatedDuration: isResolvedFromDuration ? duration || null : null, 14335 next: (t4) => { 14336 const current = resolveSpring(t4); 14337 if (!isResolvedFromDuration) { 14338 let currentVelocity = 0; 14339 if (dampingRatio < 1) { 14340 currentVelocity = t4 === 0 ? secondsToMilliseconds(initialVelocity) : calcGeneratorVelocity(resolveSpring, t4, current); 14341 } 14342 const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed; 14343 const isBelowDisplacementThreshold = Math.abs(target - current) <= restDelta; 14344 state.done = isBelowVelocityThreshold && isBelowDisplacementThreshold; 14345 } else { 14346 state.done = t4 >= duration; 14347 } 14348 state.value = state.done ? target : current; 14349 return state; 14350 }, 14351 toString: () => { 14352 const calculatedDuration = Math.min(calcGeneratorDuration(generator), maxGeneratorDuration); 14353 const easing = generateLinearEasing((progress2) => generator.next(calculatedDuration * progress2).value, calculatedDuration, 30); 14354 return calculatedDuration + "ms " + easing; 14355 } 14356 }; 14357 return generator; 14358 } 14359 14360 // packages/components/node_modules/framer-motion/dist/es/animation/generators/inertia.mjs 14361 function inertia({ keyframes: keyframes5, velocity = 0, power = 0.8, timeConstant = 325, bounceDamping = 10, bounceStiffness = 500, modifyTarget, min: min3, max: max3, restDelta = 0.5, restSpeed }) { 14362 const origin = keyframes5[0]; 14363 const state = { 14364 done: false, 14365 value: origin 14366 }; 14367 const isOutOfBounds = (v3) => min3 !== void 0 && v3 < min3 || max3 !== void 0 && v3 > max3; 14368 const nearestBoundary = (v3) => { 14369 if (min3 === void 0) 14370 return max3; 14371 if (max3 === void 0) 14372 return min3; 14373 return Math.abs(min3 - v3) < Math.abs(max3 - v3) ? min3 : max3; 14374 }; 14375 let amplitude = power * velocity; 14376 const ideal = origin + amplitude; 14377 const target = modifyTarget === void 0 ? ideal : modifyTarget(ideal); 14378 if (target !== ideal) 14379 amplitude = target - origin; 14380 const calcDelta = (t4) => -amplitude * Math.exp(-t4 / timeConstant); 14381 const calcLatest = (t4) => target + calcDelta(t4); 14382 const applyFriction = (t4) => { 14383 const delta = calcDelta(t4); 14384 const latest = calcLatest(t4); 14385 state.done = Math.abs(delta) <= restDelta; 14386 state.value = state.done ? target : latest; 14387 }; 14388 let timeReachedBoundary; 14389 let spring$1; 14390 const checkCatchBoundary = (t4) => { 14391 if (!isOutOfBounds(state.value)) 14392 return; 14393 timeReachedBoundary = t4; 14394 spring$1 = spring({ 14395 keyframes: [state.value, nearestBoundary(state.value)], 14396 velocity: calcGeneratorVelocity(calcLatest, t4, state.value), 14397 // TODO: This should be passing * 1000 14398 damping: bounceDamping, 14399 stiffness: bounceStiffness, 14400 restDelta, 14401 restSpeed 14402 }); 14403 }; 14404 checkCatchBoundary(0); 14405 return { 14406 calculatedDuration: null, 14407 next: (t4) => { 14408 let hasUpdatedFrame = false; 14409 if (!spring$1 && timeReachedBoundary === void 0) { 14410 hasUpdatedFrame = true; 14411 applyFriction(t4); 14412 checkCatchBoundary(t4); 14413 } 14414 if (timeReachedBoundary !== void 0 && t4 >= timeReachedBoundary) { 14415 return spring$1.next(t4 - timeReachedBoundary); 14416 } else { 14417 !hasUpdatedFrame && applyFriction(t4); 14418 return state; 14419 } 14420 } 14421 }; 14422 } 14423 14424 // packages/components/node_modules/framer-motion/dist/es/easing/ease.mjs 14425 var easeIn = /* @__PURE__ */ cubicBezier(0.42, 0, 1, 1); 14426 var easeOut = /* @__PURE__ */ cubicBezier(0, 0, 0.58, 1); 14427 var easeInOut = /* @__PURE__ */ cubicBezier(0.42, 0, 0.58, 1); 14428 14429 // packages/components/node_modules/framer-motion/dist/es/easing/utils/is-easing-array.mjs 14430 var isEasingArray = (ease2) => { 14431 return Array.isArray(ease2) && typeof ease2[0] !== "number"; 14432 }; 14433 14434 // packages/components/node_modules/framer-motion/dist/es/easing/utils/is-bezier-definition.mjs 14435 var isBezierDefinition = (easing) => Array.isArray(easing) && typeof easing[0] === "number"; 14436 14437 // packages/components/node_modules/framer-motion/dist/es/easing/utils/map.mjs 14438 var easingLookup = { 14439 linear: noop2, 14440 easeIn, 14441 easeInOut, 14442 easeOut, 14443 circIn, 14444 circInOut, 14445 circOut, 14446 backIn, 14447 backInOut, 14448 backOut, 14449 anticipate 14450 }; 14451 var easingDefinitionToFunction = (definition) => { 14452 if (isBezierDefinition(definition)) { 14453 invariant2(definition.length === 4, `Cubic bezier arrays must contain four numerical values.`); 14454 const [x1, y1, x2, y22] = definition; 14455 return cubicBezier(x1, y1, x2, y22); 14456 } else if (typeof definition === "string") { 14457 invariant2(easingLookup[definition] !== void 0, `Invalid easing type '$definition}'`); 14458 return easingLookup[definition]; 14459 } 14460 return definition; 14461 }; 14462 14463 // packages/components/node_modules/framer-motion/dist/es/utils/pipe.mjs 14464 var combineFunctions = (a3, b3) => (v3) => b3(a3(v3)); 14465 var pipe = (...transformers) => transformers.reduce(combineFunctions); 14466 14467 // packages/components/node_modules/framer-motion/dist/es/utils/mix/number.mjs 14468 var mixNumber = (from2, to, progress2) => { 14469 return from2 + (to - from2) * progress2; 14470 }; 14471 14472 // packages/components/node_modules/framer-motion/dist/es/utils/hsla-to-rgba.mjs 14473 function hueToRgb(p3, q, t4) { 14474 if (t4 < 0) 14475 t4 += 1; 14476 if (t4 > 1) 14477 t4 -= 1; 14478 if (t4 < 1 / 6) 14479 return p3 + (q - p3) * 6 * t4; 14480 if (t4 < 1 / 2) 14481 return q; 14482 if (t4 < 2 / 3) 14483 return p3 + (q - p3) * (2 / 3 - t4) * 6; 14484 return p3; 14485 } 14486 function hslaToRgba({ hue, saturation, lightness, alpha: alpha2 }) { 14487 hue /= 360; 14488 saturation /= 100; 14489 lightness /= 100; 14490 let red = 0; 14491 let green = 0; 14492 let blue = 0; 14493 if (!saturation) { 14494 red = green = blue = lightness; 14495 } else { 14496 const q = lightness < 0.5 ? lightness * (1 + saturation) : lightness + saturation - lightness * saturation; 14497 const p3 = 2 * lightness - q; 14498 red = hueToRgb(p3, q, hue + 1 / 3); 14499 green = hueToRgb(p3, q, hue); 14500 blue = hueToRgb(p3, q, hue - 1 / 3); 14501 } 14502 return { 14503 red: Math.round(red * 255), 14504 green: Math.round(green * 255), 14505 blue: Math.round(blue * 255), 14506 alpha: alpha2 14507 }; 14508 } 14509 14510 // packages/components/node_modules/framer-motion/dist/es/utils/mix/immediate.mjs 14511 function mixImmediate(a3, b3) { 14512 return (p3) => p3 > 0 ? b3 : a3; 14513 } 14514 14515 // packages/components/node_modules/framer-motion/dist/es/utils/mix/color.mjs 14516 var mixLinearColor = (from2, to, v3) => { 14517 const fromExpo = from2 * from2; 14518 const expo = v3 * (to * to - fromExpo) + fromExpo; 14519 return expo < 0 ? 0 : Math.sqrt(expo); 14520 }; 14521 var colorTypes = [hex, rgba, hsla]; 14522 var getColorType = (v3) => colorTypes.find((type) => type.test(v3)); 14523 function asRGBA(color2) { 14524 const type = getColorType(color2); 14525 warning(Boolean(type), `'$color2}' is not an animatable color. Use the equivalent color code instead.`); 14526 if (!Boolean(type)) 14527 return false; 14528 let model = type.parse(color2); 14529 if (type === hsla) { 14530 model = hslaToRgba(model); 14531 } 14532 return model; 14533 } 14534 var mixColor = (from2, to) => { 14535 const fromRGBA = asRGBA(from2); 14536 const toRGBA = asRGBA(to); 14537 if (!fromRGBA || !toRGBA) { 14538 return mixImmediate(from2, to); 14539 } 14540 const blended = { ...fromRGBA }; 14541 return (v3) => { 14542 blended.red = mixLinearColor(fromRGBA.red, toRGBA.red, v3); 14543 blended.green = mixLinearColor(fromRGBA.green, toRGBA.green, v3); 14544 blended.blue = mixLinearColor(fromRGBA.blue, toRGBA.blue, v3); 14545 blended.alpha = mixNumber(fromRGBA.alpha, toRGBA.alpha, v3); 14546 return rgba.transform(blended); 14547 }; 14548 }; 14549 14550 // packages/components/node_modules/framer-motion/dist/es/utils/mix/visibility.mjs 14551 var invisibleValues = /* @__PURE__ */ new Set(["none", "hidden"]); 14552 function mixVisibility(origin, target) { 14553 if (invisibleValues.has(origin)) { 14554 return (p3) => p3 <= 0 ? origin : target; 14555 } else { 14556 return (p3) => p3 >= 1 ? target : origin; 14557 } 14558 } 14559 14560 // packages/components/node_modules/framer-motion/dist/es/utils/mix/complex.mjs 14561 function mixNumber2(a3, b3) { 14562 return (p3) => mixNumber(a3, b3, p3); 14563 } 14564 function getMixer(a3) { 14565 if (typeof a3 === "number") { 14566 return mixNumber2; 14567 } else if (typeof a3 === "string") { 14568 return isCSSVariableToken(a3) ? mixImmediate : color.test(a3) ? mixColor : mixComplex; 14569 } else if (Array.isArray(a3)) { 14570 return mixArray; 14571 } else if (typeof a3 === "object") { 14572 return color.test(a3) ? mixColor : mixObject; 14573 } 14574 return mixImmediate; 14575 } 14576 function mixArray(a3, b3) { 14577 const output = [...a3]; 14578 const numValues = output.length; 14579 const blendValue = a3.map((v3, i3) => getMixer(v3)(v3, b3[i3])); 14580 return (p3) => { 14581 for (let i3 = 0; i3 < numValues; i3++) { 14582 output[i3] = blendValue[i3](p3); 14583 } 14584 return output; 14585 }; 14586 } 14587 function mixObject(a3, b3) { 14588 const output = { ...a3, ...b3 }; 14589 const blendValue = {}; 14590 for (const key in output) { 14591 if (a3[key] !== void 0 && b3[key] !== void 0) { 14592 blendValue[key] = getMixer(a3[key])(a3[key], b3[key]); 14593 } 14594 } 14595 return (v3) => { 14596 for (const key in blendValue) { 14597 output[key] = blendValue[key](v3); 14598 } 14599 return output; 14600 }; 14601 } 14602 function matchOrder(origin, target) { 14603 var _a; 14604 const orderedOrigin = []; 14605 const pointers = { color: 0, var: 0, number: 0 }; 14606 for (let i3 = 0; i3 < target.values.length; i3++) { 14607 const type = target.types[i3]; 14608 const originIndex = origin.indexes[type][pointers[type]]; 14609 const originValue = (_a = origin.values[originIndex]) !== null && _a !== void 0 ? _a : 0; 14610 orderedOrigin[i3] = originValue; 14611 pointers[type]++; 14612 } 14613 return orderedOrigin; 14614 } 14615 var mixComplex = (origin, target) => { 14616 const template = complex.createTransformer(target); 14617 const originStats = analyseComplexValue(origin); 14618 const targetStats = analyseComplexValue(target); 14619 const canInterpolate = originStats.indexes.var.length === targetStats.indexes.var.length && originStats.indexes.color.length === targetStats.indexes.color.length && originStats.indexes.number.length >= targetStats.indexes.number.length; 14620 if (canInterpolate) { 14621 if (invisibleValues.has(origin) && !targetStats.values.length || invisibleValues.has(target) && !originStats.values.length) { 14622 return mixVisibility(origin, target); 14623 } 14624 return pipe(mixArray(matchOrder(originStats, targetStats), targetStats.values), template); 14625 } else { 14626 warning(true, `Complex values '$origin}' and '$target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`); 14627 return mixImmediate(origin, target); 14628 } 14629 }; 14630 14631 // packages/components/node_modules/framer-motion/dist/es/utils/mix/index.mjs 14632 function mix(from2, to, p3) { 14633 if (typeof from2 === "number" && typeof to === "number" && typeof p3 === "number") { 14634 return mixNumber(from2, to, p3); 14635 } 14636 const mixer = getMixer(from2); 14637 return mixer(from2, to); 14638 } 14639 14640 // packages/components/node_modules/framer-motion/dist/es/utils/interpolate.mjs 14641 function createMixers(output, ease2, customMixer) { 14642 const mixers = []; 14643 const mixerFactory = customMixer || mix; 14644 const numMixers = output.length - 1; 14645 for (let i3 = 0; i3 < numMixers; i3++) { 14646 let mixer = mixerFactory(output[i3], output[i3 + 1]); 14647 if (ease2) { 14648 const easingFunction = Array.isArray(ease2) ? ease2[i3] || noop2 : ease2; 14649 mixer = pipe(easingFunction, mixer); 14650 } 14651 mixers.push(mixer); 14652 } 14653 return mixers; 14654 } 14655 function interpolate(input, output, { clamp: isClamp = true, ease: ease2, mixer } = {}) { 14656 const inputLength = input.length; 14657 invariant2(inputLength === output.length, "Both input and output ranges must be the same length"); 14658 if (inputLength === 1) 14659 return () => output[0]; 14660 if (inputLength === 2 && input[0] === input[1]) 14661 return () => output[1]; 14662 if (input[0] > input[inputLength - 1]) { 14663 input = [...input].reverse(); 14664 output = [...output].reverse(); 14665 } 14666 const mixers = createMixers(output, ease2, mixer); 14667 const numMixers = mixers.length; 14668 const interpolator = (v3) => { 14669 let i3 = 0; 14670 if (numMixers > 1) { 14671 for (; i3 < input.length - 2; i3++) { 14672 if (v3 < input[i3 + 1]) 14673 break; 14674 } 14675 } 14676 const progressInRange = progress(input[i3], input[i3 + 1], v3); 14677 return mixers[i3](progressInRange); 14678 }; 14679 return isClamp ? (v3) => interpolator(clamp2(input[0], input[inputLength - 1], v3)) : interpolator; 14680 } 14681 14682 // packages/components/node_modules/framer-motion/dist/es/utils/offsets/fill.mjs 14683 function fillOffset(offset3, remaining) { 14684 const min3 = offset3[offset3.length - 1]; 14685 for (let i3 = 1; i3 <= remaining; i3++) { 14686 const offsetProgress = progress(0, remaining, i3); 14687 offset3.push(mixNumber(min3, 1, offsetProgress)); 14688 } 14689 } 14690 14691 // packages/components/node_modules/framer-motion/dist/es/utils/offsets/default.mjs 14692 function defaultOffset(arr) { 14693 const offset3 = [0]; 14694 fillOffset(offset3, arr.length - 1); 14695 return offset3; 14696 } 14697 14698 // packages/components/node_modules/framer-motion/dist/es/utils/offsets/time.mjs 14699 function convertOffsetToTimes(offset3, duration) { 14700 return offset3.map((o4) => o4 * duration); 14701 } 14702 14703 // packages/components/node_modules/framer-motion/dist/es/animation/generators/keyframes.mjs 14704 function defaultEasing(values, easing) { 14705 return values.map(() => easing || easeInOut).splice(0, values.length - 1); 14706 } 14707 function keyframes({ duration = 300, keyframes: keyframeValues, times, ease: ease2 = "easeInOut" }) { 14708 const easingFunctions = isEasingArray(ease2) ? ease2.map(easingDefinitionToFunction) : easingDefinitionToFunction(ease2); 14709 const state = { 14710 done: false, 14711 value: keyframeValues[0] 14712 }; 14713 const absoluteTimes = convertOffsetToTimes( 14714 // Only use the provided offsets if they're the correct length 14715 // TODO Maybe we should warn here if there's a length mismatch 14716 times && times.length === keyframeValues.length ? times : defaultOffset(keyframeValues), 14717 duration 14718 ); 14719 const mapTimeToKeyframe = interpolate(absoluteTimes, keyframeValues, { 14720 ease: Array.isArray(easingFunctions) ? easingFunctions : defaultEasing(keyframeValues, easingFunctions) 14721 }); 14722 return { 14723 calculatedDuration: duration, 14724 next: (t4) => { 14725 state.value = mapTimeToKeyframe(t4); 14726 state.done = t4 >= duration; 14727 return state; 14728 } 14729 }; 14730 } 14731 14732 // packages/components/node_modules/framer-motion/dist/es/animation/animators/drivers/driver-frameloop.mjs 14733 var frameloopDriver = (update) => { 14734 const passTimestamp = ({ timestamp }) => update(timestamp); 14735 return { 14736 start: () => frame.update(passTimestamp, true), 14737 stop: () => cancelFrame(passTimestamp), 14738 /** 14739 * If we're processing this frame we can use the 14740 * framelocked timestamp to keep things in sync. 14741 */ 14742 now: () => frameData.isProcessing ? frameData.timestamp : time.now() 14743 }; 14744 }; 14745 14746 // packages/components/node_modules/framer-motion/dist/es/animation/animators/MainThreadAnimation.mjs 14747 var generators = { 14748 decay: inertia, 14749 inertia, 14750 tween: keyframes, 14751 keyframes, 14752 spring 14753 }; 14754 var percentToProgress = (percent2) => percent2 / 100; 14755 var MainThreadAnimation = class extends BaseAnimation { 14756 constructor(options2) { 14757 super(options2); 14758 this.holdTime = null; 14759 this.cancelTime = null; 14760 this.currentTime = 0; 14761 this.playbackSpeed = 1; 14762 this.pendingPlayState = "running"; 14763 this.startTime = null; 14764 this.state = "idle"; 14765 this.stop = () => { 14766 this.resolver.cancel(); 14767 this.isStopped = true; 14768 if (this.state === "idle") 14769 return; 14770 this.teardown(); 14771 const { onStop } = this.options; 14772 onStop && onStop(); 14773 }; 14774 const { name, motionValue: motionValue2, element, keyframes: keyframes5 } = this.options; 14775 const KeyframeResolver$1 = (element === null || element === void 0 ? void 0 : element.KeyframeResolver) || KeyframeResolver; 14776 const onResolved = (resolvedKeyframes, finalKeyframe) => this.onKeyframesResolved(resolvedKeyframes, finalKeyframe); 14777 this.resolver = new KeyframeResolver$1(keyframes5, onResolved, name, motionValue2, element); 14778 this.resolver.scheduleResolve(); 14779 } 14780 flatten() { 14781 super.flatten(); 14782 if (this._resolved) { 14783 Object.assign(this._resolved, this.initPlayback(this._resolved.keyframes)); 14784 } 14785 } 14786 initPlayback(keyframes$1) { 14787 const { type = "keyframes", repeat = 0, repeatDelay = 0, repeatType, velocity = 0 } = this.options; 14788 const generatorFactory = isGenerator(type) ? type : generators[type] || keyframes; 14789 let mapPercentToKeyframes; 14790 let mirroredGenerator; 14791 if (generatorFactory !== keyframes && typeof keyframes$1[0] !== "number") { 14792 if (true) { 14793 invariant2(keyframes$1.length === 2, `Only two keyframes currently supported with spring and inertia animations. Trying to animate $keyframes$1}`); 14794 } 14795 mapPercentToKeyframes = pipe(percentToProgress, mix(keyframes$1[0], keyframes$1[1])); 14796 keyframes$1 = [0, 100]; 14797 } 14798 const generator = generatorFactory({ ...this.options, keyframes: keyframes$1 }); 14799 if (repeatType === "mirror") { 14800 mirroredGenerator = generatorFactory({ 14801 ...this.options, 14802 keyframes: [...keyframes$1].reverse(), 14803 velocity: -velocity 14804 }); 14805 } 14806 if (generator.calculatedDuration === null) { 14807 generator.calculatedDuration = calcGeneratorDuration(generator); 14808 } 14809 const { calculatedDuration } = generator; 14810 const resolvedDuration = calculatedDuration + repeatDelay; 14811 const totalDuration = resolvedDuration * (repeat + 1) - repeatDelay; 14812 return { 14813 generator, 14814 mirroredGenerator, 14815 mapPercentToKeyframes, 14816 calculatedDuration, 14817 resolvedDuration, 14818 totalDuration 14819 }; 14820 } 14821 onPostResolved() { 14822 const { autoplay = true } = this.options; 14823 this.play(); 14824 if (this.pendingPlayState === "paused" || !autoplay) { 14825 this.pause(); 14826 } else { 14827 this.state = this.pendingPlayState; 14828 } 14829 } 14830 tick(timestamp, sample = false) { 14831 const { resolved } = this; 14832 if (!resolved) { 14833 const { keyframes: keyframes6 } = this.options; 14834 return { done: true, value: keyframes6[keyframes6.length - 1] }; 14835 } 14836 const { finalKeyframe, generator, mirroredGenerator, mapPercentToKeyframes, keyframes: keyframes5, calculatedDuration, totalDuration, resolvedDuration } = resolved; 14837 if (this.startTime === null) 14838 return generator.next(0); 14839 const { delay: delay2, repeat, repeatType, repeatDelay, onUpdate } = this.options; 14840 if (this.speed > 0) { 14841 this.startTime = Math.min(this.startTime, timestamp); 14842 } else if (this.speed < 0) { 14843 this.startTime = Math.min(timestamp - totalDuration / this.speed, this.startTime); 14844 } 14845 if (sample) { 14846 this.currentTime = timestamp; 14847 } else if (this.holdTime !== null) { 14848 this.currentTime = this.holdTime; 14849 } else { 14850 this.currentTime = Math.round(timestamp - this.startTime) * this.speed; 14851 } 14852 const timeWithoutDelay = this.currentTime - delay2 * (this.speed >= 0 ? 1 : -1); 14853 const isInDelayPhase = this.speed >= 0 ? timeWithoutDelay < 0 : timeWithoutDelay > totalDuration; 14854 this.currentTime = Math.max(timeWithoutDelay, 0); 14855 if (this.state === "finished" && this.holdTime === null) { 14856 this.currentTime = totalDuration; 14857 } 14858 let elapsed = this.currentTime; 14859 let frameGenerator = generator; 14860 if (repeat) { 14861 const progress2 = Math.min(this.currentTime, totalDuration) / resolvedDuration; 14862 let currentIteration = Math.floor(progress2); 14863 let iterationProgress = progress2 % 1; 14864 if (!iterationProgress && progress2 >= 1) { 14865 iterationProgress = 1; 14866 } 14867 iterationProgress === 1 && currentIteration--; 14868 currentIteration = Math.min(currentIteration, repeat + 1); 14869 const isOddIteration = Boolean(currentIteration % 2); 14870 if (isOddIteration) { 14871 if (repeatType === "reverse") { 14872 iterationProgress = 1 - iterationProgress; 14873 if (repeatDelay) { 14874 iterationProgress -= repeatDelay / resolvedDuration; 14875 } 14876 } else if (repeatType === "mirror") { 14877 frameGenerator = mirroredGenerator; 14878 } 14879 } 14880 elapsed = clamp2(0, 1, iterationProgress) * resolvedDuration; 14881 } 14882 const state = isInDelayPhase ? { done: false, value: keyframes5[0] } : frameGenerator.next(elapsed); 14883 if (mapPercentToKeyframes) { 14884 state.value = mapPercentToKeyframes(state.value); 14885 } 14886 let { done } = state; 14887 if (!isInDelayPhase && calculatedDuration !== null) { 14888 done = this.speed >= 0 ? this.currentTime >= totalDuration : this.currentTime <= 0; 14889 } 14890 const isAnimationFinished = this.holdTime === null && (this.state === "finished" || this.state === "running" && done); 14891 if (isAnimationFinished && finalKeyframe !== void 0) { 14892 state.value = getFinalKeyframe(keyframes5, this.options, finalKeyframe); 14893 } 14894 if (onUpdate) { 14895 onUpdate(state.value); 14896 } 14897 if (isAnimationFinished) { 14898 this.finish(); 14899 } 14900 return state; 14901 } 14902 get duration() { 14903 const { resolved } = this; 14904 return resolved ? millisecondsToSeconds(resolved.calculatedDuration) : 0; 14905 } 14906 get time() { 14907 return millisecondsToSeconds(this.currentTime); 14908 } 14909 set time(newTime) { 14910 newTime = secondsToMilliseconds(newTime); 14911 this.currentTime = newTime; 14912 if (this.holdTime !== null || this.speed === 0) { 14913 this.holdTime = newTime; 14914 } else if (this.driver) { 14915 this.startTime = this.driver.now() - newTime / this.speed; 14916 } 14917 } 14918 get speed() { 14919 return this.playbackSpeed; 14920 } 14921 set speed(newSpeed) { 14922 const hasChanged = this.playbackSpeed !== newSpeed; 14923 this.playbackSpeed = newSpeed; 14924 if (hasChanged) { 14925 this.time = millisecondsToSeconds(this.currentTime); 14926 } 14927 } 14928 play() { 14929 if (!this.resolver.isScheduled) { 14930 this.resolver.resume(); 14931 } 14932 if (!this._resolved) { 14933 this.pendingPlayState = "running"; 14934 return; 14935 } 14936 if (this.isStopped) 14937 return; 14938 const { driver = frameloopDriver, onPlay, startTime } = this.options; 14939 if (!this.driver) { 14940 this.driver = driver((timestamp) => this.tick(timestamp)); 14941 } 14942 onPlay && onPlay(); 14943 const now2 = this.driver.now(); 14944 if (this.holdTime !== null) { 14945 this.startTime = now2 - this.holdTime; 14946 } else if (!this.startTime) { 14947 this.startTime = startTime !== null && startTime !== void 0 ? startTime : this.calcStartTime(); 14948 } else if (this.state === "finished") { 14949 this.startTime = now2; 14950 } 14951 if (this.state === "finished") { 14952 this.updateFinishedPromise(); 14953 } 14954 this.cancelTime = this.startTime; 14955 this.holdTime = null; 14956 this.state = "running"; 14957 this.driver.start(); 14958 } 14959 pause() { 14960 var _a; 14961 if (!this._resolved) { 14962 this.pendingPlayState = "paused"; 14963 return; 14964 } 14965 this.state = "paused"; 14966 this.holdTime = (_a = this.currentTime) !== null && _a !== void 0 ? _a : 0; 14967 } 14968 complete() { 14969 if (this.state !== "running") { 14970 this.play(); 14971 } 14972 this.pendingPlayState = this.state = "finished"; 14973 this.holdTime = null; 14974 } 14975 finish() { 14976 this.teardown(); 14977 this.state = "finished"; 14978 const { onComplete } = this.options; 14979 onComplete && onComplete(); 14980 } 14981 cancel() { 14982 if (this.cancelTime !== null) { 14983 this.tick(this.cancelTime); 14984 } 14985 this.teardown(); 14986 this.updateFinishedPromise(); 14987 } 14988 teardown() { 14989 this.state = "idle"; 14990 this.stopDriver(); 14991 this.resolveFinishedPromise(); 14992 this.updateFinishedPromise(); 14993 this.startTime = this.cancelTime = null; 14994 this.resolver.cancel(); 14995 } 14996 stopDriver() { 14997 if (!this.driver) 14998 return; 14999 this.driver.stop(); 15000 this.driver = void 0; 15001 } 15002 sample(time2) { 15003 this.startTime = 0; 15004 return this.tick(time2, true); 15005 } 15006 }; 15007 15008 // packages/components/node_modules/framer-motion/dist/es/animation/animators/utils/accelerated-values.mjs 15009 var acceleratedValues = /* @__PURE__ */ new Set([ 15010 "opacity", 15011 "clipPath", 15012 "filter", 15013 "transform" 15014 // TODO: Can be accelerated but currently disabled until https://issues.chromium.org/issues/41491098 is resolved 15015 // or until we implement support for linear() easing. 15016 // "background-color" 15017 ]); 15018 15019 // packages/components/node_modules/framer-motion/dist/es/utils/memo.mjs 15020 function memo3(callback) { 15021 let result; 15022 return () => { 15023 if (result === void 0) 15024 result = callback(); 15025 return result; 15026 }; 15027 } 15028 15029 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/supports-flags.mjs 15030 var supportsFlags = { 15031 linearEasing: void 0 15032 }; 15033 15034 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/memo-supports.mjs 15035 function memoSupports(callback, supportsFlag) { 15036 const memoized = memo3(callback); 15037 return () => { 15038 var _a; 15039 return (_a = supportsFlags[supportsFlag]) !== null && _a !== void 0 ? _a : memoized(); 15040 }; 15041 } 15042 15043 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/supports-linear-easing.mjs 15044 var supportsLinearEasing = /* @__PURE__ */ memoSupports(() => { 15045 try { 15046 document.createElement("div").animate({ opacity: 0 }, { easing: "linear(0, 1)" }); 15047 } catch (e3) { 15048 return false; 15049 } 15050 return true; 15051 }, "linearEasing"); 15052 15053 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/easing.mjs 15054 function isWaapiSupportedEasing(easing) { 15055 return Boolean(typeof easing === "function" && supportsLinearEasing() || !easing || typeof easing === "string" && (easing in supportedWaapiEasing || supportsLinearEasing()) || isBezierDefinition(easing) || Array.isArray(easing) && easing.every(isWaapiSupportedEasing)); 15056 } 15057 var cubicBezierAsString = ([a3, b3, c3, d3]) => `cubic-bezier($a3}, $b3}, $c3}, $d3})`; 15058 var supportedWaapiEasing = { 15059 linear: "linear", 15060 ease: "ease", 15061 easeIn: "ease-in", 15062 easeOut: "ease-out", 15063 easeInOut: "ease-in-out", 15064 circIn: /* @__PURE__ */ cubicBezierAsString([0, 0.65, 0.55, 1]), 15065 circOut: /* @__PURE__ */ cubicBezierAsString([0.55, 0, 1, 0.45]), 15066 backIn: /* @__PURE__ */ cubicBezierAsString([0.31, 0.01, 0.66, -0.59]), 15067 backOut: /* @__PURE__ */ cubicBezierAsString([0.33, 1.53, 0.69, 0.99]) 15068 }; 15069 function mapEasingToNativeEasing(easing, duration) { 15070 if (!easing) { 15071 return void 0; 15072 } else if (typeof easing === "function" && supportsLinearEasing()) { 15073 return generateLinearEasing(easing, duration); 15074 } else if (isBezierDefinition(easing)) { 15075 return cubicBezierAsString(easing); 15076 } else if (Array.isArray(easing)) { 15077 return easing.map((segmentEasing) => mapEasingToNativeEasing(segmentEasing, duration) || supportedWaapiEasing.easeOut); 15078 } else { 15079 return supportedWaapiEasing[easing]; 15080 } 15081 } 15082 15083 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/index.mjs 15084 function startWaapiAnimation(element, valueName, keyframes5, { delay: delay2 = 0, duration = 300, repeat = 0, repeatType = "loop", ease: ease2 = "easeInOut", times } = {}) { 15085 const keyframeOptions = { [valueName]: keyframes5 }; 15086 if (times) 15087 keyframeOptions.offset = times; 15088 const easing = mapEasingToNativeEasing(ease2, duration); 15089 if (Array.isArray(easing)) 15090 keyframeOptions.easing = easing; 15091 return element.animate(keyframeOptions, { 15092 delay: delay2, 15093 duration, 15094 easing: !Array.isArray(easing) ? easing : "linear", 15095 fill: "both", 15096 iterations: repeat + 1, 15097 direction: repeatType === "reverse" ? "alternate" : "normal" 15098 }); 15099 } 15100 15101 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/attach-timeline.mjs 15102 function attachTimeline(animation, timeline) { 15103 animation.timeline = timeline; 15104 animation.onfinish = null; 15105 } 15106 15107 // packages/components/node_modules/framer-motion/dist/es/animation/animators/waapi/utils/supports-waapi.mjs 15108 var supportsWaapi = /* @__PURE__ */ memo3(() => Object.hasOwnProperty.call(Element.prototype, "animate")); 15109 15110 // packages/components/node_modules/framer-motion/dist/es/animation/animators/AcceleratedAnimation.mjs 15111 var sampleDelta = 10; 15112 var maxDuration = 2e4; 15113 function requiresPregeneratedKeyframes(options2) { 15114 return isGenerator(options2.type) || options2.type === "spring" || !isWaapiSupportedEasing(options2.ease); 15115 } 15116 function pregenerateKeyframes(keyframes5, options2) { 15117 const sampleAnimation = new MainThreadAnimation({ 15118 ...options2, 15119 keyframes: keyframes5, 15120 repeat: 0, 15121 delay: 0, 15122 isGenerator: true 15123 }); 15124 let state = { done: false, value: keyframes5[0] }; 15125 const pregeneratedKeyframes = []; 15126 let t4 = 0; 15127 while (!state.done && t4 < maxDuration) { 15128 state = sampleAnimation.sample(t4); 15129 pregeneratedKeyframes.push(state.value); 15130 t4 += sampleDelta; 15131 } 15132 return { 15133 times: void 0, 15134 keyframes: pregeneratedKeyframes, 15135 duration: t4 - sampleDelta, 15136 ease: "linear" 15137 }; 15138 } 15139 var unsupportedEasingFunctions = { 15140 anticipate, 15141 backInOut, 15142 circInOut 15143 }; 15144 function isUnsupportedEase(key) { 15145 return key in unsupportedEasingFunctions; 15146 } 15147 var AcceleratedAnimation = class extends BaseAnimation { 15148 constructor(options2) { 15149 super(options2); 15150 const { name, motionValue: motionValue2, element, keyframes: keyframes5 } = this.options; 15151 this.resolver = new DOMKeyframesResolver(keyframes5, (resolvedKeyframes, finalKeyframe) => this.onKeyframesResolved(resolvedKeyframes, finalKeyframe), name, motionValue2, element); 15152 this.resolver.scheduleResolve(); 15153 } 15154 initPlayback(keyframes5, finalKeyframe) { 15155 var _a; 15156 let { duration = 300, times, ease: ease2, type, motionValue: motionValue2, name, startTime } = this.options; 15157 if (!((_a = motionValue2.owner) === null || _a === void 0 ? void 0 : _a.current)) { 15158 return false; 15159 } 15160 if (typeof ease2 === "string" && supportsLinearEasing() && isUnsupportedEase(ease2)) { 15161 ease2 = unsupportedEasingFunctions[ease2]; 15162 } 15163 if (requiresPregeneratedKeyframes(this.options)) { 15164 const { onComplete, onUpdate, motionValue: motionValue3, element, ...options2 } = this.options; 15165 const pregeneratedAnimation = pregenerateKeyframes(keyframes5, options2); 15166 keyframes5 = pregeneratedAnimation.keyframes; 15167 if (keyframes5.length === 1) { 15168 keyframes5[1] = keyframes5[0]; 15169 } 15170 duration = pregeneratedAnimation.duration; 15171 times = pregeneratedAnimation.times; 15172 ease2 = pregeneratedAnimation.ease; 15173 type = "keyframes"; 15174 } 15175 const animation = startWaapiAnimation(motionValue2.owner.current, name, keyframes5, { ...this.options, duration, times, ease: ease2 }); 15176 animation.startTime = startTime !== null && startTime !== void 0 ? startTime : this.calcStartTime(); 15177 if (this.pendingTimeline) { 15178 attachTimeline(animation, this.pendingTimeline); 15179 this.pendingTimeline = void 0; 15180 } else { 15181 animation.onfinish = () => { 15182 const { onComplete } = this.options; 15183 motionValue2.set(getFinalKeyframe(keyframes5, this.options, finalKeyframe)); 15184 onComplete && onComplete(); 15185 this.cancel(); 15186 this.resolveFinishedPromise(); 15187 }; 15188 } 15189 return { 15190 animation, 15191 duration, 15192 times, 15193 type, 15194 ease: ease2, 15195 keyframes: keyframes5 15196 }; 15197 } 15198 get duration() { 15199 const { resolved } = this; 15200 if (!resolved) 15201 return 0; 15202 const { duration } = resolved; 15203 return millisecondsToSeconds(duration); 15204 } 15205 get time() { 15206 const { resolved } = this; 15207 if (!resolved) 15208 return 0; 15209 const { animation } = resolved; 15210 return millisecondsToSeconds(animation.currentTime || 0); 15211 } 15212 set time(newTime) { 15213 const { resolved } = this; 15214 if (!resolved) 15215 return; 15216 const { animation } = resolved; 15217 animation.currentTime = secondsToMilliseconds(newTime); 15218 } 15219 get speed() { 15220 const { resolved } = this; 15221 if (!resolved) 15222 return 1; 15223 const { animation } = resolved; 15224 return animation.playbackRate; 15225 } 15226 set speed(newSpeed) { 15227 const { resolved } = this; 15228 if (!resolved) 15229 return; 15230 const { animation } = resolved; 15231 animation.playbackRate = newSpeed; 15232 } 15233 get state() { 15234 const { resolved } = this; 15235 if (!resolved) 15236 return "idle"; 15237 const { animation } = resolved; 15238 return animation.playState; 15239 } 15240 get startTime() { 15241 const { resolved } = this; 15242 if (!resolved) 15243 return null; 15244 const { animation } = resolved; 15245 return animation.startTime; 15246 } 15247 /** 15248 * Replace the default DocumentTimeline with another AnimationTimeline. 15249 * Currently used for scroll animations. 15250 */ 15251 attachTimeline(timeline) { 15252 if (!this._resolved) { 15253 this.pendingTimeline = timeline; 15254 } else { 15255 const { resolved } = this; 15256 if (!resolved) 15257 return noop2; 15258 const { animation } = resolved; 15259 attachTimeline(animation, timeline); 15260 } 15261 return noop2; 15262 } 15263 play() { 15264 if (this.isStopped) 15265 return; 15266 const { resolved } = this; 15267 if (!resolved) 15268 return; 15269 const { animation } = resolved; 15270 if (animation.playState === "finished") { 15271 this.updateFinishedPromise(); 15272 } 15273 animation.play(); 15274 } 15275 pause() { 15276 const { resolved } = this; 15277 if (!resolved) 15278 return; 15279 const { animation } = resolved; 15280 animation.pause(); 15281 } 15282 stop() { 15283 this.resolver.cancel(); 15284 this.isStopped = true; 15285 if (this.state === "idle") 15286 return; 15287 this.resolveFinishedPromise(); 15288 this.updateFinishedPromise(); 15289 const { resolved } = this; 15290 if (!resolved) 15291 return; 15292 const { animation, keyframes: keyframes5, duration, type, ease: ease2, times } = resolved; 15293 if (animation.playState === "idle" || animation.playState === "finished") { 15294 return; 15295 } 15296 if (this.time) { 15297 const { motionValue: motionValue2, onUpdate, onComplete, element, ...options2 } = this.options; 15298 const sampleAnimation = new MainThreadAnimation({ 15299 ...options2, 15300 keyframes: keyframes5, 15301 duration, 15302 type, 15303 ease: ease2, 15304 times, 15305 isGenerator: true 15306 }); 15307 const sampleTime = secondsToMilliseconds(this.time); 15308 motionValue2.setWithVelocity(sampleAnimation.sample(sampleTime - sampleDelta).value, sampleAnimation.sample(sampleTime).value, sampleDelta); 15309 } 15310 const { onStop } = this.options; 15311 onStop && onStop(); 15312 this.cancel(); 15313 } 15314 complete() { 15315 const { resolved } = this; 15316 if (!resolved) 15317 return; 15318 resolved.animation.finish(); 15319 } 15320 cancel() { 15321 const { resolved } = this; 15322 if (!resolved) 15323 return; 15324 resolved.animation.cancel(); 15325 } 15326 static supports(options2) { 15327 const { motionValue: motionValue2, name, repeatDelay, repeatType, damping, type } = options2; 15328 return supportsWaapi() && name && acceleratedValues.has(name) && motionValue2 && motionValue2.owner && motionValue2.owner.current instanceof HTMLElement && /** 15329 * If we're outputting values to onUpdate then we can't use WAAPI as there's 15330 * no way to read the value from WAAPI every frame. 15331 */ 15332 !motionValue2.owner.getProps().onUpdate && !repeatDelay && repeatType !== "mirror" && damping !== 0 && type !== "inertia"; 15333 } 15334 }; 15335 15336 // packages/components/node_modules/framer-motion/dist/es/render/dom/scroll/supports.mjs 15337 var supportsScrollTimeline = memo3(() => window.ScrollTimeline !== void 0); 15338 15339 // packages/components/node_modules/framer-motion/dist/es/animation/GroupPlaybackControls.mjs 15340 var GroupPlaybackControls = class { 15341 constructor(animations2) { 15342 this.stop = () => this.runAll("stop"); 15343 this.animations = animations2.filter(Boolean); 15344 } 15345 then(onResolve, onReject) { 15346 return Promise.all(this.animations).then(onResolve).catch(onReject); 15347 } 15348 /** 15349 * TODO: Filter out cancelled or stopped animations before returning 15350 */ 15351 getAll(propName) { 15352 return this.animations[0][propName]; 15353 } 15354 setAll(propName, newValue) { 15355 for (let i3 = 0; i3 < this.animations.length; i3++) { 15356 this.animations[i3][propName] = newValue; 15357 } 15358 } 15359 attachTimeline(timeline, fallback) { 15360 const subscriptions = this.animations.map((animation) => { 15361 if (supportsScrollTimeline() && animation.attachTimeline) { 15362 return animation.attachTimeline(timeline); 15363 } else { 15364 return fallback(animation); 15365 } 15366 }); 15367 return () => { 15368 subscriptions.forEach((cancel, i3) => { 15369 cancel && cancel(); 15370 this.animations[i3].stop(); 15371 }); 15372 }; 15373 } 15374 get time() { 15375 return this.getAll("time"); 15376 } 15377 set time(time2) { 15378 this.setAll("time", time2); 15379 } 15380 get speed() { 15381 return this.getAll("speed"); 15382 } 15383 set speed(speed) { 15384 this.setAll("speed", speed); 15385 } 15386 get startTime() { 15387 return this.getAll("startTime"); 15388 } 15389 get duration() { 15390 let max3 = 0; 15391 for (let i3 = 0; i3 < this.animations.length; i3++) { 15392 max3 = Math.max(max3, this.animations[i3].duration); 15393 } 15394 return max3; 15395 } 15396 runAll(methodName) { 15397 this.animations.forEach((controls) => controls[methodName]()); 15398 } 15399 flatten() { 15400 this.runAll("flatten"); 15401 } 15402 play() { 15403 this.runAll("play"); 15404 } 15405 pause() { 15406 this.runAll("pause"); 15407 } 15408 cancel() { 15409 this.runAll("cancel"); 15410 } 15411 complete() { 15412 this.runAll("complete"); 15413 } 15414 }; 15415 15416 // packages/components/node_modules/framer-motion/dist/es/animation/utils/is-transition-defined.mjs 15417 function isTransitionDefined({ when, delay: _delay, delayChildren, staggerChildren, staggerDirection, repeat, repeatType, repeatDelay, from: from2, elapsed, ...transition }) { 15418 return !!Object.keys(transition).length; 15419 } 15420 15421 // packages/components/node_modules/framer-motion/dist/es/animation/interfaces/motion-value.mjs 15422 var animateMotionValue = (name, value, target, transition = {}, element, isHandoff) => (onComplete) => { 15423 const valueTransition = getValueTransition(transition, name) || {}; 15424 const delay2 = valueTransition.delay || transition.delay || 0; 15425 let { elapsed = 0 } = transition; 15426 elapsed = elapsed - secondsToMilliseconds(delay2); 15427 let options2 = { 15428 keyframes: Array.isArray(target) ? target : [null, target], 15429 ease: "easeOut", 15430 velocity: value.getVelocity(), 15431 ...valueTransition, 15432 delay: -elapsed, 15433 onUpdate: (v3) => { 15434 value.set(v3); 15435 valueTransition.onUpdate && valueTransition.onUpdate(v3); 15436 }, 15437 onComplete: () => { 15438 onComplete(); 15439 valueTransition.onComplete && valueTransition.onComplete(); 15440 }, 15441 name, 15442 motionValue: value, 15443 element: isHandoff ? void 0 : element 15444 }; 15445 if (!isTransitionDefined(valueTransition)) { 15446 options2 = { 15447 ...options2, 15448 ...getDefaultTransition(name, options2) 15449 }; 15450 } 15451 if (options2.duration) { 15452 options2.duration = secondsToMilliseconds(options2.duration); 15453 } 15454 if (options2.repeatDelay) { 15455 options2.repeatDelay = secondsToMilliseconds(options2.repeatDelay); 15456 } 15457 if (options2.from !== void 0) { 15458 options2.keyframes[0] = options2.from; 15459 } 15460 let shouldSkip = false; 15461 if (options2.type === false || options2.duration === 0 && !options2.repeatDelay) { 15462 options2.duration = 0; 15463 if (options2.delay === 0) { 15464 shouldSkip = true; 15465 } 15466 } 15467 if (instantAnimationState.current || MotionGlobalConfig.skipAnimations) { 15468 shouldSkip = true; 15469 options2.duration = 0; 15470 options2.delay = 0; 15471 } 15472 if (shouldSkip && !isHandoff && value.get() !== void 0) { 15473 const finalKeyframe = getFinalKeyframe(options2.keyframes, valueTransition); 15474 if (finalKeyframe !== void 0) { 15475 frame.update(() => { 15476 options2.onUpdate(finalKeyframe); 15477 options2.onComplete(); 15478 }); 15479 return new GroupPlaybackControls([]); 15480 } 15481 } 15482 if (!isHandoff && AcceleratedAnimation.supports(options2)) { 15483 return new AcceleratedAnimation(options2); 15484 } else { 15485 return new MainThreadAnimation(options2); 15486 } 15487 }; 15488 15489 // packages/components/node_modules/framer-motion/dist/es/utils/resolve-value.mjs 15490 var isCustomValue = (v3) => { 15491 return Boolean(v3 && typeof v3 === "object" && v3.mix && v3.toValue); 15492 }; 15493 var resolveFinalValueInKeyframes = (v3) => { 15494 return isKeyframesTarget(v3) ? v3[v3.length - 1] || 0 : v3; 15495 }; 15496 15497 // packages/components/node_modules/framer-motion/dist/es/utils/array.mjs 15498 function addUniqueItem(arr, item2) { 15499 if (arr.indexOf(item2) === -1) 15500 arr.push(item2); 15501 } 15502 function removeItem(arr, item2) { 15503 const index2 = arr.indexOf(item2); 15504 if (index2 > -1) 15505 arr.splice(index2, 1); 15506 } 15507 15508 // packages/components/node_modules/framer-motion/dist/es/utils/subscription-manager.mjs 15509 var SubscriptionManager = class { 15510 constructor() { 15511 this.subscriptions = []; 15512 } 15513 add(handler) { 15514 addUniqueItem(this.subscriptions, handler); 15515 return () => removeItem(this.subscriptions, handler); 15516 } 15517 notify(a3, b3, c3) { 15518 const numSubscriptions = this.subscriptions.length; 15519 if (!numSubscriptions) 15520 return; 15521 if (numSubscriptions === 1) { 15522 this.subscriptions[0](a3, b3, c3); 15523 } else { 15524 for (let i3 = 0; i3 < numSubscriptions; i3++) { 15525 const handler = this.subscriptions[i3]; 15526 handler && handler(a3, b3, c3); 15527 } 15528 } 15529 } 15530 getSize() { 15531 return this.subscriptions.length; 15532 } 15533 clear() { 15534 this.subscriptions.length = 0; 15535 } 15536 }; 15537 15538 // packages/components/node_modules/framer-motion/dist/es/value/index.mjs 15539 var MAX_VELOCITY_DELTA = 30; 15540 var isFloat = (value) => { 15541 return !isNaN(parseFloat(value)); 15542 }; 15543 var collectMotionValues = { 15544 current: void 0 15545 }; 15546 var MotionValue = class { 15547 /** 15548 * @param init - The initiating value 15549 * @param config - Optional configuration options 15550 * 15551 * - `transformer`: A function to transform incoming values with. 15552 * 15553 * @internal 15554 */ 15555 constructor(init2, options2 = {}) { 15556 this.version = "11.15.0"; 15557 this.canTrackVelocity = null; 15558 this.events = {}; 15559 this.updateAndNotify = (v3, render = true) => { 15560 const currentTime = time.now(); 15561 if (this.updatedAt !== currentTime) { 15562 this.setPrevFrameValue(); 15563 } 15564 this.prev = this.current; 15565 this.setCurrent(v3); 15566 if (this.current !== this.prev && this.events.change) { 15567 this.events.change.notify(this.current); 15568 } 15569 if (render && this.events.renderRequest) { 15570 this.events.renderRequest.notify(this.current); 15571 } 15572 }; 15573 this.hasAnimated = false; 15574 this.setCurrent(init2); 15575 this.owner = options2.owner; 15576 } 15577 setCurrent(current) { 15578 this.current = current; 15579 this.updatedAt = time.now(); 15580 if (this.canTrackVelocity === null && current !== void 0) { 15581 this.canTrackVelocity = isFloat(this.current); 15582 } 15583 } 15584 setPrevFrameValue(prevFrameValue = this.current) { 15585 this.prevFrameValue = prevFrameValue; 15586 this.prevUpdatedAt = this.updatedAt; 15587 } 15588 /** 15589 * Adds a function that will be notified when the `MotionValue` is updated. 15590 * 15591 * It returns a function that, when called, will cancel the subscription. 15592 * 15593 * When calling `onChange` inside a React component, it should be wrapped with the 15594 * `useEffect` hook. As it returns an unsubscribe function, this should be returned 15595 * from the `useEffect` function to ensure you don't add duplicate subscribers.. 15596 * 15597 * ```jsx 15598 * export const MyComponent = () => { 15599 * const x = useMotionValue(0) 15600 * const y = useMotionValue(0) 15601 * const opacity = useMotionValue(1) 15602 * 15603 * useEffect(() => { 15604 * function updateOpacity() { 15605 * const maxXY = Math.max(x.get(), y.get()) 15606 * const newOpacity = transform(maxXY, [0, 100], [1, 0]) 15607 * opacity.set(newOpacity) 15608 * } 15609 * 15610 * const unsubscribeX = x.on("change", updateOpacity) 15611 * const unsubscribeY = y.on("change", updateOpacity) 15612 * 15613 * return () => { 15614 * unsubscribeX() 15615 * unsubscribeY() 15616 * } 15617 * }, []) 15618 * 15619 * return <motion.div style={{ x }} /> 15620 * } 15621 * ``` 15622 * 15623 * @param subscriber - A function that receives the latest value. 15624 * @returns A function that, when called, will cancel this subscription. 15625 * 15626 * @deprecated 15627 */ 15628 onChange(subscription) { 15629 if (true) { 15630 warnOnce(false, `value.onChange(callback) is deprecated. Switch to value.on("change", callback).`); 15631 } 15632 return this.on("change", subscription); 15633 } 15634 on(eventName, callback) { 15635 if (!this.events[eventName]) { 15636 this.events[eventName] = new SubscriptionManager(); 15637 } 15638 const unsubscribe = this.events[eventName].add(callback); 15639 if (eventName === "change") { 15640 return () => { 15641 unsubscribe(); 15642 frame.read(() => { 15643 if (!this.events.change.getSize()) { 15644 this.stop(); 15645 } 15646 }); 15647 }; 15648 } 15649 return unsubscribe; 15650 } 15651 clearListeners() { 15652 for (const eventManagers in this.events) { 15653 this.events[eventManagers].clear(); 15654 } 15655 } 15656 /** 15657 * Attaches a passive effect to the `MotionValue`. 15658 * 15659 * @internal 15660 */ 15661 attach(passiveEffect, stopPassiveEffect) { 15662 this.passiveEffect = passiveEffect; 15663 this.stopPassiveEffect = stopPassiveEffect; 15664 } 15665 /** 15666 * Sets the state of the `MotionValue`. 15667 * 15668 * @remarks 15669 * 15670 * ```jsx 15671 * const x = useMotionValue(0) 15672 * x.set(10) 15673 * ``` 15674 * 15675 * @param latest - Latest value to set. 15676 * @param render - Whether to notify render subscribers. Defaults to `true` 15677 * 15678 * @public 15679 */ 15680 set(v3, render = true) { 15681 if (!render || !this.passiveEffect) { 15682 this.updateAndNotify(v3, render); 15683 } else { 15684 this.passiveEffect(v3, this.updateAndNotify); 15685 } 15686 } 15687 setWithVelocity(prev2, current, delta) { 15688 this.set(current); 15689 this.prev = void 0; 15690 this.prevFrameValue = prev2; 15691 this.prevUpdatedAt = this.updatedAt - delta; 15692 } 15693 /** 15694 * Set the state of the `MotionValue`, stopping any active animations, 15695 * effects, and resets velocity to `0`. 15696 */ 15697 jump(v3, endAnimation = true) { 15698 this.updateAndNotify(v3); 15699 this.prev = v3; 15700 this.prevUpdatedAt = this.prevFrameValue = void 0; 15701 endAnimation && this.stop(); 15702 if (this.stopPassiveEffect) 15703 this.stopPassiveEffect(); 15704 } 15705 /** 15706 * Returns the latest state of `MotionValue` 15707 * 15708 * @returns - The latest state of `MotionValue` 15709 * 15710 * @public 15711 */ 15712 get() { 15713 if (collectMotionValues.current) { 15714 collectMotionValues.current.push(this); 15715 } 15716 return this.current; 15717 } 15718 /** 15719 * @public 15720 */ 15721 getPrevious() { 15722 return this.prev; 15723 } 15724 /** 15725 * Returns the latest velocity of `MotionValue` 15726 * 15727 * @returns - The latest velocity of `MotionValue`. Returns `0` if the state is non-numerical. 15728 * 15729 * @public 15730 */ 15731 getVelocity() { 15732 const currentTime = time.now(); 15733 if (!this.canTrackVelocity || this.prevFrameValue === void 0 || currentTime - this.updatedAt > MAX_VELOCITY_DELTA) { 15734 return 0; 15735 } 15736 const delta = Math.min(this.updatedAt - this.prevUpdatedAt, MAX_VELOCITY_DELTA); 15737 return velocityPerSecond(parseFloat(this.current) - parseFloat(this.prevFrameValue), delta); 15738 } 15739 /** 15740 * Registers a new animation to control this `MotionValue`. Only one 15741 * animation can drive a `MotionValue` at one time. 15742 * 15743 * ```jsx 15744 * value.start() 15745 * ``` 15746 * 15747 * @param animation - A function that starts the provided animation 15748 * 15749 * @internal 15750 */ 15751 start(startAnimation) { 15752 this.stop(); 15753 return new Promise((resolve) => { 15754 this.hasAnimated = true; 15755 this.animation = startAnimation(resolve); 15756 if (this.events.animationStart) { 15757 this.events.animationStart.notify(); 15758 } 15759 }).then(() => { 15760 if (this.events.animationComplete) { 15761 this.events.animationComplete.notify(); 15762 } 15763 this.clearAnimation(); 15764 }); 15765 } 15766 /** 15767 * Stop the currently active animation. 15768 * 15769 * @public 15770 */ 15771 stop() { 15772 if (this.animation) { 15773 this.animation.stop(); 15774 if (this.events.animationCancel) { 15775 this.events.animationCancel.notify(); 15776 } 15777 } 15778 this.clearAnimation(); 15779 } 15780 /** 15781 * Returns `true` if this value is currently animating. 15782 * 15783 * @public 15784 */ 15785 isAnimating() { 15786 return !!this.animation; 15787 } 15788 clearAnimation() { 15789 delete this.animation; 15790 } 15791 /** 15792 * Destroy and clean up subscribers to this `MotionValue`. 15793 * 15794 * The `MotionValue` hooks like `useMotionValue` and `useTransform` automatically 15795 * handle the lifecycle of the returned `MotionValue`, so this method is only necessary if you've manually 15796 * created a `MotionValue` via the `motionValue` function. 15797 * 15798 * @public 15799 */ 15800 destroy() { 15801 this.clearListeners(); 15802 this.stop(); 15803 if (this.stopPassiveEffect) { 15804 this.stopPassiveEffect(); 15805 } 15806 } 15807 }; 15808 function motionValue(init2, options2) { 15809 return new MotionValue(init2, options2); 15810 } 15811 15812 // packages/components/node_modules/framer-motion/dist/es/render/utils/setters.mjs 15813 function setMotionValue(visualElement, key, value) { 15814 if (visualElement.hasValue(key)) { 15815 visualElement.getValue(key).set(value); 15816 } else { 15817 visualElement.addValue(key, motionValue(value)); 15818 } 15819 } 15820 function setTarget(visualElement, definition) { 15821 const resolved = resolveVariant(visualElement, definition); 15822 let { transitionEnd = {}, transition = {}, ...target } = resolved || {}; 15823 target = { ...target, ...transitionEnd }; 15824 for (const key in target) { 15825 const value = resolveFinalValueInKeyframes(target[key]); 15826 setMotionValue(visualElement, key, value); 15827 } 15828 } 15829 15830 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/camel-to-dash.mjs 15831 var camelToDash = (str) => str.replace(/([a-z])([A-Z])/gu, "$1-$2").toLowerCase(); 15832 15833 // packages/components/node_modules/framer-motion/dist/es/animation/optimized-appear/data-id.mjs 15834 var optimizedAppearDataId = "framerAppearId"; 15835 var optimizedAppearDataAttribute = "data-" + camelToDash(optimizedAppearDataId); 15836 15837 // packages/components/node_modules/framer-motion/dist/es/animation/optimized-appear/get-appear-id.mjs 15838 function getOptimisedAppearId(visualElement) { 15839 return visualElement.props[optimizedAppearDataAttribute]; 15840 } 15841 15842 // packages/components/node_modules/framer-motion/dist/es/value/utils/is-motion-value.mjs 15843 var isMotionValue = (value) => Boolean(value && value.getVelocity); 15844 15845 // packages/components/node_modules/framer-motion/dist/es/value/use-will-change/is.mjs 15846 function isWillChangeMotionValue(value) { 15847 return Boolean(isMotionValue(value) && value.add); 15848 } 15849 15850 // packages/components/node_modules/framer-motion/dist/es/value/use-will-change/add-will-change.mjs 15851 function addValueToWillChange(visualElement, key) { 15852 const willChange = visualElement.getValue("willChange"); 15853 if (isWillChangeMotionValue(willChange)) { 15854 return willChange.add(key); 15855 } 15856 } 15857 15858 // packages/components/node_modules/framer-motion/dist/es/animation/interfaces/visual-element-target.mjs 15859 function shouldBlockAnimation({ protectedKeys, needsAnimating }, key) { 15860 const shouldBlock = protectedKeys.hasOwnProperty(key) && needsAnimating[key] !== true; 15861 needsAnimating[key] = false; 15862 return shouldBlock; 15863 } 15864 function animateTarget(visualElement, targetAndTransition, { delay: delay2 = 0, transitionOverride, type } = {}) { 15865 var _a; 15866 let { transition = visualElement.getDefaultTransition(), transitionEnd, ...target } = targetAndTransition; 15867 if (transitionOverride) 15868 transition = transitionOverride; 15869 const animations2 = []; 15870 const animationTypeState = type && visualElement.animationState && visualElement.animationState.getState()[type]; 15871 for (const key in target) { 15872 const value = visualElement.getValue(key, (_a = visualElement.latestValues[key]) !== null && _a !== void 0 ? _a : null); 15873 const valueTarget = target[key]; 15874 if (valueTarget === void 0 || animationTypeState && shouldBlockAnimation(animationTypeState, key)) { 15875 continue; 15876 } 15877 const valueTransition = { 15878 delay: delay2, 15879 ...getValueTransition(transition || {}, key) 15880 }; 15881 let isHandoff = false; 15882 if (window.MotionHandoffAnimation) { 15883 const appearId = getOptimisedAppearId(visualElement); 15884 if (appearId) { 15885 const startTime = window.MotionHandoffAnimation(appearId, key, frame); 15886 if (startTime !== null) { 15887 valueTransition.startTime = startTime; 15888 isHandoff = true; 15889 } 15890 } 15891 } 15892 addValueToWillChange(visualElement, key); 15893 value.start(animateMotionValue(key, value, valueTarget, visualElement.shouldReduceMotion && transformProps.has(key) ? { type: false } : valueTransition, visualElement, isHandoff)); 15894 const animation = value.animation; 15895 if (animation) { 15896 animations2.push(animation); 15897 } 15898 } 15899 if (transitionEnd) { 15900 Promise.all(animations2).then(() => { 15901 frame.update(() => { 15902 transitionEnd && setTarget(visualElement, transitionEnd); 15903 }); 15904 }); 15905 } 15906 return animations2; 15907 } 15908 15909 // packages/components/node_modules/framer-motion/dist/es/animation/interfaces/visual-element-variant.mjs 15910 function animateVariant(visualElement, variant, options2 = {}) { 15911 var _a; 15912 const resolved = resolveVariant(visualElement, variant, options2.type === "exit" ? (_a = visualElement.presenceContext) === null || _a === void 0 ? void 0 : _a.custom : void 0); 15913 let { transition = visualElement.getDefaultTransition() || {} } = resolved || {}; 15914 if (options2.transitionOverride) { 15915 transition = options2.transitionOverride; 15916 } 15917 const getAnimation = resolved ? () => Promise.all(animateTarget(visualElement, resolved, options2)) : () => Promise.resolve(); 15918 const getChildAnimations = visualElement.variantChildren && visualElement.variantChildren.size ? (forwardDelay = 0) => { 15919 const { delayChildren = 0, staggerChildren, staggerDirection } = transition; 15920 return animateChildren(visualElement, variant, delayChildren + forwardDelay, staggerChildren, staggerDirection, options2); 15921 } : () => Promise.resolve(); 15922 const { when } = transition; 15923 if (when) { 15924 const [first, last3] = when === "beforeChildren" ? [getAnimation, getChildAnimations] : [getChildAnimations, getAnimation]; 15925 return first().then(() => last3()); 15926 } else { 15927 return Promise.all([getAnimation(), getChildAnimations(options2.delay)]); 15928 } 15929 } 15930 function animateChildren(visualElement, variant, delayChildren = 0, staggerChildren = 0, staggerDirection = 1, options2) { 15931 const animations2 = []; 15932 const maxStaggerDuration = (visualElement.variantChildren.size - 1) * staggerChildren; 15933 const generateStaggerDuration = staggerDirection === 1 ? (i3 = 0) => i3 * staggerChildren : (i3 = 0) => maxStaggerDuration - i3 * staggerChildren; 15934 Array.from(visualElement.variantChildren).sort(sortByTreeOrder).forEach((child, i3) => { 15935 child.notify("AnimationStart", variant); 15936 animations2.push(animateVariant(child, variant, { 15937 ...options2, 15938 delay: delayChildren + generateStaggerDuration(i3) 15939 }).then(() => child.notify("AnimationComplete", variant))); 15940 }); 15941 return Promise.all(animations2); 15942 } 15943 function sortByTreeOrder(a3, b3) { 15944 return a3.sortNodePosition(b3); 15945 } 15946 15947 // packages/components/node_modules/framer-motion/dist/es/animation/interfaces/visual-element.mjs 15948 function animateVisualElement(visualElement, definition, options2 = {}) { 15949 visualElement.notify("AnimationStart", definition); 15950 let animation; 15951 if (Array.isArray(definition)) { 15952 const animations2 = definition.map((variant) => animateVariant(visualElement, variant, options2)); 15953 animation = Promise.all(animations2); 15954 } else if (typeof definition === "string") { 15955 animation = animateVariant(visualElement, definition, options2); 15956 } else { 15957 const resolvedDefinition = typeof definition === "function" ? resolveVariant(visualElement, definition, options2.custom) : definition; 15958 animation = Promise.all(animateTarget(visualElement, resolvedDefinition, options2)); 15959 } 15960 return animation.then(() => { 15961 visualElement.notify("AnimationComplete", definition); 15962 }); 15963 } 15964 15965 // packages/components/node_modules/framer-motion/dist/es/render/utils/get-variant-context.mjs 15966 var numVariantProps = variantProps.length; 15967 function getVariantContext(visualElement) { 15968 if (!visualElement) 15969 return void 0; 15970 if (!visualElement.isControllingVariants) { 15971 const context2 = visualElement.parent ? getVariantContext(visualElement.parent) || {} : {}; 15972 if (visualElement.props.initial !== void 0) { 15973 context2.initial = visualElement.props.initial; 15974 } 15975 return context2; 15976 } 15977 const context = {}; 15978 for (let i3 = 0; i3 < numVariantProps; i3++) { 15979 const name = variantProps[i3]; 15980 const prop = visualElement.props[name]; 15981 if (isVariantLabel(prop) || prop === false) { 15982 context[name] = prop; 15983 } 15984 } 15985 return context; 15986 } 15987 15988 // packages/components/node_modules/framer-motion/dist/es/render/utils/animation-state.mjs 15989 var reversePriorityOrder = [...variantPriorityOrder].reverse(); 15990 var numAnimationTypes = variantPriorityOrder.length; 15991 function animateList(visualElement) { 15992 return (animations2) => Promise.all(animations2.map(({ animation, options: options2 }) => animateVisualElement(visualElement, animation, options2))); 15993 } 15994 function createAnimationState(visualElement) { 15995 let animate = animateList(visualElement); 15996 let state = createState(); 15997 let isInitialRender = true; 15998 const buildResolvedTypeValues = (type) => (acc, definition) => { 15999 var _a; 16000 const resolved = resolveVariant(visualElement, definition, type === "exit" ? (_a = visualElement.presenceContext) === null || _a === void 0 ? void 0 : _a.custom : void 0); 16001 if (resolved) { 16002 const { transition, transitionEnd, ...target } = resolved; 16003 acc = { ...acc, ...target, ...transitionEnd }; 16004 } 16005 return acc; 16006 }; 16007 function setAnimateFunction(makeAnimator) { 16008 animate = makeAnimator(visualElement); 16009 } 16010 function animateChanges(changedActiveType) { 16011 const { props } = visualElement; 16012 const context = getVariantContext(visualElement.parent) || {}; 16013 const animations2 = []; 16014 const removedKeys = /* @__PURE__ */ new Set(); 16015 let encounteredKeys = {}; 16016 let removedVariantIndex = Infinity; 16017 for (let i3 = 0; i3 < numAnimationTypes; i3++) { 16018 const type = reversePriorityOrder[i3]; 16019 const typeState = state[type]; 16020 const prop = props[type] !== void 0 ? props[type] : context[type]; 16021 const propIsVariant = isVariantLabel(prop); 16022 const activeDelta = type === changedActiveType ? typeState.isActive : null; 16023 if (activeDelta === false) 16024 removedVariantIndex = i3; 16025 let isInherited = prop === context[type] && prop !== props[type] && propIsVariant; 16026 if (isInherited && isInitialRender && visualElement.manuallyAnimateOnMount) { 16027 isInherited = false; 16028 } 16029 typeState.protectedKeys = { ...encounteredKeys }; 16030 if ( 16031 // If it isn't active and hasn't *just* been set as inactive 16032 !typeState.isActive && activeDelta === null || // If we didn't and don't have any defined prop for this animation type 16033 !prop && !typeState.prevProp || // Or if the prop doesn't define an animation 16034 isAnimationControls(prop) || typeof prop === "boolean" 16035 ) { 16036 continue; 16037 } 16038 const variantDidChange = checkVariantsDidChange(typeState.prevProp, prop); 16039 let shouldAnimateType = variantDidChange || // If we're making this variant active, we want to always make it active 16040 type === changedActiveType && typeState.isActive && !isInherited && propIsVariant || // If we removed a higher-priority variant (i is in reverse order) 16041 i3 > removedVariantIndex && propIsVariant; 16042 let handledRemovedValues = false; 16043 const definitionList = Array.isArray(prop) ? prop : [prop]; 16044 let resolvedValues = definitionList.reduce(buildResolvedTypeValues(type), {}); 16045 if (activeDelta === false) 16046 resolvedValues = {}; 16047 const { prevResolvedValues = {} } = typeState; 16048 const allKeys = { 16049 ...prevResolvedValues, 16050 ...resolvedValues 16051 }; 16052 const markToAnimate = (key) => { 16053 shouldAnimateType = true; 16054 if (removedKeys.has(key)) { 16055 handledRemovedValues = true; 16056 removedKeys.delete(key); 16057 } 16058 typeState.needsAnimating[key] = true; 16059 const motionValue2 = visualElement.getValue(key); 16060 if (motionValue2) 16061 motionValue2.liveStyle = false; 16062 }; 16063 for (const key in allKeys) { 16064 const next2 = resolvedValues[key]; 16065 const prev2 = prevResolvedValues[key]; 16066 if (encounteredKeys.hasOwnProperty(key)) 16067 continue; 16068 let valueHasChanged = false; 16069 if (isKeyframesTarget(next2) && isKeyframesTarget(prev2)) { 16070 valueHasChanged = !shallowCompare(next2, prev2); 16071 } else { 16072 valueHasChanged = next2 !== prev2; 16073 } 16074 if (valueHasChanged) { 16075 if (next2 !== void 0 && next2 !== null) { 16076 markToAnimate(key); 16077 } else { 16078 removedKeys.add(key); 16079 } 16080 } else if (next2 !== void 0 && removedKeys.has(key)) { 16081 markToAnimate(key); 16082 } else { 16083 typeState.protectedKeys[key] = true; 16084 } 16085 } 16086 typeState.prevProp = prop; 16087 typeState.prevResolvedValues = resolvedValues; 16088 if (typeState.isActive) { 16089 encounteredKeys = { ...encounteredKeys, ...resolvedValues }; 16090 } 16091 if (isInitialRender && visualElement.blockInitialAnimation) { 16092 shouldAnimateType = false; 16093 } 16094 const willAnimateViaParent = isInherited && variantDidChange; 16095 const needsAnimating = !willAnimateViaParent || handledRemovedValues; 16096 if (shouldAnimateType && needsAnimating) { 16097 animations2.push(...definitionList.map((animation) => ({ 16098 animation, 16099 options: { type } 16100 }))); 16101 } 16102 } 16103 if (removedKeys.size) { 16104 const fallbackAnimation = {}; 16105 removedKeys.forEach((key) => { 16106 const fallbackTarget = visualElement.getBaseTarget(key); 16107 const motionValue2 = visualElement.getValue(key); 16108 if (motionValue2) 16109 motionValue2.liveStyle = true; 16110 fallbackAnimation[key] = fallbackTarget !== null && fallbackTarget !== void 0 ? fallbackTarget : null; 16111 }); 16112 animations2.push({ animation: fallbackAnimation }); 16113 } 16114 let shouldAnimate = Boolean(animations2.length); 16115 if (isInitialRender && (props.initial === false || props.initial === props.animate) && !visualElement.manuallyAnimateOnMount) { 16116 shouldAnimate = false; 16117 } 16118 isInitialRender = false; 16119 return shouldAnimate ? animate(animations2) : Promise.resolve(); 16120 } 16121 function setActive(type, isActive) { 16122 var _a; 16123 if (state[type].isActive === isActive) 16124 return Promise.resolve(); 16125 (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach((child) => { 16126 var _a2; 16127 return (_a2 = child.animationState) === null || _a2 === void 0 ? void 0 : _a2.setActive(type, isActive); 16128 }); 16129 state[type].isActive = isActive; 16130 const animations2 = animateChanges(type); 16131 for (const key in state) { 16132 state[key].protectedKeys = {}; 16133 } 16134 return animations2; 16135 } 16136 return { 16137 animateChanges, 16138 setActive, 16139 setAnimateFunction, 16140 getState: () => state, 16141 reset: () => { 16142 state = createState(); 16143 isInitialRender = true; 16144 } 16145 }; 16146 } 16147 function checkVariantsDidChange(prev2, next2) { 16148 if (typeof next2 === "string") { 16149 return next2 !== prev2; 16150 } else if (Array.isArray(next2)) { 16151 return !shallowCompare(next2, prev2); 16152 } 16153 return false; 16154 } 16155 function createTypeState(isActive = false) { 16156 return { 16157 isActive, 16158 protectedKeys: {}, 16159 needsAnimating: {}, 16160 prevResolvedValues: {} 16161 }; 16162 } 16163 function createState() { 16164 return { 16165 animate: createTypeState(true), 16166 whileInView: createTypeState(), 16167 whileHover: createTypeState(), 16168 whileTap: createTypeState(), 16169 whileDrag: createTypeState(), 16170 whileFocus: createTypeState(), 16171 exit: createTypeState() 16172 }; 16173 } 16174 16175 // packages/components/node_modules/framer-motion/dist/es/motion/features/Feature.mjs 16176 var Feature = class { 16177 constructor(node2) { 16178 this.isMounted = false; 16179 this.node = node2; 16180 } 16181 update() { 16182 } 16183 }; 16184 16185 // packages/components/node_modules/framer-motion/dist/es/motion/features/animation/index.mjs 16186 var AnimationFeature = class extends Feature { 16187 /** 16188 * We dynamically generate the AnimationState manager as it contains a reference 16189 * to the underlying animation library. We only want to load that if we load this, 16190 * so people can optionally code split it out using the `m` component. 16191 */ 16192 constructor(node2) { 16193 super(node2); 16194 node2.animationState || (node2.animationState = createAnimationState(node2)); 16195 } 16196 updateAnimationControlsSubscription() { 16197 const { animate } = this.node.getProps(); 16198 if (isAnimationControls(animate)) { 16199 this.unmountControls = animate.subscribe(this.node); 16200 } 16201 } 16202 /** 16203 * Subscribe any provided AnimationControls to the component's VisualElement 16204 */ 16205 mount() { 16206 this.updateAnimationControlsSubscription(); 16207 } 16208 update() { 16209 const { animate } = this.node.getProps(); 16210 const { animate: prevAnimate } = this.node.prevProps || {}; 16211 if (animate !== prevAnimate) { 16212 this.updateAnimationControlsSubscription(); 16213 } 16214 } 16215 unmount() { 16216 var _a; 16217 this.node.animationState.reset(); 16218 (_a = this.unmountControls) === null || _a === void 0 ? void 0 : _a.call(this); 16219 } 16220 }; 16221 16222 // packages/components/node_modules/framer-motion/dist/es/motion/features/animation/exit.mjs 16223 var id = 0; 16224 var ExitAnimationFeature = class extends Feature { 16225 constructor() { 16226 super(...arguments); 16227 this.id = id++; 16228 } 16229 update() { 16230 if (!this.node.presenceContext) 16231 return; 16232 const { isPresent, onExitComplete } = this.node.presenceContext; 16233 const { isPresent: prevIsPresent } = this.node.prevPresenceContext || {}; 16234 if (!this.node.animationState || isPresent === prevIsPresent) { 16235 return; 16236 } 16237 const exitAnimation = this.node.animationState.setActive("exit", !isPresent); 16238 if (onExitComplete && !isPresent) { 16239 exitAnimation.then(() => onExitComplete(this.id)); 16240 } 16241 } 16242 mount() { 16243 const { register } = this.node.presenceContext || {}; 16244 if (register) { 16245 this.unmount = register(this.id); 16246 } 16247 } 16248 unmount() { 16249 } 16250 }; 16251 16252 // packages/components/node_modules/framer-motion/dist/es/motion/features/animations.mjs 16253 var animations = { 16254 animation: { 16255 Feature: AnimationFeature 16256 }, 16257 exit: { 16258 Feature: ExitAnimationFeature 16259 } 16260 }; 16261 16262 // node_modules/motion-dom/dist/es/gestures/drag/state/is-active.mjs 16263 var isDragging = { 16264 x: false, 16265 y: false 16266 }; 16267 function isDragActive() { 16268 return isDragging.x || isDragging.y; 16269 } 16270 16271 // node_modules/motion-dom/dist/es/utils/resolve-elements.mjs 16272 function resolveElements(elementOrSelector, scope, selectorCache) { 16273 var _a; 16274 if (elementOrSelector instanceof Element) { 16275 return [elementOrSelector]; 16276 } else if (typeof elementOrSelector === "string") { 16277 let root = document; 16278 if (scope) { 16279 root = scope.current; 16280 } 16281 const elements2 = (_a = selectorCache === null || selectorCache === void 0 ? void 0 : selectorCache[elementOrSelector]) !== null && _a !== void 0 ? _a : root.querySelectorAll(elementOrSelector); 16282 return elements2 ? Array.from(elements2) : []; 16283 } 16284 return Array.from(elementOrSelector); 16285 } 16286 16287 // node_modules/motion-dom/dist/es/gestures/utils/setup.mjs 16288 function setupGesture(elementOrSelector, options2) { 16289 const elements2 = resolveElements(elementOrSelector); 16290 const gestureAbortController = new AbortController(); 16291 const eventOptions = { 16292 passive: true, 16293 ...options2, 16294 signal: gestureAbortController.signal 16295 }; 16296 const cancel = () => gestureAbortController.abort(); 16297 return [elements2, eventOptions, cancel]; 16298 } 16299 16300 // node_modules/motion-dom/dist/es/gestures/hover.mjs 16301 function filterEvents(callback) { 16302 return (event) => { 16303 if (event.pointerType === "touch" || isDragActive()) 16304 return; 16305 callback(event); 16306 }; 16307 } 16308 function hover(elementOrSelector, onHoverStart, options2 = {}) { 16309 const [elements2, eventOptions, cancel] = setupGesture(elementOrSelector, options2); 16310 const onPointerEnter = filterEvents((enterEvent) => { 16311 const { target } = enterEvent; 16312 const onHoverEnd = onHoverStart(enterEvent); 16313 if (!onHoverEnd || !target) 16314 return; 16315 const onPointerLeave = filterEvents((leaveEvent) => { 16316 onHoverEnd(leaveEvent); 16317 target.removeEventListener("pointerleave", onPointerLeave); 16318 }); 16319 target.addEventListener("pointerleave", onPointerLeave, eventOptions); 16320 }); 16321 elements2.forEach((element) => { 16322 element.addEventListener("pointerenter", onPointerEnter, eventOptions); 16323 }); 16324 return cancel; 16325 } 16326 16327 // node_modules/motion-dom/dist/es/gestures/utils/is-primary-pointer.mjs 16328 var isPrimaryPointer = (event) => { 16329 if (event.pointerType === "mouse") { 16330 return typeof event.button !== "number" || event.button <= 0; 16331 } else { 16332 return event.isPrimary !== false; 16333 } 16334 }; 16335 16336 // node_modules/motion-dom/dist/es/gestures/press/utils/state.mjs 16337 var isPressing = /* @__PURE__ */ new WeakSet(); 16338 16339 // node_modules/motion-dom/dist/es/gestures/press/utils/keyboard.mjs 16340 function filterEvents2(callback) { 16341 return (event) => { 16342 if (event.key !== "Enter") 16343 return; 16344 callback(event); 16345 }; 16346 } 16347 function firePointerEvent(target, type) { 16348 target.dispatchEvent(new PointerEvent("pointer" + type, { isPrimary: true, bubbles: true })); 16349 } 16350 var enableKeyboardPress = (focusEvent, eventOptions) => { 16351 const element = focusEvent.currentTarget; 16352 if (!element) 16353 return; 16354 const handleKeydown = filterEvents2(() => { 16355 if (isPressing.has(element)) 16356 return; 16357 firePointerEvent(element, "down"); 16358 const handleKeyup = filterEvents2(() => { 16359 firePointerEvent(element, "up"); 16360 }); 16361 const handleBlur = () => firePointerEvent(element, "cancel"); 16362 element.addEventListener("keyup", handleKeyup, eventOptions); 16363 element.addEventListener("blur", handleBlur, eventOptions); 16364 }); 16365 element.addEventListener("keydown", handleKeydown, eventOptions); 16366 element.addEventListener("blur", () => element.removeEventListener("keydown", handleKeydown), eventOptions); 16367 }; 16368 16369 // node_modules/motion-dom/dist/es/gestures/press/utils/is-keyboard-accessible.mjs 16370 var focusableElements = /* @__PURE__ */ new Set([ 16371 "BUTTON", 16372 "INPUT", 16373 "SELECT", 16374 "TEXTAREA", 16375 "A" 16376 ]); 16377 function isElementKeyboardAccessible(element) { 16378 return focusableElements.has(element.tagName) || element.tabIndex !== -1; 16379 } 16380 16381 // node_modules/motion-dom/dist/es/gestures/utils/is-node-or-child.mjs 16382 var isNodeOrChild = (parent, child) => { 16383 if (!child) { 16384 return false; 16385 } else if (parent === child) { 16386 return true; 16387 } else { 16388 return isNodeOrChild(parent, child.parentElement); 16389 } 16390 }; 16391 16392 // node_modules/motion-dom/dist/es/gestures/press/index.mjs 16393 function isValidPressEvent(event) { 16394 return isPrimaryPointer(event) && !isDragActive(); 16395 } 16396 function press(elementOrSelector, onPressStart, options2 = {}) { 16397 const [elements2, eventOptions, cancelEvents] = setupGesture(elementOrSelector, options2); 16398 const startPress = (startEvent) => { 16399 const element = startEvent.currentTarget; 16400 if (!isValidPressEvent(startEvent) || isPressing.has(element)) 16401 return; 16402 isPressing.add(element); 16403 const onPressEnd = onPressStart(startEvent); 16404 const onPointerEnd = (endEvent, success) => { 16405 window.removeEventListener("pointerup", onPointerUp); 16406 window.removeEventListener("pointercancel", onPointerCancel); 16407 if (!isValidPressEvent(endEvent) || !isPressing.has(element)) { 16408 return; 16409 } 16410 isPressing.delete(element); 16411 if (onPressEnd) { 16412 onPressEnd(endEvent, { success }); 16413 } 16414 }; 16415 const onPointerUp = (upEvent) => { 16416 onPointerEnd(upEvent, options2.useGlobalTarget || isNodeOrChild(element, upEvent.target)); 16417 }; 16418 const onPointerCancel = (cancelEvent) => { 16419 onPointerEnd(cancelEvent, false); 16420 }; 16421 window.addEventListener("pointerup", onPointerUp, eventOptions); 16422 window.addEventListener("pointercancel", onPointerCancel, eventOptions); 16423 }; 16424 elements2.forEach((element) => { 16425 if (!isElementKeyboardAccessible(element)) { 16426 element.tabIndex = 0; 16427 } 16428 const target = options2.useGlobalTarget ? window : element; 16429 target.addEventListener("pointerdown", startPress, eventOptions); 16430 element.addEventListener("focus", (event) => enableKeyboardPress(event, eventOptions), eventOptions); 16431 }); 16432 return cancelEvents; 16433 } 16434 16435 // node_modules/motion-dom/dist/es/gestures/drag/state/set-active.mjs 16436 function setDragLock(axis) { 16437 if (axis === "x" || axis === "y") { 16438 if (isDragging[axis]) { 16439 return null; 16440 } else { 16441 isDragging[axis] = true; 16442 return () => { 16443 isDragging[axis] = false; 16444 }; 16445 } 16446 } else { 16447 if (isDragging.x || isDragging.y) { 16448 return null; 16449 } else { 16450 isDragging.x = isDragging.y = true; 16451 return () => { 16452 isDragging.x = isDragging.y = false; 16453 }; 16454 } 16455 } 16456 } 16457 16458 // packages/components/node_modules/framer-motion/dist/es/events/event-info.mjs 16459 function extractEventInfo(event) { 16460 return { 16461 point: { 16462 x: event.pageX, 16463 y: event.pageY 16464 } 16465 }; 16466 } 16467 var addPointerInfo = (handler) => { 16468 return (event) => isPrimaryPointer(event) && handler(event, extractEventInfo(event)); 16469 }; 16470 16471 // packages/components/node_modules/framer-motion/dist/es/events/add-dom-event.mjs 16472 function addDomEvent(target, eventName, handler, options2 = { passive: true }) { 16473 target.addEventListener(eventName, handler, options2); 16474 return () => target.removeEventListener(eventName, handler); 16475 } 16476 16477 // packages/components/node_modules/framer-motion/dist/es/events/add-pointer-event.mjs 16478 function addPointerEvent(target, eventName, handler, options2) { 16479 return addDomEvent(target, eventName, addPointerInfo(handler), options2); 16480 } 16481 16482 // packages/components/node_modules/framer-motion/dist/es/utils/distance.mjs 16483 var distance = (a3, b3) => Math.abs(a3 - b3); 16484 function distance2D(a3, b3) { 16485 const xDelta = distance(a3.x, b3.x); 16486 const yDelta = distance(a3.y, b3.y); 16487 return Math.sqrt(xDelta ** 2 + yDelta ** 2); 16488 } 16489 16490 // packages/components/node_modules/framer-motion/dist/es/gestures/pan/PanSession.mjs 16491 var PanSession = class { 16492 constructor(event, handlers, { transformPagePoint, contextWindow, dragSnapToOrigin = false } = {}) { 16493 this.startEvent = null; 16494 this.lastMoveEvent = null; 16495 this.lastMoveEventInfo = null; 16496 this.handlers = {}; 16497 this.contextWindow = window; 16498 this.updatePoint = () => { 16499 if (!(this.lastMoveEvent && this.lastMoveEventInfo)) 16500 return; 16501 const info2 = getPanInfo(this.lastMoveEventInfo, this.history); 16502 const isPanStarted = this.startEvent !== null; 16503 const isDistancePastThreshold = distance2D(info2.offset, { x: 0, y: 0 }) >= 3; 16504 if (!isPanStarted && !isDistancePastThreshold) 16505 return; 16506 const { point: point2 } = info2; 16507 const { timestamp: timestamp2 } = frameData; 16508 this.history.push({ ...point2, timestamp: timestamp2 }); 16509 const { onStart, onMove } = this.handlers; 16510 if (!isPanStarted) { 16511 onStart && onStart(this.lastMoveEvent, info2); 16512 this.startEvent = this.lastMoveEvent; 16513 } 16514 onMove && onMove(this.lastMoveEvent, info2); 16515 }; 16516 this.handlePointerMove = (event2, info2) => { 16517 this.lastMoveEvent = event2; 16518 this.lastMoveEventInfo = transformPoint(info2, this.transformPagePoint); 16519 frame.update(this.updatePoint, true); 16520 }; 16521 this.handlePointerUp = (event2, info2) => { 16522 this.end(); 16523 const { onEnd, onSessionEnd, resumeAnimation } = this.handlers; 16524 if (this.dragSnapToOrigin) 16525 resumeAnimation && resumeAnimation(); 16526 if (!(this.lastMoveEvent && this.lastMoveEventInfo)) 16527 return; 16528 const panInfo = getPanInfo(event2.type === "pointercancel" ? this.lastMoveEventInfo : transformPoint(info2, this.transformPagePoint), this.history); 16529 if (this.startEvent && onEnd) { 16530 onEnd(event2, panInfo); 16531 } 16532 onSessionEnd && onSessionEnd(event2, panInfo); 16533 }; 16534 if (!isPrimaryPointer(event)) 16535 return; 16536 this.dragSnapToOrigin = dragSnapToOrigin; 16537 this.handlers = handlers; 16538 this.transformPagePoint = transformPagePoint; 16539 this.contextWindow = contextWindow || window; 16540 const info = extractEventInfo(event); 16541 const initialInfo = transformPoint(info, this.transformPagePoint); 16542 const { point } = initialInfo; 16543 const { timestamp } = frameData; 16544 this.history = [{ ...point, timestamp }]; 16545 const { onSessionStart } = handlers; 16546 onSessionStart && onSessionStart(event, getPanInfo(initialInfo, this.history)); 16547 this.removeListeners = pipe(addPointerEvent(this.contextWindow, "pointermove", this.handlePointerMove), addPointerEvent(this.contextWindow, "pointerup", this.handlePointerUp), addPointerEvent(this.contextWindow, "pointercancel", this.handlePointerUp)); 16548 } 16549 updateHandlers(handlers) { 16550 this.handlers = handlers; 16551 } 16552 end() { 16553 this.removeListeners && this.removeListeners(); 16554 cancelFrame(this.updatePoint); 16555 } 16556 }; 16557 function transformPoint(info, transformPagePoint) { 16558 return transformPagePoint ? { point: transformPagePoint(info.point) } : info; 16559 } 16560 function subtractPoint(a3, b3) { 16561 return { x: a3.x - b3.x, y: a3.y - b3.y }; 16562 } 16563 function getPanInfo({ point }, history) { 16564 return { 16565 point, 16566 delta: subtractPoint(point, lastDevicePoint(history)), 16567 offset: subtractPoint(point, startDevicePoint(history)), 16568 velocity: getVelocity(history, 0.1) 16569 }; 16570 } 16571 function startDevicePoint(history) { 16572 return history[0]; 16573 } 16574 function lastDevicePoint(history) { 16575 return history[history.length - 1]; 16576 } 16577 function getVelocity(history, timeDelta) { 16578 if (history.length < 2) { 16579 return { x: 0, y: 0 }; 16580 } 16581 let i3 = history.length - 1; 16582 let timestampedPoint = null; 16583 const lastPoint = lastDevicePoint(history); 16584 while (i3 >= 0) { 16585 timestampedPoint = history[i3]; 16586 if (lastPoint.timestamp - timestampedPoint.timestamp > secondsToMilliseconds(timeDelta)) { 16587 break; 16588 } 16589 i3--; 16590 } 16591 if (!timestampedPoint) { 16592 return { x: 0, y: 0 }; 16593 } 16594 const time2 = millisecondsToSeconds(lastPoint.timestamp - timestampedPoint.timestamp); 16595 if (time2 === 0) { 16596 return { x: 0, y: 0 }; 16597 } 16598 const currentVelocity = { 16599 x: (lastPoint.x - timestampedPoint.x) / time2, 16600 y: (lastPoint.y - timestampedPoint.y) / time2 16601 }; 16602 if (currentVelocity.x === Infinity) { 16603 currentVelocity.x = 0; 16604 } 16605 if (currentVelocity.y === Infinity) { 16606 currentVelocity.y = 0; 16607 } 16608 return currentVelocity; 16609 } 16610 16611 // packages/components/node_modules/framer-motion/dist/es/utils/is-ref-object.mjs 16612 function isRefObject(ref) { 16613 return ref && typeof ref === "object" && Object.prototype.hasOwnProperty.call(ref, "current"); 16614 } 16615 16616 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/delta-calc.mjs 16617 var SCALE_PRECISION = 1e-4; 16618 var SCALE_MIN = 1 - SCALE_PRECISION; 16619 var SCALE_MAX = 1 + SCALE_PRECISION; 16620 var TRANSLATE_PRECISION = 0.01; 16621 var TRANSLATE_MIN = 0 - TRANSLATE_PRECISION; 16622 var TRANSLATE_MAX = 0 + TRANSLATE_PRECISION; 16623 function calcLength(axis) { 16624 return axis.max - axis.min; 16625 } 16626 function isNear(value, target, maxDistance) { 16627 return Math.abs(value - target) <= maxDistance; 16628 } 16629 function calcAxisDelta(delta, source, target, origin = 0.5) { 16630 delta.origin = origin; 16631 delta.originPoint = mixNumber(source.min, source.max, delta.origin); 16632 delta.scale = calcLength(target) / calcLength(source); 16633 delta.translate = mixNumber(target.min, target.max, delta.origin) - delta.originPoint; 16634 if (delta.scale >= SCALE_MIN && delta.scale <= SCALE_MAX || isNaN(delta.scale)) { 16635 delta.scale = 1; 16636 } 16637 if (delta.translate >= TRANSLATE_MIN && delta.translate <= TRANSLATE_MAX || isNaN(delta.translate)) { 16638 delta.translate = 0; 16639 } 16640 } 16641 function calcBoxDelta(delta, source, target, origin) { 16642 calcAxisDelta(delta.x, source.x, target.x, origin ? origin.originX : void 0); 16643 calcAxisDelta(delta.y, source.y, target.y, origin ? origin.originY : void 0); 16644 } 16645 function calcRelativeAxis(target, relative, parent) { 16646 target.min = parent.min + relative.min; 16647 target.max = target.min + calcLength(relative); 16648 } 16649 function calcRelativeBox(target, relative, parent) { 16650 calcRelativeAxis(target.x, relative.x, parent.x); 16651 calcRelativeAxis(target.y, relative.y, parent.y); 16652 } 16653 function calcRelativeAxisPosition(target, layout2, parent) { 16654 target.min = layout2.min - parent.min; 16655 target.max = target.min + calcLength(layout2); 16656 } 16657 function calcRelativePosition(target, layout2, parent) { 16658 calcRelativeAxisPosition(target.x, layout2.x, parent.x); 16659 calcRelativeAxisPosition(target.y, layout2.y, parent.y); 16660 } 16661 16662 // packages/components/node_modules/framer-motion/dist/es/gestures/drag/utils/constraints.mjs 16663 function applyConstraints(point, { min: min3, max: max3 }, elastic) { 16664 if (min3 !== void 0 && point < min3) { 16665 point = elastic ? mixNumber(min3, point, elastic.min) : Math.max(point, min3); 16666 } else if (max3 !== void 0 && point > max3) { 16667 point = elastic ? mixNumber(max3, point, elastic.max) : Math.min(point, max3); 16668 } 16669 return point; 16670 } 16671 function calcRelativeAxisConstraints(axis, min3, max3) { 16672 return { 16673 min: min3 !== void 0 ? axis.min + min3 : void 0, 16674 max: max3 !== void 0 ? axis.max + max3 - (axis.max - axis.min) : void 0 16675 }; 16676 } 16677 function calcRelativeConstraints(layoutBox, { top, left, bottom, right }) { 16678 return { 16679 x: calcRelativeAxisConstraints(layoutBox.x, left, right), 16680 y: calcRelativeAxisConstraints(layoutBox.y, top, bottom) 16681 }; 16682 } 16683 function calcViewportAxisConstraints(layoutAxis, constraintsAxis) { 16684 let min3 = constraintsAxis.min - layoutAxis.min; 16685 let max3 = constraintsAxis.max - layoutAxis.max; 16686 if (constraintsAxis.max - constraintsAxis.min < layoutAxis.max - layoutAxis.min) { 16687 [min3, max3] = [max3, min3]; 16688 } 16689 return { min: min3, max: max3 }; 16690 } 16691 function calcViewportConstraints(layoutBox, constraintsBox) { 16692 return { 16693 x: calcViewportAxisConstraints(layoutBox.x, constraintsBox.x), 16694 y: calcViewportAxisConstraints(layoutBox.y, constraintsBox.y) 16695 }; 16696 } 16697 function calcOrigin(source, target) { 16698 let origin = 0.5; 16699 const sourceLength = calcLength(source); 16700 const targetLength = calcLength(target); 16701 if (targetLength > sourceLength) { 16702 origin = progress(target.min, target.max - sourceLength, source.min); 16703 } else if (sourceLength > targetLength) { 16704 origin = progress(source.min, source.max - targetLength, target.min); 16705 } 16706 return clamp2(0, 1, origin); 16707 } 16708 function rebaseAxisConstraints(layout2, constraints) { 16709 const relativeConstraints = {}; 16710 if (constraints.min !== void 0) { 16711 relativeConstraints.min = constraints.min - layout2.min; 16712 } 16713 if (constraints.max !== void 0) { 16714 relativeConstraints.max = constraints.max - layout2.min; 16715 } 16716 return relativeConstraints; 16717 } 16718 var defaultElastic = 0.35; 16719 function resolveDragElastic(dragElastic = defaultElastic) { 16720 if (dragElastic === false) { 16721 dragElastic = 0; 16722 } else if (dragElastic === true) { 16723 dragElastic = defaultElastic; 16724 } 16725 return { 16726 x: resolveAxisElastic(dragElastic, "left", "right"), 16727 y: resolveAxisElastic(dragElastic, "top", "bottom") 16728 }; 16729 } 16730 function resolveAxisElastic(dragElastic, minLabel, maxLabel) { 16731 return { 16732 min: resolvePointElastic(dragElastic, minLabel), 16733 max: resolvePointElastic(dragElastic, maxLabel) 16734 }; 16735 } 16736 function resolvePointElastic(dragElastic, label) { 16737 return typeof dragElastic === "number" ? dragElastic : dragElastic[label] || 0; 16738 } 16739 16740 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/models.mjs 16741 var createAxisDelta = () => ({ 16742 translate: 0, 16743 scale: 1, 16744 origin: 0, 16745 originPoint: 0 16746 }); 16747 var createDelta = () => ({ 16748 x: createAxisDelta(), 16749 y: createAxisDelta() 16750 }); 16751 var createAxis = () => ({ min: 0, max: 0 }); 16752 var createBox = () => ({ 16753 x: createAxis(), 16754 y: createAxis() 16755 }); 16756 16757 // packages/components/node_modules/framer-motion/dist/es/projection/utils/each-axis.mjs 16758 function eachAxis(callback) { 16759 return [callback("x"), callback("y")]; 16760 } 16761 16762 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/conversion.mjs 16763 function convertBoundingBoxToBox({ top, left, right, bottom }) { 16764 return { 16765 x: { min: left, max: right }, 16766 y: { min: top, max: bottom } 16767 }; 16768 } 16769 function convertBoxToBoundingBox({ x: x2, y: y3 }) { 16770 return { top: y3.min, right: x2.max, bottom: y3.max, left: x2.min }; 16771 } 16772 function transformBoxPoints(point, transformPoint2) { 16773 if (!transformPoint2) 16774 return point; 16775 const topLeft = transformPoint2({ x: point.left, y: point.top }); 16776 const bottomRight = transformPoint2({ x: point.right, y: point.bottom }); 16777 return { 16778 top: topLeft.y, 16779 left: topLeft.x, 16780 bottom: bottomRight.y, 16781 right: bottomRight.x 16782 }; 16783 } 16784 16785 // packages/components/node_modules/framer-motion/dist/es/projection/utils/has-transform.mjs 16786 function isIdentityScale(scale2) { 16787 return scale2 === void 0 || scale2 === 1; 16788 } 16789 function hasScale({ scale: scale2, scaleX, scaleY }) { 16790 return !isIdentityScale(scale2) || !isIdentityScale(scaleX) || !isIdentityScale(scaleY); 16791 } 16792 function hasTransform(values) { 16793 return hasScale(values) || has2DTranslate(values) || values.z || values.rotate || values.rotateX || values.rotateY || values.skewX || values.skewY; 16794 } 16795 function has2DTranslate(values) { 16796 return is2DTranslate(values.x) || is2DTranslate(values.y); 16797 } 16798 function is2DTranslate(value) { 16799 return value && value !== "0%"; 16800 } 16801 16802 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/delta-apply.mjs 16803 function scalePoint(point, scale2, originPoint) { 16804 const distanceFromOrigin = point - originPoint; 16805 const scaled = scale2 * distanceFromOrigin; 16806 return originPoint + scaled; 16807 } 16808 function applyPointDelta(point, translate, scale2, originPoint, boxScale) { 16809 if (boxScale !== void 0) { 16810 point = scalePoint(point, boxScale, originPoint); 16811 } 16812 return scalePoint(point, scale2, originPoint) + translate; 16813 } 16814 function applyAxisDelta(axis, translate = 0, scale2 = 1, originPoint, boxScale) { 16815 axis.min = applyPointDelta(axis.min, translate, scale2, originPoint, boxScale); 16816 axis.max = applyPointDelta(axis.max, translate, scale2, originPoint, boxScale); 16817 } 16818 function applyBoxDelta(box, { x: x2, y: y3 }) { 16819 applyAxisDelta(box.x, x2.translate, x2.scale, x2.originPoint); 16820 applyAxisDelta(box.y, y3.translate, y3.scale, y3.originPoint); 16821 } 16822 var TREE_SCALE_SNAP_MIN = 0.999999999999; 16823 var TREE_SCALE_SNAP_MAX = 1.0000000000001; 16824 function applyTreeDeltas(box, treeScale, treePath, isSharedTransition = false) { 16825 const treeLength = treePath.length; 16826 if (!treeLength) 16827 return; 16828 treeScale.x = treeScale.y = 1; 16829 let node2; 16830 let delta; 16831 for (let i3 = 0; i3 < treeLength; i3++) { 16832 node2 = treePath[i3]; 16833 delta = node2.projectionDelta; 16834 const { visualElement } = node2.options; 16835 if (visualElement && visualElement.props.style && visualElement.props.style.display === "contents") { 16836 continue; 16837 } 16838 if (isSharedTransition && node2.options.layoutScroll && node2.scroll && node2 !== node2.root) { 16839 transformBox(box, { 16840 x: -node2.scroll.offset.x, 16841 y: -node2.scroll.offset.y 16842 }); 16843 } 16844 if (delta) { 16845 treeScale.x *= delta.x.scale; 16846 treeScale.y *= delta.y.scale; 16847 applyBoxDelta(box, delta); 16848 } 16849 if (isSharedTransition && hasTransform(node2.latestValues)) { 16850 transformBox(box, node2.latestValues); 16851 } 16852 } 16853 if (treeScale.x < TREE_SCALE_SNAP_MAX && treeScale.x > TREE_SCALE_SNAP_MIN) { 16854 treeScale.x = 1; 16855 } 16856 if (treeScale.y < TREE_SCALE_SNAP_MAX && treeScale.y > TREE_SCALE_SNAP_MIN) { 16857 treeScale.y = 1; 16858 } 16859 } 16860 function translateAxis(axis, distance2) { 16861 axis.min = axis.min + distance2; 16862 axis.max = axis.max + distance2; 16863 } 16864 function transformAxis(axis, axisTranslate, axisScale, boxScale, axisOrigin = 0.5) { 16865 const originPoint = mixNumber(axis.min, axis.max, axisOrigin); 16866 applyAxisDelta(axis, axisTranslate, axisScale, originPoint, boxScale); 16867 } 16868 function transformBox(box, transform) { 16869 transformAxis(box.x, transform.x, transform.scaleX, transform.scale, transform.originX); 16870 transformAxis(box.y, transform.y, transform.scaleY, transform.scale, transform.originY); 16871 } 16872 16873 // packages/components/node_modules/framer-motion/dist/es/projection/utils/measure.mjs 16874 function measureViewportBox(instance, transformPoint2) { 16875 return convertBoundingBoxToBox(transformBoxPoints(instance.getBoundingClientRect(), transformPoint2)); 16876 } 16877 function measurePageBox(element, rootProjectionNode2, transformPagePoint) { 16878 const viewportBox = measureViewportBox(element, transformPagePoint); 16879 const { scroll } = rootProjectionNode2; 16880 if (scroll) { 16881 translateAxis(viewportBox.x, scroll.offset.x); 16882 translateAxis(viewportBox.y, scroll.offset.y); 16883 } 16884 return viewportBox; 16885 } 16886 16887 // packages/components/node_modules/framer-motion/dist/es/utils/get-context-window.mjs 16888 var getContextWindow = ({ current }) => { 16889 return current ? current.ownerDocument.defaultView : null; 16890 }; 16891 16892 // packages/components/node_modules/framer-motion/dist/es/gestures/drag/VisualElementDragControls.mjs 16893 var elementDragControls = /* @__PURE__ */ new WeakMap(); 16894 var VisualElementDragControls = class { 16895 constructor(visualElement) { 16896 this.openDragLock = null; 16897 this.isDragging = false; 16898 this.currentDirection = null; 16899 this.originPoint = { x: 0, y: 0 }; 16900 this.constraints = false; 16901 this.hasMutatedConstraints = false; 16902 this.elastic = createBox(); 16903 this.visualElement = visualElement; 16904 } 16905 start(originEvent, { snapToCursor = false } = {}) { 16906 const { presenceContext } = this.visualElement; 16907 if (presenceContext && presenceContext.isPresent === false) 16908 return; 16909 const onSessionStart = (event) => { 16910 const { dragSnapToOrigin: dragSnapToOrigin2 } = this.getProps(); 16911 dragSnapToOrigin2 ? this.pauseAnimation() : this.stopAnimation(); 16912 if (snapToCursor) { 16913 this.snapToCursor(extractEventInfo(event).point); 16914 } 16915 }; 16916 const onStart = (event, info) => { 16917 const { drag: drag2, dragPropagation, onDragStart } = this.getProps(); 16918 if (drag2 && !dragPropagation) { 16919 if (this.openDragLock) 16920 this.openDragLock(); 16921 this.openDragLock = setDragLock(drag2); 16922 if (!this.openDragLock) 16923 return; 16924 } 16925 this.isDragging = true; 16926 this.currentDirection = null; 16927 this.resolveConstraints(); 16928 if (this.visualElement.projection) { 16929 this.visualElement.projection.isAnimationBlocked = true; 16930 this.visualElement.projection.target = void 0; 16931 } 16932 eachAxis((axis) => { 16933 let current = this.getAxisMotionValue(axis).get() || 0; 16934 if (percent.test(current)) { 16935 const { projection } = this.visualElement; 16936 if (projection && projection.layout) { 16937 const measuredAxis = projection.layout.layoutBox[axis]; 16938 if (measuredAxis) { 16939 const length2 = calcLength(measuredAxis); 16940 current = length2 * (parseFloat(current) / 100); 16941 } 16942 } 16943 } 16944 this.originPoint[axis] = current; 16945 }); 16946 if (onDragStart) { 16947 frame.postRender(() => onDragStart(event, info)); 16948 } 16949 addValueToWillChange(this.visualElement, "transform"); 16950 const { animationState } = this.visualElement; 16951 animationState && animationState.setActive("whileDrag", true); 16952 }; 16953 const onMove = (event, info) => { 16954 const { dragPropagation, dragDirectionLock, onDirectionLock, onDrag } = this.getProps(); 16955 if (!dragPropagation && !this.openDragLock) 16956 return; 16957 const { offset: offset3 } = info; 16958 if (dragDirectionLock && this.currentDirection === null) { 16959 this.currentDirection = getCurrentDirection(offset3); 16960 if (this.currentDirection !== null) { 16961 onDirectionLock && onDirectionLock(this.currentDirection); 16962 } 16963 return; 16964 } 16965 this.updateAxis("x", info.point, offset3); 16966 this.updateAxis("y", info.point, offset3); 16967 this.visualElement.render(); 16968 onDrag && onDrag(event, info); 16969 }; 16970 const onSessionEnd = (event, info) => this.stop(event, info); 16971 const resumeAnimation = () => eachAxis((axis) => { 16972 var _a; 16973 return this.getAnimationState(axis) === "paused" && ((_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.play()); 16974 }); 16975 const { dragSnapToOrigin } = this.getProps(); 16976 this.panSession = new PanSession(originEvent, { 16977 onSessionStart, 16978 onStart, 16979 onMove, 16980 onSessionEnd, 16981 resumeAnimation 16982 }, { 16983 transformPagePoint: this.visualElement.getTransformPagePoint(), 16984 dragSnapToOrigin, 16985 contextWindow: getContextWindow(this.visualElement) 16986 }); 16987 } 16988 stop(event, info) { 16989 const isDragging2 = this.isDragging; 16990 this.cancel(); 16991 if (!isDragging2) 16992 return; 16993 const { velocity } = info; 16994 this.startAnimation(velocity); 16995 const { onDragEnd } = this.getProps(); 16996 if (onDragEnd) { 16997 frame.postRender(() => onDragEnd(event, info)); 16998 } 16999 } 17000 cancel() { 17001 this.isDragging = false; 17002 const { projection, animationState } = this.visualElement; 17003 if (projection) { 17004 projection.isAnimationBlocked = false; 17005 } 17006 this.panSession && this.panSession.end(); 17007 this.panSession = void 0; 17008 const { dragPropagation } = this.getProps(); 17009 if (!dragPropagation && this.openDragLock) { 17010 this.openDragLock(); 17011 this.openDragLock = null; 17012 } 17013 animationState && animationState.setActive("whileDrag", false); 17014 } 17015 updateAxis(axis, _point, offset3) { 17016 const { drag: drag2 } = this.getProps(); 17017 if (!offset3 || !shouldDrag(axis, drag2, this.currentDirection)) 17018 return; 17019 const axisValue = this.getAxisMotionValue(axis); 17020 let next2 = this.originPoint[axis] + offset3[axis]; 17021 if (this.constraints && this.constraints[axis]) { 17022 next2 = applyConstraints(next2, this.constraints[axis], this.elastic[axis]); 17023 } 17024 axisValue.set(next2); 17025 } 17026 resolveConstraints() { 17027 var _a; 17028 const { dragConstraints, dragElastic } = this.getProps(); 17029 const layout2 = this.visualElement.projection && !this.visualElement.projection.layout ? this.visualElement.projection.measure(false) : (_a = this.visualElement.projection) === null || _a === void 0 ? void 0 : _a.layout; 17030 const prevConstraints = this.constraints; 17031 if (dragConstraints && isRefObject(dragConstraints)) { 17032 if (!this.constraints) { 17033 this.constraints = this.resolveRefConstraints(); 17034 } 17035 } else { 17036 if (dragConstraints && layout2) { 17037 this.constraints = calcRelativeConstraints(layout2.layoutBox, dragConstraints); 17038 } else { 17039 this.constraints = false; 17040 } 17041 } 17042 this.elastic = resolveDragElastic(dragElastic); 17043 if (prevConstraints !== this.constraints && layout2 && this.constraints && !this.hasMutatedConstraints) { 17044 eachAxis((axis) => { 17045 if (this.constraints !== false && this.getAxisMotionValue(axis)) { 17046 this.constraints[axis] = rebaseAxisConstraints(layout2.layoutBox[axis], this.constraints[axis]); 17047 } 17048 }); 17049 } 17050 } 17051 resolveRefConstraints() { 17052 const { dragConstraints: constraints, onMeasureDragConstraints } = this.getProps(); 17053 if (!constraints || !isRefObject(constraints)) 17054 return false; 17055 const constraintsElement = constraints.current; 17056 invariant2(constraintsElement !== null, "If `dragConstraints` is set as a React ref, that ref must be passed to another component's `ref` prop."); 17057 const { projection } = this.visualElement; 17058 if (!projection || !projection.layout) 17059 return false; 17060 const constraintsBox = measurePageBox(constraintsElement, projection.root, this.visualElement.getTransformPagePoint()); 17061 let measuredConstraints = calcViewportConstraints(projection.layout.layoutBox, constraintsBox); 17062 if (onMeasureDragConstraints) { 17063 const userConstraints = onMeasureDragConstraints(convertBoxToBoundingBox(measuredConstraints)); 17064 this.hasMutatedConstraints = !!userConstraints; 17065 if (userConstraints) { 17066 measuredConstraints = convertBoundingBoxToBox(userConstraints); 17067 } 17068 } 17069 return measuredConstraints; 17070 } 17071 startAnimation(velocity) { 17072 const { drag: drag2, dragMomentum, dragElastic, dragTransition, dragSnapToOrigin, onDragTransitionEnd } = this.getProps(); 17073 const constraints = this.constraints || {}; 17074 const momentumAnimations = eachAxis((axis) => { 17075 if (!shouldDrag(axis, drag2, this.currentDirection)) { 17076 return; 17077 } 17078 let transition = constraints && constraints[axis] || {}; 17079 if (dragSnapToOrigin) 17080 transition = { min: 0, max: 0 }; 17081 const bounceStiffness = dragElastic ? 200 : 1e6; 17082 const bounceDamping = dragElastic ? 40 : 1e7; 17083 const inertia2 = { 17084 type: "inertia", 17085 velocity: dragMomentum ? velocity[axis] : 0, 17086 bounceStiffness, 17087 bounceDamping, 17088 timeConstant: 750, 17089 restDelta: 1, 17090 restSpeed: 10, 17091 ...dragTransition, 17092 ...transition 17093 }; 17094 return this.startAxisValueAnimation(axis, inertia2); 17095 }); 17096 return Promise.all(momentumAnimations).then(onDragTransitionEnd); 17097 } 17098 startAxisValueAnimation(axis, transition) { 17099 const axisValue = this.getAxisMotionValue(axis); 17100 addValueToWillChange(this.visualElement, axis); 17101 return axisValue.start(animateMotionValue(axis, axisValue, 0, transition, this.visualElement, false)); 17102 } 17103 stopAnimation() { 17104 eachAxis((axis) => this.getAxisMotionValue(axis).stop()); 17105 } 17106 pauseAnimation() { 17107 eachAxis((axis) => { 17108 var _a; 17109 return (_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.pause(); 17110 }); 17111 } 17112 getAnimationState(axis) { 17113 var _a; 17114 return (_a = this.getAxisMotionValue(axis).animation) === null || _a === void 0 ? void 0 : _a.state; 17115 } 17116 /** 17117 * Drag works differently depending on which props are provided. 17118 * 17119 * - If _dragX and _dragY are provided, we output the gesture delta directly to those motion values. 17120 * - Otherwise, we apply the delta to the x/y motion values. 17121 */ 17122 getAxisMotionValue(axis) { 17123 const dragKey = `_drag$axis.toUpperCase()}`; 17124 const props = this.visualElement.getProps(); 17125 const externalMotionValue = props[dragKey]; 17126 return externalMotionValue ? externalMotionValue : this.visualElement.getValue(axis, (props.initial ? props.initial[axis] : void 0) || 0); 17127 } 17128 snapToCursor(point) { 17129 eachAxis((axis) => { 17130 const { drag: drag2 } = this.getProps(); 17131 if (!shouldDrag(axis, drag2, this.currentDirection)) 17132 return; 17133 const { projection } = this.visualElement; 17134 const axisValue = this.getAxisMotionValue(axis); 17135 if (projection && projection.layout) { 17136 const { min: min3, max: max3 } = projection.layout.layoutBox[axis]; 17137 axisValue.set(point[axis] - mixNumber(min3, max3, 0.5)); 17138 } 17139 }); 17140 } 17141 /** 17142 * When the viewport resizes we want to check if the measured constraints 17143 * have changed and, if so, reposition the element within those new constraints 17144 * relative to where it was before the resize. 17145 */ 17146 scalePositionWithinConstraints() { 17147 if (!this.visualElement.current) 17148 return; 17149 const { drag: drag2, dragConstraints } = this.getProps(); 17150 const { projection } = this.visualElement; 17151 if (!isRefObject(dragConstraints) || !projection || !this.constraints) 17152 return; 17153 this.stopAnimation(); 17154 const boxProgress = { x: 0, y: 0 }; 17155 eachAxis((axis) => { 17156 const axisValue = this.getAxisMotionValue(axis); 17157 if (axisValue && this.constraints !== false) { 17158 const latest = axisValue.get(); 17159 boxProgress[axis] = calcOrigin({ min: latest, max: latest }, this.constraints[axis]); 17160 } 17161 }); 17162 const { transformTemplate } = this.visualElement.getProps(); 17163 this.visualElement.current.style.transform = transformTemplate ? transformTemplate({}, "") : "none"; 17164 projection.root && projection.root.updateScroll(); 17165 projection.updateLayout(); 17166 this.resolveConstraints(); 17167 eachAxis((axis) => { 17168 if (!shouldDrag(axis, drag2, null)) 17169 return; 17170 const axisValue = this.getAxisMotionValue(axis); 17171 const { min: min3, max: max3 } = this.constraints[axis]; 17172 axisValue.set(mixNumber(min3, max3, boxProgress[axis])); 17173 }); 17174 } 17175 addListeners() { 17176 if (!this.visualElement.current) 17177 return; 17178 elementDragControls.set(this.visualElement, this); 17179 const element = this.visualElement.current; 17180 const stopPointerListener = addPointerEvent(element, "pointerdown", (event) => { 17181 const { drag: drag2, dragListener = true } = this.getProps(); 17182 drag2 && dragListener && this.start(event); 17183 }); 17184 const measureDragConstraints = () => { 17185 const { dragConstraints } = this.getProps(); 17186 if (isRefObject(dragConstraints) && dragConstraints.current) { 17187 this.constraints = this.resolveRefConstraints(); 17188 } 17189 }; 17190 const { projection } = this.visualElement; 17191 const stopMeasureLayoutListener = projection.addEventListener("measure", measureDragConstraints); 17192 if (projection && !projection.layout) { 17193 projection.root && projection.root.updateScroll(); 17194 projection.updateLayout(); 17195 } 17196 frame.read(measureDragConstraints); 17197 const stopResizeListener = addDomEvent(window, "resize", () => this.scalePositionWithinConstraints()); 17198 const stopLayoutUpdateListener = projection.addEventListener("didUpdate", (({ delta, hasLayoutChanged }) => { 17199 if (this.isDragging && hasLayoutChanged) { 17200 eachAxis((axis) => { 17201 const motionValue2 = this.getAxisMotionValue(axis); 17202 if (!motionValue2) 17203 return; 17204 this.originPoint[axis] += delta[axis].translate; 17205 motionValue2.set(motionValue2.get() + delta[axis].translate); 17206 }); 17207 this.visualElement.render(); 17208 } 17209 })); 17210 return () => { 17211 stopResizeListener(); 17212 stopPointerListener(); 17213 stopMeasureLayoutListener(); 17214 stopLayoutUpdateListener && stopLayoutUpdateListener(); 17215 }; 17216 } 17217 getProps() { 17218 const props = this.visualElement.getProps(); 17219 const { drag: drag2 = false, dragDirectionLock = false, dragPropagation = false, dragConstraints = false, dragElastic = defaultElastic, dragMomentum = true } = props; 17220 return { 17221 ...props, 17222 drag: drag2, 17223 dragDirectionLock, 17224 dragPropagation, 17225 dragConstraints, 17226 dragElastic, 17227 dragMomentum 17228 }; 17229 } 17230 }; 17231 function shouldDrag(direction, drag2, currentDirection) { 17232 return (drag2 === true || drag2 === direction) && (currentDirection === null || currentDirection === direction); 17233 } 17234 function getCurrentDirection(offset3, lockThreshold = 10) { 17235 let direction = null; 17236 if (Math.abs(offset3.y) > lockThreshold) { 17237 direction = "y"; 17238 } else if (Math.abs(offset3.x) > lockThreshold) { 17239 direction = "x"; 17240 } 17241 return direction; 17242 } 17243 17244 // packages/components/node_modules/framer-motion/dist/es/gestures/drag/index.mjs 17245 var DragGesture = class extends Feature { 17246 constructor(node2) { 17247 super(node2); 17248 this.removeGroupControls = noop2; 17249 this.removeListeners = noop2; 17250 this.controls = new VisualElementDragControls(node2); 17251 } 17252 mount() { 17253 const { dragControls } = this.node.getProps(); 17254 if (dragControls) { 17255 this.removeGroupControls = dragControls.subscribe(this.controls); 17256 } 17257 this.removeListeners = this.controls.addListeners() || noop2; 17258 } 17259 unmount() { 17260 this.removeGroupControls(); 17261 this.removeListeners(); 17262 } 17263 }; 17264 17265 // packages/components/node_modules/framer-motion/dist/es/gestures/pan/index.mjs 17266 var asyncHandler = (handler) => (event, info) => { 17267 if (handler) { 17268 frame.postRender(() => handler(event, info)); 17269 } 17270 }; 17271 var PanGesture = class extends Feature { 17272 constructor() { 17273 super(...arguments); 17274 this.removePointerDownListener = noop2; 17275 } 17276 onPointerDown(pointerDownEvent) { 17277 this.session = new PanSession(pointerDownEvent, this.createPanHandlers(), { 17278 transformPagePoint: this.node.getTransformPagePoint(), 17279 contextWindow: getContextWindow(this.node) 17280 }); 17281 } 17282 createPanHandlers() { 17283 const { onPanSessionStart, onPanStart, onPan, onPanEnd } = this.node.getProps(); 17284 return { 17285 onSessionStart: asyncHandler(onPanSessionStart), 17286 onStart: asyncHandler(onPanStart), 17287 onMove: onPan, 17288 onEnd: (event, info) => { 17289 delete this.session; 17290 if (onPanEnd) { 17291 frame.postRender(() => onPanEnd(event, info)); 17292 } 17293 } 17294 }; 17295 } 17296 mount() { 17297 this.removePointerDownListener = addPointerEvent(this.node.current, "pointerdown", (event) => this.onPointerDown(event)); 17298 } 17299 update() { 17300 this.session && this.session.updateHandlers(this.createPanHandlers()); 17301 } 17302 unmount() { 17303 this.removePointerDownListener(); 17304 this.session && this.session.end(); 17305 } 17306 }; 17307 17308 // packages/components/node_modules/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs 17309 var import_jsx_runtime39 = __toESM(require_jsx_runtime(), 1); 17310 var import_react61 = __toESM(require_react(), 1); 17311 17312 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs 17313 var import_react58 = __toESM(require_react(), 1); 17314 17315 // packages/components/node_modules/framer-motion/dist/es/context/PresenceContext.mjs 17316 var import_react57 = __toESM(require_react(), 1); 17317 var PresenceContext = (0, import_react57.createContext)(null); 17318 17319 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/use-presence.mjs 17320 function usePresence() { 17321 const context = (0, import_react58.useContext)(PresenceContext); 17322 if (context === null) 17323 return [true, null]; 17324 const { isPresent, onExitComplete, register } = context; 17325 const id3 = (0, import_react58.useId)(); 17326 (0, import_react58.useEffect)(() => register(id3), []); 17327 const safeToRemove = (0, import_react58.useCallback)(() => onExitComplete && onExitComplete(id3), [id3, onExitComplete]); 17328 return !isPresent && onExitComplete ? [false, safeToRemove] : [true]; 17329 } 17330 17331 // packages/components/node_modules/framer-motion/dist/es/context/LayoutGroupContext.mjs 17332 var import_react59 = __toESM(require_react(), 1); 17333 var LayoutGroupContext = (0, import_react59.createContext)({}); 17334 17335 // packages/components/node_modules/framer-motion/dist/es/context/SwitchLayoutGroupContext.mjs 17336 var import_react60 = __toESM(require_react(), 1); 17337 var SwitchLayoutGroupContext = (0, import_react60.createContext)({}); 17338 17339 // packages/components/node_modules/framer-motion/dist/es/projection/node/state.mjs 17340 var globalProjectionState = { 17341 /** 17342 * Global flag as to whether the tree has animated since the last time 17343 * we resized the window 17344 */ 17345 hasAnimatedSinceResize: true, 17346 /** 17347 * We set this to true once, on the first update. Any nodes added to the tree beyond that 17348 * update will be given a `data-projection-id` attribute. 17349 */ 17350 hasEverUpdated: false 17351 }; 17352 17353 // packages/components/node_modules/framer-motion/dist/es/projection/styles/scale-border-radius.mjs 17354 function pixelsToPercent(pixels, axis) { 17355 if (axis.max === axis.min) 17356 return 0; 17357 return pixels / (axis.max - axis.min) * 100; 17358 } 17359 var correctBorderRadius = { 17360 correct: (latest, node2) => { 17361 if (!node2.target) 17362 return latest; 17363 if (typeof latest === "string") { 17364 if (px.test(latest)) { 17365 latest = parseFloat(latest); 17366 } else { 17367 return latest; 17368 } 17369 } 17370 const x2 = pixelsToPercent(latest, node2.target.x); 17371 const y3 = pixelsToPercent(latest, node2.target.y); 17372 return `$x2}% $y3}%`; 17373 } 17374 }; 17375 17376 // packages/components/node_modules/framer-motion/dist/es/projection/styles/scale-box-shadow.mjs 17377 var correctBoxShadow = { 17378 correct: (latest, { treeScale, projectionDelta }) => { 17379 const original = latest; 17380 const shadow = complex.parse(latest); 17381 if (shadow.length > 5) 17382 return original; 17383 const template = complex.createTransformer(latest); 17384 const offset3 = typeof shadow[0] !== "number" ? 1 : 0; 17385 const xScale = projectionDelta.x.scale * treeScale.x; 17386 const yScale = projectionDelta.y.scale * treeScale.y; 17387 shadow[0 + offset3] /= xScale; 17388 shadow[1 + offset3] /= yScale; 17389 const averageScale = mixNumber(xScale, yScale, 0.5); 17390 if (typeof shadow[2 + offset3] === "number") 17391 shadow[2 + offset3] /= averageScale; 17392 if (typeof shadow[3 + offset3] === "number") 17393 shadow[3 + offset3] /= averageScale; 17394 return template(shadow); 17395 } 17396 }; 17397 17398 // packages/components/node_modules/framer-motion/dist/es/projection/styles/scale-correction.mjs 17399 var scaleCorrectors = {}; 17400 function addScaleCorrector(correctors) { 17401 Object.assign(scaleCorrectors, correctors); 17402 } 17403 17404 // packages/components/node_modules/framer-motion/dist/es/frameloop/microtask.mjs 17405 var { schedule: microtask, cancel: cancelMicrotask } = createRenderBatcher(queueMicrotask, false); 17406 17407 // packages/components/node_modules/framer-motion/dist/es/motion/features/layout/MeasureLayout.mjs 17408 var MeasureLayoutWithContext = class extends import_react61.Component { 17409 /** 17410 * This only mounts projection nodes for components that 17411 * need measuring, we might want to do it for all components 17412 * in order to incorporate transforms 17413 */ 17414 componentDidMount() { 17415 const { visualElement, layoutGroup, switchLayoutGroup, layoutId } = this.props; 17416 const { projection } = visualElement; 17417 addScaleCorrector(defaultScaleCorrectors); 17418 if (projection) { 17419 if (layoutGroup.group) 17420 layoutGroup.group.add(projection); 17421 if (switchLayoutGroup && switchLayoutGroup.register && layoutId) { 17422 switchLayoutGroup.register(projection); 17423 } 17424 projection.root.didUpdate(); 17425 projection.addEventListener("animationComplete", () => { 17426 this.safeToRemove(); 17427 }); 17428 projection.setOptions({ 17429 ...projection.options, 17430 onExitComplete: () => this.safeToRemove() 17431 }); 17432 } 17433 globalProjectionState.hasEverUpdated = true; 17434 } 17435 getSnapshotBeforeUpdate(prevProps) { 17436 const { layoutDependency, visualElement, drag: drag2, isPresent } = this.props; 17437 const projection = visualElement.projection; 17438 if (!projection) 17439 return null; 17440 projection.isPresent = isPresent; 17441 if (drag2 || prevProps.layoutDependency !== layoutDependency || layoutDependency === void 0) { 17442 projection.willUpdate(); 17443 } else { 17444 this.safeToRemove(); 17445 } 17446 if (prevProps.isPresent !== isPresent) { 17447 if (isPresent) { 17448 projection.promote(); 17449 } else if (!projection.relegate()) { 17450 frame.postRender(() => { 17451 const stack = projection.getStack(); 17452 if (!stack || !stack.members.length) { 17453 this.safeToRemove(); 17454 } 17455 }); 17456 } 17457 } 17458 return null; 17459 } 17460 componentDidUpdate() { 17461 const { projection } = this.props.visualElement; 17462 if (projection) { 17463 projection.root.didUpdate(); 17464 microtask.postRender(() => { 17465 if (!projection.currentAnimation && projection.isLead()) { 17466 this.safeToRemove(); 17467 } 17468 }); 17469 } 17470 } 17471 componentWillUnmount() { 17472 const { visualElement, layoutGroup, switchLayoutGroup: promoteContext } = this.props; 17473 const { projection } = visualElement; 17474 if (projection) { 17475 projection.scheduleCheckAfterUnmount(); 17476 if (layoutGroup && layoutGroup.group) 17477 layoutGroup.group.remove(projection); 17478 if (promoteContext && promoteContext.deregister) 17479 promoteContext.deregister(projection); 17480 } 17481 } 17482 safeToRemove() { 17483 const { safeToRemove } = this.props; 17484 safeToRemove && safeToRemove(); 17485 } 17486 render() { 17487 return null; 17488 } 17489 }; 17490 function MeasureLayout(props) { 17491 const [isPresent, safeToRemove] = usePresence(); 17492 const layoutGroup = (0, import_react61.useContext)(LayoutGroupContext); 17493 return (0, import_jsx_runtime39.jsx)(MeasureLayoutWithContext, { ...props, layoutGroup, switchLayoutGroup: (0, import_react61.useContext)(SwitchLayoutGroupContext), isPresent, safeToRemove }); 17494 } 17495 var defaultScaleCorrectors = { 17496 borderRadius: { 17497 ...correctBorderRadius, 17498 applyTo: [ 17499 "borderTopLeftRadius", 17500 "borderTopRightRadius", 17501 "borderBottomLeftRadius", 17502 "borderBottomRightRadius" 17503 ] 17504 }, 17505 borderTopLeftRadius: correctBorderRadius, 17506 borderTopRightRadius: correctBorderRadius, 17507 borderBottomLeftRadius: correctBorderRadius, 17508 borderBottomRightRadius: correctBorderRadius, 17509 boxShadow: correctBoxShadow 17510 }; 17511 17512 // packages/components/node_modules/framer-motion/dist/es/projection/animation/mix-values.mjs 17513 var borders = ["TopLeft", "TopRight", "BottomLeft", "BottomRight"]; 17514 var numBorders = borders.length; 17515 var asNumber = (value) => typeof value === "string" ? parseFloat(value) : value; 17516 var isPx = (value) => typeof value === "number" || px.test(value); 17517 function mixValues(target, follow, lead, progress2, shouldCrossfadeOpacity, isOnlyMember) { 17518 if (shouldCrossfadeOpacity) { 17519 target.opacity = mixNumber( 17520 0, 17521 // TODO Reinstate this if only child 17522 lead.opacity !== void 0 ? lead.opacity : 1, 17523 easeCrossfadeIn(progress2) 17524 ); 17525 target.opacityExit = mixNumber(follow.opacity !== void 0 ? follow.opacity : 1, 0, easeCrossfadeOut(progress2)); 17526 } else if (isOnlyMember) { 17527 target.opacity = mixNumber(follow.opacity !== void 0 ? follow.opacity : 1, lead.opacity !== void 0 ? lead.opacity : 1, progress2); 17528 } 17529 for (let i3 = 0; i3 < numBorders; i3++) { 17530 const borderLabel = `border$borders[i3]}Radius`; 17531 let followRadius = getRadius(follow, borderLabel); 17532 let leadRadius = getRadius(lead, borderLabel); 17533 if (followRadius === void 0 && leadRadius === void 0) 17534 continue; 17535 followRadius || (followRadius = 0); 17536 leadRadius || (leadRadius = 0); 17537 const canMix = followRadius === 0 || leadRadius === 0 || isPx(followRadius) === isPx(leadRadius); 17538 if (canMix) { 17539 target[borderLabel] = Math.max(mixNumber(asNumber(followRadius), asNumber(leadRadius), progress2), 0); 17540 if (percent.test(leadRadius) || percent.test(followRadius)) { 17541 target[borderLabel] += "%"; 17542 } 17543 } else { 17544 target[borderLabel] = leadRadius; 17545 } 17546 } 17547 if (follow.rotate || lead.rotate) { 17548 target.rotate = mixNumber(follow.rotate || 0, lead.rotate || 0, progress2); 17549 } 17550 } 17551 function getRadius(values, radiusName) { 17552 return values[radiusName] !== void 0 ? values[radiusName] : values.borderRadius; 17553 } 17554 var easeCrossfadeIn = /* @__PURE__ */ compress(0, 0.5, circOut); 17555 var easeCrossfadeOut = /* @__PURE__ */ compress(0.5, 0.95, noop2); 17556 function compress(min3, max3, easing) { 17557 return (p3) => { 17558 if (p3 < min3) 17559 return 0; 17560 if (p3 > max3) 17561 return 1; 17562 return easing(progress(min3, max3, p3)); 17563 }; 17564 } 17565 17566 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/copy.mjs 17567 function copyAxisInto(axis, originAxis) { 17568 axis.min = originAxis.min; 17569 axis.max = originAxis.max; 17570 } 17571 function copyBoxInto(box, originBox) { 17572 copyAxisInto(box.x, originBox.x); 17573 copyAxisInto(box.y, originBox.y); 17574 } 17575 function copyAxisDeltaInto(delta, originDelta) { 17576 delta.translate = originDelta.translate; 17577 delta.scale = originDelta.scale; 17578 delta.originPoint = originDelta.originPoint; 17579 delta.origin = originDelta.origin; 17580 } 17581 17582 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/delta-remove.mjs 17583 function removePointDelta(point, translate, scale2, originPoint, boxScale) { 17584 point -= translate; 17585 point = scalePoint(point, 1 / scale2, originPoint); 17586 if (boxScale !== void 0) { 17587 point = scalePoint(point, 1 / boxScale, originPoint); 17588 } 17589 return point; 17590 } 17591 function removeAxisDelta(axis, translate = 0, scale2 = 1, origin = 0.5, boxScale, originAxis = axis, sourceAxis = axis) { 17592 if (percent.test(translate)) { 17593 translate = parseFloat(translate); 17594 const relativeProgress = mixNumber(sourceAxis.min, sourceAxis.max, translate / 100); 17595 translate = relativeProgress - sourceAxis.min; 17596 } 17597 if (typeof translate !== "number") 17598 return; 17599 let originPoint = mixNumber(originAxis.min, originAxis.max, origin); 17600 if (axis === originAxis) 17601 originPoint -= translate; 17602 axis.min = removePointDelta(axis.min, translate, scale2, originPoint, boxScale); 17603 axis.max = removePointDelta(axis.max, translate, scale2, originPoint, boxScale); 17604 } 17605 function removeAxisTransforms(axis, transforms, [key, scaleKey, originKey], origin, sourceAxis) { 17606 removeAxisDelta(axis, transforms[key], transforms[scaleKey], transforms[originKey], transforms.scale, origin, sourceAxis); 17607 } 17608 var xKeys = ["x", "scaleX", "originX"]; 17609 var yKeys = ["y", "scaleY", "originY"]; 17610 function removeBoxTransforms(box, transforms, originBox, sourceBox) { 17611 removeAxisTransforms(box.x, transforms, xKeys, originBox ? originBox.x : void 0, sourceBox ? sourceBox.x : void 0); 17612 removeAxisTransforms(box.y, transforms, yKeys, originBox ? originBox.y : void 0, sourceBox ? sourceBox.y : void 0); 17613 } 17614 17615 // packages/components/node_modules/framer-motion/dist/es/projection/geometry/utils.mjs 17616 function isAxisDeltaZero(delta) { 17617 return delta.translate === 0 && delta.scale === 1; 17618 } 17619 function isDeltaZero(delta) { 17620 return isAxisDeltaZero(delta.x) && isAxisDeltaZero(delta.y); 17621 } 17622 function axisEquals(a3, b3) { 17623 return a3.min === b3.min && a3.max === b3.max; 17624 } 17625 function boxEquals(a3, b3) { 17626 return axisEquals(a3.x, b3.x) && axisEquals(a3.y, b3.y); 17627 } 17628 function axisEqualsRounded(a3, b3) { 17629 return Math.round(a3.min) === Math.round(b3.min) && Math.round(a3.max) === Math.round(b3.max); 17630 } 17631 function boxEqualsRounded(a3, b3) { 17632 return axisEqualsRounded(a3.x, b3.x) && axisEqualsRounded(a3.y, b3.y); 17633 } 17634 function aspectRatio(box) { 17635 return calcLength(box.x) / calcLength(box.y); 17636 } 17637 function axisDeltaEquals(a3, b3) { 17638 return a3.translate === b3.translate && a3.scale === b3.scale && a3.originPoint === b3.originPoint; 17639 } 17640 17641 // packages/components/node_modules/framer-motion/dist/es/projection/shared/stack.mjs 17642 var NodeStack = class { 17643 constructor() { 17644 this.members = []; 17645 } 17646 add(node2) { 17647 addUniqueItem(this.members, node2); 17648 node2.scheduleRender(); 17649 } 17650 remove(node2) { 17651 removeItem(this.members, node2); 17652 if (node2 === this.prevLead) { 17653 this.prevLead = void 0; 17654 } 17655 if (node2 === this.lead) { 17656 const prevLead = this.members[this.members.length - 1]; 17657 if (prevLead) { 17658 this.promote(prevLead); 17659 } 17660 } 17661 } 17662 relegate(node2) { 17663 const indexOfNode = this.members.findIndex((member) => node2 === member); 17664 if (indexOfNode === 0) 17665 return false; 17666 let prevLead; 17667 for (let i3 = indexOfNode; i3 >= 0; i3--) { 17668 const member = this.members[i3]; 17669 if (member.isPresent !== false) { 17670 prevLead = member; 17671 break; 17672 } 17673 } 17674 if (prevLead) { 17675 this.promote(prevLead); 17676 return true; 17677 } else { 17678 return false; 17679 } 17680 } 17681 promote(node2, preserveFollowOpacity) { 17682 const prevLead = this.lead; 17683 if (node2 === prevLead) 17684 return; 17685 this.prevLead = prevLead; 17686 this.lead = node2; 17687 node2.show(); 17688 if (prevLead) { 17689 prevLead.instance && prevLead.scheduleRender(); 17690 node2.scheduleRender(); 17691 node2.resumeFrom = prevLead; 17692 if (preserveFollowOpacity) { 17693 node2.resumeFrom.preserveOpacity = true; 17694 } 17695 if (prevLead.snapshot) { 17696 node2.snapshot = prevLead.snapshot; 17697 node2.snapshot.latestValues = prevLead.animationValues || prevLead.latestValues; 17698 } 17699 if (node2.root && node2.root.isUpdating) { 17700 node2.isLayoutDirty = true; 17701 } 17702 const { crossfade } = node2.options; 17703 if (crossfade === false) { 17704 prevLead.hide(); 17705 } 17706 } 17707 } 17708 exitAnimationComplete() { 17709 this.members.forEach((node2) => { 17710 const { options: options2, resumingFrom } = node2; 17711 options2.onExitComplete && options2.onExitComplete(); 17712 if (resumingFrom) { 17713 resumingFrom.options.onExitComplete && resumingFrom.options.onExitComplete(); 17714 } 17715 }); 17716 } 17717 scheduleRender() { 17718 this.members.forEach((node2) => { 17719 node2.instance && node2.scheduleRender(false); 17720 }); 17721 } 17722 /** 17723 * Clear any leads that have been removed this render to prevent them from being 17724 * used in future animations and to prevent memory leaks 17725 */ 17726 removeLeadSnapshot() { 17727 if (this.lead && this.lead.snapshot) { 17728 this.lead.snapshot = void 0; 17729 } 17730 } 17731 }; 17732 17733 // packages/components/node_modules/framer-motion/dist/es/projection/styles/transform.mjs 17734 function buildProjectionTransform(delta, treeScale, latestTransform) { 17735 let transform = ""; 17736 const xTranslate = delta.x.translate / treeScale.x; 17737 const yTranslate = delta.y.translate / treeScale.y; 17738 const zTranslate = (latestTransform === null || latestTransform === void 0 ? void 0 : latestTransform.z) || 0; 17739 if (xTranslate || yTranslate || zTranslate) { 17740 transform = `translate3d($xTranslate}px, $yTranslate}px, $zTranslate}px) `; 17741 } 17742 if (treeScale.x !== 1 || treeScale.y !== 1) { 17743 transform += `scale($1 / treeScale.x}, $1 / treeScale.y}) `; 17744 } 17745 if (latestTransform) { 17746 const { transformPerspective, rotate, rotateX, rotateY, skewX, skewY } = latestTransform; 17747 if (transformPerspective) 17748 transform = `perspective($transformPerspective}px) $transform}`; 17749 if (rotate) 17750 transform += `rotate($rotate}deg) `; 17751 if (rotateX) 17752 transform += `rotateX($rotateX}deg) `; 17753 if (rotateY) 17754 transform += `rotateY($rotateY}deg) `; 17755 if (skewX) 17756 transform += `skewX($skewX}deg) `; 17757 if (skewY) 17758 transform += `skewY($skewY}deg) `; 17759 } 17760 const elementScaleX = delta.x.scale * treeScale.x; 17761 const elementScaleY = delta.y.scale * treeScale.y; 17762 if (elementScaleX !== 1 || elementScaleY !== 1) { 17763 transform += `scale($elementScaleX}, $elementScaleY})`; 17764 } 17765 return transform || "none"; 17766 } 17767 17768 // packages/components/node_modules/framer-motion/dist/es/render/utils/compare-by-depth.mjs 17769 var compareByDepth = (a3, b3) => a3.depth - b3.depth; 17770 17771 // packages/components/node_modules/framer-motion/dist/es/render/utils/flat-tree.mjs 17772 var FlatTree = class { 17773 constructor() { 17774 this.children = []; 17775 this.isDirty = false; 17776 } 17777 add(child) { 17778 addUniqueItem(this.children, child); 17779 this.isDirty = true; 17780 } 17781 remove(child) { 17782 removeItem(this.children, child); 17783 this.isDirty = true; 17784 } 17785 forEach(callback) { 17786 this.isDirty && this.children.sort(compareByDepth); 17787 this.isDirty = false; 17788 this.children.forEach(callback); 17789 } 17790 }; 17791 17792 // packages/components/node_modules/framer-motion/dist/es/value/utils/resolve-motion-value.mjs 17793 function resolveMotionValue(value) { 17794 const unwrappedValue = isMotionValue(value) ? value.get() : value; 17795 return isCustomValue(unwrappedValue) ? unwrappedValue.toValue() : unwrappedValue; 17796 } 17797 17798 // packages/components/node_modules/framer-motion/dist/es/utils/delay.mjs 17799 function delay(callback, timeout) { 17800 const start = time.now(); 17801 const checkElapsed = ({ timestamp }) => { 17802 const elapsed = timestamp - start; 17803 if (elapsed >= timeout) { 17804 cancelFrame(checkElapsed); 17805 callback(elapsed - timeout); 17806 } 17807 }; 17808 frame.read(checkElapsed, true); 17809 return () => cancelFrame(checkElapsed); 17810 } 17811 17812 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/is-svg-element.mjs 17813 function isSVGElement(element) { 17814 return element instanceof SVGElement && element.tagName !== "svg"; 17815 } 17816 17817 // packages/components/node_modules/framer-motion/dist/es/animation/animate/single-value.mjs 17818 function animateSingleValue(value, keyframes5, options2) { 17819 const motionValue$1 = isMotionValue(value) ? value : motionValue(value); 17820 motionValue$1.start(animateMotionValue("", motionValue$1, keyframes5, options2)); 17821 return motionValue$1.animation; 17822 } 17823 17824 // packages/components/node_modules/framer-motion/dist/es/projection/node/create-projection-node.mjs 17825 var metrics = { 17826 type: "projectionFrame", 17827 totalNodes: 0, 17828 resolvedTargetDeltas: 0, 17829 recalculatedProjection: 0 17830 }; 17831 var isDebug = typeof window !== "undefined" && window.MotionDebug !== void 0; 17832 var transformAxes = ["", "X", "Y", "Z"]; 17833 var hiddenVisibility = { visibility: "hidden" }; 17834 var animationTarget = 1e3; 17835 var id2 = 0; 17836 function resetDistortingTransform(key, visualElement, values, sharedAnimationValues) { 17837 const { latestValues } = visualElement; 17838 if (latestValues[key]) { 17839 values[key] = latestValues[key]; 17840 visualElement.setStaticValue(key, 0); 17841 if (sharedAnimationValues) { 17842 sharedAnimationValues[key] = 0; 17843 } 17844 } 17845 } 17846 function cancelTreeOptimisedTransformAnimations(projectionNode) { 17847 projectionNode.hasCheckedOptimisedAppear = true; 17848 if (projectionNode.root === projectionNode) 17849 return; 17850 const { visualElement } = projectionNode.options; 17851 if (!visualElement) 17852 return; 17853 const appearId = getOptimisedAppearId(visualElement); 17854 if (window.MotionHasOptimisedAnimation(appearId, "transform")) { 17855 const { layout: layout2, layoutId } = projectionNode.options; 17856 window.MotionCancelOptimisedAnimation(appearId, "transform", frame, !(layout2 || layoutId)); 17857 } 17858 const { parent } = projectionNode; 17859 if (parent && !parent.hasCheckedOptimisedAppear) { 17860 cancelTreeOptimisedTransformAnimations(parent); 17861 } 17862 } 17863 function createProjectionNode({ attachResizeListener, defaultParent, measureScroll, checkIsScrollRoot, resetTransform }) { 17864 return class ProjectionNode { 17865 constructor(latestValues = {}, parent = defaultParent === null || defaultParent === void 0 ? void 0 : defaultParent()) { 17866 this.id = id2++; 17867 this.animationId = 0; 17868 this.children = /* @__PURE__ */ new Set(); 17869 this.options = {}; 17870 this.isTreeAnimating = false; 17871 this.isAnimationBlocked = false; 17872 this.isLayoutDirty = false; 17873 this.isProjectionDirty = false; 17874 this.isSharedProjectionDirty = false; 17875 this.isTransformDirty = false; 17876 this.updateManuallyBlocked = false; 17877 this.updateBlockedByResize = false; 17878 this.isUpdating = false; 17879 this.isSVG = false; 17880 this.needsReset = false; 17881 this.shouldResetTransform = false; 17882 this.hasCheckedOptimisedAppear = false; 17883 this.treeScale = { x: 1, y: 1 }; 17884 this.eventHandlers = /* @__PURE__ */ new Map(); 17885 this.hasTreeAnimated = false; 17886 this.updateScheduled = false; 17887 this.scheduleUpdate = () => this.update(); 17888 this.projectionUpdateScheduled = false; 17889 this.checkUpdateFailed = () => { 17890 if (this.isUpdating) { 17891 this.isUpdating = false; 17892 this.clearAllSnapshots(); 17893 } 17894 }; 17895 this.updateProjection = () => { 17896 this.projectionUpdateScheduled = false; 17897 if (isDebug) { 17898 metrics.totalNodes = metrics.resolvedTargetDeltas = metrics.recalculatedProjection = 0; 17899 } 17900 this.nodes.forEach(propagateDirtyNodes); 17901 this.nodes.forEach(resolveTargetDelta); 17902 this.nodes.forEach(calcProjection); 17903 this.nodes.forEach(cleanDirtyNodes); 17904 if (isDebug) { 17905 window.MotionDebug.record(metrics); 17906 } 17907 }; 17908 this.resolvedRelativeTargetAt = 0; 17909 this.hasProjected = false; 17910 this.isVisible = true; 17911 this.animationProgress = 0; 17912 this.sharedNodes = /* @__PURE__ */ new Map(); 17913 this.latestValues = latestValues; 17914 this.root = parent ? parent.root || parent : this; 17915 this.path = parent ? [...parent.path, parent] : []; 17916 this.parent = parent; 17917 this.depth = parent ? parent.depth + 1 : 0; 17918 for (let i3 = 0; i3 < this.path.length; i3++) { 17919 this.path[i3].shouldResetTransform = true; 17920 } 17921 if (this.root === this) 17922 this.nodes = new FlatTree(); 17923 } 17924 addEventListener(name, handler) { 17925 if (!this.eventHandlers.has(name)) { 17926 this.eventHandlers.set(name, new SubscriptionManager()); 17927 } 17928 return this.eventHandlers.get(name).add(handler); 17929 } 17930 notifyListeners(name, ...args) { 17931 const subscriptionManager = this.eventHandlers.get(name); 17932 subscriptionManager && subscriptionManager.notify(...args); 17933 } 17934 hasListeners(name) { 17935 return this.eventHandlers.has(name); 17936 } 17937 /** 17938 * Lifecycles 17939 */ 17940 mount(instance, isLayoutDirty = this.root.hasTreeAnimated) { 17941 if (this.instance) 17942 return; 17943 this.isSVG = isSVGElement(instance); 17944 this.instance = instance; 17945 const { layoutId, layout: layout2, visualElement } = this.options; 17946 if (visualElement && !visualElement.current) { 17947 visualElement.mount(instance); 17948 } 17949 this.root.nodes.add(this); 17950 this.parent && this.parent.children.add(this); 17951 if (isLayoutDirty && (layout2 || layoutId)) { 17952 this.isLayoutDirty = true; 17953 } 17954 if (attachResizeListener) { 17955 let cancelDelay; 17956 const resizeUnblockUpdate = () => this.root.updateBlockedByResize = false; 17957 attachResizeListener(instance, () => { 17958 this.root.updateBlockedByResize = true; 17959 cancelDelay && cancelDelay(); 17960 cancelDelay = delay(resizeUnblockUpdate, 250); 17961 if (globalProjectionState.hasAnimatedSinceResize) { 17962 globalProjectionState.hasAnimatedSinceResize = false; 17963 this.nodes.forEach(finishAnimation); 17964 } 17965 }); 17966 } 17967 if (layoutId) { 17968 this.root.registerSharedNode(layoutId, this); 17969 } 17970 if (this.options.animate !== false && visualElement && (layoutId || layout2)) { 17971 this.addEventListener("didUpdate", ({ delta, hasLayoutChanged, hasRelativeTargetChanged, layout: newLayout }) => { 17972 if (this.isTreeAnimationBlocked()) { 17973 this.target = void 0; 17974 this.relativeTarget = void 0; 17975 return; 17976 } 17977 const layoutTransition = this.options.transition || visualElement.getDefaultTransition() || defaultLayoutTransition; 17978 const { onLayoutAnimationStart, onLayoutAnimationComplete } = visualElement.getProps(); 17979 const targetChanged = !this.targetLayout || !boxEqualsRounded(this.targetLayout, newLayout) || hasRelativeTargetChanged; 17980 const hasOnlyRelativeTargetChanged = !hasLayoutChanged && hasRelativeTargetChanged; 17981 if (this.options.layoutRoot || this.resumeFrom && this.resumeFrom.instance || hasOnlyRelativeTargetChanged || hasLayoutChanged && (targetChanged || !this.currentAnimation)) { 17982 if (this.resumeFrom) { 17983 this.resumingFrom = this.resumeFrom; 17984 this.resumingFrom.resumingFrom = void 0; 17985 } 17986 this.setAnimationOrigin(delta, hasOnlyRelativeTargetChanged); 17987 const animationOptions = { 17988 ...getValueTransition(layoutTransition, "layout"), 17989 onPlay: onLayoutAnimationStart, 17990 onComplete: onLayoutAnimationComplete 17991 }; 17992 if (visualElement.shouldReduceMotion || this.options.layoutRoot) { 17993 animationOptions.delay = 0; 17994 animationOptions.type = false; 17995 } 17996 this.startAnimation(animationOptions); 17997 } else { 17998 if (!hasLayoutChanged) { 17999 finishAnimation(this); 18000 } 18001 if (this.isLead() && this.options.onExitComplete) { 18002 this.options.onExitComplete(); 18003 } 18004 } 18005 this.targetLayout = newLayout; 18006 }); 18007 } 18008 } 18009 unmount() { 18010 this.options.layoutId && this.willUpdate(); 18011 this.root.nodes.remove(this); 18012 const stack = this.getStack(); 18013 stack && stack.remove(this); 18014 this.parent && this.parent.children.delete(this); 18015 this.instance = void 0; 18016 cancelFrame(this.updateProjection); 18017 } 18018 // only on the root 18019 blockUpdate() { 18020 this.updateManuallyBlocked = true; 18021 } 18022 unblockUpdate() { 18023 this.updateManuallyBlocked = false; 18024 } 18025 isUpdateBlocked() { 18026 return this.updateManuallyBlocked || this.updateBlockedByResize; 18027 } 18028 isTreeAnimationBlocked() { 18029 return this.isAnimationBlocked || this.parent && this.parent.isTreeAnimationBlocked() || false; 18030 } 18031 // Note: currently only running on root node 18032 startUpdate() { 18033 if (this.isUpdateBlocked()) 18034 return; 18035 this.isUpdating = true; 18036 this.nodes && this.nodes.forEach(resetSkewAndRotation); 18037 this.animationId++; 18038 } 18039 getTransformTemplate() { 18040 const { visualElement } = this.options; 18041 return visualElement && visualElement.getProps().transformTemplate; 18042 } 18043 willUpdate(shouldNotifyListeners = true) { 18044 this.root.hasTreeAnimated = true; 18045 if (this.root.isUpdateBlocked()) { 18046 this.options.onExitComplete && this.options.onExitComplete(); 18047 return; 18048 } 18049 if (window.MotionCancelOptimisedAnimation && !this.hasCheckedOptimisedAppear) { 18050 cancelTreeOptimisedTransformAnimations(this); 18051 } 18052 !this.root.isUpdating && this.root.startUpdate(); 18053 if (this.isLayoutDirty) 18054 return; 18055 this.isLayoutDirty = true; 18056 for (let i3 = 0; i3 < this.path.length; i3++) { 18057 const node2 = this.path[i3]; 18058 node2.shouldResetTransform = true; 18059 node2.updateScroll("snapshot"); 18060 if (node2.options.layoutRoot) { 18061 node2.willUpdate(false); 18062 } 18063 } 18064 const { layoutId, layout: layout2 } = this.options; 18065 if (layoutId === void 0 && !layout2) 18066 return; 18067 const transformTemplate = this.getTransformTemplate(); 18068 this.prevTransformTemplateValue = transformTemplate ? transformTemplate(this.latestValues, "") : void 0; 18069 this.updateSnapshot(); 18070 shouldNotifyListeners && this.notifyListeners("willUpdate"); 18071 } 18072 update() { 18073 this.updateScheduled = false; 18074 const updateWasBlocked = this.isUpdateBlocked(); 18075 if (updateWasBlocked) { 18076 this.unblockUpdate(); 18077 this.clearAllSnapshots(); 18078 this.nodes.forEach(clearMeasurements); 18079 return; 18080 } 18081 if (!this.isUpdating) { 18082 this.nodes.forEach(clearIsLayoutDirty); 18083 } 18084 this.isUpdating = false; 18085 this.nodes.forEach(resetTransformStyle); 18086 this.nodes.forEach(updateLayout); 18087 this.nodes.forEach(notifyLayoutUpdate); 18088 this.clearAllSnapshots(); 18089 const now2 = time.now(); 18090 frameData.delta = clamp2(0, 1e3 / 60, now2 - frameData.timestamp); 18091 frameData.timestamp = now2; 18092 frameData.isProcessing = true; 18093 frameSteps.update.process(frameData); 18094 frameSteps.preRender.process(frameData); 18095 frameSteps.render.process(frameData); 18096 frameData.isProcessing = false; 18097 } 18098 didUpdate() { 18099 if (!this.updateScheduled) { 18100 this.updateScheduled = true; 18101 microtask.read(this.scheduleUpdate); 18102 } 18103 } 18104 clearAllSnapshots() { 18105 this.nodes.forEach(clearSnapshot); 18106 this.sharedNodes.forEach(removeLeadSnapshots); 18107 } 18108 scheduleUpdateProjection() { 18109 if (!this.projectionUpdateScheduled) { 18110 this.projectionUpdateScheduled = true; 18111 frame.preRender(this.updateProjection, false, true); 18112 } 18113 } 18114 scheduleCheckAfterUnmount() { 18115 frame.postRender(() => { 18116 if (this.isLayoutDirty) { 18117 this.root.didUpdate(); 18118 } else { 18119 this.root.checkUpdateFailed(); 18120 } 18121 }); 18122 } 18123 /** 18124 * Update measurements 18125 */ 18126 updateSnapshot() { 18127 if (this.snapshot || !this.instance) 18128 return; 18129 this.snapshot = this.measure(); 18130 } 18131 updateLayout() { 18132 if (!this.instance) 18133 return; 18134 this.updateScroll(); 18135 if (!(this.options.alwaysMeasureLayout && this.isLead()) && !this.isLayoutDirty) { 18136 return; 18137 } 18138 if (this.resumeFrom && !this.resumeFrom.instance) { 18139 for (let i3 = 0; i3 < this.path.length; i3++) { 18140 const node2 = this.path[i3]; 18141 node2.updateScroll(); 18142 } 18143 } 18144 const prevLayout = this.layout; 18145 this.layout = this.measure(false); 18146 this.layoutCorrected = createBox(); 18147 this.isLayoutDirty = false; 18148 this.projectionDelta = void 0; 18149 this.notifyListeners("measure", this.layout.layoutBox); 18150 const { visualElement } = this.options; 18151 visualElement && visualElement.notify("LayoutMeasure", this.layout.layoutBox, prevLayout ? prevLayout.layoutBox : void 0); 18152 } 18153 updateScroll(phase = "measure") { 18154 let needsMeasurement = Boolean(this.options.layoutScroll && this.instance); 18155 if (this.scroll && this.scroll.animationId === this.root.animationId && this.scroll.phase === phase) { 18156 needsMeasurement = false; 18157 } 18158 if (needsMeasurement) { 18159 const isRoot = checkIsScrollRoot(this.instance); 18160 this.scroll = { 18161 animationId: this.root.animationId, 18162 phase, 18163 isRoot, 18164 offset: measureScroll(this.instance), 18165 wasRoot: this.scroll ? this.scroll.isRoot : isRoot 18166 }; 18167 } 18168 } 18169 resetTransform() { 18170 if (!resetTransform) 18171 return; 18172 const isResetRequested = this.isLayoutDirty || this.shouldResetTransform || this.options.alwaysMeasureLayout; 18173 const hasProjection = this.projectionDelta && !isDeltaZero(this.projectionDelta); 18174 const transformTemplate = this.getTransformTemplate(); 18175 const transformTemplateValue = transformTemplate ? transformTemplate(this.latestValues, "") : void 0; 18176 const transformTemplateHasChanged = transformTemplateValue !== this.prevTransformTemplateValue; 18177 if (isResetRequested && (hasProjection || hasTransform(this.latestValues) || transformTemplateHasChanged)) { 18178 resetTransform(this.instance, transformTemplateValue); 18179 this.shouldResetTransform = false; 18180 this.scheduleRender(); 18181 } 18182 } 18183 measure(removeTransform = true) { 18184 const pageBox = this.measurePageBox(); 18185 let layoutBox = this.removeElementScroll(pageBox); 18186 if (removeTransform) { 18187 layoutBox = this.removeTransform(layoutBox); 18188 } 18189 roundBox(layoutBox); 18190 return { 18191 animationId: this.root.animationId, 18192 measuredBox: pageBox, 18193 layoutBox, 18194 latestValues: {}, 18195 source: this.id 18196 }; 18197 } 18198 measurePageBox() { 18199 var _a; 18200 const { visualElement } = this.options; 18201 if (!visualElement) 18202 return createBox(); 18203 const box = visualElement.measureViewportBox(); 18204 const wasInScrollRoot = ((_a = this.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot) || this.path.some(checkNodeWasScrollRoot); 18205 if (!wasInScrollRoot) { 18206 const { scroll } = this.root; 18207 if (scroll) { 18208 translateAxis(box.x, scroll.offset.x); 18209 translateAxis(box.y, scroll.offset.y); 18210 } 18211 } 18212 return box; 18213 } 18214 removeElementScroll(box) { 18215 var _a; 18216 const boxWithoutScroll = createBox(); 18217 copyBoxInto(boxWithoutScroll, box); 18218 if ((_a = this.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot) { 18219 return boxWithoutScroll; 18220 } 18221 for (let i3 = 0; i3 < this.path.length; i3++) { 18222 const node2 = this.path[i3]; 18223 const { scroll, options: options2 } = node2; 18224 if (node2 !== this.root && scroll && options2.layoutScroll) { 18225 if (scroll.wasRoot) { 18226 copyBoxInto(boxWithoutScroll, box); 18227 } 18228 translateAxis(boxWithoutScroll.x, scroll.offset.x); 18229 translateAxis(boxWithoutScroll.y, scroll.offset.y); 18230 } 18231 } 18232 return boxWithoutScroll; 18233 } 18234 applyTransform(box, transformOnly = false) { 18235 const withTransforms = createBox(); 18236 copyBoxInto(withTransforms, box); 18237 for (let i3 = 0; i3 < this.path.length; i3++) { 18238 const node2 = this.path[i3]; 18239 if (!transformOnly && node2.options.layoutScroll && node2.scroll && node2 !== node2.root) { 18240 transformBox(withTransforms, { 18241 x: -node2.scroll.offset.x, 18242 y: -node2.scroll.offset.y 18243 }); 18244 } 18245 if (!hasTransform(node2.latestValues)) 18246 continue; 18247 transformBox(withTransforms, node2.latestValues); 18248 } 18249 if (hasTransform(this.latestValues)) { 18250 transformBox(withTransforms, this.latestValues); 18251 } 18252 return withTransforms; 18253 } 18254 removeTransform(box) { 18255 const boxWithoutTransform = createBox(); 18256 copyBoxInto(boxWithoutTransform, box); 18257 for (let i3 = 0; i3 < this.path.length; i3++) { 18258 const node2 = this.path[i3]; 18259 if (!node2.instance) 18260 continue; 18261 if (!hasTransform(node2.latestValues)) 18262 continue; 18263 hasScale(node2.latestValues) && node2.updateSnapshot(); 18264 const sourceBox = createBox(); 18265 const nodeBox = node2.measurePageBox(); 18266 copyBoxInto(sourceBox, nodeBox); 18267 removeBoxTransforms(boxWithoutTransform, node2.latestValues, node2.snapshot ? node2.snapshot.layoutBox : void 0, sourceBox); 18268 } 18269 if (hasTransform(this.latestValues)) { 18270 removeBoxTransforms(boxWithoutTransform, this.latestValues); 18271 } 18272 return boxWithoutTransform; 18273 } 18274 setTargetDelta(delta) { 18275 this.targetDelta = delta; 18276 this.root.scheduleUpdateProjection(); 18277 this.isProjectionDirty = true; 18278 } 18279 setOptions(options2) { 18280 this.options = { 18281 ...this.options, 18282 ...options2, 18283 crossfade: options2.crossfade !== void 0 ? options2.crossfade : true 18284 }; 18285 } 18286 clearMeasurements() { 18287 this.scroll = void 0; 18288 this.layout = void 0; 18289 this.snapshot = void 0; 18290 this.prevTransformTemplateValue = void 0; 18291 this.targetDelta = void 0; 18292 this.target = void 0; 18293 this.isLayoutDirty = false; 18294 } 18295 forceRelativeParentToResolveTarget() { 18296 if (!this.relativeParent) 18297 return; 18298 if (this.relativeParent.resolvedRelativeTargetAt !== frameData.timestamp) { 18299 this.relativeParent.resolveTargetDelta(true); 18300 } 18301 } 18302 resolveTargetDelta(forceRecalculation = false) { 18303 var _a; 18304 const lead = this.getLead(); 18305 this.isProjectionDirty || (this.isProjectionDirty = lead.isProjectionDirty); 18306 this.isTransformDirty || (this.isTransformDirty = lead.isTransformDirty); 18307 this.isSharedProjectionDirty || (this.isSharedProjectionDirty = lead.isSharedProjectionDirty); 18308 const isShared = Boolean(this.resumingFrom) || this !== lead; 18309 const canSkip = !(forceRecalculation || isShared && this.isSharedProjectionDirty || this.isProjectionDirty || ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isProjectionDirty) || this.attemptToResolveRelativeTarget || this.root.updateBlockedByResize); 18310 if (canSkip) 18311 return; 18312 const { layout: layout2, layoutId } = this.options; 18313 if (!this.layout || !(layout2 || layoutId)) 18314 return; 18315 this.resolvedRelativeTargetAt = frameData.timestamp; 18316 if (!this.targetDelta && !this.relativeTarget) { 18317 const relativeParent = this.getClosestProjectingParent(); 18318 if (relativeParent && relativeParent.layout && this.animationProgress !== 1) { 18319 this.relativeParent = relativeParent; 18320 this.forceRelativeParentToResolveTarget(); 18321 this.relativeTarget = createBox(); 18322 this.relativeTargetOrigin = createBox(); 18323 calcRelativePosition(this.relativeTargetOrigin, this.layout.layoutBox, relativeParent.layout.layoutBox); 18324 copyBoxInto(this.relativeTarget, this.relativeTargetOrigin); 18325 } else { 18326 this.relativeParent = this.relativeTarget = void 0; 18327 } 18328 } 18329 if (!this.relativeTarget && !this.targetDelta) 18330 return; 18331 if (!this.target) { 18332 this.target = createBox(); 18333 this.targetWithTransforms = createBox(); 18334 } 18335 if (this.relativeTarget && this.relativeTargetOrigin && this.relativeParent && this.relativeParent.target) { 18336 this.forceRelativeParentToResolveTarget(); 18337 calcRelativeBox(this.target, this.relativeTarget, this.relativeParent.target); 18338 } else if (this.targetDelta) { 18339 if (Boolean(this.resumingFrom)) { 18340 this.target = this.applyTransform(this.layout.layoutBox); 18341 } else { 18342 copyBoxInto(this.target, this.layout.layoutBox); 18343 } 18344 applyBoxDelta(this.target, this.targetDelta); 18345 } else { 18346 copyBoxInto(this.target, this.layout.layoutBox); 18347 } 18348 if (this.attemptToResolveRelativeTarget) { 18349 this.attemptToResolveRelativeTarget = false; 18350 const relativeParent = this.getClosestProjectingParent(); 18351 if (relativeParent && Boolean(relativeParent.resumingFrom) === Boolean(this.resumingFrom) && !relativeParent.options.layoutScroll && relativeParent.target && this.animationProgress !== 1) { 18352 this.relativeParent = relativeParent; 18353 this.forceRelativeParentToResolveTarget(); 18354 this.relativeTarget = createBox(); 18355 this.relativeTargetOrigin = createBox(); 18356 calcRelativePosition(this.relativeTargetOrigin, this.target, relativeParent.target); 18357 copyBoxInto(this.relativeTarget, this.relativeTargetOrigin); 18358 } else { 18359 this.relativeParent = this.relativeTarget = void 0; 18360 } 18361 } 18362 if (isDebug) { 18363 metrics.resolvedTargetDeltas++; 18364 } 18365 } 18366 getClosestProjectingParent() { 18367 if (!this.parent || hasScale(this.parent.latestValues) || has2DTranslate(this.parent.latestValues)) { 18368 return void 0; 18369 } 18370 if (this.parent.isProjecting()) { 18371 return this.parent; 18372 } else { 18373 return this.parent.getClosestProjectingParent(); 18374 } 18375 } 18376 isProjecting() { 18377 return Boolean((this.relativeTarget || this.targetDelta || this.options.layoutRoot) && this.layout); 18378 } 18379 calcProjection() { 18380 var _a; 18381 const lead = this.getLead(); 18382 const isShared = Boolean(this.resumingFrom) || this !== lead; 18383 let canSkip = true; 18384 if (this.isProjectionDirty || ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isProjectionDirty)) { 18385 canSkip = false; 18386 } 18387 if (isShared && (this.isSharedProjectionDirty || this.isTransformDirty)) { 18388 canSkip = false; 18389 } 18390 if (this.resolvedRelativeTargetAt === frameData.timestamp) { 18391 canSkip = false; 18392 } 18393 if (canSkip) 18394 return; 18395 const { layout: layout2, layoutId } = this.options; 18396 this.isTreeAnimating = Boolean(this.parent && this.parent.isTreeAnimating || this.currentAnimation || this.pendingAnimation); 18397 if (!this.isTreeAnimating) { 18398 this.targetDelta = this.relativeTarget = void 0; 18399 } 18400 if (!this.layout || !(layout2 || layoutId)) 18401 return; 18402 copyBoxInto(this.layoutCorrected, this.layout.layoutBox); 18403 const prevTreeScaleX = this.treeScale.x; 18404 const prevTreeScaleY = this.treeScale.y; 18405 applyTreeDeltas(this.layoutCorrected, this.treeScale, this.path, isShared); 18406 if (lead.layout && !lead.target && (this.treeScale.x !== 1 || this.treeScale.y !== 1)) { 18407 lead.target = lead.layout.layoutBox; 18408 lead.targetWithTransforms = createBox(); 18409 } 18410 const { target } = lead; 18411 if (!target) { 18412 if (this.prevProjectionDelta) { 18413 this.createProjectionDeltas(); 18414 this.scheduleRender(); 18415 } 18416 return; 18417 } 18418 if (!this.projectionDelta || !this.prevProjectionDelta) { 18419 this.createProjectionDeltas(); 18420 } else { 18421 copyAxisDeltaInto(this.prevProjectionDelta.x, this.projectionDelta.x); 18422 copyAxisDeltaInto(this.prevProjectionDelta.y, this.projectionDelta.y); 18423 } 18424 calcBoxDelta(this.projectionDelta, this.layoutCorrected, target, this.latestValues); 18425 if (this.treeScale.x !== prevTreeScaleX || this.treeScale.y !== prevTreeScaleY || !axisDeltaEquals(this.projectionDelta.x, this.prevProjectionDelta.x) || !axisDeltaEquals(this.projectionDelta.y, this.prevProjectionDelta.y)) { 18426 this.hasProjected = true; 18427 this.scheduleRender(); 18428 this.notifyListeners("projectionUpdate", target); 18429 } 18430 if (isDebug) { 18431 metrics.recalculatedProjection++; 18432 } 18433 } 18434 hide() { 18435 this.isVisible = false; 18436 } 18437 show() { 18438 this.isVisible = true; 18439 } 18440 scheduleRender(notifyAll = true) { 18441 var _a; 18442 (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.scheduleRender(); 18443 if (notifyAll) { 18444 const stack = this.getStack(); 18445 stack && stack.scheduleRender(); 18446 } 18447 if (this.resumingFrom && !this.resumingFrom.instance) { 18448 this.resumingFrom = void 0; 18449 } 18450 } 18451 createProjectionDeltas() { 18452 this.prevProjectionDelta = createDelta(); 18453 this.projectionDelta = createDelta(); 18454 this.projectionDeltaWithTransform = createDelta(); 18455 } 18456 setAnimationOrigin(delta, hasOnlyRelativeTargetChanged = false) { 18457 const snapshot = this.snapshot; 18458 const snapshotLatestValues = snapshot ? snapshot.latestValues : {}; 18459 const mixedValues = { ...this.latestValues }; 18460 const targetDelta = createDelta(); 18461 if (!this.relativeParent || !this.relativeParent.options.layoutRoot) { 18462 this.relativeTarget = this.relativeTargetOrigin = void 0; 18463 } 18464 this.attemptToResolveRelativeTarget = !hasOnlyRelativeTargetChanged; 18465 const relativeLayout = createBox(); 18466 const snapshotSource = snapshot ? snapshot.source : void 0; 18467 const layoutSource = this.layout ? this.layout.source : void 0; 18468 const isSharedLayoutAnimation = snapshotSource !== layoutSource; 18469 const stack = this.getStack(); 18470 const isOnlyMember = !stack || stack.members.length <= 1; 18471 const shouldCrossfadeOpacity = Boolean(isSharedLayoutAnimation && !isOnlyMember && this.options.crossfade === true && !this.path.some(hasOpacityCrossfade)); 18472 this.animationProgress = 0; 18473 let prevRelativeTarget; 18474 this.mixTargetDelta = (latest) => { 18475 const progress2 = latest / 1e3; 18476 mixAxisDelta(targetDelta.x, delta.x, progress2); 18477 mixAxisDelta(targetDelta.y, delta.y, progress2); 18478 this.setTargetDelta(targetDelta); 18479 if (this.relativeTarget && this.relativeTargetOrigin && this.layout && this.relativeParent && this.relativeParent.layout) { 18480 calcRelativePosition(relativeLayout, this.layout.layoutBox, this.relativeParent.layout.layoutBox); 18481 mixBox(this.relativeTarget, this.relativeTargetOrigin, relativeLayout, progress2); 18482 if (prevRelativeTarget && boxEquals(this.relativeTarget, prevRelativeTarget)) { 18483 this.isProjectionDirty = false; 18484 } 18485 if (!prevRelativeTarget) 18486 prevRelativeTarget = createBox(); 18487 copyBoxInto(prevRelativeTarget, this.relativeTarget); 18488 } 18489 if (isSharedLayoutAnimation) { 18490 this.animationValues = mixedValues; 18491 mixValues(mixedValues, snapshotLatestValues, this.latestValues, progress2, shouldCrossfadeOpacity, isOnlyMember); 18492 } 18493 this.root.scheduleUpdateProjection(); 18494 this.scheduleRender(); 18495 this.animationProgress = progress2; 18496 }; 18497 this.mixTargetDelta(this.options.layoutRoot ? 1e3 : 0); 18498 } 18499 startAnimation(options2) { 18500 this.notifyListeners("animationStart"); 18501 this.currentAnimation && this.currentAnimation.stop(); 18502 if (this.resumingFrom && this.resumingFrom.currentAnimation) { 18503 this.resumingFrom.currentAnimation.stop(); 18504 } 18505 if (this.pendingAnimation) { 18506 cancelFrame(this.pendingAnimation); 18507 this.pendingAnimation = void 0; 18508 } 18509 this.pendingAnimation = frame.update(() => { 18510 globalProjectionState.hasAnimatedSinceResize = true; 18511 this.currentAnimation = animateSingleValue(0, animationTarget, { 18512 ...options2, 18513 onUpdate: (latest) => { 18514 this.mixTargetDelta(latest); 18515 options2.onUpdate && options2.onUpdate(latest); 18516 }, 18517 onComplete: () => { 18518 options2.onComplete && options2.onComplete(); 18519 this.completeAnimation(); 18520 } 18521 }); 18522 if (this.resumingFrom) { 18523 this.resumingFrom.currentAnimation = this.currentAnimation; 18524 } 18525 this.pendingAnimation = void 0; 18526 }); 18527 } 18528 completeAnimation() { 18529 if (this.resumingFrom) { 18530 this.resumingFrom.currentAnimation = void 0; 18531 this.resumingFrom.preserveOpacity = void 0; 18532 } 18533 const stack = this.getStack(); 18534 stack && stack.exitAnimationComplete(); 18535 this.resumingFrom = this.currentAnimation = this.animationValues = void 0; 18536 this.notifyListeners("animationComplete"); 18537 } 18538 finishAnimation() { 18539 if (this.currentAnimation) { 18540 this.mixTargetDelta && this.mixTargetDelta(animationTarget); 18541 this.currentAnimation.stop(); 18542 } 18543 this.completeAnimation(); 18544 } 18545 applyTransformsToTarget() { 18546 const lead = this.getLead(); 18547 let { targetWithTransforms, target, layout: layout2, latestValues } = lead; 18548 if (!targetWithTransforms || !target || !layout2) 18549 return; 18550 if (this !== lead && this.layout && layout2 && shouldAnimatePositionOnly(this.options.animationType, this.layout.layoutBox, layout2.layoutBox)) { 18551 target = this.target || createBox(); 18552 const xLength = calcLength(this.layout.layoutBox.x); 18553 target.x.min = lead.target.x.min; 18554 target.x.max = target.x.min + xLength; 18555 const yLength = calcLength(this.layout.layoutBox.y); 18556 target.y.min = lead.target.y.min; 18557 target.y.max = target.y.min + yLength; 18558 } 18559 copyBoxInto(targetWithTransforms, target); 18560 transformBox(targetWithTransforms, latestValues); 18561 calcBoxDelta(this.projectionDeltaWithTransform, this.layoutCorrected, targetWithTransforms, latestValues); 18562 } 18563 registerSharedNode(layoutId, node2) { 18564 if (!this.sharedNodes.has(layoutId)) { 18565 this.sharedNodes.set(layoutId, new NodeStack()); 18566 } 18567 const stack = this.sharedNodes.get(layoutId); 18568 stack.add(node2); 18569 const config = node2.options.initialPromotionConfig; 18570 node2.promote({ 18571 transition: config ? config.transition : void 0, 18572 preserveFollowOpacity: config && config.shouldPreserveFollowOpacity ? config.shouldPreserveFollowOpacity(node2) : void 0 18573 }); 18574 } 18575 isLead() { 18576 const stack = this.getStack(); 18577 return stack ? stack.lead === this : true; 18578 } 18579 getLead() { 18580 var _a; 18581 const { layoutId } = this.options; 18582 return layoutId ? ((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.lead) || this : this; 18583 } 18584 getPrevLead() { 18585 var _a; 18586 const { layoutId } = this.options; 18587 return layoutId ? (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.prevLead : void 0; 18588 } 18589 getStack() { 18590 const { layoutId } = this.options; 18591 if (layoutId) 18592 return this.root.sharedNodes.get(layoutId); 18593 } 18594 promote({ needsReset, transition, preserveFollowOpacity } = {}) { 18595 const stack = this.getStack(); 18596 if (stack) 18597 stack.promote(this, preserveFollowOpacity); 18598 if (needsReset) { 18599 this.projectionDelta = void 0; 18600 this.needsReset = true; 18601 } 18602 if (transition) 18603 this.setOptions({ transition }); 18604 } 18605 relegate() { 18606 const stack = this.getStack(); 18607 if (stack) { 18608 return stack.relegate(this); 18609 } else { 18610 return false; 18611 } 18612 } 18613 resetSkewAndRotation() { 18614 const { visualElement } = this.options; 18615 if (!visualElement) 18616 return; 18617 let hasDistortingTransform = false; 18618 const { latestValues } = visualElement; 18619 if (latestValues.z || latestValues.rotate || latestValues.rotateX || latestValues.rotateY || latestValues.rotateZ || latestValues.skewX || latestValues.skewY) { 18620 hasDistortingTransform = true; 18621 } 18622 if (!hasDistortingTransform) 18623 return; 18624 const resetValues = {}; 18625 if (latestValues.z) { 18626 resetDistortingTransform("z", visualElement, resetValues, this.animationValues); 18627 } 18628 for (let i3 = 0; i3 < transformAxes.length; i3++) { 18629 resetDistortingTransform(`rotate$transformAxes[i3]}`, visualElement, resetValues, this.animationValues); 18630 resetDistortingTransform(`skew$transformAxes[i3]}`, visualElement, resetValues, this.animationValues); 18631 } 18632 visualElement.render(); 18633 for (const key in resetValues) { 18634 visualElement.setStaticValue(key, resetValues[key]); 18635 if (this.animationValues) { 18636 this.animationValues[key] = resetValues[key]; 18637 } 18638 } 18639 visualElement.scheduleRender(); 18640 } 18641 getProjectionStyles(styleProp) { 18642 var _a, _b; 18643 if (!this.instance || this.isSVG) 18644 return void 0; 18645 if (!this.isVisible) { 18646 return hiddenVisibility; 18647 } 18648 const styles3 = { 18649 visibility: "" 18650 }; 18651 const transformTemplate = this.getTransformTemplate(); 18652 if (this.needsReset) { 18653 this.needsReset = false; 18654 styles3.opacity = ""; 18655 styles3.pointerEvents = resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || ""; 18656 styles3.transform = transformTemplate ? transformTemplate(this.latestValues, "") : "none"; 18657 return styles3; 18658 } 18659 const lead = this.getLead(); 18660 if (!this.projectionDelta || !this.layout || !lead.target) { 18661 const emptyStyles = {}; 18662 if (this.options.layoutId) { 18663 emptyStyles.opacity = this.latestValues.opacity !== void 0 ? this.latestValues.opacity : 1; 18664 emptyStyles.pointerEvents = resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || ""; 18665 } 18666 if (this.hasProjected && !hasTransform(this.latestValues)) { 18667 emptyStyles.transform = transformTemplate ? transformTemplate({}, "") : "none"; 18668 this.hasProjected = false; 18669 } 18670 return emptyStyles; 18671 } 18672 const valuesToRender = lead.animationValues || lead.latestValues; 18673 this.applyTransformsToTarget(); 18674 styles3.transform = buildProjectionTransform(this.projectionDeltaWithTransform, this.treeScale, valuesToRender); 18675 if (transformTemplate) { 18676 styles3.transform = transformTemplate(valuesToRender, styles3.transform); 18677 } 18678 const { x: x2, y: y3 } = this.projectionDelta; 18679 styles3.transformOrigin = `$x2.origin * 100}% $y3.origin * 100}% 0`; 18680 if (lead.animationValues) { 18681 styles3.opacity = lead === this ? (_b = (_a = valuesToRender.opacity) !== null && _a !== void 0 ? _a : this.latestValues.opacity) !== null && _b !== void 0 ? _b : 1 : this.preserveOpacity ? this.latestValues.opacity : valuesToRender.opacityExit; 18682 } else { 18683 styles3.opacity = lead === this ? valuesToRender.opacity !== void 0 ? valuesToRender.opacity : "" : valuesToRender.opacityExit !== void 0 ? valuesToRender.opacityExit : 0; 18684 } 18685 for (const key in scaleCorrectors) { 18686 if (valuesToRender[key] === void 0) 18687 continue; 18688 const { correct, applyTo } = scaleCorrectors[key]; 18689 const corrected = styles3.transform === "none" ? valuesToRender[key] : correct(valuesToRender[key], lead); 18690 if (applyTo) { 18691 const num = applyTo.length; 18692 for (let i3 = 0; i3 < num; i3++) { 18693 styles3[applyTo[i3]] = corrected; 18694 } 18695 } else { 18696 styles3[key] = corrected; 18697 } 18698 } 18699 if (this.options.layoutId) { 18700 styles3.pointerEvents = lead === this ? resolveMotionValue(styleProp === null || styleProp === void 0 ? void 0 : styleProp.pointerEvents) || "" : "none"; 18701 } 18702 return styles3; 18703 } 18704 clearSnapshot() { 18705 this.resumeFrom = this.snapshot = void 0; 18706 } 18707 // Only run on root 18708 resetTree() { 18709 this.root.nodes.forEach((node2) => { 18710 var _a; 18711 return (_a = node2.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop(); 18712 }); 18713 this.root.nodes.forEach(clearMeasurements); 18714 this.root.sharedNodes.clear(); 18715 } 18716 }; 18717 } 18718 function updateLayout(node2) { 18719 node2.updateLayout(); 18720 } 18721 function notifyLayoutUpdate(node2) { 18722 var _a; 18723 const snapshot = ((_a = node2.resumeFrom) === null || _a === void 0 ? void 0 : _a.snapshot) || node2.snapshot; 18724 if (node2.isLead() && node2.layout && snapshot && node2.hasListeners("didUpdate")) { 18725 const { layoutBox: layout2, measuredBox: measuredLayout } = node2.layout; 18726 const { animationType } = node2.options; 18727 const isShared = snapshot.source !== node2.layout.source; 18728 if (animationType === "size") { 18729 eachAxis((axis) => { 18730 const axisSnapshot = isShared ? snapshot.measuredBox[axis] : snapshot.layoutBox[axis]; 18731 const length2 = calcLength(axisSnapshot); 18732 axisSnapshot.min = layout2[axis].min; 18733 axisSnapshot.max = axisSnapshot.min + length2; 18734 }); 18735 } else if (shouldAnimatePositionOnly(animationType, snapshot.layoutBox, layout2)) { 18736 eachAxis((axis) => { 18737 const axisSnapshot = isShared ? snapshot.measuredBox[axis] : snapshot.layoutBox[axis]; 18738 const length2 = calcLength(layout2[axis]); 18739 axisSnapshot.max = axisSnapshot.min + length2; 18740 if (node2.relativeTarget && !node2.currentAnimation) { 18741 node2.isProjectionDirty = true; 18742 node2.relativeTarget[axis].max = node2.relativeTarget[axis].min + length2; 18743 } 18744 }); 18745 } 18746 const layoutDelta = createDelta(); 18747 calcBoxDelta(layoutDelta, layout2, snapshot.layoutBox); 18748 const visualDelta = createDelta(); 18749 if (isShared) { 18750 calcBoxDelta(visualDelta, node2.applyTransform(measuredLayout, true), snapshot.measuredBox); 18751 } else { 18752 calcBoxDelta(visualDelta, layout2, snapshot.layoutBox); 18753 } 18754 const hasLayoutChanged = !isDeltaZero(layoutDelta); 18755 let hasRelativeTargetChanged = false; 18756 if (!node2.resumeFrom) { 18757 const relativeParent = node2.getClosestProjectingParent(); 18758 if (relativeParent && !relativeParent.resumeFrom) { 18759 const { snapshot: parentSnapshot, layout: parentLayout } = relativeParent; 18760 if (parentSnapshot && parentLayout) { 18761 const relativeSnapshot = createBox(); 18762 calcRelativePosition(relativeSnapshot, snapshot.layoutBox, parentSnapshot.layoutBox); 18763 const relativeLayout = createBox(); 18764 calcRelativePosition(relativeLayout, layout2, parentLayout.layoutBox); 18765 if (!boxEqualsRounded(relativeSnapshot, relativeLayout)) { 18766 hasRelativeTargetChanged = true; 18767 } 18768 if (relativeParent.options.layoutRoot) { 18769 node2.relativeTarget = relativeLayout; 18770 node2.relativeTargetOrigin = relativeSnapshot; 18771 node2.relativeParent = relativeParent; 18772 } 18773 } 18774 } 18775 } 18776 node2.notifyListeners("didUpdate", { 18777 layout: layout2, 18778 snapshot, 18779 delta: visualDelta, 18780 layoutDelta, 18781 hasLayoutChanged, 18782 hasRelativeTargetChanged 18783 }); 18784 } else if (node2.isLead()) { 18785 const { onExitComplete } = node2.options; 18786 onExitComplete && onExitComplete(); 18787 } 18788 node2.options.transition = void 0; 18789 } 18790 function propagateDirtyNodes(node2) { 18791 if (isDebug) { 18792 metrics.totalNodes++; 18793 } 18794 if (!node2.parent) 18795 return; 18796 if (!node2.isProjecting()) { 18797 node2.isProjectionDirty = node2.parent.isProjectionDirty; 18798 } 18799 node2.isSharedProjectionDirty || (node2.isSharedProjectionDirty = Boolean(node2.isProjectionDirty || node2.parent.isProjectionDirty || node2.parent.isSharedProjectionDirty)); 18800 node2.isTransformDirty || (node2.isTransformDirty = node2.parent.isTransformDirty); 18801 } 18802 function cleanDirtyNodes(node2) { 18803 node2.isProjectionDirty = node2.isSharedProjectionDirty = node2.isTransformDirty = false; 18804 } 18805 function clearSnapshot(node2) { 18806 node2.clearSnapshot(); 18807 } 18808 function clearMeasurements(node2) { 18809 node2.clearMeasurements(); 18810 } 18811 function clearIsLayoutDirty(node2) { 18812 node2.isLayoutDirty = false; 18813 } 18814 function resetTransformStyle(node2) { 18815 const { visualElement } = node2.options; 18816 if (visualElement && visualElement.getProps().onBeforeLayoutMeasure) { 18817 visualElement.notify("BeforeLayoutMeasure"); 18818 } 18819 node2.resetTransform(); 18820 } 18821 function finishAnimation(node2) { 18822 node2.finishAnimation(); 18823 node2.targetDelta = node2.relativeTarget = node2.target = void 0; 18824 node2.isProjectionDirty = true; 18825 } 18826 function resolveTargetDelta(node2) { 18827 node2.resolveTargetDelta(); 18828 } 18829 function calcProjection(node2) { 18830 node2.calcProjection(); 18831 } 18832 function resetSkewAndRotation(node2) { 18833 node2.resetSkewAndRotation(); 18834 } 18835 function removeLeadSnapshots(stack) { 18836 stack.removeLeadSnapshot(); 18837 } 18838 function mixAxisDelta(output, delta, p3) { 18839 output.translate = mixNumber(delta.translate, 0, p3); 18840 output.scale = mixNumber(delta.scale, 1, p3); 18841 output.origin = delta.origin; 18842 output.originPoint = delta.originPoint; 18843 } 18844 function mixAxis(output, from2, to, p3) { 18845 output.min = mixNumber(from2.min, to.min, p3); 18846 output.max = mixNumber(from2.max, to.max, p3); 18847 } 18848 function mixBox(output, from2, to, p3) { 18849 mixAxis(output.x, from2.x, to.x, p3); 18850 mixAxis(output.y, from2.y, to.y, p3); 18851 } 18852 function hasOpacityCrossfade(node2) { 18853 return node2.animationValues && node2.animationValues.opacityExit !== void 0; 18854 } 18855 var defaultLayoutTransition = { 18856 duration: 0.45, 18857 ease: [0.4, 0, 0.1, 1] 18858 }; 18859 var userAgentContains = (string) => typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().includes(string); 18860 var roundPoint = userAgentContains("applewebkit/") && !userAgentContains("chrome/") ? Math.round : noop2; 18861 function roundAxis(axis) { 18862 axis.min = roundPoint(axis.min); 18863 axis.max = roundPoint(axis.max); 18864 } 18865 function roundBox(box) { 18866 roundAxis(box.x); 18867 roundAxis(box.y); 18868 } 18869 function shouldAnimatePositionOnly(animationType, snapshot, layout2) { 18870 return animationType === "position" || animationType === "preserve-aspect" && !isNear(aspectRatio(snapshot), aspectRatio(layout2), 0.2); 18871 } 18872 function checkNodeWasScrollRoot(node2) { 18873 var _a; 18874 return node2 !== node2.root && ((_a = node2.scroll) === null || _a === void 0 ? void 0 : _a.wasRoot); 18875 } 18876 18877 // packages/components/node_modules/framer-motion/dist/es/projection/node/DocumentProjectionNode.mjs 18878 var DocumentProjectionNode = createProjectionNode({ 18879 attachResizeListener: (ref, notify) => addDomEvent(ref, "resize", notify), 18880 measureScroll: () => ({ 18881 x: document.documentElement.scrollLeft || document.body.scrollLeft, 18882 y: document.documentElement.scrollTop || document.body.scrollTop 18883 }), 18884 checkIsScrollRoot: () => true 18885 }); 18886 18887 // packages/components/node_modules/framer-motion/dist/es/projection/node/HTMLProjectionNode.mjs 18888 var rootProjectionNode = { 18889 current: void 0 18890 }; 18891 var HTMLProjectionNode = createProjectionNode({ 18892 measureScroll: (instance) => ({ 18893 x: instance.scrollLeft, 18894 y: instance.scrollTop 18895 }), 18896 defaultParent: () => { 18897 if (!rootProjectionNode.current) { 18898 const documentNode = new DocumentProjectionNode({}); 18899 documentNode.mount(window); 18900 documentNode.setOptions({ layoutScroll: true }); 18901 rootProjectionNode.current = documentNode; 18902 } 18903 return rootProjectionNode.current; 18904 }, 18905 resetTransform: (instance, value) => { 18906 instance.style.transform = value !== void 0 ? value : "none"; 18907 }, 18908 checkIsScrollRoot: (instance) => Boolean(window.getComputedStyle(instance).position === "fixed") 18909 }); 18910 18911 // packages/components/node_modules/framer-motion/dist/es/motion/features/drag.mjs 18912 var drag = { 18913 pan: { 18914 Feature: PanGesture 18915 }, 18916 drag: { 18917 Feature: DragGesture, 18918 ProjectionNode: HTMLProjectionNode, 18919 MeasureLayout 18920 } 18921 }; 18922 18923 // packages/components/node_modules/framer-motion/dist/es/gestures/hover.mjs 18924 function handleHoverEvent(node2, event, lifecycle) { 18925 const { props } = node2; 18926 if (node2.animationState && props.whileHover) { 18927 node2.animationState.setActive("whileHover", lifecycle === "Start"); 18928 } 18929 const eventName = "onHover" + lifecycle; 18930 const callback = props[eventName]; 18931 if (callback) { 18932 frame.postRender(() => callback(event, extractEventInfo(event))); 18933 } 18934 } 18935 var HoverGesture = class extends Feature { 18936 mount() { 18937 const { current } = this.node; 18938 if (!current) 18939 return; 18940 this.unmount = hover(current, (startEvent) => { 18941 handleHoverEvent(this.node, startEvent, "Start"); 18942 return (endEvent) => handleHoverEvent(this.node, endEvent, "End"); 18943 }); 18944 } 18945 unmount() { 18946 } 18947 }; 18948 18949 // packages/components/node_modules/framer-motion/dist/es/gestures/focus.mjs 18950 var FocusGesture = class extends Feature { 18951 constructor() { 18952 super(...arguments); 18953 this.isActive = false; 18954 } 18955 onFocus() { 18956 let isFocusVisible = false; 18957 try { 18958 isFocusVisible = this.node.current.matches(":focus-visible"); 18959 } catch (e3) { 18960 isFocusVisible = true; 18961 } 18962 if (!isFocusVisible || !this.node.animationState) 18963 return; 18964 this.node.animationState.setActive("whileFocus", true); 18965 this.isActive = true; 18966 } 18967 onBlur() { 18968 if (!this.isActive || !this.node.animationState) 18969 return; 18970 this.node.animationState.setActive("whileFocus", false); 18971 this.isActive = false; 18972 } 18973 mount() { 18974 this.unmount = pipe(addDomEvent(this.node.current, "focus", () => this.onFocus()), addDomEvent(this.node.current, "blur", () => this.onBlur())); 18975 } 18976 unmount() { 18977 } 18978 }; 18979 18980 // packages/components/node_modules/framer-motion/dist/es/gestures/press.mjs 18981 function handlePressEvent(node2, event, lifecycle) { 18982 const { props } = node2; 18983 if (node2.animationState && props.whileTap) { 18984 node2.animationState.setActive("whileTap", lifecycle === "Start"); 18985 } 18986 const eventName = "onTap" + (lifecycle === "End" ? "" : lifecycle); 18987 const callback = props[eventName]; 18988 if (callback) { 18989 frame.postRender(() => callback(event, extractEventInfo(event))); 18990 } 18991 } 18992 var PressGesture = class extends Feature { 18993 mount() { 18994 const { current } = this.node; 18995 if (!current) 18996 return; 18997 this.unmount = press(current, (startEvent) => { 18998 handlePressEvent(this.node, startEvent, "Start"); 18999 return (endEvent, { success }) => handlePressEvent(this.node, endEvent, success ? "End" : "Cancel"); 19000 }, { useGlobalTarget: this.node.props.globalTapTarget }); 19001 } 19002 unmount() { 19003 } 19004 }; 19005 19006 // packages/components/node_modules/framer-motion/dist/es/motion/features/viewport/observers.mjs 19007 var observerCallbacks = /* @__PURE__ */ new WeakMap(); 19008 var observers = /* @__PURE__ */ new WeakMap(); 19009 var fireObserverCallback = (entry) => { 19010 const callback = observerCallbacks.get(entry.target); 19011 callback && callback(entry); 19012 }; 19013 var fireAllObserverCallbacks = (entries) => { 19014 entries.forEach(fireObserverCallback); 19015 }; 19016 function initIntersectionObserver({ root, ...options2 }) { 19017 const lookupRoot = root || document; 19018 if (!observers.has(lookupRoot)) { 19019 observers.set(lookupRoot, {}); 19020 } 19021 const rootObservers = observers.get(lookupRoot); 19022 const key = JSON.stringify(options2); 19023 if (!rootObservers[key]) { 19024 rootObservers[key] = new IntersectionObserver(fireAllObserverCallbacks, { root, ...options2 }); 19025 } 19026 return rootObservers[key]; 19027 } 19028 function observeIntersection(element, options2, callback) { 19029 const rootInteresectionObserver = initIntersectionObserver(options2); 19030 observerCallbacks.set(element, callback); 19031 rootInteresectionObserver.observe(element); 19032 return () => { 19033 observerCallbacks.delete(element); 19034 rootInteresectionObserver.unobserve(element); 19035 }; 19036 } 19037 19038 // packages/components/node_modules/framer-motion/dist/es/motion/features/viewport/index.mjs 19039 var thresholdNames = { 19040 some: 0, 19041 all: 1 19042 }; 19043 var InViewFeature = class extends Feature { 19044 constructor() { 19045 super(...arguments); 19046 this.hasEnteredView = false; 19047 this.isInView = false; 19048 } 19049 startObserver() { 19050 this.unmount(); 19051 const { viewport = {} } = this.node.getProps(); 19052 const { root, margin: rootMargin, amount = "some", once } = viewport; 19053 const options2 = { 19054 root: root ? root.current : void 0, 19055 rootMargin, 19056 threshold: typeof amount === "number" ? amount : thresholdNames[amount] 19057 }; 19058 const onIntersectionUpdate = (entry) => { 19059 const { isIntersecting } = entry; 19060 if (this.isInView === isIntersecting) 19061 return; 19062 this.isInView = isIntersecting; 19063 if (once && !isIntersecting && this.hasEnteredView) { 19064 return; 19065 } else if (isIntersecting) { 19066 this.hasEnteredView = true; 19067 } 19068 if (this.node.animationState) { 19069 this.node.animationState.setActive("whileInView", isIntersecting); 19070 } 19071 const { onViewportEnter, onViewportLeave } = this.node.getProps(); 19072 const callback = isIntersecting ? onViewportEnter : onViewportLeave; 19073 callback && callback(entry); 19074 }; 19075 return observeIntersection(this.node.current, options2, onIntersectionUpdate); 19076 } 19077 mount() { 19078 this.startObserver(); 19079 } 19080 update() { 19081 if (typeof IntersectionObserver === "undefined") 19082 return; 19083 const { props, prevProps } = this.node; 19084 const hasOptionsChanged = ["amount", "margin", "root"].some(hasViewportOptionChanged(props, prevProps)); 19085 if (hasOptionsChanged) { 19086 this.startObserver(); 19087 } 19088 } 19089 unmount() { 19090 } 19091 }; 19092 function hasViewportOptionChanged({ viewport = {} }, { viewport: prevViewport = {} } = {}) { 19093 return (name) => viewport[name] !== prevViewport[name]; 19094 } 19095 19096 // packages/components/node_modules/framer-motion/dist/es/motion/features/gestures.mjs 19097 var gestureAnimations = { 19098 inView: { 19099 Feature: InViewFeature 19100 }, 19101 tap: { 19102 Feature: PressGesture 19103 }, 19104 focus: { 19105 Feature: FocusGesture 19106 }, 19107 hover: { 19108 Feature: HoverGesture 19109 } 19110 }; 19111 19112 // packages/components/node_modules/framer-motion/dist/es/motion/features/layout.mjs 19113 var layout = { 19114 layout: { 19115 ProjectionNode: HTMLProjectionNode, 19116 MeasureLayout 19117 } 19118 }; 19119 19120 // packages/components/node_modules/framer-motion/dist/es/motion/index.mjs 19121 var import_jsx_runtime40 = __toESM(require_jsx_runtime(), 1); 19122 var import_react69 = __toESM(require_react(), 1); 19123 19124 // packages/components/node_modules/framer-motion/dist/es/context/MotionConfigContext.mjs 19125 var import_react62 = __toESM(require_react(), 1); 19126 var MotionConfigContext = (0, import_react62.createContext)({ 19127 transformPagePoint: (p3) => p3, 19128 isStatic: false, 19129 reducedMotion: "never" 19130 }); 19131 19132 // packages/components/node_modules/framer-motion/dist/es/context/MotionContext/index.mjs 19133 var import_react63 = __toESM(require_react(), 1); 19134 var MotionContext = (0, import_react63.createContext)({}); 19135 19136 // packages/components/node_modules/framer-motion/dist/es/motion/utils/use-visual-element.mjs 19137 var import_react66 = __toESM(require_react(), 1); 19138 19139 // packages/components/node_modules/framer-motion/dist/es/utils/use-isomorphic-effect.mjs 19140 var import_react64 = __toESM(require_react(), 1); 19141 19142 // packages/components/node_modules/framer-motion/dist/es/utils/is-browser.mjs 19143 var isBrowser = typeof window !== "undefined"; 19144 19145 // packages/components/node_modules/framer-motion/dist/es/utils/use-isomorphic-effect.mjs 19146 var useIsomorphicLayoutEffect = isBrowser ? import_react64.useLayoutEffect : import_react64.useEffect; 19147 19148 // packages/components/node_modules/framer-motion/dist/es/context/LazyContext.mjs 19149 var import_react65 = __toESM(require_react(), 1); 19150 var LazyContext = (0, import_react65.createContext)({ strict: false }); 19151 19152 // packages/components/node_modules/framer-motion/dist/es/motion/utils/use-visual-element.mjs 19153 function useVisualElement(Component9, visualState, props, createVisualElement, ProjectionNodeConstructor) { 19154 var _a, _b; 19155 const { visualElement: parent } = (0, import_react66.useContext)(MotionContext); 19156 const lazyContext = (0, import_react66.useContext)(LazyContext); 19157 const presenceContext = (0, import_react66.useContext)(PresenceContext); 19158 const reducedMotionConfig = (0, import_react66.useContext)(MotionConfigContext).reducedMotion; 19159 const visualElementRef = (0, import_react66.useRef)(null); 19160 createVisualElement = createVisualElement || lazyContext.renderer; 19161 if (!visualElementRef.current && createVisualElement) { 19162 visualElementRef.current = createVisualElement(Component9, { 19163 visualState, 19164 parent, 19165 props, 19166 presenceContext, 19167 blockInitialAnimation: presenceContext ? presenceContext.initial === false : false, 19168 reducedMotionConfig 19169 }); 19170 } 19171 const visualElement = visualElementRef.current; 19172 const initialLayoutGroupConfig = (0, import_react66.useContext)(SwitchLayoutGroupContext); 19173 if (visualElement && !visualElement.projection && ProjectionNodeConstructor && (visualElement.type === "html" || visualElement.type === "svg")) { 19174 createProjectionNode2(visualElementRef.current, props, ProjectionNodeConstructor, initialLayoutGroupConfig); 19175 } 19176 const isMounted = (0, import_react66.useRef)(false); 19177 (0, import_react66.useInsertionEffect)(() => { 19178 if (visualElement && isMounted.current) { 19179 visualElement.update(props, presenceContext); 19180 } 19181 }); 19182 const optimisedAppearId = props[optimizedAppearDataAttribute]; 19183 const wantsHandoff = (0, import_react66.useRef)(Boolean(optimisedAppearId) && !((_a = window.MotionHandoffIsComplete) === null || _a === void 0 ? void 0 : _a.call(window, optimisedAppearId)) && ((_b = window.MotionHasOptimisedAnimation) === null || _b === void 0 ? void 0 : _b.call(window, optimisedAppearId))); 19184 useIsomorphicLayoutEffect(() => { 19185 if (!visualElement) 19186 return; 19187 isMounted.current = true; 19188 window.MotionIsMounted = true; 19189 visualElement.updateFeatures(); 19190 microtask.render(visualElement.render); 19191 if (wantsHandoff.current && visualElement.animationState) { 19192 visualElement.animationState.animateChanges(); 19193 } 19194 }); 19195 (0, import_react66.useEffect)(() => { 19196 if (!visualElement) 19197 return; 19198 if (!wantsHandoff.current && visualElement.animationState) { 19199 visualElement.animationState.animateChanges(); 19200 } 19201 if (wantsHandoff.current) { 19202 queueMicrotask(() => { 19203 var _a2; 19204 (_a2 = window.MotionHandoffMarkAsComplete) === null || _a2 === void 0 ? void 0 : _a2.call(window, optimisedAppearId); 19205 }); 19206 wantsHandoff.current = false; 19207 } 19208 }); 19209 return visualElement; 19210 } 19211 function createProjectionNode2(visualElement, props, ProjectionNodeConstructor, initialPromotionConfig) { 19212 const { layoutId, layout: layout2, drag: drag2, dragConstraints, layoutScroll, layoutRoot } = props; 19213 visualElement.projection = new ProjectionNodeConstructor(visualElement.latestValues, props["data-framer-portal-id"] ? void 0 : getClosestProjectingNode(visualElement.parent)); 19214 visualElement.projection.setOptions({ 19215 layoutId, 19216 layout: layout2, 19217 alwaysMeasureLayout: Boolean(drag2) || dragConstraints && isRefObject(dragConstraints), 19218 visualElement, 19219 /** 19220 * TODO: Update options in an effect. This could be tricky as it'll be too late 19221 * to update by the time layout animations run. 19222 * We also need to fix this safeToRemove by linking it up to the one returned by usePresence, 19223 * ensuring it gets called if there's no potential layout animations. 19224 * 19225 */ 19226 animationType: typeof layout2 === "string" ? layout2 : "both", 19227 initialPromotionConfig, 19228 layoutScroll, 19229 layoutRoot 19230 }); 19231 } 19232 function getClosestProjectingNode(visualElement) { 19233 if (!visualElement) 19234 return void 0; 19235 return visualElement.options.allowProjection !== false ? visualElement.projection : getClosestProjectingNode(visualElement.parent); 19236 } 19237 19238 // packages/components/node_modules/framer-motion/dist/es/motion/utils/use-motion-ref.mjs 19239 var import_react67 = __toESM(require_react(), 1); 19240 function useMotionRef(visualState, visualElement, externalRef) { 19241 return (0, import_react67.useCallback)( 19242 (instance) => { 19243 instance && visualState.mount && visualState.mount(instance); 19244 if (visualElement) { 19245 if (instance) { 19246 visualElement.mount(instance); 19247 } else { 19248 visualElement.unmount(); 19249 } 19250 } 19251 if (externalRef) { 19252 if (typeof externalRef === "function") { 19253 externalRef(instance); 19254 } else if (isRefObject(externalRef)) { 19255 externalRef.current = instance; 19256 } 19257 } 19258 }, 19259 /** 19260 * Only pass a new ref callback to React if we've received a visual element 19261 * factory. Otherwise we'll be mounting/remounting every time externalRef 19262 * or other dependencies change. 19263 */ 19264 [visualElement] 19265 ); 19266 } 19267 19268 // packages/components/node_modules/framer-motion/dist/es/context/MotionContext/create.mjs 19269 var import_react68 = __toESM(require_react(), 1); 19270 19271 // packages/components/node_modules/framer-motion/dist/es/render/utils/is-controlling-variants.mjs 19272 function isControllingVariants(props) { 19273 return isAnimationControls(props.animate) || variantProps.some((name) => isVariantLabel(props[name])); 19274 } 19275 function isVariantNode(props) { 19276 return Boolean(isControllingVariants(props) || props.variants); 19277 } 19278 19279 // packages/components/node_modules/framer-motion/dist/es/context/MotionContext/utils.mjs 19280 function getCurrentTreeVariants(props, context) { 19281 if (isControllingVariants(props)) { 19282 const { initial, animate } = props; 19283 return { 19284 initial: initial === false || isVariantLabel(initial) ? initial : void 0, 19285 animate: isVariantLabel(animate) ? animate : void 0 19286 }; 19287 } 19288 return props.inherit !== false ? context : {}; 19289 } 19290 19291 // packages/components/node_modules/framer-motion/dist/es/context/MotionContext/create.mjs 19292 function useCreateMotionContext(props) { 19293 const { initial, animate } = getCurrentTreeVariants(props, (0, import_react68.useContext)(MotionContext)); 19294 return (0, import_react68.useMemo)(() => ({ initial, animate }), [variantLabelsAsDependency(initial), variantLabelsAsDependency(animate)]); 19295 } 19296 function variantLabelsAsDependency(prop) { 19297 return Array.isArray(prop) ? prop.join(" ") : prop; 19298 } 19299 19300 // packages/components/node_modules/framer-motion/dist/es/motion/features/definitions.mjs 19301 var featureProps = { 19302 animation: [ 19303 "animate", 19304 "variants", 19305 "whileHover", 19306 "whileTap", 19307 "exit", 19308 "whileInView", 19309 "whileFocus", 19310 "whileDrag" 19311 ], 19312 exit: ["exit"], 19313 drag: ["drag", "dragControls"], 19314 focus: ["whileFocus"], 19315 hover: ["whileHover", "onHoverStart", "onHoverEnd"], 19316 tap: ["whileTap", "onTap", "onTapStart", "onTapCancel"], 19317 pan: ["onPan", "onPanStart", "onPanSessionStart", "onPanEnd"], 19318 inView: ["whileInView", "onViewportEnter", "onViewportLeave"], 19319 layout: ["layout", "layoutId"] 19320 }; 19321 var featureDefinitions = {}; 19322 for (const key in featureProps) { 19323 featureDefinitions[key] = { 19324 isEnabled: (props) => featureProps[key].some((name) => !!props[name]) 19325 }; 19326 } 19327 19328 // packages/components/node_modules/framer-motion/dist/es/motion/features/load-features.mjs 19329 function loadFeatures(features) { 19330 for (const key in features) { 19331 featureDefinitions[key] = { 19332 ...featureDefinitions[key], 19333 ...features[key] 19334 }; 19335 } 19336 } 19337 19338 // packages/components/node_modules/framer-motion/dist/es/motion/utils/symbol.mjs 19339 var motionComponentSymbol = Symbol.for("motionComponentSymbol"); 19340 19341 // packages/components/node_modules/framer-motion/dist/es/motion/index.mjs 19342 function createRendererMotionComponent({ preloadedFeatures, createVisualElement, useRender, useVisualState, Component: Component9 }) { 19343 preloadedFeatures && loadFeatures(preloadedFeatures); 19344 function MotionComponent(props, externalRef) { 19345 let MeasureLayout2; 19346 const configAndProps = { 19347 ...(0, import_react69.useContext)(MotionConfigContext), 19348 ...props, 19349 layoutId: useLayoutId(props) 19350 }; 19351 const { isStatic } = configAndProps; 19352 const context = useCreateMotionContext(props); 19353 const visualState = useVisualState(props, isStatic); 19354 if (!isStatic && isBrowser) { 19355 useStrictMode(configAndProps, preloadedFeatures); 19356 const layoutProjection = getProjectionFunctionality(configAndProps); 19357 MeasureLayout2 = layoutProjection.MeasureLayout; 19358 context.visualElement = useVisualElement(Component9, visualState, configAndProps, createVisualElement, layoutProjection.ProjectionNode); 19359 } 19360 return (0, import_jsx_runtime40.jsxs)(MotionContext.Provider, { value: context, children: [MeasureLayout2 && context.visualElement ? (0, import_jsx_runtime40.jsx)(MeasureLayout2, { visualElement: context.visualElement, ...configAndProps }) : null, useRender(Component9, props, useMotionRef(visualState, context.visualElement, externalRef), visualState, isStatic, context.visualElement)] }); 19361 } 19362 const ForwardRefMotionComponent = (0, import_react69.forwardRef)(MotionComponent); 19363 ForwardRefMotionComponent[motionComponentSymbol] = Component9; 19364 return ForwardRefMotionComponent; 19365 } 19366 function useLayoutId({ layoutId }) { 19367 const layoutGroupId = (0, import_react69.useContext)(LayoutGroupContext).id; 19368 return layoutGroupId && layoutId !== void 0 ? layoutGroupId + "-" + layoutId : layoutId; 19369 } 19370 function useStrictMode(configAndProps, preloadedFeatures) { 19371 const isStrict = (0, import_react69.useContext)(LazyContext).strict; 19372 if (preloadedFeatures && isStrict) { 19373 const strictMessage = "You have rendered a `motion` component within a `LazyMotion` component. This will break tree shaking. Import and render a `m` component instead."; 19374 configAndProps.ignoreStrict ? warning(false, strictMessage) : invariant2(false, strictMessage); 19375 } 19376 } 19377 function getProjectionFunctionality(props) { 19378 const { drag: drag2, layout: layout2 } = featureDefinitions; 19379 if (!drag2 && !layout2) 19380 return {}; 19381 const combined = { ...drag2, ...layout2 }; 19382 return { 19383 MeasureLayout: (drag2 === null || drag2 === void 0 ? void 0 : drag2.isEnabled(props)) || (layout2 === null || layout2 === void 0 ? void 0 : layout2.isEnabled(props)) ? combined.MeasureLayout : void 0, 19384 ProjectionNode: combined.ProjectionNode 19385 }; 19386 } 19387 19388 // packages/components/node_modules/framer-motion/dist/es/render/svg/lowercase-elements.mjs 19389 var lowercaseSVGElements = [ 19390 "animate", 19391 "circle", 19392 "defs", 19393 "desc", 19394 "ellipse", 19395 "g", 19396 "image", 19397 "line", 19398 "filter", 19399 "marker", 19400 "mask", 19401 "metadata", 19402 "path", 19403 "pattern", 19404 "polygon", 19405 "polyline", 19406 "rect", 19407 "stop", 19408 "switch", 19409 "symbol", 19410 "svg", 19411 "text", 19412 "tspan", 19413 "use", 19414 "view" 19415 ]; 19416 19417 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/is-svg-component.mjs 19418 function isSVGComponent(Component9) { 19419 if ( 19420 /** 19421 * If it's not a string, it's a custom React component. Currently we only support 19422 * HTML custom React components. 19423 */ 19424 typeof Component9 !== "string" || /** 19425 * If it contains a dash, the element is a custom HTML webcomponent. 19426 */ 19427 Component9.includes("-") 19428 ) { 19429 return false; 19430 } else if ( 19431 /** 19432 * If it's in our list of lowercase SVG tags, it's an SVG component 19433 */ 19434 lowercaseSVGElements.indexOf(Component9) > -1 || /** 19435 * If it contains a capital letter, it's an SVG component 19436 */ 19437 /[A-Z]/u.test(Component9) 19438 ) { 19439 return true; 19440 } 19441 return false; 19442 } 19443 19444 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/render.mjs 19445 function renderHTML(element, { style: style2, vars }, styleProp, projection) { 19446 Object.assign(element.style, style2, projection && projection.getProjectionStyles(styleProp)); 19447 for (const key in vars) { 19448 element.style.setProperty(key, vars[key]); 19449 } 19450 } 19451 19452 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/camel-case-attrs.mjs 19453 var camelCaseAttributes = /* @__PURE__ */ new Set([ 19454 "baseFrequency", 19455 "diffuseConstant", 19456 "kernelMatrix", 19457 "kernelUnitLength", 19458 "keySplines", 19459 "keyTimes", 19460 "limitingConeAngle", 19461 "markerHeight", 19462 "markerWidth", 19463 "numOctaves", 19464 "targetX", 19465 "targetY", 19466 "surfaceScale", 19467 "specularConstant", 19468 "specularExponent", 19469 "stdDeviation", 19470 "tableValues", 19471 "viewBox", 19472 "gradientTransform", 19473 "pathLength", 19474 "startOffset", 19475 "textLength", 19476 "lengthAdjust" 19477 ]); 19478 19479 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/render.mjs 19480 function renderSVG(element, renderState, _styleProp, projection) { 19481 renderHTML(element, renderState, void 0, projection); 19482 for (const key in renderState.attrs) { 19483 element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]); 19484 } 19485 } 19486 19487 // packages/components/node_modules/framer-motion/dist/es/motion/utils/is-forced-motion-value.mjs 19488 function isForcedMotionValue(key, { layout: layout2, layoutId }) { 19489 return transformProps.has(key) || key.startsWith("origin") || (layout2 || layoutId !== void 0) && (!!scaleCorrectors[key] || key === "opacity"); 19490 } 19491 19492 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/scrape-motion-values.mjs 19493 function scrapeMotionValuesFromProps(props, prevProps, visualElement) { 19494 var _a; 19495 const { style: style2 } = props; 19496 const newValues = {}; 19497 for (const key in style2) { 19498 if (isMotionValue(style2[key]) || prevProps.style && isMotionValue(prevProps.style[key]) || isForcedMotionValue(key, props) || ((_a = visualElement === null || visualElement === void 0 ? void 0 : visualElement.getValue(key)) === null || _a === void 0 ? void 0 : _a.liveStyle) !== void 0) { 19499 newValues[key] = style2[key]; 19500 } 19501 } 19502 return newValues; 19503 } 19504 19505 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/scrape-motion-values.mjs 19506 function scrapeMotionValuesFromProps2(props, prevProps, visualElement) { 19507 const newValues = scrapeMotionValuesFromProps(props, prevProps, visualElement); 19508 for (const key in props) { 19509 if (isMotionValue(props[key]) || isMotionValue(prevProps[key])) { 19510 const targetKey = transformPropOrder.indexOf(key) !== -1 ? "attr" + key.charAt(0).toUpperCase() + key.substring(1) : key; 19511 newValues[targetKey] = props[key]; 19512 } 19513 } 19514 return newValues; 19515 } 19516 19517 // packages/components/node_modules/framer-motion/dist/es/motion/utils/use-visual-state.mjs 19518 var import_react71 = __toESM(require_react(), 1); 19519 19520 // packages/components/node_modules/framer-motion/dist/es/utils/use-constant.mjs 19521 var import_react70 = __toESM(require_react(), 1); 19522 function useConstant(init2) { 19523 const ref = (0, import_react70.useRef)(null); 19524 if (ref.current === null) { 19525 ref.current = init2(); 19526 } 19527 return ref.current; 19528 } 19529 19530 // packages/components/node_modules/framer-motion/dist/es/motion/utils/use-visual-state.mjs 19531 function makeState({ scrapeMotionValuesFromProps: scrapeMotionValuesFromProps3, createRenderState, onMount }, props, context, presenceContext) { 19532 const state = { 19533 latestValues: makeLatestValues(props, context, presenceContext, scrapeMotionValuesFromProps3), 19534 renderState: createRenderState() 19535 }; 19536 if (onMount) { 19537 state.mount = (instance) => onMount(props, instance, state); 19538 } 19539 return state; 19540 } 19541 var makeUseVisualState = (config) => (props, isStatic) => { 19542 const context = (0, import_react71.useContext)(MotionContext); 19543 const presenceContext = (0, import_react71.useContext)(PresenceContext); 19544 const make = () => makeState(config, props, context, presenceContext); 19545 return isStatic ? make() : useConstant(make); 19546 }; 19547 function makeLatestValues(props, context, presenceContext, scrapeMotionValues) { 19548 const values = {}; 19549 const motionValues = scrapeMotionValues(props, {}); 19550 for (const key in motionValues) { 19551 values[key] = resolveMotionValue(motionValues[key]); 19552 } 19553 let { initial, animate } = props; 19554 const isControllingVariants$1 = isControllingVariants(props); 19555 const isVariantNode$1 = isVariantNode(props); 19556 if (context && isVariantNode$1 && !isControllingVariants$1 && props.inherit !== false) { 19557 if (initial === void 0) 19558 initial = context.initial; 19559 if (animate === void 0) 19560 animate = context.animate; 19561 } 19562 let isInitialAnimationBlocked = presenceContext ? presenceContext.initial === false : false; 19563 isInitialAnimationBlocked = isInitialAnimationBlocked || initial === false; 19564 const variantToSet = isInitialAnimationBlocked ? animate : initial; 19565 if (variantToSet && typeof variantToSet !== "boolean" && !isAnimationControls(variantToSet)) { 19566 const list = Array.isArray(variantToSet) ? variantToSet : [variantToSet]; 19567 for (let i3 = 0; i3 < list.length; i3++) { 19568 const resolved = resolveVariantFromProps(props, list[i3]); 19569 if (resolved) { 19570 const { transitionEnd, transition, ...target } = resolved; 19571 for (const key in target) { 19572 let valueTarget = target[key]; 19573 if (Array.isArray(valueTarget)) { 19574 const index2 = isInitialAnimationBlocked ? valueTarget.length - 1 : 0; 19575 valueTarget = valueTarget[index2]; 19576 } 19577 if (valueTarget !== null) { 19578 values[key] = valueTarget; 19579 } 19580 } 19581 for (const key in transitionEnd) { 19582 values[key] = transitionEnd[key]; 19583 } 19584 } 19585 } 19586 } 19587 return values; 19588 } 19589 19590 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/create-render-state.mjs 19591 var createHtmlRenderState = () => ({ 19592 style: {}, 19593 transform: {}, 19594 transformOrigin: {}, 19595 vars: {} 19596 }); 19597 19598 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/create-render-state.mjs 19599 var createSvgRenderState = () => ({ 19600 ...createHtmlRenderState(), 19601 attrs: {} 19602 }); 19603 19604 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/get-as-type.mjs 19605 var getValueAsType = (value, type) => { 19606 return type && typeof value === "number" ? type.transform(value) : value; 19607 }; 19608 19609 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/build-transform.mjs 19610 var translateAlias = { 19611 x: "translateX", 19612 y: "translateY", 19613 z: "translateZ", 19614 transformPerspective: "perspective" 19615 }; 19616 var numTransforms = transformPropOrder.length; 19617 function buildTransform(latestValues, transform, transformTemplate) { 19618 let transformString = ""; 19619 let transformIsDefault = true; 19620 for (let i3 = 0; i3 < numTransforms; i3++) { 19621 const key = transformPropOrder[i3]; 19622 const value = latestValues[key]; 19623 if (value === void 0) 19624 continue; 19625 let valueIsDefault = true; 19626 if (typeof value === "number") { 19627 valueIsDefault = value === (key.startsWith("scale") ? 1 : 0); 19628 } else { 19629 valueIsDefault = parseFloat(value) === 0; 19630 } 19631 if (!valueIsDefault || transformTemplate) { 19632 const valueAsType = getValueAsType(value, numberValueTypes[key]); 19633 if (!valueIsDefault) { 19634 transformIsDefault = false; 19635 const transformName = translateAlias[key] || key; 19636 transformString += `$transformName}($valueAsType}) `; 19637 } 19638 if (transformTemplate) { 19639 transform[key] = valueAsType; 19640 } 19641 } 19642 } 19643 transformString = transformString.trim(); 19644 if (transformTemplate) { 19645 transformString = transformTemplate(transform, transformIsDefault ? "" : transformString); 19646 } else if (transformIsDefault) { 19647 transformString = "none"; 19648 } 19649 return transformString; 19650 } 19651 19652 // packages/components/node_modules/framer-motion/dist/es/render/html/utils/build-styles.mjs 19653 function buildHTMLStyles(state, latestValues, transformTemplate) { 19654 const { style: style2, vars, transformOrigin } = state; 19655 let hasTransform2 = false; 19656 let hasTransformOrigin = false; 19657 for (const key in latestValues) { 19658 const value = latestValues[key]; 19659 if (transformProps.has(key)) { 19660 hasTransform2 = true; 19661 continue; 19662 } else if (isCSSVariableName(key)) { 19663 vars[key] = value; 19664 continue; 19665 } else { 19666 const valueAsType = getValueAsType(value, numberValueTypes[key]); 19667 if (key.startsWith("origin")) { 19668 hasTransformOrigin = true; 19669 transformOrigin[key] = valueAsType; 19670 } else { 19671 style2[key] = valueAsType; 19672 } 19673 } 19674 } 19675 if (!latestValues.transform) { 19676 if (hasTransform2 || transformTemplate) { 19677 style2.transform = buildTransform(latestValues, state.transform, transformTemplate); 19678 } else if (style2.transform) { 19679 style2.transform = "none"; 19680 } 19681 } 19682 if (hasTransformOrigin) { 19683 const { originX = "50%", originY = "50%", originZ = 0 } = transformOrigin; 19684 style2.transformOrigin = `$originX} $originY} $originZ}`; 19685 } 19686 } 19687 19688 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/transform-origin.mjs 19689 function calcOrigin2(origin, offset3, size3) { 19690 return typeof origin === "string" ? origin : px.transform(offset3 + size3 * origin); 19691 } 19692 function calcSVGTransformOrigin(dimensions, originX, originY) { 19693 const pxOriginX = calcOrigin2(originX, dimensions.x, dimensions.width); 19694 const pxOriginY = calcOrigin2(originY, dimensions.y, dimensions.height); 19695 return `$pxOriginX} $pxOriginY}`; 19696 } 19697 19698 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/path.mjs 19699 var dashKeys = { 19700 offset: "stroke-dashoffset", 19701 array: "stroke-dasharray" 19702 }; 19703 var camelKeys = { 19704 offset: "strokeDashoffset", 19705 array: "strokeDasharray" 19706 }; 19707 function buildSVGPath(attrs, length2, spacing = 1, offset3 = 0, useDashCase = true) { 19708 attrs.pathLength = 1; 19709 const keys = useDashCase ? dashKeys : camelKeys; 19710 attrs[keys.offset] = px.transform(-offset3); 19711 const pathLength = px.transform(length2); 19712 const pathSpacing = px.transform(spacing); 19713 attrs[keys.array] = `$pathLength} $pathSpacing}`; 19714 } 19715 19716 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/build-attrs.mjs 19717 function buildSVGAttrs(state, { 19718 attrX, 19719 attrY, 19720 attrScale, 19721 originX, 19722 originY, 19723 pathLength, 19724 pathSpacing = 1, 19725 pathOffset = 0, 19726 // This is object creation, which we try to avoid per-frame. 19727 ...latest 19728 }, isSVGTag2, transformTemplate) { 19729 buildHTMLStyles(state, latest, transformTemplate); 19730 if (isSVGTag2) { 19731 if (state.style.viewBox) { 19732 state.attrs.viewBox = state.style.viewBox; 19733 } 19734 return; 19735 } 19736 state.attrs = state.style; 19737 state.style = {}; 19738 const { attrs, style: style2, dimensions } = state; 19739 if (attrs.transform) { 19740 if (dimensions) 19741 style2.transform = attrs.transform; 19742 delete attrs.transform; 19743 } 19744 if (dimensions && (originX !== void 0 || originY !== void 0 || style2.transform)) { 19745 style2.transformOrigin = calcSVGTransformOrigin(dimensions, originX !== void 0 ? originX : 0.5, originY !== void 0 ? originY : 0.5); 19746 } 19747 if (attrX !== void 0) 19748 attrs.x = attrX; 19749 if (attrY !== void 0) 19750 attrs.y = attrY; 19751 if (attrScale !== void 0) 19752 attrs.scale = attrScale; 19753 if (pathLength !== void 0) { 19754 buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false); 19755 } 19756 } 19757 19758 // packages/components/node_modules/framer-motion/dist/es/render/svg/utils/is-svg-tag.mjs 19759 var isSVGTag = (tag) => typeof tag === "string" && tag.toLowerCase() === "svg"; 19760 19761 // packages/components/node_modules/framer-motion/dist/es/render/svg/config-motion.mjs 19762 var svgMotionConfig = { 19763 useVisualState: makeUseVisualState({ 19764 scrapeMotionValuesFromProps: scrapeMotionValuesFromProps2, 19765 createRenderState: createSvgRenderState, 19766 onMount: (props, instance, { renderState, latestValues }) => { 19767 frame.read(() => { 19768 try { 19769 renderState.dimensions = typeof instance.getBBox === "function" ? instance.getBBox() : instance.getBoundingClientRect(); 19770 } catch (e3) { 19771 renderState.dimensions = { 19772 x: 0, 19773 y: 0, 19774 width: 0, 19775 height: 0 19776 }; 19777 } 19778 }); 19779 frame.render(() => { 19780 buildSVGAttrs(renderState, latestValues, isSVGTag(instance.tagName), props.transformTemplate); 19781 renderSVG(instance, renderState); 19782 }); 19783 } 19784 }) 19785 }; 19786 19787 // packages/components/node_modules/framer-motion/dist/es/render/html/config-motion.mjs 19788 var htmlMotionConfig = { 19789 useVisualState: makeUseVisualState({ 19790 scrapeMotionValuesFromProps, 19791 createRenderState: createHtmlRenderState 19792 }) 19793 }; 19794 19795 // packages/components/node_modules/framer-motion/dist/es/render/dom/use-render.mjs 19796 var import_react74 = __toESM(require_react(), 1); 19797 19798 // packages/components/node_modules/framer-motion/dist/es/render/html/use-props.mjs 19799 var import_react72 = __toESM(require_react(), 1); 19800 function copyRawValuesOnly(target, source, props) { 19801 for (const key in source) { 19802 if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) { 19803 target[key] = source[key]; 19804 } 19805 } 19806 } 19807 function useInitialMotionValues({ transformTemplate }, visualState) { 19808 return (0, import_react72.useMemo)(() => { 19809 const state = createHtmlRenderState(); 19810 buildHTMLStyles(state, visualState, transformTemplate); 19811 return Object.assign({}, state.vars, state.style); 19812 }, [visualState]); 19813 } 19814 function useStyle(props, visualState) { 19815 const styleProp = props.style || {}; 19816 const style2 = {}; 19817 copyRawValuesOnly(style2, styleProp, props); 19818 Object.assign(style2, useInitialMotionValues(props, visualState)); 19819 return style2; 19820 } 19821 function useHTMLProps(props, visualState) { 19822 const htmlProps = {}; 19823 const style2 = useStyle(props, visualState); 19824 if (props.drag && props.dragListener !== false) { 19825 htmlProps.draggable = false; 19826 style2.userSelect = style2.WebkitUserSelect = style2.WebkitTouchCallout = "none"; 19827 style2.touchAction = props.drag === true ? "none" : `pan-$props.drag === "x" ? "y" : "x"}`; 19828 } 19829 if (props.tabIndex === void 0 && (props.onTap || props.onTapStart || props.whileTap)) { 19830 htmlProps.tabIndex = 0; 19831 } 19832 htmlProps.style = style2; 19833 return htmlProps; 19834 } 19835 19836 // packages/components/node_modules/framer-motion/dist/es/motion/utils/valid-prop.mjs 19837 var validMotionProps = /* @__PURE__ */ new Set([ 19838 "animate", 19839 "exit", 19840 "variants", 19841 "initial", 19842 "style", 19843 "values", 19844 "variants", 19845 "transition", 19846 "transformTemplate", 19847 "custom", 19848 "inherit", 19849 "onBeforeLayoutMeasure", 19850 "onAnimationStart", 19851 "onAnimationComplete", 19852 "onUpdate", 19853 "onDragStart", 19854 "onDrag", 19855 "onDragEnd", 19856 "onMeasureDragConstraints", 19857 "onDirectionLock", 19858 "onDragTransitionEnd", 19859 "_dragX", 19860 "_dragY", 19861 "onHoverStart", 19862 "onHoverEnd", 19863 "onViewportEnter", 19864 "onViewportLeave", 19865 "globalTapTarget", 19866 "ignoreStrict", 19867 "viewport" 19868 ]); 19869 function isValidMotionProp(key) { 19870 return key.startsWith("while") || key.startsWith("drag") && key !== "draggable" || key.startsWith("layout") || key.startsWith("onTap") || key.startsWith("onPan") || key.startsWith("onLayout") || validMotionProps.has(key); 19871 } 19872 19873 // packages/components/node_modules/framer-motion/dist/es/render/dom/utils/filter-props.mjs 19874 var shouldForward = (key) => !isValidMotionProp(key); 19875 function loadExternalIsValidProp(isValidProp) { 19876 if (!isValidProp) 19877 return; 19878 shouldForward = (key) => key.startsWith("on") ? !isValidMotionProp(key) : isValidProp(key); 19879 } 19880 try { 19881 loadExternalIsValidProp((init_emotion_is_prop_valid_esm(), __toCommonJS(emotion_is_prop_valid_esm_exports)).default); 19882 } catch (_a) { 19883 } 19884 function filterProps(props, isDom, forwardMotionProps) { 19885 const filteredProps = {}; 19886 for (const key in props) { 19887 if (key === "values" && typeof props.values === "object") 19888 continue; 19889 if (shouldForward(key) || forwardMotionProps === true && isValidMotionProp(key) || !isDom && !isValidMotionProp(key) || // If trying to use native HTML drag events, forward drag listeners 19890 props["draggable"] && key.startsWith("onDrag")) { 19891 filteredProps[key] = props[key]; 19892 } 19893 } 19894 return filteredProps; 19895 } 19896 19897 // packages/components/node_modules/framer-motion/dist/es/render/svg/use-props.mjs 19898 var import_react73 = __toESM(require_react(), 1); 19899 function useSVGProps(props, visualState, _isStatic, Component9) { 19900 const visualProps = (0, import_react73.useMemo)(() => { 19901 const state = createSvgRenderState(); 19902 buildSVGAttrs(state, visualState, isSVGTag(Component9), props.transformTemplate); 19903 return { 19904 ...state.attrs, 19905 style: { ...state.style } 19906 }; 19907 }, [visualState]); 19908 if (props.style) { 19909 const rawStyles = {}; 19910 copyRawValuesOnly(rawStyles, props.style, props); 19911 visualProps.style = { ...rawStyles, ...visualProps.style }; 19912 } 19913 return visualProps; 19914 } 19915 19916 // packages/components/node_modules/framer-motion/dist/es/render/dom/use-render.mjs 19917 function createUseRender(forwardMotionProps = false) { 19918 const useRender = (Component9, props, ref, { latestValues }, isStatic) => { 19919 const useVisualProps = isSVGComponent(Component9) ? useSVGProps : useHTMLProps; 19920 const visualProps = useVisualProps(props, latestValues, isStatic, Component9); 19921 const filteredProps = filterProps(props, typeof Component9 === "string", forwardMotionProps); 19922 const elementProps = Component9 !== import_react74.Fragment ? { ...filteredProps, ...visualProps, ref } : {}; 19923 const { children } = props; 19924 const renderedChildren = (0, import_react74.useMemo)(() => isMotionValue(children) ? children.get() : children, [children]); 19925 return (0, import_react74.createElement)(Component9, { 19926 ...elementProps, 19927 children: renderedChildren 19928 }); 19929 }; 19930 return useRender; 19931 } 19932 19933 // packages/components/node_modules/framer-motion/dist/es/render/components/create-factory.mjs 19934 function createMotionComponentFactory(preloadedFeatures, createVisualElement) { 19935 return function createMotionComponent2(Component9, { forwardMotionProps } = { forwardMotionProps: false }) { 19936 const baseConfig = isSVGComponent(Component9) ? svgMotionConfig : htmlMotionConfig; 19937 const config = { 19938 ...baseConfig, 19939 preloadedFeatures, 19940 useRender: createUseRender(forwardMotionProps), 19941 createVisualElement, 19942 Component: Component9 19943 }; 19944 return createRendererMotionComponent(config); 19945 }; 19946 } 19947 19948 // packages/components/node_modules/framer-motion/dist/es/render/dom/create-visual-element.mjs 19949 var import_react75 = __toESM(require_react(), 1); 19950 19951 // packages/components/node_modules/framer-motion/dist/es/utils/reduced-motion/state.mjs 19952 var prefersReducedMotion = { current: null }; 19953 var hasReducedMotionListener = { current: false }; 19954 19955 // packages/components/node_modules/framer-motion/dist/es/utils/reduced-motion/index.mjs 19956 function initPrefersReducedMotion() { 19957 hasReducedMotionListener.current = true; 19958 if (!isBrowser) 19959 return; 19960 if (window.matchMedia) { 19961 const motionMediaQuery = window.matchMedia("(prefers-reduced-motion)"); 19962 const setReducedMotionPreferences = () => prefersReducedMotion.current = motionMediaQuery.matches; 19963 motionMediaQuery.addListener(setReducedMotionPreferences); 19964 setReducedMotionPreferences(); 19965 } else { 19966 prefersReducedMotion.current = false; 19967 } 19968 } 19969 19970 // packages/components/node_modules/framer-motion/dist/es/render/utils/motion-values.mjs 19971 function updateMotionValuesFromProps(element, next2, prev2) { 19972 for (const key in next2) { 19973 const nextValue = next2[key]; 19974 const prevValue = prev2[key]; 19975 if (isMotionValue(nextValue)) { 19976 element.addValue(key, nextValue); 19977 if (true) { 19978 warnOnce(nextValue.version === "11.15.0", `Attempting to mix Motion versions $nextValue.version} with 11.15.0 may not work as expected.`); 19979 } 19980 } else if (isMotionValue(prevValue)) { 19981 element.addValue(key, motionValue(nextValue, { owner: element })); 19982 } else if (prevValue !== nextValue) { 19983 if (element.hasValue(key)) { 19984 const existingValue = element.getValue(key); 19985 if (existingValue.liveStyle === true) { 19986 existingValue.jump(nextValue); 19987 } else if (!existingValue.hasAnimated) { 19988 existingValue.set(nextValue); 19989 } 19990 } else { 19991 const latestValue = element.getStaticValue(key); 19992 element.addValue(key, motionValue(latestValue !== void 0 ? latestValue : nextValue, { owner: element })); 19993 } 19994 } 19995 } 19996 for (const key in prev2) { 19997 if (next2[key] === void 0) 19998 element.removeValue(key); 19999 } 20000 return next2; 20001 } 20002 20003 // packages/components/node_modules/framer-motion/dist/es/render/store.mjs 20004 var visualElementStore = /* @__PURE__ */ new WeakMap(); 20005 20006 // packages/components/node_modules/framer-motion/dist/es/render/dom/value-types/find.mjs 20007 var valueTypes = [...dimensionValueTypes, color, complex]; 20008 var findValueType = (v3) => valueTypes.find(testValueType(v3)); 20009 20010 // packages/components/node_modules/framer-motion/dist/es/render/VisualElement.mjs 20011 var propEventHandlers = [ 20012 "AnimationStart", 20013 "AnimationComplete", 20014 "Update", 20015 "BeforeLayoutMeasure", 20016 "LayoutMeasure", 20017 "LayoutAnimationStart", 20018 "LayoutAnimationComplete" 20019 ]; 20020 var VisualElement = class { 20021 /** 20022 * This method takes React props and returns found MotionValues. For example, HTML 20023 * MotionValues will be found within the style prop, whereas for Three.js within attribute arrays. 20024 * 20025 * This isn't an abstract method as it needs calling in the constructor, but it is 20026 * intended to be one. 20027 */ 20028 scrapeMotionValuesFromProps(_props, _prevProps, _visualElement) { 20029 return {}; 20030 } 20031 constructor({ parent, props, presenceContext, reducedMotionConfig, blockInitialAnimation, visualState }, options2 = {}) { 20032 this.current = null; 20033 this.children = /* @__PURE__ */ new Set(); 20034 this.isVariantNode = false; 20035 this.isControllingVariants = false; 20036 this.shouldReduceMotion = null; 20037 this.values = /* @__PURE__ */ new Map(); 20038 this.KeyframeResolver = KeyframeResolver; 20039 this.features = {}; 20040 this.valueSubscriptions = /* @__PURE__ */ new Map(); 20041 this.prevMotionValues = {}; 20042 this.events = {}; 20043 this.propEventSubscriptions = {}; 20044 this.notifyUpdate = () => this.notify("Update", this.latestValues); 20045 this.render = () => { 20046 if (!this.current) 20047 return; 20048 this.triggerBuild(); 20049 this.renderInstance(this.current, this.renderState, this.props.style, this.projection); 20050 }; 20051 this.renderScheduledAt = 0; 20052 this.scheduleRender = () => { 20053 const now2 = time.now(); 20054 if (this.renderScheduledAt < now2) { 20055 this.renderScheduledAt = now2; 20056 frame.render(this.render, false, true); 20057 } 20058 }; 20059 const { latestValues, renderState } = visualState; 20060 this.latestValues = latestValues; 20061 this.baseTarget = { ...latestValues }; 20062 this.initialValues = props.initial ? { ...latestValues } : {}; 20063 this.renderState = renderState; 20064 this.parent = parent; 20065 this.props = props; 20066 this.presenceContext = presenceContext; 20067 this.depth = parent ? parent.depth + 1 : 0; 20068 this.reducedMotionConfig = reducedMotionConfig; 20069 this.options = options2; 20070 this.blockInitialAnimation = Boolean(blockInitialAnimation); 20071 this.isControllingVariants = isControllingVariants(props); 20072 this.isVariantNode = isVariantNode(props); 20073 if (this.isVariantNode) { 20074 this.variantChildren = /* @__PURE__ */ new Set(); 20075 } 20076 this.manuallyAnimateOnMount = Boolean(parent && parent.current); 20077 const { willChange, ...initialMotionValues } = this.scrapeMotionValuesFromProps(props, {}, this); 20078 for (const key in initialMotionValues) { 20079 const value = initialMotionValues[key]; 20080 if (latestValues[key] !== void 0 && isMotionValue(value)) { 20081 value.set(latestValues[key], false); 20082 } 20083 } 20084 } 20085 mount(instance) { 20086 this.current = instance; 20087 visualElementStore.set(instance, this); 20088 if (this.projection && !this.projection.instance) { 20089 this.projection.mount(instance); 20090 } 20091 if (this.parent && this.isVariantNode && !this.isControllingVariants) { 20092 this.removeFromVariantTree = this.parent.addVariantChild(this); 20093 } 20094 this.values.forEach((value, key) => this.bindToMotionValue(key, value)); 20095 if (!hasReducedMotionListener.current) { 20096 initPrefersReducedMotion(); 20097 } 20098 this.shouldReduceMotion = this.reducedMotionConfig === "never" ? false : this.reducedMotionConfig === "always" ? true : prefersReducedMotion.current; 20099 if (true) { 20100 warnOnce(this.shouldReduceMotion !== true, "You have Reduced Motion enabled on your device. Animations may not appear as expected."); 20101 } 20102 if (this.parent) 20103 this.parent.children.add(this); 20104 this.update(this.props, this.presenceContext); 20105 } 20106 unmount() { 20107 visualElementStore.delete(this.current); 20108 this.projection && this.projection.unmount(); 20109 cancelFrame(this.notifyUpdate); 20110 cancelFrame(this.render); 20111 this.valueSubscriptions.forEach((remove) => remove()); 20112 this.valueSubscriptions.clear(); 20113 this.removeFromVariantTree && this.removeFromVariantTree(); 20114 this.parent && this.parent.children.delete(this); 20115 for (const key in this.events) { 20116 this.events[key].clear(); 20117 } 20118 for (const key in this.features) { 20119 const feature = this.features[key]; 20120 if (feature) { 20121 feature.unmount(); 20122 feature.isMounted = false; 20123 } 20124 } 20125 this.current = null; 20126 } 20127 bindToMotionValue(key, value) { 20128 if (this.valueSubscriptions.has(key)) { 20129 this.valueSubscriptions.get(key)(); 20130 } 20131 const valueIsTransform = transformProps.has(key); 20132 const removeOnChange = value.on("change", (latestValue) => { 20133 this.latestValues[key] = latestValue; 20134 this.props.onUpdate && frame.preRender(this.notifyUpdate); 20135 if (valueIsTransform && this.projection) { 20136 this.projection.isTransformDirty = true; 20137 } 20138 }); 20139 const removeOnRenderRequest = value.on("renderRequest", this.scheduleRender); 20140 let removeSyncCheck; 20141 if (window.MotionCheckAppearSync) { 20142 removeSyncCheck = window.MotionCheckAppearSync(this, key, value); 20143 } 20144 this.valueSubscriptions.set(key, () => { 20145 removeOnChange(); 20146 removeOnRenderRequest(); 20147 if (removeSyncCheck) 20148 removeSyncCheck(); 20149 if (value.owner) 20150 value.stop(); 20151 }); 20152 } 20153 sortNodePosition(other) { 20154 if (!this.current || !this.sortInstanceNodePosition || this.type !== other.type) { 20155 return 0; 20156 } 20157 return this.sortInstanceNodePosition(this.current, other.current); 20158 } 20159 updateFeatures() { 20160 let key = "animation"; 20161 for (key in featureDefinitions) { 20162 const featureDefinition = featureDefinitions[key]; 20163 if (!featureDefinition) 20164 continue; 20165 const { isEnabled, Feature: FeatureConstructor } = featureDefinition; 20166 if (!this.features[key] && FeatureConstructor && isEnabled(this.props)) { 20167 this.features[key] = new FeatureConstructor(this); 20168 } 20169 if (this.features[key]) { 20170 const feature = this.features[key]; 20171 if (feature.isMounted) { 20172 feature.update(); 20173 } else { 20174 feature.mount(); 20175 feature.isMounted = true; 20176 } 20177 } 20178 } 20179 } 20180 triggerBuild() { 20181 this.build(this.renderState, this.latestValues, this.props); 20182 } 20183 /** 20184 * Measure the current viewport box with or without transforms. 20185 * Only measures axis-aligned boxes, rotate and skew must be manually 20186 * removed with a re-render to work. 20187 */ 20188 measureViewportBox() { 20189 return this.current ? this.measureInstanceViewportBox(this.current, this.props) : createBox(); 20190 } 20191 getStaticValue(key) { 20192 return this.latestValues[key]; 20193 } 20194 setStaticValue(key, value) { 20195 this.latestValues[key] = value; 20196 } 20197 /** 20198 * Update the provided props. Ensure any newly-added motion values are 20199 * added to our map, old ones removed, and listeners updated. 20200 */ 20201 update(props, presenceContext) { 20202 if (props.transformTemplate || this.props.transformTemplate) { 20203 this.scheduleRender(); 20204 } 20205 this.prevProps = this.props; 20206 this.props = props; 20207 this.prevPresenceContext = this.presenceContext; 20208 this.presenceContext = presenceContext; 20209 for (let i3 = 0; i3 < propEventHandlers.length; i3++) { 20210 const key = propEventHandlers[i3]; 20211 if (this.propEventSubscriptions[key]) { 20212 this.propEventSubscriptions[key](); 20213 delete this.propEventSubscriptions[key]; 20214 } 20215 const listenerName = "on" + key; 20216 const listener = props[listenerName]; 20217 if (listener) { 20218 this.propEventSubscriptions[key] = this.on(key, listener); 20219 } 20220 } 20221 this.prevMotionValues = updateMotionValuesFromProps(this, this.scrapeMotionValuesFromProps(props, this.prevProps, this), this.prevMotionValues); 20222 if (this.handleChildMotionValue) { 20223 this.handleChildMotionValue(); 20224 } 20225 } 20226 getProps() { 20227 return this.props; 20228 } 20229 /** 20230 * Returns the variant definition with a given name. 20231 */ 20232 getVariant(name) { 20233 return this.props.variants ? this.props.variants[name] : void 0; 20234 } 20235 /** 20236 * Returns the defined default transition on this component. 20237 */ 20238 getDefaultTransition() { 20239 return this.props.transition; 20240 } 20241 getTransformPagePoint() { 20242 return this.props.transformPagePoint; 20243 } 20244 getClosestVariantNode() { 20245 return this.isVariantNode ? this : this.parent ? this.parent.getClosestVariantNode() : void 0; 20246 } 20247 /** 20248 * Add a child visual element to our set of children. 20249 */ 20250 addVariantChild(child) { 20251 const closestVariantNode = this.getClosestVariantNode(); 20252 if (closestVariantNode) { 20253 closestVariantNode.variantChildren && closestVariantNode.variantChildren.add(child); 20254 return () => closestVariantNode.variantChildren.delete(child); 20255 } 20256 } 20257 /** 20258 * Add a motion value and bind it to this visual element. 20259 */ 20260 addValue(key, value) { 20261 const existingValue = this.values.get(key); 20262 if (value !== existingValue) { 20263 if (existingValue) 20264 this.removeValue(key); 20265 this.bindToMotionValue(key, value); 20266 this.values.set(key, value); 20267 this.latestValues[key] = value.get(); 20268 } 20269 } 20270 /** 20271 * Remove a motion value and unbind any active subscriptions. 20272 */ 20273 removeValue(key) { 20274 this.values.delete(key); 20275 const unsubscribe = this.valueSubscriptions.get(key); 20276 if (unsubscribe) { 20277 unsubscribe(); 20278 this.valueSubscriptions.delete(key); 20279 } 20280 delete this.latestValues[key]; 20281 this.removeValueFromRenderState(key, this.renderState); 20282 } 20283 /** 20284 * Check whether we have a motion value for this key 20285 */ 20286 hasValue(key) { 20287 return this.values.has(key); 20288 } 20289 getValue(key, defaultValue2) { 20290 if (this.props.values && this.props.values[key]) { 20291 return this.props.values[key]; 20292 } 20293 let value = this.values.get(key); 20294 if (value === void 0 && defaultValue2 !== void 0) { 20295 value = motionValue(defaultValue2 === null ? void 0 : defaultValue2, { owner: this }); 20296 this.addValue(key, value); 20297 } 20298 return value; 20299 } 20300 /** 20301 * If we're trying to animate to a previously unencountered value, 20302 * we need to check for it in our state and as a last resort read it 20303 * directly from the instance (which might have performance implications). 20304 */ 20305 readValue(key, target) { 20306 var _a; 20307 let value = this.latestValues[key] !== void 0 || !this.current ? this.latestValues[key] : (_a = this.getBaseTargetFromProps(this.props, key)) !== null && _a !== void 0 ? _a : this.readValueFromInstance(this.current, key, this.options); 20308 if (value !== void 0 && value !== null) { 20309 if (typeof value === "string" && (isNumericalString(value) || isZeroValueString(value))) { 20310 value = parseFloat(value); 20311 } else if (!findValueType(value) && complex.test(target)) { 20312 value = getAnimatableNone2(key, target); 20313 } 20314 this.setBaseTarget(key, isMotionValue(value) ? value.get() : value); 20315 } 20316 return isMotionValue(value) ? value.get() : value; 20317 } 20318 /** 20319 * Set the base target to later animate back to. This is currently 20320 * only hydrated on creation and when we first read a value. 20321 */ 20322 setBaseTarget(key, value) { 20323 this.baseTarget[key] = value; 20324 } 20325 /** 20326 * Find the base target for a value thats been removed from all animation 20327 * props. 20328 */ 20329 getBaseTarget(key) { 20330 var _a; 20331 const { initial } = this.props; 20332 let valueFromInitial; 20333 if (typeof initial === "string" || typeof initial === "object") { 20334 const variant = resolveVariantFromProps(this.props, initial, (_a = this.presenceContext) === null || _a === void 0 ? void 0 : _a.custom); 20335 if (variant) { 20336 valueFromInitial = variant[key]; 20337 } 20338 } 20339 if (initial && valueFromInitial !== void 0) { 20340 return valueFromInitial; 20341 } 20342 const target = this.getBaseTargetFromProps(this.props, key); 20343 if (target !== void 0 && !isMotionValue(target)) 20344 return target; 20345 return this.initialValues[key] !== void 0 && valueFromInitial === void 0 ? void 0 : this.baseTarget[key]; 20346 } 20347 on(eventName, callback) { 20348 if (!this.events[eventName]) { 20349 this.events[eventName] = new SubscriptionManager(); 20350 } 20351 return this.events[eventName].add(callback); 20352 } 20353 notify(eventName, ...args) { 20354 if (this.events[eventName]) { 20355 this.events[eventName].notify(...args); 20356 } 20357 } 20358 }; 20359 20360 // packages/components/node_modules/framer-motion/dist/es/render/dom/DOMVisualElement.mjs 20361 var DOMVisualElement = class extends VisualElement { 20362 constructor() { 20363 super(...arguments); 20364 this.KeyframeResolver = DOMKeyframesResolver; 20365 } 20366 sortInstanceNodePosition(a3, b3) { 20367 return a3.compareDocumentPosition(b3) & 2 ? 1 : -1; 20368 } 20369 getBaseTargetFromProps(props, key) { 20370 return props.style ? props.style[key] : void 0; 20371 } 20372 removeValueFromRenderState(key, { vars, style: style2 }) { 20373 delete vars[key]; 20374 delete style2[key]; 20375 } 20376 handleChildMotionValue() { 20377 if (this.childSubscription) { 20378 this.childSubscription(); 20379 delete this.childSubscription; 20380 } 20381 const { children } = this.props; 20382 if (isMotionValue(children)) { 20383 this.childSubscription = children.on("change", (latest) => { 20384 if (this.current) { 20385 this.current.textContent = `$latest}`; 20386 } 20387 }); 20388 } 20389 } 20390 }; 20391 20392 // packages/components/node_modules/framer-motion/dist/es/render/html/HTMLVisualElement.mjs 20393 function getComputedStyle3(element) { 20394 return window.getComputedStyle(element); 20395 } 20396 var HTMLVisualElement = class extends DOMVisualElement { 20397 constructor() { 20398 super(...arguments); 20399 this.type = "html"; 20400 this.renderInstance = renderHTML; 20401 } 20402 readValueFromInstance(instance, key) { 20403 if (transformProps.has(key)) { 20404 const defaultType = getDefaultValueType(key); 20405 return defaultType ? defaultType.default || 0 : 0; 20406 } else { 20407 const computedStyle = getComputedStyle3(instance); 20408 const value = (isCSSVariableName(key) ? computedStyle.getPropertyValue(key) : computedStyle[key]) || 0; 20409 return typeof value === "string" ? value.trim() : value; 20410 } 20411 } 20412 measureInstanceViewportBox(instance, { transformPagePoint }) { 20413 return measureViewportBox(instance, transformPagePoint); 20414 } 20415 build(renderState, latestValues, props) { 20416 buildHTMLStyles(renderState, latestValues, props.transformTemplate); 20417 } 20418 scrapeMotionValuesFromProps(props, prevProps, visualElement) { 20419 return scrapeMotionValuesFromProps(props, prevProps, visualElement); 20420 } 20421 }; 20422 20423 // packages/components/node_modules/framer-motion/dist/es/render/svg/SVGVisualElement.mjs 20424 var SVGVisualElement = class extends DOMVisualElement { 20425 constructor() { 20426 super(...arguments); 20427 this.type = "svg"; 20428 this.isSVGTag = false; 20429 this.measureInstanceViewportBox = createBox; 20430 } 20431 getBaseTargetFromProps(props, key) { 20432 return props[key]; 20433 } 20434 readValueFromInstance(instance, key) { 20435 if (transformProps.has(key)) { 20436 const defaultType = getDefaultValueType(key); 20437 return defaultType ? defaultType.default || 0 : 0; 20438 } 20439 key = !camelCaseAttributes.has(key) ? camelToDash(key) : key; 20440 return instance.getAttribute(key); 20441 } 20442 scrapeMotionValuesFromProps(props, prevProps, visualElement) { 20443 return scrapeMotionValuesFromProps2(props, prevProps, visualElement); 20444 } 20445 build(renderState, latestValues, props) { 20446 buildSVGAttrs(renderState, latestValues, this.isSVGTag, props.transformTemplate); 20447 } 20448 renderInstance(instance, renderState, styleProp, projection) { 20449 renderSVG(instance, renderState, styleProp, projection); 20450 } 20451 mount(instance) { 20452 this.isSVGTag = isSVGTag(instance.tagName); 20453 super.mount(instance); 20454 } 20455 }; 20456 20457 // packages/components/node_modules/framer-motion/dist/es/render/dom/create-visual-element.mjs 20458 var createDomVisualElement = (Component9, options2) => { 20459 return isSVGComponent(Component9) ? new SVGVisualElement(options2) : new HTMLVisualElement(options2, { 20460 allowProjection: Component9 !== import_react75.Fragment 20461 }); 20462 }; 20463 20464 // packages/components/node_modules/framer-motion/dist/es/render/components/motion/create.mjs 20465 var createMotionComponent = /* @__PURE__ */ createMotionComponentFactory({ 20466 ...animations, 20467 ...gestureAnimations, 20468 ...drag, 20469 ...layout 20470 }, createDomVisualElement); 20471 20472 // packages/components/node_modules/framer-motion/dist/es/render/components/motion/proxy.mjs 20473 var motion = /* @__PURE__ */ createDOMMotionComponentProxy(createMotionComponent); 20474 20475 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/index.mjs 20476 var import_jsx_runtime43 = __toESM(require_jsx_runtime(), 1); 20477 var import_react79 = __toESM(require_react(), 1); 20478 20479 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/PresenceChild.mjs 20480 var import_jsx_runtime42 = __toESM(require_jsx_runtime(), 1); 20481 var React5 = __toESM(require_react(), 1); 20482 var import_react77 = __toESM(require_react(), 1); 20483 20484 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/PopChild.mjs 20485 var import_jsx_runtime41 = __toESM(require_jsx_runtime(), 1); 20486 var React4 = __toESM(require_react(), 1); 20487 var import_react76 = __toESM(require_react(), 1); 20488 var PopChildMeasure = class extends React4.Component { 20489 getSnapshotBeforeUpdate(prevProps) { 20490 const element = this.props.childRef.current; 20491 if (element && prevProps.isPresent && !this.props.isPresent) { 20492 const size3 = this.props.sizeRef.current; 20493 size3.height = element.offsetHeight || 0; 20494 size3.width = element.offsetWidth || 0; 20495 size3.top = element.offsetTop; 20496 size3.left = element.offsetLeft; 20497 } 20498 return null; 20499 } 20500 /** 20501 * Required with getSnapshotBeforeUpdate to stop React complaining. 20502 */ 20503 componentDidUpdate() { 20504 } 20505 render() { 20506 return this.props.children; 20507 } 20508 }; 20509 function PopChild({ children, isPresent }) { 20510 const id3 = (0, import_react76.useId)(); 20511 const ref = (0, import_react76.useRef)(null); 20512 const size3 = (0, import_react76.useRef)({ 20513 width: 0, 20514 height: 0, 20515 top: 0, 20516 left: 0 20517 }); 20518 const { nonce } = (0, import_react76.useContext)(MotionConfigContext); 20519 (0, import_react76.useInsertionEffect)(() => { 20520 const { width, height, top, left } = size3.current; 20521 if (isPresent || !ref.current || !width || !height) 20522 return; 20523 ref.current.dataset.motionPopId = id3; 20524 const style2 = document.createElement("style"); 20525 if (nonce) 20526 style2.nonce = nonce; 20527 document.head.appendChild(style2); 20528 if (style2.sheet) { 20529 style2.sheet.insertRule(` 20530 [data-motion-pop-id="$id3}"] { 20531 position: absolute !important; 20532 width: $width}px !important; 20533 height: $height}px !important; 20534 top: $top}px !important; 20535 left: $left}px !important; 20536 } 20537 `); 20538 } 20539 return () => { 20540 document.head.removeChild(style2); 20541 }; 20542 }, [isPresent]); 20543 return (0, import_jsx_runtime41.jsx)(PopChildMeasure, { isPresent, childRef: ref, sizeRef: size3, children: React4.cloneElement(children, { ref }) }); 20544 } 20545 20546 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/PresenceChild.mjs 20547 var PresenceChild = ({ children, initial, isPresent, onExitComplete, custom, presenceAffectsLayout, mode: mode2 }) => { 20548 const presenceChildren = useConstant(newChildrenMap); 20549 const id3 = (0, import_react77.useId)(); 20550 const memoizedOnExitComplete = (0, import_react77.useCallback)((childId) => { 20551 presenceChildren.set(childId, true); 20552 for (const isComplete of presenceChildren.values()) { 20553 if (!isComplete) 20554 return; 20555 } 20556 onExitComplete && onExitComplete(); 20557 }, [presenceChildren, onExitComplete]); 20558 const context = (0, import_react77.useMemo)( 20559 () => ({ 20560 id: id3, 20561 initial, 20562 isPresent, 20563 custom, 20564 onExitComplete: memoizedOnExitComplete, 20565 register: (childId) => { 20566 presenceChildren.set(childId, false); 20567 return () => presenceChildren.delete(childId); 20568 } 20569 }), 20570 /** 20571 * If the presence of a child affects the layout of the components around it, 20572 * we want to make a new context value to ensure they get re-rendered 20573 * so they can detect that layout change. 20574 */ 20575 presenceAffectsLayout ? [Math.random(), memoizedOnExitComplete] : [isPresent, memoizedOnExitComplete] 20576 ); 20577 (0, import_react77.useMemo)(() => { 20578 presenceChildren.forEach((_, key) => presenceChildren.set(key, false)); 20579 }, [isPresent]); 20580 React5.useEffect(() => { 20581 !isPresent && !presenceChildren.size && onExitComplete && onExitComplete(); 20582 }, [isPresent]); 20583 if (mode2 === "popLayout") { 20584 children = (0, import_jsx_runtime42.jsx)(PopChild, { isPresent, children }); 20585 } 20586 return (0, import_jsx_runtime42.jsx)(PresenceContext.Provider, { value: context, children }); 20587 }; 20588 function newChildrenMap() { 20589 return /* @__PURE__ */ new Map(); 20590 } 20591 20592 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/utils.mjs 20593 var import_react78 = __toESM(require_react(), 1); 20594 var getChildKey = (child) => child.key || ""; 20595 function onlyElements(children) { 20596 const filtered = []; 20597 import_react78.Children.forEach(children, (child) => { 20598 if ((0, import_react78.isValidElement)(child)) 20599 filtered.push(child); 20600 }); 20601 return filtered; 20602 } 20603 20604 // packages/components/node_modules/framer-motion/dist/es/components/AnimatePresence/index.mjs 20605 var AnimatePresence = ({ children, exitBeforeEnter, custom, initial = true, onExitComplete, presenceAffectsLayout = true, mode: mode2 = "sync" }) => { 20606 invariant2(!exitBeforeEnter, "Replace exitBeforeEnter with mode='wait'"); 20607 const presentChildren = (0, import_react79.useMemo)(() => onlyElements(children), [children]); 20608 const presentKeys = presentChildren.map(getChildKey); 20609 const isInitialRender = (0, import_react79.useRef)(true); 20610 const pendingPresentChildren = (0, import_react79.useRef)(presentChildren); 20611 const exitComplete = useConstant(() => /* @__PURE__ */ new Map()); 20612 const [diffedChildren, setDiffedChildren] = (0, import_react79.useState)(presentChildren); 20613 const [renderedChildren, setRenderedChildren] = (0, import_react79.useState)(presentChildren); 20614 useIsomorphicLayoutEffect(() => { 20615 isInitialRender.current = false; 20616 pendingPresentChildren.current = presentChildren; 20617 for (let i3 = 0; i3 < renderedChildren.length; i3++) { 20618 const key = getChildKey(renderedChildren[i3]); 20619 if (!presentKeys.includes(key)) { 20620 if (exitComplete.get(key) !== true) { 20621 exitComplete.set(key, false); 20622 } 20623 } else { 20624 exitComplete.delete(key); 20625 } 20626 } 20627 }, [renderedChildren, presentKeys.length, presentKeys.join("-")]); 20628 const exitingChildren = []; 20629 if (presentChildren !== diffedChildren) { 20630 let nextChildren = [...presentChildren]; 20631 for (let i3 = 0; i3 < renderedChildren.length; i3++) { 20632 const child = renderedChildren[i3]; 20633 const key = getChildKey(child); 20634 if (!presentKeys.includes(key)) { 20635 nextChildren.splice(i3, 0, child); 20636 exitingChildren.push(child); 20637 } 20638 } 20639 if (mode2 === "wait" && exitingChildren.length) { 20640 nextChildren = exitingChildren; 20641 } 20642 setRenderedChildren(onlyElements(nextChildren)); 20643 setDiffedChildren(presentChildren); 20644 return; 20645 } 20646 if (mode2 === "wait" && renderedChildren.length > 1) { 20647 console.warn(`You're attempting to animate multiple children within AnimatePresence, but its mode is set to "wait". This will lead to odd visual behaviour.`); 20648 } 20649 const { forceRender } = (0, import_react79.useContext)(LayoutGroupContext); 20650 return (0, import_jsx_runtime43.jsx)(import_jsx_runtime43.Fragment, { children: renderedChildren.map((child) => { 20651 const key = getChildKey(child); 20652 const isPresent = presentChildren === renderedChildren || presentKeys.includes(key); 20653 const onExit = () => { 20654 if (exitComplete.has(key)) { 20655 exitComplete.set(key, true); 20656 } else { 20657 return; 20658 } 20659 let isEveryExitComplete = true; 20660 exitComplete.forEach((isExitComplete) => { 20661 if (!isExitComplete) 20662 isEveryExitComplete = false; 20663 }); 20664 if (isEveryExitComplete) { 20665 forceRender === null || forceRender === void 0 ? void 0 : forceRender(); 20666 setRenderedChildren(pendingPresentChildren.current); 20667 onExitComplete && onExitComplete(); 20668 } 20669 }; 20670 return (0, import_jsx_runtime43.jsx)(PresenceChild, { isPresent, initial: !isInitialRender.current || initial ? void 0 : false, custom: isPresent ? void 0 : custom, presenceAffectsLayout, mode: mode2, onExitComplete: isPresent ? void 0 : onExit, children: child }, key); 20671 }) }); 20672 }; 20673 20674 // packages/components/build-module/popover/utils.js 20675 var POSITION_TO_PLACEMENT = { 20676 bottom: "bottom", 20677 top: "top", 20678 "middle left": "left", 20679 "middle right": "right", 20680 "bottom left": "bottom-end", 20681 "bottom center": "bottom", 20682 "bottom right": "bottom-start", 20683 "top left": "top-end", 20684 "top center": "top", 20685 "top right": "top-start", 20686 "middle left left": "left", 20687 "middle left right": "left", 20688 "middle left bottom": "left-end", 20689 "middle left top": "left-start", 20690 "middle right left": "right", 20691 "middle right right": "right", 20692 "middle right bottom": "right-end", 20693 "middle right top": "right-start", 20694 "bottom left left": "bottom-end", 20695 "bottom left right": "bottom-end", 20696 "bottom left bottom": "bottom-end", 20697 "bottom left top": "bottom-end", 20698 "bottom center left": "bottom", 20699 "bottom center right": "bottom", 20700 "bottom center bottom": "bottom", 20701 "bottom center top": "bottom", 20702 "bottom right left": "bottom-start", 20703 "bottom right right": "bottom-start", 20704 "bottom right bottom": "bottom-start", 20705 "bottom right top": "bottom-start", 20706 "top left left": "top-end", 20707 "top left right": "top-end", 20708 "top left bottom": "top-end", 20709 "top left top": "top-end", 20710 "top center left": "top", 20711 "top center right": "top", 20712 "top center bottom": "top", 20713 "top center top": "top", 20714 "top right left": "top-start", 20715 "top right right": "top-start", 20716 "top right bottom": "top-start", 20717 "top right top": "top-start", 20718 // `middle`/`middle center [corner?]` positions are associated to a fallback 20719 // `bottom` placement because there aren't any corresponding placement values. 20720 middle: "bottom", 20721 "middle center": "bottom", 20722 "middle center bottom": "bottom", 20723 "middle center left": "bottom", 20724 "middle center right": "bottom", 20725 "middle center top": "bottom" 20726 }; 20727 var positionToPlacement = (position2) => { 20728 var _POSITION_TO_PLACEMEN; 20729 return (_POSITION_TO_PLACEMEN = POSITION_TO_PLACEMENT[position2]) !== null && _POSITION_TO_PLACEMEN !== void 0 ? _POSITION_TO_PLACEMEN : "bottom"; 20730 }; 20731 var PLACEMENT_TO_ANIMATION_ORIGIN = { 20732 top: { 20733 originX: 0.5, 20734 originY: 1 20735 }, 20736 // open from bottom, center 20737 "top-start": { 20738 originX: 0, 20739 originY: 1 20740 }, 20741 // open from bottom, left 20742 "top-end": { 20743 originX: 1, 20744 originY: 1 20745 }, 20746 // open from bottom, right 20747 right: { 20748 originX: 0, 20749 originY: 0.5 20750 }, 20751 // open from middle, left 20752 "right-start": { 20753 originX: 0, 20754 originY: 0 20755 }, 20756 // open from top, left 20757 "right-end": { 20758 originX: 0, 20759 originY: 1 20760 }, 20761 // open from bottom, left 20762 bottom: { 20763 originX: 0.5, 20764 originY: 0 20765 }, 20766 // open from top, center 20767 "bottom-start": { 20768 originX: 0, 20769 originY: 0 20770 }, 20771 // open from top, left 20772 "bottom-end": { 20773 originX: 1, 20774 originY: 0 20775 }, 20776 // open from top, right 20777 left: { 20778 originX: 1, 20779 originY: 0.5 20780 }, 20781 // open from middle, right 20782 "left-start": { 20783 originX: 1, 20784 originY: 0 20785 }, 20786 // open from top, right 20787 "left-end": { 20788 originX: 1, 20789 originY: 1 20790 }, 20791 // open from bottom, right 20792 overlay: { 20793 originX: 0.5, 20794 originY: 0.5 20795 } 20796 // open from center, center 20797 }; 20798 var placementToMotionAnimationProps = (placement) => { 20799 const translateProp = placement.startsWith("top") || placement.startsWith("bottom") ? "translateY" : "translateX"; 20800 const translateDirection = placement.startsWith("top") || placement.startsWith("left") ? 1 : -1; 20801 return { 20802 style: PLACEMENT_TO_ANIMATION_ORIGIN[placement], 20803 initial: { 20804 opacity: 0, 20805 [translateProp]: `$4 * translateDirection}px` 20806 }, 20807 animate: { 20808 opacity: 1, 20809 [translateProp]: 0 20810 }, 20811 transition: { 20812 opacity: { 20813 duration: 0.08, 20814 ease: "linear" 20815 }, 20816 [translateProp]: { 20817 duration: 0.3, 20818 ease: cubicBezier(0, 0, 0, 1) 20819 } 20820 } 20821 }; 20822 }; 20823 function isTopBottom(anchorRef) { 20824 return !!anchorRef?.top; 20825 } 20826 function isRef(anchorRef) { 20827 return !!anchorRef?.current; 20828 } 20829 var getReferenceElement = ({ 20830 anchor, 20831 anchorRef, 20832 anchorRect, 20833 getAnchorRect, 20834 fallbackReferenceElement 20835 }) => { 20836 var _referenceElement; 20837 let referenceElement = null; 20838 if (anchor) { 20839 referenceElement = anchor; 20840 } else if (isTopBottom(anchorRef)) { 20841 referenceElement = { 20842 getBoundingClientRect() { 20843 const topRect = anchorRef.top.getBoundingClientRect(); 20844 const bottomRect = anchorRef.bottom.getBoundingClientRect(); 20845 return new window.DOMRect(topRect.x, topRect.y, topRect.width, bottomRect.bottom - topRect.top); 20846 } 20847 }; 20848 } else if (isRef(anchorRef)) { 20849 referenceElement = anchorRef.current; 20850 } else if (anchorRef) { 20851 referenceElement = anchorRef; 20852 } else if (anchorRect) { 20853 referenceElement = { 20854 getBoundingClientRect() { 20855 return anchorRect; 20856 } 20857 }; 20858 } else if (getAnchorRect) { 20859 referenceElement = { 20860 getBoundingClientRect() { 20861 var _rect$x, _rect$y, _rect$width, _rect$height; 20862 const rect = getAnchorRect(fallbackReferenceElement); 20863 return new window.DOMRect((_rect$x = rect.x) !== null && _rect$x !== void 0 ? _rect$x : rect.left, (_rect$y = rect.y) !== null && _rect$y !== void 0 ? _rect$y : rect.top, (_rect$width = rect.width) !== null && _rect$width !== void 0 ? _rect$width : rect.right - rect.left, (_rect$height = rect.height) !== null && _rect$height !== void 0 ? _rect$height : rect.bottom - rect.top); 20864 } 20865 }; 20866 } else if (fallbackReferenceElement) { 20867 referenceElement = fallbackReferenceElement.parentElement; 20868 } 20869 return (_referenceElement = referenceElement) !== null && _referenceElement !== void 0 ? _referenceElement : null; 20870 }; 20871 var computePopoverPosition = (c3) => c3 === null || Number.isNaN(c3) ? void 0 : Math.round(c3); 20872 20873 // packages/components/build-module/tooltip/index.js 20874 var import_jsx_runtime44 = __toESM(require_jsx_runtime()); 20875 var TooltipInternalContext = (0, import_element9.createContext)({ 20876 isNestedInTooltip: false 20877 }); 20878 TooltipInternalContext.displayName = "TooltipInternalContext"; 20879 var TOOLTIP_DELAY = 700; 20880 var CONTEXT_VALUE = { 20881 isNestedInTooltip: true 20882 }; 20883 function UnforwardedTooltip(props, ref) { 20884 const { 20885 children, 20886 className: className2, 20887 delay: delay2 = TOOLTIP_DELAY, 20888 hideOnClick = true, 20889 placement, 20890 position: position2, 20891 shortcut, 20892 text, 20893 ...restProps 20894 } = props; 20895 const { 20896 isNestedInTooltip 20897 } = (0, import_element9.useContext)(TooltipInternalContext); 20898 const baseId = (0, import_compose.useInstanceId)(Tooltip22, "tooltip"); 20899 const describedById = text || shortcut ? baseId : void 0; 20900 const isOnlyChild = import_element9.Children.count(children) === 1; 20901 if (!isOnlyChild) { 20902 if (true) { 20903 console.error("wp-components.Tooltip should be called with only a single child element."); 20904 } 20905 } 20906 let computedPlacement; 20907 if (placement !== void 0) { 20908 computedPlacement = placement; 20909 } else if (position2 !== void 0) { 20910 computedPlacement = positionToPlacement(position2); 20911 (0, import_deprecated.default)("`position` prop in wp.components.tooltip", { 20912 since: "6.4", 20913 alternative: "`placement` prop" 20914 }); 20915 } 20916 computedPlacement = computedPlacement || "bottom"; 20917 const tooltipStore = useTooltipStore({ 20918 placement: computedPlacement, 20919 showTimeout: delay2 20920 }); 20921 const mounted = useStoreState(tooltipStore, "mounted"); 20922 if (isNestedInTooltip) { 20923 return isOnlyChild ? /* @__PURE__ */ (0, import_jsx_runtime44.jsx)(Role, { 20924 ...restProps, 20925 render: children 20926 }) : children; 20927 } 20928 function addDescribedById(element) { 20929 return describedById && mounted && element.props["aria-describedby"] === void 0 && element.props["aria-label"] !== text ? (0, import_element9.cloneElement)(element, { 20930 "aria-describedby": describedById 20931 }) : element; 20932 } 20933 return /* @__PURE__ */ (0, import_jsx_runtime44.jsxs)(TooltipInternalContext.Provider, { 20934 value: CONTEXT_VALUE, 20935 children: [/* @__PURE__ */ (0, import_jsx_runtime44.jsx)(TooltipAnchor, { 20936 onClick: hideOnClick ? tooltipStore.hide : void 0, 20937 store: tooltipStore, 20938 render: isOnlyChild ? addDescribedById(children) : void 0, 20939 ref, 20940 children: isOnlyChild ? void 0 : children 20941 }), isOnlyChild && (text || shortcut) && /* @__PURE__ */ (0, import_jsx_runtime44.jsxs)(Tooltip, { 20942 ...restProps, 20943 className: clsx_default("components-tooltip", className2), 20944 unmountOnHide: true, 20945 gutter: 4, 20946 id: describedById, 20947 overflowPadding: 0.5, 20948 store: tooltipStore, 20949 children: [text, shortcut && /* @__PURE__ */ (0, import_jsx_runtime44.jsx)(shortcut_default, { 20950 className: text ? "components-tooltip__shortcut" : "", 20951 shortcut 20952 })] 20953 })] 20954 }); 20955 } 20956 var Tooltip22 = (0, import_element9.forwardRef)(UnforwardedTooltip); 20957 var tooltip_default = Tooltip22; 20958 20959 // packages/components/build-module/context/context-system-provider.js 20960 var import_deepmerge = __toESM(require_cjs()); 20961 var import_es6 = __toESM(require_es6()); 20962 20963 // node_modules/is-plain-object/dist/is-plain-object.mjs 20964 function isObject2(o4) { 20965 return Object.prototype.toString.call(o4) === "[object Object]"; 20966 } 20967 function isPlainObject(o4) { 20968 var ctor, prot; 20969 if (isObject2(o4) === false) return false; 20970 ctor = o4.constructor; 20971 if (ctor === void 0) return true; 20972 prot = ctor.prototype; 20973 if (isObject2(prot) === false) return false; 20974 if (prot.hasOwnProperty("isPrototypeOf") === false) { 20975 return false; 20976 } 20977 return true; 20978 } 20979 20980 // packages/components/build-module/context/context-system-provider.js 20981 var import_element14 = __toESM(require_element()); 20982 var import_warning = __toESM(require_warning()); 20983 20984 // packages/components/build-module/utils/hooks/use-controlled-state.js 20985 var import_element10 = __toESM(require_element()); 20986 20987 // packages/components/build-module/utils/values.js 20988 function isValueDefined(value) { 20989 return value !== void 0 && value !== null; 20990 } 20991 function isValueEmpty(value) { 20992 const isEmptyString = value === ""; 20993 return !isValueDefined(value) || isEmptyString; 20994 } 20995 function getDefinedValue(values = [], fallbackValue) { 20996 var _values$find; 20997 return (_values$find = values.find(isValueDefined)) !== null && _values$find !== void 0 ? _values$find : fallbackValue; 20998 } 20999 var stringToNumber = (value) => { 21000 return parseFloat(value); 21001 }; 21002 var ensureNumber = (value) => { 21003 return typeof value === "string" ? stringToNumber(value) : value; 21004 }; 21005 21006 // packages/components/build-module/utils/hooks/use-controlled-state.js 21007 var defaultOptions = { 21008 initial: void 0, 21009 /** 21010 * Defaults to empty string, as that is preferred for usage with 21011 * <input />, <textarea />, and <select /> form elements. 21012 */ 21013 fallback: "" 21014 }; 21015 function useControlledState(currentState, options2 = defaultOptions) { 21016 const { 21017 initial, 21018 fallback 21019 } = { 21020 ...defaultOptions, 21021 ...options2 21022 }; 21023 const [internalState, setInternalState] = (0, import_element10.useState)(currentState); 21024 const hasCurrentState = isValueDefined(currentState); 21025 (0, import_element10.useEffect)(() => { 21026 if (hasCurrentState && internalState) { 21027 setInternalState(void 0); 21028 } 21029 }, [hasCurrentState, internalState]); 21030 const state = getDefinedValue([currentState, internalState, initial], fallback); 21031 const setState = (0, import_element10.useCallback)((nextState) => { 21032 if (!hasCurrentState) { 21033 setInternalState(nextState); 21034 } 21035 }, [hasCurrentState]); 21036 return [state, setState]; 21037 } 21038 var use_controlled_state_default = useControlledState; 21039 21040 // packages/components/build-module/utils/hooks/use-update-effect.js 21041 var import_element11 = __toESM(require_element()); 21042 function useUpdateEffect2(effect, deps) { 21043 const mountedRef = (0, import_element11.useRef)(false); 21044 (0, import_element11.useEffect)(() => { 21045 if (mountedRef.current) { 21046 return effect(); 21047 } 21048 mountedRef.current = true; 21049 return void 0; 21050 }, deps); 21051 (0, import_element11.useEffect)(() => () => { 21052 mountedRef.current = false; 21053 }, []); 21054 } 21055 var use_update_effect_default = useUpdateEffect2; 21056 21057 // packages/components/build-module/utils/hooks/use-controlled-value.js 21058 var import_element12 = __toESM(require_element()); 21059 function useControlledValue({ 21060 defaultValue: defaultValue2, 21061 onChange, 21062 value: valueProp 21063 }) { 21064 const hasValue = typeof valueProp !== "undefined"; 21065 const initialValue2 = hasValue ? valueProp : defaultValue2; 21066 const [state, setState] = (0, import_element12.useState)(initialValue2); 21067 const value = hasValue ? valueProp : state; 21068 const uncontrolledSetValue = (0, import_element12.useCallback)((nextValue, ...args) => { 21069 setState(nextValue); 21070 onChange?.(nextValue, ...args); 21071 }, [onChange]); 21072 let setValue; 21073 if (hasValue && typeof onChange === "function") { 21074 setValue = onChange; 21075 } else if (!hasValue && typeof onChange === "function") { 21076 setValue = uncontrolledSetValue; 21077 } else { 21078 setValue = setState; 21079 } 21080 return [value, setValue]; 21081 } 21082 21083 // node_modules/@emotion/react/dist/emotion-react.browser.esm.js 21084 var import_react81 = __toESM(require_react()); 21085 21086 // node_modules/@emotion/sheet/dist/emotion-sheet.browser.esm.js 21087 function sheetForTag(tag) { 21088 if (tag.sheet) { 21089 return tag.sheet; 21090 } 21091 for (var i3 = 0; i3 < document.styleSheets.length; i3++) { 21092 if (document.styleSheets[i3].ownerNode === tag) { 21093 return document.styleSheets[i3]; 21094 } 21095 } 21096 } 21097 function createStyleElement(options2) { 21098 var tag = document.createElement("style"); 21099 tag.setAttribute("data-emotion", options2.key); 21100 if (options2.nonce !== void 0) { 21101 tag.setAttribute("nonce", options2.nonce); 21102 } 21103 tag.appendChild(document.createTextNode("")); 21104 tag.setAttribute("data-s", ""); 21105 return tag; 21106 } 21107 var StyleSheet = /* @__PURE__ */ (function() { 21108 function StyleSheet2(options2) { 21109 var _this = this; 21110 this._insertTag = function(tag) { 21111 var before; 21112 if (_this.tags.length === 0) { 21113 if (_this.insertionPoint) { 21114 before = _this.insertionPoint.nextSibling; 21115 } else if (_this.prepend) { 21116 before = _this.container.firstChild; 21117 } else { 21118 before = _this.before; 21119 } 21120 } else { 21121 before = _this.tags[_this.tags.length - 1].nextSibling; 21122 } 21123 _this.container.insertBefore(tag, before); 21124 _this.tags.push(tag); 21125 }; 21126 this.isSpeedy = options2.speedy === void 0 ? false : options2.speedy; 21127 this.tags = []; 21128 this.ctr = 0; 21129 this.nonce = options2.nonce; 21130 this.key = options2.key; 21131 this.container = options2.container; 21132 this.prepend = options2.prepend; 21133 this.insertionPoint = options2.insertionPoint; 21134 this.before = null; 21135 } 21136 var _proto = StyleSheet2.prototype; 21137 _proto.hydrate = function hydrate2(nodes) { 21138 nodes.forEach(this._insertTag); 21139 }; 21140 _proto.insert = function insert2(rule) { 21141 if (this.ctr % (this.isSpeedy ? 65e3 : 1) === 0) { 21142 this._insertTag(createStyleElement(this)); 21143 } 21144 var tag = this.tags[this.tags.length - 1]; 21145 if (true) { 21146 var isImportRule3 = rule.charCodeAt(0) === 64 && rule.charCodeAt(1) === 105; 21147 if (isImportRule3 && this._alreadyInsertedOrderInsensitiveRule) { 21148 console.error("You're attempting to insert the following rule:\n" + rule + "\n\n`@import` rules must be before all other types of rules in a stylesheet but other rules have already been inserted. Please ensure that `@import` rules are before all other rules."); 21149 } 21150 this._alreadyInsertedOrderInsensitiveRule = this._alreadyInsertedOrderInsensitiveRule || !isImportRule3; 21151 } 21152 if (this.isSpeedy) { 21153 var sheet2 = sheetForTag(tag); 21154 try { 21155 sheet2.insertRule(rule, sheet2.cssRules.length); 21156 } catch (e3) { 21157 if (!/:(-moz-placeholder|-moz-focus-inner|-moz-focusring|-ms-input-placeholder|-moz-read-write|-moz-read-only|-ms-clear){/.test(rule)) { 21158 console.error('There was a problem inserting the following rule: "' + rule + '"', e3); 21159 } 21160 } 21161 } else { 21162 tag.appendChild(document.createTextNode(rule)); 21163 } 21164 this.ctr++; 21165 }; 21166 _proto.flush = function flush2() { 21167 this.tags.forEach(function(tag) { 21168 return tag.parentNode && tag.parentNode.removeChild(tag); 21169 }); 21170 this.tags = []; 21171 this.ctr = 0; 21172 if (true) { 21173 this._alreadyInsertedOrderInsensitiveRule = false; 21174 } 21175 }; 21176 return StyleSheet2; 21177 })(); 21178 21179 // node_modules/stylis/src/Enum.js 21180 var MS = "-ms-"; 21181 var MOZ = "-moz-"; 21182 var WEBKIT = "-webkit-"; 21183 var COMMENT = "comm"; 21184 var RULESET = "rule"; 21185 var DECLARATION = "decl"; 21186 var IMPORT = "@import"; 21187 var KEYFRAMES = "@keyframes"; 21188 21189 // node_modules/stylis/src/Utility.js 21190 var abs = Math.abs; 21191 var from = String.fromCharCode; 21192 var assign = Object.assign; 21193 function hash(value, length2) { 21194 return (((length2 << 2 ^ charat(value, 0)) << 2 ^ charat(value, 1)) << 2 ^ charat(value, 2)) << 2 ^ charat(value, 3); 21195 } 21196 function trim(value) { 21197 return value.trim(); 21198 } 21199 function match(value, pattern) { 21200 return (value = pattern.exec(value)) ? value[0] : value; 21201 } 21202 function replace(value, pattern, replacement) { 21203 return value.replace(pattern, replacement); 21204 } 21205 function indexof(value, search) { 21206 return value.indexOf(search); 21207 } 21208 function charat(value, index2) { 21209 return value.charCodeAt(index2) | 0; 21210 } 21211 function substr(value, begin, end) { 21212 return value.slice(begin, end); 21213 } 21214 function strlen(value) { 21215 return value.length; 21216 } 21217 function sizeof(value) { 21218 return value.length; 21219 } 21220 function append(value, array) { 21221 return array.push(value), value; 21222 } 21223 function combine(array, callback) { 21224 return array.map(callback).join(""); 21225 } 21226 21227 // node_modules/stylis/src/Tokenizer.js 21228 var line = 1; 21229 var column = 1; 21230 var length = 0; 21231 var position = 0; 21232 var character = 0; 21233 var characters = ""; 21234 function node(value, root, parent, type, props, children, length2) { 21235 return { value, root, parent, type, props, children, line, column, length: length2, return: "" }; 21236 } 21237 function copy(root, props) { 21238 return assign(node("", null, null, "", null, null, 0), root, { length: -root.length }, props); 21239 } 21240 function char() { 21241 return character; 21242 } 21243 function prev() { 21244 character = position > 0 ? charat(characters, --position) : 0; 21245 if (column--, character === 10) 21246 column = 1, line--; 21247 return character; 21248 } 21249 function next() { 21250 character = position < length ? charat(characters, position++) : 0; 21251 if (column++, character === 10) 21252 column = 1, line++; 21253 return character; 21254 } 21255 function peek() { 21256 return charat(characters, position); 21257 } 21258 function caret() { 21259 return position; 21260 } 21261 function slice(begin, end) { 21262 return substr(characters, begin, end); 21263 } 21264 function token(type) { 21265 switch (type) { 21266 // \0 \t \n \r \s whitespace token 21267 case 0: 21268 case 9: 21269 case 10: 21270 case 13: 21271 case 32: 21272 return 5; 21273 // ! + , / > @ ~ isolate token 21274 case 33: 21275 case 43: 21276 case 44: 21277 case 47: 21278 case 62: 21279 case 64: 21280 case 126: 21281 // ; { } breakpoint token 21282 case 59: 21283 case 123: 21284 case 125: 21285 return 4; 21286 // : accompanied token 21287 case 58: 21288 return 3; 21289 // " ' ( [ opening delimit token 21290 case 34: 21291 case 39: 21292 case 40: 21293 case 91: 21294 return 2; 21295 // ) ] closing delimit token 21296 case 41: 21297 case 93: 21298 return 1; 21299 } 21300 return 0; 21301 } 21302 function alloc(value) { 21303 return line = column = 1, length = strlen(characters = value), position = 0, []; 21304 } 21305 function dealloc(value) { 21306 return characters = "", value; 21307 } 21308 function delimit(type) { 21309 return trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type))); 21310 } 21311 function whitespace(type) { 21312 while (character = peek()) 21313 if (character < 33) 21314 next(); 21315 else 21316 break; 21317 return token(type) > 2 || token(character) > 3 ? "" : " "; 21318 } 21319 function escaping(index2, count) { 21320 while (--count && next()) 21321 if (character < 48 || character > 102 || character > 57 && character < 65 || character > 70 && character < 97) 21322 break; 21323 return slice(index2, caret() + (count < 6 && peek() == 32 && next() == 32)); 21324 } 21325 function delimiter(type) { 21326 while (next()) 21327 switch (character) { 21328 // ] ) " ' 21329 case type: 21330 return position; 21331 // " ' 21332 case 34: 21333 case 39: 21334 if (type !== 34 && type !== 39) 21335 delimiter(character); 21336 break; 21337 // ( 21338 case 40: 21339 if (type === 41) 21340 delimiter(type); 21341 break; 21342 // \ 21343 case 92: 21344 next(); 21345 break; 21346 } 21347 return position; 21348 } 21349 function commenter(type, index2) { 21350 while (next()) 21351 if (type + character === 47 + 10) 21352 break; 21353 else if (type + character === 42 + 42 && peek() === 47) 21354 break; 21355 return "/*" + slice(index2, position - 1) + "*" + from(type === 47 ? type : next()); 21356 } 21357 function identifier(index2) { 21358 while (!token(peek())) 21359 next(); 21360 return slice(index2, position); 21361 } 21362 21363 // node_modules/stylis/src/Parser.js 21364 function compile(value) { 21365 return dealloc(parse("", null, null, null, [""], value = alloc(value), 0, [0], value)); 21366 } 21367 function parse(value, root, parent, rule, rules, rulesets, pseudo, points, declarations) { 21368 var index2 = 0; 21369 var offset3 = 0; 21370 var length2 = pseudo; 21371 var atrule = 0; 21372 var property = 0; 21373 var previous = 0; 21374 var variable = 1; 21375 var scanning = 1; 21376 var ampersand = 1; 21377 var character2 = 0; 21378 var type = ""; 21379 var props = rules; 21380 var children = rulesets; 21381 var reference = rule; 21382 var characters2 = type; 21383 while (scanning) 21384 switch (previous = character2, character2 = next()) { 21385 // ( 21386 case 40: 21387 if (previous != 108 && characters2.charCodeAt(length2 - 1) == 58) { 21388 if (indexof(characters2 += replace(delimit(character2), "&", "&\f"), "&\f") != -1) 21389 ampersand = -1; 21390 break; 21391 } 21392 // " ' [ 21393 case 34: 21394 case 39: 21395 case 91: 21396 characters2 += delimit(character2); 21397 break; 21398 // \t \n \r \s 21399 case 9: 21400 case 10: 21401 case 13: 21402 case 32: 21403 characters2 += whitespace(previous); 21404 break; 21405 // \ 21406 case 92: 21407 characters2 += escaping(caret() - 1, 7); 21408 continue; 21409 // / 21410 case 47: 21411 switch (peek()) { 21412 case 42: 21413 case 47: 21414 append(comment(commenter(next(), caret()), root, parent), declarations); 21415 break; 21416 default: 21417 characters2 += "/"; 21418 } 21419 break; 21420 // { 21421 case 123 * variable: 21422 points[index2++] = strlen(characters2) * ampersand; 21423 // } ; \0 21424 case 125 * variable: 21425 case 59: 21426 case 0: 21427 switch (character2) { 21428 // \0 } 21429 case 0: 21430 case 125: 21431 scanning = 0; 21432 // ; 21433 case 59 + offset3: 21434 if (property > 0 && strlen(characters2) - length2) 21435 append(property > 32 ? declaration(characters2 + ";", rule, parent, length2 - 1) : declaration(replace(characters2, " ", "") + ";", rule, parent, length2 - 2), declarations); 21436 break; 21437 // @ ; 21438 case 59: 21439 characters2 += ";"; 21440 // { rule/at-rule 21441 default: 21442 append(reference = ruleset(characters2, root, parent, index2, offset3, rules, points, type, props = [], children = [], length2), rulesets); 21443 if (character2 === 123) 21444 if (offset3 === 0) 21445 parse(characters2, root, reference, reference, props, rulesets, length2, points, children); 21446 else 21447 switch (atrule) { 21448 // d m s 21449 case 100: 21450 case 109: 21451 case 115: 21452 parse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length2), children), rules, children, length2, points, rule ? props : children); 21453 break; 21454 default: 21455 parse(characters2, reference, reference, reference, [""], children, 0, points, children); 21456 } 21457 } 21458 index2 = offset3 = property = 0, variable = ampersand = 1, type = characters2 = "", length2 = pseudo; 21459 break; 21460 // : 21461 case 58: 21462 length2 = 1 + strlen(characters2), property = previous; 21463 default: 21464 if (variable < 1) { 21465 if (character2 == 123) 21466 --variable; 21467 else if (character2 == 125 && variable++ == 0 && prev() == 125) 21468 continue; 21469 } 21470 switch (characters2 += from(character2), character2 * variable) { 21471 // & 21472 case 38: 21473 ampersand = offset3 > 0 ? 1 : (characters2 += "\f", -1); 21474 break; 21475 // , 21476 case 44: 21477 points[index2++] = (strlen(characters2) - 1) * ampersand, ampersand = 1; 21478 break; 21479 // @ 21480 case 64: 21481 if (peek() === 45) 21482 characters2 += delimit(next()); 21483 atrule = peek(), offset3 = length2 = strlen(type = characters2 += identifier(caret())), character2++; 21484 break; 21485 // - 21486 case 45: 21487 if (previous === 45 && strlen(characters2) == 2) 21488 variable = 0; 21489 } 21490 } 21491 return rulesets; 21492 } 21493 function ruleset(value, root, parent, index2, offset3, rules, points, type, props, children, length2) { 21494 var post = offset3 - 1; 21495 var rule = offset3 === 0 ? rules : [""]; 21496 var size3 = sizeof(rule); 21497 for (var i3 = 0, j2 = 0, k2 = 0; i3 < index2; ++i3) 21498 for (var x2 = 0, y3 = substr(value, post + 1, post = abs(j2 = points[i3])), z2 = value; x2 < size3; ++x2) 21499 if (z2 = trim(j2 > 0 ? rule[x2] + " " + y3 : replace(y3, /&\f/g, rule[x2]))) 21500 props[k2++] = z2; 21501 return node(value, root, parent, offset3 === 0 ? RULESET : type, props, children, length2); 21502 } 21503 function comment(value, root, parent) { 21504 return node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0); 21505 } 21506 function declaration(value, root, parent, length2) { 21507 return node(value, root, parent, DECLARATION, substr(value, 0, length2), substr(value, length2 + 1, -1), length2); 21508 } 21509 21510 // node_modules/stylis/src/Prefixer.js 21511 function prefix(value, length2) { 21512 switch (hash(value, length2)) { 21513 // color-adjust 21514 case 5103: 21515 return WEBKIT + "print-" + value + value; 21516 // animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function) 21517 case 5737: 21518 case 4201: 21519 case 3177: 21520 case 3433: 21521 case 1641: 21522 case 4457: 21523 case 2921: 21524 // text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break 21525 case 5572: 21526 case 6356: 21527 case 5844: 21528 case 3191: 21529 case 6645: 21530 case 3005: 21531 // mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite, 21532 case 6391: 21533 case 5879: 21534 case 5623: 21535 case 6135: 21536 case 4599: 21537 case 4855: 21538 // background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width) 21539 case 4215: 21540 case 6389: 21541 case 5109: 21542 case 5365: 21543 case 5621: 21544 case 3829: 21545 return WEBKIT + value + value; 21546 // appearance, user-select, transform, hyphens, text-size-adjust 21547 case 5349: 21548 case 4246: 21549 case 4810: 21550 case 6968: 21551 case 2756: 21552 return WEBKIT + value + MOZ + value + MS + value + value; 21553 // flex, flex-direction 21554 case 6828: 21555 case 4268: 21556 return WEBKIT + value + MS + value + value; 21557 // order 21558 case 6165: 21559 return WEBKIT + value + MS + "flex-" + value + value; 21560 // align-items 21561 case 5187: 21562 return WEBKIT + value + replace(value, /(\w+).+(:[^]+)/, WEBKIT + "box-$1$2" + MS + "flex-$1$2") + value; 21563 // align-self 21564 case 5443: 21565 return WEBKIT + value + MS + "flex-item-" + replace(value, /flex-|-self/, "") + value; 21566 // align-content 21567 case 4675: 21568 return WEBKIT + value + MS + "flex-line-pack" + replace(value, /align-content|flex-|-self/, "") + value; 21569 // flex-shrink 21570 case 5548: 21571 return WEBKIT + value + MS + replace(value, "shrink", "negative") + value; 21572 // flex-basis 21573 case 5292: 21574 return WEBKIT + value + MS + replace(value, "basis", "preferred-size") + value; 21575 // flex-grow 21576 case 6060: 21577 return WEBKIT + "box-" + replace(value, "-grow", "") + WEBKIT + value + MS + replace(value, "grow", "positive") + value; 21578 // transition 21579 case 4554: 21580 return WEBKIT + replace(value, /([^-])(transform)/g, "$1" + WEBKIT + "$2") + value; 21581 // cursor 21582 case 6187: 21583 return replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + "$1"), /(image-set)/, WEBKIT + "$1"), value, "") + value; 21584 // background, background-image 21585 case 5495: 21586 case 3959: 21587 return replace(value, /(image-set\([^]*)/, WEBKIT + "$1$`$1"); 21588 // justify-content 21589 case 4968: 21590 return replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + "box-pack:$3" + MS + "flex-pack:$3"), /s.+-b[^;]+/, "justify") + WEBKIT + value + value; 21591 // (margin|padding)-inline-(start|end) 21592 case 4095: 21593 case 3583: 21594 case 4068: 21595 case 2532: 21596 return replace(value, /(.+)-inline(.+)/, WEBKIT + "$1$2") + value; 21597 // (min|max)?(width|height|inline-size|block-size) 21598 case 8116: 21599 case 7059: 21600 case 5753: 21601 case 5535: 21602 case 5445: 21603 case 5701: 21604 case 4933: 21605 case 4677: 21606 case 5533: 21607 case 5789: 21608 case 5021: 21609 case 4765: 21610 if (strlen(value) - 1 - length2 > 6) 21611 switch (charat(value, length2 + 1)) { 21612 // (m)ax-content, (m)in-content 21613 case 109: 21614 if (charat(value, length2 + 4) !== 45) 21615 break; 21616 // (f)ill-available, (f)it-content 21617 case 102: 21618 return replace(value, /(.+:)(.+)-([^]+)/, "$1" + WEBKIT + "$2-$3$1" + MOZ + (charat(value, length2 + 3) == 108 ? "$3" : "$2-$3")) + value; 21619 // (s)tretch 21620 case 115: 21621 return ~indexof(value, "stretch") ? prefix(replace(value, "stretch", "fill-available"), length2) + value : value; 21622 } 21623 break; 21624 // position: sticky 21625 case 4949: 21626 if (charat(value, length2 + 1) !== 115) 21627 break; 21628 // display: (flex|inline-flex) 21629 case 6444: 21630 switch (charat(value, strlen(value) - 3 - (~indexof(value, "!important") && 10))) { 21631 // stic(k)y 21632 case 107: 21633 return replace(value, ":", ":" + WEBKIT) + value; 21634 // (inline-)?fl(e)x 21635 case 101: 21636 return replace(value, /(.+:)([^;!]+)(;|!.+)?/, "$1" + WEBKIT + (charat(value, 14) === 45 ? "inline-" : "") + "box$3$1" + WEBKIT + "$2$3$1" + MS + "$2box$3") + value; 21637 } 21638 break; 21639 // writing-mode 21640 case 5936: 21641 switch (charat(value, length2 + 11)) { 21642 // vertical-l(r) 21643 case 114: 21644 return WEBKIT + value + MS + replace(value, /[svh]\w+-[tblr]{2}/, "tb") + value; 21645 // vertical-r(l) 21646 case 108: 21647 return WEBKIT + value + MS + replace(value, /[svh]\w+-[tblr]{2}/, "tb-rl") + value; 21648 // horizontal(-)tb 21649 case 45: 21650 return WEBKIT + value + MS + replace(value, /[svh]\w+-[tblr]{2}/, "lr") + value; 21651 } 21652 return WEBKIT + value + MS + value + value; 21653 } 21654 return value; 21655 } 21656 21657 // node_modules/stylis/src/Serializer.js 21658 function serialize(children, callback) { 21659 var output = ""; 21660 var length2 = sizeof(children); 21661 for (var i3 = 0; i3 < length2; i3++) 21662 output += callback(children[i3], i3, children, callback) || ""; 21663 return output; 21664 } 21665 function stringify(element, index2, children, callback) { 21666 switch (element.type) { 21667 case IMPORT: 21668 case DECLARATION: 21669 return element.return = element.return || element.value; 21670 case COMMENT: 21671 return ""; 21672 case KEYFRAMES: 21673 return element.return = element.value + "{" + serialize(element.children, callback) + "}"; 21674 case RULESET: 21675 element.value = element.props.join(","); 21676 } 21677 return strlen(children = serialize(element.children, callback)) ? element.return = element.value + "{" + children + "}" : ""; 21678 } 21679 21680 // node_modules/stylis/src/Middleware.js 21681 function middleware(collection) { 21682 var length2 = sizeof(collection); 21683 return function(element, index2, children, callback) { 21684 var output = ""; 21685 for (var i3 = 0; i3 < length2; i3++) 21686 output += collection[i3](element, index2, children, callback) || ""; 21687 return output; 21688 }; 21689 } 21690 function prefixer(element, index2, children, callback) { 21691 if (element.length > -1) { 21692 if (!element.return) 21693 switch (element.type) { 21694 case DECLARATION: 21695 element.return = prefix(element.value, element.length); 21696 break; 21697 case KEYFRAMES: 21698 return serialize([copy(element, { value: replace(element.value, "@", "@" + WEBKIT) })], callback); 21699 case RULESET: 21700 if (element.length) 21701 return combine(element.props, function(value) { 21702 switch (match(value, /(::plac\w+|:read-\w+)/)) { 21703 // :read-(only|write) 21704 case ":read-only": 21705 case ":read-write": 21706 return serialize([copy(element, { props: [replace(value, /:(read-\w+)/, ":" + MOZ + "$1")] })], callback); 21707 // :placeholder 21708 case "::placeholder": 21709 return serialize([ 21710 copy(element, { props: [replace(value, /:(plac\w+)/, ":" + WEBKIT + "input-$1")] }), 21711 copy(element, { props: [replace(value, /:(plac\w+)/, ":" + MOZ + "$1")] }), 21712 copy(element, { props: [replace(value, /:(plac\w+)/, MS + "input-$1")] }) 21713 ], callback); 21714 } 21715 return ""; 21716 }); 21717 } 21718 } 21719 } 21720 21721 // node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js 21722 var last = function last2(arr) { 21723 return arr.length ? arr[arr.length - 1] : null; 21724 }; 21725 var identifierWithPointTracking = function identifierWithPointTracking2(begin, points, index2) { 21726 var previous = 0; 21727 var character2 = 0; 21728 while (true) { 21729 previous = character2; 21730 character2 = peek(); 21731 if (previous === 38 && character2 === 12) { 21732 points[index2] = 1; 21733 } 21734 if (token(character2)) { 21735 break; 21736 } 21737 next(); 21738 } 21739 return slice(begin, position); 21740 }; 21741 var toRules = function toRules2(parsed, points) { 21742 var index2 = -1; 21743 var character2 = 44; 21744 do { 21745 switch (token(character2)) { 21746 case 0: 21747 if (character2 === 38 && peek() === 12) { 21748 points[index2] = 1; 21749 } 21750 parsed[index2] += identifierWithPointTracking(position - 1, points, index2); 21751 break; 21752 case 2: 21753 parsed[index2] += delimit(character2); 21754 break; 21755 case 4: 21756 if (character2 === 44) { 21757 parsed[++index2] = peek() === 58 ? "&\f" : ""; 21758 points[index2] = parsed[index2].length; 21759 break; 21760 } 21761 // fallthrough 21762 default: 21763 parsed[index2] += from(character2); 21764 } 21765 } while (character2 = next()); 21766 return parsed; 21767 }; 21768 var getRules = function getRules2(value, points) { 21769 return dealloc(toRules(alloc(value), points)); 21770 }; 21771 var fixedElements = /* @__PURE__ */ new WeakMap(); 21772 var compat = function compat2(element) { 21773 if (element.type !== "rule" || !element.parent || // positive .length indicates that this rule contains pseudo 21774 // negative .length indicates that this rule has been already prefixed 21775 element.length < 1) { 21776 return; 21777 } 21778 var value = element.value, parent = element.parent; 21779 var isImplicitRule = element.column === parent.column && element.line === parent.line; 21780 while (parent.type !== "rule") { 21781 parent = parent.parent; 21782 if (!parent) return; 21783 } 21784 if (element.props.length === 1 && value.charCodeAt(0) !== 58 && !fixedElements.get(parent)) { 21785 return; 21786 } 21787 if (isImplicitRule) { 21788 return; 21789 } 21790 fixedElements.set(element, true); 21791 var points = []; 21792 var rules = getRules(value, points); 21793 var parentRules = parent.props; 21794 for (var i3 = 0, k2 = 0; i3 < rules.length; i3++) { 21795 for (var j2 = 0; j2 < parentRules.length; j2++, k2++) { 21796 element.props[k2] = points[i3] ? rules[i3].replace(/&\f/g, parentRules[j2]) : parentRules[j2] + " " + rules[i3]; 21797 } 21798 } 21799 }; 21800 var removeLabel = function removeLabel2(element) { 21801 if (element.type === "decl") { 21802 var value = element.value; 21803 if ( 21804 // charcode for l 21805 value.charCodeAt(0) === 108 && // charcode for b 21806 value.charCodeAt(2) === 98 21807 ) { 21808 element["return"] = ""; 21809 element.value = ""; 21810 } 21811 } 21812 }; 21813 var ignoreFlag = "emotion-disable-server-rendering-unsafe-selector-warning-please-do-not-use-this-the-warning-exists-for-a-reason"; 21814 var isIgnoringComment = function isIgnoringComment2(element) { 21815 return !!element && element.type === "comm" && element.children.indexOf(ignoreFlag) > -1; 21816 }; 21817 var createUnsafeSelectorsAlarm = function createUnsafeSelectorsAlarm2(cache2) { 21818 return function(element, index2, children) { 21819 if (element.type !== "rule") return; 21820 var unsafePseudoClasses = element.value.match(/(:first|:nth|:nth-last)-child/g); 21821 if (unsafePseudoClasses && cache2.compat !== true) { 21822 var prevElement = index2 > 0 ? children[index2 - 1] : null; 21823 if (prevElement && isIgnoringComment(last(prevElement.children))) { 21824 return; 21825 } 21826 unsafePseudoClasses.forEach(function(unsafePseudoClass) { 21827 console.error('The pseudo class "' + unsafePseudoClass + '" is potentially unsafe when doing server-side rendering. Try changing it to "' + unsafePseudoClass.split("-child")[0] + '-of-type".'); 21828 }); 21829 } 21830 }; 21831 }; 21832 var isImportRule = function isImportRule2(element) { 21833 return element.type.charCodeAt(1) === 105 && element.type.charCodeAt(0) === 64; 21834 }; 21835 var isPrependedWithRegularRules = function isPrependedWithRegularRules2(index2, children) { 21836 for (var i3 = index2 - 1; i3 >= 0; i3--) { 21837 if (!isImportRule(children[i3])) { 21838 return true; 21839 } 21840 } 21841 return false; 21842 }; 21843 var nullifyElement = function nullifyElement2(element) { 21844 element.type = ""; 21845 element.value = ""; 21846 element["return"] = ""; 21847 element.children = ""; 21848 element.props = ""; 21849 }; 21850 var incorrectImportAlarm = function incorrectImportAlarm2(element, index2, children) { 21851 if (!isImportRule(element)) { 21852 return; 21853 } 21854 if (element.parent) { 21855 console.error("`@import` rules can't be nested inside other rules. Please move it to the top level and put it before regular rules. Keep in mind that they can only be used within global styles."); 21856 nullifyElement(element); 21857 } else if (isPrependedWithRegularRules(index2, children)) { 21858 console.error("`@import` rules can't be after other rules. Please put your `@import` rules before your other rules."); 21859 nullifyElement(element); 21860 } 21861 }; 21862 var defaultStylisPlugins = [prefixer]; 21863 var createCache = function createCache2(options2) { 21864 var key = options2.key; 21865 if (!key) { 21866 throw new Error("You have to configure `key` for your cache. Please make sure it's unique (and not equal to 'css') as it's used for linking styles to your cache.\nIf multiple caches share the same key they might \"fight\" for each other's style elements."); 21867 } 21868 if (key === "css") { 21869 var ssrStyles = document.querySelectorAll("style[data-emotion]:not([data-s])"); 21870 Array.prototype.forEach.call(ssrStyles, function(node2) { 21871 var dataEmotionAttribute = node2.getAttribute("data-emotion"); 21872 if (dataEmotionAttribute.indexOf(" ") === -1) { 21873 return; 21874 } 21875 document.head.appendChild(node2); 21876 node2.setAttribute("data-s", ""); 21877 }); 21878 } 21879 var stylisPlugins = options2.stylisPlugins || defaultStylisPlugins; 21880 if (true) { 21881 if (/[^a-z-]/.test(key)) { 21882 throw new Error('Emotion key must only contain lower case alphabetical characters and - but "' + key + '" was passed'); 21883 } 21884 } 21885 var inserted = {}; 21886 var container; 21887 var nodesToHydrate = []; 21888 { 21889 container = options2.container || document.head; 21890 Array.prototype.forEach.call( 21891 // this means we will ignore elements which don't have a space in them which 21892 // means that the style elements we're looking at are only Emotion 11 server-rendered style elements 21893 document.querySelectorAll('style[data-emotion^="' + key + ' "]'), 21894 function(node2) { 21895 var attrib = node2.getAttribute("data-emotion").split(" "); 21896 for (var i3 = 1; i3 < attrib.length; i3++) { 21897 inserted[attrib[i3]] = true; 21898 } 21899 nodesToHydrate.push(node2); 21900 } 21901 ); 21902 } 21903 var _insert; 21904 var omnipresentPlugins = [compat, removeLabel]; 21905 if (true) { 21906 omnipresentPlugins.push(createUnsafeSelectorsAlarm({ 21907 get compat() { 21908 return cache2.compat; 21909 } 21910 }), incorrectImportAlarm); 21911 } 21912 { 21913 var currentSheet; 21914 var finalizingPlugins = [stringify, true ? function(element) { 21915 if (!element.root) { 21916 if (element["return"]) { 21917 currentSheet.insert(element["return"]); 21918 } else if (element.value && element.type !== COMMENT) { 21919 currentSheet.insert(element.value + "{}"); 21920 } 21921 } 21922 } : rulesheet(function(rule) { 21923 currentSheet.insert(rule); 21924 })]; 21925 var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins)); 21926 var stylis = function stylis2(styles3) { 21927 return serialize(compile(styles3), serializer); 21928 }; 21929 _insert = function insert2(selector2, serialized, sheet2, shouldCache) { 21930 currentSheet = sheet2; 21931 if (serialized.map !== void 0) { 21932 currentSheet = { 21933 insert: function insert3(rule) { 21934 sheet2.insert(rule + serialized.map); 21935 } 21936 }; 21937 } 21938 stylis(selector2 ? selector2 + "{" + serialized.styles + "}" : serialized.styles); 21939 if (shouldCache) { 21940 cache2.inserted[serialized.name] = true; 21941 } 21942 }; 21943 } 21944 var cache2 = { 21945 key, 21946 sheet: new StyleSheet({ 21947 key, 21948 container, 21949 nonce: options2.nonce, 21950 speedy: options2.speedy, 21951 prepend: options2.prepend, 21952 insertionPoint: options2.insertionPoint 21953 }), 21954 nonce: options2.nonce, 21955 inserted, 21956 registered: {}, 21957 insert: _insert 21958 }; 21959 cache2.sheet.hydrate(nodesToHydrate); 21960 return cache2; 21961 }; 21962 var emotion_cache_browser_esm_default = createCache; 21963 21964 // node_modules/@emotion/react/dist/emotion-element-699e6908.browser.esm.js 21965 var import_react80 = __toESM(require_react()); 21966 21967 // node_modules/@babel/runtime/helpers/esm/extends.js 21968 function _extends() { 21969 return _extends = Object.assign ? Object.assign.bind() : function(n3) { 21970 for (var e3 = 1; e3 < arguments.length; e3++) { 21971 var t4 = arguments[e3]; 21972 for (var r4 in t4) ({}).hasOwnProperty.call(t4, r4) && (n3[r4] = t4[r4]); 21973 } 21974 return n3; 21975 }, _extends.apply(null, arguments); 21976 } 21977 21978 // node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js 21979 var isBrowser2 = true; 21980 function getRegisteredStyles(registered, registeredStyles, classNames) { 21981 var rawClassName = ""; 21982 classNames.split(" ").forEach(function(className2) { 21983 if (registered[className2] !== void 0) { 21984 registeredStyles.push(registered[className2] + ";"); 21985 } else { 21986 rawClassName += className2 + " "; 21987 } 21988 }); 21989 return rawClassName; 21990 } 21991 var registerStyles = function registerStyles2(cache2, serialized, isStringTag) { 21992 var className2 = cache2.key + "-" + serialized.name; 21993 if ( 21994 // we only need to add the styles to the registered cache if the 21995 // class name could be used further down 21996 // the tree but if it's a string tag, we know it won't 21997 // so we don't have to add it to registered cache. 21998 // this improves memory usage since we can avoid storing the whole style string 21999 (isStringTag === false || // we need to always store it if we're in compat mode and 22000 // in node since emotion-server relies on whether a style is in 22001 // the registered cache to know whether a style is global or not 22002 // also, note that this check will be dead code eliminated in the browser 22003 isBrowser2 === false) && cache2.registered[className2] === void 0 22004 ) { 22005 cache2.registered[className2] = serialized.styles; 22006 } 22007 }; 22008 var insertStyles = function insertStyles2(cache2, serialized, isStringTag) { 22009 registerStyles(cache2, serialized, isStringTag); 22010 var className2 = cache2.key + "-" + serialized.name; 22011 if (cache2.inserted[serialized.name] === void 0) { 22012 var current = serialized; 22013 do { 22014 cache2.insert(serialized === current ? "." + className2 : "", current, cache2.sheet, true); 22015 current = current.next; 22016 } while (current !== void 0); 22017 } 22018 }; 22019 22020 // node_modules/@emotion/hash/dist/emotion-hash.esm.js 22021 function murmur2(str) { 22022 var h3 = 0; 22023 var k2, i3 = 0, len = str.length; 22024 for (; len >= 4; ++i3, len -= 4) { 22025 k2 = str.charCodeAt(i3) & 255 | (str.charCodeAt(++i3) & 255) << 8 | (str.charCodeAt(++i3) & 255) << 16 | (str.charCodeAt(++i3) & 255) << 24; 22026 k2 = /* Math.imul(k, m): */ 22027 (k2 & 65535) * 1540483477 + ((k2 >>> 16) * 59797 << 16); 22028 k2 ^= /* k >>> r: */ 22029 k2 >>> 24; 22030 h3 = /* Math.imul(k, m): */ 22031 (k2 & 65535) * 1540483477 + ((k2 >>> 16) * 59797 << 16) ^ /* Math.imul(h, m): */ 22032 (h3 & 65535) * 1540483477 + ((h3 >>> 16) * 59797 << 16); 22033 } 22034 switch (len) { 22035 case 3: 22036 h3 ^= (str.charCodeAt(i3 + 2) & 255) << 16; 22037 case 2: 22038 h3 ^= (str.charCodeAt(i3 + 1) & 255) << 8; 22039 case 1: 22040 h3 ^= str.charCodeAt(i3) & 255; 22041 h3 = /* Math.imul(h, m): */ 22042 (h3 & 65535) * 1540483477 + ((h3 >>> 16) * 59797 << 16); 22043 } 22044 h3 ^= h3 >>> 13; 22045 h3 = /* Math.imul(h, m): */ 22046 (h3 & 65535) * 1540483477 + ((h3 >>> 16) * 59797 << 16); 22047 return ((h3 ^ h3 >>> 15) >>> 0).toString(36); 22048 } 22049 22050 // node_modules/@emotion/unitless/dist/emotion-unitless.esm.js 22051 var unitlessKeys = { 22052 animationIterationCount: 1, 22053 aspectRatio: 1, 22054 borderImageOutset: 1, 22055 borderImageSlice: 1, 22056 borderImageWidth: 1, 22057 boxFlex: 1, 22058 boxFlexGroup: 1, 22059 boxOrdinalGroup: 1, 22060 columnCount: 1, 22061 columns: 1, 22062 flex: 1, 22063 flexGrow: 1, 22064 flexPositive: 1, 22065 flexShrink: 1, 22066 flexNegative: 1, 22067 flexOrder: 1, 22068 gridRow: 1, 22069 gridRowEnd: 1, 22070 gridRowSpan: 1, 22071 gridRowStart: 1, 22072 gridColumn: 1, 22073 gridColumnEnd: 1, 22074 gridColumnSpan: 1, 22075 gridColumnStart: 1, 22076 msGridRow: 1, 22077 msGridRowSpan: 1, 22078 msGridColumn: 1, 22079 msGridColumnSpan: 1, 22080 fontWeight: 1, 22081 lineHeight: 1, 22082 opacity: 1, 22083 order: 1, 22084 orphans: 1, 22085 tabSize: 1, 22086 widows: 1, 22087 zIndex: 1, 22088 zoom: 1, 22089 WebkitLineClamp: 1, 22090 // SVG-related properties 22091 fillOpacity: 1, 22092 floodOpacity: 1, 22093 stopOpacity: 1, 22094 strokeDasharray: 1, 22095 strokeDashoffset: 1, 22096 strokeMiterlimit: 1, 22097 strokeOpacity: 1, 22098 strokeWidth: 1 22099 }; 22100 22101 // node_modules/@emotion/serialize/node_modules/@emotion/memoize/dist/emotion-memoize.esm.js 22102 function memoize2(fn) { 22103 var cache2 = /* @__PURE__ */ Object.create(null); 22104 return function(arg) { 22105 if (cache2[arg] === void 0) cache2[arg] = fn(arg); 22106 return cache2[arg]; 22107 }; 22108 } 22109 22110 // node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js 22111 var ILLEGAL_ESCAPE_SEQUENCE_ERROR = `You have illegal escape sequence in your template literal, most likely inside content's property value. 22112 Because you write your CSS inside a JavaScript string you actually have to do double escaping, so for example "content: '\\00d7';" should become "content: '\\\\00d7';". 22113 You can read more about this here: 22114 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences`; 22115 var UNDEFINED_AS_OBJECT_KEY_ERROR = "You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key)."; 22116 var hyphenateRegex = /[A-Z]|^ms/g; 22117 var animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g; 22118 var isCustomProperty = function isCustomProperty2(property) { 22119 return property.charCodeAt(1) === 45; 22120 }; 22121 var isProcessableValue = function isProcessableValue2(value) { 22122 return value != null && typeof value !== "boolean"; 22123 }; 22124 var processStyleName = /* @__PURE__ */ memoize2(function(styleName) { 22125 return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, "-$&").toLowerCase(); 22126 }); 22127 var processStyleValue = function processStyleValue2(key, value) { 22128 switch (key) { 22129 case "animation": 22130 case "animationName": { 22131 if (typeof value === "string") { 22132 return value.replace(animationRegex, function(match5, p1, p22) { 22133 cursor = { 22134 name: p1, 22135 styles: p22, 22136 next: cursor 22137 }; 22138 return p1; 22139 }); 22140 } 22141 } 22142 } 22143 if (unitlessKeys[key] !== 1 && !isCustomProperty(key) && typeof value === "number" && value !== 0) { 22144 return value + "px"; 22145 } 22146 return value; 22147 }; 22148 if (true) { 22149 contentValuePattern = /(var|attr|counters?|url|element|(((repeating-)?(linear|radial))|conic)-gradient)\(|(no-)?(open|close)-quote/; 22150 contentValues = ["normal", "none", "initial", "inherit", "unset"]; 22151 oldProcessStyleValue = processStyleValue; 22152 msPattern = /^-ms-/; 22153 hyphenPattern = /-(.)/g; 22154 hyphenatedCache = {}; 22155 processStyleValue = function processStyleValue3(key, value) { 22156 if (key === "content") { 22157 if (typeof value !== "string" || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '"' && value.charAt(0) !== "'")) { 22158 throw new Error("You seem to be using a value for 'content' without quotes, try replacing it with `content: '\"" + value + "\"'`"); 22159 } 22160 } 22161 var processed = oldProcessStyleValue(key, value); 22162 if (processed !== "" && !isCustomProperty(key) && key.indexOf("-") !== -1 && hyphenatedCache[key] === void 0) { 22163 hyphenatedCache[key] = true; 22164 console.error("Using kebab-case for css properties in objects is not supported. Did you mean " + key.replace(msPattern, "ms-").replace(hyphenPattern, function(str, _char) { 22165 return _char.toUpperCase(); 22166 }) + "?"); 22167 } 22168 return processed; 22169 }; 22170 } 22171 var contentValuePattern; 22172 var contentValues; 22173 var oldProcessStyleValue; 22174 var msPattern; 22175 var hyphenPattern; 22176 var hyphenatedCache; 22177 var noComponentSelectorMessage = "Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform."; 22178 function handleInterpolation(mergedProps, registered, interpolation) { 22179 if (interpolation == null) { 22180 return ""; 22181 } 22182 if (interpolation.__emotion_styles !== void 0) { 22183 if (interpolation.toString() === "NO_COMPONENT_SELECTOR") { 22184 throw new Error(noComponentSelectorMessage); 22185 } 22186 return interpolation; 22187 } 22188 switch (typeof interpolation) { 22189 case "boolean": { 22190 return ""; 22191 } 22192 case "object": { 22193 if (interpolation.anim === 1) { 22194 cursor = { 22195 name: interpolation.name, 22196 styles: interpolation.styles, 22197 next: cursor 22198 }; 22199 return interpolation.name; 22200 } 22201 if (interpolation.styles !== void 0) { 22202 var next2 = interpolation.next; 22203 if (next2 !== void 0) { 22204 while (next2 !== void 0) { 22205 cursor = { 22206 name: next2.name, 22207 styles: next2.styles, 22208 next: cursor 22209 }; 22210 next2 = next2.next; 22211 } 22212 } 22213 var styles3 = interpolation.styles + ";"; 22214 if (interpolation.map !== void 0) { 22215 styles3 += interpolation.map; 22216 } 22217 return styles3; 22218 } 22219 return createStringFromObject(mergedProps, registered, interpolation); 22220 } 22221 case "function": { 22222 if (mergedProps !== void 0) { 22223 var previousCursor = cursor; 22224 var result = interpolation(mergedProps); 22225 cursor = previousCursor; 22226 return handleInterpolation(mergedProps, registered, result); 22227 } else if (true) { 22228 console.error("Functions that are interpolated in css calls will be stringified.\nIf you want to have a css call based on props, create a function that returns a css call like this\nlet dynamicStyle = (props) => css`color: $props.color}`\nIt can be called directly with props or interpolated in a styled call like this\nlet SomeComponent = styled('div')`$dynamicStyle}`"); 22229 } 22230 break; 22231 } 22232 case "string": 22233 if (true) { 22234 var matched = []; 22235 var replaced = interpolation.replace(animationRegex, function(match5, p1, p22) { 22236 var fakeVarName = "animation" + matched.length; 22237 matched.push("const " + fakeVarName + " = keyframes`" + p22.replace(/^@keyframes animation-\w+/, "") + "`"); 22238 return "${" + fakeVarName + "}"; 22239 }); 22240 if (matched.length) { 22241 console.error("`keyframes` output got interpolated into plain string, please wrap it with `css`.\n\nInstead of doing this:\n\n" + [].concat(matched, ["`" + replaced + "`"]).join("\n") + "\n\nYou should wrap it with `css` like this:\n\n" + ("css`" + replaced + "`")); 22242 } 22243 } 22244 break; 22245 } 22246 if (registered == null) { 22247 return interpolation; 22248 } 22249 var cached = registered[interpolation]; 22250 return cached !== void 0 ? cached : interpolation; 22251 } 22252 function createStringFromObject(mergedProps, registered, obj) { 22253 var string = ""; 22254 if (Array.isArray(obj)) { 22255 for (var i3 = 0; i3 < obj.length; i3++) { 22256 string += handleInterpolation(mergedProps, registered, obj[i3]) + ";"; 22257 } 22258 } else { 22259 for (var _key in obj) { 22260 var value = obj[_key]; 22261 if (typeof value !== "object") { 22262 if (registered != null && registered[value] !== void 0) { 22263 string += _key + "{" + registered[value] + "}"; 22264 } else if (isProcessableValue(value)) { 22265 string += processStyleName(_key) + ":" + processStyleValue(_key, value) + ";"; 22266 } 22267 } else { 22268 if (_key === "NO_COMPONENT_SELECTOR" && true) { 22269 throw new Error(noComponentSelectorMessage); 22270 } 22271 if (Array.isArray(value) && typeof value[0] === "string" && (registered == null || registered[value[0]] === void 0)) { 22272 for (var _i = 0; _i < value.length; _i++) { 22273 if (isProcessableValue(value[_i])) { 22274 string += processStyleName(_key) + ":" + processStyleValue(_key, value[_i]) + ";"; 22275 } 22276 } 22277 } else { 22278 var interpolated = handleInterpolation(mergedProps, registered, value); 22279 switch (_key) { 22280 case "animation": 22281 case "animationName": { 22282 string += processStyleName(_key) + ":" + interpolated + ";"; 22283 break; 22284 } 22285 default: { 22286 if (_key === "undefined") { 22287 console.error(UNDEFINED_AS_OBJECT_KEY_ERROR); 22288 } 22289 string += _key + "{" + interpolated + "}"; 22290 } 22291 } 22292 } 22293 } 22294 } 22295 } 22296 return string; 22297 } 22298 var labelPattern = /label:\s*([^\s;\n{]+)\s*(;|$)/g; 22299 var sourceMapPattern; 22300 if (true) { 22301 sourceMapPattern = /\/\*#\ssourceMappingURL=data:application\/json;\S+\s+\*\//g; 22302 } 22303 var cursor; 22304 var serializeStyles = function serializeStyles2(args, registered, mergedProps) { 22305 if (args.length === 1 && typeof args[0] === "object" && args[0] !== null && args[0].styles !== void 0) { 22306 return args[0]; 22307 } 22308 var stringMode = true; 22309 var styles3 = ""; 22310 cursor = void 0; 22311 var strings = args[0]; 22312 if (strings == null || strings.raw === void 0) { 22313 stringMode = false; 22314 styles3 += handleInterpolation(mergedProps, registered, strings); 22315 } else { 22316 if (strings[0] === void 0) { 22317 console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR); 22318 } 22319 styles3 += strings[0]; 22320 } 22321 for (var i3 = 1; i3 < args.length; i3++) { 22322 styles3 += handleInterpolation(mergedProps, registered, args[i3]); 22323 if (stringMode) { 22324 if (strings[i3] === void 0) { 22325 console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR); 22326 } 22327 styles3 += strings[i3]; 22328 } 22329 } 22330 var sourceMap; 22331 if (true) { 22332 styles3 = styles3.replace(sourceMapPattern, function(match6) { 22333 sourceMap = match6; 22334 return ""; 22335 }); 22336 } 22337 labelPattern.lastIndex = 0; 22338 var identifierName = ""; 22339 var match5; 22340 while ((match5 = labelPattern.exec(styles3)) !== null) { 22341 identifierName += "-" + // $FlowFixMe we know it's not null 22342 match5[1]; 22343 } 22344 var name = murmur2(styles3) + identifierName; 22345 if (true) { 22346 return { 22347 name, 22348 styles: styles3, 22349 map: sourceMap, 22350 next: cursor, 22351 toString: function toString() { 22352 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 22353 } 22354 }; 22355 } 22356 return { 22357 name, 22358 styles: styles3, 22359 next: cursor 22360 }; 22361 }; 22362 22363 // node_modules/@emotion/react/dist/emotion-element-699e6908.browser.esm.js 22364 var hasOwnProperty2 = {}.hasOwnProperty; 22365 var EmotionCacheContext = /* @__PURE__ */ (0, import_react80.createContext)( 22366 // we're doing this to avoid preconstruct's dead code elimination in this one case 22367 // because this module is primarily intended for the browser and node 22368 // but it's also required in react native and similar environments sometimes 22369 // and we could have a special build just for that 22370 // but this is much easier and the native packages 22371 // might use a different theme context in the future anyway 22372 typeof HTMLElement !== "undefined" ? /* @__PURE__ */ emotion_cache_browser_esm_default({ 22373 key: "css" 22374 }) : null 22375 ); 22376 if (true) { 22377 EmotionCacheContext.displayName = "EmotionCacheContext"; 22378 } 22379 var CacheProvider = EmotionCacheContext.Provider; 22380 var __unsafe_useEmotionCache = function useEmotionCache() { 22381 return (0, import_react80.useContext)(EmotionCacheContext); 22382 }; 22383 var withEmotionCache = function withEmotionCache2(func) { 22384 return /* @__PURE__ */ (0, import_react80.forwardRef)(function(props, ref) { 22385 var cache2 = (0, import_react80.useContext)(EmotionCacheContext); 22386 return func(props, cache2, ref); 22387 }); 22388 }; 22389 var ThemeContext = /* @__PURE__ */ (0, import_react80.createContext)({}); 22390 if (true) { 22391 ThemeContext.displayName = "EmotionThemeContext"; 22392 } 22393 var typePropName = "__EMOTION_TYPE_PLEASE_DO_NOT_USE__"; 22394 var labelPropName = "__EMOTION_LABEL_PLEASE_DO_NOT_USE__"; 22395 var Noop = function Noop2() { 22396 return null; 22397 }; 22398 var Emotion = /* @__PURE__ */ withEmotionCache(function(props, cache2, ref) { 22399 var cssProp = props.css; 22400 if (typeof cssProp === "string" && cache2.registered[cssProp] !== void 0) { 22401 cssProp = cache2.registered[cssProp]; 22402 } 22403 var type = props[typePropName]; 22404 var registeredStyles = [cssProp]; 22405 var className2 = ""; 22406 if (typeof props.className === "string") { 22407 className2 = getRegisteredStyles(cache2.registered, registeredStyles, props.className); 22408 } else if (props.className != null) { 22409 className2 = props.className + " "; 22410 } 22411 var serialized = serializeStyles(registeredStyles, void 0, (0, import_react80.useContext)(ThemeContext)); 22412 if (serialized.name.indexOf("-") === -1) { 22413 var labelFromStack = props[labelPropName]; 22414 if (labelFromStack) { 22415 serialized = serializeStyles([serialized, "label:" + labelFromStack + ";"]); 22416 } 22417 } 22418 var rules = insertStyles(cache2, serialized, typeof type === "string"); 22419 className2 += cache2.key + "-" + serialized.name; 22420 var newProps = {}; 22421 for (var key in props) { 22422 if (hasOwnProperty2.call(props, key) && key !== "css" && key !== typePropName && key !== labelPropName) { 22423 newProps[key] = props[key]; 22424 } 22425 } 22426 newProps.ref = ref; 22427 newProps.className = className2; 22428 var ele = /* @__PURE__ */ (0, import_react80.createElement)(type, newProps); 22429 var possiblyStyleElement = /* @__PURE__ */ (0, import_react80.createElement)(Noop, null); 22430 return /* @__PURE__ */ (0, import_react80.createElement)(import_react80.Fragment, null, possiblyStyleElement, ele); 22431 }); 22432 if (true) { 22433 Emotion.displayName = "EmotionCssPropInternal"; 22434 } 22435 22436 // node_modules/@emotion/react/dist/emotion-react.browser.esm.js 22437 var import_hoist_non_react_statics = __toESM(require_hoist_non_react_statics_cjs()); 22438 var pkg = { 22439 name: "@emotion/react", 22440 version: "11.7.1", 22441 main: "dist/emotion-react.cjs.js", 22442 module: "dist/emotion-react.esm.js", 22443 browser: { 22444 "./dist/emotion-react.cjs.js": "./dist/emotion-react.browser.cjs.js", 22445 "./dist/emotion-react.esm.js": "./dist/emotion-react.browser.esm.js" 22446 }, 22447 types: "types/index.d.ts", 22448 files: [ 22449 "src", 22450 "dist", 22451 "jsx-runtime", 22452 "jsx-dev-runtime", 22453 "_isolated-hnrs", 22454 "types/*.d.ts", 22455 "macro.js", 22456 "macro.d.ts", 22457 "macro.js.flow" 22458 ], 22459 sideEffects: false, 22460 author: "mitchellhamilton <mitchell@mitchellhamilton.me>", 22461 license: "MIT", 22462 scripts: { 22463 "test:typescript": "dtslint types" 22464 }, 22465 dependencies: { 22466 "@babel/runtime": "^7.13.10", 22467 "@emotion/cache": "^11.7.1", 22468 "@emotion/serialize": "^1.0.2", 22469 "@emotion/sheet": "^1.1.0", 22470 "@emotion/utils": "^1.0.0", 22471 "@emotion/weak-memoize": "^0.2.5", 22472 "hoist-non-react-statics": "^3.3.1" 22473 }, 22474 peerDependencies: { 22475 "@babel/core": "^7.0.0", 22476 react: ">=16.8.0" 22477 }, 22478 peerDependenciesMeta: { 22479 "@babel/core": { 22480 optional: true 22481 }, 22482 "@types/react": { 22483 optional: true 22484 } 22485 }, 22486 devDependencies: { 22487 "@babel/core": "^7.13.10", 22488 "@emotion/css": "11.7.1", 22489 "@emotion/css-prettifier": "1.0.1", 22490 "@emotion/server": "11.4.0", 22491 "@emotion/styled": "11.6.0", 22492 "@types/react": "^16.9.11", 22493 dtslint: "^0.3.0", 22494 "html-tag-names": "^1.1.2", 22495 react: "16.14.0", 22496 "svg-tag-names": "^1.1.1" 22497 }, 22498 repository: "https://github.com/emotion-js/emotion/tree/main/packages/react", 22499 publishConfig: { 22500 access: "public" 22501 }, 22502 "umd:main": "dist/emotion-react.umd.min.js", 22503 preconstruct: { 22504 entrypoints: [ 22505 "./index.js", 22506 "./jsx-runtime.js", 22507 "./jsx-dev-runtime.js", 22508 "./_isolated-hnrs.js" 22509 ], 22510 umdName: "emotionReact" 22511 } 22512 }; 22513 var warnedAboutCssPropForGlobal = false; 22514 var Global = /* @__PURE__ */ withEmotionCache(function(props, cache2) { 22515 if (!warnedAboutCssPropForGlobal && // check for className as well since the user is 22516 // probably using the custom createElement which 22517 // means it will be turned into a className prop 22518 // $FlowFixMe I don't really want to add it to the type since it shouldn't be used 22519 (props.className || props.css)) { 22520 console.error("It looks like you're using the css prop on Global, did you mean to use the styles prop instead?"); 22521 warnedAboutCssPropForGlobal = true; 22522 } 22523 var styles3 = props.styles; 22524 var serialized = serializeStyles([styles3], void 0, (0, import_react81.useContext)(ThemeContext)); 22525 var sheetRef = (0, import_react81.useRef)(); 22526 (0, import_react81.useLayoutEffect)(function() { 22527 var key = cache2.key + "-global"; 22528 var sheet2 = new StyleSheet({ 22529 key, 22530 nonce: cache2.sheet.nonce, 22531 container: cache2.sheet.container, 22532 speedy: cache2.sheet.isSpeedy 22533 }); 22534 var rehydrating = false; 22535 var node2 = document.querySelector('style[data-emotion="' + key + " " + serialized.name + '"]'); 22536 if (cache2.sheet.tags.length) { 22537 sheet2.before = cache2.sheet.tags[0]; 22538 } 22539 if (node2 !== null) { 22540 rehydrating = true; 22541 node2.setAttribute("data-emotion", key); 22542 sheet2.hydrate([node2]); 22543 } 22544 sheetRef.current = [sheet2, rehydrating]; 22545 return function() { 22546 sheet2.flush(); 22547 }; 22548 }, [cache2]); 22549 (0, import_react81.useLayoutEffect)(function() { 22550 var sheetRefCurrent = sheetRef.current; 22551 var sheet2 = sheetRefCurrent[0], rehydrating = sheetRefCurrent[1]; 22552 if (rehydrating) { 22553 sheetRefCurrent[1] = false; 22554 return; 22555 } 22556 if (serialized.next !== void 0) { 22557 insertStyles(cache2, serialized.next, true); 22558 } 22559 if (sheet2.tags.length) { 22560 var element = sheet2.tags[sheet2.tags.length - 1].nextElementSibling; 22561 sheet2.before = element; 22562 sheet2.flush(); 22563 } 22564 cache2.insert("", serialized, sheet2, false); 22565 }, [cache2, serialized.name]); 22566 return null; 22567 }); 22568 if (true) { 22569 Global.displayName = "EmotionGlobal"; 22570 } 22571 function css() { 22572 for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { 22573 args[_key] = arguments[_key]; 22574 } 22575 return serializeStyles(args); 22576 } 22577 var keyframes2 = function keyframes3() { 22578 var insertable = css.apply(void 0, arguments); 22579 var name = "animation-" + insertable.name; 22580 return { 22581 name, 22582 styles: "@keyframes " + name + "{" + insertable.styles + "}", 22583 anim: 1, 22584 toString: function toString() { 22585 return "_EMO_" + this.name + "_" + this.styles + "_EMO_"; 22586 } 22587 }; 22588 }; 22589 var classnames = function classnames2(args) { 22590 var len = args.length; 22591 var i3 = 0; 22592 var cls = ""; 22593 for (; i3 < len; i3++) { 22594 var arg = args[i3]; 22595 if (arg == null) continue; 22596 var toAdd = void 0; 22597 switch (typeof arg) { 22598 case "boolean": 22599 break; 22600 case "object": { 22601 if (Array.isArray(arg)) { 22602 toAdd = classnames2(arg); 22603 } else { 22604 if (arg.styles !== void 0 && arg.name !== void 0) { 22605 console.error("You have passed styles created with `css` from `@emotion/react` package to the `cx`.\n`cx` is meant to compose class names (strings) so you should convert those styles to a class name by passing them to the `css` received from <ClassNames/> component."); 22606 } 22607 toAdd = ""; 22608 for (var k2 in arg) { 22609 if (arg[k2] && k2) { 22610 toAdd && (toAdd += " "); 22611 toAdd += k2; 22612 } 22613 } 22614 } 22615 break; 22616 } 22617 default: { 22618 toAdd = arg; 22619 } 22620 } 22621 if (toAdd) { 22622 cls && (cls += " "); 22623 cls += toAdd; 22624 } 22625 } 22626 return cls; 22627 }; 22628 function merge(registered, css6, className2) { 22629 var registeredStyles = []; 22630 var rawClassName = getRegisteredStyles(registered, registeredStyles, className2); 22631 if (registeredStyles.length < 2) { 22632 return className2; 22633 } 22634 return rawClassName + css6(registeredStyles); 22635 } 22636 var Noop3 = function Noop4() { 22637 return null; 22638 }; 22639 var ClassNames = /* @__PURE__ */ withEmotionCache(function(props, cache2) { 22640 var hasRendered = false; 22641 var css6 = function css7() { 22642 if (hasRendered && true) { 22643 throw new Error("css can only be used during render"); 22644 } 22645 for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { 22646 args[_key] = arguments[_key]; 22647 } 22648 var serialized = serializeStyles(args, cache2.registered); 22649 { 22650 insertStyles(cache2, serialized, false); 22651 } 22652 return cache2.key + "-" + serialized.name; 22653 }; 22654 var cx3 = function cx4() { 22655 if (hasRendered && true) { 22656 throw new Error("cx can only be used during render"); 22657 } 22658 for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { 22659 args[_key2] = arguments[_key2]; 22660 } 22661 return merge(cache2.registered, css6, classnames(args)); 22662 }; 22663 var content = { 22664 css: css6, 22665 cx: cx3, 22666 theme: (0, import_react81.useContext)(ThemeContext) 22667 }; 22668 var ele = props.children(content); 22669 hasRendered = true; 22670 var possiblyStyleElement = /* @__PURE__ */ (0, import_react81.createElement)(Noop3, null); 22671 return /* @__PURE__ */ (0, import_react81.createElement)(import_react81.Fragment, null, possiblyStyleElement, ele); 22672 }); 22673 if (true) { 22674 ClassNames.displayName = "EmotionClassNames"; 22675 } 22676 if (true) { 22677 isBrowser4 = true; 22678 isJest = typeof jest !== "undefined"; 22679 if (isBrowser4 && !isJest) { 22680 globalContext = // $FlowIgnore 22681 typeof globalThis !== "undefined" ? globalThis : isBrowser4 ? window : global; 22682 globalKey = "__EMOTION_REACT_" + pkg.version.split(".")[0] + "__"; 22683 if (globalContext[globalKey]) { 22684 console.warn("You are loading @emotion/react when it is already loaded. Running multiple instances may cause problems. This can happen if multiple versions are used, or if multiple builds of the same version are used."); 22685 } 22686 globalContext[globalKey] = true; 22687 } 22688 } 22689 var isBrowser4; 22690 var isJest; 22691 var globalContext; 22692 var globalKey; 22693 22694 // node_modules/@emotion/css/create-instance/dist/emotion-css-create-instance.esm.js 22695 function insertWithoutScoping(cache2, serialized) { 22696 if (cache2.inserted[serialized.name] === void 0) { 22697 return cache2.insert("", serialized, cache2.sheet, true); 22698 } 22699 } 22700 function merge2(registered, css6, className2) { 22701 var registeredStyles = []; 22702 var rawClassName = getRegisteredStyles(registered, registeredStyles, className2); 22703 if (registeredStyles.length < 2) { 22704 return className2; 22705 } 22706 return rawClassName + css6(registeredStyles); 22707 } 22708 var createEmotion = function createEmotion2(options2) { 22709 var cache2 = emotion_cache_browser_esm_default(options2); 22710 cache2.sheet.speedy = function(value) { 22711 if (this.ctr !== 0) { 22712 throw new Error("speedy must be changed before any rules are inserted"); 22713 } 22714 this.isSpeedy = value; 22715 }; 22716 cache2.compat = true; 22717 var css6 = function css7() { 22718 for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { 22719 args[_key] = arguments[_key]; 22720 } 22721 var serialized = serializeStyles(args, cache2.registered, void 0); 22722 insertStyles(cache2, serialized, false); 22723 return cache2.key + "-" + serialized.name; 22724 }; 22725 var keyframes5 = function keyframes6() { 22726 for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { 22727 args[_key2] = arguments[_key2]; 22728 } 22729 var serialized = serializeStyles(args, cache2.registered); 22730 var animation = "animation-" + serialized.name; 22731 insertWithoutScoping(cache2, { 22732 name: serialized.name, 22733 styles: "@keyframes " + animation + "{" + serialized.styles + "}" 22734 }); 22735 return animation; 22736 }; 22737 var injectGlobal2 = function injectGlobal3() { 22738 for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { 22739 args[_key3] = arguments[_key3]; 22740 } 22741 var serialized = serializeStyles(args, cache2.registered); 22742 insertWithoutScoping(cache2, serialized); 22743 }; 22744 var cx3 = function cx4() { 22745 for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { 22746 args[_key4] = arguments[_key4]; 22747 } 22748 return merge2(cache2.registered, css6, classnames3(args)); 22749 }; 22750 return { 22751 css: css6, 22752 cx: cx3, 22753 injectGlobal: injectGlobal2, 22754 keyframes: keyframes5, 22755 hydrate: function hydrate2(ids) { 22756 ids.forEach(function(key) { 22757 cache2.inserted[key] = true; 22758 }); 22759 }, 22760 flush: function flush2() { 22761 cache2.registered = {}; 22762 cache2.inserted = {}; 22763 cache2.sheet.flush(); 22764 }, 22765 // $FlowFixMe 22766 sheet: cache2.sheet, 22767 cache: cache2, 22768 getRegisteredStyles: getRegisteredStyles.bind(null, cache2.registered), 22769 merge: merge2.bind(null, cache2.registered, css6) 22770 }; 22771 }; 22772 var classnames3 = function classnames4(args) { 22773 var cls = ""; 22774 for (var i3 = 0; i3 < args.length; i3++) { 22775 var arg = args[i3]; 22776 if (arg == null) continue; 22777 var toAdd = void 0; 22778 switch (typeof arg) { 22779 case "boolean": 22780 break; 22781 case "object": { 22782 if (Array.isArray(arg)) { 22783 toAdd = classnames4(arg); 22784 } else { 22785 toAdd = ""; 22786 for (var k2 in arg) { 22787 if (arg[k2] && k2) { 22788 toAdd && (toAdd += " "); 22789 toAdd += k2; 22790 } 22791 } 22792 } 22793 break; 22794 } 22795 default: { 22796 toAdd = arg; 22797 } 22798 } 22799 if (toAdd) { 22800 cls && (cls += " "); 22801 cls += toAdd; 22802 } 22803 } 22804 return cls; 22805 }; 22806 var emotion_css_create_instance_esm_default = createEmotion; 22807 22808 // node_modules/@emotion/css/dist/emotion-css.esm.js 22809 var _createEmotion = emotion_css_create_instance_esm_default({ 22810 key: "css" 22811 }); 22812 var flush = _createEmotion.flush; 22813 var hydrate = _createEmotion.hydrate; 22814 var cx2 = _createEmotion.cx; 22815 var merge3 = _createEmotion.merge; 22816 var getRegisteredStyles2 = _createEmotion.getRegisteredStyles; 22817 var injectGlobal = _createEmotion.injectGlobal; 22818 var keyframes4 = _createEmotion.keyframes; 22819 var css2 = _createEmotion.css; 22820 var sheet = _createEmotion.sheet; 22821 var cache = _createEmotion.cache; 22822 22823 // packages/components/build-module/utils/hooks/use-cx.js 22824 var import_element13 = __toESM(require_element()); 22825 var isSerializedStyles = (o4) => typeof o4 !== "undefined" && o4 !== null && ["name", "styles"].every((p3) => typeof o4[p3] !== "undefined"); 22826 var useCx = () => { 22827 const cache2 = __unsafe_useEmotionCache(); 22828 const cx3 = (0, import_element13.useCallback)((...classNames) => { 22829 if (cache2 === null) { 22830 throw new Error("The `useCx` hook should be only used within a valid Emotion Cache Context"); 22831 } 22832 return cx2(...classNames.map((arg) => { 22833 if (isSerializedStyles(arg)) { 22834 insertStyles(cache2, arg, false); 22835 return `$cache2.key}-$arg.name}`; 22836 } 22837 return arg; 22838 })); 22839 }, [cache2]); 22840 return cx3; 22841 }; 22842 22843 // packages/components/build-module/utils/box-sizing.js 22844 function _EMOTION_STRINGIFIED_CSS_ERROR__() { 22845 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 22846 } 22847 var boxSizingReset = false ? { 22848 name: "kv6lnz", 22849 styles: "box-sizing:border-box;*,*::before,*::after{box-sizing:inherit;}" 22850 } : { 22851 name: "1pa5nhz-boxSizingReset", 22852 styles: "box-sizing:border-box;*,*::before,*::after{box-sizing:inherit;};label:boxSizingReset;", 22853 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1zaXppbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS2lDIiwiZmlsZSI6ImJveC1zaXppbmcudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBib3hTaXppbmdSZXNldCA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQqLFxuXHQqOjpiZWZvcmUsXG5cdCo6OmFmdGVyIHtcblx0XHRib3gtc2l6aW5nOiBpbmhlcml0O1xuXHR9XG5gO1xuIl19 */", 22854 toString: _EMOTION_STRINGIFIED_CSS_ERROR__ 22855 }; 22856 22857 // node_modules/memize/dist/index.js 22858 function memize(fn, options2) { 22859 var size3 = 0; 22860 var head; 22861 var tail; 22862 options2 = options2 || {}; 22863 function memoized() { 22864 var node2 = head, len = arguments.length, args, i3; 22865 searchCache: while (node2) { 22866 if (node2.args.length !== arguments.length) { 22867 node2 = node2.next; 22868 continue; 22869 } 22870 for (i3 = 0; i3 < len; i3++) { 22871 if (node2.args[i3] !== arguments[i3]) { 22872 node2 = node2.next; 22873 continue searchCache; 22874 } 22875 } 22876 if (node2 !== head) { 22877 if (node2 === tail) { 22878 tail = node2.prev; 22879 } 22880 node2.prev.next = node2.next; 22881 if (node2.next) { 22882 node2.next.prev = node2.prev; 22883 } 22884 node2.next = head; 22885 node2.prev = null; 22886 head.prev = node2; 22887 head = node2; 22888 } 22889 return node2.val; 22890 } 22891 args = new Array(len); 22892 for (i3 = 0; i3 < len; i3++) { 22893 args[i3] = arguments[i3]; 22894 } 22895 node2 = { 22896 args, 22897 // Generate the result from original function 22898 val: fn.apply(null, args) 22899 }; 22900 if (head) { 22901 head.prev = node2; 22902 node2.next = head; 22903 } else { 22904 tail = node2; 22905 } 22906 if (size3 === /** @type {MemizeOptions} */ 22907 options2.maxSize) { 22908 tail = /** @type {MemizeCacheNode} */ 22909 tail.prev; 22910 tail.next = null; 22911 } else { 22912 size3++; 22913 } 22914 head = node2; 22915 return node2.val; 22916 } 22917 memoized.clear = function() { 22918 head = null; 22919 tail = null; 22920 size3 = 0; 22921 }; 22922 return memoized; 22923 } 22924 22925 // node_modules/colord/index.mjs 22926 var r2 = { grad: 0.9, turn: 360, rad: 360 / (2 * Math.PI) }; 22927 var t = function(r4) { 22928 return "string" == typeof r4 ? r4.length > 0 : "number" == typeof r4; 22929 }; 22930 var n = function(r4, t4, n3) { 22931 return void 0 === t4 && (t4 = 0), void 0 === n3 && (n3 = Math.pow(10, t4)), Math.round(n3 * r4) / n3 + 0; 22932 }; 22933 var e = function(r4, t4, n3) { 22934 return void 0 === t4 && (t4 = 0), void 0 === n3 && (n3 = 1), r4 > n3 ? n3 : r4 > t4 ? r4 : t4; 22935 }; 22936 var u = function(r4) { 22937 return (r4 = isFinite(r4) ? r4 % 360 : 0) > 0 ? r4 : r4 + 360; 22938 }; 22939 var a = function(r4) { 22940 return { r: e(r4.r, 0, 255), g: e(r4.g, 0, 255), b: e(r4.b, 0, 255), a: e(r4.a) }; 22941 }; 22942 var o = function(r4) { 22943 return { r: n(r4.r), g: n(r4.g), b: n(r4.b), a: n(r4.a, 3) }; 22944 }; 22945 var i = /^#([0-9a-f]{3,8})$/i; 22946 var s = function(r4) { 22947 var t4 = r4.toString(16); 22948 return t4.length < 2 ? "0" + t4 : t4; 22949 }; 22950 var h = function(r4) { 22951 var t4 = r4.r, n3 = r4.g, e3 = r4.b, u3 = r4.a, a3 = Math.max(t4, n3, e3), o4 = a3 - Math.min(t4, n3, e3), i3 = o4 ? a3 === t4 ? (n3 - e3) / o4 : a3 === n3 ? 2 + (e3 - t4) / o4 : 4 + (t4 - n3) / o4 : 0; 22952 return { h: 60 * (i3 < 0 ? i3 + 6 : i3), s: a3 ? o4 / a3 * 100 : 0, v: a3 / 255 * 100, a: u3 }; 22953 }; 22954 var b = function(r4) { 22955 var t4 = r4.h, n3 = r4.s, e3 = r4.v, u3 = r4.a; 22956 t4 = t4 / 360 * 6, n3 /= 100, e3 /= 100; 22957 var a3 = Math.floor(t4), o4 = e3 * (1 - n3), i3 = e3 * (1 - (t4 - a3) * n3), s3 = e3 * (1 - (1 - t4 + a3) * n3), h3 = a3 % 6; 22958 return { r: 255 * [e3, i3, o4, o4, s3, e3][h3], g: 255 * [s3, e3, e3, i3, o4, o4][h3], b: 255 * [o4, o4, s3, e3, e3, i3][h3], a: u3 }; 22959 }; 22960 var g = function(r4) { 22961 return { h: u(r4.h), s: e(r4.s, 0, 100), l: e(r4.l, 0, 100), a: e(r4.a) }; 22962 }; 22963 var d = function(r4) { 22964 return { h: n(r4.h), s: n(r4.s), l: n(r4.l), a: n(r4.a, 3) }; 22965 }; 22966 var f = function(r4) { 22967 return b((n3 = (t4 = r4).s, { h: t4.h, s: (n3 *= ((e3 = t4.l) < 50 ? e3 : 100 - e3) / 100) > 0 ? 2 * n3 / (e3 + n3) * 100 : 0, v: e3 + n3, a: t4.a })); 22968 var t4, n3, e3; 22969 }; 22970 var c = function(r4) { 22971 return { h: (t4 = h(r4)).h, s: (u3 = (200 - (n3 = t4.s)) * (e3 = t4.v) / 100) > 0 && u3 < 200 ? n3 * e3 / 100 / (u3 <= 100 ? u3 : 200 - u3) * 100 : 0, l: u3 / 2, a: t4.a }; 22972 var t4, n3, e3, u3; 22973 }; 22974 var l = /^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s*,\s*([+-]?\d*\.?\d+)%\s*,\s*([+-]?\d*\.?\d+)%\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i; 22975 var p = /^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s+([+-]?\d*\.?\d+)%\s+([+-]?\d*\.?\d+)%\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i; 22976 var v = /^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i; 22977 var m = /^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i; 22978 var y = { string: [[function(r4) { 22979 var t4 = i.exec(r4); 22980 return t4 ? (r4 = t4[1]).length <= 4 ? { r: parseInt(r4[0] + r4[0], 16), g: parseInt(r4[1] + r4[1], 16), b: parseInt(r4[2] + r4[2], 16), a: 4 === r4.length ? n(parseInt(r4[3] + r4[3], 16) / 255, 2) : 1 } : 6 === r4.length || 8 === r4.length ? { r: parseInt(r4.substr(0, 2), 16), g: parseInt(r4.substr(2, 2), 16), b: parseInt(r4.substr(4, 2), 16), a: 8 === r4.length ? n(parseInt(r4.substr(6, 2), 16) / 255, 2) : 1 } : null : null; 22981 }, "hex"], [function(r4) { 22982 var t4 = v.exec(r4) || m.exec(r4); 22983 return t4 ? t4[2] !== t4[4] || t4[4] !== t4[6] ? null : a({ r: Number(t4[1]) / (t4[2] ? 100 / 255 : 1), g: Number(t4[3]) / (t4[4] ? 100 / 255 : 1), b: Number(t4[5]) / (t4[6] ? 100 / 255 : 1), a: void 0 === t4[7] ? 1 : Number(t4[7]) / (t4[8] ? 100 : 1) }) : null; 22984 }, "rgb"], [function(t4) { 22985 var n3 = l.exec(t4) || p.exec(t4); 22986 if (!n3) return null; 22987 var e3, u3, a3 = g({ h: (e3 = n3[1], u3 = n3[2], void 0 === u3 && (u3 = "deg"), Number(e3) * (r2[u3] || 1)), s: Number(n3[3]), l: Number(n3[4]), a: void 0 === n3[5] ? 1 : Number(n3[5]) / (n3[6] ? 100 : 1) }); 22988 return f(a3); 22989 }, "hsl"]], object: [[function(r4) { 22990 var n3 = r4.r, e3 = r4.g, u3 = r4.b, o4 = r4.a, i3 = void 0 === o4 ? 1 : o4; 22991 return t(n3) && t(e3) && t(u3) ? a({ r: Number(n3), g: Number(e3), b: Number(u3), a: Number(i3) }) : null; 22992 }, "rgb"], [function(r4) { 22993 var n3 = r4.h, e3 = r4.s, u3 = r4.l, a3 = r4.a, o4 = void 0 === a3 ? 1 : a3; 22994 if (!t(n3) || !t(e3) || !t(u3)) return null; 22995 var i3 = g({ h: Number(n3), s: Number(e3), l: Number(u3), a: Number(o4) }); 22996 return f(i3); 22997 }, "hsl"], [function(r4) { 22998 var n3 = r4.h, a3 = r4.s, o4 = r4.v, i3 = r4.a, s3 = void 0 === i3 ? 1 : i3; 22999 if (!t(n3) || !t(a3) || !t(o4)) return null; 23000 var h3 = (function(r5) { 23001 return { h: u(r5.h), s: e(r5.s, 0, 100), v: e(r5.v, 0, 100), a: e(r5.a) }; 23002 })({ h: Number(n3), s: Number(a3), v: Number(o4), a: Number(s3) }); 23003 return b(h3); 23004 }, "hsv"]] }; 23005 var N = function(r4, t4) { 23006 for (var n3 = 0; n3 < t4.length; n3++) { 23007 var e3 = t4[n3][0](r4); 23008 if (e3) return [e3, t4[n3][1]]; 23009 } 23010 return [null, void 0]; 23011 }; 23012 var x = function(r4) { 23013 return "string" == typeof r4 ? N(r4.trim(), y.string) : "object" == typeof r4 && null !== r4 ? N(r4, y.object) : [null, void 0]; 23014 }; 23015 var I = function(r4) { 23016 return x(r4)[1]; 23017 }; 23018 var M = function(r4, t4) { 23019 var n3 = c(r4); 23020 return { h: n3.h, s: e(n3.s + 100 * t4, 0, 100), l: n3.l, a: n3.a }; 23021 }; 23022 var H = function(r4) { 23023 return (299 * r4.r + 587 * r4.g + 114 * r4.b) / 1e3 / 255; 23024 }; 23025 var $ = function(r4, t4) { 23026 var n3 = c(r4); 23027 return { h: n3.h, s: n3.s, l: e(n3.l + 100 * t4, 0, 100), a: n3.a }; 23028 }; 23029 var j = (function() { 23030 function r4(r5) { 23031 this.parsed = x(r5)[0], this.rgba = this.parsed || { r: 0, g: 0, b: 0, a: 1 }; 23032 } 23033 return r4.prototype.isValid = function() { 23034 return null !== this.parsed; 23035 }, r4.prototype.brightness = function() { 23036 return n(H(this.rgba), 2); 23037 }, r4.prototype.isDark = function() { 23038 return H(this.rgba) < 0.5; 23039 }, r4.prototype.isLight = function() { 23040 return H(this.rgba) >= 0.5; 23041 }, r4.prototype.toHex = function() { 23042 return r5 = o(this.rgba), t4 = r5.r, e3 = r5.g, u3 = r5.b, i3 = (a3 = r5.a) < 1 ? s(n(255 * a3)) : "", "#" + s(t4) + s(e3) + s(u3) + i3; 23043 var r5, t4, e3, u3, a3, i3; 23044 }, r4.prototype.toRgb = function() { 23045 return o(this.rgba); 23046 }, r4.prototype.toRgbString = function() { 23047 return r5 = o(this.rgba), t4 = r5.r, n3 = r5.g, e3 = r5.b, (u3 = r5.a) < 1 ? "rgba(" + t4 + ", " + n3 + ", " + e3 + ", " + u3 + ")" : "rgb(" + t4 + ", " + n3 + ", " + e3 + ")"; 23048 var r5, t4, n3, e3, u3; 23049 }, r4.prototype.toHsl = function() { 23050 return d(c(this.rgba)); 23051 }, r4.prototype.toHslString = function() { 23052 return r5 = d(c(this.rgba)), t4 = r5.h, n3 = r5.s, e3 = r5.l, (u3 = r5.a) < 1 ? "hsla(" + t4 + ", " + n3 + "%, " + e3 + "%, " + u3 + ")" : "hsl(" + t4 + ", " + n3 + "%, " + e3 + "%)"; 23053 var r5, t4, n3, e3, u3; 23054 }, r4.prototype.toHsv = function() { 23055 return r5 = h(this.rgba), { h: n(r5.h), s: n(r5.s), v: n(r5.v), a: n(r5.a, 3) }; 23056 var r5; 23057 }, r4.prototype.invert = function() { 23058 return w({ r: 255 - (r5 = this.rgba).r, g: 255 - r5.g, b: 255 - r5.b, a: r5.a }); 23059 var r5; 23060 }, r4.prototype.saturate = function(r5) { 23061 return void 0 === r5 && (r5 = 0.1), w(M(this.rgba, r5)); 23062 }, r4.prototype.desaturate = function(r5) { 23063 return void 0 === r5 && (r5 = 0.1), w(M(this.rgba, -r5)); 23064 }, r4.prototype.grayscale = function() { 23065 return w(M(this.rgba, -1)); 23066 }, r4.prototype.lighten = function(r5) { 23067 return void 0 === r5 && (r5 = 0.1), w($(this.rgba, r5)); 23068 }, r4.prototype.darken = function(r5) { 23069 return void 0 === r5 && (r5 = 0.1), w($(this.rgba, -r5)); 23070 }, r4.prototype.rotate = function(r5) { 23071 return void 0 === r5 && (r5 = 15), this.hue(this.hue() + r5); 23072 }, r4.prototype.alpha = function(r5) { 23073 return "number" == typeof r5 ? w({ r: (t4 = this.rgba).r, g: t4.g, b: t4.b, a: r5 }) : n(this.rgba.a, 3); 23074 var t4; 23075 }, r4.prototype.hue = function(r5) { 23076 var t4 = c(this.rgba); 23077 return "number" == typeof r5 ? w({ h: r5, s: t4.s, l: t4.l, a: t4.a }) : n(t4.h); 23078 }, r4.prototype.isEqual = function(r5) { 23079 return this.toHex() === w(r5).toHex(); 23080 }, r4; 23081 })(); 23082 var w = function(r4) { 23083 return r4 instanceof j ? r4 : new j(r4); 23084 }; 23085 var S = []; 23086 var k = function(r4) { 23087 r4.forEach(function(r5) { 23088 S.indexOf(r5) < 0 && (r5(j, y), S.push(r5)); 23089 }); 23090 }; 23091 23092 // node_modules/colord/plugins/names.mjs 23093 function names_default(e3, f3) { 23094 var a3 = { white: "#ffffff", bisque: "#ffe4c4", blue: "#0000ff", cadetblue: "#5f9ea0", chartreuse: "#7fff00", chocolate: "#d2691e", coral: "#ff7f50", antiquewhite: "#faebd7", aqua: "#00ffff", azure: "#f0ffff", whitesmoke: "#f5f5f5", papayawhip: "#ffefd5", plum: "#dda0dd", blanchedalmond: "#ffebcd", black: "#000000", gold: "#ffd700", goldenrod: "#daa520", gainsboro: "#dcdcdc", cornsilk: "#fff8dc", cornflowerblue: "#6495ed", burlywood: "#deb887", aquamarine: "#7fffd4", beige: "#f5f5dc", crimson: "#dc143c", cyan: "#00ffff", darkblue: "#00008b", darkcyan: "#008b8b", darkgoldenrod: "#b8860b", darkkhaki: "#bdb76b", darkgray: "#a9a9a9", darkgreen: "#006400", darkgrey: "#a9a9a9", peachpuff: "#ffdab9", darkmagenta: "#8b008b", darkred: "#8b0000", darkorchid: "#9932cc", darkorange: "#ff8c00", darkslateblue: "#483d8b", gray: "#808080", darkslategray: "#2f4f4f", darkslategrey: "#2f4f4f", deeppink: "#ff1493", deepskyblue: "#00bfff", wheat: "#f5deb3", firebrick: "#b22222", floralwhite: "#fffaf0", ghostwhite: "#f8f8ff", darkviolet: "#9400d3", magenta: "#ff00ff", green: "#008000", dodgerblue: "#1e90ff", grey: "#808080", honeydew: "#f0fff0", hotpink: "#ff69b4", blueviolet: "#8a2be2", forestgreen: "#228b22", lawngreen: "#7cfc00", indianred: "#cd5c5c", indigo: "#4b0082", fuchsia: "#ff00ff", brown: "#a52a2a", maroon: "#800000", mediumblue: "#0000cd", lightcoral: "#f08080", darkturquoise: "#00ced1", lightcyan: "#e0ffff", ivory: "#fffff0", lightyellow: "#ffffe0", lightsalmon: "#ffa07a", lightseagreen: "#20b2aa", linen: "#faf0e6", mediumaquamarine: "#66cdaa", lemonchiffon: "#fffacd", lime: "#00ff00", khaki: "#f0e68c", mediumseagreen: "#3cb371", limegreen: "#32cd32", mediumspringgreen: "#00fa9a", lightskyblue: "#87cefa", lightblue: "#add8e6", midnightblue: "#191970", lightpink: "#ffb6c1", mistyrose: "#ffe4e1", moccasin: "#ffe4b5", mintcream: "#f5fffa", lightslategray: "#778899", lightslategrey: "#778899", navajowhite: "#ffdead", navy: "#000080", mediumvioletred: "#c71585", powderblue: "#b0e0e6", palegoldenrod: "#eee8aa", oldlace: "#fdf5e6", paleturquoise: "#afeeee", mediumturquoise: "#48d1cc", mediumorchid: "#ba55d3", rebeccapurple: "#663399", lightsteelblue: "#b0c4de", mediumslateblue: "#7b68ee", thistle: "#d8bfd8", tan: "#d2b48c", orchid: "#da70d6", mediumpurple: "#9370db", purple: "#800080", pink: "#ffc0cb", skyblue: "#87ceeb", springgreen: "#00ff7f", palegreen: "#98fb98", red: "#ff0000", yellow: "#ffff00", slateblue: "#6a5acd", lavenderblush: "#fff0f5", peru: "#cd853f", palevioletred: "#db7093", violet: "#ee82ee", teal: "#008080", slategray: "#708090", slategrey: "#708090", aliceblue: "#f0f8ff", darkseagreen: "#8fbc8f", darkolivegreen: "#556b2f", greenyellow: "#adff2f", seagreen: "#2e8b57", seashell: "#fff5ee", tomato: "#ff6347", silver: "#c0c0c0", sienna: "#a0522d", lavender: "#e6e6fa", lightgreen: "#90ee90", orange: "#ffa500", orangered: "#ff4500", steelblue: "#4682b4", royalblue: "#4169e1", turquoise: "#40e0d0", yellowgreen: "#9acd32", salmon: "#fa8072", saddlebrown: "#8b4513", sandybrown: "#f4a460", rosybrown: "#bc8f8f", darksalmon: "#e9967a", lightgoldenrodyellow: "#fafad2", snow: "#fffafa", lightgrey: "#d3d3d3", lightgray: "#d3d3d3", dimgray: "#696969", dimgrey: "#696969", olivedrab: "#6b8e23", olive: "#808000" }, r4 = {}; 23095 for (var d3 in a3) r4[a3[d3]] = d3; 23096 var l3 = {}; 23097 e3.prototype.toName = function(f4) { 23098 if (!(this.rgba.a || this.rgba.r || this.rgba.g || this.rgba.b)) return "transparent"; 23099 var d4, i3, n3 = r4[this.toHex()]; 23100 if (n3) return n3; 23101 if (null == f4 ? void 0 : f4.closest) { 23102 var o4 = this.toRgb(), t4 = 1 / 0, b3 = "black"; 23103 if (!l3.length) for (var c3 in a3) l3[c3] = new e3(a3[c3]).toRgb(); 23104 for (var g3 in a3) { 23105 var u3 = (d4 = o4, i3 = l3[g3], Math.pow(d4.r - i3.r, 2) + Math.pow(d4.g - i3.g, 2) + Math.pow(d4.b - i3.b, 2)); 23106 u3 < t4 && (t4 = u3, b3 = g3); 23107 } 23108 return b3; 23109 } 23110 }; 23111 f3.string.push([function(f4) { 23112 var r5 = f4.toLowerCase(), d4 = "transparent" === r5 ? "#0000" : a3[r5]; 23113 return d4 ? new e3(d4).toRgb() : null; 23114 }, "name"]); 23115 } 23116 23117 // packages/components/build-module/utils/colors.js 23118 var colorComputationNode; 23119 k([names_default]); 23120 function getColorComputationNode() { 23121 if (typeof document === "undefined") { 23122 return; 23123 } 23124 if (!colorComputationNode) { 23125 const el = document.createElement("div"); 23126 el.setAttribute("data-g2-color-computation-node", ""); 23127 document.body.appendChild(el); 23128 colorComputationNode = el; 23129 } 23130 return colorComputationNode; 23131 } 23132 function isColor(value) { 23133 if (typeof value !== "string") { 23134 return false; 23135 } 23136 const test2 = w(value); 23137 return test2.isValid(); 23138 } 23139 function _getComputedBackgroundColor(backgroundColor) { 23140 if (typeof backgroundColor !== "string") { 23141 return ""; 23142 } 23143 if (isColor(backgroundColor)) { 23144 return backgroundColor; 23145 } 23146 if (!backgroundColor.includes("var(")) { 23147 return ""; 23148 } 23149 if (typeof document === "undefined") { 23150 return ""; 23151 } 23152 const el = getColorComputationNode(); 23153 if (!el) { 23154 return ""; 23155 } 23156 el.style.background = backgroundColor; 23157 const computedColor = window?.getComputedStyle(el).background; 23158 el.style.background = ""; 23159 return computedColor || ""; 23160 } 23161 var getComputedBackgroundColor = memize(_getComputedBackgroundColor); 23162 function getOptimalTextColor(backgroundColor) { 23163 const background2 = getComputedBackgroundColor(backgroundColor); 23164 return w(background2).isLight() ? "#000000" : "#ffffff"; 23165 } 23166 function getOptimalTextShade(backgroundColor) { 23167 const result = getOptimalTextColor(backgroundColor); 23168 return result === "#000000" ? "dark" : "light"; 23169 } 23170 23171 // packages/components/build-module/utils/rtl.js 23172 var import_i18n2 = __toESM(require_i18n()); 23173 var LOWER_LEFT_REGEXP = new RegExp(/-left/g); 23174 var LOWER_RIGHT_REGEXP = new RegExp(/-right/g); 23175 var UPPER_LEFT_REGEXP = new RegExp(/Left/g); 23176 var UPPER_RIGHT_REGEXP = new RegExp(/Right/g); 23177 function getConvertedKey(key) { 23178 if (key === "left") { 23179 return "right"; 23180 } 23181 if (key === "right") { 23182 return "left"; 23183 } 23184 if (LOWER_LEFT_REGEXP.test(key)) { 23185 return key.replace(LOWER_LEFT_REGEXP, "-right"); 23186 } 23187 if (LOWER_RIGHT_REGEXP.test(key)) { 23188 return key.replace(LOWER_RIGHT_REGEXP, "-left"); 23189 } 23190 if (UPPER_LEFT_REGEXP.test(key)) { 23191 return key.replace(UPPER_LEFT_REGEXP, "Right"); 23192 } 23193 if (UPPER_RIGHT_REGEXP.test(key)) { 23194 return key.replace(UPPER_RIGHT_REGEXP, "Left"); 23195 } 23196 return key; 23197 } 23198 var convertLTRToRTL = (ltrStyles = {}) => { 23199 return Object.fromEntries(Object.entries(ltrStyles).map(([key, value]) => [getConvertedKey(key), value])); 23200 }; 23201 function rtl(ltrStyles = {}, rtlStyles) { 23202 return () => { 23203 if (rtlStyles) { 23204 return (0, import_i18n2.isRTL)() ? /* @__PURE__ */ css(rtlStyles, false ? "" : ";label:rtl;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ0bC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RW9CIiwiZmlsZSI6InJ0bC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuY29uc3QgTE9XRVJfTEVGVF9SRUdFWFAgPSBuZXcgUmVnRXhwKCAvLWxlZnQvZyApO1xuY29uc3QgTE9XRVJfUklHSFRfUkVHRVhQID0gbmV3IFJlZ0V4cCggLy1yaWdodC9nICk7XG5jb25zdCBVUFBFUl9MRUZUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9MZWZ0L2cgKTtcbmNvbnN0IFVQUEVSX1JJR0hUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9SaWdodC9nICk7XG5cbi8qKlxuICogRmxpcHMgYSBDU1MgcHJvcGVydHkgZnJvbSBsZWZ0IDwtPiByaWdodC5cbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30ga2V5IFRoZSBDU1MgcHJvcGVydHkgbmFtZS5cbiAqXG4gKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBmbGlwcGVkIENTUyBwcm9wZXJ0eSBuYW1lLCBpZiBhcHBsaWNhYmxlLlxuICovXG5mdW5jdGlvbiBnZXRDb252ZXJ0ZWRLZXkoIGtleSApIHtcblx0aWYgKCBrZXkgPT09ICdsZWZ0JyApIHtcblx0XHRyZXR1cm4gJ3JpZ2h0Jztcblx0fVxuXG5cdGlmICgga2V5ID09PSAncmlnaHQnICkge1xuXHRcdHJldHVybiAnbGVmdCc7XG5cdH1cblxuXHRpZiAoIExPV0VSX0xFRlRfUkVHRVhQLnRlc3QoIGtleSApICkge1xuXHRcdHJldHVybiBrZXkucmVwbGFjZSggTE9XRVJfTEVGVF9SRUdFWFAsICctcmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIExPV0VSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIExPV0VSX1JJR0hUX1JFR0VYUCwgJy1sZWZ0JyApO1xuXHR9XG5cblx0aWYgKCBVUFBFUl9MRUZUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX0xFRlRfUkVHRVhQLCAnUmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIFVQUEVSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX1JJR0hUX1JFR0VYUCwgJ0xlZnQnICk7XG5cdH1cblxuXHRyZXR1cm4ga2V5O1xufVxuXG4vKipcbiAqIEFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBjb252ZXJ0ZXIgZm9yIHN0eWxlIHByb3BlcnRpZXNcbiAqXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBsdHJTdHlsZXNcbiAqXG4gKiBAcmV0dXJuIHtpbXBvcnQoJ3JlYWN0JykuQ1NTUHJvcGVydGllc30gQ29udmVydGVkIGx0ciAtPiBydGwgc3R5bGVzXG4gKi9cbmV4cG9ydCBjb25zdCBjb252ZXJ0TFRSVG9SVEwgPSAoIGx0clN0eWxlcyA9IHt9ICkgPT4ge1xuXHRyZXR1cm4gT2JqZWN0LmZyb21FbnRyaWVzKFxuXHRcdE9iamVjdC5lbnRyaWVzKCBsdHJTdHlsZXMgKS5tYXAoICggWyBrZXksIHZhbHVlIF0gKSA9PiBbXG5cdFx0XHRnZXRDb252ZXJ0ZWRLZXkoIGtleSApLFxuXHRcdFx0dmFsdWUsXG5cdFx0XSApXG5cdCk7XG59O1xuXG4vKipcbiAqIEEgaGlnaGVyLW9yZGVyIGZ1bmN0aW9uIHRoYXQgY3JlYXRlIGFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBzdHlsZSBjb252ZXJ0ZXIgZm9yIENTUyBvYmplY3RzLlxuICpcbiAqIEBwYXJhbSB7aW1wb3J0KCdyZWFjdCcpLkNTU1Byb3BlcnRpZXN9IGx0clN0eWxlcyAgIEx0ciBzdHlsZXMuIENvbnZlcnRzIGFuZCByZW5kZXJzIGZyb20gbHRyIC0+IHJ0bCBzdHlsZXMsIGlmIGFwcGxpY2FibGUuXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBbcnRsU3R5bGVzXSBSdGwgc3R5bGVzLiBSZW5kZXJzIGlmIHByb3ZpZGVkLlxuICpcbiAqIEByZXR1cm4geygpID0+IGltcG9ydCgnQGVtb3Rpb24vcmVhY3QnKS5TZXJpYWxpemVkU3R5bGVzfSBBIGZ1bmN0aW9uIHRvIG91dHB1dCBDU1Mgc3R5bGVzIGZvciBFbW90aW9uJ3MgcmVuZGVyZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJ0bCggbHRyU3R5bGVzID0ge30sIHJ0bFN0eWxlcyApIHtcblx0cmV0dXJuICgpID0+IHtcblx0XHRpZiAoIHJ0bFN0eWxlcyApIHtcblx0XHRcdC8vIEB0cy1pZ25vcmU6IGBjc3NgIHR5cGVzIGFyZSB3cm9uZywgaXQgY2FuIGFjY2VwdCBhbiBvYmplY3Q6IGh0dHBzOi8vZW1vdGlvbi5zaC9kb2NzL29iamVjdC1zdHlsZXMjd2l0aC1jc3Ncblx0XHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBydGxTdHlsZXMgKSA6IGNzcyggbHRyU3R5bGVzICk7XG5cdFx0fVxuXG5cdFx0Ly8gQHRzLWlnbm9yZTogYGNzc2AgdHlwZXMgYXJlIHdyb25nLCBpdCBjYW4gYWNjZXB0IGFuIG9iamVjdDogaHR0cHM6Ly9lbW90aW9uLnNoL2RvY3Mvb2JqZWN0LXN0eWxlcyN3aXRoLWNzc1xuXHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBjb252ZXJ0TFRSVG9SVEwoIGx0clN0eWxlcyApICkgOiBjc3MoIGx0clN0eWxlcyApO1xuXHR9O1xufVxuXG4vKipcbiAqIENhbGwgdGhpcyBpbiB0aGUgYHVzZU1lbW9gIGRlcGVuZGVuY3kgYXJyYXkgdG8gZW5zdXJlIHRoYXQgc3Vic2VxdWVudCByZW5kZXJzIHdpbGxcbiAqIGNhdXNlIHJ0bCBzdHlsZXMgdG8gdXBkYXRlIGJhc2VkIG9uIHRoZSBgaXNSVExgIHJldHVybiB2YWx1ZSBldmVuIGlmIGFsbCBvdGhlciBkZXBlbmRlbmNpZXNcbiAqIHJlbWFpbiB0aGUgc2FtZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgc3R5bGVzID0gdXNlTWVtbyggKCkgPT4ge1xuICogICByZXR1cm4gY3NzYFxuICogICAgICR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzEwcHgnIH0gKSB9XG4gKiAgIGA7XG4gKiB9LCBbIHJ0bC53YXRjaCgpIF0gKTtcbiAqL1xucnRsLndhdGNoID0gKCkgPT4gaXNSVEwoKTtcbiJdfQ== */") : /* @__PURE__ */ css(ltrStyles, false ? "" : ";label:rtl;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ0bC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RXVDIiwiZmlsZSI6InJ0bC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuY29uc3QgTE9XRVJfTEVGVF9SRUdFWFAgPSBuZXcgUmVnRXhwKCAvLWxlZnQvZyApO1xuY29uc3QgTE9XRVJfUklHSFRfUkVHRVhQID0gbmV3IFJlZ0V4cCggLy1yaWdodC9nICk7XG5jb25zdCBVUFBFUl9MRUZUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9MZWZ0L2cgKTtcbmNvbnN0IFVQUEVSX1JJR0hUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9SaWdodC9nICk7XG5cbi8qKlxuICogRmxpcHMgYSBDU1MgcHJvcGVydHkgZnJvbSBsZWZ0IDwtPiByaWdodC5cbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30ga2V5IFRoZSBDU1MgcHJvcGVydHkgbmFtZS5cbiAqXG4gKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBmbGlwcGVkIENTUyBwcm9wZXJ0eSBuYW1lLCBpZiBhcHBsaWNhYmxlLlxuICovXG5mdW5jdGlvbiBnZXRDb252ZXJ0ZWRLZXkoIGtleSApIHtcblx0aWYgKCBrZXkgPT09ICdsZWZ0JyApIHtcblx0XHRyZXR1cm4gJ3JpZ2h0Jztcblx0fVxuXG5cdGlmICgga2V5ID09PSAncmlnaHQnICkge1xuXHRcdHJldHVybiAnbGVmdCc7XG5cdH1cblxuXHRpZiAoIExPV0VSX0xFRlRfUkVHRVhQLnRlc3QoIGtleSApICkge1xuXHRcdHJldHVybiBrZXkucmVwbGFjZSggTE9XRVJfTEVGVF9SRUdFWFAsICctcmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIExPV0VSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIExPV0VSX1JJR0hUX1JFR0VYUCwgJy1sZWZ0JyApO1xuXHR9XG5cblx0aWYgKCBVUFBFUl9MRUZUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX0xFRlRfUkVHRVhQLCAnUmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIFVQUEVSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX1JJR0hUX1JFR0VYUCwgJ0xlZnQnICk7XG5cdH1cblxuXHRyZXR1cm4ga2V5O1xufVxuXG4vKipcbiAqIEFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBjb252ZXJ0ZXIgZm9yIHN0eWxlIHByb3BlcnRpZXNcbiAqXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBsdHJTdHlsZXNcbiAqXG4gKiBAcmV0dXJuIHtpbXBvcnQoJ3JlYWN0JykuQ1NTUHJvcGVydGllc30gQ29udmVydGVkIGx0ciAtPiBydGwgc3R5bGVzXG4gKi9cbmV4cG9ydCBjb25zdCBjb252ZXJ0TFRSVG9SVEwgPSAoIGx0clN0eWxlcyA9IHt9ICkgPT4ge1xuXHRyZXR1cm4gT2JqZWN0LmZyb21FbnRyaWVzKFxuXHRcdE9iamVjdC5lbnRyaWVzKCBsdHJTdHlsZXMgKS5tYXAoICggWyBrZXksIHZhbHVlIF0gKSA9PiBbXG5cdFx0XHRnZXRDb252ZXJ0ZWRLZXkoIGtleSApLFxuXHRcdFx0dmFsdWUsXG5cdFx0XSApXG5cdCk7XG59O1xuXG4vKipcbiAqIEEgaGlnaGVyLW9yZGVyIGZ1bmN0aW9uIHRoYXQgY3JlYXRlIGFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBzdHlsZSBjb252ZXJ0ZXIgZm9yIENTUyBvYmplY3RzLlxuICpcbiAqIEBwYXJhbSB7aW1wb3J0KCdyZWFjdCcpLkNTU1Byb3BlcnRpZXN9IGx0clN0eWxlcyAgIEx0ciBzdHlsZXMuIENvbnZlcnRzIGFuZCByZW5kZXJzIGZyb20gbHRyIC0+IHJ0bCBzdHlsZXMsIGlmIGFwcGxpY2FibGUuXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBbcnRsU3R5bGVzXSBSdGwgc3R5bGVzLiBSZW5kZXJzIGlmIHByb3ZpZGVkLlxuICpcbiAqIEByZXR1cm4geygpID0+IGltcG9ydCgnQGVtb3Rpb24vcmVhY3QnKS5TZXJpYWxpemVkU3R5bGVzfSBBIGZ1bmN0aW9uIHRvIG91dHB1dCBDU1Mgc3R5bGVzIGZvciBFbW90aW9uJ3MgcmVuZGVyZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJ0bCggbHRyU3R5bGVzID0ge30sIHJ0bFN0eWxlcyApIHtcblx0cmV0dXJuICgpID0+IHtcblx0XHRpZiAoIHJ0bFN0eWxlcyApIHtcblx0XHRcdC8vIEB0cy1pZ25vcmU6IGBjc3NgIHR5cGVzIGFyZSB3cm9uZywgaXQgY2FuIGFjY2VwdCBhbiBvYmplY3Q6IGh0dHBzOi8vZW1vdGlvbi5zaC9kb2NzL29iamVjdC1zdHlsZXMjd2l0aC1jc3Ncblx0XHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBydGxTdHlsZXMgKSA6IGNzcyggbHRyU3R5bGVzICk7XG5cdFx0fVxuXG5cdFx0Ly8gQHRzLWlnbm9yZTogYGNzc2AgdHlwZXMgYXJlIHdyb25nLCBpdCBjYW4gYWNjZXB0IGFuIG9iamVjdDogaHR0cHM6Ly9lbW90aW9uLnNoL2RvY3Mvb2JqZWN0LXN0eWxlcyN3aXRoLWNzc1xuXHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBjb252ZXJ0TFRSVG9SVEwoIGx0clN0eWxlcyApICkgOiBjc3MoIGx0clN0eWxlcyApO1xuXHR9O1xufVxuXG4vKipcbiAqIENhbGwgdGhpcyBpbiB0aGUgYHVzZU1lbW9gIGRlcGVuZGVuY3kgYXJyYXkgdG8gZW5zdXJlIHRoYXQgc3Vic2VxdWVudCByZW5kZXJzIHdpbGxcbiAqIGNhdXNlIHJ0bCBzdHlsZXMgdG8gdXBkYXRlIGJhc2VkIG9uIHRoZSBgaXNSVExgIHJldHVybiB2YWx1ZSBldmVuIGlmIGFsbCBvdGhlciBkZXBlbmRlbmNpZXNcbiAqIHJlbWFpbiB0aGUgc2FtZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgc3R5bGVzID0gdXNlTWVtbyggKCkgPT4ge1xuICogICByZXR1cm4gY3NzYFxuICogICAgICR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzEwcHgnIH0gKSB9XG4gKiAgIGA7XG4gKiB9LCBbIHJ0bC53YXRjaCgpIF0gKTtcbiAqL1xucnRsLndhdGNoID0gKCkgPT4gaXNSVEwoKTtcbiJdfQ== */"); 23205 } 23206 return (0, import_i18n2.isRTL)() ? /* @__PURE__ */ css(convertLTRToRTL(ltrStyles), false ? "" : ";label:rtl;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ0bC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRm1CIiwiZmlsZSI6InJ0bC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuY29uc3QgTE9XRVJfTEVGVF9SRUdFWFAgPSBuZXcgUmVnRXhwKCAvLWxlZnQvZyApO1xuY29uc3QgTE9XRVJfUklHSFRfUkVHRVhQID0gbmV3IFJlZ0V4cCggLy1yaWdodC9nICk7XG5jb25zdCBVUFBFUl9MRUZUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9MZWZ0L2cgKTtcbmNvbnN0IFVQUEVSX1JJR0hUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9SaWdodC9nICk7XG5cbi8qKlxuICogRmxpcHMgYSBDU1MgcHJvcGVydHkgZnJvbSBsZWZ0IDwtPiByaWdodC5cbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30ga2V5IFRoZSBDU1MgcHJvcGVydHkgbmFtZS5cbiAqXG4gKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBmbGlwcGVkIENTUyBwcm9wZXJ0eSBuYW1lLCBpZiBhcHBsaWNhYmxlLlxuICovXG5mdW5jdGlvbiBnZXRDb252ZXJ0ZWRLZXkoIGtleSApIHtcblx0aWYgKCBrZXkgPT09ICdsZWZ0JyApIHtcblx0XHRyZXR1cm4gJ3JpZ2h0Jztcblx0fVxuXG5cdGlmICgga2V5ID09PSAncmlnaHQnICkge1xuXHRcdHJldHVybiAnbGVmdCc7XG5cdH1cblxuXHRpZiAoIExPV0VSX0xFRlRfUkVHRVhQLnRlc3QoIGtleSApICkge1xuXHRcdHJldHVybiBrZXkucmVwbGFjZSggTE9XRVJfTEVGVF9SRUdFWFAsICctcmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIExPV0VSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIExPV0VSX1JJR0hUX1JFR0VYUCwgJy1sZWZ0JyApO1xuXHR9XG5cblx0aWYgKCBVUFBFUl9MRUZUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX0xFRlRfUkVHRVhQLCAnUmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIFVQUEVSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX1JJR0hUX1JFR0VYUCwgJ0xlZnQnICk7XG5cdH1cblxuXHRyZXR1cm4ga2V5O1xufVxuXG4vKipcbiAqIEFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBjb252ZXJ0ZXIgZm9yIHN0eWxlIHByb3BlcnRpZXNcbiAqXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBsdHJTdHlsZXNcbiAqXG4gKiBAcmV0dXJuIHtpbXBvcnQoJ3JlYWN0JykuQ1NTUHJvcGVydGllc30gQ29udmVydGVkIGx0ciAtPiBydGwgc3R5bGVzXG4gKi9cbmV4cG9ydCBjb25zdCBjb252ZXJ0TFRSVG9SVEwgPSAoIGx0clN0eWxlcyA9IHt9ICkgPT4ge1xuXHRyZXR1cm4gT2JqZWN0LmZyb21FbnRyaWVzKFxuXHRcdE9iamVjdC5lbnRyaWVzKCBsdHJTdHlsZXMgKS5tYXAoICggWyBrZXksIHZhbHVlIF0gKSA9PiBbXG5cdFx0XHRnZXRDb252ZXJ0ZWRLZXkoIGtleSApLFxuXHRcdFx0dmFsdWUsXG5cdFx0XSApXG5cdCk7XG59O1xuXG4vKipcbiAqIEEgaGlnaGVyLW9yZGVyIGZ1bmN0aW9uIHRoYXQgY3JlYXRlIGFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBzdHlsZSBjb252ZXJ0ZXIgZm9yIENTUyBvYmplY3RzLlxuICpcbiAqIEBwYXJhbSB7aW1wb3J0KCdyZWFjdCcpLkNTU1Byb3BlcnRpZXN9IGx0clN0eWxlcyAgIEx0ciBzdHlsZXMuIENvbnZlcnRzIGFuZCByZW5kZXJzIGZyb20gbHRyIC0+IHJ0bCBzdHlsZXMsIGlmIGFwcGxpY2FibGUuXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBbcnRsU3R5bGVzXSBSdGwgc3R5bGVzLiBSZW5kZXJzIGlmIHByb3ZpZGVkLlxuICpcbiAqIEByZXR1cm4geygpID0+IGltcG9ydCgnQGVtb3Rpb24vcmVhY3QnKS5TZXJpYWxpemVkU3R5bGVzfSBBIGZ1bmN0aW9uIHRvIG91dHB1dCBDU1Mgc3R5bGVzIGZvciBFbW90aW9uJ3MgcmVuZGVyZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJ0bCggbHRyU3R5bGVzID0ge30sIHJ0bFN0eWxlcyApIHtcblx0cmV0dXJuICgpID0+IHtcblx0XHRpZiAoIHJ0bFN0eWxlcyApIHtcblx0XHRcdC8vIEB0cy1pZ25vcmU6IGBjc3NgIHR5cGVzIGFyZSB3cm9uZywgaXQgY2FuIGFjY2VwdCBhbiBvYmplY3Q6IGh0dHBzOi8vZW1vdGlvbi5zaC9kb2NzL29iamVjdC1zdHlsZXMjd2l0aC1jc3Ncblx0XHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBydGxTdHlsZXMgKSA6IGNzcyggbHRyU3R5bGVzICk7XG5cdFx0fVxuXG5cdFx0Ly8gQHRzLWlnbm9yZTogYGNzc2AgdHlwZXMgYXJlIHdyb25nLCBpdCBjYW4gYWNjZXB0IGFuIG9iamVjdDogaHR0cHM6Ly9lbW90aW9uLnNoL2RvY3Mvb2JqZWN0LXN0eWxlcyN3aXRoLWNzc1xuXHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBjb252ZXJ0TFRSVG9SVEwoIGx0clN0eWxlcyApICkgOiBjc3MoIGx0clN0eWxlcyApO1xuXHR9O1xufVxuXG4vKipcbiAqIENhbGwgdGhpcyBpbiB0aGUgYHVzZU1lbW9gIGRlcGVuZGVuY3kgYXJyYXkgdG8gZW5zdXJlIHRoYXQgc3Vic2VxdWVudCByZW5kZXJzIHdpbGxcbiAqIGNhdXNlIHJ0bCBzdHlsZXMgdG8gdXBkYXRlIGJhc2VkIG9uIHRoZSBgaXNSVExgIHJldHVybiB2YWx1ZSBldmVuIGlmIGFsbCBvdGhlciBkZXBlbmRlbmNpZXNcbiAqIHJlbWFpbiB0aGUgc2FtZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgc3R5bGVzID0gdXNlTWVtbyggKCkgPT4ge1xuICogICByZXR1cm4gY3NzYFxuICogICAgICR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzEwcHgnIH0gKSB9XG4gKiAgIGA7XG4gKiB9LCBbIHJ0bC53YXRjaCgpIF0gKTtcbiAqL1xucnRsLndhdGNoID0gKCkgPT4gaXNSVEwoKTtcbiJdfQ== */") : /* @__PURE__ */ css(ltrStyles, false ? "" : ";label:rtl;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJ0bC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRnlEIiwiZmlsZSI6InJ0bC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuY29uc3QgTE9XRVJfTEVGVF9SRUdFWFAgPSBuZXcgUmVnRXhwKCAvLWxlZnQvZyApO1xuY29uc3QgTE9XRVJfUklHSFRfUkVHRVhQID0gbmV3IFJlZ0V4cCggLy1yaWdodC9nICk7XG5jb25zdCBVUFBFUl9MRUZUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9MZWZ0L2cgKTtcbmNvbnN0IFVQUEVSX1JJR0hUX1JFR0VYUCA9IG5ldyBSZWdFeHAoIC9SaWdodC9nICk7XG5cbi8qKlxuICogRmxpcHMgYSBDU1MgcHJvcGVydHkgZnJvbSBsZWZ0IDwtPiByaWdodC5cbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30ga2V5IFRoZSBDU1MgcHJvcGVydHkgbmFtZS5cbiAqXG4gKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBmbGlwcGVkIENTUyBwcm9wZXJ0eSBuYW1lLCBpZiBhcHBsaWNhYmxlLlxuICovXG5mdW5jdGlvbiBnZXRDb252ZXJ0ZWRLZXkoIGtleSApIHtcblx0aWYgKCBrZXkgPT09ICdsZWZ0JyApIHtcblx0XHRyZXR1cm4gJ3JpZ2h0Jztcblx0fVxuXG5cdGlmICgga2V5ID09PSAncmlnaHQnICkge1xuXHRcdHJldHVybiAnbGVmdCc7XG5cdH1cblxuXHRpZiAoIExPV0VSX0xFRlRfUkVHRVhQLnRlc3QoIGtleSApICkge1xuXHRcdHJldHVybiBrZXkucmVwbGFjZSggTE9XRVJfTEVGVF9SRUdFWFAsICctcmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIExPV0VSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIExPV0VSX1JJR0hUX1JFR0VYUCwgJy1sZWZ0JyApO1xuXHR9XG5cblx0aWYgKCBVUFBFUl9MRUZUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX0xFRlRfUkVHRVhQLCAnUmlnaHQnICk7XG5cdH1cblxuXHRpZiAoIFVQUEVSX1JJR0hUX1JFR0VYUC50ZXN0KCBrZXkgKSApIHtcblx0XHRyZXR1cm4ga2V5LnJlcGxhY2UoIFVQUEVSX1JJR0hUX1JFR0VYUCwgJ0xlZnQnICk7XG5cdH1cblxuXHRyZXR1cm4ga2V5O1xufVxuXG4vKipcbiAqIEFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBjb252ZXJ0ZXIgZm9yIHN0eWxlIHByb3BlcnRpZXNcbiAqXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBsdHJTdHlsZXNcbiAqXG4gKiBAcmV0dXJuIHtpbXBvcnQoJ3JlYWN0JykuQ1NTUHJvcGVydGllc30gQ29udmVydGVkIGx0ciAtPiBydGwgc3R5bGVzXG4gKi9cbmV4cG9ydCBjb25zdCBjb252ZXJ0TFRSVG9SVEwgPSAoIGx0clN0eWxlcyA9IHt9ICkgPT4ge1xuXHRyZXR1cm4gT2JqZWN0LmZyb21FbnRyaWVzKFxuXHRcdE9iamVjdC5lbnRyaWVzKCBsdHJTdHlsZXMgKS5tYXAoICggWyBrZXksIHZhbHVlIF0gKSA9PiBbXG5cdFx0XHRnZXRDb252ZXJ0ZWRLZXkoIGtleSApLFxuXHRcdFx0dmFsdWUsXG5cdFx0XSApXG5cdCk7XG59O1xuXG4vKipcbiAqIEEgaGlnaGVyLW9yZGVyIGZ1bmN0aW9uIHRoYXQgY3JlYXRlIGFuIGluY3JlZGlibHkgYmFzaWMgbHRyIC0+IHJ0bCBzdHlsZSBjb252ZXJ0ZXIgZm9yIENTUyBvYmplY3RzLlxuICpcbiAqIEBwYXJhbSB7aW1wb3J0KCdyZWFjdCcpLkNTU1Byb3BlcnRpZXN9IGx0clN0eWxlcyAgIEx0ciBzdHlsZXMuIENvbnZlcnRzIGFuZCByZW5kZXJzIGZyb20gbHRyIC0+IHJ0bCBzdHlsZXMsIGlmIGFwcGxpY2FibGUuXG4gKiBAcGFyYW0ge2ltcG9ydCgncmVhY3QnKS5DU1NQcm9wZXJ0aWVzfSBbcnRsU3R5bGVzXSBSdGwgc3R5bGVzLiBSZW5kZXJzIGlmIHByb3ZpZGVkLlxuICpcbiAqIEByZXR1cm4geygpID0+IGltcG9ydCgnQGVtb3Rpb24vcmVhY3QnKS5TZXJpYWxpemVkU3R5bGVzfSBBIGZ1bmN0aW9uIHRvIG91dHB1dCBDU1Mgc3R5bGVzIGZvciBFbW90aW9uJ3MgcmVuZGVyZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJ0bCggbHRyU3R5bGVzID0ge30sIHJ0bFN0eWxlcyApIHtcblx0cmV0dXJuICgpID0+IHtcblx0XHRpZiAoIHJ0bFN0eWxlcyApIHtcblx0XHRcdC8vIEB0cy1pZ25vcmU6IGBjc3NgIHR5cGVzIGFyZSB3cm9uZywgaXQgY2FuIGFjY2VwdCBhbiBvYmplY3Q6IGh0dHBzOi8vZW1vdGlvbi5zaC9kb2NzL29iamVjdC1zdHlsZXMjd2l0aC1jc3Ncblx0XHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBydGxTdHlsZXMgKSA6IGNzcyggbHRyU3R5bGVzICk7XG5cdFx0fVxuXG5cdFx0Ly8gQHRzLWlnbm9yZTogYGNzc2AgdHlwZXMgYXJlIHdyb25nLCBpdCBjYW4gYWNjZXB0IGFuIG9iamVjdDogaHR0cHM6Ly9lbW90aW9uLnNoL2RvY3Mvb2JqZWN0LXN0eWxlcyN3aXRoLWNzc1xuXHRcdHJldHVybiBpc1JUTCgpID8gY3NzKCBjb252ZXJ0TFRSVG9SVEwoIGx0clN0eWxlcyApICkgOiBjc3MoIGx0clN0eWxlcyApO1xuXHR9O1xufVxuXG4vKipcbiAqIENhbGwgdGhpcyBpbiB0aGUgYHVzZU1lbW9gIGRlcGVuZGVuY3kgYXJyYXkgdG8gZW5zdXJlIHRoYXQgc3Vic2VxdWVudCByZW5kZXJzIHdpbGxcbiAqIGNhdXNlIHJ0bCBzdHlsZXMgdG8gdXBkYXRlIGJhc2VkIG9uIHRoZSBgaXNSVExgIHJldHVybiB2YWx1ZSBldmVuIGlmIGFsbCBvdGhlciBkZXBlbmRlbmNpZXNcbiAqIHJlbWFpbiB0aGUgc2FtZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3Qgc3R5bGVzID0gdXNlTWVtbyggKCkgPT4ge1xuICogICByZXR1cm4gY3NzYFxuICogICAgICR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzEwcHgnIH0gKSB9XG4gKiAgIGA7XG4gKiB9LCBbIHJ0bC53YXRjaCgpIF0gKTtcbiAqL1xucnRsLndhdGNoID0gKCkgPT4gaXNSVEwoKTtcbiJdfQ== */"); 23207 }; 23208 } 23209 rtl.watch = () => (0, import_i18n2.isRTL)(); 23210 23211 // packages/components/build-module/utils/font-values.js 23212 var font_values_default = { 23213 "default.fontFamily": "-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif", 23214 "default.fontSize": "13px", 23215 "helpText.fontSize": "12px", 23216 mobileTextMinFontSize: "16px" 23217 }; 23218 23219 // packages/components/build-module/utils/font.js 23220 function font(value) { 23221 var _FONT$value; 23222 return (_FONT$value = font_values_default[value]) !== null && _FONT$value !== void 0 ? _FONT$value : ""; 23223 } 23224 23225 // packages/components/build-module/utils/breakpoint-values.js 23226 var breakpoint_values_default = { 23227 huge: "1440px", 23228 wide: "1280px", 23229 "x-large": "1080px", 23230 large: "960px", 23231 // admin sidebar auto folds 23232 medium: "782px", 23233 // Adminbar goes big. 23234 small: "600px", 23235 mobile: "480px", 23236 "zoomed-in": "280px" 23237 }; 23238 23239 // packages/components/build-module/utils/breakpoint.js 23240 var breakpoint = (point) => `@media (min-width: $breakpoint_values_default[point]})`; 23241 23242 // packages/components/build-module/utils/colors-values.js 23243 var white = "#fff"; 23244 var GRAY = { 23245 900: "#1e1e1e", 23246 800: "#2f2f2f", 23247 /** Meets 4.6:1 text contrast against white. */ 23248 700: "#757575", 23249 /** Meets 3:1 UI or large text contrast against white. */ 23250 600: "#949494", 23251 400: "#ccc", 23252 /** Used for most borders. */ 23253 300: "#ddd", 23254 /** Used sparingly for light borders. */ 23255 200: "#e0e0e0", 23256 /** Used for light gray backgrounds. */ 23257 100: "#f0f0f0" 23258 }; 23259 var ALERT = { 23260 yellow: "#f0b849", 23261 red: "#d94f4f", 23262 green: "#4ab866" 23263 }; 23264 var THEME = { 23265 accent: `var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9))`, 23266 accentDarker10: `var(--wp-components-color-accent-darker-10, var(--wp-admin-theme-color-darker-10, #2145e6))`, 23267 accentDarker20: `var(--wp-components-color-accent-darker-20, var(--wp-admin-theme-color-darker-20, #183ad6))`, 23268 /** Used when placing text on the accent color. */ 23269 accentInverted: `var(--wp-components-color-accent-inverted, $white})`, 23270 background: `var(--wp-components-color-background, $white})`, 23271 foreground: `var(--wp-components-color-foreground, $GRAY[900]})`, 23272 /** Used when placing text on the foreground color. */ 23273 foregroundInverted: `var(--wp-components-color-foreground-inverted, $white})`, 23274 gray: { 23275 /** @deprecated Use `COLORS.theme.foreground` instead. */ 23276 900: `var(--wp-components-color-foreground, $GRAY[900]})`, 23277 800: `var(--wp-components-color-gray-800, $GRAY[800]})`, 23278 700: `var(--wp-components-color-gray-700, $GRAY[700]})`, 23279 600: `var(--wp-components-color-gray-600, $GRAY[600]})`, 23280 400: `var(--wp-components-color-gray-400, $GRAY[400]})`, 23281 300: `var(--wp-components-color-gray-300, $GRAY[300]})`, 23282 200: `var(--wp-components-color-gray-200, $GRAY[200]})`, 23283 100: `var(--wp-components-color-gray-100, $GRAY[100]})` 23284 } 23285 }; 23286 var UI = { 23287 background: THEME.background, 23288 backgroundDisabled: THEME.gray[100], 23289 border: THEME.gray[600], 23290 borderHover: THEME.gray[700], 23291 borderFocus: THEME.accent, 23292 borderDisabled: THEME.gray[400], 23293 textDisabled: THEME.gray[600], 23294 // Matches @wordpress/base-styles 23295 darkGrayPlaceholder: `color-mix(in srgb, $THEME.foreground}, transparent 38%)`, 23296 lightGrayPlaceholder: `color-mix(in srgb, $THEME.background}, transparent 35%)` 23297 }; 23298 var COLORS = Object.freeze({ 23299 /** 23300 * The main gray color object. 23301 * 23302 * @deprecated Use semantic aliases in `COLORS.ui` or theme-ready variables in `COLORS.theme.gray`. 23303 */ 23304 gray: GRAY, 23305 // TODO: Stop exporting this when everything is migrated to `theme` or `ui` 23306 /** 23307 * @deprecated Prefer theme-ready variables in `COLORS.theme`. 23308 */ 23309 white, 23310 alert: ALERT, 23311 /** 23312 * Theme-ready variables with fallbacks. 23313 * 23314 * Prefer semantic aliases in `COLORS.ui` when applicable. 23315 */ 23316 theme: THEME, 23317 /** 23318 * Semantic aliases (prefer these over raw variables when applicable). 23319 */ 23320 ui: UI 23321 }); 23322 23323 // packages/components/build-module/utils/config-values.js 23324 var CONTROL_HEIGHT = "36px"; 23325 var CONTROL_PROPS = { 23326 // These values should be shared with TextControl. 23327 controlPaddingX: 12, 23328 controlPaddingXSmall: 8, 23329 controlPaddingXLarge: 12 * 1.3334, 23330 // TODO: Deprecate 23331 controlBoxShadowFocus: `0 0 0 0.5px $COLORS.theme.accent}`, 23332 controlHeight: CONTROL_HEIGHT, 23333 controlHeightXSmall: `calc( $CONTROL_HEIGHT} * 0.6 )`, 23334 controlHeightSmall: `calc( $CONTROL_HEIGHT} * 0.8 )`, 23335 controlHeightLarge: `calc( $CONTROL_HEIGHT} * 1.2 )`, 23336 controlHeightXLarge: `calc( $CONTROL_HEIGHT} * 1.4 )` 23337 }; 23338 var config_values_default = Object.assign({}, CONTROL_PROPS, { 23339 colorDivider: "rgba(0, 0, 0, 0.1)", 23340 colorScrollbarThumb: "rgba(0, 0, 0, 0.2)", 23341 colorScrollbarThumbHover: "rgba(0, 0, 0, 0.5)", 23342 colorScrollbarTrack: "rgba(0, 0, 0, 0.04)", 23343 elevationIntensity: 1, 23344 radiusXSmall: "1px", 23345 radiusSmall: "2px", 23346 radiusMedium: "4px", 23347 radiusLarge: "8px", 23348 radiusFull: "9999px", 23349 radiusRound: "50%", 23350 borderWidth: "1px", 23351 borderWidthFocus: "1.5px", 23352 borderWidthTab: "4px", 23353 spinnerSize: 16, 23354 fontSize: "13px", 23355 fontSizeH1: "calc(2.44 * 13px)", 23356 fontSizeH2: "calc(1.95 * 13px)", 23357 fontSizeH3: "calc(1.56 * 13px)", 23358 fontSizeH4: "calc(1.25 * 13px)", 23359 fontSizeH5: "13px", 23360 fontSizeH6: "calc(0.8 * 13px)", 23361 fontSizeInputMobile: "16px", 23362 fontSizeMobile: "15px", 23363 fontSizeSmall: "calc(0.92 * 13px)", 23364 fontSizeXSmall: "calc(0.75 * 13px)", 23365 fontLineHeightBase: "1.4", 23366 fontWeight: "normal", 23367 fontWeightMedium: "499", 23368 // ensures fallback to 400 (instead of 600) 23369 fontWeightHeading: "600", 23370 gridBase: "4px", 23371 elevationXSmall: `0 1px 1px rgba(0, 0, 0, 0.03), 0 1px 2px rgba(0, 0, 0, 0.02), 0 3px 3px rgba(0, 0, 0, 0.02), 0 4px 4px rgba(0, 0, 0, 0.01)`, 23372 elevationSmall: `0 1px 2px rgba(0, 0, 0, 0.05), 0 2px 3px rgba(0, 0, 0, 0.04), 0 6px 6px rgba(0, 0, 0, 0.03), 0 8px 8px rgba(0, 0, 0, 0.02)`, 23373 elevationMedium: `0 2px 3px rgba(0, 0, 0, 0.05), 0 4px 5px rgba(0, 0, 0, 0.04), 0 12px 12px rgba(0, 0, 0, 0.03), 0 16px 16px rgba(0, 0, 0, 0.02)`, 23374 elevationLarge: `0 5px 15px rgba(0, 0, 0, 0.08), 0 15px 27px rgba(0, 0, 0, 0.07), 0 30px 36px rgba(0, 0, 0, 0.04), 0 50px 43px rgba(0, 0, 0, 0.02)`, 23375 surfaceBackgroundColor: COLORS.white, 23376 surfaceBackgroundSubtleColor: "#F3F3F3", 23377 surfaceBackgroundTintColor: "#F5F5F5", 23378 surfaceBorderColor: "rgba(0, 0, 0, 0.1)", 23379 surfaceBorderBoldColor: "rgba(0, 0, 0, 0.15)", 23380 surfaceBorderSubtleColor: "rgba(0, 0, 0, 0.05)", 23381 surfaceBackgroundTertiaryColor: COLORS.white, 23382 surfaceColor: COLORS.white, 23383 transitionDuration: "200ms", 23384 transitionDurationFast: "160ms", 23385 transitionDurationFaster: "120ms", 23386 transitionDurationFastest: "100ms", 23387 transitionTimingFunction: "cubic-bezier(0.08, 0.52, 0.52, 1)", 23388 transitionTimingFunctionControl: "cubic-bezier(0.12, 0.8, 0.32, 1)" 23389 }); 23390 23391 // packages/components/build-module/utils/base-label.js 23392 var baseLabelTypography = /* @__PURE__ */ css("font-size:11px;font-weight:", config_values_default.fontWeightMedium, ";line-height:1.4;text-transform:uppercase;" + (false ? "" : ";label:baseLabelTypography;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtbGFiZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWXNDIiwiZmlsZSI6ImJhc2UtbGFiZWwudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBDT05GSUcgZnJvbSAnLi9jb25maWctdmFsdWVzLmpzJztcblxuLy8gVGhpcyBpcyBhIHZlcnkgbG93LWxldmVsIG1peGluIHdoaWNoIHlvdSBzaG91bGRuJ3QgaGF2ZSB0byB1c2UgZGlyZWN0bHkuXG4vLyBUcnkgdG8gdXNlIEJhc2VDb250cm9sJ3MgU3R5bGVkTGFiZWwgb3IgQmFzZUNvbnRyb2wuVmlzdWFsTGFiZWwgaWYgeW91IGNhbi5cbmV4cG9ydCBjb25zdCBiYXNlTGFiZWxUeXBvZ3JhcGh5ID0gY3NzYFxuXHRmb250LXNpemU6IDExcHg7XG5cdGZvbnQtd2VpZ2h0OiAkeyBDT05GSUcuZm9udFdlaWdodE1lZGl1bSB9O1xuXHRsaW5lLWhlaWdodDogMS40O1xuXHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuYDtcbiJdfQ== */"); 23393 23394 // packages/components/build-module/context/context-system-provider.js 23395 var import_jsx_runtime45 = __toESM(require_jsx_runtime()); 23396 var ComponentsContext = (0, import_element14.createContext)( 23397 /** @type {Record<string, any>} */ 23398 {} 23399 ); 23400 ComponentsContext.displayName = "ComponentsContext"; 23401 var useComponentsContext = () => (0, import_element14.useContext)(ComponentsContext); 23402 function useContextSystemBridge({ 23403 value 23404 }) { 23405 const parentContext = useComponentsContext(); 23406 const valueRef = (0, import_element14.useRef)(value); 23407 use_update_effect_default(() => { 23408 if ( 23409 // Objects are equivalent. 23410 (0, import_es6.default)(valueRef.current, value) && // But not the same reference. 23411 valueRef.current !== value 23412 ) { 23413 true ? (0, import_warning.default)(`Please memoize your context: $JSON.stringify(value)}`) : void 0; 23414 } 23415 }, [value]); 23416 const config = (0, import_element14.useMemo)(() => { 23417 return (0, import_deepmerge.default)(parentContext !== null && parentContext !== void 0 ? parentContext : {}, value !== null && value !== void 0 ? value : {}, { 23418 isMergeableObject: isPlainObject 23419 }); 23420 }, [parentContext, value]); 23421 return config; 23422 } 23423 var BaseContextSystemProvider = ({ 23424 children, 23425 value 23426 }) => { 23427 const contextValue = useContextSystemBridge({ 23428 value 23429 }); 23430 return /* @__PURE__ */ (0, import_jsx_runtime45.jsx)(ComponentsContext.Provider, { 23431 value: contextValue, 23432 children 23433 }); 23434 }; 23435 var ContextSystemProvider = (0, import_element14.memo)(BaseContextSystemProvider); 23436 23437 // packages/components/build-module/context/context-connect.js 23438 var import_element15 = __toESM(require_element()); 23439 var import_warning2 = __toESM(require_warning()); 23440 23441 // packages/components/build-module/context/constants.js 23442 var COMPONENT_NAMESPACE = "data-wp-component"; 23443 var CONNECTED_NAMESPACE = "data-wp-c16t"; 23444 var CONNECT_STATIC_NAMESPACE = "__contextSystemKey__"; 23445 23446 // node_modules/tslib/tslib.es6.mjs 23447 var __assign = function() { 23448 __assign = Object.assign || function __assign4(t4) { 23449 for (var s3, i3 = 1, n3 = arguments.length; i3 < n3; i3++) { 23450 s3 = arguments[i3]; 23451 for (var p3 in s3) if (Object.prototype.hasOwnProperty.call(s3, p3)) t4[p3] = s3[p3]; 23452 } 23453 return t4; 23454 }; 23455 return __assign.apply(this, arguments); 23456 }; 23457 23458 // node_modules/lower-case/dist.es2015/index.js 23459 function lowerCase(str) { 23460 return str.toLowerCase(); 23461 } 23462 23463 // node_modules/no-case/dist.es2015/index.js 23464 var DEFAULT_SPLIT_REGEXP = [/([a-z0-9])([A-Z])/g, /([A-Z])([A-Z][a-z])/g]; 23465 var DEFAULT_STRIP_REGEXP = /[^A-Z0-9]+/gi; 23466 function noCase(input, options2) { 23467 if (options2 === void 0) { 23468 options2 = {}; 23469 } 23470 var _a = options2.splitRegexp, splitRegexp = _a === void 0 ? DEFAULT_SPLIT_REGEXP : _a, _b = options2.stripRegexp, stripRegexp = _b === void 0 ? DEFAULT_STRIP_REGEXP : _b, _c = options2.transform, transform = _c === void 0 ? lowerCase : _c, _d = options2.delimiter, delimiter2 = _d === void 0 ? " " : _d; 23471 var result = replace2(replace2(input, splitRegexp, "$1\0$2"), stripRegexp, "\0"); 23472 var start = 0; 23473 var end = result.length; 23474 while (result.charAt(start) === "\0") 23475 start++; 23476 while (result.charAt(end - 1) === "\0") 23477 end--; 23478 return result.slice(start, end).split("\0").map(transform).join(delimiter2); 23479 } 23480 function replace2(input, re3, value) { 23481 if (re3 instanceof RegExp) 23482 return input.replace(re3, value); 23483 return re3.reduce(function(input2, re4) { 23484 return input2.replace(re4, value); 23485 }, input); 23486 } 23487 23488 // node_modules/dot-case/dist.es2015/index.js 23489 function dotCase(input, options2) { 23490 if (options2 === void 0) { 23491 options2 = {}; 23492 } 23493 return noCase(input, __assign({ delimiter: "." }, options2)); 23494 } 23495 23496 // node_modules/param-case/dist.es2015/index.js 23497 function paramCase(input, options2) { 23498 if (options2 === void 0) { 23499 options2 = {}; 23500 } 23501 return dotCase(input, __assign({ delimiter: "-" }, options2)); 23502 } 23503 23504 // packages/components/build-module/context/get-styled-class-name-from-key.js 23505 function getStyledClassName(namespace) { 23506 const kebab = paramCase(namespace); 23507 return `components-$kebab}`; 23508 } 23509 var getStyledClassNameFromKey = memize(getStyledClassName); 23510 23511 // packages/components/build-module/context/context-connect.js 23512 function contextConnect(Component9, namespace) { 23513 return _contextConnect(Component9, namespace, { 23514 forwardsRef: true 23515 }); 23516 } 23517 function contextConnectWithoutRef(Component9, namespace) { 23518 return _contextConnect(Component9, namespace); 23519 } 23520 function _contextConnect(Component9, namespace, options2) { 23521 const WrappedComponent = options2?.forwardsRef ? (0, import_element15.forwardRef)(Component9) : Component9; 23522 if (typeof namespace === "undefined") { 23523 true ? (0, import_warning2.default)("contextConnect: Please provide a namespace") : void 0; 23524 } 23525 let mergedNamespace = WrappedComponent[CONNECT_STATIC_NAMESPACE] || [namespace]; 23526 if (Array.isArray(namespace)) { 23527 mergedNamespace = [...mergedNamespace, ...namespace]; 23528 } 23529 if (typeof namespace === "string") { 23530 mergedNamespace = [...mergedNamespace, namespace]; 23531 } 23532 return Object.assign(WrappedComponent, { 23533 [CONNECT_STATIC_NAMESPACE]: [...new Set(mergedNamespace)], 23534 displayName: namespace, 23535 selector: `.$getStyledClassNameFromKey(namespace)}` 23536 }); 23537 } 23538 function getConnectNamespace(Component9) { 23539 if (!Component9) { 23540 return []; 23541 } 23542 let namespaces = []; 23543 if (Component9[CONNECT_STATIC_NAMESPACE]) { 23544 namespaces = Component9[CONNECT_STATIC_NAMESPACE]; 23545 } 23546 if (Component9.type && Component9.type[CONNECT_STATIC_NAMESPACE]) { 23547 namespaces = Component9.type[CONNECT_STATIC_NAMESPACE]; 23548 } 23549 return namespaces; 23550 } 23551 function hasConnectNamespace(Component9, match5) { 23552 if (!Component9) { 23553 return false; 23554 } 23555 if (typeof match5 === "string") { 23556 return getConnectNamespace(Component9).includes(match5); 23557 } 23558 if (Array.isArray(match5)) { 23559 return match5.some((result) => getConnectNamespace(Component9).includes(result)); 23560 } 23561 return false; 23562 } 23563 23564 // packages/components/build-module/context/use-context-system.js 23565 var import_warning3 = __toESM(require_warning()); 23566 23567 // packages/components/build-module/context/utils.js 23568 function getNamespace(componentName) { 23569 return { 23570 [COMPONENT_NAMESPACE]: componentName 23571 }; 23572 } 23573 function getConnectedNamespace() { 23574 return { 23575 [CONNECTED_NAMESPACE]: true 23576 }; 23577 } 23578 23579 // packages/components/build-module/context/use-context-system.js 23580 function useContextSystem(props, namespace) { 23581 const contextSystemProps = useComponentsContext(); 23582 if (typeof namespace === "undefined") { 23583 true ? (0, import_warning3.default)("useContextSystem: Please provide a namespace") : void 0; 23584 } 23585 const contextProps = contextSystemProps?.[namespace] || {}; 23586 const finalComponentProps = { 23587 ...getConnectedNamespace(), 23588 ...getNamespace(namespace) 23589 }; 23590 const { 23591 _overrides: overrideProps, 23592 ...otherContextProps 23593 } = contextProps; 23594 const initialMergedProps = Object.entries(otherContextProps).length ? Object.assign({}, otherContextProps, props) : props; 23595 const cx3 = useCx(); 23596 const classes = cx3(getStyledClassNameFromKey(namespace), props.className); 23597 const rendered = typeof initialMergedProps.renderChildren === "function" ? initialMergedProps.renderChildren(initialMergedProps) : initialMergedProps.children; 23598 for (const key in initialMergedProps) { 23599 finalComponentProps[key] = initialMergedProps[key]; 23600 } 23601 for (const key in overrideProps) { 23602 finalComponentProps[key] = overrideProps[key]; 23603 } 23604 if (rendered !== void 0) { 23605 finalComponentProps.children = rendered; 23606 } 23607 finalComponentProps.className = classes; 23608 return finalComponentProps; 23609 } 23610 23611 // packages/components/build-module/visually-hidden/styles.js 23612 var visuallyHidden = { 23613 border: 0, 23614 clip: "rect(1px, 1px, 1px, 1px)", 23615 WebkitClipPath: "inset( 50% )", 23616 clipPath: "inset( 50% )", 23617 height: "1px", 23618 margin: "-1px", 23619 overflow: "hidden", 23620 padding: 0, 23621 position: "absolute", 23622 width: "1px", 23623 wordWrap: "normal" 23624 }; 23625 23626 // node_modules/@emotion/styled/base/dist/emotion-styled-base.browser.esm.js 23627 var import_react85 = __toESM(require_react()); 23628 init_emotion_is_prop_valid_esm(); 23629 var testOmitPropsOnStringTag = isPropValid; 23630 var testOmitPropsOnComponent = function testOmitPropsOnComponent2(key) { 23631 return key !== "theme"; 23632 }; 23633 var getDefaultShouldForwardProp = function getDefaultShouldForwardProp2(tag) { 23634 return typeof tag === "string" && // 96 is one less than the char code 23635 // for "a" so this is checking that 23636 // it's a lowercase character 23637 tag.charCodeAt(0) > 96 ? testOmitPropsOnStringTag : testOmitPropsOnComponent; 23638 }; 23639 var composeShouldForwardProps = function composeShouldForwardProps2(tag, options2, isReal) { 23640 var shouldForwardProp; 23641 if (options2) { 23642 var optionsShouldForwardProp = options2.shouldForwardProp; 23643 shouldForwardProp = tag.__emotion_forwardProp && optionsShouldForwardProp ? function(propName) { 23644 return tag.__emotion_forwardProp(propName) && optionsShouldForwardProp(propName); 23645 } : optionsShouldForwardProp; 23646 } 23647 if (typeof shouldForwardProp !== "function" && isReal) { 23648 shouldForwardProp = tag.__emotion_forwardProp; 23649 } 23650 return shouldForwardProp; 23651 }; 23652 var ILLEGAL_ESCAPE_SEQUENCE_ERROR2 = `You have illegal escape sequence in your template literal, most likely inside content's property value. 23653 Because you write your CSS inside a JavaScript string you actually have to do double escaping, so for example "content: '\\00d7';" should become "content: '\\\\00d7';". 23654 You can read more about this here: 23655 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences`; 23656 var Noop5 = function Noop6() { 23657 return null; 23658 }; 23659 var createStyled = function createStyled2(tag, options2) { 23660 if (true) { 23661 if (tag === void 0) { 23662 throw new Error("You are trying to create a styled element with an undefined component.\nYou may have forgotten to import it."); 23663 } 23664 } 23665 var isReal = tag.__emotion_real === tag; 23666 var baseTag = isReal && tag.__emotion_base || tag; 23667 var identifierName; 23668 var targetClassName; 23669 if (options2 !== void 0) { 23670 identifierName = options2.label; 23671 targetClassName = options2.target; 23672 } 23673 var shouldForwardProp = composeShouldForwardProps(tag, options2, isReal); 23674 var defaultShouldForwardProp = shouldForwardProp || getDefaultShouldForwardProp(baseTag); 23675 var shouldUseAs = !defaultShouldForwardProp("as"); 23676 return function() { 23677 var args = arguments; 23678 var styles3 = isReal && tag.__emotion_styles !== void 0 ? tag.__emotion_styles.slice(0) : []; 23679 if (identifierName !== void 0) { 23680 styles3.push("label:" + identifierName + ";"); 23681 } 23682 if (args[0] == null || args[0].raw === void 0) { 23683 styles3.push.apply(styles3, args); 23684 } else { 23685 if (args[0][0] === void 0) { 23686 console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR2); 23687 } 23688 styles3.push(args[0][0]); 23689 var len = args.length; 23690 var i3 = 1; 23691 for (; i3 < len; i3++) { 23692 if (args[0][i3] === void 0) { 23693 console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR2); 23694 } 23695 styles3.push(args[i3], args[0][i3]); 23696 } 23697 } 23698 var Styled = withEmotionCache(function(props, cache2, ref) { 23699 var finalTag = shouldUseAs && props.as || baseTag; 23700 var className2 = ""; 23701 var classInterpolations = []; 23702 var mergedProps = props; 23703 if (props.theme == null) { 23704 mergedProps = {}; 23705 for (var key in props) { 23706 mergedProps[key] = props[key]; 23707 } 23708 mergedProps.theme = (0, import_react85.useContext)(ThemeContext); 23709 } 23710 if (typeof props.className === "string") { 23711 className2 = getRegisteredStyles(cache2.registered, classInterpolations, props.className); 23712 } else if (props.className != null) { 23713 className2 = props.className + " "; 23714 } 23715 var serialized = serializeStyles(styles3.concat(classInterpolations), cache2.registered, mergedProps); 23716 var rules = insertStyles(cache2, serialized, typeof finalTag === "string"); 23717 className2 += cache2.key + "-" + serialized.name; 23718 if (targetClassName !== void 0) { 23719 className2 += " " + targetClassName; 23720 } 23721 var finalShouldForwardProp = shouldUseAs && shouldForwardProp === void 0 ? getDefaultShouldForwardProp(finalTag) : defaultShouldForwardProp; 23722 var newProps = {}; 23723 for (var _key in props) { 23724 if (shouldUseAs && _key === "as") continue; 23725 if ( 23726 // $FlowFixMe 23727 finalShouldForwardProp(_key) 23728 ) { 23729 newProps[_key] = props[_key]; 23730 } 23731 } 23732 newProps.className = className2; 23733 newProps.ref = ref; 23734 var ele = /* @__PURE__ */ (0, import_react85.createElement)(finalTag, newProps); 23735 var possiblyStyleElement = /* @__PURE__ */ (0, import_react85.createElement)(Noop5, null); 23736 return /* @__PURE__ */ (0, import_react85.createElement)(import_react85.Fragment, null, possiblyStyleElement, ele); 23737 }); 23738 Styled.displayName = identifierName !== void 0 ? identifierName : "Styled(" + (typeof baseTag === "string" ? baseTag : baseTag.displayName || baseTag.name || "Component") + ")"; 23739 Styled.defaultProps = tag.defaultProps; 23740 Styled.__emotion_real = Styled; 23741 Styled.__emotion_base = baseTag; 23742 Styled.__emotion_styles = styles3; 23743 Styled.__emotion_forwardProp = shouldForwardProp; 23744 Object.defineProperty(Styled, "toString", { 23745 value: function value() { 23746 if (targetClassName === void 0 && true) { 23747 return "NO_COMPONENT_SELECTOR"; 23748 } 23749 return "." + targetClassName; 23750 } 23751 }); 23752 Styled.withComponent = function(nextTag, nextOptions) { 23753 return createStyled2(nextTag, _extends({}, options2, nextOptions, { 23754 shouldForwardProp: composeShouldForwardProps(Styled, nextOptions, true) 23755 })).apply(void 0, styles3); 23756 }; 23757 return Styled; 23758 }; 23759 }; 23760 var emotion_styled_base_browser_esm_default = createStyled; 23761 23762 // packages/components/build-module/view/component.js 23763 var import_element16 = __toESM(require_element()); 23764 var import_jsx_runtime46 = __toESM(require_jsx_runtime()); 23765 var PolymorphicDiv = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 23766 target: "e19lxcc00" 23767 } : { 23768 target: "e19lxcc00", 23769 label: "PolymorphicDiv" 23770 })(false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZWlDIiwiZmlsZSI6ImNvbXBvbmVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuXG5jb25zdCBQb2x5bW9ycGhpY0RpdiA9IHN0eWxlZC5kaXZgYDtcblxuZnVuY3Rpb24gVW5mb3J3YXJkZWRWaWV3PCBUIGV4dGVuZHMgUmVhY3QuRWxlbWVudFR5cGUgPSAnZGl2JyA+KFxuXHR7IGFzLCAuLi5yZXN0UHJvcHMgfTogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IHt9LCBUID4sXG5cdHJlZjogUmVhY3QuRm9yd2FyZGVkUmVmPCBhbnkgPlxuKSB7XG5cdHJldHVybiA8UG9seW1vcnBoaWNEaXYgYXM9eyBhcyB9IHJlZj17IHJlZiB9IHsgLi4ucmVzdFByb3BzIH0gLz47XG59XG5cbi8qKlxuICogYFZpZXdgIGlzIGEgY29yZSBjb21wb25lbnQgdGhhdCByZW5kZXJzIGV2ZXJ5dGhpbmcgaW4gdGhlIGxpYnJhcnkuXG4gKiBJdCBpcyB0aGUgcHJpbmNpcGxlIGNvbXBvbmVudCBpbiB0aGUgZW50aXJlIGxpYnJhcnkuXG4gKlxuICogYGBganN4XG4gKiBpbXBvcnQgeyBWaWV3IH0gZnJvbSBgQHdvcmRwcmVzcy9jb21wb25lbnRzYDtcbiAqXG4gKiBmdW5jdGlvbiBFeGFtcGxlKCkge1xuICogXHRyZXR1cm4gKFxuICogXHRcdDxWaWV3PlxuICogXHRcdFx0IENvZGUgaXMgUG9ldHJ5XG4gKiBcdFx0PC9WaWV3PlxuICogXHQpO1xuICogfVxuICogYGBgXG4gKi9cbmV4cG9ydCBjb25zdCBWaWV3ID0gT2JqZWN0LmFzc2lnbiggZm9yd2FyZFJlZiggVW5mb3J3YXJkZWRWaWV3ICksIHtcblx0c2VsZWN0b3I6ICcuY29tcG9uZW50cy12aWV3Jyxcbn0gKTtcblxuZXhwb3J0IGRlZmF1bHQgVmlldztcbiJdfQ== */"); 23771 function UnforwardedView({ 23772 as, 23773 ...restProps 23774 }, ref) { 23775 return /* @__PURE__ */ (0, import_jsx_runtime46.jsx)(PolymorphicDiv, { 23776 as, 23777 ref, 23778 ...restProps 23779 }); 23780 } 23781 var View = Object.assign((0, import_element16.forwardRef)(UnforwardedView), { 23782 selector: ".components-view" 23783 }); 23784 var component_default = View; 23785 23786 // packages/components/build-module/visually-hidden/component.js 23787 var import_jsx_runtime47 = __toESM(require_jsx_runtime()); 23788 function UnconnectedVisuallyHidden(props, forwardedRef) { 23789 const { 23790 style: styleProp, 23791 ...contextProps 23792 } = useContextSystem(props, "VisuallyHidden"); 23793 return /* @__PURE__ */ (0, import_jsx_runtime47.jsx)(component_default, { 23794 ref: forwardedRef, 23795 ...contextProps, 23796 style: { 23797 ...visuallyHidden, 23798 ...styleProp || {} 23799 } 23800 }); 23801 } 23802 var VisuallyHidden3 = contextConnect(UnconnectedVisuallyHidden, "VisuallyHidden"); 23803 var component_default2 = VisuallyHidden3; 23804 23805 // packages/components/build-module/alignment-matrix-control/utils.js 23806 var import_i18n3 = __toESM(require_i18n()); 23807 var GRID = [["top left", "top center", "top right"], ["center left", "center center", "center right"], ["bottom left", "bottom center", "bottom right"]]; 23808 var ALIGNMENT_LABEL = { 23809 "top left": (0, import_i18n3.__)("Top Left"), 23810 "top center": (0, import_i18n3.__)("Top Center"), 23811 "top right": (0, import_i18n3.__)("Top Right"), 23812 "center left": (0, import_i18n3.__)("Center Left"), 23813 "center center": (0, import_i18n3.__)("Center"), 23814 center: (0, import_i18n3.__)("Center"), 23815 "center right": (0, import_i18n3.__)("Center Right"), 23816 "bottom left": (0, import_i18n3.__)("Bottom Left"), 23817 "bottom center": (0, import_i18n3.__)("Bottom Center"), 23818 "bottom right": (0, import_i18n3.__)("Bottom Right") 23819 }; 23820 var ALIGNMENTS = GRID.flat(); 23821 function normalize(value) { 23822 const normalized = value === "center" ? "center center" : value; 23823 const transformed = normalized?.replace("-", " "); 23824 return ALIGNMENTS.includes(transformed) ? transformed : void 0; 23825 } 23826 function getItemId(prefixId, value) { 23827 const normalized = normalize(value); 23828 if (!normalized) { 23829 return; 23830 } 23831 const id3 = normalized.replace(" ", "-"); 23832 return `$prefixId}-$id3}`; 23833 } 23834 function getItemValue(prefixId, id3) { 23835 const value = id3?.replace(prefixId + "-", ""); 23836 return normalize(value); 23837 } 23838 function getAlignmentIndex(alignment = "center") { 23839 const normalized = normalize(alignment); 23840 if (!normalized) { 23841 return void 0; 23842 } 23843 const index2 = ALIGNMENTS.indexOf(normalized); 23844 return index2 > -1 ? index2 : void 0; 23845 } 23846 23847 // packages/components/build-module/alignment-matrix-control/cell.js 23848 var import_jsx_runtime48 = __toESM(require_jsx_runtime()); 23849 var css3 = `/** 23850 * SCSS Variables. 23851 * 23852 * Please use variables from this sheet to ensure consistency across the UI. 23853 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 23854 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 23855 */ 23856 /** 23857 * Colors 23858 */ 23859 /** 23860 * Fonts & basic variables. 23861 */ 23862 /** 23863 * Typography 23864 */ 23865 /** 23866 * Grid System. 23867 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 23868 */ 23869 /** 23870 * Radius scale. 23871 */ 23872 /** 23873 * Elevation scale. 23874 */ 23875 /** 23876 * Dimensions. 23877 */ 23878 /** 23879 * Mobile specific styles 23880 */ 23881 /** 23882 * Editor styles. 23883 */ 23884 /** 23885 * Block & Editor UI. 23886 */ 23887 /** 23888 * Block paddings. 23889 */ 23890 /** 23891 * React Native specific. 23892 * These variables do not appear to be used anywhere else. 23893 */ 23894 .style-module__grid-container__AuKvW { 23895 direction: ltr; 23896 display: grid; 23897 grid-template-columns: repeat(3, 1fr); 23898 grid-template-rows: repeat(3, 1fr); 23899 box-sizing: border-box; 23900 aspect-ratio: 1; 23901 border: 1px solid transparent; 23902 border-radius: 4px; 23903 outline: none; 23904 cursor: pointer; 23905 } 23906 23907 .style-module__grid-row__xCH47 { 23908 grid-column: 1/-1; 23909 box-sizing: border-box; 23910 display: grid; 23911 grid-template-columns: repeat(3, 1fr); 23912 } 23913 23914 .style-module__cell__Ovdp9 { 23915 position: relative; 23916 display: flex; 23917 align-items: center; 23918 justify-content: center; 23919 box-sizing: border-box; 23920 margin: 0; 23921 padding: 0; 23922 appearance: none; 23923 border: none; 23924 outline: none; 23925 } 23926 23927 .style-module__point__N-8S1 { 23928 display: block; 23929 contain: strict; 23930 box-sizing: border-box; 23931 width: 6px; 23932 aspect-ratio: 1; 23933 margin: auto; 23934 color: var(--wp-components-color-gray-400, #ccc); 23935 /* Use border instead of background color so that the point shows 23936 in Windows High Contrast Mode */ 23937 border: 3px solid currentColor; 23938 /* Highlight active item */ 23939 } 23940 .style-module__cell__Ovdp9[data-active-item] .style-module__point__N-8S1 { 23941 color: var(--wp-components-color-foreground, #1e1e1e); 23942 transform: scale(1.6666666667); 23943 } 23944 .style-module__point__N-8S1 { 23945 /* Hover styles for non-active items */ 23946 } 23947 .style-module__cell__Ovdp9:not([data-active-item]):hover .style-module__point__N-8S1 { 23948 color: var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9)); 23949 } 23950 .style-module__point__N-8S1 { 23951 /* Show an outline only when interacting with keyboard */ 23952 } 23953 .style-module__cell__Ovdp9[data-focus-visible] .style-module__point__N-8S1 { 23954 outline: 1px solid var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9)); 23955 outline-offset: 1px; 23956 } 23957 @media not (prefers-reduced-motion) { 23958 .style-module__point__N-8S1 { 23959 transition-property: color, transform; 23960 transition-duration: 120ms; 23961 transition-timing-function: linear; 23962 } 23963 }`; 23964 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css3)); 23965 var style_module_default = { 23966 "grid-container": "style-module__grid-container__AuKvW", 23967 "grid-row": "style-module__grid-row__xCH47", 23968 "cell": "style-module__cell__Ovdp9", 23969 "point": "style-module__point__N-8S1" 23970 }; 23971 function Cell({ 23972 id: id3, 23973 value, 23974 ...props 23975 }) { 23976 return /* @__PURE__ */ (0, import_jsx_runtime48.jsx)(tooltip_default, { 23977 text: ALIGNMENT_LABEL[value], 23978 children: /* @__PURE__ */ (0, import_jsx_runtime48.jsxs)(Composite22.Item, { 23979 id: id3, 23980 render: /* @__PURE__ */ (0, import_jsx_runtime48.jsx)("span", { 23981 ...props, 23982 className: clsx_default(style_module_default.cell, props.className), 23983 role: "gridcell" 23984 }), 23985 children: [/* @__PURE__ */ (0, import_jsx_runtime48.jsx)(component_default2, { 23986 children: value 23987 }), /* @__PURE__ */ (0, import_jsx_runtime48.jsx)("span", { 23988 className: style_module_default.point, 23989 role: "presentation" 23990 })] 23991 }) 23992 }); 23993 } 23994 23995 // packages/components/build-module/alignment-matrix-control/icon.js 23996 var import_primitives = __toESM(require_primitives()); 23997 var import_jsx_runtime49 = __toESM(require_jsx_runtime()); 23998 var BASE_SIZE = 24; 23999 var GRID_CELL_SIZE = 7; 24000 var GRID_PADDING = (BASE_SIZE - 3 * GRID_CELL_SIZE) / 2; 24001 var DOT_SIZE = 2; 24002 var DOT_SIZE_SELECTED = 4; 24003 function AlignmentMatrixControlIcon({ 24004 className: className2, 24005 disablePointerEvents = true, 24006 size: size3, 24007 width, 24008 height, 24009 style: style2 = {}, 24010 value = "center", 24011 ...props 24012 }) { 24013 var _ref11, _ref25; 24014 return /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(import_primitives.SVG, { 24015 xmlns: "http://www.w3.org/2000/svg", 24016 viewBox: `0 0 $BASE_SIZE} $BASE_SIZE}`, 24017 width: (_ref11 = size3 !== null && size3 !== void 0 ? size3 : width) !== null && _ref11 !== void 0 ? _ref11 : BASE_SIZE, 24018 height: (_ref25 = size3 !== null && size3 !== void 0 ? size3 : height) !== null && _ref25 !== void 0 ? _ref25 : BASE_SIZE, 24019 role: "presentation", 24020 className: clsx_default("component-alignment-matrix-control-icon", className2), 24021 style: { 24022 pointerEvents: disablePointerEvents ? "none" : void 0, 24023 ...style2 24024 }, 24025 ...props, 24026 children: ALIGNMENTS.map((align, index2) => { 24027 const dotSize = getAlignmentIndex(value) === index2 ? DOT_SIZE_SELECTED : DOT_SIZE; 24028 return /* @__PURE__ */ (0, import_jsx_runtime49.jsx)(import_primitives.Rect, { 24029 x: GRID_PADDING + index2 % 3 * GRID_CELL_SIZE + (GRID_CELL_SIZE - dotSize) / 2, 24030 y: GRID_PADDING + Math.floor(index2 / 3) * GRID_CELL_SIZE + (GRID_CELL_SIZE - dotSize) / 2, 24031 width: dotSize, 24032 height: dotSize, 24033 fill: "currentColor" 24034 }, align); 24035 }) 24036 }); 24037 } 24038 var icon_default = AlignmentMatrixControlIcon; 24039 24040 // packages/components/build-module/alignment-matrix-control/index.js 24041 var import_jsx_runtime50 = __toESM(require_jsx_runtime()); 24042 var css4 = `/** 24043 * SCSS Variables. 24044 * 24045 * Please use variables from this sheet to ensure consistency across the UI. 24046 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 24047 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 24048 */ 24049 /** 24050 * Colors 24051 */ 24052 /** 24053 * Fonts & basic variables. 24054 */ 24055 /** 24056 * Typography 24057 */ 24058 /** 24059 * Grid System. 24060 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 24061 */ 24062 /** 24063 * Radius scale. 24064 */ 24065 /** 24066 * Elevation scale. 24067 */ 24068 /** 24069 * Dimensions. 24070 */ 24071 /** 24072 * Mobile specific styles 24073 */ 24074 /** 24075 * Editor styles. 24076 */ 24077 /** 24078 * Block & Editor UI. 24079 */ 24080 /** 24081 * Block paddings. 24082 */ 24083 /** 24084 * React Native specific. 24085 * These variables do not appear to be used anywhere else. 24086 */ 24087 .style-module__grid-container__AuKvW { 24088 direction: ltr; 24089 display: grid; 24090 grid-template-columns: repeat(3, 1fr); 24091 grid-template-rows: repeat(3, 1fr); 24092 box-sizing: border-box; 24093 aspect-ratio: 1; 24094 border: 1px solid transparent; 24095 border-radius: 4px; 24096 outline: none; 24097 cursor: pointer; 24098 } 24099 24100 .style-module__grid-row__xCH47 { 24101 grid-column: 1/-1; 24102 box-sizing: border-box; 24103 display: grid; 24104 grid-template-columns: repeat(3, 1fr); 24105 } 24106 24107 .style-module__cell__Ovdp9 { 24108 position: relative; 24109 display: flex; 24110 align-items: center; 24111 justify-content: center; 24112 box-sizing: border-box; 24113 margin: 0; 24114 padding: 0; 24115 appearance: none; 24116 border: none; 24117 outline: none; 24118 } 24119 24120 .style-module__point__N-8S1 { 24121 display: block; 24122 contain: strict; 24123 box-sizing: border-box; 24124 width: 6px; 24125 aspect-ratio: 1; 24126 margin: auto; 24127 color: var(--wp-components-color-gray-400, #ccc); 24128 /* Use border instead of background color so that the point shows 24129 in Windows High Contrast Mode */ 24130 border: 3px solid currentColor; 24131 /* Highlight active item */ 24132 } 24133 .style-module__cell__Ovdp9[data-active-item] .style-module__point__N-8S1 { 24134 color: var(--wp-components-color-foreground, #1e1e1e); 24135 transform: scale(1.6666666667); 24136 } 24137 .style-module__point__N-8S1 { 24138 /* Hover styles for non-active items */ 24139 } 24140 .style-module__cell__Ovdp9:not([data-active-item]):hover .style-module__point__N-8S1 { 24141 color: var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9)); 24142 } 24143 .style-module__point__N-8S1 { 24144 /* Show an outline only when interacting with keyboard */ 24145 } 24146 .style-module__cell__Ovdp9[data-focus-visible] .style-module__point__N-8S1 { 24147 outline: 1px solid var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9)); 24148 outline-offset: 1px; 24149 } 24150 @media not (prefers-reduced-motion) { 24151 .style-module__point__N-8S1 { 24152 transition-property: color, transform; 24153 transition-duration: 120ms; 24154 transition-timing-function: linear; 24155 } 24156 }`; 24157 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css4)); 24158 var style_module_default2 = { 24159 "grid-container": "style-module__grid-container__AuKvW", 24160 "grid-row": "style-module__grid-row__xCH47", 24161 "cell": "style-module__cell__Ovdp9", 24162 "point": "style-module__point__N-8S1" 24163 }; 24164 function UnforwardedAlignmentMatrixControl({ 24165 className: className2, 24166 id: id3, 24167 label = (0, import_i18n4.__)("Alignment Matrix Control"), 24168 defaultValue: defaultValue2 = "center center", 24169 value, 24170 onChange, 24171 width = 92, 24172 ...props 24173 }) { 24174 const baseId = (0, import_compose2.useInstanceId)(UnforwardedAlignmentMatrixControl, "alignment-matrix-control", id3); 24175 const setActiveId = (0, import_element17.useCallback)((nextActiveId) => { 24176 const nextValue = getItemValue(baseId, nextActiveId); 24177 if (nextValue) { 24178 onChange?.(nextValue); 24179 } 24180 }, [baseId, onChange]); 24181 const classes = clsx_default("component-alignment-matrix-control", style_module_default2["grid-container"], className2); 24182 return /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Composite22, { 24183 defaultActiveId: getItemId(baseId, defaultValue2), 24184 activeId: getItemId(baseId, value), 24185 setActiveId, 24186 rtl: (0, import_i18n4.isRTL)(), 24187 render: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("div", { 24188 ...props, 24189 className: classes, 24190 "aria-label": label, 24191 id: baseId, 24192 role: "grid", 24193 style: { 24194 width: `$width}px` 24195 } 24196 }), 24197 children: GRID.map((cells, index2) => /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Composite22.Row, { 24198 render: /* @__PURE__ */ (0, import_jsx_runtime50.jsx)("div", { 24199 className: style_module_default2["grid-row"], 24200 role: "row" 24201 }), 24202 children: cells.map((cell) => /* @__PURE__ */ (0, import_jsx_runtime50.jsx)(Cell, { 24203 id: getItemId(baseId, cell), 24204 value: cell 24205 }, cell)) 24206 }, index2)) 24207 }); 24208 } 24209 var AlignmentMatrixControl = Object.assign(UnforwardedAlignmentMatrixControl, { 24210 /** 24211 * Render an alignment matrix as an icon. 24212 * 24213 * ```jsx 24214 * import { AlignmentMatrixControl } from '@wordpress/components'; 24215 * 24216 * <Icon icon={<AlignmentMatrixControl.Icon value="top left" />} /> 24217 * ``` 24218 */ 24219 Icon: Object.assign(icon_default, { 24220 displayName: "AlignmentMatrixControl.Icon" 24221 }) 24222 }); 24223 var alignment_matrix_control_default = AlignmentMatrixControl; 24224 24225 // packages/components/build-module/animate/index.js 24226 function getDefaultOrigin(type) { 24227 return type === "appear" ? "top" : "left"; 24228 } 24229 function getAnimateClassName(options2) { 24230 if (options2.type === "loading") { 24231 return "components-animate__loading"; 24232 } 24233 const { 24234 type, 24235 origin = getDefaultOrigin(type) 24236 } = options2; 24237 if (type === "appear") { 24238 const [yAxis, xAxis = "center"] = origin.split(" "); 24239 return clsx_default("components-animate__appear", { 24240 ["is-from-" + xAxis]: xAxis !== "center", 24241 ["is-from-" + yAxis]: yAxis !== "middle" 24242 }); 24243 } 24244 if (type === "slide-in") { 24245 return clsx_default("components-animate__slide-in", "is-from-" + origin); 24246 } 24247 return void 0; 24248 } 24249 function Animate({ 24250 type, 24251 options: options2 = {}, 24252 children 24253 }) { 24254 return children({ 24255 className: getAnimateClassName({ 24256 type, 24257 ...options2 24258 }) 24259 }); 24260 } 24261 var animate_default = Animate; 24262 24263 // packages/components/build-module/angle-picker-control/index.js 24264 var import_element37 = __toESM(require_element()); 24265 var import_i18n6 = __toESM(require_i18n()); 24266 24267 // packages/components/build-module/flex/flex/hook.js 24268 var import_element19 = __toESM(require_element()); 24269 var import_deprecated2 = __toESM(require_deprecated()); 24270 24271 // packages/components/build-module/utils/use-responsive-value.js 24272 var import_element18 = __toESM(require_element()); 24273 var breakpoints = ["40em", "52em", "64em"]; 24274 var useBreakpointIndex = (options2 = {}) => { 24275 const { 24276 defaultIndex = 0 24277 } = options2; 24278 if (typeof defaultIndex !== "number") { 24279 throw new TypeError(`Default breakpoint index should be a number. Got: $defaultIndex}, $typeof defaultIndex}`); 24280 } else if (defaultIndex < 0 || defaultIndex > breakpoints.length - 1) { 24281 throw new RangeError(`Default breakpoint index out of range. Theme has $breakpoints.length} breakpoints, got index $defaultIndex}`); 24282 } 24283 const [value, setValue] = (0, import_element18.useState)(defaultIndex); 24284 (0, import_element18.useEffect)(() => { 24285 const getIndex = () => breakpoints.filter((bp) => { 24286 return typeof window !== "undefined" ? window.matchMedia(`screen and (min-width: $bp})`).matches : false; 24287 }).length; 24288 const onResize = () => { 24289 const newValue = getIndex(); 24290 if (value !== newValue) { 24291 setValue(newValue); 24292 } 24293 }; 24294 onResize(); 24295 if (typeof window !== "undefined") { 24296 window.addEventListener("resize", onResize); 24297 } 24298 return () => { 24299 if (typeof window !== "undefined") { 24300 window.removeEventListener("resize", onResize); 24301 } 24302 }; 24303 }, [value]); 24304 return value; 24305 }; 24306 function useResponsiveValue(values, options2 = {}) { 24307 const index2 = useBreakpointIndex(options2); 24308 if (!Array.isArray(values) && typeof values !== "function") { 24309 return values; 24310 } 24311 const array = values || []; 24312 return ( 24313 /** @type {T[]} */ 24314 array[ 24315 /* eslint-enable jsdoc/no-undefined-types */ 24316 index2 >= array.length ? array.length - 1 : index2 24317 ] 24318 ); 24319 } 24320 24321 // packages/components/build-module/utils/space.js 24322 var GRID_BASE = "4px"; 24323 function space(value) { 24324 if (typeof value === "undefined") { 24325 return void 0; 24326 } 24327 if (!value) { 24328 return "0"; 24329 } 24330 const asInt = typeof value === "number" ? value : Number(value); 24331 if (typeof window !== "undefined" && window.CSS?.supports?.("margin", value.toString()) || Number.isNaN(asInt)) { 24332 return value.toString(); 24333 } 24334 return `calc($GRID_BASE} * $value})`; 24335 } 24336 24337 // packages/components/build-module/flex/styles.js 24338 function _EMOTION_STRINGIFIED_CSS_ERROR__2() { 24339 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 24340 } 24341 var Flex = false ? { 24342 name: "zjik7", 24343 styles: "display:flex" 24344 } : { 24345 name: "a57899-Flex", 24346 styles: "display:flex;label:Flex;", 24347 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLdUIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgRmxleCA9IGNzc2Bcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcblx0bWF4LWhlaWdodDogMTAwJTtcblx0bWF4LXdpZHRoOiAxMDAlO1xuXHRtaW4taGVpZ2h0OiAwO1xuXHRtaW4td2lkdGg6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG4vKipcbiAqIFdvcmthcm91bmQgdG8gb3B0aW1pemUgRE9NIHJlbmRlcmluZy5cbiAqIFdlJ2xsIGVuaGFuY2UgYWxpZ25tZW50IHdpdGggbmFpdmUgcGFyZW50IGZsZXggYXNzdW1wdGlvbnMuXG4gKlxuICogVHJhZGUtb2ZmOlxuICogRmFyIGxlc3MgRE9NIGxlc3MuIEhvd2V2ZXIsIFVJIHJlbmRlcmluZyBpcyBub3QgYXMgcmVsaWFibGUuXG4gKi9cblxuLyoqXG4gKiBJbXByb3ZlcyBzdGFiaWxpdHkgb2Ygd2lkdGgvaGVpZ2h0IHJlbmRlcmluZy5cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9JdHNKb25RL2cyL3B1bGwvMTQ5XG4gKi9cbmV4cG9ydCBjb25zdCBJdGVtc0NvbHVtbiA9IGNzc2Bcblx0PiAqIHtcblx0XHRtaW4taGVpZ2h0OiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbXNSb3cgPSBjc3NgXG5cdD4gKiB7XG5cdFx0bWluLXdpZHRoOiAwO1xuXHR9XG5gO1xuIl19 */", 24348 toString: _EMOTION_STRINGIFIED_CSS_ERROR__2 24349 }; 24350 var Item = false ? { 24351 name: "qgaee5", 24352 styles: "display:block;max-height:100%;max-width:100%;min-height:0;min-width:0" 24353 } : { 24354 name: "14ac8g8-Item", 24355 styles: "display:block;max-height:100%;max-width:100%;min-height:0;min-width:0;label:Item;", 24356 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTdUIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgRmxleCA9IGNzc2Bcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcblx0bWF4LWhlaWdodDogMTAwJTtcblx0bWF4LXdpZHRoOiAxMDAlO1xuXHRtaW4taGVpZ2h0OiAwO1xuXHRtaW4td2lkdGg6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG4vKipcbiAqIFdvcmthcm91bmQgdG8gb3B0aW1pemUgRE9NIHJlbmRlcmluZy5cbiAqIFdlJ2xsIGVuaGFuY2UgYWxpZ25tZW50IHdpdGggbmFpdmUgcGFyZW50IGZsZXggYXNzdW1wdGlvbnMuXG4gKlxuICogVHJhZGUtb2ZmOlxuICogRmFyIGxlc3MgRE9NIGxlc3MuIEhvd2V2ZXIsIFVJIHJlbmRlcmluZyBpcyBub3QgYXMgcmVsaWFibGUuXG4gKi9cblxuLyoqXG4gKiBJbXByb3ZlcyBzdGFiaWxpdHkgb2Ygd2lkdGgvaGVpZ2h0IHJlbmRlcmluZy5cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9JdHNKb25RL2cyL3B1bGwvMTQ5XG4gKi9cbmV4cG9ydCBjb25zdCBJdGVtc0NvbHVtbiA9IGNzc2Bcblx0PiAqIHtcblx0XHRtaW4taGVpZ2h0OiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbXNSb3cgPSBjc3NgXG5cdD4gKiB7XG5cdFx0bWluLXdpZHRoOiAwO1xuXHR9XG5gO1xuIl19 */", 24357 toString: _EMOTION_STRINGIFIED_CSS_ERROR__2 24358 }; 24359 var block = false ? { 24360 name: "82a6rk", 24361 styles: "flex:1" 24362 } : { 24363 name: "1ya6i3g-block", 24364 styles: "flex:1;label:block;", 24365 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQndCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IEZsZXggPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbSA9IGNzc2Bcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLWhlaWdodDogMDtcblx0bWluLXdpZHRoOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRmbGV4OiAxO1xuYDtcblxuLyoqXG4gKiBXb3JrYXJvdW5kIHRvIG9wdGltaXplIERPTSByZW5kZXJpbmcuXG4gKiBXZSdsbCBlbmhhbmNlIGFsaWdubWVudCB3aXRoIG5haXZlIHBhcmVudCBmbGV4IGFzc3VtcHRpb25zLlxuICpcbiAqIFRyYWRlLW9mZjpcbiAqIEZhciBsZXNzIERPTSBsZXNzLiBIb3dldmVyLCBVSSByZW5kZXJpbmcgaXMgbm90IGFzIHJlbGlhYmxlLlxuICovXG5cbi8qKlxuICogSW1wcm92ZXMgc3RhYmlsaXR5IG9mIHdpZHRoL2hlaWdodCByZW5kZXJpbmcuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vSXRzSm9uUS9nMi9wdWxsLzE0OVxuICovXG5leHBvcnQgY29uc3QgSXRlbXNDb2x1bW4gPSBjc3NgXG5cdD4gKiB7XG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IEl0ZW1zUm93ID0gY3NzYFxuXHQ+ICoge1xuXHRcdG1pbi13aWR0aDogMDtcblx0fVxuYDtcbiJdfQ== */", 24366 toString: _EMOTION_STRINGIFIED_CSS_ERROR__2 24367 }; 24368 var ItemsColumn = false ? { 24369 name: "13nosa1", 24370 styles: ">*{min-height:0;}" 24371 } : { 24372 name: "9k4k7f-ItemsColumn", 24373 styles: ">*{min-height:0;};label:ItemsColumn;", 24374 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQzhCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IEZsZXggPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbSA9IGNzc2Bcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLWhlaWdodDogMDtcblx0bWluLXdpZHRoOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRmbGV4OiAxO1xuYDtcblxuLyoqXG4gKiBXb3JrYXJvdW5kIHRvIG9wdGltaXplIERPTSByZW5kZXJpbmcuXG4gKiBXZSdsbCBlbmhhbmNlIGFsaWdubWVudCB3aXRoIG5haXZlIHBhcmVudCBmbGV4IGFzc3VtcHRpb25zLlxuICpcbiAqIFRyYWRlLW9mZjpcbiAqIEZhciBsZXNzIERPTSBsZXNzLiBIb3dldmVyLCBVSSByZW5kZXJpbmcgaXMgbm90IGFzIHJlbGlhYmxlLlxuICovXG5cbi8qKlxuICogSW1wcm92ZXMgc3RhYmlsaXR5IG9mIHdpZHRoL2hlaWdodCByZW5kZXJpbmcuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vSXRzSm9uUS9nMi9wdWxsLzE0OVxuICovXG5leHBvcnQgY29uc3QgSXRlbXNDb2x1bW4gPSBjc3NgXG5cdD4gKiB7XG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IEl0ZW1zUm93ID0gY3NzYFxuXHQ+ICoge1xuXHRcdG1pbi13aWR0aDogMDtcblx0fVxuYDtcbiJdfQ== */", 24375 toString: _EMOTION_STRINGIFIED_CSS_ERROR__2 24376 }; 24377 var ItemsRow = false ? { 24378 name: "1pwxzk4", 24379 styles: ">*{min-width:0;}" 24380 } : { 24381 name: "1ozeagb-ItemsRow", 24382 styles: ">*{min-width:0;};label:ItemsRow;", 24383 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QzJCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IEZsZXggPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbSA9IGNzc2Bcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLWhlaWdodDogMDtcblx0bWluLXdpZHRoOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRmbGV4OiAxO1xuYDtcblxuLyoqXG4gKiBXb3JrYXJvdW5kIHRvIG9wdGltaXplIERPTSByZW5kZXJpbmcuXG4gKiBXZSdsbCBlbmhhbmNlIGFsaWdubWVudCB3aXRoIG5haXZlIHBhcmVudCBmbGV4IGFzc3VtcHRpb25zLlxuICpcbiAqIFRyYWRlLW9mZjpcbiAqIEZhciBsZXNzIERPTSBsZXNzLiBIb3dldmVyLCBVSSByZW5kZXJpbmcgaXMgbm90IGFzIHJlbGlhYmxlLlxuICovXG5cbi8qKlxuICogSW1wcm92ZXMgc3RhYmlsaXR5IG9mIHdpZHRoL2hlaWdodCByZW5kZXJpbmcuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vSXRzSm9uUS9nMi9wdWxsLzE0OVxuICovXG5leHBvcnQgY29uc3QgSXRlbXNDb2x1bW4gPSBjc3NgXG5cdD4gKiB7XG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IEl0ZW1zUm93ID0gY3NzYFxuXHQ+ICoge1xuXHRcdG1pbi13aWR0aDogMDtcblx0fVxuYDtcbiJdfQ== */", 24384 toString: _EMOTION_STRINGIFIED_CSS_ERROR__2 24385 }; 24386 24387 // packages/components/build-module/flex/flex/hook.js 24388 function useDeprecatedProps(props) { 24389 const { 24390 isReversed, 24391 ...otherProps 24392 } = props; 24393 if (typeof isReversed !== "undefined") { 24394 (0, import_deprecated2.default)("Flex isReversed", { 24395 alternative: 'Flex direction="row-reverse" or "column-reverse"', 24396 since: "5.9" 24397 }); 24398 return { 24399 ...otherProps, 24400 direction: isReversed ? "row-reverse" : "row" 24401 }; 24402 } 24403 return otherProps; 24404 } 24405 function useFlex(props) { 24406 const { 24407 align, 24408 className: className2, 24409 direction: directionProp = "row", 24410 expanded = true, 24411 gap = 2, 24412 justify = "space-between", 24413 wrap = false, 24414 ...otherProps 24415 } = useContextSystem(useDeprecatedProps(props), "Flex"); 24416 const directionAsArray = Array.isArray(directionProp) ? directionProp : [directionProp]; 24417 const direction = useResponsiveValue(directionAsArray); 24418 const isColumn = typeof direction === "string" && !!direction.includes("column"); 24419 const cx3 = useCx(); 24420 const classes = (0, import_element19.useMemo)(() => { 24421 const base = /* @__PURE__ */ css({ 24422 alignItems: align !== null && align !== void 0 ? align : isColumn ? "normal" : "center", 24423 flexDirection: direction, 24424 flexWrap: wrap ? "wrap" : void 0, 24425 gap: space(gap), 24426 justifyContent: justify, 24427 height: isColumn && expanded ? "100%" : void 0, 24428 width: !isColumn && expanded ? "100%" : void 0 24429 }, false ? "" : ";label:base;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0VlIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcbmltcG9ydCBkZXByZWNhdGVkIGZyb20gJ0B3b3JkcHJlc3MvZGVwcmVjYXRlZCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi8uLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi8uLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZVJlc3BvbnNpdmVWYWx1ZSB9IGZyb20gJy4uLy4uL3V0aWxzL3VzZS1yZXNwb25zaXZlLXZhbHVlJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRmxleFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5mdW5jdGlvbiB1c2VEZXByZWNhdGVkUHJvcHMoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgRmxleFByb3BzLCAnZGl2JyA+XG4pOiBPbWl0PCB0eXBlb2YgcHJvcHMsICdpc1JldmVyc2VkJyA+IHtcblx0Y29uc3QgeyBpc1JldmVyc2VkLCAuLi5vdGhlclByb3BzIH0gPSBwcm9wcztcblxuXHRpZiAoIHR5cGVvZiBpc1JldmVyc2VkICE9PSAndW5kZWZpbmVkJyApIHtcblx0XHRkZXByZWNhdGVkKCAnRmxleCBpc1JldmVyc2VkJywge1xuXHRcdFx0YWx0ZXJuYXRpdmU6ICdGbGV4IGRpcmVjdGlvbj1cInJvdy1yZXZlcnNlXCIgb3IgXCJjb2x1bW4tcmV2ZXJzZVwiJyxcblx0XHRcdHNpbmNlOiAnNS45Jyxcblx0XHR9ICk7XG5cdFx0cmV0dXJuIHtcblx0XHRcdC4uLm90aGVyUHJvcHMsXG5cdFx0XHRkaXJlY3Rpb246IGlzUmV2ZXJzZWQgPyAncm93LXJldmVyc2UnIDogJ3JvdycsXG5cdFx0fTtcblx0fVxuXG5cdHJldHVybiBvdGhlclByb3BzO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlRmxleCggcHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBGbGV4UHJvcHMsICdkaXYnID4gKSB7XG5cdGNvbnN0IHtcblx0XHRhbGlnbixcblx0XHRjbGFzc05hbWUsXG5cdFx0ZGlyZWN0aW9uOiBkaXJlY3Rpb25Qcm9wID0gJ3JvdycsXG5cdFx0ZXhwYW5kZWQgPSB0cnVlLFxuXHRcdGdhcCA9IDIsXG5cdFx0anVzdGlmeSA9ICdzcGFjZS1iZXR3ZWVuJyxcblx0XHR3cmFwID0gZmFsc2UsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggdXNlRGVwcmVjYXRlZFByb3BzKCBwcm9wcyApLCAnRmxleCcgKTtcblxuXHRjb25zdCBkaXJlY3Rpb25Bc0FycmF5ID0gQXJyYXkuaXNBcnJheSggZGlyZWN0aW9uUHJvcCApXG5cdFx0PyBkaXJlY3Rpb25Qcm9wXG5cdFx0OiBbIGRpcmVjdGlvblByb3AgXTtcblx0Y29uc3QgZGlyZWN0aW9uID0gdXNlUmVzcG9uc2l2ZVZhbHVlKCBkaXJlY3Rpb25Bc0FycmF5ICk7XG5cblx0Y29uc3QgaXNDb2x1bW4gPVxuXHRcdHR5cGVvZiBkaXJlY3Rpb24gPT09ICdzdHJpbmcnICYmICEhIGRpcmVjdGlvbi5pbmNsdWRlcyggJ2NvbHVtbicgKTtcblxuXHRjb25zdCBjeCA9IHVzZUN4KCk7XG5cblx0Y29uc3QgY2xhc3NlcyA9IHVzZU1lbW8oICgpID0+IHtcblx0XHRjb25zdCBiYXNlID0gY3NzKCB7XG5cdFx0XHRhbGlnbkl0ZW1zOiBhbGlnbiA/PyAoIGlzQ29sdW1uID8gJ25vcm1hbCcgOiAnY2VudGVyJyApLFxuXHRcdFx0ZmxleERpcmVjdGlvbjogZGlyZWN0aW9uLFxuXHRcdFx0ZmxleFdyYXA6IHdyYXAgPyAnd3JhcCcgOiB1bmRlZmluZWQsXG5cdFx0XHRnYXA6IHNwYWNlKCBnYXAgKSxcblx0XHRcdGp1c3RpZnlDb250ZW50OiBqdXN0aWZ5LFxuXHRcdFx0aGVpZ2h0OiBpc0NvbHVtbiAmJiBleHBhbmRlZCA/ICcxMDAlJyA6IHVuZGVmaW5lZCxcblx0XHRcdHdpZHRoOiAhIGlzQ29sdW1uICYmIGV4cGFuZGVkID8gJzEwMCUnIDogdW5kZWZpbmVkLFxuXHRcdH0gKTtcblxuXHRcdHJldHVybiBjeChcblx0XHRcdHN0eWxlcy5GbGV4LFxuXHRcdFx0YmFzZSxcblx0XHRcdGlzQ29sdW1uID8gc3R5bGVzLkl0ZW1zQ29sdW1uIDogc3R5bGVzLkl0ZW1zUm93LFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFsaWduLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjeCxcblx0XHRkaXJlY3Rpb24sXG5cdFx0ZXhwYW5kZWQsXG5cdFx0Z2FwLFxuXHRcdGlzQ29sdW1uLFxuXHRcdGp1c3RpZnksXG5cdFx0d3JhcCxcblx0XSApO1xuXG5cdHJldHVybiB7IC4uLm90aGVyUHJvcHMsIGNsYXNzTmFtZTogY2xhc3NlcywgaXNDb2x1bW4gfTtcbn1cbiJdfQ== */"); 24430 return cx3(Flex, base, isColumn ? ItemsColumn : ItemsRow, className2); 24431 }, [align, className2, cx3, direction, expanded, gap, isColumn, justify, wrap]); 24432 return { 24433 ...otherProps, 24434 className: classes, 24435 isColumn 24436 }; 24437 } 24438 24439 // packages/components/build-module/flex/context.js 24440 var import_element20 = __toESM(require_element()); 24441 var FlexContext = (0, import_element20.createContext)({ 24442 flexItemDisplay: void 0 24443 }); 24444 var useFlexContext = () => (0, import_element20.useContext)(FlexContext); 24445 24446 // packages/components/build-module/flex/flex/component.js 24447 var import_jsx_runtime51 = __toESM(require_jsx_runtime()); 24448 function UnconnectedFlex(props, forwardedRef) { 24449 const { 24450 children, 24451 isColumn, 24452 ...otherProps 24453 } = useFlex(props); 24454 return /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(FlexContext.Provider, { 24455 value: { 24456 flexItemDisplay: isColumn ? "block" : void 0 24457 }, 24458 children: /* @__PURE__ */ (0, import_jsx_runtime51.jsx)(component_default, { 24459 ...otherProps, 24460 ref: forwardedRef, 24461 children 24462 }) 24463 }); 24464 } 24465 var Flex2 = contextConnect(UnconnectedFlex, "Flex"); 24466 var component_default3 = Flex2; 24467 24468 // packages/components/build-module/flex/flex-item/hook.js 24469 function useFlexItem(props) { 24470 const { 24471 className: className2, 24472 display: displayProp, 24473 isBlock = false, 24474 ...otherProps 24475 } = useContextSystem(props, "FlexItem"); 24476 const sx = {}; 24477 const contextDisplay = useFlexContext().flexItemDisplay; 24478 sx.Base = /* @__PURE__ */ css({ 24479 display: displayProp || contextDisplay 24480 }, false ? "" : ";label:sx-Base;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0NXIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi8uLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi8uLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUZsZXhDb250ZXh0IH0gZnJvbSAnLi4vY29udGV4dCc7XG5pbXBvcnQgKiBhcyBzdHlsZXMgZnJvbSAnLi4vc3R5bGVzJztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB0eXBlIHsgRmxleEl0ZW1Qcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUZsZXhJdGVtKFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IEZsZXhJdGVtUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGRpc3BsYXk6IGRpc3BsYXlQcm9wLFxuXHRcdGlzQmxvY2sgPSBmYWxzZSxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ0ZsZXhJdGVtJyApO1xuXG5cdGNvbnN0IHN4OiB7XG5cdFx0QmFzZT86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdH0gPSB7fTtcblxuXHRjb25zdCBjb250ZXh0RGlzcGxheSA9IHVzZUZsZXhDb250ZXh0KCkuZmxleEl0ZW1EaXNwbGF5O1xuXG5cdHN4LkJhc2UgPSBjc3MoIHtcblx0XHRkaXNwbGF5OiBkaXNwbGF5UHJvcCB8fCBjb250ZXh0RGlzcGxheSxcblx0fSApO1xuXG5cdGNvbnN0IGN4ID0gdXNlQ3goKTtcblxuXHRjb25zdCBjbGFzc2VzID0gY3goXG5cdFx0c3R5bGVzLkl0ZW0sXG5cdFx0c3guQmFzZSxcblx0XHRpc0Jsb2NrICYmIHN0eWxlcy5ibG9jayxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4ge1xuXHRcdC4uLm90aGVyUHJvcHMsXG5cdFx0Y2xhc3NOYW1lOiBjbGFzc2VzLFxuXHR9O1xufVxuIl19 */"); 24481 const cx3 = useCx(); 24482 const classes = cx3(Item, sx.Base, isBlock && block, className2); 24483 return { 24484 ...otherProps, 24485 className: classes 24486 }; 24487 } 24488 24489 // packages/components/build-module/flex/flex-item/component.js 24490 var import_jsx_runtime52 = __toESM(require_jsx_runtime()); 24491 function UnconnectedFlexItem(props, forwardedRef) { 24492 const flexItemProps = useFlexItem(props); 24493 return /* @__PURE__ */ (0, import_jsx_runtime52.jsx)(component_default, { 24494 ...flexItemProps, 24495 ref: forwardedRef 24496 }); 24497 } 24498 var FlexItem = contextConnect(UnconnectedFlexItem, "FlexItem"); 24499 var component_default4 = FlexItem; 24500 24501 // packages/components/build-module/flex/flex-block/hook.js 24502 function useFlexBlock(props) { 24503 const otherProps = useContextSystem(props, "FlexBlock"); 24504 const flexItemProps = useFlexItem({ 24505 isBlock: true, 24506 ...otherProps 24507 }); 24508 return flexItemProps; 24509 } 24510 24511 // packages/components/build-module/flex/flex-block/component.js 24512 var import_jsx_runtime53 = __toESM(require_jsx_runtime()); 24513 function UnconnectedFlexBlock(props, forwardedRef) { 24514 const flexBlockProps = useFlexBlock(props); 24515 return /* @__PURE__ */ (0, import_jsx_runtime53.jsx)(component_default, { 24516 ...flexBlockProps, 24517 ref: forwardedRef 24518 }); 24519 } 24520 var FlexBlock = contextConnect(UnconnectedFlexBlock, "FlexBlock"); 24521 var component_default5 = FlexBlock; 24522 24523 // packages/components/build-module/spacer/hook.js 24524 function isDefined(o4) { 24525 return typeof o4 !== "undefined" && o4 !== null; 24526 } 24527 function useSpacer(props) { 24528 const { 24529 className: className2, 24530 margin, 24531 marginBottom = 2, 24532 marginLeft, 24533 marginRight, 24534 marginTop, 24535 marginX, 24536 marginY, 24537 padding: padding2, 24538 paddingBottom, 24539 paddingLeft, 24540 paddingRight, 24541 paddingTop, 24542 paddingX, 24543 paddingY: paddingY2, 24544 ...otherProps 24545 } = useContextSystem(props, "Spacer"); 24546 const cx3 = useCx(); 24547 const classes = cx3(isDefined(margin) && /* @__PURE__ */ css("margin:", space(margin), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNENNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(marginY) && /* @__PURE__ */ css("margin-bottom:", space(marginY), ";margin-top:", space(marginY), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0RNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(marginX) && /* @__PURE__ */ css("margin-left:", space(marginX), ";margin-right:", space(marginX), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcURNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(marginTop) && /* @__PURE__ */ css("margin-top:", space(marginTop), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(marginBottom) && /* @__PURE__ */ css("margin-bottom:", space(marginBottom), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOERNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(marginLeft) && rtl({ 24548 marginLeft: space(marginLeft) 24549 })(), isDefined(marginRight) && rtl({ 24550 marginRight: space(marginRight) 24551 })(), isDefined(padding2) && /* @__PURE__ */ css("padding:", space(padding2), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEVNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(paddingY2) && /* @__PURE__ */ css("padding-bottom:", space(paddingY2), ";padding-top:", space(paddingY2), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEVNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(paddingX) && /* @__PURE__ */ css("padding-left:", space(paddingX), ";padding-right:", space(paddingX), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUZNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(paddingTop) && /* @__PURE__ */ css("padding-top:", space(paddingTop), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0ZNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(paddingBottom) && /* @__PURE__ */ css("padding-bottom:", space(paddingBottom), ";" + (false ? "" : ";label:classes;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEZNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgcnRsLCB1c2VDeCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3BhY2VyUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZnVuY3Rpb24gaXNEZWZpbmVkPCBUID4oIG86IFQgKTogbyBpcyBFeGNsdWRlPCBULCBudWxsIHwgdW5kZWZpbmVkID4ge1xuXHRyZXR1cm4gdHlwZW9mIG8gIT09ICd1bmRlZmluZWQnICYmIG8gIT09IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTcGFjZXIoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgU3BhY2VyUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdG1hcmdpbixcblx0XHRtYXJnaW5Cb3R0b20gPSAyLFxuXHRcdG1hcmdpbkxlZnQsXG5cdFx0bWFyZ2luUmlnaHQsXG5cdFx0bWFyZ2luVG9wLFxuXHRcdG1hcmdpblgsXG5cdFx0bWFyZ2luWSxcblx0XHRwYWRkaW5nLFxuXHRcdHBhZGRpbmdCb3R0b20sXG5cdFx0cGFkZGluZ0xlZnQsXG5cdFx0cGFkZGluZ1JpZ2h0LFxuXHRcdHBhZGRpbmdUb3AsXG5cdFx0cGFkZGluZ1gsXG5cdFx0cGFkZGluZ1ksXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdTcGFjZXInICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSBjeChcblx0XHRpc0RlZmluZWQoIG1hcmdpbiApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbjogJHsgc3BhY2UoIG1hcmdpbiApIH07XG5cdFx0XHRgLFxuXHRcdGlzRGVmaW5lZCggbWFyZ2luWSApICYmXG5cdFx0XHRjc3NgXG5cdFx0XHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCBtYXJnaW5ZICkgfTtcblx0XHRcdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIG1hcmdpblkgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIG1hcmdpblggKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIG1hcmdpblggKSB9O1xuXHRcdFx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCBtYXJnaW5YICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Ub3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggbWFyZ2luVG9wICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5Cb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggbWFyZ2luQm90dG9tICkgfTtcblx0XHRcdGAsXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5MZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRtYXJnaW5MZWZ0OiBzcGFjZSggbWFyZ2luTGVmdCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBtYXJnaW5SaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0bWFyZ2luUmlnaHQ6IHNwYWNlKCBtYXJnaW5SaWdodCApLFxuXHRcdFx0fSApKCksXG5cdFx0aXNEZWZpbmVkKCBwYWRkaW5nICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIHBhZGRpbmcgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdZICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBwYWRkaW5nWSApIH07XG5cdFx0XHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggcGFkZGluZ1kgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdYICkgJiZcblx0XHRcdGNzc2Bcblx0XHRcdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggcGFkZGluZ1ggKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdUb3AgKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIHBhZGRpbmdUb3AgKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdCb3R0b20gKSAmJlxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogJHsgc3BhY2UoIHBhZGRpbmdCb3R0b20gKSB9O1xuXHRcdFx0YCxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdMZWZ0ICkgJiZcblx0XHRcdHJ0bCgge1xuXHRcdFx0XHRwYWRkaW5nTGVmdDogc3BhY2UoIHBhZGRpbmdMZWZ0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRpc0RlZmluZWQoIHBhZGRpbmdSaWdodCApICYmXG5cdFx0XHRydGwoIHtcblx0XHRcdFx0cGFkZGluZ1JpZ2h0OiBzcGFjZSggcGFkZGluZ1JpZ2h0ICksXG5cdFx0XHR9ICkoKSxcblx0XHRjbGFzc05hbWVcblx0KTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMgfTtcbn1cbiJdfQ== */"), isDefined(paddingLeft) && rtl({ 24552 paddingLeft: space(paddingLeft) 24553 })(), isDefined(paddingRight) && rtl({ 24554 paddingRight: space(paddingRight) 24555 })(), className2); 24556 return { 24557 ...otherProps, 24558 className: classes 24559 }; 24560 } 24561 24562 // packages/components/build-module/spacer/component.js 24563 var import_jsx_runtime54 = __toESM(require_jsx_runtime()); 24564 function UnconnectedSpacer(props, forwardedRef) { 24565 const spacerProps = useSpacer(props); 24566 return /* @__PURE__ */ (0, import_jsx_runtime54.jsx)(component_default, { 24567 ...spacerProps, 24568 ref: forwardedRef 24569 }); 24570 } 24571 var Spacer = contextConnect(UnconnectedSpacer, "Spacer"); 24572 var component_default6 = Spacer; 24573 24574 // packages/components/build-module/number-control/index.js 24575 var import_element35 = __toESM(require_element()); 24576 var import_i18n5 = __toESM(require_i18n()); 24577 24578 // packages/icons/build-module/icon/index.js 24579 var import_element21 = __toESM(require_element()); 24580 var icon_default2 = (0, import_element21.forwardRef)( 24581 ({ icon, size: size3 = 24, ...props }, ref) => { 24582 return (0, import_element21.cloneElement)(icon, { 24583 width: size3, 24584 height: size3, 24585 ...props, 24586 ref 24587 }); 24588 } 24589 ); 24590 24591 // packages/icons/build-module/library/arrow-left.js 24592 var import_primitives2 = __toESM(require_primitives()); 24593 var import_jsx_runtime55 = __toESM(require_jsx_runtime()); 24594 var arrow_left_default = /* @__PURE__ */ (0, import_jsx_runtime55.jsx)(import_primitives2.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime55.jsx)(import_primitives2.Path, { d: "M20 11.2H6.8l3.7-3.7-1-1L3.9 12l5.6 5.5 1-1-3.7-3.7H20z" }) }); 24595 24596 // packages/icons/build-module/library/arrow-right.js 24597 var import_primitives3 = __toESM(require_primitives()); 24598 var import_jsx_runtime56 = __toESM(require_jsx_runtime()); 24599 var arrow_right_default = /* @__PURE__ */ (0, import_jsx_runtime56.jsx)(import_primitives3.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime56.jsx)(import_primitives3.Path, { d: "m14.5 6.5-1 1 3.7 3.7H4v1.6h13.2l-3.7 3.7 1 1 5.6-5.5z" }) }); 24600 24601 // packages/icons/build-module/library/caution.js 24602 var import_primitives4 = __toESM(require_primitives()); 24603 var import_jsx_runtime57 = __toESM(require_jsx_runtime()); 24604 var caution_default = /* @__PURE__ */ (0, import_jsx_runtime57.jsx)(import_primitives4.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime57.jsx)( 24605 import_primitives4.Path, 24606 { 24607 fillRule: "evenodd", 24608 clipRule: "evenodd", 24609 d: "M5.5 12a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0ZM12 4a8 8 0 1 0 0 16 8 8 0 0 0 0-16Zm-.75 12v-1.5h1.5V16h-1.5Zm0-8v5h1.5V8h-1.5Z" 24610 } 24611 ) }); 24612 24613 // packages/icons/build-module/library/check.js 24614 var import_primitives5 = __toESM(require_primitives()); 24615 var import_jsx_runtime58 = __toESM(require_jsx_runtime()); 24616 var check_default = /* @__PURE__ */ (0, import_jsx_runtime58.jsx)(import_primitives5.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime58.jsx)(import_primitives5.Path, { d: "M16.5 7.5 10 13.9l-2.5-2.4-1 1 3.5 3.6 7.5-7.6z" }) }); 24617 24618 // packages/icons/build-module/library/chevron-down.js 24619 var import_primitives6 = __toESM(require_primitives()); 24620 var import_jsx_runtime59 = __toESM(require_jsx_runtime()); 24621 var chevron_down_default = /* @__PURE__ */ (0, import_jsx_runtime59.jsx)(import_primitives6.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime59.jsx)(import_primitives6.Path, { d: "M17.5 11.6L12 16l-5.5-4.4.9-1.2L12 14l4.5-3.6 1 1.2z" }) }); 24622 24623 // packages/icons/build-module/library/chevron-left.js 24624 var import_primitives7 = __toESM(require_primitives()); 24625 var import_jsx_runtime60 = __toESM(require_jsx_runtime()); 24626 var chevron_left_default = /* @__PURE__ */ (0, import_jsx_runtime60.jsx)(import_primitives7.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime60.jsx)(import_primitives7.Path, { d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z" }) }); 24627 24628 // packages/icons/build-module/library/chevron-right-small.js 24629 var import_primitives8 = __toESM(require_primitives()); 24630 var import_jsx_runtime61 = __toESM(require_jsx_runtime()); 24631 var chevron_right_small_default = /* @__PURE__ */ (0, import_jsx_runtime61.jsx)(import_primitives8.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime61.jsx)(import_primitives8.Path, { d: "M10.8622 8.04053L14.2805 12.0286L10.8622 16.0167L9.72327 15.0405L12.3049 12.0286L9.72327 9.01672L10.8622 8.04053Z" }) }); 24632 24633 // packages/icons/build-module/library/chevron-right.js 24634 var import_primitives9 = __toESM(require_primitives()); 24635 var import_jsx_runtime62 = __toESM(require_jsx_runtime()); 24636 var chevron_right_default = /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(import_primitives9.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime62.jsx)(import_primitives9.Path, { d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z" }) }); 24637 24638 // packages/icons/build-module/library/chevron-up.js 24639 var import_primitives10 = __toESM(require_primitives()); 24640 var import_jsx_runtime63 = __toESM(require_jsx_runtime()); 24641 var chevron_up_default = /* @__PURE__ */ (0, import_jsx_runtime63.jsx)(import_primitives10.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime63.jsx)(import_primitives10.Path, { d: "M6.5 12.4L12 8l5.5 4.4-.9 1.2L12 10l-4.5 3.6-1-1.2z" }) }); 24642 24643 // packages/icons/build-module/library/close-small.js 24644 var import_primitives11 = __toESM(require_primitives()); 24645 var import_jsx_runtime64 = __toESM(require_jsx_runtime()); 24646 var close_small_default = /* @__PURE__ */ (0, import_jsx_runtime64.jsx)(import_primitives11.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime64.jsx)(import_primitives11.Path, { d: "M12 13.06l3.712 3.713 1.061-1.06L13.061 12l3.712-3.712-1.06-1.06L12 10.938 8.288 7.227l-1.061 1.06L10.939 12l-3.712 3.712 1.06 1.061L12 13.061z" }) }); 24647 24648 // packages/icons/build-module/library/close.js 24649 var import_primitives12 = __toESM(require_primitives()); 24650 var import_jsx_runtime65 = __toESM(require_jsx_runtime()); 24651 var close_default = /* @__PURE__ */ (0, import_jsx_runtime65.jsx)(import_primitives12.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime65.jsx)(import_primitives12.Path, { d: "m13.06 12 6.47-6.47-1.06-1.06L12 10.94 5.53 4.47 4.47 5.53 10.94 12l-6.47 6.47 1.06 1.06L12 13.06l6.47 6.47 1.06-1.06L13.06 12Z" }) }); 24652 24653 // packages/icons/build-module/library/copy.js 24654 var import_primitives13 = __toESM(require_primitives()); 24655 var import_jsx_runtime66 = __toESM(require_jsx_runtime()); 24656 var copy_default = /* @__PURE__ */ (0, import_jsx_runtime66.jsx)(import_primitives13.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime66.jsx)( 24657 import_primitives13.Path, 24658 { 24659 fillRule: "evenodd", 24660 clipRule: "evenodd", 24661 d: "M5 4.5h11a.5.5 0 0 1 .5.5v11a.5.5 0 0 1-.5.5H5a.5.5 0 0 1-.5-.5V5a.5.5 0 0 1 .5-.5ZM3 5a2 2 0 0 1 2-2h11a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5Zm17 3v10.75c0 .69-.56 1.25-1.25 1.25H6v1.5h12.75a2.75 2.75 0 0 0 2.75-2.75V8H20Z" 24662 } 24663 ) }); 24664 24665 // packages/icons/build-module/library/error.js 24666 var import_primitives14 = __toESM(require_primitives()); 24667 var import_jsx_runtime67 = __toESM(require_jsx_runtime()); 24668 var error_default = /* @__PURE__ */ (0, import_jsx_runtime67.jsx)(import_primitives14.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime67.jsx)( 24669 import_primitives14.Path, 24670 { 24671 fillRule: "evenodd", 24672 clipRule: "evenodd", 24673 d: "M12.218 5.377a.25.25 0 0 0-.436 0l-7.29 12.96a.25.25 0 0 0 .218.373h14.58a.25.25 0 0 0 .218-.372l-7.29-12.96Zm-1.743-.735c.669-1.19 2.381-1.19 3.05 0l7.29 12.96a1.75 1.75 0 0 1-1.525 2.608H4.71a1.75 1.75 0 0 1-1.525-2.608l7.29-12.96ZM12.75 17.46h-1.5v-1.5h1.5v1.5Zm-1.5-3h1.5v-5h-1.5v5Z" 24674 } 24675 ) }); 24676 24677 // packages/icons/build-module/library/info.js 24678 var import_primitives15 = __toESM(require_primitives()); 24679 var import_jsx_runtime68 = __toESM(require_jsx_runtime()); 24680 var info_default = /* @__PURE__ */ (0, import_jsx_runtime68.jsx)(import_primitives15.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime68.jsx)( 24681 import_primitives15.Path, 24682 { 24683 fillRule: "evenodd", 24684 clipRule: "evenodd", 24685 d: "M5.5 12a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0ZM12 4a8 8 0 1 0 0 16 8 8 0 0 0 0-16Zm.75 4v1.5h-1.5V8h1.5Zm0 8v-5h-1.5v5h1.5Z" 24686 } 24687 ) }); 24688 24689 // packages/icons/build-module/library/line-dashed.js 24690 var import_primitives16 = __toESM(require_primitives()); 24691 var import_jsx_runtime69 = __toESM(require_jsx_runtime()); 24692 var line_dashed_default = /* @__PURE__ */ (0, import_jsx_runtime69.jsx)(import_primitives16.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime69.jsx)( 24693 import_primitives16.Path, 24694 { 24695 fillRule: "evenodd", 24696 d: "M5 11.25h3v1.5H5v-1.5zm5.5 0h3v1.5h-3v-1.5zm8.5 0h-3v1.5h3v-1.5z", 24697 clipRule: "evenodd" 24698 } 24699 ) }); 24700 24701 // packages/icons/build-module/library/line-dotted.js 24702 var import_primitives17 = __toESM(require_primitives()); 24703 var import_jsx_runtime70 = __toESM(require_jsx_runtime()); 24704 var line_dotted_default = /* @__PURE__ */ (0, import_jsx_runtime70.jsx)(import_primitives17.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime70.jsx)( 24705 import_primitives17.Path, 24706 { 24707 fillRule: "evenodd", 24708 d: "M5.25 11.25h1.5v1.5h-1.5v-1.5zm3 0h1.5v1.5h-1.5v-1.5zm4.5 0h-1.5v1.5h1.5v-1.5zm1.5 0h1.5v1.5h-1.5v-1.5zm4.5 0h-1.5v1.5h1.5v-1.5z", 24709 clipRule: "evenodd" 24710 } 24711 ) }); 24712 24713 // packages/icons/build-module/library/line-solid.js 24714 var import_primitives18 = __toESM(require_primitives()); 24715 var import_jsx_runtime71 = __toESM(require_jsx_runtime()); 24716 var line_solid_default = /* @__PURE__ */ (0, import_jsx_runtime71.jsx)(import_primitives18.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime71.jsx)(import_primitives18.Path, { d: "M5 11.25h14v1.5H5z" }) }); 24717 24718 // packages/icons/build-module/library/link-off.js 24719 var import_primitives19 = __toESM(require_primitives()); 24720 var import_jsx_runtime72 = __toESM(require_jsx_runtime()); 24721 var link_off_default = /* @__PURE__ */ (0, import_jsx_runtime72.jsx)(import_primitives19.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime72.jsx)(import_primitives19.Path, { d: "M17.031 4.703 15.576 4l-1.56 3H14v.03l-2.324 4.47H9.5V13h1.396l-1.502 2.889h-.95a3.694 3.694 0 0 1 0-7.389H10V7H8.444a5.194 5.194 0 1 0 0 10.389h.17L7.5 19.53l1.416.719L15.049 8.5h.507a3.694 3.694 0 0 1 0 7.39H14v1.5h1.556a5.194 5.194 0 0 0 .273-10.383l1.202-2.304Z" }) }); 24722 24723 // packages/icons/build-module/library/link.js 24724 var import_primitives20 = __toESM(require_primitives()); 24725 var import_jsx_runtime73 = __toESM(require_jsx_runtime()); 24726 var link_default = /* @__PURE__ */ (0, import_jsx_runtime73.jsx)(import_primitives20.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime73.jsx)(import_primitives20.Path, { d: "M10 17.389H8.444A5.194 5.194 0 1 1 8.444 7H10v1.5H8.444a3.694 3.694 0 0 0 0 7.389H10v1.5ZM14 7h1.556a5.194 5.194 0 0 1 0 10.39H14v-1.5h1.556a3.694 3.694 0 0 0 0-7.39H14V7Zm-4.5 6h5v-1.5h-5V13Z" }) }); 24727 24728 // packages/icons/build-module/library/menu.js 24729 var import_primitives21 = __toESM(require_primitives()); 24730 var import_jsx_runtime74 = __toESM(require_jsx_runtime()); 24731 var menu_default = /* @__PURE__ */ (0, import_jsx_runtime74.jsx)(import_primitives21.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime74.jsx)(import_primitives21.Path, { d: "M5 5v1.5h14V5H5zm0 7.8h14v-1.5H5v1.5zM5 19h14v-1.5H5V19z" }) }); 24732 24733 // packages/icons/build-module/library/more-vertical.js 24734 var import_primitives22 = __toESM(require_primitives()); 24735 var import_jsx_runtime75 = __toESM(require_jsx_runtime()); 24736 var more_vertical_default = /* @__PURE__ */ (0, import_jsx_runtime75.jsx)(import_primitives22.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime75.jsx)(import_primitives22.Path, { d: "M13 19h-2v-2h2v2zm0-6h-2v-2h2v2zm0-6h-2V5h2v2z" }) }); 24737 24738 // packages/icons/build-module/library/plus.js 24739 var import_primitives23 = __toESM(require_primitives()); 24740 var import_jsx_runtime76 = __toESM(require_jsx_runtime()); 24741 var plus_default = /* @__PURE__ */ (0, import_jsx_runtime76.jsx)(import_primitives23.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime76.jsx)(import_primitives23.Path, { d: "M11 12.5V17.5H12.5V12.5H17.5V11H12.5V6H11V11H6V12.5H11Z" }) }); 24742 24743 // packages/icons/build-module/library/published.js 24744 var import_primitives24 = __toESM(require_primitives()); 24745 var import_jsx_runtime77 = __toESM(require_jsx_runtime()); 24746 var published_default = /* @__PURE__ */ (0, import_jsx_runtime77.jsx)(import_primitives24.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime77.jsx)( 24747 import_primitives24.Path, 24748 { 24749 fillRule: "evenodd", 24750 clipRule: "evenodd", 24751 d: "M12 18.5a6.5 6.5 0 1 1 0-13 6.5 6.5 0 0 1 0 13ZM4 12a8 8 0 1 1 16 0 8 8 0 0 1-16 0Zm11.53-1.47-1.06-1.06L11 12.94l-1.47-1.47-1.06 1.06L11 15.06l4.53-4.53Z" 24752 } 24753 ) }); 24754 24755 // packages/icons/build-module/library/reset.js 24756 var import_primitives25 = __toESM(require_primitives()); 24757 var import_jsx_runtime78 = __toESM(require_jsx_runtime()); 24758 var reset_default = /* @__PURE__ */ (0, import_jsx_runtime78.jsx)(import_primitives25.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime78.jsx)(import_primitives25.Path, { d: "M7 11.5h10V13H7z" }) }); 24759 24760 // packages/icons/build-module/library/search.js 24761 var import_primitives26 = __toESM(require_primitives()); 24762 var import_jsx_runtime79 = __toESM(require_jsx_runtime()); 24763 var search_default = /* @__PURE__ */ (0, import_jsx_runtime79.jsx)(import_primitives26.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime79.jsx)(import_primitives26.Path, { d: "M13 5c-3.3 0-6 2.7-6 6 0 1.4.5 2.7 1.3 3.7l-3.8 3.8 1.1 1.1 3.8-3.8c1 .8 2.3 1.3 3.7 1.3 3.3 0 6-2.7 6-6S16.3 5 13 5zm0 10.5c-2.5 0-4.5-2-4.5-4.5s2-4.5 4.5-4.5 4.5 2 4.5 4.5-2 4.5-4.5 4.5z" }) }); 24764 24765 // packages/icons/build-module/library/settings.js 24766 var import_primitives27 = __toESM(require_primitives()); 24767 var import_jsx_runtime80 = __toESM(require_jsx_runtime()); 24768 var settings_default = /* @__PURE__ */ (0, import_jsx_runtime80.jsxs)(import_primitives27.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: [ 24769 /* @__PURE__ */ (0, import_jsx_runtime80.jsx)(import_primitives27.Path, { d: "m19 7.5h-7.628c-.3089-.87389-1.1423-1.5-2.122-1.5-.97966 0-1.81309.62611-2.12197 1.5h-2.12803v1.5h2.12803c.30888.87389 1.14231 1.5 2.12197 1.5.9797 0 1.8131-.62611 2.122-1.5h7.628z" }), 24770 /* @__PURE__ */ (0, import_jsx_runtime80.jsx)(import_primitives27.Path, { d: "m19 15h-2.128c-.3089-.8739-1.1423-1.5-2.122-1.5s-1.8131.6261-2.122 1.5h-7.628v1.5h7.628c.3089.8739 1.1423 1.5 2.122 1.5s1.8131-.6261 2.122-1.5h2.128z" }) 24771 ] }); 24772 24773 // packages/icons/build-module/library/swatch.js 24774 var import_primitives28 = __toESM(require_primitives()); 24775 var import_jsx_runtime81 = __toESM(require_jsx_runtime()); 24776 var swatch_default = /* @__PURE__ */ (0, import_jsx_runtime81.jsx)(import_primitives28.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime81.jsx)(import_primitives28.Path, { d: "M7.1 5.7 8 6.9c.4-.3.9-.6 1.5-.8l-.6-1.4c-.7.3-1.3.6-1.8 1ZM4.6 8.9l1.4.6c.2-.5.5-1 .8-1.5l-1.2-.9c-.4.6-.8 1.2-1 1.8Zm14.8 0c-.3-.7-.6-1.3-1-1.8l-1.2.9c.3.4.6.9.8 1.5l1.4-.6ZM7.1 18.3c.6.4 1.2.8 1.8 1l.6-1.4c-.5-.2-1-.5-1.5-.8l-.9 1.2ZM5.5 12v-.9h-.7l-.7-.2v2l1.5-.2v-.9Zm-.7 3h-.2c.3.7.6 1.3 1 1.9l1.2-.9c-.3-.4-.6-.9-.8-1.5l-1.2.5Zm9.7 3 .5 1.2v.2c.7-.3 1.3-.6 1.9-1l-.9-1.2c-.4.3-.9.6-1.5.8Zm-2.5.5h-.9l-.2 1.3v.2h2l-.2-1.5h-.9Zm7.9-7.5-1.5.2V13h.7l.7.2v-2ZM18 14.5c-.2.5-.5 1-.8 1.5l1.2.9c.4-.6.8-1.2 1-1.8h-.2l-1.2-.6ZM11 4.1l.2 1.5H13V4.2h-1.9ZM14.5 6c.5.2 1 .5 1.5.8l.9-1.2c-.6-.4-1.2-.8-1.8-1L14.5 6Z" }) }); 24777 24778 // packages/icons/build-module/library/tip.js 24779 var import_primitives29 = __toESM(require_primitives()); 24780 var import_jsx_runtime82 = __toESM(require_jsx_runtime()); 24781 var tip_default = /* @__PURE__ */ (0, import_jsx_runtime82.jsx)(import_primitives29.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime82.jsx)(import_primitives29.Path, { d: "M12 15.8c-3.7 0-6.8-3-6.8-6.8s3-6.8 6.8-6.8c3.7 0 6.8 3 6.8 6.8s-3.1 6.8-6.8 6.8zm0-12C9.1 3.8 6.8 6.1 6.8 9s2.4 5.2 5.2 5.2c2.9 0 5.2-2.4 5.2-5.2S14.9 3.8 12 3.8zM8 17.5h8V19H8zM10 20.5h4V22h-4z" }) }); 24782 24783 // packages/icons/build-module/library/upload.js 24784 var import_primitives30 = __toESM(require_primitives()); 24785 var import_jsx_runtime83 = __toESM(require_jsx_runtime()); 24786 var upload_default = /* @__PURE__ */ (0, import_jsx_runtime83.jsx)(import_primitives30.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime83.jsx)(import_primitives30.Path, { d: "M18.5 15v3.5H13V6.7l4.5 4.1 1-1.1-6.2-5.8-5.8 5.8 1 1.1 4-4v11.7h-6V15H4v5h16v-5z" }) }); 24787 24788 // packages/components/build-module/number-control/index.js 24789 var import_compose7 = __toESM(require_compose()); 24790 var import_deprecated5 = __toESM(require_deprecated()); 24791 24792 // packages/components/build-module/input-control/index.js 24793 var import_compose5 = __toESM(require_compose()); 24794 var import_element31 = __toESM(require_element()); 24795 24796 // packages/components/build-module/input-control/input-base.js 24797 var import_compose3 = __toESM(require_compose()); 24798 var import_element26 = __toESM(require_element()); 24799 24800 // packages/components/build-module/input-control/backdrop.js 24801 var import_element25 = __toESM(require_element()); 24802 24803 // packages/components/build-module/text/hook.js 24804 var import_element24 = __toESM(require_element()); 24805 24806 // packages/components/build-module/truncate/hook.js 24807 var import_element22 = __toESM(require_element()); 24808 24809 // packages/components/build-module/truncate/styles.js 24810 function _EMOTION_STRINGIFIED_CSS_ERROR__3() { 24811 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 24812 } 24813 var Truncate = false ? { 24814 name: "hdknak", 24815 styles: "display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap" 24816 } : { 24817 name: "abxxyf-Truncate", 24818 styles: "display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;label:Truncate;", 24819 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLMkIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgVHJ1bmNhdGUgPSBjc3NgXG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcbmA7XG4iXX0= */", 24820 toString: _EMOTION_STRINGIFIED_CSS_ERROR__3 24821 }; 24822 24823 // packages/components/build-module/truncate/utils.js 24824 var TRUNCATE_ELLIPSIS = "\u2026"; 24825 var TRUNCATE_TYPE = { 24826 auto: "auto", 24827 head: "head", 24828 middle: "middle", 24829 tail: "tail", 24830 none: "none" 24831 }; 24832 var TRUNCATE_DEFAULT_PROPS = { 24833 ellipsis: TRUNCATE_ELLIPSIS, 24834 ellipsizeMode: TRUNCATE_TYPE.auto, 24835 limit: 0, 24836 numberOfLines: 0 24837 }; 24838 function truncateMiddle(word, headLength, tailLength, ellipsis) { 24839 if (typeof word !== "string") { 24840 return ""; 24841 } 24842 const wordLength = word.length; 24843 const frontLength = ~~headLength; 24844 const backLength = ~~tailLength; 24845 const truncateStr = isValueDefined(ellipsis) ? ellipsis : TRUNCATE_ELLIPSIS; 24846 if (frontLength === 0 && backLength === 0 || frontLength >= wordLength || backLength >= wordLength || frontLength + backLength >= wordLength) { 24847 return word; 24848 } else if (backLength === 0) { 24849 return word.slice(0, frontLength) + truncateStr; 24850 } 24851 return word.slice(0, frontLength) + truncateStr + word.slice(wordLength - backLength); 24852 } 24853 function truncateContent(words = "", props) { 24854 const mergedProps = { 24855 ...TRUNCATE_DEFAULT_PROPS, 24856 ...props 24857 }; 24858 const { 24859 ellipsis, 24860 ellipsizeMode, 24861 limit 24862 } = mergedProps; 24863 if (ellipsizeMode === TRUNCATE_TYPE.none) { 24864 return words; 24865 } 24866 let truncateHead; 24867 let truncateTail; 24868 switch (ellipsizeMode) { 24869 case TRUNCATE_TYPE.head: 24870 truncateHead = 0; 24871 truncateTail = limit; 24872 break; 24873 case TRUNCATE_TYPE.middle: 24874 truncateHead = Math.floor(limit / 2); 24875 truncateTail = Math.floor(limit / 2); 24876 break; 24877 default: 24878 truncateHead = limit; 24879 truncateTail = 0; 24880 } 24881 const truncatedContent = ellipsizeMode !== TRUNCATE_TYPE.auto ? truncateMiddle(words, truncateHead, truncateTail, ellipsis) : words; 24882 return truncatedContent; 24883 } 24884 24885 // packages/components/build-module/truncate/hook.js 24886 function useTruncate(props) { 24887 const { 24888 className: className2, 24889 children, 24890 ellipsis = TRUNCATE_ELLIPSIS, 24891 ellipsizeMode = TRUNCATE_TYPE.auto, 24892 limit = 0, 24893 numberOfLines = 0, 24894 ...otherProps 24895 } = useContextSystem(props, "Truncate"); 24896 const cx3 = useCx(); 24897 let childrenAsText; 24898 if (typeof children === "string") { 24899 childrenAsText = children; 24900 } else if (typeof children === "number") { 24901 childrenAsText = children.toString(); 24902 } 24903 const truncatedContent = childrenAsText ? truncateContent(childrenAsText, { 24904 ellipsis, 24905 ellipsizeMode, 24906 limit, 24907 numberOfLines 24908 }) : children; 24909 const shouldTruncate = !!childrenAsText && ellipsizeMode === TRUNCATE_TYPE.auto; 24910 const classes = (0, import_element22.useMemo)(() => { 24911 const truncateLines = /* @__PURE__ */ css(numberOfLines === 1 ? "word-break: break-all;" : "", " -webkit-box-orient:vertical;-webkit-line-clamp:", numberOfLines, ";display:-webkit-box;overflow:hidden;" + (false ? "" : ";label:truncateLines;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEQyQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBUUlVOQ0FURV9FTExJUFNJUywgVFJVTkNBVEVfVFlQRSwgdHJ1bmNhdGVDb250ZW50IH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgdHlwZSB7IFRydW5jYXRlUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdXNlVHJ1bmNhdGUoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgVHJ1bmNhdGVQcm9wcywgJ3NwYW4nID5cbikge1xuXHRjb25zdCB7XG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGNoaWxkcmVuLFxuXHRcdGVsbGlwc2lzID0gVFJVTkNBVEVfRUxMSVBTSVMsXG5cdFx0ZWxsaXBzaXplTW9kZSA9IFRSVU5DQVRFX1RZUEUuYXV0byxcblx0XHRsaW1pdCA9IDAsXG5cdFx0bnVtYmVyT2ZMaW5lcyA9IDAsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdUcnVuY2F0ZScgKTtcblxuXHRjb25zdCBjeCA9IHVzZUN4KCk7XG5cblx0bGV0IGNoaWxkcmVuQXNUZXh0O1xuXHRpZiAoIHR5cGVvZiBjaGlsZHJlbiA9PT0gJ3N0cmluZycgKSB7XG5cdFx0Y2hpbGRyZW5Bc1RleHQgPSBjaGlsZHJlbjtcblx0fSBlbHNlIGlmICggdHlwZW9mIGNoaWxkcmVuID09PSAnbnVtYmVyJyApIHtcblx0XHRjaGlsZHJlbkFzVGV4dCA9IGNoaWxkcmVuLnRvU3RyaW5nKCk7XG5cdH1cblxuXHRjb25zdCB0cnVuY2F0ZWRDb250ZW50ID0gY2hpbGRyZW5Bc1RleHRcblx0XHQ/IHRydW5jYXRlQ29udGVudCggY2hpbGRyZW5Bc1RleHQsIHtcblx0XHRcdFx0ZWxsaXBzaXMsXG5cdFx0XHRcdGVsbGlwc2l6ZU1vZGUsXG5cdFx0XHRcdGxpbWl0LFxuXHRcdFx0XHRudW1iZXJPZkxpbmVzLFxuXHRcdCAgfSApXG5cdFx0OiBjaGlsZHJlbjtcblxuXHRjb25zdCBzaG91bGRUcnVuY2F0ZSA9XG5cdFx0ISEgY2hpbGRyZW5Bc1RleHQgJiYgZWxsaXBzaXplTW9kZSA9PT0gVFJVTkNBVEVfVFlQRS5hdXRvO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0Ly8gVGhlIGB3b3JkLWJyZWFrOiBicmVhay1hbGxgIHByb3BlcnR5IGZpcnN0IG1ha2VzIHN1cmUgYSB0ZXh0IGxpbmVcblx0XHQvLyBicmVha3MgZXZlbiB3aGVuIGl0IGNvbnRhaW5zICd1bmJyZWFrYWJsZScgY29udGVudCBzdWNoIGFzIGxvbmcgVVJMcy5cblx0XHQvLyBTZWUgaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzYwODYwLlxuXHRcdGNvbnN0IHRydW5jYXRlTGluZXMgPSBjc3NgXG5cdFx0XHQkeyBudW1iZXJPZkxpbmVzID09PSAxID8gJ3dvcmQtYnJlYWs6IGJyZWFrLWFsbDsnIDogJycgfVxuXHRcdFx0LXdlYmtpdC1ib3gtb3JpZW50OiB2ZXJ0aWNhbDtcblx0XHRcdC13ZWJraXQtbGluZS1jbGFtcDogJHsgbnVtYmVyT2ZMaW5lcyB9O1xuXHRcdFx0ZGlzcGxheTogLXdlYmtpdC1ib3g7XG5cdFx0XHRvdmVyZmxvdzogaGlkZGVuO1xuXHRcdGA7XG5cblx0XHRyZXR1cm4gY3goXG5cdFx0XHRzaG91bGRUcnVuY2F0ZSAmJiAhIG51bWJlck9mTGluZXMgJiYgc3R5bGVzLlRydW5jYXRlLFxuXHRcdFx0c2hvdWxkVHJ1bmNhdGUgJiYgISEgbnVtYmVyT2ZMaW5lcyAmJiB0cnVuY2F0ZUxpbmVzLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgWyBjbGFzc05hbWUsIGN4LCBudW1iZXJPZkxpbmVzLCBzaG91bGRUcnVuY2F0ZSBdICk7XG5cblx0cmV0dXJuIHsgLi4ub3RoZXJQcm9wcywgY2xhc3NOYW1lOiBjbGFzc2VzLCBjaGlsZHJlbjogdHJ1bmNhdGVkQ29udGVudCB9O1xufVxuIl19 */"); 24912 return cx3(shouldTruncate && !numberOfLines && Truncate, shouldTruncate && !!numberOfLines && truncateLines, className2); 24913 }, [className2, cx3, numberOfLines, shouldTruncate]); 24914 return { 24915 ...otherProps, 24916 className: classes, 24917 children: truncatedContent 24918 }; 24919 } 24920 24921 // packages/components/build-module/truncate/component.js 24922 var import_jsx_runtime84 = __toESM(require_jsx_runtime()); 24923 function UnconnectedTruncate(props, forwardedRef) { 24924 const truncateProps = useTruncate(props); 24925 return /* @__PURE__ */ (0, import_jsx_runtime84.jsx)(component_default, { 24926 as: "span", 24927 ...truncateProps, 24928 ref: forwardedRef 24929 }); 24930 } 24931 var Truncate2 = contextConnect(UnconnectedTruncate, "Truncate"); 24932 var component_default7 = Truncate2; 24933 24934 // packages/components/build-module/text/styles.js 24935 var styles_exports3 = {}; 24936 __export(styles_exports3, { 24937 Text: () => Text, 24938 block: () => block2, 24939 destructive: () => destructive, 24940 highlighterText: () => highlighterText, 24941 muted: () => muted, 24942 positive: () => positive, 24943 upperCase: () => upperCase 24944 }); 24945 function _EMOTION_STRINGIFIED_CSS_ERROR__4() { 24946 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 24947 } 24948 var Text = /* @__PURE__ */ css("color:", COLORS.theme.foreground, ";line-height:", config_values_default.fontLineHeightBase, ";margin:0;text-wrap:balance;text-wrap:pretty;" + (false ? "" : ";label:Text;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVdUIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IFRleHQgPSBjc3NgXG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuXHRtYXJnaW46IDA7XG5cdHRleHQtd3JhcDogYmFsYW5jZTsgLyogRmFsbGJhY2sgZm9yIFNhZmFyaS4gKi9cblx0dGV4dC13cmFwOiBwcmV0dHk7XG5gO1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGRpc3BsYXk6IGJsb2NrO1xuYDtcblxuZXhwb3J0IGNvbnN0IHBvc2l0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LmdyZWVuIH07XG5gO1xuXG5leHBvcnQgY29uc3QgZGVzdHJ1Y3RpdmUgPSBjc3NgXG5cdGNvbG9yOiAkeyBDT0xPUlMuYWxlcnQucmVkIH07XG5gO1xuXG5leHBvcnQgY29uc3QgbXV0ZWQgPSBjc3NgXG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBoaWdobGlnaHRlclRleHQgPSBjc3NgXG5cdG1hcmsge1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy5hbGVydC55ZWxsb3cgfTtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0XHRib3gtc2hhZG93OlxuXHRcdFx0MCAwIDAgMXB4IHJnYmEoIDAsIDAsIDAsIDAuMDUgKSBpbnNldCxcblx0XHRcdDAgLTFweCAwIHJnYmEoIDAsIDAsIDAsIDAuMSApIGluc2V0O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgdXBwZXJDYXNlID0gY3NzYFxuXHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuYDtcbiJdfQ== */"); 24949 var block2 = false ? { 24950 name: "4zleql", 24951 styles: "display:block" 24952 } : { 24953 name: "14aceuy-block", 24954 styles: "display:block;label:block;", 24955 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQndCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */", 24956 toString: _EMOTION_STRINGIFIED_CSS_ERROR__4 24957 }; 24958 var positive = /* @__PURE__ */ css("color:", COLORS.alert.green, ";" + (false ? "" : ";label:positive;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQjJCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */"); 24959 var destructive = /* @__PURE__ */ css("color:", COLORS.alert.red, ";" + (false ? "" : ";label:destructive;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQjhCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */"); 24960 var muted = /* @__PURE__ */ css("color:", COLORS.gray[700], ";" + (false ? "" : ";label:muted;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4QndCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */"); 24961 var highlighterText = /* @__PURE__ */ css("mark{background:", COLORS.alert.yellow, ";border-radius:", config_values_default.radiusSmall, ";box-shadow:0 0 0 1px rgba( 0, 0, 0, 0.05 ) inset,0 -1px 0 rgba( 0, 0, 0, 0.1 ) inset;}" + (false ? "" : ";label:highlighterText;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ2tDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */"); 24962 var upperCase = false ? { 24963 name: "50zrmy", 24964 styles: "text-transform:uppercase" 24965 } : { 24966 name: "1mrt3zt-upperCase", 24967 styles: "text-transform:uppercase;label:upperCase;", 24968 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QzRCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBUZXh0ID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0bGluZS1oZWlnaHQ6ICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfTtcblx0bWFyZ2luOiAwO1xuXHR0ZXh0LXdyYXA6IGJhbGFuY2U7IC8qIEZhbGxiYWNrIGZvciBTYWZhcmkuICovXG5cdHRleHQtd3JhcDogcHJldHR5O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBwb3NpdGl2ZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5hbGVydC5ncmVlbiB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGRlc3RydWN0aXZlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmFsZXJ0LnJlZCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG11dGVkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgaGlnaGxpZ2h0ZXJUZXh0ID0gY3NzYFxuXHRtYXJrIHtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuYWxlcnQueWVsbG93IH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjA1ICkgaW5zZXQsXG5cdFx0XHQwIC0xcHggMCByZ2JhKCAwLCAwLCAwLCAwLjEgKSBpbnNldDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IHVwcGVyQ2FzZSA9IGNzc2Bcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG4iXX0= */", 24969 toString: _EMOTION_STRINGIFIED_CSS_ERROR__4 24970 }; 24971 24972 // packages/components/build-module/text/utils.js 24973 var import_highlight_words_core = __toESM(require_dist()); 24974 var import_element23 = __toESM(require_element()); 24975 var lowercaseProps = (object) => { 24976 const mapped = {}; 24977 for (const key in object) { 24978 mapped[key.toLowerCase()] = object[key]; 24979 } 24980 return mapped; 24981 }; 24982 var memoizedLowercaseProps = memize(lowercaseProps); 24983 function createHighlighterText({ 24984 activeClassName = "", 24985 activeIndex = -1, 24986 activeStyle, 24987 autoEscape, 24988 caseSensitive = false, 24989 children, 24990 findChunks, 24991 highlightClassName = "", 24992 highlightStyle = {}, 24993 highlightTag = "mark", 24994 sanitize: sanitize2, 24995 searchWords = [], 24996 unhighlightClassName = "", 24997 unhighlightStyle 24998 }) { 24999 if (!children) { 25000 return null; 25001 } 25002 if (typeof children !== "string") { 25003 return children; 25004 } 25005 const textToHighlight = children; 25006 const chunks = (0, import_highlight_words_core.findAll)({ 25007 autoEscape, 25008 caseSensitive, 25009 findChunks, 25010 sanitize: sanitize2, 25011 searchWords, 25012 textToHighlight 25013 }); 25014 const HighlightTag = highlightTag; 25015 let highlightIndex = -1; 25016 let highlightClassNames = ""; 25017 let highlightStyles; 25018 const textContent = chunks.map((chunk, index2) => { 25019 const text = textToHighlight.substr(chunk.start, chunk.end - chunk.start); 25020 if (chunk.highlight) { 25021 highlightIndex++; 25022 let highlightClass; 25023 if (typeof highlightClassName === "object") { 25024 if (!caseSensitive) { 25025 highlightClassName = memoizedLowercaseProps(highlightClassName); 25026 highlightClass = highlightClassName[text.toLowerCase()]; 25027 } else { 25028 highlightClass = highlightClassName[text]; 25029 } 25030 } else { 25031 highlightClass = highlightClassName; 25032 } 25033 const isActive = highlightIndex === +activeIndex; 25034 highlightClassNames = `$highlightClass} $isActive ? activeClassName : ""}`; 25035 highlightStyles = isActive === true && activeStyle !== null ? Object.assign({}, highlightStyle, activeStyle) : highlightStyle; 25036 const props = { 25037 children: text, 25038 className: highlightClassNames, 25039 key: index2, 25040 style: highlightStyles 25041 }; 25042 if (typeof HighlightTag !== "string") { 25043 props.highlightIndex = highlightIndex; 25044 } 25045 return (0, import_element23.createElement)(HighlightTag, props); 25046 } 25047 return (0, import_element23.createElement)("span", { 25048 children: text, 25049 className: unhighlightClassName, 25050 key: index2, 25051 style: unhighlightStyle 25052 }); 25053 }); 25054 return textContent; 25055 } 25056 25057 // packages/components/build-module/utils/font-size.js 25058 var BASE_FONT_SIZE = 13; 25059 var PRESET_FONT_SIZES = { 25060 body: BASE_FONT_SIZE, 25061 caption: 10, 25062 footnote: 11, 25063 largeTitle: 28, 25064 subheadline: 12, 25065 title: 20 25066 }; 25067 var HEADING_FONT_SIZES = [1, 2, 3, 4, 5, 6].flatMap((n3) => [n3, n3.toString()]); 25068 function getFontSize(size3 = BASE_FONT_SIZE) { 25069 if (size3 in PRESET_FONT_SIZES) { 25070 return getFontSize(PRESET_FONT_SIZES[size3]); 25071 } 25072 if (typeof size3 !== "number") { 25073 const parsed = parseFloat(size3); 25074 if (Number.isNaN(parsed)) { 25075 return size3; 25076 } 25077 size3 = parsed; 25078 } 25079 const ratio = `($size3} / $BASE_FONT_SIZE})`; 25080 return `calc($ratio} * $config_values_default.fontSize})`; 25081 } 25082 function getHeadingFontSize(size3 = 3) { 25083 if (!HEADING_FONT_SIZES.includes(size3)) { 25084 return getFontSize(size3); 25085 } 25086 const headingSize = `fontSizeH$size3}`; 25087 return config_values_default[headingSize]; 25088 } 25089 25090 // packages/components/build-module/text/get-line-height.js 25091 function getLineHeight(adjustLineHeightForInnerControls, lineHeight) { 25092 if (lineHeight) { 25093 return lineHeight; 25094 } 25095 if (!adjustLineHeightForInnerControls) { 25096 return; 25097 } 25098 let value = `calc($config_values_default.controlHeight} + $space(2)})`; 25099 switch (adjustLineHeightForInnerControls) { 25100 case "large": 25101 value = `calc($config_values_default.controlHeightLarge} + $space(2)})`; 25102 break; 25103 case "small": 25104 value = `calc($config_values_default.controlHeightSmall} + $space(2)})`; 25105 break; 25106 case "xSmall": 25107 value = `calc($config_values_default.controlHeightXSmall} + $space(2)})`; 25108 break; 25109 default: 25110 break; 25111 } 25112 return value; 25113 } 25114 25115 // packages/components/build-module/text/hook.js 25116 function _EMOTION_STRINGIFIED_CSS_ERROR__5() { 25117 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 25118 } 25119 var _ref = false ? { 25120 name: "50zrmy", 25121 styles: "text-transform:uppercase" 25122 } : { 25123 name: "18bqwxz-sx-upperCase", 25124 styles: "text-transform:uppercase;label:sx-upperCase;", 25125 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0dpQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbywgQ2hpbGRyZW4sIGNsb25lRWxlbWVudCB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IGhhc0Nvbm5lY3ROYW1lc3BhY2UsIHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZVRydW5jYXRlIH0gZnJvbSAnLi4vdHJ1bmNhdGUnO1xuaW1wb3J0IHsgZ2V0T3B0aW1hbFRleHRTaGFkZSB9IGZyb20gJy4uL3V0aWxzL2NvbG9ycyc7XG5pbXBvcnQgKiBhcyBzdHlsZXMgZnJvbSAnLi9zdHlsZXMnO1xuaW1wb3J0IHsgY3JlYXRlSGlnaGxpZ2h0ZXJUZXh0IH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyBnZXRGb250U2l6ZSB9IGZyb20gJy4uL3V0aWxzL2ZvbnQtc2l6ZSc7XG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IGdldExpbmVIZWlnaHQgfSBmcm9tICcuL2dldC1saW5lLWhlaWdodCc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgdHlwZSB7IFByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgdHlwZSBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbi8qKlxuICogQHBhcmFtIHtpbXBvcnQoJy4uL2NvbnRleHQnKS5Xb3JkUHJlc3NDb21wb25lbnRQcm9wczxpbXBvcnQoJy4vdHlwZXMnKS5Qcm9wcywgJ3NwYW4nPn0gcHJvcHNcbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdXNlVGV4dChcblx0cHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBQcm9wcywgJ3NwYW4nID5cbikge1xuXHRjb25zdCB7XG5cdFx0YWRqdXN0TGluZUhlaWdodEZvcklubmVyQ29udHJvbHMsXG5cdFx0YWxpZ24sXG5cdFx0Y2hpbGRyZW4sXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGNvbG9yLFxuXHRcdGVsbGlwc2l6ZU1vZGUsXG5cdFx0aXNEZXN0cnVjdGl2ZSA9IGZhbHNlLFxuXHRcdGRpc3BsYXksXG5cdFx0aGlnaGxpZ2h0RXNjYXBlID0gZmFsc2UsXG5cdFx0aGlnaGxpZ2h0Q2FzZVNlbnNpdGl2ZSA9IGZhbHNlLFxuXHRcdGhpZ2hsaWdodFdvcmRzLFxuXHRcdGhpZ2hsaWdodFNhbml0aXplLFxuXHRcdGlzQmxvY2sgPSBmYWxzZSxcblx0XHRsZXR0ZXJTcGFjaW5nLFxuXHRcdGxpbmVIZWlnaHQ6IGxpbmVIZWlnaHRQcm9wLFxuXHRcdG9wdGltaXplUmVhZGFiaWxpdHlGb3IsXG5cdFx0c2l6ZSxcblx0XHR0cnVuY2F0ZSA9IGZhbHNlLFxuXHRcdHVwcGVyQ2FzZSA9IGZhbHNlLFxuXHRcdHZhcmlhbnQsXG5cdFx0d2VpZ2h0ID0gQ09ORklHLmZvbnRXZWlnaHQsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdUZXh0JyApO1xuXG5cdGxldCBjb250ZW50OiBSZWFjdC5SZWFjdE5vZGUgPSBjaGlsZHJlbjtcblx0Y29uc3QgaXNIaWdobGlnaHRlciA9IEFycmF5LmlzQXJyYXkoIGhpZ2hsaWdodFdvcmRzICk7XG5cdGNvbnN0IGlzQ2FwdGlvbiA9IHNpemUgPT09ICdjYXB0aW9uJztcblxuXHRpZiAoIGlzSGlnaGxpZ2h0ZXIgKSB7XG5cdFx0aWYgKCB0eXBlb2YgY2hpbGRyZW4gIT09ICdzdHJpbmcnICkge1xuXHRcdFx0dGhyb3cgbmV3IFR5cGVFcnJvcihcblx0XHRcdFx0J2BjaGlsZHJlbmAgb2YgYFRleHRgIG11c3Qgb25seSBiZSBgc3RyaW5nYCB0eXBlcyB3aGVuIGBoaWdobGlnaHRXb3Jkc2AgaXMgZGVmaW5lZCdcblx0XHRcdCk7XG5cdFx0fVxuXG5cdFx0Y29udGVudCA9IGNyZWF0ZUhpZ2hsaWdodGVyVGV4dCgge1xuXHRcdFx0YXV0b0VzY2FwZTogaGlnaGxpZ2h0RXNjYXBlLFxuXHRcdFx0Y2hpbGRyZW4sXG5cdFx0XHRjYXNlU2Vuc2l0aXZlOiBoaWdobGlnaHRDYXNlU2Vuc2l0aXZlLFxuXHRcdFx0c2VhcmNoV29yZHM6IGhpZ2hsaWdodFdvcmRzLFxuXHRcdFx0c2FuaXRpemU6IGhpZ2hsaWdodFNhbml0aXplLFxuXHRcdH0gKTtcblx0fVxuXG5cdGNvbnN0IGN4ID0gdXNlQ3goKTtcblxuXHRjb25zdCBjbGFzc2VzID0gdXNlTWVtbyggKCkgPT4ge1xuXHRcdGNvbnN0IHN4OiBSZWNvcmQ8IHN0cmluZywgU2VyaWFsaXplZFN0eWxlcyB8IG51bGwgPiA9IHt9O1xuXG5cdFx0Y29uc3QgbGluZUhlaWdodCA9IGdldExpbmVIZWlnaHQoXG5cdFx0XHRhZGp1c3RMaW5lSGVpZ2h0Rm9ySW5uZXJDb250cm9scyxcblx0XHRcdGxpbmVIZWlnaHRQcm9wXG5cdFx0KTtcblxuXHRcdHN4LkJhc2UgPSBjc3MoIHtcblx0XHRcdGNvbG9yLFxuXHRcdFx0ZGlzcGxheSxcblx0XHRcdGZvbnRTaXplOiBnZXRGb250U2l6ZSggc2l6ZSApLFxuXHRcdFx0Zm9udFdlaWdodDogd2VpZ2h0LFxuXHRcdFx0bGluZUhlaWdodCxcblx0XHRcdGxldHRlclNwYWNpbmcsXG5cdFx0XHR0ZXh0QWxpZ246IGFsaWduLFxuXHRcdH0gKTtcblxuXHRcdHN4LnVwcGVyQ2FzZSA9IGNzcyggeyB0ZXh0VHJhbnNmb3JtOiAndXBwZXJjYXNlJyB9ICk7XG5cblx0XHRzeC5vcHRpbWFsVGV4dENvbG9yID0gbnVsbDtcblxuXHRcdGlmICggb3B0aW1pemVSZWFkYWJpbGl0eUZvciApIHtcblx0XHRcdGNvbnN0IGlzT3B0aW1hbFRleHRDb2xvckRhcmsgPVxuXHRcdFx0XHRnZXRPcHRpbWFsVGV4dFNoYWRlKCBvcHRpbWl6ZVJlYWRhYmlsaXR5Rm9yICkgPT09ICdkYXJrJztcblxuXHRcdFx0Ly8gU2hvdWxkIG5vdCB1c2UgdGhlbWUgY29sb3JzXG5cdFx0XHRzeC5vcHRpbWFsVGV4dENvbG9yID0gaXNPcHRpbWFsVGV4dENvbG9yRGFya1xuXHRcdFx0XHQ/IGNzcyggeyBjb2xvcjogQ09MT1JTLmdyYXlbIDkwMCBdIH0gKVxuXHRcdFx0XHQ6IGNzcyggeyBjb2xvcjogQ09MT1JTLndoaXRlIH0gKTtcblx0XHR9XG5cblx0XHRyZXR1cm4gY3goXG5cdFx0XHRzdHlsZXMuVGV4dCxcblx0XHRcdHN4LkJhc2UsXG5cdFx0XHRzeC5vcHRpbWFsVGV4dENvbG9yLFxuXHRcdFx0aXNEZXN0cnVjdGl2ZSAmJiBzdHlsZXMuZGVzdHJ1Y3RpdmUsXG5cdFx0XHQhISBpc0hpZ2hsaWdodGVyICYmIHN0eWxlcy5oaWdobGlnaHRlclRleHQsXG5cdFx0XHRpc0Jsb2NrICYmIHN0eWxlcy5ibG9jayxcblx0XHRcdGlzQ2FwdGlvbiAmJiBzdHlsZXMubXV0ZWQsXG5cdFx0XHR2YXJpYW50ICYmIHN0eWxlc1sgdmFyaWFudCBdLFxuXHRcdFx0dXBwZXJDYXNlICYmIHN4LnVwcGVyQ2FzZSxcblx0XHRcdGNsYXNzTmFtZVxuXHRcdCk7XG5cdH0sIFtcblx0XHRhZGp1c3RMaW5lSGVpZ2h0Rm9ySW5uZXJDb250cm9scyxcblx0XHRhbGlnbixcblx0XHRjbGFzc05hbWUsXG5cdFx0Y29sb3IsXG5cdFx0Y3gsXG5cdFx0ZGlzcGxheSxcblx0XHRpc0Jsb2NrLFxuXHRcdGlzQ2FwdGlvbixcblx0XHRpc0Rlc3RydWN0aXZlLFxuXHRcdGlzSGlnaGxpZ2h0ZXIsXG5cdFx0bGV0dGVyU3BhY2luZyxcblx0XHRsaW5lSGVpZ2h0UHJvcCxcblx0XHRvcHRpbWl6ZVJlYWRhYmlsaXR5Rm9yLFxuXHRcdHNpemUsXG5cdFx0dXBwZXJDYXNlLFxuXHRcdHZhcmlhbnQsXG5cdFx0d2VpZ2h0LFxuXHRdICk7XG5cblx0bGV0IGZpbmFsRWxsaXBzaXplTW9kZTogdW5kZWZpbmVkIHwgJ2F1dG8nIHwgJ25vbmUnO1xuXHRpZiAoIHRydW5jYXRlID09PSB0cnVlICkge1xuXHRcdGZpbmFsRWxsaXBzaXplTW9kZSA9ICdhdXRvJztcblx0fVxuXHRpZiAoIHRydW5jYXRlID09PSBmYWxzZSApIHtcblx0XHRmaW5hbEVsbGlwc2l6ZU1vZGUgPSAnbm9uZSc7XG5cdH1cblxuXHRjb25zdCBmaW5hbENvbXBvbmVudFByb3BzID0ge1xuXHRcdC4uLm90aGVyUHJvcHMsXG5cdFx0Y2xhc3NOYW1lOiBjbGFzc2VzLFxuXHRcdGNoaWxkcmVuLFxuXHRcdGVsbGlwc2l6ZU1vZGU6IGVsbGlwc2l6ZU1vZGUgfHwgZmluYWxFbGxpcHNpemVNb2RlLFxuXHR9O1xuXG5cdGNvbnN0IHRydW5jYXRlUHJvcHMgPSB1c2VUcnVuY2F0ZSggZmluYWxDb21wb25lbnRQcm9wcyApO1xuXG5cdC8qKlxuXHQgKiBFbmhhbmNlIGNoaWxkIGA8TGluayAvPmAgY29tcG9uZW50cyB0byBpbmhlcml0IGZvbnQgc2l6ZS5cblx0ICovXG5cdGlmICggISB0cnVuY2F0ZSAmJiBBcnJheS5pc0FycmF5KCBjaGlsZHJlbiApICkge1xuXHRcdGNvbnRlbnQgPSBDaGlsZHJlbi5tYXAoIGNoaWxkcmVuLCAoIGNoaWxkICkgPT4ge1xuXHRcdFx0aWYgKFxuXHRcdFx0XHR0eXBlb2YgY2hpbGQgIT09ICdvYmplY3QnIHx8XG5cdFx0XHRcdGNoaWxkID09PSBudWxsIHx8XG5cdFx0XHRcdCEgKCAncHJvcHMnIGluIGNoaWxkIClcblx0XHRcdCkge1xuXHRcdFx0XHRyZXR1cm4gY2hpbGQ7XG5cdFx0XHR9XG5cblx0XHRcdGNvbnN0IGlzTGluayA9IGhhc0Nvbm5lY3ROYW1lc3BhY2UoIGNoaWxkLCBbICdMaW5rJyBdICk7XG5cdFx0XHRpZiAoIGlzTGluayApIHtcblx0XHRcdFx0cmV0dXJuIGNsb25lRWxlbWVudCggY2hpbGQsIHtcblx0XHRcdFx0XHRzaXplOiBjaGlsZC5wcm9wcy5zaXplIHx8ICdpbmhlcml0Jyxcblx0XHRcdFx0fSApO1xuXHRcdFx0fVxuXG5cdFx0XHRyZXR1cm4gY2hpbGQ7XG5cdFx0fSApO1xuXHR9XG5cblx0cmV0dXJuIHtcblx0XHQuLi50cnVuY2F0ZVByb3BzLFxuXHRcdGNoaWxkcmVuOiB0cnVuY2F0ZSA/IHRydW5jYXRlUHJvcHMuY2hpbGRyZW4gOiBjb250ZW50LFxuXHR9O1xufVxuIl19 */", 25126 toString: _EMOTION_STRINGIFIED_CSS_ERROR__5 25127 }; 25128 function useText(props) { 25129 const { 25130 adjustLineHeightForInnerControls, 25131 align, 25132 children, 25133 className: className2, 25134 color: color2, 25135 ellipsizeMode, 25136 isDestructive = false, 25137 display, 25138 highlightEscape = false, 25139 highlightCaseSensitive = false, 25140 highlightWords, 25141 highlightSanitize, 25142 isBlock = false, 25143 letterSpacing, 25144 lineHeight: lineHeightProp, 25145 optimizeReadabilityFor, 25146 size: size3, 25147 truncate = false, 25148 upperCase: upperCase2 = false, 25149 variant, 25150 weight = config_values_default.fontWeight, 25151 ...otherProps 25152 } = useContextSystem(props, "Text"); 25153 let content = children; 25154 const isHighlighter = Array.isArray(highlightWords); 25155 const isCaption = size3 === "caption"; 25156 if (isHighlighter) { 25157 if (typeof children !== "string") { 25158 throw new TypeError("`children` of `Text` must only be `string` types when `highlightWords` is defined"); 25159 } 25160 content = createHighlighterText({ 25161 autoEscape: highlightEscape, 25162 children, 25163 caseSensitive: highlightCaseSensitive, 25164 searchWords: highlightWords, 25165 sanitize: highlightSanitize 25166 }); 25167 } 25168 const cx3 = useCx(); 25169 const classes = (0, import_element24.useMemo)(() => { 25170 const sx = {}; 25171 const lineHeight = getLineHeight(adjustLineHeightForInnerControls, lineHeightProp); 25172 sx.Base = /* @__PURE__ */ css({ 25173 color: color2, 25174 display, 25175 fontSize: getFontSize(size3), 25176 fontWeight: weight, 25177 lineHeight, 25178 letterSpacing, 25179 textAlign: align 25180 }, false ? "" : ";label:sx-Base;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0ZZIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vLCBDaGlsZHJlbiwgY2xvbmVFbGVtZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgaGFzQ29ubmVjdE5hbWVzcGFjZSwgdXNlQ29udGV4dFN5c3RlbSB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgdXNlVHJ1bmNhdGUgfSBmcm9tICcuLi90cnVuY2F0ZSc7XG5pbXBvcnQgeyBnZXRPcHRpbWFsVGV4dFNoYWRlIH0gZnJvbSAnLi4vdXRpbHMvY29sb3JzJztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBjcmVhdGVIaWdobGlnaHRlclRleHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IGdldEZvbnRTaXplIH0gZnJvbSAnLi4vdXRpbHMvZm9udC1zaXplJztcbmltcG9ydCB7IENPTkZJRywgQ09MT1JTIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgZ2V0TGluZUhlaWdodCB9IGZyb20gJy4vZ2V0LWxpbmUtaGVpZ2h0JztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB0eXBlIHsgUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB0eXBlIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuLyoqXG4gKiBAcGFyYW0ge2ltcG9ydCgnLi4vY29udGV4dCcpLldvcmRQcmVzc0NvbXBvbmVudFByb3BzPGltcG9ydCgnLi90eXBlcycpLlByb3BzLCAnc3Bhbic+fSBwcm9wc1xuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VUZXh0KFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IFByb3BzLCAnc3BhbicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhZGp1c3RMaW5lSGVpZ2h0Rm9ySW5uZXJDb250cm9scyxcblx0XHRhbGlnbixcblx0XHRjaGlsZHJlbixcblx0XHRjbGFzc05hbWUsXG5cdFx0Y29sb3IsXG5cdFx0ZWxsaXBzaXplTW9kZSxcblx0XHRpc0Rlc3RydWN0aXZlID0gZmFsc2UsXG5cdFx0ZGlzcGxheSxcblx0XHRoaWdobGlnaHRFc2NhcGUgPSBmYWxzZSxcblx0XHRoaWdobGlnaHRDYXNlU2Vuc2l0aXZlID0gZmFsc2UsXG5cdFx0aGlnaGxpZ2h0V29yZHMsXG5cdFx0aGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0aXNCbG9jayA9IGZhbHNlLFxuXHRcdGxldHRlclNwYWNpbmcsXG5cdFx0bGluZUhlaWdodDogbGluZUhlaWdodFByb3AsXG5cdFx0b3B0aW1pemVSZWFkYWJpbGl0eUZvcixcblx0XHRzaXplLFxuXHRcdHRydW5jYXRlID0gZmFsc2UsXG5cdFx0dXBwZXJDYXNlID0gZmFsc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQgPSBDT05GSUcuZm9udFdlaWdodCxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ1RleHQnICk7XG5cblx0bGV0IGNvbnRlbnQ6IFJlYWN0LlJlYWN0Tm9kZSA9IGNoaWxkcmVuO1xuXHRjb25zdCBpc0hpZ2hsaWdodGVyID0gQXJyYXkuaXNBcnJheSggaGlnaGxpZ2h0V29yZHMgKTtcblx0Y29uc3QgaXNDYXB0aW9uID0gc2l6ZSA9PT0gJ2NhcHRpb24nO1xuXG5cdGlmICggaXNIaWdobGlnaHRlciApIHtcblx0XHRpZiAoIHR5cGVvZiBjaGlsZHJlbiAhPT0gJ3N0cmluZycgKSB7XG5cdFx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKFxuXHRcdFx0XHQnYGNoaWxkcmVuYCBvZiBgVGV4dGAgbXVzdCBvbmx5IGJlIGBzdHJpbmdgIHR5cGVzIHdoZW4gYGhpZ2hsaWdodFdvcmRzYCBpcyBkZWZpbmVkJ1xuXHRcdFx0KTtcblx0XHR9XG5cblx0XHRjb250ZW50ID0gY3JlYXRlSGlnaGxpZ2h0ZXJUZXh0KCB7XG5cdFx0XHRhdXRvRXNjYXBlOiBoaWdobGlnaHRFc2NhcGUsXG5cdFx0XHRjaGlsZHJlbixcblx0XHRcdGNhc2VTZW5zaXRpdmU6IGhpZ2hsaWdodENhc2VTZW5zaXRpdmUsXG5cdFx0XHRzZWFyY2hXb3JkczogaGlnaGxpZ2h0V29yZHMsXG5cdFx0XHRzYW5pdGl6ZTogaGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0fSApO1xuXHR9XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0Y29uc3Qgc3g6IFJlY29yZDwgc3RyaW5nLCBTZXJpYWxpemVkU3R5bGVzIHwgbnVsbCA+ID0ge307XG5cblx0XHRjb25zdCBsaW5lSGVpZ2h0ID0gZ2V0TGluZUhlaWdodChcblx0XHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdFx0bGluZUhlaWdodFByb3Bcblx0XHQpO1xuXG5cdFx0c3guQmFzZSA9IGNzcygge1xuXHRcdFx0Y29sb3IsXG5cdFx0XHRkaXNwbGF5LFxuXHRcdFx0Zm9udFNpemU6IGdldEZvbnRTaXplKCBzaXplICksXG5cdFx0XHRmb250V2VpZ2h0OiB3ZWlnaHQsXG5cdFx0XHRsaW5lSGVpZ2h0LFxuXHRcdFx0bGV0dGVyU3BhY2luZyxcblx0XHRcdHRleHRBbGlnbjogYWxpZ24sXG5cdFx0fSApO1xuXG5cdFx0c3gudXBwZXJDYXNlID0gY3NzKCB7IHRleHRUcmFuc2Zvcm06ICd1cHBlcmNhc2UnIH0gKTtcblxuXHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBudWxsO1xuXG5cdFx0aWYgKCBvcHRpbWl6ZVJlYWRhYmlsaXR5Rm9yICkge1xuXHRcdFx0Y29uc3QgaXNPcHRpbWFsVGV4dENvbG9yRGFyayA9XG5cdFx0XHRcdGdldE9wdGltYWxUZXh0U2hhZGUoIG9wdGltaXplUmVhZGFiaWxpdHlGb3IgKSA9PT0gJ2RhcmsnO1xuXG5cdFx0XHQvLyBTaG91bGQgbm90IHVzZSB0aGVtZSBjb2xvcnNcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBpc09wdGltYWxUZXh0Q29sb3JEYXJrXG5cdFx0XHRcdD8gY3NzKCB7IGNvbG9yOiBDT0xPUlMuZ3JheVsgOTAwIF0gfSApXG5cdFx0XHRcdDogY3NzKCB7IGNvbG9yOiBDT0xPUlMud2hpdGUgfSApO1xuXHRcdH1cblxuXHRcdHJldHVybiBjeChcblx0XHRcdHN0eWxlcy5UZXh0LFxuXHRcdFx0c3guQmFzZSxcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IsXG5cdFx0XHRpc0Rlc3RydWN0aXZlICYmIHN0eWxlcy5kZXN0cnVjdGl2ZSxcblx0XHRcdCEhIGlzSGlnaGxpZ2h0ZXIgJiYgc3R5bGVzLmhpZ2hsaWdodGVyVGV4dCxcblx0XHRcdGlzQmxvY2sgJiYgc3R5bGVzLmJsb2NrLFxuXHRcdFx0aXNDYXB0aW9uICYmIHN0eWxlcy5tdXRlZCxcblx0XHRcdHZhcmlhbnQgJiYgc3R5bGVzWyB2YXJpYW50IF0sXG5cdFx0XHR1cHBlckNhc2UgJiYgc3gudXBwZXJDYXNlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdGFsaWduLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjb2xvcixcblx0XHRjeCxcblx0XHRkaXNwbGF5LFxuXHRcdGlzQmxvY2ssXG5cdFx0aXNDYXB0aW9uLFxuXHRcdGlzRGVzdHJ1Y3RpdmUsXG5cdFx0aXNIaWdobGlnaHRlcixcblx0XHRsZXR0ZXJTcGFjaW5nLFxuXHRcdGxpbmVIZWlnaHRQcm9wLFxuXHRcdG9wdGltaXplUmVhZGFiaWxpdHlGb3IsXG5cdFx0c2l6ZSxcblx0XHR1cHBlckNhc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQsXG5cdF0gKTtcblxuXHRsZXQgZmluYWxFbGxpcHNpemVNb2RlOiB1bmRlZmluZWQgfCAnYXV0bycgfCAnbm9uZSc7XG5cdGlmICggdHJ1bmNhdGUgPT09IHRydWUgKSB7XG5cdFx0ZmluYWxFbGxpcHNpemVNb2RlID0gJ2F1dG8nO1xuXHR9XG5cdGlmICggdHJ1bmNhdGUgPT09IGZhbHNlICkge1xuXHRcdGZpbmFsRWxsaXBzaXplTW9kZSA9ICdub25lJztcblx0fVxuXG5cdGNvbnN0IGZpbmFsQ29tcG9uZW50UHJvcHMgPSB7XG5cdFx0Li4ub3RoZXJQcm9wcyxcblx0XHRjbGFzc05hbWU6IGNsYXNzZXMsXG5cdFx0Y2hpbGRyZW4sXG5cdFx0ZWxsaXBzaXplTW9kZTogZWxsaXBzaXplTW9kZSB8fCBmaW5hbEVsbGlwc2l6ZU1vZGUsXG5cdH07XG5cblx0Y29uc3QgdHJ1bmNhdGVQcm9wcyA9IHVzZVRydW5jYXRlKCBmaW5hbENvbXBvbmVudFByb3BzICk7XG5cblx0LyoqXG5cdCAqIEVuaGFuY2UgY2hpbGQgYDxMaW5rIC8+YCBjb21wb25lbnRzIHRvIGluaGVyaXQgZm9udCBzaXplLlxuXHQgKi9cblx0aWYgKCAhIHRydW5jYXRlICYmIEFycmF5LmlzQXJyYXkoIGNoaWxkcmVuICkgKSB7XG5cdFx0Y29udGVudCA9IENoaWxkcmVuLm1hcCggY2hpbGRyZW4sICggY2hpbGQgKSA9PiB7XG5cdFx0XHRpZiAoXG5cdFx0XHRcdHR5cGVvZiBjaGlsZCAhPT0gJ29iamVjdCcgfHxcblx0XHRcdFx0Y2hpbGQgPT09IG51bGwgfHxcblx0XHRcdFx0ISAoICdwcm9wcycgaW4gY2hpbGQgKVxuXHRcdFx0KSB7XG5cdFx0XHRcdHJldHVybiBjaGlsZDtcblx0XHRcdH1cblxuXHRcdFx0Y29uc3QgaXNMaW5rID0gaGFzQ29ubmVjdE5hbWVzcGFjZSggY2hpbGQsIFsgJ0xpbmsnIF0gKTtcblx0XHRcdGlmICggaXNMaW5rICkge1xuXHRcdFx0XHRyZXR1cm4gY2xvbmVFbGVtZW50KCBjaGlsZCwge1xuXHRcdFx0XHRcdHNpemU6IGNoaWxkLnByb3BzLnNpemUgfHwgJ2luaGVyaXQnLFxuXHRcdFx0XHR9ICk7XG5cdFx0XHR9XG5cblx0XHRcdHJldHVybiBjaGlsZDtcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4ge1xuXHRcdC4uLnRydW5jYXRlUHJvcHMsXG5cdFx0Y2hpbGRyZW46IHRydW5jYXRlID8gdHJ1bmNhdGVQcm9wcy5jaGlsZHJlbiA6IGNvbnRlbnQsXG5cdH07XG59XG4iXX0= */"); 25181 sx.upperCase = _ref; 25182 sx.optimalTextColor = null; 25183 if (optimizeReadabilityFor) { 25184 const isOptimalTextColorDark = getOptimalTextShade(optimizeReadabilityFor) === "dark"; 25185 sx.optimalTextColor = isOptimalTextColorDark ? /* @__PURE__ */ css({ 25186 color: COLORS.gray[900] 25187 }, false ? "" : ";label:sx-optimalTextColor;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEdNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vLCBDaGlsZHJlbiwgY2xvbmVFbGVtZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgaGFzQ29ubmVjdE5hbWVzcGFjZSwgdXNlQ29udGV4dFN5c3RlbSB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgdXNlVHJ1bmNhdGUgfSBmcm9tICcuLi90cnVuY2F0ZSc7XG5pbXBvcnQgeyBnZXRPcHRpbWFsVGV4dFNoYWRlIH0gZnJvbSAnLi4vdXRpbHMvY29sb3JzJztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBjcmVhdGVIaWdobGlnaHRlclRleHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IGdldEZvbnRTaXplIH0gZnJvbSAnLi4vdXRpbHMvZm9udC1zaXplJztcbmltcG9ydCB7IENPTkZJRywgQ09MT1JTIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgZ2V0TGluZUhlaWdodCB9IGZyb20gJy4vZ2V0LWxpbmUtaGVpZ2h0JztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB0eXBlIHsgUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB0eXBlIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuLyoqXG4gKiBAcGFyYW0ge2ltcG9ydCgnLi4vY29udGV4dCcpLldvcmRQcmVzc0NvbXBvbmVudFByb3BzPGltcG9ydCgnLi90eXBlcycpLlByb3BzLCAnc3Bhbic+fSBwcm9wc1xuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VUZXh0KFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IFByb3BzLCAnc3BhbicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhZGp1c3RMaW5lSGVpZ2h0Rm9ySW5uZXJDb250cm9scyxcblx0XHRhbGlnbixcblx0XHRjaGlsZHJlbixcblx0XHRjbGFzc05hbWUsXG5cdFx0Y29sb3IsXG5cdFx0ZWxsaXBzaXplTW9kZSxcblx0XHRpc0Rlc3RydWN0aXZlID0gZmFsc2UsXG5cdFx0ZGlzcGxheSxcblx0XHRoaWdobGlnaHRFc2NhcGUgPSBmYWxzZSxcblx0XHRoaWdobGlnaHRDYXNlU2Vuc2l0aXZlID0gZmFsc2UsXG5cdFx0aGlnaGxpZ2h0V29yZHMsXG5cdFx0aGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0aXNCbG9jayA9IGZhbHNlLFxuXHRcdGxldHRlclNwYWNpbmcsXG5cdFx0bGluZUhlaWdodDogbGluZUhlaWdodFByb3AsXG5cdFx0b3B0aW1pemVSZWFkYWJpbGl0eUZvcixcblx0XHRzaXplLFxuXHRcdHRydW5jYXRlID0gZmFsc2UsXG5cdFx0dXBwZXJDYXNlID0gZmFsc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQgPSBDT05GSUcuZm9udFdlaWdodCxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ1RleHQnICk7XG5cblx0bGV0IGNvbnRlbnQ6IFJlYWN0LlJlYWN0Tm9kZSA9IGNoaWxkcmVuO1xuXHRjb25zdCBpc0hpZ2hsaWdodGVyID0gQXJyYXkuaXNBcnJheSggaGlnaGxpZ2h0V29yZHMgKTtcblx0Y29uc3QgaXNDYXB0aW9uID0gc2l6ZSA9PT0gJ2NhcHRpb24nO1xuXG5cdGlmICggaXNIaWdobGlnaHRlciApIHtcblx0XHRpZiAoIHR5cGVvZiBjaGlsZHJlbiAhPT0gJ3N0cmluZycgKSB7XG5cdFx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKFxuXHRcdFx0XHQnYGNoaWxkcmVuYCBvZiBgVGV4dGAgbXVzdCBvbmx5IGJlIGBzdHJpbmdgIHR5cGVzIHdoZW4gYGhpZ2hsaWdodFdvcmRzYCBpcyBkZWZpbmVkJ1xuXHRcdFx0KTtcblx0XHR9XG5cblx0XHRjb250ZW50ID0gY3JlYXRlSGlnaGxpZ2h0ZXJUZXh0KCB7XG5cdFx0XHRhdXRvRXNjYXBlOiBoaWdobGlnaHRFc2NhcGUsXG5cdFx0XHRjaGlsZHJlbixcblx0XHRcdGNhc2VTZW5zaXRpdmU6IGhpZ2hsaWdodENhc2VTZW5zaXRpdmUsXG5cdFx0XHRzZWFyY2hXb3JkczogaGlnaGxpZ2h0V29yZHMsXG5cdFx0XHRzYW5pdGl6ZTogaGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0fSApO1xuXHR9XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0Y29uc3Qgc3g6IFJlY29yZDwgc3RyaW5nLCBTZXJpYWxpemVkU3R5bGVzIHwgbnVsbCA+ID0ge307XG5cblx0XHRjb25zdCBsaW5lSGVpZ2h0ID0gZ2V0TGluZUhlaWdodChcblx0XHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdFx0bGluZUhlaWdodFByb3Bcblx0XHQpO1xuXG5cdFx0c3guQmFzZSA9IGNzcygge1xuXHRcdFx0Y29sb3IsXG5cdFx0XHRkaXNwbGF5LFxuXHRcdFx0Zm9udFNpemU6IGdldEZvbnRTaXplKCBzaXplICksXG5cdFx0XHRmb250V2VpZ2h0OiB3ZWlnaHQsXG5cdFx0XHRsaW5lSGVpZ2h0LFxuXHRcdFx0bGV0dGVyU3BhY2luZyxcblx0XHRcdHRleHRBbGlnbjogYWxpZ24sXG5cdFx0fSApO1xuXG5cdFx0c3gudXBwZXJDYXNlID0gY3NzKCB7IHRleHRUcmFuc2Zvcm06ICd1cHBlcmNhc2UnIH0gKTtcblxuXHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBudWxsO1xuXG5cdFx0aWYgKCBvcHRpbWl6ZVJlYWRhYmlsaXR5Rm9yICkge1xuXHRcdFx0Y29uc3QgaXNPcHRpbWFsVGV4dENvbG9yRGFyayA9XG5cdFx0XHRcdGdldE9wdGltYWxUZXh0U2hhZGUoIG9wdGltaXplUmVhZGFiaWxpdHlGb3IgKSA9PT0gJ2RhcmsnO1xuXG5cdFx0XHQvLyBTaG91bGQgbm90IHVzZSB0aGVtZSBjb2xvcnNcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBpc09wdGltYWxUZXh0Q29sb3JEYXJrXG5cdFx0XHRcdD8gY3NzKCB7IGNvbG9yOiBDT0xPUlMuZ3JheVsgOTAwIF0gfSApXG5cdFx0XHRcdDogY3NzKCB7IGNvbG9yOiBDT0xPUlMud2hpdGUgfSApO1xuXHRcdH1cblxuXHRcdHJldHVybiBjeChcblx0XHRcdHN0eWxlcy5UZXh0LFxuXHRcdFx0c3guQmFzZSxcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IsXG5cdFx0XHRpc0Rlc3RydWN0aXZlICYmIHN0eWxlcy5kZXN0cnVjdGl2ZSxcblx0XHRcdCEhIGlzSGlnaGxpZ2h0ZXIgJiYgc3R5bGVzLmhpZ2hsaWdodGVyVGV4dCxcblx0XHRcdGlzQmxvY2sgJiYgc3R5bGVzLmJsb2NrLFxuXHRcdFx0aXNDYXB0aW9uICYmIHN0eWxlcy5tdXRlZCxcblx0XHRcdHZhcmlhbnQgJiYgc3R5bGVzWyB2YXJpYW50IF0sXG5cdFx0XHR1cHBlckNhc2UgJiYgc3gudXBwZXJDYXNlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdGFsaWduLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjb2xvcixcblx0XHRjeCxcblx0XHRkaXNwbGF5LFxuXHRcdGlzQmxvY2ssXG5cdFx0aXNDYXB0aW9uLFxuXHRcdGlzRGVzdHJ1Y3RpdmUsXG5cdFx0aXNIaWdobGlnaHRlcixcblx0XHRsZXR0ZXJTcGFjaW5nLFxuXHRcdGxpbmVIZWlnaHRQcm9wLFxuXHRcdG9wdGltaXplUmVhZGFiaWxpdHlGb3IsXG5cdFx0c2l6ZSxcblx0XHR1cHBlckNhc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQsXG5cdF0gKTtcblxuXHRsZXQgZmluYWxFbGxpcHNpemVNb2RlOiB1bmRlZmluZWQgfCAnYXV0bycgfCAnbm9uZSc7XG5cdGlmICggdHJ1bmNhdGUgPT09IHRydWUgKSB7XG5cdFx0ZmluYWxFbGxpcHNpemVNb2RlID0gJ2F1dG8nO1xuXHR9XG5cdGlmICggdHJ1bmNhdGUgPT09IGZhbHNlICkge1xuXHRcdGZpbmFsRWxsaXBzaXplTW9kZSA9ICdub25lJztcblx0fVxuXG5cdGNvbnN0IGZpbmFsQ29tcG9uZW50UHJvcHMgPSB7XG5cdFx0Li4ub3RoZXJQcm9wcyxcblx0XHRjbGFzc05hbWU6IGNsYXNzZXMsXG5cdFx0Y2hpbGRyZW4sXG5cdFx0ZWxsaXBzaXplTW9kZTogZWxsaXBzaXplTW9kZSB8fCBmaW5hbEVsbGlwc2l6ZU1vZGUsXG5cdH07XG5cblx0Y29uc3QgdHJ1bmNhdGVQcm9wcyA9IHVzZVRydW5jYXRlKCBmaW5hbENvbXBvbmVudFByb3BzICk7XG5cblx0LyoqXG5cdCAqIEVuaGFuY2UgY2hpbGQgYDxMaW5rIC8+YCBjb21wb25lbnRzIHRvIGluaGVyaXQgZm9udCBzaXplLlxuXHQgKi9cblx0aWYgKCAhIHRydW5jYXRlICYmIEFycmF5LmlzQXJyYXkoIGNoaWxkcmVuICkgKSB7XG5cdFx0Y29udGVudCA9IENoaWxkcmVuLm1hcCggY2hpbGRyZW4sICggY2hpbGQgKSA9PiB7XG5cdFx0XHRpZiAoXG5cdFx0XHRcdHR5cGVvZiBjaGlsZCAhPT0gJ29iamVjdCcgfHxcblx0XHRcdFx0Y2hpbGQgPT09IG51bGwgfHxcblx0XHRcdFx0ISAoICdwcm9wcycgaW4gY2hpbGQgKVxuXHRcdFx0KSB7XG5cdFx0XHRcdHJldHVybiBjaGlsZDtcblx0XHRcdH1cblxuXHRcdFx0Y29uc3QgaXNMaW5rID0gaGFzQ29ubmVjdE5hbWVzcGFjZSggY2hpbGQsIFsgJ0xpbmsnIF0gKTtcblx0XHRcdGlmICggaXNMaW5rICkge1xuXHRcdFx0XHRyZXR1cm4gY2xvbmVFbGVtZW50KCBjaGlsZCwge1xuXHRcdFx0XHRcdHNpemU6IGNoaWxkLnByb3BzLnNpemUgfHwgJ2luaGVyaXQnLFxuXHRcdFx0XHR9ICk7XG5cdFx0XHR9XG5cblx0XHRcdHJldHVybiBjaGlsZDtcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4ge1xuXHRcdC4uLnRydW5jYXRlUHJvcHMsXG5cdFx0Y2hpbGRyZW46IHRydW5jYXRlID8gdHJ1bmNhdGVQcm9wcy5jaGlsZHJlbiA6IGNvbnRlbnQsXG5cdH07XG59XG4iXX0= */") : /* @__PURE__ */ css({ 25188 color: COLORS.white 25189 }, false ? "" : ";label:sx-optimalTextColor;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkdNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vLCBDaGlsZHJlbiwgY2xvbmVFbGVtZW50IH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgaGFzQ29ubmVjdE5hbWVzcGFjZSwgdXNlQ29udGV4dFN5c3RlbSB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgdXNlVHJ1bmNhdGUgfSBmcm9tICcuLi90cnVuY2F0ZSc7XG5pbXBvcnQgeyBnZXRPcHRpbWFsVGV4dFNoYWRlIH0gZnJvbSAnLi4vdXRpbHMvY29sb3JzJztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBjcmVhdGVIaWdobGlnaHRlclRleHQgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IGdldEZvbnRTaXplIH0gZnJvbSAnLi4vdXRpbHMvZm9udC1zaXplJztcbmltcG9ydCB7IENPTkZJRywgQ09MT1JTIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgZ2V0TGluZUhlaWdodCB9IGZyb20gJy4vZ2V0LWxpbmUtaGVpZ2h0JztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB0eXBlIHsgUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB0eXBlIFJlYWN0IGZyb20gJ3JlYWN0JztcblxuLyoqXG4gKiBAcGFyYW0ge2ltcG9ydCgnLi4vY29udGV4dCcpLldvcmRQcmVzc0NvbXBvbmVudFByb3BzPGltcG9ydCgnLi90eXBlcycpLlByb3BzLCAnc3Bhbic+fSBwcm9wc1xuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VUZXh0KFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IFByb3BzLCAnc3BhbicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhZGp1c3RMaW5lSGVpZ2h0Rm9ySW5uZXJDb250cm9scyxcblx0XHRhbGlnbixcblx0XHRjaGlsZHJlbixcblx0XHRjbGFzc05hbWUsXG5cdFx0Y29sb3IsXG5cdFx0ZWxsaXBzaXplTW9kZSxcblx0XHRpc0Rlc3RydWN0aXZlID0gZmFsc2UsXG5cdFx0ZGlzcGxheSxcblx0XHRoaWdobGlnaHRFc2NhcGUgPSBmYWxzZSxcblx0XHRoaWdobGlnaHRDYXNlU2Vuc2l0aXZlID0gZmFsc2UsXG5cdFx0aGlnaGxpZ2h0V29yZHMsXG5cdFx0aGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0aXNCbG9jayA9IGZhbHNlLFxuXHRcdGxldHRlclNwYWNpbmcsXG5cdFx0bGluZUhlaWdodDogbGluZUhlaWdodFByb3AsXG5cdFx0b3B0aW1pemVSZWFkYWJpbGl0eUZvcixcblx0XHRzaXplLFxuXHRcdHRydW5jYXRlID0gZmFsc2UsXG5cdFx0dXBwZXJDYXNlID0gZmFsc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQgPSBDT05GSUcuZm9udFdlaWdodCxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ1RleHQnICk7XG5cblx0bGV0IGNvbnRlbnQ6IFJlYWN0LlJlYWN0Tm9kZSA9IGNoaWxkcmVuO1xuXHRjb25zdCBpc0hpZ2hsaWdodGVyID0gQXJyYXkuaXNBcnJheSggaGlnaGxpZ2h0V29yZHMgKTtcblx0Y29uc3QgaXNDYXB0aW9uID0gc2l6ZSA9PT0gJ2NhcHRpb24nO1xuXG5cdGlmICggaXNIaWdobGlnaHRlciApIHtcblx0XHRpZiAoIHR5cGVvZiBjaGlsZHJlbiAhPT0gJ3N0cmluZycgKSB7XG5cdFx0XHR0aHJvdyBuZXcgVHlwZUVycm9yKFxuXHRcdFx0XHQnYGNoaWxkcmVuYCBvZiBgVGV4dGAgbXVzdCBvbmx5IGJlIGBzdHJpbmdgIHR5cGVzIHdoZW4gYGhpZ2hsaWdodFdvcmRzYCBpcyBkZWZpbmVkJ1xuXHRcdFx0KTtcblx0XHR9XG5cblx0XHRjb250ZW50ID0gY3JlYXRlSGlnaGxpZ2h0ZXJUZXh0KCB7XG5cdFx0XHRhdXRvRXNjYXBlOiBoaWdobGlnaHRFc2NhcGUsXG5cdFx0XHRjaGlsZHJlbixcblx0XHRcdGNhc2VTZW5zaXRpdmU6IGhpZ2hsaWdodENhc2VTZW5zaXRpdmUsXG5cdFx0XHRzZWFyY2hXb3JkczogaGlnaGxpZ2h0V29yZHMsXG5cdFx0XHRzYW5pdGl6ZTogaGlnaGxpZ2h0U2FuaXRpemUsXG5cdFx0fSApO1xuXHR9XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0Y29uc3Qgc3g6IFJlY29yZDwgc3RyaW5nLCBTZXJpYWxpemVkU3R5bGVzIHwgbnVsbCA+ID0ge307XG5cblx0XHRjb25zdCBsaW5lSGVpZ2h0ID0gZ2V0TGluZUhlaWdodChcblx0XHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdFx0bGluZUhlaWdodFByb3Bcblx0XHQpO1xuXG5cdFx0c3guQmFzZSA9IGNzcygge1xuXHRcdFx0Y29sb3IsXG5cdFx0XHRkaXNwbGF5LFxuXHRcdFx0Zm9udFNpemU6IGdldEZvbnRTaXplKCBzaXplICksXG5cdFx0XHRmb250V2VpZ2h0OiB3ZWlnaHQsXG5cdFx0XHRsaW5lSGVpZ2h0LFxuXHRcdFx0bGV0dGVyU3BhY2luZyxcblx0XHRcdHRleHRBbGlnbjogYWxpZ24sXG5cdFx0fSApO1xuXG5cdFx0c3gudXBwZXJDYXNlID0gY3NzKCB7IHRleHRUcmFuc2Zvcm06ICd1cHBlcmNhc2UnIH0gKTtcblxuXHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBudWxsO1xuXG5cdFx0aWYgKCBvcHRpbWl6ZVJlYWRhYmlsaXR5Rm9yICkge1xuXHRcdFx0Y29uc3QgaXNPcHRpbWFsVGV4dENvbG9yRGFyayA9XG5cdFx0XHRcdGdldE9wdGltYWxUZXh0U2hhZGUoIG9wdGltaXplUmVhZGFiaWxpdHlGb3IgKSA9PT0gJ2RhcmsnO1xuXG5cdFx0XHQvLyBTaG91bGQgbm90IHVzZSB0aGVtZSBjb2xvcnNcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IgPSBpc09wdGltYWxUZXh0Q29sb3JEYXJrXG5cdFx0XHRcdD8gY3NzKCB7IGNvbG9yOiBDT0xPUlMuZ3JheVsgOTAwIF0gfSApXG5cdFx0XHRcdDogY3NzKCB7IGNvbG9yOiBDT0xPUlMud2hpdGUgfSApO1xuXHRcdH1cblxuXHRcdHJldHVybiBjeChcblx0XHRcdHN0eWxlcy5UZXh0LFxuXHRcdFx0c3guQmFzZSxcblx0XHRcdHN4Lm9wdGltYWxUZXh0Q29sb3IsXG5cdFx0XHRpc0Rlc3RydWN0aXZlICYmIHN0eWxlcy5kZXN0cnVjdGl2ZSxcblx0XHRcdCEhIGlzSGlnaGxpZ2h0ZXIgJiYgc3R5bGVzLmhpZ2hsaWdodGVyVGV4dCxcblx0XHRcdGlzQmxvY2sgJiYgc3R5bGVzLmJsb2NrLFxuXHRcdFx0aXNDYXB0aW9uICYmIHN0eWxlcy5tdXRlZCxcblx0XHRcdHZhcmlhbnQgJiYgc3R5bGVzWyB2YXJpYW50IF0sXG5cdFx0XHR1cHBlckNhc2UgJiYgc3gudXBwZXJDYXNlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFkanVzdExpbmVIZWlnaHRGb3JJbm5lckNvbnRyb2xzLFxuXHRcdGFsaWduLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjb2xvcixcblx0XHRjeCxcblx0XHRkaXNwbGF5LFxuXHRcdGlzQmxvY2ssXG5cdFx0aXNDYXB0aW9uLFxuXHRcdGlzRGVzdHJ1Y3RpdmUsXG5cdFx0aXNIaWdobGlnaHRlcixcblx0XHRsZXR0ZXJTcGFjaW5nLFxuXHRcdGxpbmVIZWlnaHRQcm9wLFxuXHRcdG9wdGltaXplUmVhZGFiaWxpdHlGb3IsXG5cdFx0c2l6ZSxcblx0XHR1cHBlckNhc2UsXG5cdFx0dmFyaWFudCxcblx0XHR3ZWlnaHQsXG5cdF0gKTtcblxuXHRsZXQgZmluYWxFbGxpcHNpemVNb2RlOiB1bmRlZmluZWQgfCAnYXV0bycgfCAnbm9uZSc7XG5cdGlmICggdHJ1bmNhdGUgPT09IHRydWUgKSB7XG5cdFx0ZmluYWxFbGxpcHNpemVNb2RlID0gJ2F1dG8nO1xuXHR9XG5cdGlmICggdHJ1bmNhdGUgPT09IGZhbHNlICkge1xuXHRcdGZpbmFsRWxsaXBzaXplTW9kZSA9ICdub25lJztcblx0fVxuXG5cdGNvbnN0IGZpbmFsQ29tcG9uZW50UHJvcHMgPSB7XG5cdFx0Li4ub3RoZXJQcm9wcyxcblx0XHRjbGFzc05hbWU6IGNsYXNzZXMsXG5cdFx0Y2hpbGRyZW4sXG5cdFx0ZWxsaXBzaXplTW9kZTogZWxsaXBzaXplTW9kZSB8fCBmaW5hbEVsbGlwc2l6ZU1vZGUsXG5cdH07XG5cblx0Y29uc3QgdHJ1bmNhdGVQcm9wcyA9IHVzZVRydW5jYXRlKCBmaW5hbENvbXBvbmVudFByb3BzICk7XG5cblx0LyoqXG5cdCAqIEVuaGFuY2UgY2hpbGQgYDxMaW5rIC8+YCBjb21wb25lbnRzIHRvIGluaGVyaXQgZm9udCBzaXplLlxuXHQgKi9cblx0aWYgKCAhIHRydW5jYXRlICYmIEFycmF5LmlzQXJyYXkoIGNoaWxkcmVuICkgKSB7XG5cdFx0Y29udGVudCA9IENoaWxkcmVuLm1hcCggY2hpbGRyZW4sICggY2hpbGQgKSA9PiB7XG5cdFx0XHRpZiAoXG5cdFx0XHRcdHR5cGVvZiBjaGlsZCAhPT0gJ29iamVjdCcgfHxcblx0XHRcdFx0Y2hpbGQgPT09IG51bGwgfHxcblx0XHRcdFx0ISAoICdwcm9wcycgaW4gY2hpbGQgKVxuXHRcdFx0KSB7XG5cdFx0XHRcdHJldHVybiBjaGlsZDtcblx0XHRcdH1cblxuXHRcdFx0Y29uc3QgaXNMaW5rID0gaGFzQ29ubmVjdE5hbWVzcGFjZSggY2hpbGQsIFsgJ0xpbmsnIF0gKTtcblx0XHRcdGlmICggaXNMaW5rICkge1xuXHRcdFx0XHRyZXR1cm4gY2xvbmVFbGVtZW50KCBjaGlsZCwge1xuXHRcdFx0XHRcdHNpemU6IGNoaWxkLnByb3BzLnNpemUgfHwgJ2luaGVyaXQnLFxuXHRcdFx0XHR9ICk7XG5cdFx0XHR9XG5cblx0XHRcdHJldHVybiBjaGlsZDtcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4ge1xuXHRcdC4uLnRydW5jYXRlUHJvcHMsXG5cdFx0Y2hpbGRyZW46IHRydW5jYXRlID8gdHJ1bmNhdGVQcm9wcy5jaGlsZHJlbiA6IGNvbnRlbnQsXG5cdH07XG59XG4iXX0= */"); 25190 } 25191 return cx3(Text, sx.Base, sx.optimalTextColor, isDestructive && destructive, !!isHighlighter && highlighterText, isBlock && block2, isCaption && muted, variant && styles_exports3[variant], upperCase2 && sx.upperCase, className2); 25192 }, [adjustLineHeightForInnerControls, align, className2, color2, cx3, display, isBlock, isCaption, isDestructive, isHighlighter, letterSpacing, lineHeightProp, optimizeReadabilityFor, size3, upperCase2, variant, weight]); 25193 let finalEllipsizeMode; 25194 if (truncate === true) { 25195 finalEllipsizeMode = "auto"; 25196 } 25197 if (truncate === false) { 25198 finalEllipsizeMode = "none"; 25199 } 25200 const finalComponentProps = { 25201 ...otherProps, 25202 className: classes, 25203 children, 25204 ellipsizeMode: ellipsizeMode || finalEllipsizeMode 25205 }; 25206 const truncateProps = useTruncate(finalComponentProps); 25207 if (!truncate && Array.isArray(children)) { 25208 content = import_element24.Children.map(children, (child) => { 25209 if (typeof child !== "object" || child === null || !("props" in child)) { 25210 return child; 25211 } 25212 const isLink = hasConnectNamespace(child, ["Link"]); 25213 if (isLink) { 25214 return (0, import_element24.cloneElement)(child, { 25215 size: child.props.size || "inherit" 25216 }); 25217 } 25218 return child; 25219 }); 25220 } 25221 return { 25222 ...truncateProps, 25223 children: truncate ? truncateProps.children : content 25224 }; 25225 } 25226 25227 // packages/components/build-module/text/component.js 25228 var import_jsx_runtime85 = __toESM(require_jsx_runtime()); 25229 function UnconnectedText(props, forwardedRef) { 25230 const textProps = useText(props); 25231 return /* @__PURE__ */ (0, import_jsx_runtime85.jsx)(component_default, { 25232 as: "span", 25233 ...textProps, 25234 ref: forwardedRef 25235 }); 25236 } 25237 var Text2 = contextConnect(UnconnectedText, "Text"); 25238 var component_default8 = Text2; 25239 25240 // packages/components/build-module/input-control/styles/input-control-styles.js 25241 var import_jsx_runtime86 = __toESM(require_jsx_runtime()); 25242 function _EMOTION_STRINGIFIED_CSS_ERROR__6() { 25243 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 25244 } 25245 var Prefix = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 25246 target: "em5sgkm8" 25247 } : { 25248 target: "em5sgkm8", 25249 label: "Prefix" 25250 })(false ? { 25251 name: "pvvbxf", 25252 styles: "box-sizing:border-box;display:block" 25253 } : { 25254 name: "pvvbxf", 25255 styles: "box-sizing:border-box;display:block", 25256 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAwBiC","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */", 25257 toString: _EMOTION_STRINGIFIED_CSS_ERROR__6 25258 }); 25259 var Suffix = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 25260 target: "em5sgkm7" 25261 } : { 25262 target: "em5sgkm7", 25263 label: "Suffix" 25264 })(false ? { 25265 name: "jgf79h", 25266 styles: "align-items:center;align-self:stretch;box-sizing:border-box;display:flex" 25267 } : { 25268 name: "jgf79h", 25269 styles: "align-items:center;align-self:stretch;box-sizing:border-box;display:flex", 25270 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA6BiC","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */", 25271 toString: _EMOTION_STRINGIFIED_CSS_ERROR__6 25272 }); 25273 var backdropBorderColor = ({ 25274 disabled, 25275 isBorderless 25276 }) => { 25277 if (isBorderless) { 25278 return "transparent"; 25279 } 25280 if (disabled) { 25281 return COLORS.ui.borderDisabled; 25282 } 25283 return COLORS.ui.border; 25284 }; 25285 var BackdropUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 25286 target: "em5sgkm6" 25287 } : { 25288 target: "em5sgkm6", 25289 label: "BackdropUI" 25290 })("&&&{box-sizing:border-box;border-color:", backdropBorderColor, ";border-radius:inherit;border-style:solid;border-width:1px;bottom:0;left:0;margin:0;padding:0;pointer-events:none;position:absolute;right:0;top:0;", rtl({ 25291 paddingLeft: 2 25292 }), ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAwDqD","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25293 var Root = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default3, false ? { 25294 target: "em5sgkm5" 25295 } : { 25296 target: "em5sgkm5", 25297 label: "Root" 25298 })("box-sizing:border-box;position:relative;border-radius:", config_values_default.radiusSmall, ";padding-top:0;&:focus-within:not( :has( :is( ", Prefix, ", ", Suffix, " ):focus-within ) ){", BackdropUI, "{border-color:", COLORS.ui.borderFocus, ";box-shadow:", config_values_default.controlBoxShadowFocus, ";outline:2px solid transparent;outline-offset:-2px;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA4EkC","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25299 var containerDisabledStyles = ({ 25300 disabled 25301 }) => { 25302 const backgroundColor = disabled ? COLORS.ui.backgroundDisabled : COLORS.ui.background; 25303 return /* @__PURE__ */ css({ 25304 backgroundColor 25305 }, false ? "" : ";label:containerDisabledStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAmGQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25306 }; 25307 var _ref2 = false ? { 25308 name: "1d3w5wq", 25309 styles: "width:100%" 25310 } : { 25311 name: "uo2pd2-containerWidthStyles", 25312 styles: "width:100%;label:containerWidthStyles;", 25313 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2GS","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */", 25314 toString: _EMOTION_STRINGIFIED_CSS_ERROR__6 25315 }; 25316 var containerWidthStyles = ({ 25317 __unstableInputWidth, 25318 labelPosition 25319 }) => { 25320 if (!__unstableInputWidth) { 25321 return _ref2; 25322 } 25323 if (labelPosition === "side") { 25324 return ""; 25325 } 25326 if (labelPosition === "edge") { 25327 return /* @__PURE__ */ css({ 25328 flex: `0 0 $__unstableInputWidth}` 25329 }, false ? "" : ";label:containerWidthStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAmHS","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25330 } 25331 return /* @__PURE__ */ css({ 25332 width: __unstableInputWidth 25333 }, false ? "" : ";label:containerWidthStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAwHQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25334 }; 25335 var Container = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 25336 target: "em5sgkm4" 25337 } : { 25338 target: "em5sgkm4", 25339 label: "Container" 25340 })("align-items:center;box-sizing:border-box;border-radius:inherit;display:flex;flex:1;position:relative;", containerDisabledStyles, " ", containerWidthStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2HqD","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25341 var disabledStyles = ({ 25342 disabled 25343 }) => { 25344 if (!disabled) { 25345 return ""; 25346 } 25347 return /* @__PURE__ */ css({ 25348 color: COLORS.ui.textDisabled 25349 }, false ? "" : ";label:disabledStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAsJQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25350 }; 25351 var fontSizeStyles = ({ 25352 inputSize: size3 25353 }) => { 25354 const sizes = { 25355 default: "13px", 25356 small: "11px", 25357 compact: "13px", 25358 "__unstable-large": "13px" 25359 }; 25360 const fontSize = sizes[size3] || sizes.default; 25361 const fontSizeMobile = "16px"; 25362 if (!fontSize) { 25363 return ""; 25364 } 25365 return /* @__PURE__ */ css("font-size:", fontSizeMobile, ";@media ( min-width: 600px ){font-size:", fontSize, ";}" + (false ? "" : ";label:fontSizeStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA0KW","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25366 }; 25367 var getSizeConfig = ({ 25368 inputSize: size3, 25369 __next40pxDefaultSize 25370 }) => { 25371 const sizes = { 25372 default: { 25373 height: 40, 25374 lineHeight: 1, 25375 minHeight: 40, 25376 paddingLeft: config_values_default.controlPaddingX, 25377 paddingRight: config_values_default.controlPaddingX 25378 }, 25379 small: { 25380 height: 24, 25381 lineHeight: 1, 25382 minHeight: 24, 25383 paddingLeft: config_values_default.controlPaddingXSmall, 25384 paddingRight: config_values_default.controlPaddingXSmall 25385 }, 25386 compact: { 25387 height: 32, 25388 lineHeight: 1, 25389 minHeight: 32, 25390 paddingLeft: config_values_default.controlPaddingXSmall, 25391 paddingRight: config_values_default.controlPaddingXSmall 25392 }, 25393 "__unstable-large": { 25394 height: 40, 25395 lineHeight: 1, 25396 minHeight: 40, 25397 paddingLeft: config_values_default.controlPaddingX, 25398 paddingRight: config_values_default.controlPaddingX 25399 } 25400 }; 25401 if (!__next40pxDefaultSize) { 25402 sizes.default = sizes.compact; 25403 } 25404 return sizes[size3] || sizes.default; 25405 }; 25406 var sizeStyles = (props) => { 25407 return /* @__PURE__ */ css(getSizeConfig(props), false ? "" : ";label:sizeStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA+NQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25408 }; 25409 var customPaddings = ({ 25410 paddingInlineStart, 25411 paddingInlineEnd 25412 }) => { 25413 return /* @__PURE__ */ css({ 25414 paddingInlineStart, 25415 paddingInlineEnd 25416 }, false ? "" : ";label:customPaddings;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAsOQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25417 }; 25418 var dragStyles = ({ 25419 isDragging: isDragging2, 25420 dragCursor 25421 }) => { 25422 let defaultArrowStyles; 25423 let activeDragCursorStyles; 25424 if (isDragging2) { 25425 defaultArrowStyles = /* @__PURE__ */ css("cursor:", dragCursor, ";user-select:none;&::-webkit-outer-spin-button,&::-webkit-inner-spin-button{-webkit-appearance:none!important;margin:0!important;}" + (false ? "" : ";label:defaultArrowStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA8O0B","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25426 } 25427 if (isDragging2 && dragCursor) { 25428 activeDragCursorStyles = /* @__PURE__ */ css("&:active{cursor:", dragCursor, ";}" + (false ? "" : ";label:activeDragCursorStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2P8B","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25429 } 25430 return /* @__PURE__ */ css(defaultArrowStyles, " ", activeDragCursorStyles, ";" + (false ? "" : ";label:dragStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAkQW","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25431 }; 25432 var Input = /* @__PURE__ */ emotion_styled_base_browser_esm_default("input", false ? { 25433 target: "em5sgkm3" 25434 } : { 25435 target: "em5sgkm3", 25436 label: "Input" 25437 })("&&&{background-color:transparent;box-sizing:border-box;border:none;box-shadow:none!important;color:", COLORS.theme.foreground, ";display:block;font-family:inherit;margin:0;outline:none;width:100%;", dragStyles, " ", disabledStyles, " ", fontSizeStyles, " ", sizeStyles, " ", customPaddings, " &::-webkit-input-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}&::-moz-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}&:-ms-input-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}&[type='email'],&[type='url']{direction:ltr;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2Q+C","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25438 var BaseLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default8, false ? { 25439 target: "em5sgkm2" 25440 } : { 25441 target: "em5sgkm2", 25442 label: "BaseLabel" 25443 })("&&&{", baseLabelTypography, ";box-sizing:border-box;display:block;padding-top:0;padding-bottom:0;max-width:100%;z-index:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAkTqE","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25444 var Label = (props) => /* @__PURE__ */ (0, import_jsx_runtime86.jsx)(BaseLabel, { 25445 ...props, 25446 as: "label" 25447 }); 25448 var LabelWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default4, false ? { 25449 target: "em5sgkm1" 25450 } : { 25451 target: "em5sgkm1", 25452 label: "LabelWrapper" 25453 })(false ? { 25454 name: "1b6uupn", 25455 styles: "max-width:calc( 100% - 10px )" 25456 } : { 25457 name: "1b6uupn", 25458 styles: "max-width:calc( 100% - 10px )", 25459 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2U8C","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */", 25460 toString: _EMOTION_STRINGIFIED_CSS_ERROR__6 25461 }); 25462 var prefixSuffixWrapperStyles = ({ 25463 variant = "default", 25464 size: size3, 25465 __next40pxDefaultSize, 25466 isPrefix 25467 }) => { 25468 const { 25469 paddingLeft: padding2 25470 } = getSizeConfig({ 25471 inputSize: size3, 25472 __next40pxDefaultSize 25473 }); 25474 const paddingProperty = isPrefix ? "paddingInlineStart" : "paddingInlineEnd"; 25475 if (variant === "default") { 25476 return /* @__PURE__ */ css({ 25477 [paddingProperty]: padding2 25478 }, false ? "" : ";label:prefixSuffixWrapperStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA+VS","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25479 } 25480 return /* @__PURE__ */ css({ 25481 display: "flex", 25482 [paddingProperty]: padding2 - 4 25483 }, false ? "" : ";label:prefixSuffixWrapperStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AAqWQ","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */"); 25484 }; 25485 var PrefixSuffixWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 25486 target: "em5sgkm0" 25487 } : { 25488 target: "em5sgkm0", 25489 label: "PrefixSuffixWrapper" 25490 })(prefixSuffixWrapperStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["input-control-styles.tsx"],"names":[],"mappings":"AA2W6C","file":"input-control-styles.tsx","sourcesContent":["/**\n * External dependencies\n */\nimport type { SerializedStyles } from '@emotion/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { CSSProperties, ReactNode } from 'react';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../../context';\nimport { Flex, FlexItem } from '../../flex';\nimport { Text } from '../../text';\nimport { baseLabelTypography, COLORS, CONFIG, rtl } from '../../utils';\nimport type { LabelPosition, Size, PrefixSuffixWrapperProps } from '../types';\n\ntype ContainerProps = {\n\tdisabled?: boolean;\n\thideLabel?: boolean;\n\t__unstableInputWidth?: CSSProperties[ 'width' ];\n\tlabelPosition?: LabelPosition;\n};\n\nexport const Prefix = styled.span`\n\tbox-sizing: border-box;\n\tdisplay: block;\n`;\n\nexport const Suffix = styled.span`\n\talign-items: center;\n\talign-self: stretch;\n\tbox-sizing: border-box;\n\tdisplay: flex;\n`;\n\ntype BackdropProps = {\n\tdisabled?: boolean;\n\tisBorderless?: boolean;\n};\n\nconst backdropBorderColor = ( {\n\tdisabled,\n\tisBorderless,\n}: BackdropProps ): CSSProperties[ 'borderColor' ] => {\n\tif ( isBorderless ) {\n\t\treturn 'transparent';\n\t}\n\n\tif ( disabled ) {\n\t\treturn COLORS.ui.borderDisabled;\n\t}\n\n\treturn COLORS.ui.border;\n};\n\nexport const BackdropUI = styled.div< BackdropProps >`\n\t&&& {\n\t\tbox-sizing: border-box;\n\t\tborder-color: ${ backdropBorderColor };\n\t\tborder-radius: inherit;\n\t\tborder-style: solid;\n\t\tborder-width: 1px;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tpointer-events: none;\n\t\tposition: absolute;\n\t\tright: 0;\n\t\ttop: 0;\n\n\t\t${ rtl( { paddingLeft: 2 } ) }\n\t}\n`;\n\nexport const Root = styled( Flex )`\n\tbox-sizing: border-box;\n\tposition: relative;\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tpadding-top: 0;\n\n\t// Focus within, excluding cases where auxiliary controls in prefix or suffix have focus.\n\t&:focus-within:not( :has( :is( ${ Prefix }, ${ Suffix } ):focus-within ) ) {\n\t\t${ BackdropUI } {\n\t\t\tborder-color: ${ COLORS.ui.borderFocus };\n\t\t\tbox-shadow: ${ CONFIG.controlBoxShadowFocus };\n\t\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\t\toutline: 2px solid transparent;\n\t\t\toutline-offset: -2px;\n\t\t}\n\t}\n`;\n\nconst containerDisabledStyles = ( { disabled }: ContainerProps ) => {\n\tconst backgroundColor = disabled\n\t\t? COLORS.ui.backgroundDisabled\n\t\t: COLORS.ui.background;\n\n\treturn css( { backgroundColor } );\n};\n\nconst containerWidthStyles = ( {\n\t__unstableInputWidth,\n\tlabelPosition,\n}: ContainerProps ) => {\n\tif ( ! __unstableInputWidth ) {\n\t\treturn css( { width: '100%' } );\n\t}\n\n\tif ( labelPosition === 'side' ) {\n\t\treturn '';\n\t}\n\n\tif ( labelPosition === 'edge' ) {\n\t\treturn css( {\n\t\t\tflex: `0 0 ${ __unstableInputWidth }`,\n\t\t} );\n\t}\n\n\treturn css( { width: __unstableInputWidth } );\n};\n\nexport const Container = styled.div< ContainerProps >`\n\talign-items: center;\n\tbox-sizing: border-box;\n\tborder-radius: inherit;\n\tdisplay: flex;\n\tflex: 1;\n\tposition: relative;\n\n\t${ containerDisabledStyles }\n\t${ containerWidthStyles }\n`;\n\ntype InputProps = {\n\t__next40pxDefaultSize?: boolean;\n\tdisabled?: boolean;\n\tinputSize?: Size;\n\tisDragging?: boolean;\n\tdragCursor?: CSSProperties[ 'cursor' ];\n\tpaddingInlineStart?: CSSProperties[ 'paddingInlineStart' ];\n\tpaddingInlineEnd?: CSSProperties[ 'paddingInlineEnd' ];\n};\n\nconst disabledStyles = ( { disabled }: InputProps ) => {\n\tif ( ! disabled ) {\n\t\treturn '';\n\t}\n\n\treturn css( {\n\t\tcolor: COLORS.ui.textDisabled,\n\t} );\n};\n\nexport const fontSizeStyles = ( { inputSize: size }: InputProps ) => {\n\tconst sizes = {\n\t\tdefault: '13px',\n\t\tsmall: '11px',\n\t\tcompact: '13px',\n\t\t'__unstable-large': '13px',\n\t};\n\n\tconst fontSize = sizes[ size as Size ] || sizes.default;\n\tconst fontSizeMobile = '16px';\n\n\tif ( ! fontSize ) {\n\t\treturn '';\n\t}\n\n\treturn css`\n\t\tfont-size: ${ fontSizeMobile };\n\n\t\t@media ( min-width: 600px ) {\n\t\t\tfont-size: ${ fontSize };\n\t\t}\n\t`;\n};\n\nexport const getSizeConfig = ( {\n\tinputSize: size,\n\t__next40pxDefaultSize,\n}: InputProps ) => {\n\t// Paddings may be overridden by the custom paddings props.\n\tconst sizes = {\n\t\tdefault: {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t\tsmall: {\n\t\t\theight: 24,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 24,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\tcompact: {\n\t\t\theight: 32,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 32,\n\t\t\tpaddingLeft: CONFIG.controlPaddingXSmall,\n\t\t\tpaddingRight: CONFIG.controlPaddingXSmall,\n\t\t},\n\t\t'__unstable-large': {\n\t\t\theight: 40,\n\t\t\tlineHeight: 1,\n\t\t\tminHeight: 40,\n\t\t\tpaddingLeft: CONFIG.controlPaddingX,\n\t\t\tpaddingRight: CONFIG.controlPaddingX,\n\t\t},\n\t};\n\n\tif ( ! __next40pxDefaultSize ) {\n\t\tsizes.default = sizes.compact;\n\t}\n\n\treturn sizes[ size as Size ] || sizes.default;\n};\n\nconst sizeStyles = ( props: InputProps ) => {\n\treturn css( getSizeConfig( props ) );\n};\n\nconst customPaddings = ( {\n\tpaddingInlineStart,\n\tpaddingInlineEnd,\n}: InputProps ) => {\n\treturn css( { paddingInlineStart, paddingInlineEnd } );\n};\n\nconst dragStyles = ( { isDragging, dragCursor }: InputProps ) => {\n\tlet defaultArrowStyles: SerializedStyles | undefined;\n\tlet activeDragCursorStyles: SerializedStyles | undefined;\n\n\tif ( isDragging ) {\n\t\tdefaultArrowStyles = css`\n\t\t\tcursor: ${ dragCursor };\n\t\t\tuser-select: none;\n\n\t\t\t&::-webkit-outer-spin-button,\n\t\t\t&::-webkit-inner-spin-button {\n\t\t\t\t-webkit-appearance: none !important;\n\t\t\t\tmargin: 0 !important;\n\t\t\t}\n\t\t`;\n\t}\n\n\tif ( isDragging && dragCursor ) {\n\t\tactiveDragCursorStyles = css`\n\t\t\t&:active {\n\t\t\t\tcursor: ${ dragCursor };\n\t\t\t}\n\t\t`;\n\t}\n\n\treturn css`\n\t\t${ defaultArrowStyles }\n\t\t${ activeDragCursorStyles }\n\t`;\n};\n\n// TODO: Resolve need to use &&& to increase specificity\n// https://github.com/WordPress/gutenberg/issues/18483\n\nexport const Input = styled.input< InputProps >`\n\t&&& {\n\t\tbackground-color: transparent;\n\t\tbox-sizing: border-box;\n\t\tborder: none;\n\t\tbox-shadow: none !important;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tdisplay: block;\n\t\tfont-family: inherit;\n\t\tmargin: 0;\n\t\toutline: none;\n\t\twidth: 100%;\n\n\t\t${ dragStyles }\n\t\t${ disabledStyles }\n\t\t${ fontSizeStyles }\n\t\t${ sizeStyles }\n\t\t${ customPaddings }\n\n\t\t&::-webkit-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&::-moz-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&:-ms-input-placeholder {\n\t\t\tcolor: ${ COLORS.ui.darkGrayPlaceholder };\n\t\t}\n\n\t\t&[type='email'],\n\t\t&[type='url'] {\n\t\t\t/* rtl:ignore */\n\t\t\tdirection: ltr;\n\t\t}\n\t}\n`;\n\nconst BaseLabel = styled( Text )< { labelPosition?: LabelPosition } >`\n\t&&& {\n\t\t${ baseLabelTypography };\n\n\t\tbox-sizing: border-box;\n\t\tdisplay: block;\n\t\tpadding-top: 0;\n\t\tpadding-bottom: 0;\n\t\tmax-width: 100%;\n\t\tz-index: 1;\n\n\t\toverflow: hidden;\n\t\ttext-overflow: ellipsis;\n\t\twhite-space: nowrap;\n\t}\n`;\n\nexport const Label = (\n\tprops: WordPressComponentProps<\n\t\t{ labelPosition?: LabelPosition; children: ReactNode },\n\t\t'label',\n\t\tfalse\n\t>\n) => <BaseLabel { ...props } as=\"label\" />;\n\nexport const LabelWrapper = styled( FlexItem )`\n\tmax-width: calc( 100% - 10px );\n`;\n\nconst prefixSuffixWrapperStyles = ( {\n\tvariant = 'default',\n\tsize,\n\t__next40pxDefaultSize,\n\tisPrefix,\n}: PrefixSuffixWrapperProps & { isPrefix?: boolean } ) => {\n\tconst { paddingLeft: padding } = getSizeConfig( {\n\t\tinputSize: size,\n\t\t__next40pxDefaultSize,\n\t} );\n\n\tconst paddingProperty = isPrefix\n\t\t? 'paddingInlineStart'\n\t\t: 'paddingInlineEnd';\n\n\tif ( variant === 'default' ) {\n\t\treturn css( {\n\t\t\t[ paddingProperty ]: padding,\n\t\t} );\n\t}\n\n\t// If variant is 'icon' or 'control'\n\treturn css( {\n\t\tdisplay: 'flex',\n\t\t[ paddingProperty ]: padding - 4,\n\t} );\n};\n\nexport const PrefixSuffixWrapper = styled.div`\n\t${ prefixSuffixWrapperStyles }\n`;\n"]} */")); 25491 25492 // packages/components/build-module/input-control/backdrop.js 25493 var import_jsx_runtime87 = __toESM(require_jsx_runtime()); 25494 function Backdrop({ 25495 disabled = false, 25496 isBorderless = false 25497 }) { 25498 return /* @__PURE__ */ (0, import_jsx_runtime87.jsx)(BackdropUI, { 25499 "aria-hidden": "true", 25500 className: "components-input-control__backdrop", 25501 disabled, 25502 isBorderless 25503 }); 25504 } 25505 var MemoizedBackdrop = (0, import_element25.memo)(Backdrop); 25506 var backdrop_default = MemoizedBackdrop; 25507 25508 // packages/components/build-module/input-control/label.js 25509 var import_jsx_runtime88 = __toESM(require_jsx_runtime()); 25510 function Label2({ 25511 children, 25512 hideLabelFromVision, 25513 htmlFor, 25514 ...props 25515 }) { 25516 if (!children) { 25517 return null; 25518 } 25519 if (hideLabelFromVision) { 25520 return /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(component_default2, { 25521 as: "label", 25522 htmlFor, 25523 children 25524 }); 25525 } 25526 return /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(LabelWrapper, { 25527 children: /* @__PURE__ */ (0, import_jsx_runtime88.jsx)(Label, { 25528 htmlFor, 25529 ...props, 25530 children 25531 }) 25532 }); 25533 } 25534 25535 // packages/components/build-module/utils/use-deprecated-props.js 25536 function useDeprecated36pxDefaultSizeProp(props) { 25537 const { 25538 __next36pxDefaultSize, 25539 __next40pxDefaultSize, 25540 ...otherProps 25541 } = props; 25542 return { 25543 ...otherProps, 25544 __next40pxDefaultSize: __next40pxDefaultSize !== null && __next40pxDefaultSize !== void 0 ? __next40pxDefaultSize : __next36pxDefaultSize 25545 }; 25546 } 25547 25548 // packages/components/build-module/input-control/input-base.js 25549 var import_jsx_runtime89 = __toESM(require_jsx_runtime()); 25550 function useUniqueId(idProp) { 25551 const instanceId = (0, import_compose3.useInstanceId)(InputBase); 25552 const id3 = `input-base-control-$instanceId}`; 25553 return idProp || id3; 25554 } 25555 function getUIFlexProps(labelPosition) { 25556 const props = {}; 25557 switch (labelPosition) { 25558 case "top": 25559 props.direction = "column"; 25560 props.expanded = false; 25561 props.gap = 0; 25562 break; 25563 case "bottom": 25564 props.direction = "column-reverse"; 25565 props.expanded = false; 25566 props.gap = 0; 25567 break; 25568 case "edge": 25569 props.justify = "space-between"; 25570 break; 25571 } 25572 return props; 25573 } 25574 function InputBase(props, ref) { 25575 const { 25576 __next40pxDefaultSize, 25577 __unstableInputWidth, 25578 children, 25579 className: className2, 25580 disabled = false, 25581 hideLabelFromVision = false, 25582 labelPosition, 25583 id: idProp, 25584 isBorderless = false, 25585 label, 25586 prefix: prefix2, 25587 size: size3 = "default", 25588 suffix, 25589 ...restProps 25590 } = useDeprecated36pxDefaultSizeProp(useContextSystem(props, "InputBase")); 25591 const id3 = useUniqueId(idProp); 25592 const hideLabel = hideLabelFromVision || !label; 25593 const prefixSuffixContextValue = (0, import_element26.useMemo)(() => { 25594 return { 25595 InputControlPrefixWrapper: { 25596 __next40pxDefaultSize, 25597 size: size3 25598 }, 25599 InputControlSuffixWrapper: { 25600 __next40pxDefaultSize, 25601 size: size3 25602 } 25603 }; 25604 }, [__next40pxDefaultSize, size3]); 25605 return ( 25606 // @ts-expect-error The `direction` prop from Flex (FlexDirection) conflicts with legacy SVGAttributes `direction` (string) that come from React intrinsic prop definitions. 25607 /* @__PURE__ */ (0, import_jsx_runtime89.jsxs)(Root, { 25608 ...restProps, 25609 ...getUIFlexProps(labelPosition), 25610 className: className2, 25611 gap: 2, 25612 ref, 25613 children: [/* @__PURE__ */ (0, import_jsx_runtime89.jsx)(Label2, { 25614 className: "components-input-control__label", 25615 hideLabelFromVision, 25616 labelPosition, 25617 htmlFor: id3, 25618 children: label 25619 }), /* @__PURE__ */ (0, import_jsx_runtime89.jsxs)(Container, { 25620 __unstableInputWidth, 25621 className: "components-input-control__container", 25622 disabled, 25623 hideLabel, 25624 labelPosition, 25625 children: [/* @__PURE__ */ (0, import_jsx_runtime89.jsxs)(ContextSystemProvider, { 25626 value: prefixSuffixContextValue, 25627 children: [prefix2 && /* @__PURE__ */ (0, import_jsx_runtime89.jsx)(Prefix, { 25628 className: "components-input-control__prefix", 25629 children: prefix2 25630 }), children, suffix && /* @__PURE__ */ (0, import_jsx_runtime89.jsx)(Suffix, { 25631 className: "components-input-control__suffix", 25632 children: suffix 25633 })] 25634 }), /* @__PURE__ */ (0, import_jsx_runtime89.jsx)(backdrop_default, { 25635 disabled, 25636 isBorderless 25637 })] 25638 })] 25639 }) 25640 ); 25641 } 25642 var input_base_default = contextConnect(InputBase, "InputBase"); 25643 25644 // node_modules/@use-gesture/core/dist/maths-0ab39ae9.esm.js 25645 function clamp3(v3, min3, max3) { 25646 return Math.max(min3, Math.min(v3, max3)); 25647 } 25648 var V = { 25649 toVector(v3, fallback) { 25650 if (v3 === void 0) v3 = fallback; 25651 return Array.isArray(v3) ? v3 : [v3, v3]; 25652 }, 25653 add(v1, v22) { 25654 return [v1[0] + v22[0], v1[1] + v22[1]]; 25655 }, 25656 sub(v1, v22) { 25657 return [v1[0] - v22[0], v1[1] - v22[1]]; 25658 }, 25659 addTo(v1, v22) { 25660 v1[0] += v22[0]; 25661 v1[1] += v22[1]; 25662 }, 25663 subTo(v1, v22) { 25664 v1[0] -= v22[0]; 25665 v1[1] -= v22[1]; 25666 } 25667 }; 25668 function rubberband(distance2, dimension, constant) { 25669 if (dimension === 0 || Math.abs(dimension) === Infinity) return Math.pow(distance2, constant * 5); 25670 return distance2 * dimension * constant / (dimension + constant * distance2); 25671 } 25672 function rubberbandIfOutOfBounds(position2, min3, max3, constant = 0.15) { 25673 if (constant === 0) return clamp3(position2, min3, max3); 25674 if (position2 < min3) return -rubberband(min3 - position2, max3 - min3, constant) + min3; 25675 if (position2 > max3) return +rubberband(position2 - max3, max3 - min3, constant) + max3; 25676 return position2; 25677 } 25678 function computeRubberband(bounds, [Vx, Vy], [Rx, Ry]) { 25679 const [[X0, X1], [Y0, Y1]] = bounds; 25680 return [rubberbandIfOutOfBounds(Vx, X0, X1, Rx), rubberbandIfOutOfBounds(Vy, Y0, Y1, Ry)]; 25681 } 25682 25683 // node_modules/@use-gesture/core/dist/actions-fe213e88.esm.js 25684 function _toPrimitive(input, hint) { 25685 if (typeof input !== "object" || input === null) return input; 25686 var prim = input[Symbol.toPrimitive]; 25687 if (prim !== void 0) { 25688 var res = prim.call(input, hint || "default"); 25689 if (typeof res !== "object") return res; 25690 throw new TypeError("@@toPrimitive must return a primitive value."); 25691 } 25692 return (hint === "string" ? String : Number)(input); 25693 } 25694 function _toPropertyKey(arg) { 25695 var key = _toPrimitive(arg, "string"); 25696 return typeof key === "symbol" ? key : String(key); 25697 } 25698 function _defineProperty(obj, key, value) { 25699 key = _toPropertyKey(key); 25700 if (key in obj) { 25701 Object.defineProperty(obj, key, { 25702 value, 25703 enumerable: true, 25704 configurable: true, 25705 writable: true 25706 }); 25707 } else { 25708 obj[key] = value; 25709 } 25710 return obj; 25711 } 25712 function ownKeys(e3, r4) { 25713 var t4 = Object.keys(e3); 25714 if (Object.getOwnPropertySymbols) { 25715 var o4 = Object.getOwnPropertySymbols(e3); 25716 r4 && (o4 = o4.filter(function(r5) { 25717 return Object.getOwnPropertyDescriptor(e3, r5).enumerable; 25718 })), t4.push.apply(t4, o4); 25719 } 25720 return t4; 25721 } 25722 function _objectSpread2(e3) { 25723 for (var r4 = 1; r4 < arguments.length; r4++) { 25724 var t4 = null != arguments[r4] ? arguments[r4] : {}; 25725 r4 % 2 ? ownKeys(Object(t4), true).forEach(function(r5) { 25726 _defineProperty(e3, r5, t4[r5]); 25727 }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e3, Object.getOwnPropertyDescriptors(t4)) : ownKeys(Object(t4)).forEach(function(r5) { 25728 Object.defineProperty(e3, r5, Object.getOwnPropertyDescriptor(t4, r5)); 25729 }); 25730 } 25731 return e3; 25732 } 25733 var EVENT_TYPE_MAP = { 25734 pointer: { 25735 start: "down", 25736 change: "move", 25737 end: "up" 25738 }, 25739 mouse: { 25740 start: "down", 25741 change: "move", 25742 end: "up" 25743 }, 25744 touch: { 25745 start: "start", 25746 change: "move", 25747 end: "end" 25748 }, 25749 gesture: { 25750 start: "start", 25751 change: "change", 25752 end: "end" 25753 } 25754 }; 25755 function capitalize(string) { 25756 if (!string) return ""; 25757 return string[0].toUpperCase() + string.slice(1); 25758 } 25759 var actionsWithoutCaptureSupported = ["enter", "leave"]; 25760 function hasCapture(capture = false, actionKey) { 25761 return capture && !actionsWithoutCaptureSupported.includes(actionKey); 25762 } 25763 function toHandlerProp(device, action = "", capture = false) { 25764 const deviceProps = EVENT_TYPE_MAP[device]; 25765 const actionKey = deviceProps ? deviceProps[action] || action : action; 25766 return "on" + capitalize(device) + capitalize(actionKey) + (hasCapture(capture, actionKey) ? "Capture" : ""); 25767 } 25768 var pointerCaptureEvents = ["gotpointercapture", "lostpointercapture"]; 25769 function parseProp(prop) { 25770 let eventKey = prop.substring(2).toLowerCase(); 25771 const passive = !!~eventKey.indexOf("passive"); 25772 if (passive) eventKey = eventKey.replace("passive", ""); 25773 const captureKey = pointerCaptureEvents.includes(eventKey) ? "capturecapture" : "capture"; 25774 const capture = !!~eventKey.indexOf(captureKey); 25775 if (capture) eventKey = eventKey.replace("capture", ""); 25776 return { 25777 device: eventKey, 25778 capture, 25779 passive 25780 }; 25781 } 25782 function toDomEventType(device, action = "") { 25783 const deviceProps = EVENT_TYPE_MAP[device]; 25784 const actionKey = deviceProps ? deviceProps[action] || action : action; 25785 return device + actionKey; 25786 } 25787 function isTouch(event) { 25788 return "touches" in event; 25789 } 25790 function getPointerType(event) { 25791 if (isTouch(event)) return "touch"; 25792 if ("pointerType" in event) return event.pointerType; 25793 return "mouse"; 25794 } 25795 function getCurrentTargetTouchList(event) { 25796 return Array.from(event.touches).filter((e3) => { 25797 var _event$currentTarget, _event$currentTarget$; 25798 return e3.target === event.currentTarget || ((_event$currentTarget = event.currentTarget) === null || _event$currentTarget === void 0 || (_event$currentTarget$ = _event$currentTarget.contains) === null || _event$currentTarget$ === void 0 ? void 0 : _event$currentTarget$.call(_event$currentTarget, e3.target)); 25799 }); 25800 } 25801 function getTouchList(event) { 25802 return event.type === "touchend" || event.type === "touchcancel" ? event.changedTouches : event.targetTouches; 25803 } 25804 function getValueEvent(event) { 25805 return isTouch(event) ? getTouchList(event)[0] : event; 25806 } 25807 function touchIds(event) { 25808 return getCurrentTargetTouchList(event).map((touch) => touch.identifier); 25809 } 25810 function pointerId(event) { 25811 const valueEvent = getValueEvent(event); 25812 return isTouch(event) ? valueEvent.identifier : valueEvent.pointerId; 25813 } 25814 function pointerValues(event) { 25815 const valueEvent = getValueEvent(event); 25816 return [valueEvent.clientX, valueEvent.clientY]; 25817 } 25818 function getEventDetails(event) { 25819 const payload = {}; 25820 if ("buttons" in event) payload.buttons = event.buttons; 25821 if ("shiftKey" in event) { 25822 const { 25823 shiftKey, 25824 altKey, 25825 metaKey, 25826 ctrlKey 25827 } = event; 25828 Object.assign(payload, { 25829 shiftKey, 25830 altKey, 25831 metaKey, 25832 ctrlKey 25833 }); 25834 } 25835 return payload; 25836 } 25837 function call(v3, ...args) { 25838 if (typeof v3 === "function") { 25839 return v3(...args); 25840 } else { 25841 return v3; 25842 } 25843 } 25844 function noop3() { 25845 } 25846 function chain2(...fns) { 25847 if (fns.length === 0) return noop3; 25848 if (fns.length === 1) return fns[0]; 25849 return function() { 25850 let result; 25851 for (const fn of fns) { 25852 result = fn.apply(this, arguments) || result; 25853 } 25854 return result; 25855 }; 25856 } 25857 function assignDefault(value, fallback) { 25858 return Object.assign({}, fallback, value || {}); 25859 } 25860 var BEFORE_LAST_KINEMATICS_DELAY = 32; 25861 var Engine = class { 25862 constructor(ctrl, args, key) { 25863 this.ctrl = ctrl; 25864 this.args = args; 25865 this.key = key; 25866 if (!this.state) { 25867 this.state = {}; 25868 this.computeValues([0, 0]); 25869 this.computeInitial(); 25870 if (this.init) this.init(); 25871 this.reset(); 25872 } 25873 } 25874 get state() { 25875 return this.ctrl.state[this.key]; 25876 } 25877 set state(state) { 25878 this.ctrl.state[this.key] = state; 25879 } 25880 get shared() { 25881 return this.ctrl.state.shared; 25882 } 25883 get eventStore() { 25884 return this.ctrl.gestureEventStores[this.key]; 25885 } 25886 get timeoutStore() { 25887 return this.ctrl.gestureTimeoutStores[this.key]; 25888 } 25889 get config() { 25890 return this.ctrl.config[this.key]; 25891 } 25892 get sharedConfig() { 25893 return this.ctrl.config.shared; 25894 } 25895 get handler() { 25896 return this.ctrl.handlers[this.key]; 25897 } 25898 reset() { 25899 const { 25900 state, 25901 shared, 25902 ingKey, 25903 args 25904 } = this; 25905 shared[ingKey] = state._active = state.active = state._blocked = state._force = false; 25906 state._step = [false, false]; 25907 state.intentional = false; 25908 state._movement = [0, 0]; 25909 state._distance = [0, 0]; 25910 state._direction = [0, 0]; 25911 state._delta = [0, 0]; 25912 state._bounds = [[-Infinity, Infinity], [-Infinity, Infinity]]; 25913 state.args = args; 25914 state.axis = void 0; 25915 state.memo = void 0; 25916 state.elapsedTime = state.timeDelta = 0; 25917 state.direction = [0, 0]; 25918 state.distance = [0, 0]; 25919 state.overflow = [0, 0]; 25920 state._movementBound = [false, false]; 25921 state.velocity = [0, 0]; 25922 state.movement = [0, 0]; 25923 state.delta = [0, 0]; 25924 state.timeStamp = 0; 25925 } 25926 start(event) { 25927 const state = this.state; 25928 const config = this.config; 25929 if (!state._active) { 25930 this.reset(); 25931 this.computeInitial(); 25932 state._active = true; 25933 state.target = event.target; 25934 state.currentTarget = event.currentTarget; 25935 state.lastOffset = config.from ? call(config.from, state) : state.offset; 25936 state.offset = state.lastOffset; 25937 state.startTime = state.timeStamp = event.timeStamp; 25938 } 25939 } 25940 computeValues(values) { 25941 const state = this.state; 25942 state._values = values; 25943 state.values = this.config.transform(values); 25944 } 25945 computeInitial() { 25946 const state = this.state; 25947 state._initial = state._values; 25948 state.initial = state.values; 25949 } 25950 compute(event) { 25951 const { 25952 state, 25953 config, 25954 shared 25955 } = this; 25956 state.args = this.args; 25957 let dt = 0; 25958 if (event) { 25959 state.event = event; 25960 if (config.preventDefault && event.cancelable) state.event.preventDefault(); 25961 state.type = event.type; 25962 shared.touches = this.ctrl.pointerIds.size || this.ctrl.touchIds.size; 25963 shared.locked = !!document.pointerLockElement; 25964 Object.assign(shared, getEventDetails(event)); 25965 shared.down = shared.pressed = shared.buttons % 2 === 1 || shared.touches > 0; 25966 dt = event.timeStamp - state.timeStamp; 25967 state.timeStamp = event.timeStamp; 25968 state.elapsedTime = state.timeStamp - state.startTime; 25969 } 25970 if (state._active) { 25971 const _absoluteDelta = state._delta.map(Math.abs); 25972 V.addTo(state._distance, _absoluteDelta); 25973 } 25974 if (this.axisIntent) this.axisIntent(event); 25975 const [_m0, _m1] = state._movement; 25976 const [t0, t1] = config.threshold; 25977 const { 25978 _step, 25979 values 25980 } = state; 25981 if (config.hasCustomTransform) { 25982 if (_step[0] === false) _step[0] = Math.abs(_m0) >= t0 && values[0]; 25983 if (_step[1] === false) _step[1] = Math.abs(_m1) >= t1 && values[1]; 25984 } else { 25985 if (_step[0] === false) _step[0] = Math.abs(_m0) >= t0 && Math.sign(_m0) * t0; 25986 if (_step[1] === false) _step[1] = Math.abs(_m1) >= t1 && Math.sign(_m1) * t1; 25987 } 25988 state.intentional = _step[0] !== false || _step[1] !== false; 25989 if (!state.intentional) return; 25990 const movement = [0, 0]; 25991 if (config.hasCustomTransform) { 25992 const [v0, v1] = values; 25993 movement[0] = _step[0] !== false ? v0 - _step[0] : 0; 25994 movement[1] = _step[1] !== false ? v1 - _step[1] : 0; 25995 } else { 25996 movement[0] = _step[0] !== false ? _m0 - _step[0] : 0; 25997 movement[1] = _step[1] !== false ? _m1 - _step[1] : 0; 25998 } 25999 if (this.restrictToAxis && !state._blocked) this.restrictToAxis(movement); 26000 const previousOffset = state.offset; 26001 const gestureIsActive = state._active && !state._blocked || state.active; 26002 if (gestureIsActive) { 26003 state.first = state._active && !state.active; 26004 state.last = !state._active && state.active; 26005 state.active = shared[this.ingKey] = state._active; 26006 if (event) { 26007 if (state.first) { 26008 if ("bounds" in config) state._bounds = call(config.bounds, state); 26009 if (this.setup) this.setup(); 26010 } 26011 state.movement = movement; 26012 this.computeOffset(); 26013 } 26014 } 26015 const [ox, oy] = state.offset; 26016 const [[x0, x1], [y0, y1]] = state._bounds; 26017 state.overflow = [ox < x0 ? -1 : ox > x1 ? 1 : 0, oy < y0 ? -1 : oy > y1 ? 1 : 0]; 26018 state._movementBound[0] = state.overflow[0] ? state._movementBound[0] === false ? state._movement[0] : state._movementBound[0] : false; 26019 state._movementBound[1] = state.overflow[1] ? state._movementBound[1] === false ? state._movement[1] : state._movementBound[1] : false; 26020 const rubberband2 = state._active ? config.rubberband || [0, 0] : [0, 0]; 26021 state.offset = computeRubberband(state._bounds, state.offset, rubberband2); 26022 state.delta = V.sub(state.offset, previousOffset); 26023 this.computeMovement(); 26024 if (gestureIsActive && (!state.last || dt > BEFORE_LAST_KINEMATICS_DELAY)) { 26025 state.delta = V.sub(state.offset, previousOffset); 26026 const absoluteDelta = state.delta.map(Math.abs); 26027 V.addTo(state.distance, absoluteDelta); 26028 state.direction = state.delta.map(Math.sign); 26029 state._direction = state._delta.map(Math.sign); 26030 if (!state.first && dt > 0) { 26031 state.velocity = [absoluteDelta[0] / dt, absoluteDelta[1] / dt]; 26032 state.timeDelta = dt; 26033 } 26034 } 26035 } 26036 emit() { 26037 const state = this.state; 26038 const shared = this.shared; 26039 const config = this.config; 26040 if (!state._active) this.clean(); 26041 if ((state._blocked || !state.intentional) && !state._force && !config.triggerAllEvents) return; 26042 const memo6 = this.handler(_objectSpread2(_objectSpread2(_objectSpread2({}, shared), state), {}, { 26043 [this.aliasKey]: state.values 26044 })); 26045 if (memo6 !== void 0) state.memo = memo6; 26046 } 26047 clean() { 26048 this.eventStore.clean(); 26049 this.timeoutStore.clean(); 26050 } 26051 }; 26052 function selectAxis([dx, dy], threshold) { 26053 const absDx = Math.abs(dx); 26054 const absDy = Math.abs(dy); 26055 if (absDx > absDy && absDx > threshold) { 26056 return "x"; 26057 } 26058 if (absDy > absDx && absDy > threshold) { 26059 return "y"; 26060 } 26061 return void 0; 26062 } 26063 var CoordinatesEngine = class extends Engine { 26064 constructor(...args) { 26065 super(...args); 26066 _defineProperty(this, "aliasKey", "xy"); 26067 } 26068 reset() { 26069 super.reset(); 26070 this.state.axis = void 0; 26071 } 26072 init() { 26073 this.state.offset = [0, 0]; 26074 this.state.lastOffset = [0, 0]; 26075 } 26076 computeOffset() { 26077 this.state.offset = V.add(this.state.lastOffset, this.state.movement); 26078 } 26079 computeMovement() { 26080 this.state.movement = V.sub(this.state.offset, this.state.lastOffset); 26081 } 26082 axisIntent(event) { 26083 const state = this.state; 26084 const config = this.config; 26085 if (!state.axis && event) { 26086 const threshold = typeof config.axisThreshold === "object" ? config.axisThreshold[getPointerType(event)] : config.axisThreshold; 26087 state.axis = selectAxis(state._movement, threshold); 26088 } 26089 state._blocked = (config.lockDirection || !!config.axis) && !state.axis || !!config.axis && config.axis !== state.axis; 26090 } 26091 restrictToAxis(v3) { 26092 if (this.config.axis || this.config.lockDirection) { 26093 switch (this.state.axis) { 26094 case "x": 26095 v3[1] = 0; 26096 break; 26097 case "y": 26098 v3[0] = 0; 26099 break; 26100 } 26101 } 26102 } 26103 }; 26104 var identity2 = (v3) => v3; 26105 var DEFAULT_RUBBERBAND = 0.15; 26106 var commonConfigResolver = { 26107 enabled(value = true) { 26108 return value; 26109 }, 26110 eventOptions(value, _k, config) { 26111 return _objectSpread2(_objectSpread2({}, config.shared.eventOptions), value); 26112 }, 26113 preventDefault(value = false) { 26114 return value; 26115 }, 26116 triggerAllEvents(value = false) { 26117 return value; 26118 }, 26119 rubberband(value = 0) { 26120 switch (value) { 26121 case true: 26122 return [DEFAULT_RUBBERBAND, DEFAULT_RUBBERBAND]; 26123 case false: 26124 return [0, 0]; 26125 default: 26126 return V.toVector(value); 26127 } 26128 }, 26129 from(value) { 26130 if (typeof value === "function") return value; 26131 if (value != null) return V.toVector(value); 26132 }, 26133 transform(value, _k, config) { 26134 const transform = value || config.shared.transform; 26135 this.hasCustomTransform = !!transform; 26136 if (true) { 26137 const originalTransform = transform || identity2; 26138 return (v3) => { 26139 const r4 = originalTransform(v3); 26140 if (!isFinite(r4[0]) || !isFinite(r4[1])) { 26141 console.warn(`[@use-gesture]: config.transform() must produce a valid result, but it was: [$r4[0]},${[1]}]`); 26142 } 26143 return r4; 26144 }; 26145 } 26146 return transform || identity2; 26147 }, 26148 threshold(value) { 26149 return V.toVector(value, 0); 26150 } 26151 }; 26152 if (true) { 26153 Object.assign(commonConfigResolver, { 26154 domTarget(value) { 26155 if (value !== void 0) { 26156 throw Error(`[@use-gesture]: \`domTarget\` option has been renamed to \`target\`.`); 26157 } 26158 return NaN; 26159 }, 26160 lockDirection(value) { 26161 if (value !== void 0) { 26162 throw Error(`[@use-gesture]: \`lockDirection\` option has been merged with \`axis\`. Use it as in \`{ axis: 'lock' }\``); 26163 } 26164 return NaN; 26165 }, 26166 initial(value) { 26167 if (value !== void 0) { 26168 throw Error(`[@use-gesture]: \`initial\` option has been renamed to \`from\`.`); 26169 } 26170 return NaN; 26171 } 26172 }); 26173 } 26174 var DEFAULT_AXIS_THRESHOLD = 0; 26175 var coordinatesConfigResolver = _objectSpread2(_objectSpread2({}, commonConfigResolver), {}, { 26176 axis(_v, _k, { 26177 axis 26178 }) { 26179 this.lockDirection = axis === "lock"; 26180 if (!this.lockDirection) return axis; 26181 }, 26182 axisThreshold(value = DEFAULT_AXIS_THRESHOLD) { 26183 return value; 26184 }, 26185 bounds(value = {}) { 26186 if (typeof value === "function") { 26187 return (state) => coordinatesConfigResolver.bounds(value(state)); 26188 } 26189 if ("current" in value) { 26190 return () => value.current; 26191 } 26192 if (typeof HTMLElement === "function" && value instanceof HTMLElement) { 26193 return value; 26194 } 26195 const { 26196 left = -Infinity, 26197 right = Infinity, 26198 top = -Infinity, 26199 bottom = Infinity 26200 } = value; 26201 return [[left, right], [top, bottom]]; 26202 } 26203 }); 26204 var KEYS_DELTA_MAP = { 26205 ArrowRight: (displacement, factor = 1) => [displacement * factor, 0], 26206 ArrowLeft: (displacement, factor = 1) => [-1 * displacement * factor, 0], 26207 ArrowUp: (displacement, factor = 1) => [0, -1 * displacement * factor], 26208 ArrowDown: (displacement, factor = 1) => [0, displacement * factor] 26209 }; 26210 var DragEngine = class extends CoordinatesEngine { 26211 constructor(...args) { 26212 super(...args); 26213 _defineProperty(this, "ingKey", "dragging"); 26214 } 26215 reset() { 26216 super.reset(); 26217 const state = this.state; 26218 state._pointerId = void 0; 26219 state._pointerActive = false; 26220 state._keyboardActive = false; 26221 state._preventScroll = false; 26222 state._delayed = false; 26223 state.swipe = [0, 0]; 26224 state.tap = false; 26225 state.canceled = false; 26226 state.cancel = this.cancel.bind(this); 26227 } 26228 setup() { 26229 const state = this.state; 26230 if (state._bounds instanceof HTMLElement) { 26231 const boundRect = state._bounds.getBoundingClientRect(); 26232 const targetRect = state.currentTarget.getBoundingClientRect(); 26233 const _bounds = { 26234 left: boundRect.left - targetRect.left + state.offset[0], 26235 right: boundRect.right - targetRect.right + state.offset[0], 26236 top: boundRect.top - targetRect.top + state.offset[1], 26237 bottom: boundRect.bottom - targetRect.bottom + state.offset[1] 26238 }; 26239 state._bounds = coordinatesConfigResolver.bounds(_bounds); 26240 } 26241 } 26242 cancel() { 26243 const state = this.state; 26244 if (state.canceled) return; 26245 state.canceled = true; 26246 state._active = false; 26247 setTimeout(() => { 26248 this.compute(); 26249 this.emit(); 26250 }, 0); 26251 } 26252 setActive() { 26253 this.state._active = this.state._pointerActive || this.state._keyboardActive; 26254 } 26255 clean() { 26256 this.pointerClean(); 26257 this.state._pointerActive = false; 26258 this.state._keyboardActive = false; 26259 super.clean(); 26260 } 26261 pointerDown(event) { 26262 const config = this.config; 26263 const state = this.state; 26264 if (event.buttons != null && (Array.isArray(config.pointerButtons) ? !config.pointerButtons.includes(event.buttons) : config.pointerButtons !== -1 && config.pointerButtons !== event.buttons)) return; 26265 const ctrlIds = this.ctrl.setEventIds(event); 26266 if (config.pointerCapture) { 26267 event.target.setPointerCapture(event.pointerId); 26268 } 26269 if (ctrlIds && ctrlIds.size > 1 && state._pointerActive) return; 26270 this.start(event); 26271 this.setupPointer(event); 26272 state._pointerId = pointerId(event); 26273 state._pointerActive = true; 26274 this.computeValues(pointerValues(event)); 26275 this.computeInitial(); 26276 if (config.preventScrollAxis && getPointerType(event) !== "mouse") { 26277 state._active = false; 26278 this.setupScrollPrevention(event); 26279 } else if (config.delay > 0) { 26280 this.setupDelayTrigger(event); 26281 if (config.triggerAllEvents) { 26282 this.compute(event); 26283 this.emit(); 26284 } 26285 } else { 26286 this.startPointerDrag(event); 26287 } 26288 } 26289 startPointerDrag(event) { 26290 const state = this.state; 26291 state._active = true; 26292 state._preventScroll = true; 26293 state._delayed = false; 26294 this.compute(event); 26295 this.emit(); 26296 } 26297 pointerMove(event) { 26298 const state = this.state; 26299 const config = this.config; 26300 if (!state._pointerActive) return; 26301 const id3 = pointerId(event); 26302 if (state._pointerId !== void 0 && id3 !== state._pointerId) return; 26303 const _values = pointerValues(event); 26304 if (document.pointerLockElement === event.target) { 26305 state._delta = [event.movementX, event.movementY]; 26306 } else { 26307 state._delta = V.sub(_values, state._values); 26308 this.computeValues(_values); 26309 } 26310 V.addTo(state._movement, state._delta); 26311 this.compute(event); 26312 if (state._delayed && state.intentional) { 26313 this.timeoutStore.remove("dragDelay"); 26314 state.active = false; 26315 this.startPointerDrag(event); 26316 return; 26317 } 26318 if (config.preventScrollAxis && !state._preventScroll) { 26319 if (state.axis) { 26320 if (state.axis === config.preventScrollAxis || config.preventScrollAxis === "xy") { 26321 state._active = false; 26322 this.clean(); 26323 return; 26324 } else { 26325 this.timeoutStore.remove("startPointerDrag"); 26326 this.startPointerDrag(event); 26327 return; 26328 } 26329 } else { 26330 return; 26331 } 26332 } 26333 this.emit(); 26334 } 26335 pointerUp(event) { 26336 this.ctrl.setEventIds(event); 26337 try { 26338 if (this.config.pointerCapture && event.target.hasPointerCapture(event.pointerId)) { 26339 ; 26340 event.target.releasePointerCapture(event.pointerId); 26341 } 26342 } catch (_unused) { 26343 if (true) { 26344 console.warn(`[@use-gesture]: If you see this message, it's likely that you're using an outdated version of \`@react-three/fiber\`. 26345 26346 Please upgrade to the latest version.`); 26347 } 26348 } 26349 const state = this.state; 26350 const config = this.config; 26351 if (!state._active || !state._pointerActive) return; 26352 const id3 = pointerId(event); 26353 if (state._pointerId !== void 0 && id3 !== state._pointerId) return; 26354 this.state._pointerActive = false; 26355 this.setActive(); 26356 this.compute(event); 26357 const [dx, dy] = state._distance; 26358 state.tap = dx <= config.tapsThreshold && dy <= config.tapsThreshold; 26359 if (state.tap && config.filterTaps) { 26360 state._force = true; 26361 } else { 26362 const [_dx, _dy] = state._delta; 26363 const [_mx, _my] = state._movement; 26364 const [svx, svy] = config.swipe.velocity; 26365 const [sx, sy] = config.swipe.distance; 26366 const sdt = config.swipe.duration; 26367 if (state.elapsedTime < sdt) { 26368 const _vx = Math.abs(_dx / state.timeDelta); 26369 const _vy = Math.abs(_dy / state.timeDelta); 26370 if (_vx > svx && Math.abs(_mx) > sx) state.swipe[0] = Math.sign(_dx); 26371 if (_vy > svy && Math.abs(_my) > sy) state.swipe[1] = Math.sign(_dy); 26372 } 26373 } 26374 this.emit(); 26375 } 26376 pointerClick(event) { 26377 if (!this.state.tap && event.detail > 0) { 26378 event.preventDefault(); 26379 event.stopPropagation(); 26380 } 26381 } 26382 setupPointer(event) { 26383 const config = this.config; 26384 const device = config.device; 26385 if (true) { 26386 try { 26387 if (device === "pointer" && config.preventScrollDelay === void 0) { 26388 const currentTarget = "uv" in event ? event.sourceEvent.currentTarget : event.currentTarget; 26389 const style2 = window.getComputedStyle(currentTarget); 26390 if (style2.touchAction === "auto") { 26391 console.warn(`[@use-gesture]: The drag target has its \`touch-action\` style property set to \`auto\`. It is recommended to add \`touch-action: 'none'\` so that the drag gesture behaves correctly on touch-enabled devices. For more information read this: https://use-gesture.netlify.app/docs/extras/#touch-action. 26392 26393 This message will only show in development mode. It won't appear in production. If this is intended, you can ignore it.`, currentTarget); 26394 } 26395 } 26396 } catch (_unused2) { 26397 } 26398 } 26399 if (config.pointerLock) { 26400 event.currentTarget.requestPointerLock(); 26401 } 26402 if (!config.pointerCapture) { 26403 this.eventStore.add(this.sharedConfig.window, device, "change", this.pointerMove.bind(this)); 26404 this.eventStore.add(this.sharedConfig.window, device, "end", this.pointerUp.bind(this)); 26405 this.eventStore.add(this.sharedConfig.window, device, "cancel", this.pointerUp.bind(this)); 26406 } 26407 } 26408 pointerClean() { 26409 if (this.config.pointerLock && document.pointerLockElement === this.state.currentTarget) { 26410 document.exitPointerLock(); 26411 } 26412 } 26413 preventScroll(event) { 26414 if (this.state._preventScroll && event.cancelable) { 26415 event.preventDefault(); 26416 } 26417 } 26418 setupScrollPrevention(event) { 26419 this.state._preventScroll = false; 26420 persistEvent(event); 26421 const remove = this.eventStore.add(this.sharedConfig.window, "touch", "change", this.preventScroll.bind(this), { 26422 passive: false 26423 }); 26424 this.eventStore.add(this.sharedConfig.window, "touch", "end", remove); 26425 this.eventStore.add(this.sharedConfig.window, "touch", "cancel", remove); 26426 this.timeoutStore.add("startPointerDrag", this.startPointerDrag.bind(this), this.config.preventScrollDelay, event); 26427 } 26428 setupDelayTrigger(event) { 26429 this.state._delayed = true; 26430 this.timeoutStore.add("dragDelay", () => { 26431 this.state._step = [0, 0]; 26432 this.startPointerDrag(event); 26433 }, this.config.delay); 26434 } 26435 keyDown(event) { 26436 const deltaFn = KEYS_DELTA_MAP[event.key]; 26437 if (deltaFn) { 26438 const state = this.state; 26439 const factor = event.shiftKey ? 10 : event.altKey ? 0.1 : 1; 26440 this.start(event); 26441 state._delta = deltaFn(this.config.keyboardDisplacement, factor); 26442 state._keyboardActive = true; 26443 V.addTo(state._movement, state._delta); 26444 this.compute(event); 26445 this.emit(); 26446 } 26447 } 26448 keyUp(event) { 26449 if (!(event.key in KEYS_DELTA_MAP)) return; 26450 this.state._keyboardActive = false; 26451 this.setActive(); 26452 this.compute(event); 26453 this.emit(); 26454 } 26455 bind(bindFunction) { 26456 const device = this.config.device; 26457 bindFunction(device, "start", this.pointerDown.bind(this)); 26458 if (this.config.pointerCapture) { 26459 bindFunction(device, "change", this.pointerMove.bind(this)); 26460 bindFunction(device, "end", this.pointerUp.bind(this)); 26461 bindFunction(device, "cancel", this.pointerUp.bind(this)); 26462 bindFunction("lostPointerCapture", "", this.pointerUp.bind(this)); 26463 } 26464 if (this.config.keys) { 26465 bindFunction("key", "down", this.keyDown.bind(this)); 26466 bindFunction("key", "up", this.keyUp.bind(this)); 26467 } 26468 if (this.config.filterTaps) { 26469 bindFunction("click", "", this.pointerClick.bind(this), { 26470 capture: true, 26471 passive: false 26472 }); 26473 } 26474 } 26475 }; 26476 function persistEvent(event) { 26477 "persist" in event && typeof event.persist === "function" && event.persist(); 26478 } 26479 var isBrowser3 = typeof window !== "undefined" && window.document && window.document.createElement; 26480 function supportsTouchEvents() { 26481 return isBrowser3 && "ontouchstart" in window; 26482 } 26483 function isTouchScreen() { 26484 return supportsTouchEvents() || isBrowser3 && window.navigator.maxTouchPoints > 1; 26485 } 26486 function supportsPointerEvents() { 26487 return isBrowser3 && "onpointerdown" in window; 26488 } 26489 function supportsPointerLock() { 26490 return isBrowser3 && "exitPointerLock" in window.document; 26491 } 26492 function supportsGestureEvents() { 26493 try { 26494 return "constructor" in GestureEvent; 26495 } catch (e3) { 26496 return false; 26497 } 26498 } 26499 var SUPPORT = { 26500 isBrowser: isBrowser3, 26501 gesture: supportsGestureEvents(), 26502 touch: supportsTouchEvents(), 26503 touchscreen: isTouchScreen(), 26504 pointer: supportsPointerEvents(), 26505 pointerLock: supportsPointerLock() 26506 }; 26507 var DEFAULT_PREVENT_SCROLL_DELAY = 250; 26508 var DEFAULT_DRAG_DELAY = 180; 26509 var DEFAULT_SWIPE_VELOCITY = 0.5; 26510 var DEFAULT_SWIPE_DISTANCE = 50; 26511 var DEFAULT_SWIPE_DURATION = 250; 26512 var DEFAULT_KEYBOARD_DISPLACEMENT = 10; 26513 var DEFAULT_DRAG_AXIS_THRESHOLD = { 26514 mouse: 0, 26515 touch: 0, 26516 pen: 8 26517 }; 26518 var dragConfigResolver = _objectSpread2(_objectSpread2({}, coordinatesConfigResolver), {}, { 26519 device(_v, _k, { 26520 pointer: { 26521 touch = false, 26522 lock: lock2 = false, 26523 mouse = false 26524 } = {} 26525 }) { 26526 this.pointerLock = lock2 && SUPPORT.pointerLock; 26527 if (SUPPORT.touch && touch) return "touch"; 26528 if (this.pointerLock) return "mouse"; 26529 if (SUPPORT.pointer && !mouse) return "pointer"; 26530 if (SUPPORT.touch) return "touch"; 26531 return "mouse"; 26532 }, 26533 preventScrollAxis(value, _k, { 26534 preventScroll 26535 }) { 26536 this.preventScrollDelay = typeof preventScroll === "number" ? preventScroll : preventScroll || preventScroll === void 0 && value ? DEFAULT_PREVENT_SCROLL_DELAY : void 0; 26537 if (!SUPPORT.touchscreen || preventScroll === false) return void 0; 26538 return value ? value : preventScroll !== void 0 ? "y" : void 0; 26539 }, 26540 pointerCapture(_v, _k, { 26541 pointer: { 26542 capture = true, 26543 buttons = 1, 26544 keys = true 26545 } = {} 26546 }) { 26547 this.pointerButtons = buttons; 26548 this.keys = keys; 26549 return !this.pointerLock && this.device === "pointer" && capture; 26550 }, 26551 threshold(value, _k, { 26552 filterTaps = false, 26553 tapsThreshold = 3, 26554 axis = void 0 26555 }) { 26556 const threshold = V.toVector(value, filterTaps ? tapsThreshold : axis ? 1 : 0); 26557 this.filterTaps = filterTaps; 26558 this.tapsThreshold = tapsThreshold; 26559 return threshold; 26560 }, 26561 swipe({ 26562 velocity = DEFAULT_SWIPE_VELOCITY, 26563 distance: distance2 = DEFAULT_SWIPE_DISTANCE, 26564 duration = DEFAULT_SWIPE_DURATION 26565 } = {}) { 26566 return { 26567 velocity: this.transform(V.toVector(velocity)), 26568 distance: this.transform(V.toVector(distance2)), 26569 duration 26570 }; 26571 }, 26572 delay(value = 0) { 26573 switch (value) { 26574 case true: 26575 return DEFAULT_DRAG_DELAY; 26576 case false: 26577 return 0; 26578 default: 26579 return value; 26580 } 26581 }, 26582 axisThreshold(value) { 26583 if (!value) return DEFAULT_DRAG_AXIS_THRESHOLD; 26584 return _objectSpread2(_objectSpread2({}, DEFAULT_DRAG_AXIS_THRESHOLD), value); 26585 }, 26586 keyboardDisplacement(value = DEFAULT_KEYBOARD_DISPLACEMENT) { 26587 return value; 26588 } 26589 }); 26590 if (true) { 26591 Object.assign(dragConfigResolver, { 26592 useTouch(value) { 26593 if (value !== void 0) { 26594 throw Error(`[@use-gesture]: \`useTouch\` option has been renamed to \`pointer.touch\`. Use it as in \`{ pointer: { touch: true } }\`.`); 26595 } 26596 return NaN; 26597 }, 26598 experimental_preventWindowScrollY(value) { 26599 if (value !== void 0) { 26600 throw Error(`[@use-gesture]: \`experimental_preventWindowScrollY\` option has been renamed to \`preventScroll\`.`); 26601 } 26602 return NaN; 26603 }, 26604 swipeVelocity(value) { 26605 if (value !== void 0) { 26606 throw Error(`[@use-gesture]: \`swipeVelocity\` option has been renamed to \`swipe.velocity\`. Use it as in \`{ swipe: { velocity: 0.5 } }\`.`); 26607 } 26608 return NaN; 26609 }, 26610 swipeDistance(value) { 26611 if (value !== void 0) { 26612 throw Error(`[@use-gesture]: \`swipeDistance\` option has been renamed to \`swipe.distance\`. Use it as in \`{ swipe: { distance: 50 } }\`.`); 26613 } 26614 return NaN; 26615 }, 26616 swipeDuration(value) { 26617 if (value !== void 0) { 26618 throw Error(`[@use-gesture]: \`swipeDuration\` option has been renamed to \`swipe.duration\`. Use it as in \`{ swipe: { duration: 250 } }\`.`); 26619 } 26620 return NaN; 26621 } 26622 }); 26623 } 26624 var pinchConfigResolver = _objectSpread2(_objectSpread2({}, commonConfigResolver), {}, { 26625 device(_v, _k, { 26626 shared, 26627 pointer: { 26628 touch = false 26629 } = {} 26630 }) { 26631 const sharedConfig = shared; 26632 if (sharedConfig.target && !SUPPORT.touch && SUPPORT.gesture) return "gesture"; 26633 if (SUPPORT.touch && touch) return "touch"; 26634 if (SUPPORT.touchscreen) { 26635 if (SUPPORT.pointer) return "pointer"; 26636 if (SUPPORT.touch) return "touch"; 26637 } 26638 }, 26639 bounds(_v, _k, { 26640 scaleBounds = {}, 26641 angleBounds = {} 26642 }) { 26643 const _scaleBounds = (state) => { 26644 const D2 = assignDefault(call(scaleBounds, state), { 26645 min: -Infinity, 26646 max: Infinity 26647 }); 26648 return [D2.min, D2.max]; 26649 }; 26650 const _angleBounds = (state) => { 26651 const A2 = assignDefault(call(angleBounds, state), { 26652 min: -Infinity, 26653 max: Infinity 26654 }); 26655 return [A2.min, A2.max]; 26656 }; 26657 if (typeof scaleBounds !== "function" && typeof angleBounds !== "function") return [_scaleBounds(), _angleBounds()]; 26658 return (state) => [_scaleBounds(state), _angleBounds(state)]; 26659 }, 26660 threshold(value, _k, config) { 26661 this.lockDirection = config.axis === "lock"; 26662 const threshold = V.toVector(value, this.lockDirection ? [0.1, 3] : 0); 26663 return threshold; 26664 }, 26665 modifierKey(value) { 26666 if (value === void 0) return "ctrlKey"; 26667 return value; 26668 }, 26669 pinchOnWheel(value = true) { 26670 return value; 26671 } 26672 }); 26673 var moveConfigResolver = _objectSpread2(_objectSpread2({}, coordinatesConfigResolver), {}, { 26674 mouseOnly: (value = true) => value 26675 }); 26676 var hoverConfigResolver = _objectSpread2(_objectSpread2({}, coordinatesConfigResolver), {}, { 26677 mouseOnly: (value = true) => value 26678 }); 26679 var EngineMap = /* @__PURE__ */ new Map(); 26680 var ConfigResolverMap = /* @__PURE__ */ new Map(); 26681 function registerAction(action) { 26682 EngineMap.set(action.key, action.engine); 26683 ConfigResolverMap.set(action.key, action.resolver); 26684 } 26685 var dragAction = { 26686 key: "drag", 26687 engine: DragEngine, 26688 resolver: dragConfigResolver 26689 }; 26690 26691 // node_modules/@use-gesture/react/dist/use-gesture-react.esm.js 26692 var import_react94 = __toESM(require_react()); 26693 26694 // node_modules/@use-gesture/core/dist/use-gesture-core.esm.js 26695 function _objectWithoutPropertiesLoose(source, excluded) { 26696 if (source == null) return {}; 26697 var target = {}; 26698 var sourceKeys = Object.keys(source); 26699 var key, i3; 26700 for (i3 = 0; i3 < sourceKeys.length; i3++) { 26701 key = sourceKeys[i3]; 26702 if (excluded.indexOf(key) >= 0) continue; 26703 target[key] = source[key]; 26704 } 26705 return target; 26706 } 26707 function _objectWithoutProperties(source, excluded) { 26708 if (source == null) return {}; 26709 var target = _objectWithoutPropertiesLoose(source, excluded); 26710 var key, i3; 26711 if (Object.getOwnPropertySymbols) { 26712 var sourceSymbolKeys = Object.getOwnPropertySymbols(source); 26713 for (i3 = 0; i3 < sourceSymbolKeys.length; i3++) { 26714 key = sourceSymbolKeys[i3]; 26715 if (excluded.indexOf(key) >= 0) continue; 26716 if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; 26717 target[key] = source[key]; 26718 } 26719 } 26720 return target; 26721 } 26722 var sharedConfigResolver = { 26723 target(value) { 26724 if (value) { 26725 return () => "current" in value ? value.current : value; 26726 } 26727 return void 0; 26728 }, 26729 enabled(value = true) { 26730 return value; 26731 }, 26732 window(value = SUPPORT.isBrowser ? window : void 0) { 26733 return value; 26734 }, 26735 eventOptions({ 26736 passive = true, 26737 capture = false 26738 } = {}) { 26739 return { 26740 passive, 26741 capture 26742 }; 26743 }, 26744 transform(value) { 26745 return value; 26746 } 26747 }; 26748 var _excluded = ["target", "eventOptions", "window", "enabled", "transform"]; 26749 function resolveWith(config = {}, resolvers) { 26750 const result = {}; 26751 for (const [key, resolver] of Object.entries(resolvers)) { 26752 switch (typeof resolver) { 26753 case "function": 26754 if (true) { 26755 const r4 = resolver.call(result, config[key], key, config); 26756 if (!Number.isNaN(r4)) result[key] = r4; 26757 } else { 26758 result[key] = resolver.call(result, config[key], key, config); 26759 } 26760 break; 26761 case "object": 26762 result[key] = resolveWith(config[key], resolver); 26763 break; 26764 case "boolean": 26765 if (resolver) result[key] = config[key]; 26766 break; 26767 } 26768 } 26769 return result; 26770 } 26771 function parse2(newConfig, gestureKey, _config = {}) { 26772 const _ref11 = newConfig, { 26773 target, 26774 eventOptions, 26775 window: window2, 26776 enabled, 26777 transform 26778 } = _ref11, rest = _objectWithoutProperties(_ref11, _excluded); 26779 _config.shared = resolveWith({ 26780 target, 26781 eventOptions, 26782 window: window2, 26783 enabled, 26784 transform 26785 }, sharedConfigResolver); 26786 if (gestureKey) { 26787 const resolver = ConfigResolverMap.get(gestureKey); 26788 _config[gestureKey] = resolveWith(_objectSpread2({ 26789 shared: _config.shared 26790 }, rest), resolver); 26791 } else { 26792 for (const key in rest) { 26793 const resolver = ConfigResolverMap.get(key); 26794 if (resolver) { 26795 _config[key] = resolveWith(_objectSpread2({ 26796 shared: _config.shared 26797 }, rest[key]), resolver); 26798 } else if (true) { 26799 if (!["drag", "pinch", "scroll", "wheel", "move", "hover"].includes(key)) { 26800 if (key === "domTarget") { 26801 throw Error(`[@use-gesture]: \`domTarget\` option has been renamed to \`target\`.`); 26802 } 26803 console.warn(`[@use-gesture]: Unknown config key \`$key}\` was used. Please read the documentation for further information.`); 26804 } 26805 } 26806 } 26807 } 26808 return _config; 26809 } 26810 var EventStore = class { 26811 constructor(ctrl, gestureKey) { 26812 _defineProperty(this, "_listeners", /* @__PURE__ */ new Set()); 26813 this._ctrl = ctrl; 26814 this._gestureKey = gestureKey; 26815 } 26816 add(element, device, action, handler, options2) { 26817 const listeners = this._listeners; 26818 const type = toDomEventType(device, action); 26819 const _options = this._gestureKey ? this._ctrl.config[this._gestureKey].eventOptions : {}; 26820 const eventOptions = _objectSpread2(_objectSpread2({}, _options), options2); 26821 element.addEventListener(type, handler, eventOptions); 26822 const remove = () => { 26823 element.removeEventListener(type, handler, eventOptions); 26824 listeners.delete(remove); 26825 }; 26826 listeners.add(remove); 26827 return remove; 26828 } 26829 clean() { 26830 this._listeners.forEach((remove) => remove()); 26831 this._listeners.clear(); 26832 } 26833 }; 26834 var TimeoutStore = class { 26835 constructor() { 26836 _defineProperty(this, "_timeouts", /* @__PURE__ */ new Map()); 26837 } 26838 add(key, callback, ms = 140, ...args) { 26839 this.remove(key); 26840 this._timeouts.set(key, window.setTimeout(callback, ms, ...args)); 26841 } 26842 remove(key) { 26843 const timeout = this._timeouts.get(key); 26844 if (timeout) window.clearTimeout(timeout); 26845 } 26846 clean() { 26847 this._timeouts.forEach((timeout) => void window.clearTimeout(timeout)); 26848 this._timeouts.clear(); 26849 } 26850 }; 26851 var Controller = class { 26852 constructor(handlers) { 26853 _defineProperty(this, "gestures", /* @__PURE__ */ new Set()); 26854 _defineProperty(this, "_targetEventStore", new EventStore(this)); 26855 _defineProperty(this, "gestureEventStores", {}); 26856 _defineProperty(this, "gestureTimeoutStores", {}); 26857 _defineProperty(this, "handlers", {}); 26858 _defineProperty(this, "config", {}); 26859 _defineProperty(this, "pointerIds", /* @__PURE__ */ new Set()); 26860 _defineProperty(this, "touchIds", /* @__PURE__ */ new Set()); 26861 _defineProperty(this, "state", { 26862 shared: { 26863 shiftKey: false, 26864 metaKey: false, 26865 ctrlKey: false, 26866 altKey: false 26867 } 26868 }); 26869 resolveGestures(this, handlers); 26870 } 26871 setEventIds(event) { 26872 if (isTouch(event)) { 26873 this.touchIds = new Set(touchIds(event)); 26874 return this.touchIds; 26875 } else if ("pointerId" in event) { 26876 if (event.type === "pointerup" || event.type === "pointercancel") this.pointerIds.delete(event.pointerId); 26877 else if (event.type === "pointerdown") this.pointerIds.add(event.pointerId); 26878 return this.pointerIds; 26879 } 26880 } 26881 applyHandlers(handlers, nativeHandlers) { 26882 this.handlers = handlers; 26883 this.nativeHandlers = nativeHandlers; 26884 } 26885 applyConfig(config, gestureKey) { 26886 this.config = parse2(config, gestureKey, this.config); 26887 } 26888 clean() { 26889 this._targetEventStore.clean(); 26890 for (const key of this.gestures) { 26891 this.gestureEventStores[key].clean(); 26892 this.gestureTimeoutStores[key].clean(); 26893 } 26894 } 26895 effect() { 26896 if (this.config.shared.target) this.bind(); 26897 return () => this._targetEventStore.clean(); 26898 } 26899 bind(...args) { 26900 const sharedConfig = this.config.shared; 26901 const props = {}; 26902 let target; 26903 if (sharedConfig.target) { 26904 target = sharedConfig.target(); 26905 if (!target) return; 26906 } 26907 if (sharedConfig.enabled) { 26908 for (const gestureKey of this.gestures) { 26909 const gestureConfig = this.config[gestureKey]; 26910 const bindFunction = bindToProps(props, gestureConfig.eventOptions, !!target); 26911 if (gestureConfig.enabled) { 26912 const Engine2 = EngineMap.get(gestureKey); 26913 new Engine2(this, args, gestureKey).bind(bindFunction); 26914 } 26915 } 26916 const nativeBindFunction = bindToProps(props, sharedConfig.eventOptions, !!target); 26917 for (const eventKey in this.nativeHandlers) { 26918 nativeBindFunction(eventKey, "", (event) => this.nativeHandlers[eventKey](_objectSpread2(_objectSpread2({}, this.state.shared), {}, { 26919 event, 26920 args 26921 })), void 0, true); 26922 } 26923 } 26924 for (const handlerProp in props) { 26925 props[handlerProp] = chain2(...props[handlerProp]); 26926 } 26927 if (!target) return props; 26928 for (const handlerProp in props) { 26929 const { 26930 device, 26931 capture, 26932 passive 26933 } = parseProp(handlerProp); 26934 this._targetEventStore.add(target, device, "", props[handlerProp], { 26935 capture, 26936 passive 26937 }); 26938 } 26939 } 26940 }; 26941 function setupGesture2(ctrl, gestureKey) { 26942 ctrl.gestures.add(gestureKey); 26943 ctrl.gestureEventStores[gestureKey] = new EventStore(ctrl, gestureKey); 26944 ctrl.gestureTimeoutStores[gestureKey] = new TimeoutStore(); 26945 } 26946 function resolveGestures(ctrl, internalHandlers) { 26947 if (internalHandlers.drag) setupGesture2(ctrl, "drag"); 26948 if (internalHandlers.wheel) setupGesture2(ctrl, "wheel"); 26949 if (internalHandlers.scroll) setupGesture2(ctrl, "scroll"); 26950 if (internalHandlers.move) setupGesture2(ctrl, "move"); 26951 if (internalHandlers.pinch) setupGesture2(ctrl, "pinch"); 26952 if (internalHandlers.hover) setupGesture2(ctrl, "hover"); 26953 } 26954 var bindToProps = (props, eventOptions, withPassiveOption) => (device, action, handler, options2 = {}, isNative = false) => { 26955 var _options$capture, _options$passive; 26956 const capture = (_options$capture = options2.capture) !== null && _options$capture !== void 0 ? _options$capture : eventOptions.capture; 26957 const passive = (_options$passive = options2.passive) !== null && _options$passive !== void 0 ? _options$passive : eventOptions.passive; 26958 let handlerProp = isNative ? device : toHandlerProp(device, action, capture); 26959 if (withPassiveOption && passive) handlerProp += "Passive"; 26960 props[handlerProp] = props[handlerProp] || []; 26961 props[handlerProp].push(handler); 26962 }; 26963 26964 // node_modules/@use-gesture/react/dist/use-gesture-react.esm.js 26965 function useRecognizers(handlers, config = {}, gestureKey, nativeHandlers) { 26966 const ctrl = import_react94.default.useMemo(() => new Controller(handlers), []); 26967 ctrl.applyHandlers(handlers, nativeHandlers); 26968 ctrl.applyConfig(config, gestureKey); 26969 import_react94.default.useEffect(ctrl.effect.bind(ctrl)); 26970 import_react94.default.useEffect(() => { 26971 return ctrl.clean.bind(ctrl); 26972 }, []); 26973 if (config.target === void 0) { 26974 return ctrl.bind.bind(ctrl); 26975 } 26976 return void 0; 26977 } 26978 function useDrag(handler, config) { 26979 registerAction(dragAction); 26980 return useRecognizers({ 26981 drag: handler 26982 }, config || {}, "drag"); 26983 } 26984 26985 // packages/components/build-module/input-control/input-field.js 26986 var import_element29 = __toESM(require_element()); 26987 26988 // packages/components/build-module/input-control/utils.js 26989 var import_element27 = __toESM(require_element()); 26990 function getDragCursor(dragDirection) { 26991 let dragCursor = "ns-resize"; 26992 switch (dragDirection) { 26993 case "n": 26994 case "s": 26995 dragCursor = "ns-resize"; 26996 break; 26997 case "e": 26998 case "w": 26999 dragCursor = "ew-resize"; 27000 break; 27001 } 27002 return dragCursor; 27003 } 27004 function useDragCursor(isDragging2, dragDirection) { 27005 const dragCursor = getDragCursor(dragDirection); 27006 (0, import_element27.useEffect)(() => { 27007 if (isDragging2) { 27008 document.documentElement.style.cursor = dragCursor; 27009 } else { 27010 document.documentElement.style.cursor = null; 27011 } 27012 }, [isDragging2, dragCursor]); 27013 return dragCursor; 27014 } 27015 function useDraft(props) { 27016 const previousValueRef = (0, import_element27.useRef)(props.value); 27017 const [draft, setDraft] = (0, import_element27.useState)({}); 27018 const value = draft.value !== void 0 ? draft.value : props.value; 27019 (0, import_element27.useLayoutEffect)(() => { 27020 const { 27021 current: previousValue 27022 } = previousValueRef; 27023 previousValueRef.current = props.value; 27024 if (draft.value !== void 0 && !draft.isStale) { 27025 setDraft({ 27026 ...draft, 27027 isStale: true 27028 }); 27029 } else if (draft.isStale && props.value !== previousValue) { 27030 setDraft({}); 27031 } 27032 }, [props.value, draft]); 27033 const onChange = (nextValue, extra) => { 27034 setDraft((current) => Object.assign(current, { 27035 value: nextValue, 27036 isStale: false 27037 })); 27038 props.onChange(nextValue, extra); 27039 }; 27040 const onBlur = (event) => { 27041 setDraft({}); 27042 props.onBlur?.(event); 27043 }; 27044 return { 27045 value, 27046 onBlur, 27047 onChange 27048 }; 27049 } 27050 27051 // packages/components/build-module/input-control/reducer/reducer.js 27052 var import_element28 = __toESM(require_element()); 27053 27054 // packages/components/build-module/input-control/reducer/state.js 27055 var initialStateReducer = (state) => state; 27056 var initialInputControlState = { 27057 error: null, 27058 initialValue: "", 27059 isDirty: false, 27060 isDragEnabled: false, 27061 isDragging: false, 27062 isPressEnterToChange: false, 27063 value: "" 27064 }; 27065 27066 // packages/components/build-module/input-control/reducer/actions.js 27067 var CHANGE = "CHANGE"; 27068 var COMMIT = "COMMIT"; 27069 var CONTROL = "CONTROL"; 27070 var DRAG_END = "DRAG_END"; 27071 var DRAG_START = "DRAG_START"; 27072 var DRAG = "DRAG"; 27073 var INVALIDATE = "INVALIDATE"; 27074 var PRESS_DOWN = "PRESS_DOWN"; 27075 var PRESS_ENTER = "PRESS_ENTER"; 27076 var PRESS_UP = "PRESS_UP"; 27077 var RESET = "RESET"; 27078 27079 // packages/components/build-module/input-control/reducer/reducer.js 27080 function mergeInitialState(initialState = initialInputControlState) { 27081 const { 27082 value 27083 } = initialState; 27084 return { 27085 ...initialInputControlState, 27086 ...initialState, 27087 initialValue: value 27088 }; 27089 } 27090 function inputControlStateReducer(composedStateReducers) { 27091 return (state, action) => { 27092 const nextState = { 27093 ...state 27094 }; 27095 switch (action.type) { 27096 /* 27097 * Controlled updates 27098 */ 27099 case CONTROL: 27100 nextState.value = action.payload.value; 27101 nextState.isDirty = false; 27102 nextState._event = void 0; 27103 return nextState; 27104 /** 27105 * Keyboard events 27106 */ 27107 case PRESS_UP: 27108 nextState.isDirty = false; 27109 break; 27110 case PRESS_DOWN: 27111 nextState.isDirty = false; 27112 break; 27113 /** 27114 * Drag events 27115 */ 27116 case DRAG_START: 27117 nextState.isDragging = true; 27118 break; 27119 case DRAG_END: 27120 nextState.isDragging = false; 27121 break; 27122 /** 27123 * Input events 27124 */ 27125 case CHANGE: 27126 nextState.error = null; 27127 nextState.value = action.payload.value; 27128 if (state.isPressEnterToChange) { 27129 nextState.isDirty = true; 27130 } 27131 break; 27132 case COMMIT: 27133 nextState.value = action.payload.value; 27134 nextState.isDirty = false; 27135 break; 27136 case RESET: 27137 nextState.error = null; 27138 nextState.isDirty = false; 27139 nextState.value = action.payload.value || state.initialValue; 27140 break; 27141 /** 27142 * Validation 27143 */ 27144 case INVALIDATE: 27145 nextState.error = action.payload.error; 27146 break; 27147 } 27148 nextState._event = action.payload.event; 27149 return composedStateReducers(nextState, action); 27150 }; 27151 } 27152 function useInputControlStateReducer(stateReducer = initialStateReducer, initialState = initialInputControlState, onChangeHandler) { 27153 const [state, dispatch] = (0, import_element28.useReducer)(inputControlStateReducer(stateReducer), mergeInitialState(initialState)); 27154 const createChangeEvent = (type) => (nextValue, event) => { 27155 dispatch({ 27156 type, 27157 payload: { 27158 value: nextValue, 27159 event 27160 } 27161 }); 27162 }; 27163 const createKeyEvent = (type) => (event) => { 27164 dispatch({ 27165 type, 27166 payload: { 27167 event 27168 } 27169 }); 27170 }; 27171 const createDragEvent = (type) => (payload) => { 27172 dispatch({ 27173 type, 27174 payload 27175 }); 27176 }; 27177 const change = createChangeEvent(CHANGE); 27178 const invalidate = (error, event) => dispatch({ 27179 type: INVALIDATE, 27180 payload: { 27181 error, 27182 event 27183 } 27184 }); 27185 const reset = createChangeEvent(RESET); 27186 const commit = createChangeEvent(COMMIT); 27187 const dragStart = createDragEvent(DRAG_START); 27188 const drag2 = createDragEvent(DRAG); 27189 const dragEnd = createDragEvent(DRAG_END); 27190 const pressUp = createKeyEvent(PRESS_UP); 27191 const pressDown = createKeyEvent(PRESS_DOWN); 27192 const pressEnter = createKeyEvent(PRESS_ENTER); 27193 const currentStateRef = (0, import_element28.useRef)(state); 27194 const refPropsRef = (0, import_element28.useRef)({ 27195 value: initialState.value, 27196 onChangeHandler 27197 }); 27198 (0, import_element28.useLayoutEffect)(() => { 27199 currentStateRef.current = state; 27200 refPropsRef.current = { 27201 value: initialState.value, 27202 onChangeHandler 27203 }; 27204 }); 27205 (0, import_element28.useLayoutEffect)(() => { 27206 if (currentStateRef.current._event !== void 0 && state.value !== refPropsRef.current.value && !state.isDirty) { 27207 var _state$value; 27208 refPropsRef.current.onChangeHandler((_state$value = state.value) !== null && _state$value !== void 0 ? _state$value : "", { 27209 event: currentStateRef.current._event 27210 }); 27211 } 27212 }, [state.value, state.isDirty]); 27213 (0, import_element28.useLayoutEffect)(() => { 27214 if (initialState.value !== currentStateRef.current.value && !currentStateRef.current.isDirty) { 27215 var _initialState$value; 27216 dispatch({ 27217 type: CONTROL, 27218 payload: { 27219 value: (_initialState$value = initialState.value) !== null && _initialState$value !== void 0 ? _initialState$value : "" 27220 } 27221 }); 27222 } 27223 }, [initialState.value]); 27224 return { 27225 change, 27226 commit, 27227 dispatch, 27228 drag: drag2, 27229 dragEnd, 27230 dragStart, 27231 invalidate, 27232 pressDown, 27233 pressEnter, 27234 pressUp, 27235 reset, 27236 state 27237 }; 27238 } 27239 27240 // packages/components/build-module/utils/with-ignore-ime-events.js 27241 function withIgnoreIMEEvents(handler) { 27242 return (event) => { 27243 const { 27244 isComposing 27245 } = "nativeEvent" in event ? event.nativeEvent : event; 27246 if (isComposing || // Workaround for Mac Safari where the final Enter/Backspace of an IME composition 27247 // is `isComposing=false`, even though it's technically still part of the composition. 27248 // These can only be detected by keyCode. 27249 event.keyCode === 229) { 27250 return; 27251 } 27252 handler(event); 27253 }; 27254 } 27255 27256 // packages/components/build-module/input-control/input-field.js 27257 var import_jsx_runtime90 = __toESM(require_jsx_runtime()); 27258 var noop4 = () => { 27259 }; 27260 function InputField({ 27261 disabled = false, 27262 dragDirection = "n", 27263 dragThreshold = 10, 27264 id: id3, 27265 isDragEnabled = false, 27266 isPressEnterToChange = false, 27267 onBlur = noop4, 27268 onChange = noop4, 27269 onDrag = noop4, 27270 onDragEnd = noop4, 27271 onDragStart = noop4, 27272 onKeyDown = noop4, 27273 onValidate = noop4, 27274 size: size3 = "default", 27275 stateReducer = (state) => state, 27276 value: valueProp, 27277 type, 27278 ...props 27279 }, ref) { 27280 const { 27281 // State. 27282 state, 27283 // Actions. 27284 change, 27285 commit, 27286 drag: drag2, 27287 dragEnd, 27288 dragStart, 27289 invalidate, 27290 pressDown, 27291 pressEnter, 27292 pressUp, 27293 reset 27294 } = useInputControlStateReducer(stateReducer, { 27295 isDragEnabled, 27296 value: valueProp, 27297 isPressEnterToChange 27298 }, onChange); 27299 const { 27300 value, 27301 isDragging: isDragging2, 27302 isDirty 27303 } = state; 27304 const wasDirtyOnBlur = (0, import_element29.useRef)(false); 27305 const dragCursor = useDragCursor(isDragging2, dragDirection); 27306 const handleOnBlur = (event) => { 27307 onBlur(event); 27308 if (isDirty || !event.target.validity.valid) { 27309 wasDirtyOnBlur.current = true; 27310 handleOnCommit(event); 27311 } 27312 }; 27313 const handleOnChange = (event) => { 27314 const nextValue = event.target.value; 27315 change(nextValue, event); 27316 }; 27317 const handleOnCommit = (event) => { 27318 const nextValue = event.currentTarget.value; 27319 try { 27320 onValidate(nextValue); 27321 commit(nextValue, event); 27322 } catch (err) { 27323 invalidate(err, event); 27324 } 27325 }; 27326 const handleOnKeyDown = (event) => { 27327 const { 27328 key 27329 } = event; 27330 onKeyDown(event); 27331 switch (key) { 27332 case "ArrowUp": 27333 pressUp(event); 27334 break; 27335 case "ArrowDown": 27336 pressDown(event); 27337 break; 27338 case "Enter": 27339 pressEnter(event); 27340 if (isPressEnterToChange) { 27341 event.preventDefault(); 27342 handleOnCommit(event); 27343 } 27344 break; 27345 case "Escape": 27346 if (isPressEnterToChange && isDirty) { 27347 event.preventDefault(); 27348 reset(valueProp, event); 27349 } 27350 break; 27351 } 27352 }; 27353 const dragGestureProps = useDrag((dragProps2) => { 27354 const { 27355 distance: distance2, 27356 dragging, 27357 event, 27358 target 27359 } = dragProps2; 27360 dragProps2.event = { 27361 ...dragProps2.event, 27362 target 27363 }; 27364 if (!distance2) { 27365 return; 27366 } 27367 event.stopPropagation(); 27368 if (!dragging) { 27369 onDragEnd(dragProps2); 27370 dragEnd(dragProps2); 27371 return; 27372 } 27373 onDrag(dragProps2); 27374 drag2(dragProps2); 27375 if (!isDragging2) { 27376 onDragStart(dragProps2); 27377 dragStart(dragProps2); 27378 } 27379 }, { 27380 axis: dragDirection === "e" || dragDirection === "w" ? "x" : "y", 27381 threshold: dragThreshold, 27382 enabled: isDragEnabled, 27383 pointer: { 27384 capture: false 27385 } 27386 }); 27387 const dragProps = isDragEnabled ? dragGestureProps() : {}; 27388 return /* @__PURE__ */ (0, import_jsx_runtime90.jsx)(Input, { 27389 ...props, 27390 ...dragProps, 27391 className: "components-input-control__input", 27392 disabled, 27393 dragCursor, 27394 isDragging: isDragging2, 27395 id: id3, 27396 onBlur: handleOnBlur, 27397 onChange: handleOnChange, 27398 onKeyDown: withIgnoreIMEEvents(handleOnKeyDown), 27399 ref, 27400 inputSize: size3, 27401 value: value !== null && value !== void 0 ? value : "", 27402 type 27403 }); 27404 } 27405 var ForwardedComponent = (0, import_element29.forwardRef)(InputField); 27406 var input_field_default = ForwardedComponent; 27407 27408 // packages/components/build-module/base-control/index.js 27409 var import_element30 = __toESM(require_element()); 27410 27411 // packages/components/build-module/base-control/styles/base-control-styles.js 27412 function _EMOTION_STRINGIFIED_CSS_ERROR__7() { 27413 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 27414 } 27415 var Wrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 27416 target: "ej5x27r4" 27417 } : { 27418 target: "ej5x27r4", 27419 label: "Wrapper" 27420 })("font-family:", font("default.fontFamily"), ";font-size:", font("default.fontSize"), ";", boxSizingReset, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWWlDIiwiZmlsZSI6ImJhc2UtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGJhc2VMYWJlbFR5cG9ncmFwaHksIGJveFNpemluZ1Jlc2V0LCBmb250LCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRTaXplJyApIH07XG5cblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEZpZWxkID0gc3R5bGVkLmRpdmBcblx0LmNvbXBvbmVudHMtcGFuZWxfX3JvdyAmIHtcblx0XHRtYXJnaW4tYm90dG9tOiBpbmhlcml0O1xuXHR9XG5gO1xuXG5jb25zdCBsYWJlbFN0eWxlcyA9IGNzc2Bcblx0JHsgYmFzZUxhYmVsVHlwb2dyYXBoeSB9O1xuXG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggMiApIH07XG5cdC8qKlxuXHQgKiBSZW1vdmVzIENocm9tZS9TYWZhcmkvRmlyZWZveCB1c2VyIGFnZW50IHN0eWxlc2hlZXQgcGFkZGluZyBmcm9tXG5cdCAqIFN0eWxlZExhYmVsIHdoZW4gaXQgaXMgcmVuZGVyZWQgYXMgYSBsZWdlbmQuXG5cdCAqL1xuXHRwYWRkaW5nOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZExhYmVsID0gc3R5bGVkLmxhYmVsYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSGVscCA9IHN0eWxlZC5wYFxuXHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2hlbHBUZXh0LmZvbnRTaXplJyApIH07XG5cdGZvbnQtc3R5bGU6IG5vcm1hbDtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFZpc3VhbExhYmVsID0gc3R5bGVkLnNwYW5gXG5cdCR7IGxhYmVsU3R5bGVzIH1cbmA7XG4iXX0= */")); 27421 var StyledField = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 27422 target: "ej5x27r3" 27423 } : { 27424 target: "ej5x27r3", 27425 label: "StyledField" 27426 })(false ? { 27427 name: "1chyuqs", 27428 styles: ".components-panel__row &{margin-bottom:inherit;}" 27429 } : { 27430 name: "1chyuqs", 27431 styles: ".components-panel__row &{margin-bottom:inherit;}", 27432 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJxQyIsImZpbGUiOiJiYXNlLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBiYXNlTGFiZWxUeXBvZ3JhcGh5LCBib3hTaXppbmdSZXNldCwgZm9udCwgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGaWVsZCA9IHN0eWxlZC5kaXZgXG5cdC5jb21wb25lbnRzLXBhbmVsX19yb3cgJiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogaW5oZXJpdDtcblx0fVxuYDtcblxuY29uc3QgbGFiZWxTdHlsZXMgPSBjc3NgXG5cdCR7IGJhc2VMYWJlbFR5cG9ncmFwaHkgfTtcblxuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHQvKipcblx0ICogUmVtb3ZlcyBDaHJvbWUvU2FmYXJpL0ZpcmVmb3ggdXNlciBhZ2VudCBzdHlsZXNoZWV0IHBhZGRpbmcgZnJvbVxuXHQgKiBTdHlsZWRMYWJlbCB3aGVuIGl0IGlzIHJlbmRlcmVkIGFzIGEgbGVnZW5kLlxuXHQgKi9cblx0cGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcblx0JHsgbGFiZWxTdHlsZXMgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlbHAgPSBzdHlsZWQucGBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRtYXJnaW4tYm90dG9tOiAwO1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdoZWxwVGV4dC5mb250U2l6ZScgKSB9O1xuXHRmb250LXN0eWxlOiBub3JtYWw7XG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRWaXN1YWxMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuIl19 */", 27433 toString: _EMOTION_STRINGIFIED_CSS_ERROR__7 27434 }); 27435 var labelStyles = /* @__PURE__ */ css(baseLabelTypography, ";display:block;margin-bottom:", space(2), ";padding:0;" + (false ? "" : ";label:labelStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJ1QiIsImZpbGUiOiJiYXNlLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBiYXNlTGFiZWxUeXBvZ3JhcGh5LCBib3hTaXppbmdSZXNldCwgZm9udCwgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGaWVsZCA9IHN0eWxlZC5kaXZgXG5cdC5jb21wb25lbnRzLXBhbmVsX19yb3cgJiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogaW5oZXJpdDtcblx0fVxuYDtcblxuY29uc3QgbGFiZWxTdHlsZXMgPSBjc3NgXG5cdCR7IGJhc2VMYWJlbFR5cG9ncmFwaHkgfTtcblxuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHQvKipcblx0ICogUmVtb3ZlcyBDaHJvbWUvU2FmYXJpL0ZpcmVmb3ggdXNlciBhZ2VudCBzdHlsZXNoZWV0IHBhZGRpbmcgZnJvbVxuXHQgKiBTdHlsZWRMYWJlbCB3aGVuIGl0IGlzIHJlbmRlcmVkIGFzIGEgbGVnZW5kLlxuXHQgKi9cblx0cGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcblx0JHsgbGFiZWxTdHlsZXMgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlbHAgPSBzdHlsZWQucGBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRtYXJnaW4tYm90dG9tOiAwO1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdoZWxwVGV4dC5mb250U2l6ZScgKSB9O1xuXHRmb250LXN0eWxlOiBub3JtYWw7XG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRWaXN1YWxMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuIl19 */"); 27436 var StyledLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default("label", false ? { 27437 target: "ej5x27r2" 27438 } : { 27439 target: "ej5x27r2", 27440 label: "StyledLabel" 27441 })(labelStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUN1QyIsImZpbGUiOiJiYXNlLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBiYXNlTGFiZWxUeXBvZ3JhcGh5LCBib3hTaXppbmdSZXNldCwgZm9udCwgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGaWVsZCA9IHN0eWxlZC5kaXZgXG5cdC5jb21wb25lbnRzLXBhbmVsX19yb3cgJiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogaW5oZXJpdDtcblx0fVxuYDtcblxuY29uc3QgbGFiZWxTdHlsZXMgPSBjc3NgXG5cdCR7IGJhc2VMYWJlbFR5cG9ncmFwaHkgfTtcblxuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHQvKipcblx0ICogUmVtb3ZlcyBDaHJvbWUvU2FmYXJpL0ZpcmVmb3ggdXNlciBhZ2VudCBzdHlsZXNoZWV0IHBhZGRpbmcgZnJvbVxuXHQgKiBTdHlsZWRMYWJlbCB3aGVuIGl0IGlzIHJlbmRlcmVkIGFzIGEgbGVnZW5kLlxuXHQgKi9cblx0cGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcblx0JHsgbGFiZWxTdHlsZXMgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlbHAgPSBzdHlsZWQucGBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRtYXJnaW4tYm90dG9tOiAwO1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdoZWxwVGV4dC5mb250U2l6ZScgKSB9O1xuXHRmb250LXN0eWxlOiBub3JtYWw7XG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRWaXN1YWxMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuIl19 */")); 27442 var StyledHelp = /* @__PURE__ */ emotion_styled_base_browser_esm_default("p", false ? { 27443 target: "ej5x27r1" 27444 } : { 27445 target: "ej5x27r1", 27446 label: "StyledHelp" 27447 })("margin-top:", space(2), ";margin-bottom:0;font-size:", font("helpText.fontSize"), ";font-style:normal;color:", COLORS.gray[700], ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUNrQyIsImZpbGUiOiJiYXNlLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBiYXNlTGFiZWxUeXBvZ3JhcGh5LCBib3hTaXppbmdSZXNldCwgZm9udCwgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGaWVsZCA9IHN0eWxlZC5kaXZgXG5cdC5jb21wb25lbnRzLXBhbmVsX19yb3cgJiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogaW5oZXJpdDtcblx0fVxuYDtcblxuY29uc3QgbGFiZWxTdHlsZXMgPSBjc3NgXG5cdCR7IGJhc2VMYWJlbFR5cG9ncmFwaHkgfTtcblxuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHQvKipcblx0ICogUmVtb3ZlcyBDaHJvbWUvU2FmYXJpL0ZpcmVmb3ggdXNlciBhZ2VudCBzdHlsZXNoZWV0IHBhZGRpbmcgZnJvbVxuXHQgKiBTdHlsZWRMYWJlbCB3aGVuIGl0IGlzIHJlbmRlcmVkIGFzIGEgbGVnZW5kLlxuXHQgKi9cblx0cGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcblx0JHsgbGFiZWxTdHlsZXMgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlbHAgPSBzdHlsZWQucGBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRtYXJnaW4tYm90dG9tOiAwO1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdoZWxwVGV4dC5mb250U2l6ZScgKSB9O1xuXHRmb250LXN0eWxlOiBub3JtYWw7XG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRWaXN1YWxMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuIl19 */")); 27448 var StyledVisualLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 27449 target: "ej5x27r0" 27450 } : { 27451 target: "ej5x27r0", 27452 label: "StyledVisualLabel" 27453 })(labelStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhc2UtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUQ0QyIsImZpbGUiOiJiYXNlLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBiYXNlTGFiZWxUeXBvZ3JhcGh5LCBib3hTaXppbmdSZXNldCwgZm9udCwgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRGaWVsZCA9IHN0eWxlZC5kaXZgXG5cdC5jb21wb25lbnRzLXBhbmVsX19yb3cgJiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogaW5oZXJpdDtcblx0fVxuYDtcblxuY29uc3QgbGFiZWxTdHlsZXMgPSBjc3NgXG5cdCR7IGJhc2VMYWJlbFR5cG9ncmFwaHkgfTtcblxuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHQvKipcblx0ICogUmVtb3ZlcyBDaHJvbWUvU2FmYXJpL0ZpcmVmb3ggdXNlciBhZ2VudCBzdHlsZXNoZWV0IHBhZGRpbmcgZnJvbVxuXHQgKiBTdHlsZWRMYWJlbCB3aGVuIGl0IGlzIHJlbmRlcmVkIGFzIGEgbGVnZW5kLlxuXHQgKi9cblx0cGFkZGluZzogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZC5sYWJlbGBcblx0JHsgbGFiZWxTdHlsZXMgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEhlbHAgPSBzdHlsZWQucGBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRtYXJnaW4tYm90dG9tOiAwO1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdoZWxwVGV4dC5mb250U2l6ZScgKSB9O1xuXHRmb250LXN0eWxlOiBub3JtYWw7XG5cdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRWaXN1YWxMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHQkeyBsYWJlbFN0eWxlcyB9XG5gO1xuIl19 */")); 27454 27455 // packages/components/build-module/base-control/index.js 27456 var import_jsx_runtime91 = __toESM(require_jsx_runtime()); 27457 27458 // packages/components/build-module/base-control/hooks.js 27459 var import_compose4 = __toESM(require_compose()); 27460 function useBaseControlProps(props) { 27461 const { 27462 help, 27463 id: preferredId, 27464 ...restProps 27465 } = props; 27466 const uniqueId3 = (0, import_compose4.useInstanceId)(base_control_default, "wp-components-base-control", preferredId); 27467 return { 27468 baseControlProps: { 27469 id: uniqueId3, 27470 help, 27471 ...restProps 27472 }, 27473 controlProps: { 27474 id: uniqueId3, 27475 ...!!help ? { 27476 "aria-describedby": `$uniqueId3}__help` 27477 } : {} 27478 } 27479 }; 27480 } 27481 27482 // packages/components/build-module/base-control/index.js 27483 var UnconnectedBaseControl = (props) => { 27484 const { 27485 id: id3, 27486 label, 27487 hideLabelFromVision = false, 27488 help, 27489 className: className2, 27490 children 27491 } = useContextSystem(props, "BaseControl"); 27492 return /* @__PURE__ */ (0, import_jsx_runtime91.jsxs)(Wrapper, { 27493 className: className2, 27494 children: [/* @__PURE__ */ (0, import_jsx_runtime91.jsxs)(StyledField, { 27495 className: "components-base-control__field", 27496 children: [label && id3 && (hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(component_default2, { 27497 as: "label", 27498 htmlFor: id3, 27499 children: label 27500 }) : /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(StyledLabel, { 27501 className: "components-base-control__label", 27502 htmlFor: id3, 27503 children: label 27504 })), label && !id3 && (hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(component_default2, { 27505 as: "label", 27506 children: label 27507 }) : /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(VisualLabel, { 27508 children: label 27509 })), children] 27510 }), !!help && /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(StyledHelp, { 27511 id: id3 ? id3 + "__help" : void 0, 27512 className: "components-base-control__help", 27513 children: help 27514 })] 27515 }); 27516 }; 27517 var UnforwardedVisualLabel = (props, ref) => { 27518 const { 27519 className: className2, 27520 children, 27521 ...restProps 27522 } = props; 27523 return /* @__PURE__ */ (0, import_jsx_runtime91.jsx)(StyledVisualLabel, { 27524 ref, 27525 ...restProps, 27526 className: clsx_default("components-base-control__label", className2), 27527 children 27528 }); 27529 }; 27530 var VisualLabel = (0, import_element30.forwardRef)(UnforwardedVisualLabel); 27531 var BaseControl = Object.assign(contextConnectWithoutRef(UnconnectedBaseControl, "BaseControl"), { 27532 /** 27533 * `BaseControl.VisualLabel` is used to render a purely visual label inside a `BaseControl` component. 27534 * 27535 * It should only be used in cases where the children being rendered inside `BaseControl` are already accessibly labeled, 27536 * e.g., a button, but we want an additional visual label for that section equivalent to the labels `BaseControl` would 27537 * otherwise use if the `label` prop was passed. 27538 * 27539 * ```jsx 27540 * import { BaseControl } from '@wordpress/components'; 27541 * 27542 * const MyBaseControl = () => ( 27543 * <BaseControl help="This button is already accessibly labeled."> 27544 * <BaseControl.VisualLabel>Author</BaseControl.VisualLabel> 27545 * <Button>Select an author</Button> 27546 * </BaseControl> 27547 * ); 27548 * ``` 27549 */ 27550 VisualLabel 27551 }); 27552 var base_control_default = BaseControl; 27553 27554 // packages/components/build-module/utils/deprecated-36px-size.js 27555 var import_deprecated3 = __toESM(require_deprecated()); 27556 function maybeWarnDeprecated36pxSize({ 27557 componentName, 27558 __next40pxDefaultSize, 27559 size: size3, 27560 __shouldNotWarnDeprecated36pxSize 27561 }) { 27562 if (__shouldNotWarnDeprecated36pxSize || __next40pxDefaultSize || size3 !== void 0 && size3 !== "default") { 27563 return; 27564 } 27565 (0, import_deprecated3.default)(`36px default size for wp.components.$componentName}`, { 27566 since: "6.8", 27567 version: "7.1", 27568 hint: "Set the `__next40pxDefaultSize` prop to true to start opting into the new default size, which will become the default in a future version." 27569 }); 27570 } 27571 27572 // packages/components/build-module/input-control/index.js 27573 var import_jsx_runtime92 = __toESM(require_jsx_runtime()); 27574 var noop5 = () => { 27575 }; 27576 function useUniqueId2(idProp) { 27577 const instanceId = (0, import_compose5.useInstanceId)(InputControl); 27578 const id3 = `inspector-input-control-$instanceId}`; 27579 return idProp || id3; 27580 } 27581 function UnforwardedInputControl(props, ref) { 27582 const { 27583 __next40pxDefaultSize, 27584 __shouldNotWarnDeprecated36pxSize, 27585 __unstableStateReducer: stateReducer = (state) => state, 27586 __unstableInputWidth, 27587 className: className2, 27588 disabled = false, 27589 help, 27590 hideLabelFromVision = false, 27591 id: idProp, 27592 isPressEnterToChange = false, 27593 label, 27594 labelPosition = "top", 27595 onChange = noop5, 27596 onValidate = noop5, 27597 onKeyDown = noop5, 27598 prefix: prefix2, 27599 size: size3 = "default", 27600 style: style2, 27601 suffix, 27602 value, 27603 ...restProps 27604 } = useDeprecated36pxDefaultSizeProp(props); 27605 const id3 = useUniqueId2(idProp); 27606 const classes = clsx_default("components-input-control", className2); 27607 const draftHookProps = useDraft({ 27608 value, 27609 onBlur: restProps.onBlur, 27610 onChange 27611 }); 27612 const helpProp = !!help ? { 27613 "aria-describedby": `$id3}__help` 27614 } : {}; 27615 maybeWarnDeprecated36pxSize({ 27616 componentName: "InputControl", 27617 __next40pxDefaultSize, 27618 size: size3, 27619 __shouldNotWarnDeprecated36pxSize 27620 }); 27621 return /* @__PURE__ */ (0, import_jsx_runtime92.jsx)(base_control_default, { 27622 className: classes, 27623 help, 27624 id: id3, 27625 children: /* @__PURE__ */ (0, import_jsx_runtime92.jsx)(input_base_default, { 27626 __next40pxDefaultSize, 27627 __unstableInputWidth, 27628 disabled, 27629 gap: 3, 27630 hideLabelFromVision, 27631 id: id3, 27632 justify: "left", 27633 label, 27634 labelPosition, 27635 prefix: prefix2, 27636 size: size3, 27637 style: style2, 27638 suffix, 27639 children: /* @__PURE__ */ (0, import_jsx_runtime92.jsx)(input_field_default, { 27640 ...restProps, 27641 ...helpProp, 27642 __next40pxDefaultSize, 27643 className: "components-input-control__input", 27644 disabled, 27645 id: id3, 27646 isPressEnterToChange, 27647 onKeyDown, 27648 onValidate, 27649 paddingInlineStart: prefix2 ? space(1) : void 0, 27650 paddingInlineEnd: suffix ? space(1) : void 0, 27651 ref, 27652 size: size3, 27653 stateReducer, 27654 ...draftHookProps 27655 }) 27656 }) 27657 }); 27658 } 27659 var InputControl = (0, import_element31.forwardRef)(UnforwardedInputControl); 27660 var input_control_default = InputControl; 27661 27662 // packages/components/build-module/button/index.js 27663 var import_deprecated4 = __toESM(require_deprecated()); 27664 var import_element33 = __toESM(require_element()); 27665 var import_compose6 = __toESM(require_compose()); 27666 27667 // packages/components/build-module/icon/index.js 27668 var import_element32 = __toESM(require_element()); 27669 var import_primitives31 = __toESM(require_primitives()); 27670 27671 // packages/components/build-module/dashicon/index.js 27672 var import_jsx_runtime93 = __toESM(require_jsx_runtime()); 27673 function Dashicon({ 27674 icon, 27675 className: className2, 27676 size: size3 = 20, 27677 style: style2 = {}, 27678 ...extraProps 27679 }) { 27680 const iconClass = ["dashicon", "dashicons", "dashicons-" + icon, className2].filter(Boolean).join(" "); 27681 const sizeStyles3 = ( 27682 // using `!=` to catch both 20 and "20" 27683 // eslint-disable-next-line eqeqeq 27684 20 != size3 ? { 27685 fontSize: `$size3}px`, 27686 width: `$size3}px`, 27687 height: `$size3}px` 27688 } : {} 27689 ); 27690 const styles3 = { 27691 ...sizeStyles3, 27692 ...style2 27693 }; 27694 return /* @__PURE__ */ (0, import_jsx_runtime93.jsx)("span", { 27695 className: iconClass, 27696 style: styles3, 27697 ...extraProps 27698 }); 27699 } 27700 var dashicon_default = Dashicon; 27701 27702 // packages/components/build-module/icon/index.js 27703 var import_jsx_runtime94 = __toESM(require_jsx_runtime()); 27704 function Icon({ 27705 icon = null, 27706 size: size3 = "string" === typeof icon ? 20 : 24, 27707 ...additionalProps 27708 }) { 27709 if ("string" === typeof icon) { 27710 return /* @__PURE__ */ (0, import_jsx_runtime94.jsx)(dashicon_default, { 27711 icon, 27712 size: size3, 27713 ...additionalProps 27714 }); 27715 } 27716 if ((0, import_element32.isValidElement)(icon) && dashicon_default === icon.type) { 27717 return (0, import_element32.cloneElement)(icon, { 27718 ...additionalProps 27719 }); 27720 } 27721 if ("function" === typeof icon) { 27722 return (0, import_element32.createElement)(icon, { 27723 size: size3, 27724 ...additionalProps 27725 }); 27726 } 27727 if (icon && (icon.type === "svg" || icon.type === import_primitives31.SVG)) { 27728 const appliedProps = { 27729 ...icon.props, 27730 width: size3, 27731 height: size3, 27732 ...additionalProps 27733 }; 27734 return /* @__PURE__ */ (0, import_jsx_runtime94.jsx)(import_primitives31.SVG, { 27735 ...appliedProps 27736 }); 27737 } 27738 if ((0, import_element32.isValidElement)(icon)) { 27739 return (0, import_element32.cloneElement)(icon, { 27740 // @ts-ignore Just forwarding the size prop along 27741 size: size3, 27742 width: size3, 27743 height: size3, 27744 ...additionalProps 27745 }); 27746 } 27747 return icon; 27748 } 27749 var icon_default3 = Icon; 27750 27751 // packages/components/build-module/button/index.js 27752 var import_jsx_runtime95 = __toESM(require_jsx_runtime()); 27753 var disabledEventsOnDisabledButton = ["onMouseDown", "onClick"]; 27754 function useDeprecatedProps2({ 27755 __experimentalIsFocusable, 27756 isDefault, 27757 isPrimary, 27758 isSecondary, 27759 isTertiary, 27760 isLink, 27761 isPressed, 27762 isSmall, 27763 size: size3, 27764 variant, 27765 describedBy, 27766 ...otherProps 27767 }) { 27768 let computedSize = size3; 27769 let computedVariant = variant; 27770 const newProps = { 27771 accessibleWhenDisabled: __experimentalIsFocusable, 27772 // @todo Mark `isPressed` as deprecated 27773 "aria-pressed": isPressed, 27774 description: describedBy 27775 }; 27776 if (isSmall) { 27777 var _computedSize; 27778 (_computedSize = computedSize) !== null && _computedSize !== void 0 ? _computedSize : computedSize = "small"; 27779 } 27780 if (isPrimary) { 27781 var _computedVariant; 27782 (_computedVariant = computedVariant) !== null && _computedVariant !== void 0 ? _computedVariant : computedVariant = "primary"; 27783 } 27784 if (isTertiary) { 27785 var _computedVariant2; 27786 (_computedVariant2 = computedVariant) !== null && _computedVariant2 !== void 0 ? _computedVariant2 : computedVariant = "tertiary"; 27787 } 27788 if (isSecondary) { 27789 var _computedVariant3; 27790 (_computedVariant3 = computedVariant) !== null && _computedVariant3 !== void 0 ? _computedVariant3 : computedVariant = "secondary"; 27791 } 27792 if (isDefault) { 27793 var _computedVariant4; 27794 (0, import_deprecated4.default)("wp.components.Button `isDefault` prop", { 27795 since: "5.4", 27796 alternative: 'variant="secondary"' 27797 }); 27798 (_computedVariant4 = computedVariant) !== null && _computedVariant4 !== void 0 ? _computedVariant4 : computedVariant = "secondary"; 27799 } 27800 if (isLink) { 27801 var _computedVariant5; 27802 (_computedVariant5 = computedVariant) !== null && _computedVariant5 !== void 0 ? _computedVariant5 : computedVariant = "link"; 27803 } 27804 return { 27805 ...newProps, 27806 ...otherProps, 27807 size: computedSize, 27808 variant: computedVariant 27809 }; 27810 } 27811 function UnforwardedButton(props, ref) { 27812 const { 27813 __next40pxDefaultSize, 27814 accessibleWhenDisabled, 27815 isBusy, 27816 isDestructive, 27817 className: className2, 27818 disabled, 27819 icon, 27820 iconPosition = "left", 27821 iconSize, 27822 showTooltip, 27823 tooltipPosition, 27824 shortcut, 27825 label, 27826 children, 27827 size: size3 = "default", 27828 text, 27829 variant, 27830 description, 27831 ...buttonOrAnchorProps 27832 } = useDeprecatedProps2(props); 27833 const { 27834 href, 27835 target, 27836 "aria-checked": ariaChecked, 27837 "aria-pressed": ariaPressed, 27838 "aria-selected": ariaSelected, 27839 ...additionalProps 27840 } = "href" in buttonOrAnchorProps ? buttonOrAnchorProps : { 27841 href: void 0, 27842 target: void 0, 27843 ...buttonOrAnchorProps 27844 }; 27845 const instanceId = (0, import_compose6.useInstanceId)(Button3, "components-button__description"); 27846 const hasChildren = "string" === typeof children && !!children || Array.isArray(children) && children?.[0] && children[0] !== null && // Tooltip should not considered as a child 27847 children?.[0]?.props?.className !== "components-tooltip"; 27848 const truthyAriaPressedValues = [true, "true", "mixed"]; 27849 const classes = clsx_default("components-button", className2, { 27850 "is-next-40px-default-size": __next40pxDefaultSize, 27851 "is-secondary": variant === "secondary", 27852 "is-primary": variant === "primary", 27853 "is-small": size3 === "small", 27854 "is-compact": size3 === "compact", 27855 "is-tertiary": variant === "tertiary", 27856 "is-pressed": truthyAriaPressedValues.includes(ariaPressed), 27857 "is-pressed-mixed": ariaPressed === "mixed", 27858 "is-busy": isBusy, 27859 "is-link": variant === "link", 27860 "is-destructive": isDestructive, 27861 "has-text": !!icon && (hasChildren || text), 27862 "has-icon": !!icon, 27863 "has-icon-right": iconPosition === "right" 27864 }); 27865 const trulyDisabled = disabled && !accessibleWhenDisabled; 27866 const Tag = href !== void 0 && !disabled ? "a" : "button"; 27867 const buttonProps = Tag === "button" ? { 27868 type: "button", 27869 disabled: trulyDisabled, 27870 "aria-checked": ariaChecked, 27871 "aria-pressed": ariaPressed, 27872 "aria-selected": ariaSelected 27873 } : {}; 27874 const anchorProps = Tag === "a" ? { 27875 href, 27876 target 27877 } : {}; 27878 const disableEventProps = {}; 27879 if (disabled && accessibleWhenDisabled) { 27880 buttonProps["aria-disabled"] = true; 27881 anchorProps["aria-disabled"] = true; 27882 for (const disabledEvent of disabledEventsOnDisabledButton) { 27883 disableEventProps[disabledEvent] = (event) => { 27884 if (event) { 27885 event.stopPropagation(); 27886 event.preventDefault(); 27887 } 27888 }; 27889 } 27890 } 27891 const shouldShowTooltip = !trulyDisabled && // An explicit tooltip is passed or... 27892 (showTooltip && !!label || // There's a shortcut or... 27893 !!shortcut || // There's a label and... 27894 !!label && // The children are empty and... 27895 !children?.length && // The tooltip is not explicitly disabled. 27896 false !== showTooltip); 27897 const descriptionId = description ? instanceId : void 0; 27898 const describedById = additionalProps["aria-describedby"] || descriptionId; 27899 const commonProps = { 27900 className: classes, 27901 "aria-label": additionalProps["aria-label"] || label, 27902 "aria-describedby": describedById, 27903 ref 27904 }; 27905 const elementChildren = /* @__PURE__ */ (0, import_jsx_runtime95.jsxs)(import_jsx_runtime95.Fragment, { 27906 children: [icon && iconPosition === "left" && /* @__PURE__ */ (0, import_jsx_runtime95.jsx)(icon_default3, { 27907 icon, 27908 size: iconSize 27909 }), text && /* @__PURE__ */ (0, import_jsx_runtime95.jsx)(import_jsx_runtime95.Fragment, { 27910 children: text 27911 }), children, icon && iconPosition === "right" && /* @__PURE__ */ (0, import_jsx_runtime95.jsx)(icon_default3, { 27912 icon, 27913 size: iconSize 27914 })] 27915 }); 27916 const element = Tag === "a" ? /* @__PURE__ */ (0, import_jsx_runtime95.jsx)("a", { 27917 ...anchorProps, 27918 ...additionalProps, 27919 ...disableEventProps, 27920 ...commonProps, 27921 children: elementChildren 27922 }) : /* @__PURE__ */ (0, import_jsx_runtime95.jsx)("button", { 27923 ...buttonProps, 27924 ...additionalProps, 27925 ...disableEventProps, 27926 ...commonProps, 27927 children: elementChildren 27928 }); 27929 const tooltipProps = shouldShowTooltip ? { 27930 text: children?.length && description ? description : label, 27931 shortcut, 27932 placement: tooltipPosition && // Convert legacy `position` values to be used with the new `placement` prop 27933 positionToPlacement(tooltipPosition) 27934 } : {}; 27935 return /* @__PURE__ */ (0, import_jsx_runtime95.jsxs)(import_jsx_runtime95.Fragment, { 27936 children: [/* @__PURE__ */ (0, import_jsx_runtime95.jsx)(tooltip_default, { 27937 ...tooltipProps, 27938 children: element 27939 }), description && /* @__PURE__ */ (0, import_jsx_runtime95.jsx)(component_default2, { 27940 children: /* @__PURE__ */ (0, import_jsx_runtime95.jsx)("span", { 27941 id: descriptionId, 27942 children: description 27943 }) 27944 })] 27945 }); 27946 } 27947 var Button3 = (0, import_element33.forwardRef)(UnforwardedButton); 27948 var button_default = Button3; 27949 27950 // packages/components/build-module/number-control/styles/number-control-styles.js 27951 function _EMOTION_STRINGIFIED_CSS_ERROR__8() { 27952 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 27953 } 27954 var _ref3 = false ? { 27955 name: "euqsgg", 27956 styles: "input[type='number']::-webkit-outer-spin-button,input[type='number']::-webkit-inner-spin-button{-webkit-appearance:none!important;margin:0!important;}input[type='number']{-moz-appearance:textfield;}" 27957 } : { 27958 name: "jl4rev-htmlArrowStyles", 27959 styles: "input[type='number']::-webkit-outer-spin-button,input[type='number']::-webkit-inner-spin-button{-webkit-appearance:none!important;margin:0!important;}input[type='number']{-moz-appearance:textfield;};label:htmlArrowStyles;", 27960 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm51bWJlci1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQlciLCJmaWxlIjoibnVtYmVyLWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgSW5wdXRDb250cm9sIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wnO1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmNvbnN0IGh0bWxBcnJvd1N0eWxlcyA9ICggeyBoaWRlSFRNTEFycm93cyB9OiB7IGhpZGVIVE1MQXJyb3dzOiBib29sZWFuIH0gKSA9PiB7XG5cdGlmICggISBoaWRlSFRNTEFycm93cyApIHtcblx0XHRyZXR1cm4gYGA7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGlucHV0W3R5cGU9J251bWJlciddOjotd2Via2l0LW91dGVyLXNwaW4tYnV0dG9uLFxuXHRcdGlucHV0W3R5cGU9J251bWJlciddOjotd2Via2l0LWlubmVyLXNwaW4tYnV0dG9uIHtcblx0XHRcdC13ZWJraXQtYXBwZWFyYW5jZTogbm9uZSAhaW1wb3J0YW50O1xuXHRcdFx0bWFyZ2luOiAwICFpbXBvcnRhbnQ7XG5cdFx0fVxuXG5cdFx0aW5wdXRbdHlwZT0nbnVtYmVyJ10ge1xuXHRcdFx0LW1vei1hcHBlYXJhbmNlOiB0ZXh0ZmllbGQ7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IElucHV0ID0gc3R5bGVkKCBJbnB1dENvbnRyb2wgKWBcblx0JHsgaHRtbEFycm93U3R5bGVzIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU3BpbkJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmJiYmIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHR9XG5gO1xuXG5jb25zdCBzbWFsbFNwaW5CdXR0b25zID0gY3NzYFxuXHR3aWR0aDogJHsgc3BhY2UoIDUgKSB9O1xuXHRtaW4td2lkdGg6ICR7IHNwYWNlKCA1ICkgfTtcblx0aGVpZ2h0OiAkeyBzcGFjZSggNSApIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgc3R5bGVzID0geyBzbWFsbFNwaW5CdXR0b25zIH07XG4iXX0= */", 27961 toString: _EMOTION_STRINGIFIED_CSS_ERROR__8 27962 }; 27963 var htmlArrowStyles = ({ 27964 hideHTMLArrows 27965 }) => { 27966 if (!hideHTMLArrows) { 27967 return ``; 27968 } 27969 return _ref3; 27970 }; 27971 var Input2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(input_control_default, false ? { 27972 target: "ep09it41" 27973 } : { 27974 target: "ep09it41", 27975 label: "Input" 27976 })(htmlArrowStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm51bWJlci1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzJDIiwiZmlsZSI6Im51bWJlci1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IElucHV0Q29udHJvbCBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sJztcbmltcG9ydCB7IENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCBodG1sQXJyb3dTdHlsZXMgPSAoIHsgaGlkZUhUTUxBcnJvd3MgfTogeyBoaWRlSFRNTEFycm93czogYm9vbGVhbiB9ICkgPT4ge1xuXHRpZiAoICEgaGlkZUhUTUxBcnJvd3MgKSB7XG5cdFx0cmV0dXJuIGBgO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG5cdFx0XHQtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmUgIWltcG9ydGFudDtcblx0XHRcdG1hcmdpbjogMCAhaW1wb3J0YW50O1xuXHRcdH1cblxuXHRcdGlucHV0W3R5cGU9J251bWJlciddIHtcblx0XHRcdC1tb3otYXBwZWFyYW5jZTogdGV4dGZpZWxkO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dCA9IHN0eWxlZCggSW5wdXRDb250cm9sIClgXG5cdCR7IGh0bWxBcnJvd1N0eWxlcyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFNwaW5CdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiYmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuY29uc3Qgc21hbGxTcGluQnV0dG9ucyA9IGNzc2Bcblx0d2lkdGg6ICR7IHNwYWNlKCA1ICkgfTtcblx0bWluLXdpZHRoOiAkeyBzcGFjZSggNSApIH07XG5cdGhlaWdodDogJHsgc3BhY2UoIDUgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHsgc21hbGxTcGluQnV0dG9ucyB9O1xuIl19 */")); 27977 var SpinButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 27978 target: "ep09it40" 27979 } : { 27980 target: "ep09it40", 27981 label: "SpinButton" 27982 })("&&&&&{color:", COLORS.theme.accent, ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm51bWJlci1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQzBDIiwiZmlsZSI6Im51bWJlci1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IElucHV0Q29udHJvbCBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sJztcbmltcG9ydCB7IENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCBodG1sQXJyb3dTdHlsZXMgPSAoIHsgaGlkZUhUTUxBcnJvd3MgfTogeyBoaWRlSFRNTEFycm93czogYm9vbGVhbiB9ICkgPT4ge1xuXHRpZiAoICEgaGlkZUhUTUxBcnJvd3MgKSB7XG5cdFx0cmV0dXJuIGBgO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG5cdFx0XHQtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmUgIWltcG9ydGFudDtcblx0XHRcdG1hcmdpbjogMCAhaW1wb3J0YW50O1xuXHRcdH1cblxuXHRcdGlucHV0W3R5cGU9J251bWJlciddIHtcblx0XHRcdC1tb3otYXBwZWFyYW5jZTogdGV4dGZpZWxkO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dCA9IHN0eWxlZCggSW5wdXRDb250cm9sIClgXG5cdCR7IGh0bWxBcnJvd1N0eWxlcyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFNwaW5CdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiYmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuY29uc3Qgc21hbGxTcGluQnV0dG9ucyA9IGNzc2Bcblx0d2lkdGg6ICR7IHNwYWNlKCA1ICkgfTtcblx0bWluLXdpZHRoOiAkeyBzcGFjZSggNSApIH07XG5cdGhlaWdodDogJHsgc3BhY2UoIDUgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHsgc21hbGxTcGluQnV0dG9ucyB9O1xuIl19 */")); 27983 var smallSpinButtons = /* @__PURE__ */ css("width:", space(5), ";min-width:", space(5), ";height:", space(5), ";" + (false ? "" : ";label:smallSpinButtons;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm51bWJlci1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQzRCIiwiZmlsZSI6Im51bWJlci1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IElucHV0Q29udHJvbCBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sJztcbmltcG9ydCB7IENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCBodG1sQXJyb3dTdHlsZXMgPSAoIHsgaGlkZUhUTUxBcnJvd3MgfTogeyBoaWRlSFRNTEFycm93czogYm9vbGVhbiB9ICkgPT4ge1xuXHRpZiAoICEgaGlkZUhUTUxBcnJvd3MgKSB7XG5cdFx0cmV0dXJuIGBgO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcblx0XHRpbnB1dFt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG5cdFx0XHQtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmUgIWltcG9ydGFudDtcblx0XHRcdG1hcmdpbjogMCAhaW1wb3J0YW50O1xuXHRcdH1cblxuXHRcdGlucHV0W3R5cGU9J251bWJlciddIHtcblx0XHRcdC1tb3otYXBwZWFyYW5jZTogdGV4dGZpZWxkO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBJbnB1dCA9IHN0eWxlZCggSW5wdXRDb250cm9sIClgXG5cdCR7IGh0bWxBcnJvd1N0eWxlcyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFNwaW5CdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiYmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuY29uc3Qgc21hbGxTcGluQnV0dG9ucyA9IGNzc2Bcblx0d2lkdGg6ICR7IHNwYWNlKCA1ICkgfTtcblx0bWluLXdpZHRoOiAkeyBzcGFjZSggNSApIH07XG5cdGhlaWdodDogJHsgc3BhY2UoIDUgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHN0eWxlcyA9IHsgc21hbGxTcGluQnV0dG9ucyB9O1xuIl19 */"); 27984 var styles = { 27985 smallSpinButtons 27986 }; 27987 27988 // packages/components/build-module/utils/math.js 27989 function getNumber(value) { 27990 const number2 = Number(value); 27991 return isNaN(number2) ? 0 : number2; 27992 } 27993 function add(...args) { 27994 return args.reduce( 27995 /** @type {(sum:number, arg: number|string) => number} */ 27996 (sum, arg) => sum + getNumber(arg), 27997 0 27998 ); 27999 } 28000 function subtract(...args) { 28001 return args.reduce( 28002 /** @type {(diff:number, arg: number|string, index:number) => number} */ 28003 (diff, arg, index2) => { 28004 const value = getNumber(arg); 28005 return index2 === 0 ? value : diff - value; 28006 }, 28007 0 28008 ); 28009 } 28010 function getPrecision(value) { 28011 const split = (value + "").split("."); 28012 return split[1] !== void 0 ? split[1].length : 0; 28013 } 28014 function clamp4(value, min3, max3) { 28015 const baseValue = getNumber(value); 28016 return Math.max(min3, Math.min(baseValue, max3)); 28017 } 28018 function ensureValidStep(value, min3, step) { 28019 const baseValue = getNumber(value); 28020 const minValue = getNumber(min3); 28021 const stepValue = getNumber(step); 28022 const precision = Math.max(getPrecision(step), getPrecision(min3)); 28023 const tare = minValue % stepValue ? minValue : 0; 28024 const rounded3 = Math.round((baseValue - tare) / stepValue) * stepValue; 28025 const fromMin = rounded3 + tare; 28026 return precision ? getNumber(fromMin.toFixed(precision)) : fromMin; 28027 } 28028 28029 // packages/components/build-module/h-stack/utils.js 28030 var H_ALIGNMENTS = { 28031 bottom: { 28032 align: "flex-end", 28033 justify: "center" 28034 }, 28035 bottomLeft: { 28036 align: "flex-end", 28037 justify: "flex-start" 28038 }, 28039 bottomRight: { 28040 align: "flex-end", 28041 justify: "flex-end" 28042 }, 28043 center: { 28044 align: "center", 28045 justify: "center" 28046 }, 28047 edge: { 28048 align: "center", 28049 justify: "space-between" 28050 }, 28051 left: { 28052 align: "center", 28053 justify: "flex-start" 28054 }, 28055 right: { 28056 align: "center", 28057 justify: "flex-end" 28058 }, 28059 stretch: { 28060 align: "stretch" 28061 }, 28062 top: { 28063 align: "flex-start", 28064 justify: "center" 28065 }, 28066 topLeft: { 28067 align: "flex-start", 28068 justify: "flex-start" 28069 }, 28070 topRight: { 28071 align: "flex-start", 28072 justify: "flex-end" 28073 } 28074 }; 28075 var V_ALIGNMENTS = { 28076 bottom: { 28077 justify: "flex-end", 28078 align: "center" 28079 }, 28080 bottomLeft: { 28081 justify: "flex-end", 28082 align: "flex-start" 28083 }, 28084 bottomRight: { 28085 justify: "flex-end", 28086 align: "flex-end" 28087 }, 28088 center: { 28089 justify: "center", 28090 align: "center" 28091 }, 28092 edge: { 28093 justify: "space-between", 28094 align: "center" 28095 }, 28096 left: { 28097 justify: "center", 28098 align: "flex-start" 28099 }, 28100 right: { 28101 justify: "center", 28102 align: "flex-end" 28103 }, 28104 stretch: { 28105 align: "stretch" 28106 }, 28107 top: { 28108 justify: "flex-start", 28109 align: "center" 28110 }, 28111 topLeft: { 28112 justify: "flex-start", 28113 align: "flex-start" 28114 }, 28115 topRight: { 28116 justify: "flex-start", 28117 align: "flex-end" 28118 } 28119 }; 28120 function getAlignmentProps(alignment, direction = "row") { 28121 if (!isValueDefined(alignment)) { 28122 return {}; 28123 } 28124 const isVertical = direction === "column"; 28125 const props = isVertical ? V_ALIGNMENTS : H_ALIGNMENTS; 28126 const alignmentProps = alignment in props ? props[alignment] : { 28127 align: alignment 28128 }; 28129 return alignmentProps; 28130 } 28131 28132 // packages/components/build-module/utils/get-valid-children.js 28133 var import_element34 = __toESM(require_element()); 28134 function getValidChildren(children) { 28135 if (typeof children === "string") { 28136 return [children]; 28137 } 28138 return import_element34.Children.toArray(children).filter((child) => (0, import_element34.isValidElement)(child)); 28139 } 28140 28141 // packages/components/build-module/h-stack/hook.js 28142 var import_jsx_runtime96 = __toESM(require_jsx_runtime()); 28143 function useHStack(props) { 28144 const { 28145 alignment = "edge", 28146 children, 28147 direction, 28148 spacing = 2, 28149 ...otherProps 28150 } = useContextSystem(props, "HStack"); 28151 const align = getAlignmentProps(alignment, direction); 28152 const validChildren = getValidChildren(children); 28153 const clonedChildren = validChildren.map((child, index2) => { 28154 const _isSpacer = hasConnectNamespace(child, ["Spacer"]); 28155 if (_isSpacer) { 28156 const childElement = child; 28157 const _key = childElement.key || `hstack-$index2}`; 28158 return /* @__PURE__ */ (0, import_jsx_runtime96.jsx)(component_default4, { 28159 isBlock: true, 28160 ...childElement.props 28161 }, _key); 28162 } 28163 return child; 28164 }); 28165 const propsForFlex = { 28166 children: clonedChildren, 28167 direction, 28168 justify: "center", 28169 ...align, 28170 ...otherProps, 28171 gap: spacing 28172 }; 28173 const { 28174 isColumn, 28175 ...flexProps 28176 } = useFlex(propsForFlex); 28177 return flexProps; 28178 } 28179 28180 // packages/components/build-module/h-stack/component.js 28181 var import_jsx_runtime97 = __toESM(require_jsx_runtime()); 28182 function UnconnectedHStack(props, forwardedRef) { 28183 const hStackProps = useHStack(props); 28184 return /* @__PURE__ */ (0, import_jsx_runtime97.jsx)(component_default, { 28185 ...hStackProps, 28186 ref: forwardedRef 28187 }); 28188 } 28189 var HStack = contextConnect(UnconnectedHStack, "HStack"); 28190 var component_default9 = HStack; 28191 28192 // packages/components/build-module/number-control/index.js 28193 var import_jsx_runtime98 = __toESM(require_jsx_runtime()); 28194 var noop6 = () => { 28195 }; 28196 function UnforwardedNumberControl(props, forwardedRef) { 28197 const { 28198 __unstableStateReducer: stateReducerProp, 28199 className: className2, 28200 dragDirection = "n", 28201 hideHTMLArrows = false, 28202 spinControls = hideHTMLArrows ? "none" : "native", 28203 isDragEnabled = true, 28204 isShiftStepEnabled = true, 28205 label, 28206 max: max3 = Infinity, 28207 min: min3 = -Infinity, 28208 required = false, 28209 shiftStep = 10, 28210 step = 1, 28211 spinFactor = 1, 28212 type: typeProp = "number", 28213 value: valueProp, 28214 size: size3 = "default", 28215 suffix, 28216 onChange = noop6, 28217 __shouldNotWarnDeprecated36pxSize, 28218 ...restProps 28219 } = useDeprecated36pxDefaultSizeProp(props); 28220 maybeWarnDeprecated36pxSize({ 28221 componentName: "NumberControl", 28222 size: size3, 28223 __next40pxDefaultSize: restProps.__next40pxDefaultSize, 28224 __shouldNotWarnDeprecated36pxSize 28225 }); 28226 if (hideHTMLArrows) { 28227 (0, import_deprecated5.default)("wp.components.NumberControl hideHTMLArrows prop ", { 28228 alternative: 'spinControls="none"', 28229 since: "6.2", 28230 version: "6.3" 28231 }); 28232 } 28233 const inputRef = (0, import_element35.useRef)(); 28234 const mergedRef = (0, import_compose7.useMergeRefs)([inputRef, forwardedRef]); 28235 const isStepAny = step === "any"; 28236 const baseStep = isStepAny ? 1 : ensureNumber(step); 28237 const baseSpin = ensureNumber(spinFactor) * baseStep; 28238 const constrainValue = (value, stepOverride) => { 28239 if (!isStepAny) { 28240 value = ensureValidStep(value, min3, stepOverride !== null && stepOverride !== void 0 ? stepOverride : baseStep); 28241 } 28242 return `$clamp4(value, min3, max3)}`; 28243 }; 28244 const baseValue = constrainValue(0); 28245 const autoComplete = typeProp === "number" ? "off" : void 0; 28246 const classes = clsx_default("components-number-control", className2); 28247 const cx3 = useCx(); 28248 const spinButtonClasses = cx3(size3 === "small" && styles.smallSpinButtons); 28249 const spinValue = (value, direction, event) => { 28250 event?.preventDefault(); 28251 const shift3 = event?.shiftKey && isShiftStepEnabled; 28252 const delta = shift3 ? ensureNumber(shiftStep) * baseSpin : baseSpin; 28253 let nextValue = isValueEmpty(value) ? baseValue : value; 28254 if (direction === "up") { 28255 nextValue = add(nextValue, delta); 28256 } else if (direction === "down") { 28257 nextValue = subtract(nextValue, delta); 28258 } 28259 return constrainValue(nextValue, shift3 ? delta : void 0); 28260 }; 28261 const numberControlStateReducer = (state, action) => { 28262 const nextState = { 28263 ...state 28264 }; 28265 const { 28266 type, 28267 payload 28268 } = action; 28269 const event = payload.event; 28270 const currentValue = nextState.value; 28271 if (type === PRESS_UP || type === PRESS_DOWN) { 28272 nextState.value = spinValue(currentValue, type === PRESS_UP ? "up" : "down", event); 28273 } 28274 if (type === DRAG && isDragEnabled) { 28275 const [x2, y3] = payload.delta; 28276 const enableShift = payload.shiftKey && isShiftStepEnabled; 28277 const modifier = enableShift ? ensureNumber(shiftStep) * baseSpin : baseSpin; 28278 let directionModifier; 28279 let delta; 28280 switch (dragDirection) { 28281 case "n": 28282 delta = y3; 28283 directionModifier = -1; 28284 break; 28285 case "e": 28286 delta = x2; 28287 directionModifier = (0, import_i18n5.isRTL)() ? -1 : 1; 28288 break; 28289 case "s": 28290 delta = y3; 28291 directionModifier = 1; 28292 break; 28293 case "w": 28294 delta = x2; 28295 directionModifier = (0, import_i18n5.isRTL)() ? 1 : -1; 28296 break; 28297 } 28298 if (delta !== 0) { 28299 delta = Math.ceil(Math.abs(delta)) * Math.sign(delta); 28300 const distance2 = delta * modifier * directionModifier; 28301 nextState.value = constrainValue( 28302 // @ts-expect-error TODO: Investigate if it's ok for currentValue to be undefined 28303 add(currentValue, distance2), 28304 enableShift ? modifier : void 0 28305 ); 28306 } 28307 } 28308 if (type === PRESS_ENTER || type === COMMIT) { 28309 const applyEmptyValue = required === false && currentValue === ""; 28310 nextState.value = applyEmptyValue ? currentValue : ( 28311 // @ts-expect-error TODO: Investigate if it's ok for currentValue to be undefined 28312 constrainValue(currentValue) 28313 ); 28314 } 28315 return nextState; 28316 }; 28317 const buildSpinButtonClickHandler = (direction) => (event) => onChange(String(spinValue(valueProp, direction, event)), { 28318 // Set event.target to the <input> so that consumers can use 28319 // e.g. event.target.validity. 28320 event: { 28321 ...event, 28322 target: inputRef.current 28323 } 28324 }); 28325 return /* @__PURE__ */ (0, import_jsx_runtime98.jsx)(Input2, { 28326 autoComplete, 28327 inputMode: "numeric", 28328 ...restProps, 28329 className: classes, 28330 dragDirection, 28331 hideHTMLArrows: spinControls !== "native", 28332 isDragEnabled, 28333 label, 28334 max: max3 === Infinity ? void 0 : max3, 28335 min: min3 === -Infinity ? void 0 : min3, 28336 ref: mergedRef, 28337 required, 28338 step, 28339 type: typeProp, 28340 value: valueProp, 28341 __unstableStateReducer: (state, action) => { 28342 var _stateReducerProp; 28343 const baseState = numberControlStateReducer(state, action); 28344 return (_stateReducerProp = stateReducerProp?.(baseState, action)) !== null && _stateReducerProp !== void 0 ? _stateReducerProp : baseState; 28345 }, 28346 size: size3, 28347 __shouldNotWarnDeprecated36pxSize: true, 28348 suffix: spinControls === "custom" ? /* @__PURE__ */ (0, import_jsx_runtime98.jsxs)(import_jsx_runtime98.Fragment, { 28349 children: [suffix, /* @__PURE__ */ (0, import_jsx_runtime98.jsx)(component_default6, { 28350 marginBottom: 0, 28351 marginRight: 2, 28352 children: /* @__PURE__ */ (0, import_jsx_runtime98.jsxs)(component_default9, { 28353 spacing: 1, 28354 children: [/* @__PURE__ */ (0, import_jsx_runtime98.jsx)(SpinButton, { 28355 className: spinButtonClasses, 28356 icon: plus_default, 28357 size: "small", 28358 label: (0, import_i18n5.__)("Increment"), 28359 onClick: buildSpinButtonClickHandler("up") 28360 }), /* @__PURE__ */ (0, import_jsx_runtime98.jsx)(SpinButton, { 28361 className: spinButtonClasses, 28362 icon: reset_default, 28363 size: "small", 28364 label: (0, import_i18n5.__)("Decrement"), 28365 onClick: buildSpinButtonClickHandler("down") 28366 })] 28367 }) 28368 })] 28369 }) : suffix, 28370 onChange 28371 }); 28372 } 28373 var NumberControl = (0, import_element35.forwardRef)(UnforwardedNumberControl); 28374 var number_control_default = NumberControl; 28375 28376 // packages/components/build-module/input-control/input-prefix-wrapper.js 28377 var import_jsx_runtime99 = __toESM(require_jsx_runtime()); 28378 function UnconnectedInputControlPrefixWrapper(props, forwardedRef) { 28379 const derivedProps = useContextSystem(props, "InputControlPrefixWrapper"); 28380 return /* @__PURE__ */ (0, import_jsx_runtime99.jsx)(PrefixSuffixWrapper, { 28381 ...derivedProps, 28382 isPrefix: true, 28383 ref: forwardedRef 28384 }); 28385 } 28386 var InputControlPrefixWrapper = contextConnect(UnconnectedInputControlPrefixWrapper, "InputControlPrefixWrapper"); 28387 var input_prefix_wrapper_default = InputControlPrefixWrapper; 28388 28389 // packages/components/build-module/input-control/input-suffix-wrapper.js 28390 var import_jsx_runtime100 = __toESM(require_jsx_runtime()); 28391 function UnconnectedInputControlSuffixWrapper(props, forwardedRef) { 28392 const derivedProps = useContextSystem(props, "InputControlSuffixWrapper"); 28393 return /* @__PURE__ */ (0, import_jsx_runtime100.jsx)(PrefixSuffixWrapper, { 28394 ...derivedProps, 28395 ref: forwardedRef 28396 }); 28397 } 28398 var InputControlSuffixWrapper = contextConnect(UnconnectedInputControlSuffixWrapper, "InputControlSuffixWrapper"); 28399 var input_suffix_wrapper_default = InputControlSuffixWrapper; 28400 28401 // packages/components/build-module/angle-picker-control/angle-circle.js 28402 var import_element36 = __toESM(require_element()); 28403 var import_compose8 = __toESM(require_compose()); 28404 var import_jsx_runtime101 = __toESM(require_jsx_runtime()); 28405 var css5 = `/** 28406 * SCSS Variables. 28407 * 28408 * Please use variables from this sheet to ensure consistency across the UI. 28409 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 28410 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 28411 */ 28412 /** 28413 * Colors 28414 */ 28415 /** 28416 * Fonts & basic variables. 28417 */ 28418 /** 28419 * Typography 28420 */ 28421 /** 28422 * Grid System. 28423 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 28424 */ 28425 /** 28426 * Radius scale. 28427 */ 28428 /** 28429 * Elevation scale. 28430 */ 28431 /** 28432 * Dimensions. 28433 */ 28434 /** 28435 * Mobile specific styles 28436 */ 28437 /** 28438 * Editor styles. 28439 */ 28440 /** 28441 * Block & Editor UI. 28442 */ 28443 /** 28444 * Block paddings. 28445 */ 28446 /** 28447 * React Native specific. 28448 * These variables do not appear to be used anywhere else. 28449 */ 28450 .style-module__circle-root__j1e41 { 28451 border-radius: 50%; 28452 border: 1px solid var(--wp-components-color-gray-600, #949494); 28453 box-sizing: border-box; 28454 cursor: grab; 28455 height: 32px; 28456 overflow: hidden; 28457 width: 32px; 28458 } 28459 .style-module__circle-root__j1e41:active { 28460 cursor: grabbing; 28461 } 28462 28463 .style-module__circle-indicator-wrapper__sbrph { 28464 box-sizing: border-box; 28465 position: relative; 28466 width: 100%; 28467 height: 100%; 28468 } 28469 .style-module__circle-indicator-wrapper__sbrph:focus-visible { 28470 outline: none; 28471 } 28472 28473 .style-module__circle-indicator__bS-go { 28474 background: var(--wp-components-color-accent, var(--wp-admin-theme-color, #3858e9)); 28475 border-radius: 50%; 28476 box-sizing: border-box; 28477 display: block; 28478 left: 50%; 28479 top: 4px; 28480 transform: translateX(-50%); 28481 position: absolute; 28482 width: 6px; 28483 height: 6px; 28484 }`; 28485 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css5)); 28486 var style_module_default3 = { 28487 "circle-root": "style-module__circle-root__j1e41", 28488 "circle-indicator-wrapper": "style-module__circle-indicator-wrapper__sbrph", 28489 "circle-indicator": "style-module__circle-indicator__bS-go" 28490 }; 28491 function AngleCircle({ 28492 value, 28493 onChange, 28494 className: className2, 28495 ...props 28496 }) { 28497 const angleCircleRef = (0, import_element36.useRef)(null); 28498 const angleCircleCenterRef = (0, import_element36.useRef)(); 28499 const previousCursorValueRef = (0, import_element36.useRef)(); 28500 const setAngleCircleCenter = () => { 28501 if (angleCircleRef.current === null) { 28502 return; 28503 } 28504 const rect = angleCircleRef.current.getBoundingClientRect(); 28505 angleCircleCenterRef.current = { 28506 x: rect.x + rect.width / 2, 28507 y: rect.y + rect.height / 2 28508 }; 28509 }; 28510 const changeAngleToPosition = (event) => { 28511 if (event === void 0) { 28512 return; 28513 } 28514 event.preventDefault(); 28515 event.target?.focus(); 28516 if (angleCircleCenterRef.current !== void 0 && onChange !== void 0) { 28517 const { 28518 x: centerX, 28519 y: centerY 28520 } = angleCircleCenterRef.current; 28521 onChange(getAngle(centerX, centerY, event.clientX, event.clientY)); 28522 } 28523 }; 28524 const { 28525 startDrag, 28526 isDragging: isDragging2 28527 } = (0, import_compose8.__experimentalUseDragging)({ 28528 onDragStart: (event) => { 28529 setAngleCircleCenter(); 28530 changeAngleToPosition(event); 28531 }, 28532 onDragMove: changeAngleToPosition, 28533 onDragEnd: changeAngleToPosition 28534 }); 28535 (0, import_element36.useEffect)(() => { 28536 if (isDragging2) { 28537 if (previousCursorValueRef.current === void 0) { 28538 previousCursorValueRef.current = document.body.style.cursor; 28539 } 28540 document.body.style.cursor = "grabbing"; 28541 } else { 28542 document.body.style.cursor = previousCursorValueRef.current || ""; 28543 previousCursorValueRef.current = void 0; 28544 } 28545 }, [isDragging2]); 28546 return ( 28547 // eslint-disable-next-line jsx-a11y/no-static-element-interactions 28548 /* @__PURE__ */ (0, import_jsx_runtime101.jsx)("div", { 28549 ref: angleCircleRef, 28550 onMouseDown: startDrag, 28551 className: clsx_default("components-angle-picker-control__angle-circle", style_module_default3["circle-root"], className2), 28552 ...props, 28553 children: /* @__PURE__ */ (0, import_jsx_runtime101.jsx)("div", { 28554 style: value ? { 28555 transform: `rotate($value}deg)` 28556 } : void 0, 28557 className: clsx_default("components-angle-picker-control__angle-circle-indicator-wrapper", style_module_default3["circle-indicator-wrapper"]), 28558 tabIndex: -1, 28559 children: /* @__PURE__ */ (0, import_jsx_runtime101.jsx)("div", { 28560 className: clsx_default("components-angle-picker-control__angle-circle-indicator", style_module_default3["circle-indicator"]) 28561 }) 28562 }) 28563 }) 28564 ); 28565 } 28566 function getAngle(centerX, centerY, pointX, pointY) { 28567 const y3 = pointY - centerY; 28568 const x2 = pointX - centerX; 28569 const angleInRadians = Math.atan2(y3, x2); 28570 const angleInDeg = Math.round(angleInRadians * (180 / Math.PI)) + 90; 28571 if (angleInDeg < 0) { 28572 return 360 + angleInDeg; 28573 } 28574 return angleInDeg; 28575 } 28576 var angle_circle_default = AngleCircle; 28577 28578 // packages/components/build-module/angle-picker-control/index.js 28579 var import_jsx_runtime102 = __toESM(require_jsx_runtime()); 28580 function UnforwardedAnglePickerControl(props, ref) { 28581 const { 28582 className: className2, 28583 label = (0, import_i18n6.__)("Angle"), 28584 onChange, 28585 value, 28586 ...restProps 28587 } = props; 28588 const handleOnNumberChange = (unprocessedValue) => { 28589 if (onChange === void 0) { 28590 return; 28591 } 28592 const inputValue = unprocessedValue !== void 0 && unprocessedValue !== "" ? parseInt(unprocessedValue, 10) : 0; 28593 onChange(inputValue); 28594 }; 28595 const classes = clsx_default("components-angle-picker-control", className2); 28596 const prefixOrSuffixProp = (0, import_i18n6.isRTL)() ? { 28597 prefix: /* @__PURE__ */ (0, import_jsx_runtime102.jsx)(input_prefix_wrapper_default, { 28598 children: "\xB0" 28599 }) 28600 } : { 28601 suffix: /* @__PURE__ */ (0, import_jsx_runtime102.jsx)(input_suffix_wrapper_default, { 28602 children: "\xB0" 28603 }) 28604 }; 28605 return /* @__PURE__ */ (0, import_jsx_runtime102.jsxs)(component_default3, { 28606 ...restProps, 28607 ref, 28608 className: classes, 28609 gap: 2, 28610 children: [/* @__PURE__ */ (0, import_jsx_runtime102.jsx)(component_default5, { 28611 children: /* @__PURE__ */ (0, import_jsx_runtime102.jsx)(number_control_default, { 28612 __next40pxDefaultSize: true, 28613 label, 28614 className: "components-angle-picker-control__input-field", 28615 max: 360, 28616 min: 0, 28617 onChange: handleOnNumberChange, 28618 step: "1", 28619 value, 28620 spinControls: "none", 28621 ...prefixOrSuffixProp 28622 }) 28623 }), /* @__PURE__ */ (0, import_jsx_runtime102.jsx)(component_default6, { 28624 marginBottom: "1", 28625 marginTop: "auto", 28626 children: /* @__PURE__ */ (0, import_jsx_runtime102.jsx)(angle_circle_default, { 28627 "aria-hidden": "true", 28628 value, 28629 onChange 28630 }) 28631 })] 28632 }); 28633 } 28634 var AnglePickerControl = (0, import_element37.forwardRef)(UnforwardedAnglePickerControl); 28635 var angle_picker_control_default = AnglePickerControl; 28636 28637 // packages/components/build-module/autocomplete/index.js 28638 var import_remove_accents3 = __toESM(require_remove_accents()); 28639 var import_element53 = __toESM(require_element()); 28640 var import_compose21 = __toESM(require_compose()); 28641 var import_rich_text2 = __toESM(require_rich_text()); 28642 var import_a11y2 = __toESM(require_a11y()); 28643 var import_keycodes = __toESM(require_keycodes()); 28644 28645 // packages/components/build-module/autocomplete/autocompleter-ui.js 28646 var import_react_dom6 = __toESM(require_react_dom()); 28647 var import_element52 = __toESM(require_element()); 28648 var import_rich_text = __toESM(require_rich_text()); 28649 var import_compose20 = __toESM(require_compose()); 28650 var import_a11y = __toESM(require_a11y()); 28651 var import_i18n8 = __toESM(require_i18n()); 28652 28653 // packages/components/build-module/autocomplete/get-default-use-items.js 28654 var import_remove_accents2 = __toESM(require_remove_accents()); 28655 var import_compose9 = __toESM(require_compose()); 28656 var import_element38 = __toESM(require_element()); 28657 28658 // packages/components/build-module/utils/strings.js 28659 var import_remove_accents = __toESM(require_remove_accents()); 28660 var ALL_UNICODE_DASH_CHARACTERS = new RegExp(/[\u007e\u00ad\u2053\u207b\u208b\u2212\p{Pd}]/gu); 28661 var normalizeTextString = (value) => { 28662 return (0, import_remove_accents.default)(value).normalize("NFKC").toLocaleLowerCase().replace(ALL_UNICODE_DASH_CHARACTERS, "-"); 28663 }; 28664 function kebabCase(str) { 28665 var _str$toString; 28666 let input = (_str$toString = str?.toString?.()) !== null && _str$toString !== void 0 ? _str$toString : ""; 28667 input = input.replace(/['\u2019]/, ""); 28668 return paramCase(input, { 28669 splitRegexp: [ 28670 /(?!(?:1ST|2ND|3RD|[4-9]TH)(?![a-z]))([a-z0-9])([A-Z])/g, 28671 // fooBar => foo-bar, 3Bar => 3-bar 28672 /(?!(?:1st|2nd|3rd|[4-9]th)(?![a-z]))([0-9])([a-z])/g, 28673 // 3bar => 3-bar 28674 /([A-Za-z])([0-9])/g, 28675 // Foo3 => foo-3, foo3 => foo-3 28676 /([A-Z])([A-Z][a-z])/g 28677 // FOOBar => foo-bar 28678 ] 28679 }); 28680 } 28681 function escapeRegExp(string) { 28682 return string.replace(/[\\^$.*+?()[\]{}|]/g, "\\$&"); 28683 } 28684 28685 // packages/components/build-module/autocomplete/get-default-use-items.js 28686 function filterOptions(search, options2 = [], maxResults = 10) { 28687 const filtered = []; 28688 for (let i3 = 0; i3 < options2.length; i3++) { 28689 const option = options2[i3]; 28690 let { 28691 keywords = [] 28692 } = option; 28693 if ("string" === typeof option.label) { 28694 keywords = [...keywords, option.label]; 28695 } 28696 const isMatch = keywords.some((keyword) => search.test((0, import_remove_accents2.default)(keyword))); 28697 if (!isMatch) { 28698 continue; 28699 } 28700 filtered.push(option); 28701 if (filtered.length === maxResults) { 28702 break; 28703 } 28704 } 28705 return filtered; 28706 } 28707 function getDefaultUseItems(autocompleter) { 28708 return (filterValue) => { 28709 const [items, setItems] = (0, import_element38.useState)([]); 28710 (0, import_element38.useLayoutEffect)(() => { 28711 const { 28712 options: options2, 28713 isDebounced 28714 } = autocompleter; 28715 const loadOptions = (0, import_compose9.debounce)(() => { 28716 const promise2 = Promise.resolve(typeof options2 === "function" ? options2(filterValue) : options2).then((optionsData) => { 28717 if (promise2.canceled) { 28718 return; 28719 } 28720 const keyedOptions = optionsData.map((optionData, optionIndex) => ({ 28721 key: `$autocompleter.name}-$optionIndex}`, 28722 value: optionData, 28723 label: autocompleter.getOptionLabel(optionData), 28724 keywords: autocompleter.getOptionKeywords ? autocompleter.getOptionKeywords(optionData) : [], 28725 isDisabled: autocompleter.isOptionDisabled ? autocompleter.isOptionDisabled(optionData) : false 28726 })); 28727 const search = new RegExp("(?:\\b|\\s|^)" + escapeRegExp(filterValue), "i"); 28728 setItems(filterOptions(search, keyedOptions)); 28729 }); 28730 return promise2; 28731 }, isDebounced ? 250 : 0); 28732 const promise = loadOptions(); 28733 return () => { 28734 loadOptions.cancel(); 28735 if (promise) { 28736 promise.canceled = true; 28737 } 28738 }; 28739 }, [filterValue]); 28740 return [items]; 28741 }; 28742 } 28743 28744 // node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.mjs 28745 var React7 = __toESM(require_react(), 1); 28746 var import_react98 = __toESM(require_react(), 1); 28747 var ReactDOM = __toESM(require_react_dom(), 1); 28748 var arrow3 = (options2) => { 28749 function isRef2(value) { 28750 return {}.hasOwnProperty.call(value, "current"); 28751 } 28752 return { 28753 name: "arrow", 28754 options: options2, 28755 fn(state) { 28756 const { 28757 element, 28758 padding: padding2 28759 } = typeof options2 === "function" ? options2(state) : options2; 28760 if (element && isRef2(element)) { 28761 if (element.current != null) { 28762 return arrow2({ 28763 element: element.current, 28764 padding: padding2 28765 }).fn(state); 28766 } 28767 return {}; 28768 } 28769 if (element) { 28770 return arrow2({ 28771 element, 28772 padding: padding2 28773 }).fn(state); 28774 } 28775 return {}; 28776 } 28777 }; 28778 }; 28779 var index = typeof document !== "undefined" ? import_react98.useLayoutEffect : import_react98.useEffect; 28780 function deepEqual(a3, b3) { 28781 if (a3 === b3) { 28782 return true; 28783 } 28784 if (typeof a3 !== typeof b3) { 28785 return false; 28786 } 28787 if (typeof a3 === "function" && a3.toString() === b3.toString()) { 28788 return true; 28789 } 28790 let length2; 28791 let i3; 28792 let keys; 28793 if (a3 && b3 && typeof a3 === "object") { 28794 if (Array.isArray(a3)) { 28795 length2 = a3.length; 28796 if (length2 !== b3.length) return false; 28797 for (i3 = length2; i3-- !== 0; ) { 28798 if (!deepEqual(a3[i3], b3[i3])) { 28799 return false; 28800 } 28801 } 28802 return true; 28803 } 28804 keys = Object.keys(a3); 28805 length2 = keys.length; 28806 if (length2 !== Object.keys(b3).length) { 28807 return false; 28808 } 28809 for (i3 = length2; i3-- !== 0; ) { 28810 if (!{}.hasOwnProperty.call(b3, keys[i3])) { 28811 return false; 28812 } 28813 } 28814 for (i3 = length2; i3-- !== 0; ) { 28815 const key = keys[i3]; 28816 if (key === "_owner" && a3.$$typeof) { 28817 continue; 28818 } 28819 if (!deepEqual(a3[key], b3[key])) { 28820 return false; 28821 } 28822 } 28823 return true; 28824 } 28825 return a3 !== a3 && b3 !== b3; 28826 } 28827 function getDPR(element) { 28828 if (typeof window === "undefined") { 28829 return 1; 28830 } 28831 const win = element.ownerDocument.defaultView || window; 28832 return win.devicePixelRatio || 1; 28833 } 28834 function roundByDPR2(element, value) { 28835 const dpr = getDPR(element); 28836 return Math.round(value * dpr) / dpr; 28837 } 28838 function useLatestRef(value) { 28839 const ref = React7.useRef(value); 28840 index(() => { 28841 ref.current = value; 28842 }); 28843 return ref; 28844 } 28845 function useFloating(options2) { 28846 if (options2 === void 0) { 28847 options2 = {}; 28848 } 28849 const { 28850 placement = "bottom", 28851 strategy = "absolute", 28852 middleware: middleware2 = [], 28853 platform: platform2, 28854 elements: { 28855 reference: externalReference, 28856 floating: externalFloating 28857 } = {}, 28858 transform = true, 28859 whileElementsMounted, 28860 open 28861 } = options2; 28862 const [data, setData] = React7.useState({ 28863 x: 0, 28864 y: 0, 28865 strategy, 28866 placement, 28867 middlewareData: {}, 28868 isPositioned: false 28869 }); 28870 const [latestMiddleware, setLatestMiddleware] = React7.useState(middleware2); 28871 if (!deepEqual(latestMiddleware, middleware2)) { 28872 setLatestMiddleware(middleware2); 28873 } 28874 const [_reference, _setReference] = React7.useState(null); 28875 const [_floating, _setFloating] = React7.useState(null); 28876 const setReference = React7.useCallback((node2) => { 28877 if (node2 !== referenceRef.current) { 28878 referenceRef.current = node2; 28879 _setReference(node2); 28880 } 28881 }, []); 28882 const setFloating = React7.useCallback((node2) => { 28883 if (node2 !== floatingRef.current) { 28884 floatingRef.current = node2; 28885 _setFloating(node2); 28886 } 28887 }, []); 28888 const referenceEl = externalReference || _reference; 28889 const floatingEl = externalFloating || _floating; 28890 const referenceRef = React7.useRef(null); 28891 const floatingRef = React7.useRef(null); 28892 const dataRef = React7.useRef(data); 28893 const hasWhileElementsMounted = whileElementsMounted != null; 28894 const whileElementsMountedRef = useLatestRef(whileElementsMounted); 28895 const platformRef = useLatestRef(platform2); 28896 const update = React7.useCallback(() => { 28897 if (!referenceRef.current || !floatingRef.current) { 28898 return; 28899 } 28900 const config = { 28901 placement, 28902 strategy, 28903 middleware: latestMiddleware 28904 }; 28905 if (platformRef.current) { 28906 config.platform = platformRef.current; 28907 } 28908 computePosition2(referenceRef.current, floatingRef.current, config).then((data2) => { 28909 const fullData = { 28910 ...data2, 28911 isPositioned: true 28912 }; 28913 if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) { 28914 dataRef.current = fullData; 28915 ReactDOM.flushSync(() => { 28916 setData(fullData); 28917 }); 28918 } 28919 }); 28920 }, [latestMiddleware, placement, strategy, platformRef]); 28921 index(() => { 28922 if (open === false && dataRef.current.isPositioned) { 28923 dataRef.current.isPositioned = false; 28924 setData((data2) => ({ 28925 ...data2, 28926 isPositioned: false 28927 })); 28928 } 28929 }, [open]); 28930 const isMountedRef = React7.useRef(false); 28931 index(() => { 28932 isMountedRef.current = true; 28933 return () => { 28934 isMountedRef.current = false; 28935 }; 28936 }, []); 28937 index(() => { 28938 if (referenceEl) referenceRef.current = referenceEl; 28939 if (floatingEl) floatingRef.current = floatingEl; 28940 if (referenceEl && floatingEl) { 28941 if (whileElementsMountedRef.current) { 28942 return whileElementsMountedRef.current(referenceEl, floatingEl, update); 28943 } 28944 update(); 28945 } 28946 }, [referenceEl, floatingEl, update, whileElementsMountedRef, hasWhileElementsMounted]); 28947 const refs = React7.useMemo(() => ({ 28948 reference: referenceRef, 28949 floating: floatingRef, 28950 setReference, 28951 setFloating 28952 }), [setReference, setFloating]); 28953 const elements2 = React7.useMemo(() => ({ 28954 reference: referenceEl, 28955 floating: floatingEl 28956 }), [referenceEl, floatingEl]); 28957 const floatingStyles = React7.useMemo(() => { 28958 const initialStyles = { 28959 position: strategy, 28960 left: 0, 28961 top: 0 28962 }; 28963 if (!elements2.floating) { 28964 return initialStyles; 28965 } 28966 const x2 = roundByDPR2(elements2.floating, data.x); 28967 const y3 = roundByDPR2(elements2.floating, data.y); 28968 if (transform) { 28969 return { 28970 ...initialStyles, 28971 transform: "translate(" + x2 + "px, " + y3 + "px)", 28972 ...getDPR(elements2.floating) >= 1.5 && { 28973 willChange: "transform" 28974 } 28975 }; 28976 } 28977 return { 28978 position: strategy, 28979 left: x2, 28980 top: y3 28981 }; 28982 }, [strategy, transform, elements2.floating, data.x, data.y]); 28983 return React7.useMemo(() => ({ 28984 ...data, 28985 update, 28986 refs, 28987 elements: elements2, 28988 floatingStyles 28989 }), [data, update, refs, elements2, floatingStyles]); 28990 } 28991 28992 // packages/components/build-module/popover/index.js 28993 var import_element51 = __toESM(require_element()); 28994 var import_compose19 = __toESM(require_compose()); 28995 var import_deprecated6 = __toESM(require_deprecated()); 28996 var import_primitives32 = __toESM(require_primitives()); 28997 var import_i18n7 = __toESM(require_i18n()); 28998 28999 // packages/components/build-module/scroll-lock/index.js 29000 var import_element39 = __toESM(require_element()); 29001 var previousScrollTop = 0; 29002 function setLocked(locked) { 29003 const scrollingElement = document.scrollingElement || document.body; 29004 if (locked) { 29005 previousScrollTop = scrollingElement.scrollTop; 29006 } 29007 const methodName = locked ? "add" : "remove"; 29008 scrollingElement.classList[methodName]("lockscroll"); 29009 document.documentElement.classList[methodName]("lockscroll"); 29010 if (!locked) { 29011 scrollingElement.scrollTop = previousScrollTop; 29012 } 29013 } 29014 var lockCounter = 0; 29015 function ScrollLock() { 29016 (0, import_element39.useEffect)(() => { 29017 if (lockCounter === 0) { 29018 setLocked(true); 29019 } 29020 ++lockCounter; 29021 return () => { 29022 if (lockCounter === 1) { 29023 setLocked(false); 29024 } 29025 --lockCounter; 29026 }; 29027 }, []); 29028 return null; 29029 } 29030 var scroll_lock_default = ScrollLock; 29031 29032 // packages/components/build-module/slot-fill/index.js 29033 var import_element50 = __toESM(require_element()); 29034 29035 // packages/components/build-module/slot-fill/fill.js 29036 var import_element41 = __toESM(require_element()); 29037 29038 // packages/components/build-module/slot-fill/context.js 29039 var import_compose10 = __toESM(require_compose()); 29040 var import_element40 = __toESM(require_element()); 29041 var initialValue = { 29042 slots: (0, import_compose10.observableMap)(), 29043 fills: (0, import_compose10.observableMap)(), 29044 registerSlot: () => { 29045 }, 29046 unregisterSlot: () => { 29047 }, 29048 registerFill: () => { 29049 }, 29050 unregisterFill: () => { 29051 }, 29052 updateFill: () => { 29053 } 29054 }; 29055 var SlotFillContext = (0, import_element40.createContext)(initialValue); 29056 SlotFillContext.displayName = "SlotFillContext"; 29057 var context_default = SlotFillContext; 29058 29059 // packages/components/build-module/slot-fill/fill.js 29060 function Fill({ 29061 name, 29062 children 29063 }) { 29064 const registry = (0, import_element41.useContext)(context_default); 29065 const instanceRef = (0, import_element41.useRef)({}); 29066 const childrenRef = (0, import_element41.useRef)(children); 29067 (0, import_element41.useLayoutEffect)(() => { 29068 childrenRef.current = children; 29069 }, [children]); 29070 (0, import_element41.useLayoutEffect)(() => { 29071 const instance = instanceRef.current; 29072 registry.registerFill(name, instance, childrenRef.current); 29073 return () => registry.unregisterFill(name, instance); 29074 }, [registry, name]); 29075 (0, import_element41.useLayoutEffect)(() => { 29076 registry.updateFill(name, instanceRef.current, childrenRef.current); 29077 }); 29078 return null; 29079 } 29080 29081 // packages/components/build-module/slot-fill/slot.js 29082 var import_compose11 = __toESM(require_compose()); 29083 var import_element42 = __toESM(require_element()); 29084 var import_jsx_runtime103 = __toESM(require_jsx_runtime()); 29085 function isFunction(maybeFunc) { 29086 return typeof maybeFunc === "function"; 29087 } 29088 function addKeysToChildren(children) { 29089 return import_element42.Children.map(children, (child, childIndex) => { 29090 if (!child || typeof child === "string") { 29091 return child; 29092 } 29093 let childKey = childIndex; 29094 if (typeof child === "object" && "key" in child && child?.key) { 29095 childKey = child.key; 29096 } 29097 return (0, import_element42.cloneElement)(child, { 29098 key: childKey 29099 }); 29100 }); 29101 } 29102 function Slot(props) { 29103 var _useObservableValue; 29104 const registry = (0, import_element42.useContext)(context_default); 29105 const instanceRef = (0, import_element42.useRef)({}); 29106 const { 29107 name, 29108 children, 29109 fillProps = {} 29110 } = props; 29111 (0, import_element42.useLayoutEffect)(() => { 29112 const instance = instanceRef.current; 29113 registry.registerSlot(name, instance); 29114 return () => registry.unregisterSlot(name, instance); 29115 }, [registry, name]); 29116 let fills = (_useObservableValue = (0, import_compose11.useObservableValue)(registry.fills, name)) !== null && _useObservableValue !== void 0 ? _useObservableValue : []; 29117 const currentSlot = (0, import_compose11.useObservableValue)(registry.slots, name); 29118 if (currentSlot !== instanceRef.current) { 29119 fills = []; 29120 } 29121 const renderedFills = fills.map((fill) => { 29122 const fillChildren = isFunction(fill.children) ? fill.children(fillProps) : fill.children; 29123 return addKeysToChildren(fillChildren); 29124 }).filter( 29125 // In some cases fills are rendered only when some conditions apply. 29126 // This ensures that we only use non-empty fills when rendering, i.e., 29127 // it allows us to render wrappers only when the fills are actually present. 29128 (element) => !(0, import_element42.isEmptyElement)(element) 29129 ); 29130 return /* @__PURE__ */ (0, import_jsx_runtime103.jsx)(import_jsx_runtime103.Fragment, { 29131 children: isFunction(children) ? children(renderedFills) : renderedFills 29132 }); 29133 } 29134 var slot_default = Slot; 29135 29136 // packages/components/build-module/slot-fill/bubbles-virtually/fill.js 29137 var import_compose13 = __toESM(require_compose()); 29138 var import_element44 = __toESM(require_element()); 29139 29140 // packages/components/build-module/slot-fill/bubbles-virtually/slot-fill-context.js 29141 var import_element43 = __toESM(require_element()); 29142 var import_warning4 = __toESM(require_warning()); 29143 var import_compose12 = __toESM(require_compose()); 29144 var initialContextValue = { 29145 slots: (0, import_compose12.observableMap)(), 29146 fills: (0, import_compose12.observableMap)(), 29147 registerSlot: () => { 29148 true ? (0, import_warning4.default)("Components must be wrapped within `SlotFillProvider`. See https://developer.wordpress.org/block-editor/components/slot-fill/") : void 0; 29149 }, 29150 updateSlot: () => { 29151 }, 29152 unregisterSlot: () => { 29153 }, 29154 registerFill: () => { 29155 }, 29156 unregisterFill: () => { 29157 }, 29158 // This helps the provider know if it's using the default context value or not. 29159 isDefault: true 29160 }; 29161 var SlotFillContext2 = (0, import_element43.createContext)(initialContextValue); 29162 SlotFillContext2.displayName = "SlotFillContext"; 29163 var slot_fill_context_default = SlotFillContext2; 29164 29165 // node_modules/uuid/dist/esm-browser/rng.js 29166 var getRandomValues; 29167 var rnds8 = new Uint8Array(16); 29168 function rng() { 29169 if (!getRandomValues) { 29170 getRandomValues = typeof crypto !== "undefined" && crypto.getRandomValues && crypto.getRandomValues.bind(crypto); 29171 if (!getRandomValues) { 29172 throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported"); 29173 } 29174 } 29175 return getRandomValues(rnds8); 29176 } 29177 29178 // node_modules/uuid/dist/esm-browser/stringify.js 29179 var byteToHex = []; 29180 for (let i3 = 0; i3 < 256; ++i3) { 29181 byteToHex.push((i3 + 256).toString(16).slice(1)); 29182 } 29183 function unsafeStringify(arr, offset3 = 0) { 29184 return byteToHex[arr[offset3 + 0]] + byteToHex[arr[offset3 + 1]] + byteToHex[arr[offset3 + 2]] + byteToHex[arr[offset3 + 3]] + "-" + byteToHex[arr[offset3 + 4]] + byteToHex[arr[offset3 + 5]] + "-" + byteToHex[arr[offset3 + 6]] + byteToHex[arr[offset3 + 7]] + "-" + byteToHex[arr[offset3 + 8]] + byteToHex[arr[offset3 + 9]] + "-" + byteToHex[arr[offset3 + 10]] + byteToHex[arr[offset3 + 11]] + byteToHex[arr[offset3 + 12]] + byteToHex[arr[offset3 + 13]] + byteToHex[arr[offset3 + 14]] + byteToHex[arr[offset3 + 15]]; 29185 } 29186 29187 // node_modules/uuid/dist/esm-browser/native.js 29188 var randomUUID = typeof crypto !== "undefined" && crypto.randomUUID && crypto.randomUUID.bind(crypto); 29189 var native_default = { 29190 randomUUID 29191 }; 29192 29193 // node_modules/uuid/dist/esm-browser/v4.js 29194 function v4(options2, buf, offset3) { 29195 if (native_default.randomUUID && !buf && !options2) { 29196 return native_default.randomUUID(); 29197 } 29198 options2 = options2 || {}; 29199 const rnds = options2.random || (options2.rng || rng)(); 29200 rnds[6] = rnds[6] & 15 | 64; 29201 rnds[8] = rnds[8] & 63 | 128; 29202 if (buf) { 29203 offset3 = offset3 || 0; 29204 for (let i3 = 0; i3 < 16; ++i3) { 29205 buf[offset3 + i3] = rnds[i3]; 29206 } 29207 return buf; 29208 } 29209 return unsafeStringify(rnds); 29210 } 29211 var v4_default = v4; 29212 29213 // packages/components/build-module/style-provider/index.js 29214 var import_jsx_runtime104 = __toESM(require_jsx_runtime()); 29215 var uuidCache = /* @__PURE__ */ new Set(); 29216 var containerCacheMap = /* @__PURE__ */ new WeakMap(); 29217 var memoizedCreateCacheWithContainer = (container) => { 29218 if (containerCacheMap.has(container)) { 29219 return containerCacheMap.get(container); 29220 } 29221 let key = v4_default().replace(/[0-9]/g, ""); 29222 while (uuidCache.has(key)) { 29223 key = v4_default().replace(/[0-9]/g, ""); 29224 } 29225 uuidCache.add(key); 29226 const cache2 = emotion_cache_browser_esm_default({ 29227 container, 29228 key 29229 }); 29230 containerCacheMap.set(container, cache2); 29231 return cache2; 29232 }; 29233 function StyleProvider(props) { 29234 const { 29235 children, 29236 document: document2 29237 } = props; 29238 if (!document2) { 29239 return null; 29240 } 29241 const cache2 = memoizedCreateCacheWithContainer(document2.head); 29242 return /* @__PURE__ */ (0, import_jsx_runtime104.jsx)(CacheProvider, { 29243 value: cache2, 29244 children 29245 }); 29246 } 29247 var style_provider_default = StyleProvider; 29248 29249 // packages/components/build-module/slot-fill/bubbles-virtually/fill.js 29250 var import_jsx_runtime105 = __toESM(require_jsx_runtime()); 29251 function Fill2({ 29252 name, 29253 children 29254 }) { 29255 var _slot$fillProps; 29256 const registry = (0, import_element44.useContext)(slot_fill_context_default); 29257 const slot = (0, import_compose13.useObservableValue)(registry.slots, name); 29258 const instanceRef = (0, import_element44.useRef)({}); 29259 (0, import_element44.useEffect)(() => { 29260 const instance = instanceRef.current; 29261 registry.registerFill(name, instance); 29262 return () => registry.unregisterFill(name, instance); 29263 }, [registry, name]); 29264 if (!slot || !slot.ref.current) { 29265 return null; 29266 } 29267 const wrappedChildren = /* @__PURE__ */ (0, import_jsx_runtime105.jsx)(style_provider_default, { 29268 document: slot.ref.current.ownerDocument, 29269 children: typeof children === "function" ? children((_slot$fillProps = slot.fillProps) !== null && _slot$fillProps !== void 0 ? _slot$fillProps : {}) : children 29270 }); 29271 return (0, import_element44.createPortal)(wrappedChildren, slot.ref.current); 29272 } 29273 29274 // packages/components/build-module/slot-fill/bubbles-virtually/slot.js 29275 var import_element45 = __toESM(require_element()); 29276 var import_compose14 = __toESM(require_compose()); 29277 var import_jsx_runtime106 = __toESM(require_jsx_runtime()); 29278 function Slot2(props, forwardedRef) { 29279 const { 29280 name, 29281 fillProps = {}, 29282 as, 29283 // `children` is not allowed. However, if it is passed, 29284 // it will be displayed as is, so remove `children`. 29285 children, 29286 ...restProps 29287 } = props; 29288 const registry = (0, import_element45.useContext)(slot_fill_context_default); 29289 const ref = (0, import_element45.useRef)(null); 29290 const fillPropsRef = (0, import_element45.useRef)(fillProps); 29291 (0, import_element45.useLayoutEffect)(() => { 29292 fillPropsRef.current = fillProps; 29293 }, [fillProps]); 29294 (0, import_element45.useLayoutEffect)(() => { 29295 registry.registerSlot(name, ref, fillPropsRef.current); 29296 return () => registry.unregisterSlot(name, ref); 29297 }, [registry, name]); 29298 (0, import_element45.useLayoutEffect)(() => { 29299 registry.updateSlot(name, ref, fillPropsRef.current); 29300 }); 29301 return /* @__PURE__ */ (0, import_jsx_runtime106.jsx)(component_default, { 29302 as, 29303 ref: (0, import_compose14.useMergeRefs)([forwardedRef, ref]), 29304 ...restProps 29305 }); 29306 } 29307 var slot_default2 = (0, import_element45.forwardRef)(Slot2); 29308 29309 // packages/components/build-module/slot-fill/bubbles-virtually/slot-fill-provider.js 29310 var import_element46 = __toESM(require_element()); 29311 var import_is_shallow_equal = __toESM(require_is_shallow_equal()); 29312 var import_compose15 = __toESM(require_compose()); 29313 var import_jsx_runtime107 = __toESM(require_jsx_runtime()); 29314 function createSlotRegistry() { 29315 const slots = (0, import_compose15.observableMap)(); 29316 const fills = (0, import_compose15.observableMap)(); 29317 const registerSlot = (name, ref, fillProps) => { 29318 slots.set(name, { 29319 ref, 29320 fillProps 29321 }); 29322 }; 29323 const unregisterSlot = (name, ref) => { 29324 const slot = slots.get(name); 29325 if (!slot) { 29326 return; 29327 } 29328 if (slot.ref !== ref) { 29329 return; 29330 } 29331 slots.delete(name); 29332 }; 29333 const updateSlot = (name, ref, fillProps) => { 29334 const slot = slots.get(name); 29335 if (!slot) { 29336 return; 29337 } 29338 if (slot.ref !== ref) { 29339 return; 29340 } 29341 if ((0, import_is_shallow_equal.default)(slot.fillProps, fillProps)) { 29342 return; 29343 } 29344 slots.set(name, { 29345 ref, 29346 fillProps 29347 }); 29348 }; 29349 const registerFill = (name, ref) => { 29350 fills.set(name, [...fills.get(name) || [], ref]); 29351 }; 29352 const unregisterFill = (name, ref) => { 29353 const fillsForName = fills.get(name); 29354 if (!fillsForName) { 29355 return; 29356 } 29357 fills.set(name, fillsForName.filter((fillRef) => fillRef !== ref)); 29358 }; 29359 return { 29360 slots, 29361 fills, 29362 registerSlot, 29363 updateSlot, 29364 unregisterSlot, 29365 registerFill, 29366 unregisterFill 29367 }; 29368 } 29369 function SlotFillProvider({ 29370 children 29371 }) { 29372 const [registry] = (0, import_element46.useState)(createSlotRegistry); 29373 return /* @__PURE__ */ (0, import_jsx_runtime107.jsx)(slot_fill_context_default.Provider, { 29374 value: registry, 29375 children 29376 }); 29377 } 29378 29379 // packages/components/build-module/slot-fill/provider.js 29380 var import_element47 = __toESM(require_element()); 29381 var import_compose16 = __toESM(require_compose()); 29382 var import_jsx_runtime108 = __toESM(require_jsx_runtime()); 29383 function createSlotRegistry2() { 29384 const slots = (0, import_compose16.observableMap)(); 29385 const fills = (0, import_compose16.observableMap)(); 29386 function registerSlot(name, instance) { 29387 slots.set(name, instance); 29388 } 29389 function unregisterSlot(name, instance) { 29390 if (slots.get(name) !== instance) { 29391 return; 29392 } 29393 slots.delete(name); 29394 } 29395 function registerFill(name, instance, children) { 29396 fills.set(name, [...fills.get(name) || [], { 29397 instance, 29398 children 29399 }]); 29400 } 29401 function unregisterFill(name, instance) { 29402 const fillsForName = fills.get(name); 29403 if (!fillsForName) { 29404 return; 29405 } 29406 fills.set(name, fillsForName.filter((fill) => fill.instance !== instance)); 29407 } 29408 function updateFill(name, instance, children) { 29409 const fillsForName = fills.get(name); 29410 if (!fillsForName) { 29411 return; 29412 } 29413 const fillForInstance = fillsForName.find((f3) => f3.instance === instance); 29414 if (!fillForInstance) { 29415 return; 29416 } 29417 if (fillForInstance.children === children) { 29418 return; 29419 } 29420 fills.set(name, fillsForName.map((f3) => { 29421 if (f3.instance === instance) { 29422 return { 29423 instance, 29424 children 29425 }; 29426 } 29427 return f3; 29428 })); 29429 } 29430 return { 29431 slots, 29432 fills, 29433 registerSlot, 29434 unregisterSlot, 29435 registerFill, 29436 unregisterFill, 29437 updateFill 29438 }; 29439 } 29440 function SlotFillProvider2({ 29441 children 29442 }) { 29443 const [contextValue] = (0, import_element47.useState)(createSlotRegistry2); 29444 return /* @__PURE__ */ (0, import_jsx_runtime108.jsx)(context_default.Provider, { 29445 value: contextValue, 29446 children 29447 }); 29448 } 29449 var provider_default = SlotFillProvider2; 29450 29451 // packages/components/build-module/slot-fill/index.js 29452 var import_jsx_runtime109 = __toESM(require_jsx_runtime()); 29453 29454 // packages/components/build-module/slot-fill/bubbles-virtually/use-slot.js 29455 var import_element48 = __toESM(require_element()); 29456 var import_compose17 = __toESM(require_compose()); 29457 function useSlot(name) { 29458 const registry = (0, import_element48.useContext)(slot_fill_context_default); 29459 const slot = (0, import_compose17.useObservableValue)(registry.slots, name); 29460 return { 29461 ...slot 29462 }; 29463 } 29464 29465 // packages/components/build-module/slot-fill/bubbles-virtually/use-slot-fills.js 29466 var import_element49 = __toESM(require_element()); 29467 var import_compose18 = __toESM(require_compose()); 29468 function useSlotFills(name) { 29469 const registry = (0, import_element49.useContext)(slot_fill_context_default); 29470 return (0, import_compose18.useObservableValue)(registry.fills, name); 29471 } 29472 29473 // packages/components/build-module/slot-fill/index.js 29474 function Fill3(props) { 29475 return /* @__PURE__ */ (0, import_jsx_runtime109.jsxs)(import_jsx_runtime109.Fragment, { 29476 children: [/* @__PURE__ */ (0, import_jsx_runtime109.jsx)(Fill, { 29477 ...props 29478 }), /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(Fill2, { 29479 ...props 29480 })] 29481 }); 29482 } 29483 function UnforwardedSlot(props, ref) { 29484 const { 29485 bubblesVirtually, 29486 ...restProps 29487 } = props; 29488 if (bubblesVirtually) { 29489 return /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(slot_default2, { 29490 ...restProps, 29491 ref 29492 }); 29493 } 29494 return /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(slot_default, { 29495 ...restProps 29496 }); 29497 } 29498 var Slot3 = (0, import_element50.forwardRef)(UnforwardedSlot); 29499 function Provider({ 29500 children, 29501 passthrough = false 29502 }) { 29503 const parent = (0, import_element50.useContext)(slot_fill_context_default); 29504 if (!parent.isDefault && passthrough) { 29505 return /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(import_jsx_runtime109.Fragment, { 29506 children 29507 }); 29508 } 29509 return /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(provider_default, { 29510 children: /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(SlotFillProvider, { 29511 children 29512 }) 29513 }); 29514 } 29515 Provider.displayName = "SlotFillProvider"; 29516 function createSlotFill(key) { 29517 const baseName = typeof key === "symbol" ? key.description : key; 29518 const FillComponent = (props) => /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(Fill3, { 29519 name: key, 29520 ...props 29521 }); 29522 FillComponent.displayName = `$baseName}Fill`; 29523 const SlotComponent = (props) => /* @__PURE__ */ (0, import_jsx_runtime109.jsx)(Slot3, { 29524 name: key, 29525 ...props 29526 }); 29527 SlotComponent.displayName = `$baseName}Slot`; 29528 SlotComponent.__unstableName = key; 29529 return { 29530 name: key, 29531 Fill: FillComponent, 29532 Slot: SlotComponent 29533 }; 29534 } 29535 29536 // packages/components/build-module/popover/overlay-middlewares.js 29537 function overlayMiddlewares() { 29538 return [{ 29539 name: "overlay", 29540 fn({ 29541 rects 29542 }) { 29543 return rects.reference; 29544 } 29545 }, size2({ 29546 apply({ 29547 rects, 29548 elements: elements2 29549 }) { 29550 var _elements$floating; 29551 const { 29552 firstElementChild 29553 } = (_elements$floating = elements2.floating) !== null && _elements$floating !== void 0 ? _elements$floating : {}; 29554 if (!(firstElementChild instanceof HTMLElement)) { 29555 return; 29556 } 29557 Object.assign(firstElementChild.style, { 29558 width: `$rects.reference.width}px`, 29559 height: `$rects.reference.height}px` 29560 }); 29561 } 29562 })]; 29563 } 29564 29565 // packages/components/build-module/popover/index.js 29566 var import_jsx_runtime110 = __toESM(require_jsx_runtime()); 29567 var SLOT_NAME = "Popover"; 29568 var OVERFLOW_PADDING = 8; 29569 var ArrowTriangle = () => /* @__PURE__ */ (0, import_jsx_runtime110.jsxs)(import_primitives32.SVG, { 29570 xmlns: "http://www.w3.org/2000/svg", 29571 viewBox: "0 0 100 100", 29572 className: "components-popover__triangle", 29573 role: "presentation", 29574 children: [/* @__PURE__ */ (0, import_jsx_runtime110.jsx)(import_primitives32.Path, { 29575 className: "components-popover__triangle-bg", 29576 d: "M 0 0 L 50 50 L 100 0" 29577 }), /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(import_primitives32.Path, { 29578 className: "components-popover__triangle-border", 29579 d: "M 0 0 L 50 50 L 100 0", 29580 vectorEffect: "non-scaling-stroke" 29581 })] 29582 }); 29583 var slotNameContext = (0, import_element51.createContext)(void 0); 29584 slotNameContext.displayName = "__unstableSlotNameContext"; 29585 var fallbackContainerClassname = "components-popover__fallback-container"; 29586 var getPopoverFallbackContainer = () => { 29587 let container = document.body.querySelector("." + fallbackContainerClassname); 29588 if (!container) { 29589 container = document.createElement("div"); 29590 container.className = fallbackContainerClassname; 29591 document.body.append(container); 29592 } 29593 return container; 29594 }; 29595 var UnforwardedPopover = (props, forwardedRef) => { 29596 const { 29597 animate = true, 29598 headerTitle, 29599 constrainTabbing, 29600 onClose, 29601 children, 29602 className: className2, 29603 noArrow = true, 29604 position: position2, 29605 placement: placementProp = "bottom-start", 29606 offset: offsetProp = 0, 29607 focusOnMount = "firstElement", 29608 anchor, 29609 expandOnMobile, 29610 onFocusOutside, 29611 __unstableSlotName = SLOT_NAME, 29612 flip: flip3 = true, 29613 resize = true, 29614 shift: shift3 = false, 29615 inline: inline3 = false, 29616 variant, 29617 style: contentStyle, 29618 // Deprecated props 29619 __unstableForcePosition, 29620 anchorRef, 29621 anchorRect, 29622 getAnchorRect, 29623 isAlternate, 29624 // Rest 29625 ...contentProps 29626 } = useContextSystem(props, "Popover"); 29627 let computedFlipProp = flip3; 29628 let computedResizeProp = resize; 29629 if (__unstableForcePosition !== void 0) { 29630 (0, import_deprecated6.default)("`__unstableForcePosition` prop in wp.components.Popover", { 29631 since: "6.1", 29632 version: "6.3", 29633 alternative: "`flip={ false }` and `resize={ false }`" 29634 }); 29635 computedFlipProp = !__unstableForcePosition; 29636 computedResizeProp = !__unstableForcePosition; 29637 } 29638 if (anchorRef !== void 0) { 29639 (0, import_deprecated6.default)("`anchorRef` prop in wp.components.Popover", { 29640 since: "6.1", 29641 alternative: "`anchor` prop" 29642 }); 29643 } 29644 if (anchorRect !== void 0) { 29645 (0, import_deprecated6.default)("`anchorRect` prop in wp.components.Popover", { 29646 since: "6.1", 29647 alternative: "`anchor` prop" 29648 }); 29649 } 29650 if (getAnchorRect !== void 0) { 29651 (0, import_deprecated6.default)("`getAnchorRect` prop in wp.components.Popover", { 29652 since: "6.1", 29653 alternative: "`anchor` prop" 29654 }); 29655 } 29656 const computedVariant = isAlternate ? "toolbar" : variant; 29657 if (isAlternate !== void 0) { 29658 (0, import_deprecated6.default)("`isAlternate` prop in wp.components.Popover", { 29659 since: "6.2", 29660 alternative: "`variant` prop with the `'toolbar'` value" 29661 }); 29662 } 29663 const arrowRef = (0, import_element51.useRef)(null); 29664 const [fallbackReferenceElement, setFallbackReferenceElement] = (0, import_element51.useState)(null); 29665 const anchorRefFallback = (0, import_element51.useCallback)((node2) => { 29666 setFallbackReferenceElement(node2); 29667 }, []); 29668 const isMobileViewport = (0, import_compose19.useViewportMatch)("medium", "<"); 29669 const isExpanded = expandOnMobile && isMobileViewport; 29670 const hasArrow = !isExpanded && !noArrow; 29671 const normalizedPlacementFromProps = position2 ? positionToPlacement(position2) : placementProp; 29672 const middleware2 = [...placementProp === "overlay" ? overlayMiddlewares() : [], offset2(offsetProp), computedFlipProp && flip2(), computedResizeProp && size2({ 29673 padding: OVERFLOW_PADDING, 29674 apply(sizeProps) { 29675 var _refs$floating$curren; 29676 const { 29677 firstElementChild 29678 } = (_refs$floating$curren = refs.floating.current) !== null && _refs$floating$curren !== void 0 ? _refs$floating$curren : {}; 29679 if (!(firstElementChild instanceof HTMLElement)) { 29680 return; 29681 } 29682 Object.assign(firstElementChild.style, { 29683 maxHeight: `$Math.max(0, sizeProps.availableHeight)}px`, 29684 overflow: "auto" 29685 }); 29686 } 29687 }), shift3 && shift2({ 29688 crossAxis: true, 29689 limiter: limitShift2(), 29690 padding: 1 29691 // Necessary to avoid flickering at the edge of the viewport. 29692 }), arrow3({ 29693 element: arrowRef 29694 })]; 29695 const slotName = (0, import_element51.useContext)(slotNameContext) || __unstableSlotName; 29696 const slot = useSlot(slotName); 29697 let onDialogClose; 29698 if (onClose || onFocusOutside) { 29699 onDialogClose = (type, event) => { 29700 if (type === "focus-outside") { 29701 const blurTarget = event?.target; 29702 const referenceElement = refs.reference.current; 29703 const floatingElement = refs.floating.current; 29704 const isBlurFromThisPopover = referenceElement && "contains" in referenceElement && referenceElement.contains(blurTarget) || floatingElement?.contains(blurTarget); 29705 if (!isBlurFromThisPopover) { 29706 return; 29707 } 29708 if (onFocusOutside) { 29709 onFocusOutside(event); 29710 } else if (onClose) { 29711 onClose(); 29712 } 29713 } else if (onClose) { 29714 onClose(); 29715 } 29716 }; 29717 } 29718 const [dialogRef, dialogProps] = (0, import_compose19.__experimentalUseDialog)({ 29719 constrainTabbing, 29720 focusOnMount, 29721 __unstableOnClose: onDialogClose, 29722 // @ts-expect-error The __unstableOnClose property needs to be deprecated first (see https://github.com/WordPress/gutenberg/pull/27675) 29723 onClose: onDialogClose 29724 }); 29725 const { 29726 // Positioning coordinates 29727 x: x2, 29728 y: y3, 29729 // Object with "regular" refs to both "reference" and "floating" 29730 refs, 29731 // Type of CSS position property to use (absolute or fixed) 29732 strategy, 29733 update, 29734 placement: computedPlacement, 29735 middlewareData: { 29736 arrow: arrowData 29737 } 29738 } = useFloating({ 29739 placement: normalizedPlacementFromProps === "overlay" ? void 0 : normalizedPlacementFromProps, 29740 middleware: middleware2, 29741 whileElementsMounted: (referenceParam, floatingParam, updateParam) => autoUpdate(referenceParam, floatingParam, updateParam, { 29742 layoutShift: false, 29743 animationFrame: true 29744 }) 29745 }); 29746 const arrowCallbackRef = (0, import_element51.useCallback)((node2) => { 29747 arrowRef.current = node2; 29748 update(); 29749 }, [update]); 29750 const anchorRefTop = anchorRef?.top; 29751 const anchorRefBottom = anchorRef?.bottom; 29752 const anchorRefStartContainer = anchorRef?.startContainer; 29753 const anchorRefCurrent = anchorRef?.current; 29754 (0, import_element51.useLayoutEffect)(() => { 29755 const resultingReferenceElement = getReferenceElement({ 29756 anchor, 29757 anchorRef, 29758 anchorRect, 29759 getAnchorRect, 29760 fallbackReferenceElement 29761 }); 29762 refs.setReference(resultingReferenceElement); 29763 }, [anchor, anchorRef, anchorRefTop, anchorRefBottom, anchorRefStartContainer, anchorRefCurrent, anchorRect, getAnchorRect, fallbackReferenceElement, refs]); 29764 const mergedFloatingRef = (0, import_compose19.useMergeRefs)([refs.setFloating, dialogRef, forwardedRef]); 29765 const style2 = isExpanded ? void 0 : { 29766 position: strategy, 29767 top: 0, 29768 left: 0, 29769 // `x` and `y` are framer-motion specific props and are shorthands 29770 // for `translateX` and `translateY`. Currently it is not possible 29771 // to use `translateX` and `translateY` because those values would 29772 // be overridden by the return value of the 29773 // `placementToMotionAnimationProps` function. 29774 x: computePopoverPosition(x2), 29775 y: computePopoverPosition(y3) 29776 }; 29777 const shouldReduceMotion = (0, import_compose19.useReducedMotion)(); 29778 const shouldAnimate = animate && !isExpanded && !shouldReduceMotion; 29779 const [animationFinished, setAnimationFinished] = (0, import_element51.useState)(false); 29780 const { 29781 style: motionInlineStyles, 29782 ...otherMotionProps 29783 } = (0, import_element51.useMemo)(() => placementToMotionAnimationProps(computedPlacement), [computedPlacement]); 29784 const animationProps = shouldAnimate ? { 29785 style: { 29786 ...contentStyle, 29787 ...motionInlineStyles, 29788 ...style2 29789 }, 29790 onAnimationComplete: () => setAnimationFinished(true), 29791 ...otherMotionProps 29792 } : { 29793 animate: false, 29794 style: { 29795 ...contentStyle, 29796 ...style2 29797 } 29798 }; 29799 const isPositioned = (!shouldAnimate || animationFinished) && x2 !== null && y3 !== null; 29800 let content = /* @__PURE__ */ (0, import_jsx_runtime110.jsxs)(motion.div, { 29801 className: clsx_default(className2, { 29802 "is-expanded": isExpanded, 29803 "is-positioned": isPositioned, 29804 // Use the 'alternate' classname for 'toolbar' variant for back compat. 29805 [`is-$computedVariant === "toolbar" ? "alternate" : computedVariant}`]: computedVariant 29806 }), 29807 ...animationProps, 29808 ...contentProps, 29809 ref: mergedFloatingRef, 29810 ...dialogProps, 29811 tabIndex: -1, 29812 children: [isExpanded && /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(scroll_lock_default, {}), isExpanded && /* @__PURE__ */ (0, import_jsx_runtime110.jsxs)("div", { 29813 className: "components-popover__header", 29814 children: [/* @__PURE__ */ (0, import_jsx_runtime110.jsx)("span", { 29815 className: "components-popover__header-title", 29816 children: headerTitle 29817 }), /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(button_default, { 29818 className: "components-popover__close", 29819 size: "small", 29820 icon: close_default, 29821 onClick: onClose, 29822 label: (0, import_i18n7.__)("Close") 29823 })] 29824 }), /* @__PURE__ */ (0, import_jsx_runtime110.jsx)("div", { 29825 className: "components-popover__content", 29826 children 29827 }), hasArrow && /* @__PURE__ */ (0, import_jsx_runtime110.jsx)("div", { 29828 ref: arrowCallbackRef, 29829 className: ["components-popover__arrow", `is-$computedPlacement.split("-")[0]}`].join(" "), 29830 style: { 29831 left: typeof arrowData?.x !== "undefined" && Number.isFinite(arrowData.x) ? `$arrowData.x}px` : "", 29832 top: typeof arrowData?.y !== "undefined" && Number.isFinite(arrowData.y) ? `$arrowData.y}px` : "" 29833 }, 29834 children: /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(ArrowTriangle, {}) 29835 })] 29836 }); 29837 const shouldRenderWithinSlot = slot.ref && !inline3; 29838 const hasAnchor = anchorRef || anchorRect || anchor; 29839 if (shouldRenderWithinSlot) { 29840 content = /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(Fill3, { 29841 name: slotName, 29842 children: content 29843 }); 29844 } else if (!inline3) { 29845 content = (0, import_element51.createPortal)(/* @__PURE__ */ (0, import_jsx_runtime110.jsx)(StyleProvider, { 29846 document, 29847 children: content 29848 }), getPopoverFallbackContainer()); 29849 } 29850 if (hasAnchor) { 29851 return content; 29852 } 29853 return /* @__PURE__ */ (0, import_jsx_runtime110.jsxs)(import_jsx_runtime110.Fragment, { 29854 children: [/* @__PURE__ */ (0, import_jsx_runtime110.jsx)("span", { 29855 ref: anchorRefFallback 29856 }), content] 29857 }); 29858 }; 29859 var PopoverSlot = (0, import_element51.forwardRef)(({ 29860 name = SLOT_NAME 29861 }, ref) => { 29862 return /* @__PURE__ */ (0, import_jsx_runtime110.jsx)(Slot3, { 29863 bubblesVirtually: true, 29864 name, 29865 className: "popover-slot", 29866 ref 29867 }); 29868 }); 29869 var Popover3 = Object.assign(contextConnect(UnforwardedPopover, "Popover"), { 29870 /** 29871 * Renders a slot that is used internally by Popover for rendering content. 29872 */ 29873 Slot: Object.assign(PopoverSlot, { 29874 displayName: "Popover.Slot" 29875 }), 29876 /** 29877 * Provides a context to manage popover slot names. 29878 * 29879 * This is marked as unstable and should not be used directly. 29880 */ 29881 __unstableSlotNameProvider: Object.assign(slotNameContext.Provider, { 29882 displayName: "Popover.__unstableSlotNameProvider" 29883 }) 29884 }); 29885 var popover_default = Popover3; 29886 29887 // packages/components/build-module/autocomplete/autocompleter-ui.js 29888 var import_jsx_runtime111 = __toESM(require_jsx_runtime()); 29889 function ListBox({ 29890 items, 29891 onSelect, 29892 selectedIndex, 29893 instanceId, 29894 listBoxId, 29895 className: className2, 29896 Component: Component9 = "div" 29897 }) { 29898 return /* @__PURE__ */ (0, import_jsx_runtime111.jsx)(Component9, { 29899 id: listBoxId, 29900 role: "listbox", 29901 className: "components-autocomplete__results", 29902 children: items.map((option, index2) => /* @__PURE__ */ (0, import_jsx_runtime111.jsx)(button_default, { 29903 id: `components-autocomplete-item-$instanceId}-$option.key}`, 29904 role: "option", 29905 __next40pxDefaultSize: true, 29906 "aria-selected": index2 === selectedIndex, 29907 accessibleWhenDisabled: true, 29908 disabled: option.isDisabled, 29909 className: clsx_default("components-autocomplete__result", className2, { 29910 // Unused, for backwards compatibility. 29911 "is-selected": index2 === selectedIndex 29912 }), 29913 variant: index2 === selectedIndex ? "primary" : void 0, 29914 onClick: () => onSelect(option), 29915 children: option.label 29916 }, option.key)) 29917 }); 29918 } 29919 function getAutoCompleterUI(autocompleter) { 29920 var _autocompleter$useIte; 29921 const useItems = (_autocompleter$useIte = autocompleter.useItems) !== null && _autocompleter$useIte !== void 0 ? _autocompleter$useIte : getDefaultUseItems(autocompleter); 29922 function AutocompleterUI({ 29923 filterValue, 29924 instanceId, 29925 listBoxId, 29926 className: className2, 29927 selectedIndex, 29928 onChangeOptions, 29929 onSelect, 29930 onReset, 29931 reset, 29932 contentRef 29933 }) { 29934 const [items] = useItems(filterValue); 29935 const popoverAnchor = (0, import_rich_text.useAnchor)({ 29936 editableContentElement: contentRef.current 29937 }); 29938 const [needsA11yCompat, setNeedsA11yCompat] = (0, import_element52.useState)(false); 29939 const popoverRef = (0, import_element52.useRef)(null); 29940 const popoverRefs = (0, import_compose20.useMergeRefs)([popoverRef, (0, import_compose20.useRefEffect)((node2) => { 29941 if (!contentRef.current) { 29942 return; 29943 } 29944 setNeedsA11yCompat(node2.ownerDocument !== contentRef.current.ownerDocument); 29945 }, [contentRef])]); 29946 useOnClickOutside(popoverRef, reset); 29947 const debouncedSpeak = (0, import_compose20.useDebounce)(import_a11y.speak, 500); 29948 function announce(options2) { 29949 if (!debouncedSpeak) { 29950 return; 29951 } 29952 if (!!options2.length) { 29953 if (filterValue) { 29954 debouncedSpeak((0, import_i18n8.sprintf)( 29955 /* translators: %d: number of results. */ 29956 (0, import_i18n8._n)("%d result found, use up and down arrow keys to navigate.", "%d results found, use up and down arrow keys to navigate.", options2.length), 29957 options2.length 29958 ), "assertive"); 29959 } else { 29960 debouncedSpeak((0, import_i18n8.sprintf)( 29961 /* translators: %d: number of results. */ 29962 (0, import_i18n8._n)("Initial %d result loaded. Type to filter all available results. Use up and down arrow keys to navigate.", "Initial %d results loaded. Type to filter all available results. Use up and down arrow keys to navigate.", options2.length), 29963 options2.length 29964 ), "assertive"); 29965 } 29966 } else { 29967 debouncedSpeak((0, import_i18n8.__)("No results."), "assertive"); 29968 } 29969 } 29970 (0, import_element52.useLayoutEffect)(() => { 29971 onChangeOptions(items); 29972 announce(items); 29973 }, [items]); 29974 if (items.length === 0) { 29975 return null; 29976 } 29977 return /* @__PURE__ */ (0, import_jsx_runtime111.jsxs)(import_jsx_runtime111.Fragment, { 29978 children: [/* @__PURE__ */ (0, import_jsx_runtime111.jsx)(popover_default, { 29979 offset: 8, 29980 focusOnMount: false, 29981 onClose: onReset, 29982 placement: "top-start", 29983 className: "components-autocomplete__popover", 29984 anchor: popoverAnchor, 29985 ref: popoverRefs, 29986 children: /* @__PURE__ */ (0, import_jsx_runtime111.jsx)(ListBox, { 29987 items, 29988 onSelect, 29989 selectedIndex, 29990 instanceId, 29991 listBoxId, 29992 className: className2 29993 }) 29994 }), contentRef.current && needsA11yCompat && (0, import_react_dom6.createPortal)(/* @__PURE__ */ (0, import_jsx_runtime111.jsx)(ListBox, { 29995 items, 29996 onSelect, 29997 selectedIndex, 29998 instanceId, 29999 listBoxId, 30000 className: className2, 30001 Component: component_default2 30002 }), contentRef.current.ownerDocument.body)] 30003 }); 30004 } 30005 return AutocompleterUI; 30006 } 30007 function useOnClickOutside(ref, handler) { 30008 (0, import_element52.useEffect)(() => { 30009 const listener = (event) => { 30010 if (!ref.current || ref.current.contains(event.target)) { 30011 return; 30012 } 30013 handler(event); 30014 }; 30015 document.addEventListener("mousedown", listener); 30016 document.addEventListener("touchstart", listener); 30017 return () => { 30018 document.removeEventListener("mousedown", listener); 30019 document.removeEventListener("touchstart", listener); 30020 }; 30021 }, [handler, ref]); 30022 } 30023 30024 // packages/components/build-module/utils/get-node-text.js 30025 var getNodeText = (node2) => { 30026 if (node2 === null) { 30027 return ""; 30028 } 30029 switch (typeof node2) { 30030 case "string": 30031 case "number": 30032 return node2.toString(); 30033 case "object": { 30034 if (node2 instanceof Array) { 30035 return node2.map(getNodeText).join(""); 30036 } 30037 if ("props" in node2) { 30038 return getNodeText(node2.props.children); 30039 } 30040 return ""; 30041 } 30042 default: 30043 return ""; 30044 } 30045 }; 30046 var get_node_text_default = getNodeText; 30047 30048 // packages/components/build-module/autocomplete/index.js 30049 var import_jsx_runtime112 = __toESM(require_jsx_runtime()); 30050 var EMPTY_FILTERED_OPTIONS = []; 30051 var AUTOCOMPLETE_HOOK_REFERENCE = {}; 30052 function useAutocomplete({ 30053 record, 30054 onChange, 30055 onReplace, 30056 completers, 30057 contentRef 30058 }) { 30059 const instanceId = (0, import_compose21.useInstanceId)(AUTOCOMPLETE_HOOK_REFERENCE); 30060 const [selectedIndex, setSelectedIndex] = (0, import_element53.useState)(0); 30061 const [filteredOptions, setFilteredOptions] = (0, import_element53.useState)(EMPTY_FILTERED_OPTIONS); 30062 const [filterValue, setFilterValue] = (0, import_element53.useState)(""); 30063 const [autocompleter, setAutocompleter] = (0, import_element53.useState)(null); 30064 const [AutocompleterUI, setAutocompleterUI] = (0, import_element53.useState)(null); 30065 const backspacingRef = (0, import_element53.useRef)(false); 30066 function insertCompletion(replacement) { 30067 if (autocompleter === null) { 30068 return; 30069 } 30070 const end = record.start; 30071 const start = end - autocompleter.triggerPrefix.length - filterValue.length; 30072 const toInsert = (0, import_rich_text2.create)({ 30073 html: (0, import_element53.renderToString)(replacement) 30074 }); 30075 onChange((0, import_rich_text2.insert)(record, toInsert, start, end)); 30076 } 30077 function select(option) { 30078 const { 30079 getOptionCompletion 30080 } = autocompleter || {}; 30081 if (option.isDisabled) { 30082 return; 30083 } 30084 if (getOptionCompletion) { 30085 const completion = getOptionCompletion(option.value, filterValue); 30086 const isCompletionObject = (obj) => { 30087 return obj !== null && typeof obj === "object" && "action" in obj && obj.action !== void 0 && "value" in obj && obj.value !== void 0; 30088 }; 30089 const completionObject = isCompletionObject(completion) ? completion : { 30090 action: "insert-at-caret", 30091 value: completion 30092 }; 30093 if ("replace" === completionObject.action) { 30094 onReplace([completionObject.value]); 30095 return; 30096 } else if ("insert-at-caret" === completionObject.action) { 30097 insertCompletion(completionObject.value); 30098 } 30099 } 30100 reset(); 30101 contentRef.current?.focus(); 30102 } 30103 function reset() { 30104 setSelectedIndex(0); 30105 setFilteredOptions(EMPTY_FILTERED_OPTIONS); 30106 setFilterValue(""); 30107 setAutocompleter(null); 30108 setAutocompleterUI(null); 30109 } 30110 function onChangeOptions(options2) { 30111 setSelectedIndex(options2.length === filteredOptions.length ? selectedIndex : 0); 30112 setFilteredOptions(options2); 30113 } 30114 function handleKeyDown(event) { 30115 backspacingRef.current = event.key === "Backspace"; 30116 if (!autocompleter) { 30117 return; 30118 } 30119 if (filteredOptions.length === 0) { 30120 return; 30121 } 30122 if (event.defaultPrevented) { 30123 return; 30124 } 30125 switch (event.key) { 30126 case "ArrowUp": { 30127 const newIndex = (selectedIndex === 0 ? filteredOptions.length : selectedIndex) - 1; 30128 setSelectedIndex(newIndex); 30129 if ((0, import_keycodes.isAppleOS)()) { 30130 (0, import_a11y2.speak)(get_node_text_default(filteredOptions[newIndex].label), "assertive"); 30131 } 30132 break; 30133 } 30134 case "ArrowDown": { 30135 const newIndex = (selectedIndex + 1) % filteredOptions.length; 30136 setSelectedIndex(newIndex); 30137 if ((0, import_keycodes.isAppleOS)()) { 30138 (0, import_a11y2.speak)(get_node_text_default(filteredOptions[newIndex].label), "assertive"); 30139 } 30140 break; 30141 } 30142 case "Escape": 30143 setAutocompleter(null); 30144 setAutocompleterUI(null); 30145 event.preventDefault(); 30146 break; 30147 case "Enter": 30148 select(filteredOptions[selectedIndex]); 30149 break; 30150 case "ArrowLeft": 30151 case "ArrowRight": 30152 reset(); 30153 return; 30154 default: 30155 return; 30156 } 30157 event.preventDefault(); 30158 } 30159 const textContent = (0, import_element53.useMemo)(() => { 30160 if ((0, import_rich_text2.isCollapsed)(record)) { 30161 return (0, import_rich_text2.getTextContent)((0, import_rich_text2.slice)(record, 0)); 30162 } 30163 return ""; 30164 }, [record]); 30165 (0, import_element53.useEffect)(() => { 30166 if (!textContent) { 30167 if (autocompleter) { 30168 reset(); 30169 } 30170 return; 30171 } 30172 const completer = completers.reduce((lastTrigger, currentCompleter) => { 30173 const triggerIndex2 = textContent.lastIndexOf(currentCompleter.triggerPrefix); 30174 const lastTriggerIndex = lastTrigger !== null ? textContent.lastIndexOf(lastTrigger.triggerPrefix) : -1; 30175 return triggerIndex2 > lastTriggerIndex ? currentCompleter : lastTrigger; 30176 }, null); 30177 if (!completer) { 30178 if (autocompleter) { 30179 reset(); 30180 } 30181 return; 30182 } 30183 const { 30184 allowContext, 30185 triggerPrefix 30186 } = completer; 30187 const triggerIndex = textContent.lastIndexOf(triggerPrefix); 30188 const textWithoutTrigger = textContent.slice(triggerIndex + triggerPrefix.length); 30189 const tooDistantFromTrigger = textWithoutTrigger.length > 50; 30190 if (tooDistantFromTrigger) { 30191 return; 30192 } 30193 const mismatch = filteredOptions.length === 0; 30194 const wordsFromTrigger = textWithoutTrigger.split(/\s/); 30195 const hasOneTriggerWord = wordsFromTrigger.length === 1; 30196 const matchingWhileBackspacing = backspacingRef.current && wordsFromTrigger.length <= 3; 30197 if (mismatch && !(matchingWhileBackspacing || hasOneTriggerWord)) { 30198 if (autocompleter) { 30199 reset(); 30200 } 30201 return; 30202 } 30203 const textAfterSelection = (0, import_rich_text2.getTextContent)((0, import_rich_text2.slice)(record, void 0, (0, import_rich_text2.getTextContent)(record).length)); 30204 if (allowContext && !allowContext(textContent.slice(0, triggerIndex), textAfterSelection)) { 30205 if (autocompleter) { 30206 reset(); 30207 } 30208 return; 30209 } 30210 if (/^\s/.test(textWithoutTrigger) || /\s\s+$/.test(textWithoutTrigger)) { 30211 if (autocompleter) { 30212 reset(); 30213 } 30214 return; 30215 } 30216 if (!/[\u0000-\uFFFF]*$/.test(textWithoutTrigger)) { 30217 if (autocompleter) { 30218 reset(); 30219 } 30220 return; 30221 } 30222 const safeTrigger = escapeRegExp(completer.triggerPrefix); 30223 const text = (0, import_remove_accents3.default)(textContent); 30224 const match5 = text.slice(text.lastIndexOf(completer.triggerPrefix)).match(new RegExp(`$safeTrigger}([\0-\uFFFF]*)$`)); 30225 const query = match5 && match5[1]; 30226 setAutocompleter(completer); 30227 setAutocompleterUI(() => completer !== autocompleter ? getAutoCompleterUI(completer) : AutocompleterUI); 30228 setFilterValue(query === null ? "" : query); 30229 }, [textContent]); 30230 const { 30231 key: selectedKey = "" 30232 } = filteredOptions[selectedIndex] || {}; 30233 const { 30234 className: className2 30235 } = autocompleter || {}; 30236 const isExpanded = !!autocompleter && filteredOptions.length > 0; 30237 const listBoxId = isExpanded ? `components-autocomplete-listbox-$instanceId}` : void 0; 30238 const activeId = isExpanded ? `components-autocomplete-item-$instanceId}-$selectedKey}` : null; 30239 const hasSelection = record.start !== void 0; 30240 const showPopover = !!textContent && hasSelection && !!AutocompleterUI; 30241 return { 30242 listBoxId, 30243 activeId, 30244 onKeyDown: withIgnoreIMEEvents(handleKeyDown), 30245 popover: showPopover && /* @__PURE__ */ (0, import_jsx_runtime112.jsx)(AutocompleterUI, { 30246 className: className2, 30247 filterValue, 30248 instanceId, 30249 listBoxId, 30250 selectedIndex, 30251 onChangeOptions, 30252 onSelect: select, 30253 value: record, 30254 contentRef, 30255 reset 30256 }) 30257 }; 30258 } 30259 function useLastDifferentValue(value) { 30260 const history = (0, import_element53.useRef)(/* @__PURE__ */ new Set()); 30261 history.current.add(value); 30262 if (history.current.size > 2) { 30263 history.current.delete(Array.from(history.current)[0]); 30264 } 30265 return Array.from(history.current)[0]; 30266 } 30267 function useAutocompleteProps(options2) { 30268 const ref = (0, import_element53.useRef)(null); 30269 const onKeyDownRef = (0, import_element53.useRef)(); 30270 const { 30271 record 30272 } = options2; 30273 const previousRecord = useLastDifferentValue(record); 30274 const { 30275 popover, 30276 listBoxId, 30277 activeId, 30278 onKeyDown 30279 } = useAutocomplete({ 30280 ...options2, 30281 contentRef: ref 30282 }); 30283 onKeyDownRef.current = onKeyDown; 30284 const mergedRefs = (0, import_compose21.useMergeRefs)([ref, (0, import_compose21.useRefEffect)((element) => { 30285 function _onKeyDown(event) { 30286 onKeyDownRef.current?.(event); 30287 } 30288 element.addEventListener("keydown", _onKeyDown); 30289 return () => { 30290 element.removeEventListener("keydown", _onKeyDown); 30291 }; 30292 }, [])]); 30293 const didUserInput = record.text !== previousRecord?.text; 30294 if (!didUserInput) { 30295 return { 30296 ref: mergedRefs 30297 }; 30298 } 30299 return { 30300 ref: mergedRefs, 30301 children: popover, 30302 "aria-autocomplete": listBoxId ? "list" : void 0, 30303 "aria-owns": listBoxId, 30304 "aria-activedescendant": activeId 30305 }; 30306 } 30307 function Autocomplete({ 30308 children, 30309 isSelected: isSelected2, 30310 ...options2 30311 }) { 30312 const { 30313 popover, 30314 ...props 30315 } = useAutocomplete(options2); 30316 return /* @__PURE__ */ (0, import_jsx_runtime112.jsxs)(import_jsx_runtime112.Fragment, { 30317 children: [children(props), isSelected2 && popover] 30318 }); 30319 } 30320 30321 // packages/components/build-module/border-box-control/border-box-control/component.js 30322 var import_i18n26 = __toESM(require_i18n()); 30323 var import_element92 = __toESM(require_element()); 30324 var import_compose39 = __toESM(require_compose()); 30325 30326 // packages/components/build-module/border-box-control/border-box-control-linked-button/component.js 30327 var import_i18n9 = __toESM(require_i18n()); 30328 30329 // packages/components/build-module/border-box-control/border-box-control-linked-button/hook.js 30330 var import_element54 = __toESM(require_element()); 30331 30332 // packages/components/build-module/border-box-control/styles.js 30333 function _EMOTION_STRINGIFIED_CSS_ERROR__9() { 30334 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 30335 } 30336 var borderBoxControl = /* @__PURE__ */ css(false ? "" : ";label:borderBoxControl;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhbUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4uL2JvcmRlci1jb250cm9sL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgQm9yZGVycyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbCA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgbGlua2VkQm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0ZmxleDogMTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiAnMjRweCcgfSApKCkgfVxuYDtcblxuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sTGlua2VkQnV0dG9uID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnOHB4JyA6ICczcHgnIH07XG5cdFx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSgpIH1cblx0XHRsaW5lLWhlaWdodDogMDtcblx0YDtcbn07XG5cbmNvbnN0IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHtcblx0XHRjb2xvciA9IENPTE9SUy5ncmF5WyAyMDAgXSxcblx0XHRzdHlsZSA9ICdzb2xpZCcsXG5cdFx0d2lkdGggPSBDT05GSUcuYm9yZGVyV2lkdGgsXG5cdH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgY2xhbXBlZFdpZHRoID1cblx0XHR3aWR0aCAhPT0gQ09ORklHLmJvcmRlcldpZHRoID8gYGNsYW1wKDFweCwgJHsgd2lkdGggfSwgMTBweClgIDogd2lkdGg7XG5cdGNvbnN0IGhhc1Zpc2libGVCb3JkZXIgPSAoICEhIHdpZHRoICYmIHdpZHRoICE9PSAnMCcgKSB8fCAhISBjb2xvcjtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBoYXNWaXNpYmxlQm9yZGVyID8gc3R5bGUgfHwgJ3NvbGlkJyA6IHN0eWxlO1xuXG5cdHJldHVybiBgJHsgY29sb3IgfSAkeyBib3JkZXJTdHlsZSB9ICR7IGNsYW1wZWRXaWR0aCB9YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sVmlzdWFsaXplciA9IChcblx0Ym9yZGVycz86IEJvcmRlcnMsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHR0b3A6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdHJpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3R0b206ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdGxlZnQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICczOXB4JyA6ICcyOXB4JyB9O1xuXHRcdGJvcmRlci10b3A6ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy50b3AgKSB9O1xuXHRcdGJvcmRlci1ib3R0b206ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5ib3R0b20gKSB9O1xuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyTGVmdDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LmxlZnQgKSxcblx0XHR9ICkoKSB9XG5cdFx0JHsgcnRsKCB7XG5cdFx0XHRib3JkZXJSaWdodDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LnJpZ2h0ICksXG5cdFx0fSApKCkgfVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2xTcGxpdENvbnRyb2xzID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRmbGV4OiAxO1xuXHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gdW5kZWZpbmVkIDogJzgwJScgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjZW50ZXJlZEJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGdyaWQtY29sdW1uOiBzcGFuIDI7XG5cdG1hcmdpbjogMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IHJpZ2h0Qm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6ICdhdXRvJyB9ICkoKSB9XG5gO1xuIl19 */"); 30337 var linkedBorderControl = () => /* @__PURE__ */ css("flex:1;", rtl({ 30338 marginRight: "24px" 30339 })(), ";" + (false ? "" : ";label:linkedBorderControl;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlNEMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4uL2JvcmRlci1jb250cm9sL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgQm9yZGVycyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbCA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgbGlua2VkQm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0ZmxleDogMTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiAnMjRweCcgfSApKCkgfVxuYDtcblxuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sTGlua2VkQnV0dG9uID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnOHB4JyA6ICczcHgnIH07XG5cdFx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSgpIH1cblx0XHRsaW5lLWhlaWdodDogMDtcblx0YDtcbn07XG5cbmNvbnN0IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHtcblx0XHRjb2xvciA9IENPTE9SUy5ncmF5WyAyMDAgXSxcblx0XHRzdHlsZSA9ICdzb2xpZCcsXG5cdFx0d2lkdGggPSBDT05GSUcuYm9yZGVyV2lkdGgsXG5cdH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgY2xhbXBlZFdpZHRoID1cblx0XHR3aWR0aCAhPT0gQ09ORklHLmJvcmRlcldpZHRoID8gYGNsYW1wKDFweCwgJHsgd2lkdGggfSwgMTBweClgIDogd2lkdGg7XG5cdGNvbnN0IGhhc1Zpc2libGVCb3JkZXIgPSAoICEhIHdpZHRoICYmIHdpZHRoICE9PSAnMCcgKSB8fCAhISBjb2xvcjtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBoYXNWaXNpYmxlQm9yZGVyID8gc3R5bGUgfHwgJ3NvbGlkJyA6IHN0eWxlO1xuXG5cdHJldHVybiBgJHsgY29sb3IgfSAkeyBib3JkZXJTdHlsZSB9ICR7IGNsYW1wZWRXaWR0aCB9YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sVmlzdWFsaXplciA9IChcblx0Ym9yZGVycz86IEJvcmRlcnMsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHR0b3A6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdHJpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3R0b206ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdGxlZnQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICczOXB4JyA6ICcyOXB4JyB9O1xuXHRcdGJvcmRlci10b3A6ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy50b3AgKSB9O1xuXHRcdGJvcmRlci1ib3R0b206ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5ib3R0b20gKSB9O1xuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyTGVmdDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LmxlZnQgKSxcblx0XHR9ICkoKSB9XG5cdFx0JHsgcnRsKCB7XG5cdFx0XHRib3JkZXJSaWdodDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LnJpZ2h0ICksXG5cdFx0fSApKCkgfVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2xTcGxpdENvbnRyb2xzID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRmbGV4OiAxO1xuXHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gdW5kZWZpbmVkIDogJzgwJScgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjZW50ZXJlZEJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGdyaWQtY29sdW1uOiBzcGFuIDI7XG5cdG1hcmdpbjogMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IHJpZ2h0Qm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6ICdhdXRvJyB9ICkoKSB9XG5gO1xuIl19 */"); 30340 var wrapper = false ? { 30341 name: "bjn8wh", 30342 styles: "position:relative" 30343 } : { 30344 name: "memc06-wrapper", 30345 styles: "position:relative;label:wrapper;", 30346 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQjBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcblxuaW1wb3J0IHR5cGUgeyBCb3JkZXIgfSBmcm9tICcuLi9ib3JkZXItY29udHJvbC90eXBlcyc7XG5pbXBvcnQgdHlwZSB7IEJvcmRlcnMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2wgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IGxpbmtlZEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdGZsZXg6IDE7XG5cdCR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzI0cHgnIH0gKSgpIH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbExpbmtlZEJ1dHRvbiA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHRvcDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzhweCcgOiAnM3B4JyB9O1xuXHRcdCR7IHJ0bCggeyByaWdodDogMCB9ICkoKSB9XG5cdFx0bGluZS1oZWlnaHQ6IDA7XG5cdGA7XG59O1xuXG5jb25zdCBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayA9ICggYm9yZGVyPzogQm9yZGVyICkgPT4ge1xuXHRjb25zdCB7XG5cdFx0Y29sb3IgPSBDT0xPUlMuZ3JheVsgMjAwIF0sXG5cdFx0c3R5bGUgPSAnc29saWQnLFxuXHRcdHdpZHRoID0gQ09ORklHLmJvcmRlcldpZHRoLFxuXHR9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdGNvbnN0IGNsYW1wZWRXaWR0aCA9XG5cdFx0d2lkdGggIT09IENPTkZJRy5ib3JkZXJXaWR0aCA/IGBjbGFtcCgxcHgsICR7IHdpZHRoIH0sIDEwcHgpYCA6IHdpZHRoO1xuXHRjb25zdCBoYXNWaXNpYmxlQm9yZGVyID0gKCAhISB3aWR0aCAmJiB3aWR0aCAhPT0gJzAnICkgfHwgISEgY29sb3I7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gaGFzVmlzaWJsZUJvcmRlciA/IHN0eWxlIHx8ICdzb2xpZCcgOiBzdHlsZTtcblxuXHRyZXR1cm4gYCR7IGNvbG9yIH0gJHsgYm9yZGVyU3R5bGUgfSAkeyBjbGFtcGVkV2lkdGggfWA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbFZpc3VhbGl6ZXIgPSAoXG5cdGJvcmRlcnM/OiBCb3JkZXJzLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRyaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzM5cHgnIDogJzI5cHgnIH07XG5cdFx0Ym90dG9tOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRsZWZ0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3JkZXItdG9wOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8udG9wICkgfTtcblx0XHRib3JkZXItYm90dG9tOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8uYm90dG9tICkgfTtcblx0XHQkeyBydGwoIHtcblx0XHRcdGJvcmRlckxlZnQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5sZWZ0ICksXG5cdFx0fSApKCkgfVxuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyUmlnaHQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5yaWdodCApLFxuXHRcdH0gKSgpIH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sU3BsaXRDb250cm9scyA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0ZmxleDogMTtcblx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/IHVuZGVmaW5lZCA6ICc4MCUnIH07XG5gO1xuXG5leHBvcnQgY29uc3QgY2VudGVyZWRCb3JkZXJDb250cm9sID0gY3NzYFxuXHRncmlkLWNvbHVtbjogc3BhbiAyO1xuXHRtYXJnaW46IDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCByaWdodEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiAnYXV0bycgfSApKCkgfVxuYDtcbiJdfQ== */", 30347 toString: _EMOTION_STRINGIFIED_CSS_ERROR__9 30348 }; 30349 var borderBoxControlLinkedButton = (size3) => { 30350 return /* @__PURE__ */ css("position:absolute;top:", size3 === "__unstable-large" ? "8px" : "3px", ";", rtl({ 30351 right: 0 30352 })(), " line-height:0;" + (false ? "" : ";label:borderBoxControlLinkedButton;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQlciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4uL2JvcmRlci1jb250cm9sL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgQm9yZGVycyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbCA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgbGlua2VkQm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0ZmxleDogMTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiAnMjRweCcgfSApKCkgfVxuYDtcblxuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sTGlua2VkQnV0dG9uID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnOHB4JyA6ICczcHgnIH07XG5cdFx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSgpIH1cblx0XHRsaW5lLWhlaWdodDogMDtcblx0YDtcbn07XG5cbmNvbnN0IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHtcblx0XHRjb2xvciA9IENPTE9SUy5ncmF5WyAyMDAgXSxcblx0XHRzdHlsZSA9ICdzb2xpZCcsXG5cdFx0d2lkdGggPSBDT05GSUcuYm9yZGVyV2lkdGgsXG5cdH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgY2xhbXBlZFdpZHRoID1cblx0XHR3aWR0aCAhPT0gQ09ORklHLmJvcmRlcldpZHRoID8gYGNsYW1wKDFweCwgJHsgd2lkdGggfSwgMTBweClgIDogd2lkdGg7XG5cdGNvbnN0IGhhc1Zpc2libGVCb3JkZXIgPSAoICEhIHdpZHRoICYmIHdpZHRoICE9PSAnMCcgKSB8fCAhISBjb2xvcjtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBoYXNWaXNpYmxlQm9yZGVyID8gc3R5bGUgfHwgJ3NvbGlkJyA6IHN0eWxlO1xuXG5cdHJldHVybiBgJHsgY29sb3IgfSAkeyBib3JkZXJTdHlsZSB9ICR7IGNsYW1wZWRXaWR0aCB9YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sVmlzdWFsaXplciA9IChcblx0Ym9yZGVycz86IEJvcmRlcnMsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHR0b3A6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdHJpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3R0b206ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdGxlZnQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICczOXB4JyA6ICcyOXB4JyB9O1xuXHRcdGJvcmRlci10b3A6ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy50b3AgKSB9O1xuXHRcdGJvcmRlci1ib3R0b206ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5ib3R0b20gKSB9O1xuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyTGVmdDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LmxlZnQgKSxcblx0XHR9ICkoKSB9XG5cdFx0JHsgcnRsKCB7XG5cdFx0XHRib3JkZXJSaWdodDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LnJpZ2h0ICksXG5cdFx0fSApKCkgfVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2xTcGxpdENvbnRyb2xzID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRmbGV4OiAxO1xuXHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gdW5kZWZpbmVkIDogJzgwJScgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjZW50ZXJlZEJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGdyaWQtY29sdW1uOiBzcGFuIDI7XG5cdG1hcmdpbjogMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IHJpZ2h0Qm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6ICdhdXRvJyB9ICkoKSB9XG5gO1xuIl19 */"); 30353 }; 30354 var borderBoxStyleWithFallback = (border) => { 30355 const { 30356 color: color2 = COLORS.gray[200], 30357 style: style2 = "solid", 30358 width = config_values_default.borderWidth 30359 } = border || {}; 30360 const clampedWidth = width !== config_values_default.borderWidth ? `clamp(1px, $width}, 10px)` : width; 30361 const hasVisibleBorder = !!width && width !== "0" || !!color2; 30362 const borderStyle = hasVisibleBorder ? style2 || "solid" : style2; 30363 return `$color2} $borderStyle} $clampedWidth}`; 30364 }; 30365 var borderBoxControlVisualizer = (borders2, size3) => { 30366 return /* @__PURE__ */ css("position:absolute;top:", size3 === "__unstable-large" ? "20px" : "15px", ";right:", size3 === "__unstable-large" ? "39px" : "29px", ";bottom:", size3 === "__unstable-large" ? "20px" : "15px", ";left:", size3 === "__unstable-large" ? "39px" : "29px", ";border-top:", borderBoxStyleWithFallback(borders2?.top), ";border-bottom:", borderBoxStyleWithFallback(borders2?.bottom), ";", rtl({ 30367 borderLeft: borderBoxStyleWithFallback(borders2?.left) 30368 })(), " ", rtl({ 30369 borderRight: borderBoxStyleWithFallback(borders2?.right) 30370 })(), ";" + (false ? "" : ";label:borderBoxControlVisualizer;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRFciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4uL2JvcmRlci1jb250cm9sL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgQm9yZGVycyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbCA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgbGlua2VkQm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0ZmxleDogMTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiAnMjRweCcgfSApKCkgfVxuYDtcblxuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sTGlua2VkQnV0dG9uID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnOHB4JyA6ICczcHgnIH07XG5cdFx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSgpIH1cblx0XHRsaW5lLWhlaWdodDogMDtcblx0YDtcbn07XG5cbmNvbnN0IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHtcblx0XHRjb2xvciA9IENPTE9SUy5ncmF5WyAyMDAgXSxcblx0XHRzdHlsZSA9ICdzb2xpZCcsXG5cdFx0d2lkdGggPSBDT05GSUcuYm9yZGVyV2lkdGgsXG5cdH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgY2xhbXBlZFdpZHRoID1cblx0XHR3aWR0aCAhPT0gQ09ORklHLmJvcmRlcldpZHRoID8gYGNsYW1wKDFweCwgJHsgd2lkdGggfSwgMTBweClgIDogd2lkdGg7XG5cdGNvbnN0IGhhc1Zpc2libGVCb3JkZXIgPSAoICEhIHdpZHRoICYmIHdpZHRoICE9PSAnMCcgKSB8fCAhISBjb2xvcjtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBoYXNWaXNpYmxlQm9yZGVyID8gc3R5bGUgfHwgJ3NvbGlkJyA6IHN0eWxlO1xuXG5cdHJldHVybiBgJHsgY29sb3IgfSAkeyBib3JkZXJTdHlsZSB9ICR7IGNsYW1wZWRXaWR0aCB9YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sVmlzdWFsaXplciA9IChcblx0Ym9yZGVycz86IEJvcmRlcnMsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHR0b3A6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdHJpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3R0b206ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdGxlZnQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICczOXB4JyA6ICcyOXB4JyB9O1xuXHRcdGJvcmRlci10b3A6ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy50b3AgKSB9O1xuXHRcdGJvcmRlci1ib3R0b206ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5ib3R0b20gKSB9O1xuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyTGVmdDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LmxlZnQgKSxcblx0XHR9ICkoKSB9XG5cdFx0JHsgcnRsKCB7XG5cdFx0XHRib3JkZXJSaWdodDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LnJpZ2h0ICksXG5cdFx0fSApKCkgfVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2xTcGxpdENvbnRyb2xzID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRmbGV4OiAxO1xuXHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gdW5kZWZpbmVkIDogJzgwJScgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjZW50ZXJlZEJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGdyaWQtY29sdW1uOiBzcGFuIDI7XG5cdG1hcmdpbjogMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IHJpZ2h0Qm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6ICdhdXRvJyB9ICkoKSB9XG5gO1xuIl19 */"); 30371 }; 30372 var borderBoxControlSplitControls = (size3) => /* @__PURE__ */ css("position:relative;flex:1;width:", size3 === "__unstable-large" ? void 0 : "80%", ";" + (false ? "" : ";label:borderBoxControlSplitControls;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RVEiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4uL2JvcmRlci1jb250cm9sL3R5cGVzJztcbmltcG9ydCB0eXBlIHsgQm9yZGVycyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbCA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgbGlua2VkQm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0ZmxleDogMTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiAnMjRweCcgfSApKCkgfVxuYDtcblxuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sTGlua2VkQnV0dG9uID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnOHB4JyA6ICczcHgnIH07XG5cdFx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSgpIH1cblx0XHRsaW5lLWhlaWdodDogMDtcblx0YDtcbn07XG5cbmNvbnN0IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHtcblx0XHRjb2xvciA9IENPTE9SUy5ncmF5WyAyMDAgXSxcblx0XHRzdHlsZSA9ICdzb2xpZCcsXG5cdFx0d2lkdGggPSBDT05GSUcuYm9yZGVyV2lkdGgsXG5cdH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgY2xhbXBlZFdpZHRoID1cblx0XHR3aWR0aCAhPT0gQ09ORklHLmJvcmRlcldpZHRoID8gYGNsYW1wKDFweCwgJHsgd2lkdGggfSwgMTBweClgIDogd2lkdGg7XG5cdGNvbnN0IGhhc1Zpc2libGVCb3JkZXIgPSAoICEhIHdpZHRoICYmIHdpZHRoICE9PSAnMCcgKSB8fCAhISBjb2xvcjtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBoYXNWaXNpYmxlQm9yZGVyID8gc3R5bGUgfHwgJ3NvbGlkJyA6IHN0eWxlO1xuXG5cdHJldHVybiBgJHsgY29sb3IgfSAkeyBib3JkZXJTdHlsZSB9ICR7IGNsYW1wZWRXaWR0aCB9YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sVmlzdWFsaXplciA9IChcblx0Ym9yZGVycz86IEJvcmRlcnMsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHR0b3A6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdHJpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3R0b206ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyMHB4JyA6ICcxNXB4JyB9O1xuXHRcdGxlZnQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICczOXB4JyA6ICcyOXB4JyB9O1xuXHRcdGJvcmRlci10b3A6ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy50b3AgKSB9O1xuXHRcdGJvcmRlci1ib3R0b206ICR7IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5ib3R0b20gKSB9O1xuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyTGVmdDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LmxlZnQgKSxcblx0XHR9ICkoKSB9XG5cdFx0JHsgcnRsKCB7XG5cdFx0XHRib3JkZXJSaWdodDogYm9yZGVyQm94U3R5bGVXaXRoRmFsbGJhY2soIGJvcmRlcnM/LnJpZ2h0ICksXG5cdFx0fSApKCkgfVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2xTcGxpdENvbnRyb2xzID0gKFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRmbGV4OiAxO1xuXHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gdW5kZWZpbmVkIDogJzgwJScgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjZW50ZXJlZEJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGdyaWQtY29sdW1uOiBzcGFuIDI7XG5cdG1hcmdpbjogMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IHJpZ2h0Qm9yZGVyQ29udHJvbCA9ICgpID0+IGNzc2Bcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6ICdhdXRvJyB9ICkoKSB9XG5gO1xuIl19 */"); 30373 var centeredBorderControl = false ? { 30374 name: "1nwbfnf", 30375 styles: "grid-column:span 2;margin:0 auto" 30376 } : { 30377 name: "gedmrr-centeredBorderControl", 30378 styles: "grid-column:span 2;margin:0 auto;label:centeredBorderControl;", 30379 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXdDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcblxuaW1wb3J0IHR5cGUgeyBCb3JkZXIgfSBmcm9tICcuLi9ib3JkZXItY29udHJvbC90eXBlcyc7XG5pbXBvcnQgdHlwZSB7IEJvcmRlcnMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2wgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IGxpbmtlZEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdGZsZXg6IDE7XG5cdCR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzI0cHgnIH0gKSgpIH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbExpbmtlZEJ1dHRvbiA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHRvcDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzhweCcgOiAnM3B4JyB9O1xuXHRcdCR7IHJ0bCggeyByaWdodDogMCB9ICkoKSB9XG5cdFx0bGluZS1oZWlnaHQ6IDA7XG5cdGA7XG59O1xuXG5jb25zdCBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayA9ICggYm9yZGVyPzogQm9yZGVyICkgPT4ge1xuXHRjb25zdCB7XG5cdFx0Y29sb3IgPSBDT0xPUlMuZ3JheVsgMjAwIF0sXG5cdFx0c3R5bGUgPSAnc29saWQnLFxuXHRcdHdpZHRoID0gQ09ORklHLmJvcmRlcldpZHRoLFxuXHR9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdGNvbnN0IGNsYW1wZWRXaWR0aCA9XG5cdFx0d2lkdGggIT09IENPTkZJRy5ib3JkZXJXaWR0aCA/IGBjbGFtcCgxcHgsICR7IHdpZHRoIH0sIDEwcHgpYCA6IHdpZHRoO1xuXHRjb25zdCBoYXNWaXNpYmxlQm9yZGVyID0gKCAhISB3aWR0aCAmJiB3aWR0aCAhPT0gJzAnICkgfHwgISEgY29sb3I7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gaGFzVmlzaWJsZUJvcmRlciA/IHN0eWxlIHx8ICdzb2xpZCcgOiBzdHlsZTtcblxuXHRyZXR1cm4gYCR7IGNvbG9yIH0gJHsgYm9yZGVyU3R5bGUgfSAkeyBjbGFtcGVkV2lkdGggfWA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbFZpc3VhbGl6ZXIgPSAoXG5cdGJvcmRlcnM/OiBCb3JkZXJzLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRyaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzM5cHgnIDogJzI5cHgnIH07XG5cdFx0Ym90dG9tOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRsZWZ0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3JkZXItdG9wOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8udG9wICkgfTtcblx0XHRib3JkZXItYm90dG9tOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8uYm90dG9tICkgfTtcblx0XHQkeyBydGwoIHtcblx0XHRcdGJvcmRlckxlZnQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5sZWZ0ICksXG5cdFx0fSApKCkgfVxuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyUmlnaHQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5yaWdodCApLFxuXHRcdH0gKSgpIH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sU3BsaXRDb250cm9scyA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0ZmxleDogMTtcblx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/IHVuZGVmaW5lZCA6ICc4MCUnIH07XG5gO1xuXG5leHBvcnQgY29uc3QgY2VudGVyZWRCb3JkZXJDb250cm9sID0gY3NzYFxuXHRncmlkLWNvbHVtbjogc3BhbiAyO1xuXHRtYXJnaW46IDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCByaWdodEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiAnYXV0bycgfSApKCkgfVxuYDtcbiJdfQ== */", 30380 toString: _EMOTION_STRINGIFIED_CSS_ERROR__9 30381 }; 30382 var rightBorderControl = () => /* @__PURE__ */ css(rtl({ 30383 marginLeft: "auto" 30384 })(), ";" + (false ? "" : ";label:rightBorderControl;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRjJDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcblxuaW1wb3J0IHR5cGUgeyBCb3JkZXIgfSBmcm9tICcuLi9ib3JkZXItY29udHJvbC90eXBlcyc7XG5pbXBvcnQgdHlwZSB7IEJvcmRlcnMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGJvcmRlckJveENvbnRyb2wgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IGxpbmtlZEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdGZsZXg6IDE7XG5cdCR7IHJ0bCggeyBtYXJnaW5SaWdodDogJzI0cHgnIH0gKSgpIH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbExpbmtlZEJ1dHRvbiA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHRvcDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzhweCcgOiAnM3B4JyB9O1xuXHRcdCR7IHJ0bCggeyByaWdodDogMCB9ICkoKSB9XG5cdFx0bGluZS1oZWlnaHQ6IDA7XG5cdGA7XG59O1xuXG5jb25zdCBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayA9ICggYm9yZGVyPzogQm9yZGVyICkgPT4ge1xuXHRjb25zdCB7XG5cdFx0Y29sb3IgPSBDT0xPUlMuZ3JheVsgMjAwIF0sXG5cdFx0c3R5bGUgPSAnc29saWQnLFxuXHRcdHdpZHRoID0gQ09ORklHLmJvcmRlcldpZHRoLFxuXHR9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdGNvbnN0IGNsYW1wZWRXaWR0aCA9XG5cdFx0d2lkdGggIT09IENPTkZJRy5ib3JkZXJXaWR0aCA/IGBjbGFtcCgxcHgsICR7IHdpZHRoIH0sIDEwcHgpYCA6IHdpZHRoO1xuXHRjb25zdCBoYXNWaXNpYmxlQm9yZGVyID0gKCAhISB3aWR0aCAmJiB3aWR0aCAhPT0gJzAnICkgfHwgISEgY29sb3I7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gaGFzVmlzaWJsZUJvcmRlciA/IHN0eWxlIHx8ICdzb2xpZCcgOiBzdHlsZTtcblxuXHRyZXR1cm4gYCR7IGNvbG9yIH0gJHsgYm9yZGVyU3R5bGUgfSAkeyBjbGFtcGVkV2lkdGggfWA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQm94Q29udHJvbFZpc3VhbGl6ZXIgPSAoXG5cdGJvcmRlcnM/OiBCb3JkZXJzLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0dG9wOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRyaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzM5cHgnIDogJzI5cHgnIH07XG5cdFx0Ym90dG9tOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjBweCcgOiAnMTVweCcgfTtcblx0XHRsZWZ0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMzlweCcgOiAnMjlweCcgfTtcblx0XHRib3JkZXItdG9wOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8udG9wICkgfTtcblx0XHRib3JkZXItYm90dG9tOiAkeyBib3JkZXJCb3hTdHlsZVdpdGhGYWxsYmFjayggYm9yZGVycz8uYm90dG9tICkgfTtcblx0XHQkeyBydGwoIHtcblx0XHRcdGJvcmRlckxlZnQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5sZWZ0ICksXG5cdFx0fSApKCkgfVxuXHRcdCR7IHJ0bCgge1xuXHRcdFx0Ym9yZGVyUmlnaHQ6IGJvcmRlckJveFN0eWxlV2l0aEZhbGxiYWNrKCBib3JkZXJzPy5yaWdodCApLFxuXHRcdH0gKSgpIH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBib3JkZXJCb3hDb250cm9sU3BsaXRDb250cm9scyA9IChcblx0c2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJ1xuKSA9PiBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0ZmxleDogMTtcblx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/IHVuZGVmaW5lZCA6ICc4MCUnIH07XG5gO1xuXG5leHBvcnQgY29uc3QgY2VudGVyZWRCb3JkZXJDb250cm9sID0gY3NzYFxuXHRncmlkLWNvbHVtbjogc3BhbiAyO1xuXHRtYXJnaW46IDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCByaWdodEJvcmRlckNvbnRyb2wgPSAoKSA9PiBjc3NgXG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiAnYXV0bycgfSApKCkgfVxuYDtcbiJdfQ== */"); 30385 30386 // packages/components/build-module/border-box-control/border-box-control-linked-button/hook.js 30387 function useBorderBoxControlLinkedButton(props) { 30388 const { 30389 className: className2, 30390 size: size3 = "default", 30391 ...otherProps 30392 } = useContextSystem(props, "BorderBoxControlLinkedButton"); 30393 const cx3 = useCx(); 30394 const classes = (0, import_element54.useMemo)(() => { 30395 return cx3(borderBoxControlLinkedButton(size3), className2); 30396 }, [className2, cx3, size3]); 30397 return { 30398 ...otherProps, 30399 className: classes 30400 }; 30401 } 30402 30403 // packages/components/build-module/border-box-control/border-box-control-linked-button/component.js 30404 var import_jsx_runtime113 = __toESM(require_jsx_runtime()); 30405 var BorderBoxControlLinkedButton = (props, forwardedRef) => { 30406 const { 30407 className: className2, 30408 isLinked, 30409 ...buttonProps 30410 } = useBorderBoxControlLinkedButton(props); 30411 const label = isLinked ? (0, import_i18n9.__)("Unlink sides") : (0, import_i18n9.__)("Link sides"); 30412 return /* @__PURE__ */ (0, import_jsx_runtime113.jsx)(button_default, { 30413 ...buttonProps, 30414 size: "small", 30415 icon: isLinked ? link_default : link_off_default, 30416 iconSize: 24, 30417 label, 30418 ref: forwardedRef, 30419 className: className2 30420 }); 30421 }; 30422 var ConnectedBorderBoxControlLinkedButton = contextConnect(BorderBoxControlLinkedButton, "BorderBoxControlLinkedButton"); 30423 var component_default10 = ConnectedBorderBoxControlLinkedButton; 30424 30425 // packages/components/build-module/border-box-control/border-box-control-split-controls/component.js 30426 var import_i18n25 = __toESM(require_i18n()); 30427 var import_element90 = __toESM(require_element()); 30428 var import_compose38 = __toESM(require_compose()); 30429 30430 // packages/components/build-module/border-box-control/border-box-control-visualizer/hook.js 30431 var import_element55 = __toESM(require_element()); 30432 function useBorderBoxControlVisualizer(props) { 30433 const { 30434 className: className2, 30435 value, 30436 size: size3 = "default", 30437 ...otherProps 30438 } = useContextSystem(props, "BorderBoxControlVisualizer"); 30439 const cx3 = useCx(); 30440 const classes = (0, import_element55.useMemo)(() => { 30441 return cx3(borderBoxControlVisualizer(value, size3), className2); 30442 }, [cx3, className2, value, size3]); 30443 return { 30444 ...otherProps, 30445 className: classes, 30446 value 30447 }; 30448 } 30449 30450 // packages/components/build-module/border-box-control/border-box-control-visualizer/component.js 30451 var import_jsx_runtime114 = __toESM(require_jsx_runtime()); 30452 var BorderBoxControlVisualizer = (props, forwardedRef) => { 30453 const { 30454 value, 30455 ...otherProps 30456 } = useBorderBoxControlVisualizer(props); 30457 return /* @__PURE__ */ (0, import_jsx_runtime114.jsx)(component_default, { 30458 ...otherProps, 30459 ref: forwardedRef 30460 }); 30461 }; 30462 var ConnectedBorderBoxControlVisualizer = contextConnect(BorderBoxControlVisualizer, "BorderBoxControlVisualizer"); 30463 var component_default11 = ConnectedBorderBoxControlVisualizer; 30464 30465 // packages/components/build-module/border-control/border-control/component.js 30466 var import_i18n24 = __toESM(require_i18n()); 30467 30468 // packages/components/build-module/border-control/border-control-dropdown/component.js 30469 var import_i18n22 = __toESM(require_i18n()); 30470 30471 // packages/components/build-module/border-control/border-control-style-picker/component.js 30472 var import_i18n11 = __toESM(require_i18n()); 30473 30474 // packages/components/build-module/toggle-group-control/toggle-group-control/component.js 30475 var import_element63 = __toESM(require_element()); 30476 var import_compose28 = __toESM(require_compose()); 30477 30478 // packages/components/build-module/toggle-group-control/toggle-group-control/styles.js 30479 function _EMOTION_STRINGIFIED_CSS_ERROR__10() { 30480 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 30481 } 30482 var toggleGroupControl = ({ 30483 isBlock, 30484 isDeselectable, 30485 size: size3 30486 }) => /* @__PURE__ */ css("background:", COLORS.ui.background, ";border:1px solid transparent;border-radius:", config_values_default.radiusSmall, ";display:inline-flex;min-width:0;position:relative;", toggleGroupControlSize(size3), " ", !isDeselectable && enclosingBorders(isBlock), "@media not ( prefers-reduced-motion ){&[data-indicator-animated]::before{transition-property:transform,border-radius;transition-duration:0.2s;transition-timing-function:ease-out;}}&::before{content:'';position:absolute;pointer-events:none;background:", COLORS.theme.foreground, ";outline:2px solid transparent;outline-offset:-3px;--antialiasing-factor:100;border-radius:calc(\n ", config_values_default.radiusXSmall, " /\n (\n var( --selected-width, 0 ) /\n var( --antialiasing-factor )\n )\n )/", config_values_default.radiusXSmall, ";left:-1px;width:calc( var( --antialiasing-factor ) * 1px );height:calc( var( --selected-height, 0 ) * 1px );transform-origin:left top;transform:translateX( calc( var( --selected-left, 0 ) * 1px ) ) scaleX(\n calc(\n var( --selected-width, 0 ) / var( --antialiasing-factor )\n )\n );}" + (false ? "" : ";label:toggleGroupControl;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQlUiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCB0b2dnbGVHcm91cENvbnRyb2wgPSAoIHtcblx0aXNCbG9jayxcblx0aXNEZXNlbGVjdGFibGUsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzQmxvY2snIHwgJ2lzRGVzZWxlY3RhYmxlJyA+ICYge1xuXHRzaXplOiBOb25OdWxsYWJsZTwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdzaXplJyBdID47XG59ICkgPT4gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9O1xuXHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtaW4td2lkdGg6IDA7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHQkeyB0b2dnbGVHcm91cENvbnRyb2xTaXplKCBzaXplICkgfVxuXHQkeyAhIGlzRGVzZWxlY3RhYmxlICYmIGVuY2xvc2luZ0JvcmRlcnMoIGlzQmxvY2sgKSB9XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0JltkYXRhLWluZGljYXRvci1hbmltYXRlZF06OmJlZm9yZSB7XG5cdFx0XHR0cmFuc2l0aW9uLXByb3BlcnR5OiB0cmFuc2Zvcm0sIGJvcmRlci1yYWRpdXM7XG5cdFx0XHR0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjJzO1xuXHRcdFx0dHJhbnNpdGlvbi10aW1pbmctZnVuY3Rpb246IGVhc2Utb3V0O1xuXHRcdH1cblx0fVxuXG5cdCY6OmJlZm9yZSB7XG5cdFx0Y29udGVudDogJyc7XG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRvdXRsaW5lLW9mZnNldDogLTNweDtcblxuXHRcdC8qIFVzaW5nIGEgbGFyZ2UgdmFsdWUgdG8gYXZvaWQgYW50aWFsaWFzaW5nIHJvdW5kaW5nIGlzc3Vlc1xuXHRcdFx0d2hlbiBzY2FsaW5nIGluIHRoZSB0cmFuc2Zvcm0sIHNlZTogaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9hLzUyMTU5MTIzICovXG5cdFx0LS1hbnRpYWxpYXNpbmctZmFjdG9yOiAxMDA7XG5cdFx0LyogQWRqdXN0aW5nIHRoZSBib3JkZXIgcmFkaXVzIHRvIG1hdGNoIHRoZSBzY2FsaW5nIGluIHRoZSB4IGF4aXMuICovXG5cdFx0Ym9yZGVyLXJhZGl1czogY2FsYyhcblx0XHRcdFx0JHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9IC9cblx0XHRcdFx0XHQoXG5cdFx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvXG5cdFx0XHRcdFx0XHRcdHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0XHQpXG5cdFx0XHQpIC8gJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGxlZnQ6IC0xcHg7IC8vIENvcnJlY3RpbmcgZm9yIGJvcmRlci5cblx0XHR3aWR0aDogY2FsYyggdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKSAqIDFweCApO1xuXHRcdGhlaWdodDogY2FsYyggdmFyKCAtLXNlbGVjdGVkLWhlaWdodCwgMCApICogMXB4ICk7XG5cdFx0dHJhbnNmb3JtLW9yaWdpbjogbGVmdCB0b3A7XG5cdFx0dHJhbnNmb3JtOiB0cmFuc2xhdGVYKCBjYWxjKCB2YXIoIC0tc2VsZWN0ZWQtbGVmdCwgMCApICogMXB4ICkgKVxuXHRcdFx0c2NhbGVYKFxuXHRcdFx0XHRjYWxjKFxuXHRcdFx0XHRcdHZhciggLS1zZWxlY3RlZC13aWR0aCwgMCApIC8gdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKVxuXHRcdFx0XHQpXG5cdFx0XHQpO1xuXHR9XG5gO1xuXG5jb25zdCBlbmNsb3NpbmdCb3JkZXJzID0gKCBpc0Jsb2NrOiBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ2lzQmxvY2snIF0gKSA9PiB7XG5cdGNvbnN0IGVuY2xvc2luZ0JvcmRlciA9IGNzc2Bcblx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblx0YDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdCR7IGlzQmxvY2sgJiYgZW5jbG9zaW5nQm9yZGVyIH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVySG92ZXIgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzLXdpdGhpbiB7XG5cdFx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0Ym94LXNoYWRvdzogJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuXHRcdFx0ei1pbmRleDogMTtcblx0XHRcdC8vIFdpbmRvd3MgSGlnaCBDb250cmFzdCBtb2RlIHdpbGwgc2hvdyB0aGlzIG91dGxpbmUsIGJ1dCBub3QgdGhlIGJveC1zaGFkb3cuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogLTJweDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSA9IChcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+XG4pID0+IHtcblx0Y29uc3Qgc3R5bGVzID0ge1xuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDM2cHg7XG5cdFx0XHRwYWRkaW5nOiAycHg7XG5cdFx0YCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdFx0XHRwYWRkaW5nOiAzcHg7XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc3R5bGVzWyBzaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpc3VhbExhYmVsV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdC8vIE1ha2VzIHRoZSBpbmxpbmUgbGFiZWwgYmUgdGhlIGNvcnJlY3QgaGVpZ2h0LCBlcXVpdmFsZW50IHRvIHNldHRpbmcgbGluZS1oZWlnaHQ6IDBcblx0ZGlzcGxheTogZmxleDtcbmA7XG4iXX0= */"); 30487 var enclosingBorders = (isBlock) => { 30488 const enclosingBorder = /* @__PURE__ */ css("border-color:", COLORS.ui.border, ";" + (false ? "" : ";label:enclosingBorder;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RTRCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sID0gKCB7XG5cdGlzQmxvY2ssXG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRzaXplLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdpc0Jsb2NrJyB8ICdpc0Rlc2VsZWN0YWJsZScgPiAmIHtcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+O1xufSApID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JHsgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSggc2l6ZSApIH1cblx0JHsgISBpc0Rlc2VsZWN0YWJsZSAmJiBlbmNsb3NpbmdCb3JkZXJzKCBpc0Jsb2NrICkgfVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCZbZGF0YS1pbmRpY2F0b3ItYW5pbWF0ZWRdOjpiZWZvcmUge1xuXHRcdFx0dHJhbnNpdGlvbi1wcm9wZXJ0eTogdHJhbnNmb3JtLCBib3JkZXItcmFkaXVzO1xuXHRcdFx0dHJhbnNpdGlvbi1kdXJhdGlvbjogMC4ycztcblx0XHRcdHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiBlYXNlLW91dDtcblx0XHR9XG5cdH1cblxuXHQmOjpiZWZvcmUge1xuXHRcdGNvbnRlbnQ6ICcnO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9O1xuXG5cdFx0Ly8gV2luZG93cyBIaWdoIENvbnRyYXN0IG1vZGUgd2lsbCBzaG93IHRoaXMgb3V0bGluZSwgYnV0IG5vdCB0aGUgYm94LXNoYWRvdy5cblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XG5cblx0XHQvKiBVc2luZyBhIGxhcmdlIHZhbHVlIHRvIGF2b2lkIGFudGlhbGlhc2luZyByb3VuZGluZyBpc3N1ZXNcblx0XHRcdHdoZW4gc2NhbGluZyBpbiB0aGUgdHJhbnNmb3JtLCBzZWU6IGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vYS81MjE1OTEyMyAqL1xuXHRcdC0tYW50aWFsaWFzaW5nLWZhY3RvcjogMTAwO1xuXHRcdC8qIEFkanVzdGluZyB0aGUgYm9yZGVyIHJhZGl1cyB0byBtYXRjaCB0aGUgc2NhbGluZyBpbiB0aGUgeCBheGlzLiAqL1xuXHRcdGJvcmRlci1yYWRpdXM6IGNhbGMoXG5cdFx0XHRcdCR7IENPTkZJRy5yYWRpdXNYU21hbGwgfSAvXG5cdFx0XHRcdFx0KFxuXHRcdFx0XHRcdFx0dmFyKCAtLXNlbGVjdGVkLXdpZHRoLCAwICkgL1xuXHRcdFx0XHRcdFx0XHR2YXIoIC0tYW50aWFsaWFzaW5nLWZhY3RvciApXG5cdFx0XHRcdFx0KVxuXHRcdFx0KSAvICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRsZWZ0OiAtMXB4OyAvLyBDb3JyZWN0aW5nIGZvciBib3JkZXIuXG5cdFx0d2lkdGg6IGNhbGMoIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yICkgKiAxcHggKTtcblx0XHRoZWlnaHQ6IGNhbGMoIHZhciggLS1zZWxlY3RlZC1oZWlnaHQsIDAgKSAqIDFweCApO1xuXHRcdHRyYW5zZm9ybS1vcmlnaW46IGxlZnQgdG9wO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlWCggY2FsYyggdmFyKCAtLXNlbGVjdGVkLWxlZnQsIDAgKSAqIDFweCApIClcblx0XHRcdHNjYWxlWChcblx0XHRcdFx0Y2FsYyhcblx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0KVxuXHRcdFx0KTtcblx0fVxuYDtcblxuY29uc3QgZW5jbG9zaW5nQm9yZGVycyA9ICggaXNCbG9jazogVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdpc0Jsb2NrJyBdICkgPT4ge1xuXHRjb25zdCBlbmNsb3NpbmdCb3JkZXIgPSBjc3NgXG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyIH07XG5cdGA7XG5cblx0cmV0dXJuIGNzc2Bcblx0XHQkeyBpc0Jsb2NrICYmIGVuY2xvc2luZ0JvcmRlciB9XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckhvdmVyIH07XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy13aXRoaW4ge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdGJveC1zaGFkb3c6ICR7IENPTkZJRy5jb250cm9sQm94U2hhZG93Rm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0b3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvZ2dsZUdyb3VwQ29udHJvbFNpemUgPSAoXG5cdHNpemU6IE5vbk51bGxhYmxlPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ3NpemUnIF0gPlxuKSA9PiB7XG5cdGNvbnN0IHN0eWxlcyA9IHtcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiAzNnB4O1xuXHRcdFx0cGFkZGluZzogMnB4O1xuXHRcdGAsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiA0MHB4O1xuXHRcdFx0cGFkZGluZzogM3B4O1xuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHN0eWxlc1sgc2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaXN1YWxMYWJlbFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQvLyBNYWtlcyB0aGUgaW5saW5lIGxhYmVsIGJlIHRoZSBjb3JyZWN0IGhlaWdodCwgZXF1aXZhbGVudCB0byBzZXR0aW5nIGxpbmUtaGVpZ2h0OiAwXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuIl19 */"); 30489 return /* @__PURE__ */ css(isBlock && enclosingBorder, " &:hover{border-color:", COLORS.ui.borderHover, ";}&:focus-within{border-color:", COLORS.ui.borderFocus, ";box-shadow:", config_values_default.controlBoxShadowFocus, ";z-index:1;outline:2px solid transparent;outline-offset:-2px;}" + (false ? "" : ";label:enclosingBorders;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RVciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCB0b2dnbGVHcm91cENvbnRyb2wgPSAoIHtcblx0aXNCbG9jayxcblx0aXNEZXNlbGVjdGFibGUsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzQmxvY2snIHwgJ2lzRGVzZWxlY3RhYmxlJyA+ICYge1xuXHRzaXplOiBOb25OdWxsYWJsZTwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdzaXplJyBdID47XG59ICkgPT4gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9O1xuXHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtaW4td2lkdGg6IDA7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHQkeyB0b2dnbGVHcm91cENvbnRyb2xTaXplKCBzaXplICkgfVxuXHQkeyAhIGlzRGVzZWxlY3RhYmxlICYmIGVuY2xvc2luZ0JvcmRlcnMoIGlzQmxvY2sgKSB9XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0JltkYXRhLWluZGljYXRvci1hbmltYXRlZF06OmJlZm9yZSB7XG5cdFx0XHR0cmFuc2l0aW9uLXByb3BlcnR5OiB0cmFuc2Zvcm0sIGJvcmRlci1yYWRpdXM7XG5cdFx0XHR0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjJzO1xuXHRcdFx0dHJhbnNpdGlvbi10aW1pbmctZnVuY3Rpb246IGVhc2Utb3V0O1xuXHRcdH1cblx0fVxuXG5cdCY6OmJlZm9yZSB7XG5cdFx0Y29udGVudDogJyc7XG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRvdXRsaW5lLW9mZnNldDogLTNweDtcblxuXHRcdC8qIFVzaW5nIGEgbGFyZ2UgdmFsdWUgdG8gYXZvaWQgYW50aWFsaWFzaW5nIHJvdW5kaW5nIGlzc3Vlc1xuXHRcdFx0d2hlbiBzY2FsaW5nIGluIHRoZSB0cmFuc2Zvcm0sIHNlZTogaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9hLzUyMTU5MTIzICovXG5cdFx0LS1hbnRpYWxpYXNpbmctZmFjdG9yOiAxMDA7XG5cdFx0LyogQWRqdXN0aW5nIHRoZSBib3JkZXIgcmFkaXVzIHRvIG1hdGNoIHRoZSBzY2FsaW5nIGluIHRoZSB4IGF4aXMuICovXG5cdFx0Ym9yZGVyLXJhZGl1czogY2FsYyhcblx0XHRcdFx0JHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9IC9cblx0XHRcdFx0XHQoXG5cdFx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvXG5cdFx0XHRcdFx0XHRcdHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0XHQpXG5cdFx0XHQpIC8gJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGxlZnQ6IC0xcHg7IC8vIENvcnJlY3RpbmcgZm9yIGJvcmRlci5cblx0XHR3aWR0aDogY2FsYyggdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKSAqIDFweCApO1xuXHRcdGhlaWdodDogY2FsYyggdmFyKCAtLXNlbGVjdGVkLWhlaWdodCwgMCApICogMXB4ICk7XG5cdFx0dHJhbnNmb3JtLW9yaWdpbjogbGVmdCB0b3A7XG5cdFx0dHJhbnNmb3JtOiB0cmFuc2xhdGVYKCBjYWxjKCB2YXIoIC0tc2VsZWN0ZWQtbGVmdCwgMCApICogMXB4ICkgKVxuXHRcdFx0c2NhbGVYKFxuXHRcdFx0XHRjYWxjKFxuXHRcdFx0XHRcdHZhciggLS1zZWxlY3RlZC13aWR0aCwgMCApIC8gdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKVxuXHRcdFx0XHQpXG5cdFx0XHQpO1xuXHR9XG5gO1xuXG5jb25zdCBlbmNsb3NpbmdCb3JkZXJzID0gKCBpc0Jsb2NrOiBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ2lzQmxvY2snIF0gKSA9PiB7XG5cdGNvbnN0IGVuY2xvc2luZ0JvcmRlciA9IGNzc2Bcblx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblx0YDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdCR7IGlzQmxvY2sgJiYgZW5jbG9zaW5nQm9yZGVyIH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVySG92ZXIgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzLXdpdGhpbiB7XG5cdFx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0Ym94LXNoYWRvdzogJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuXHRcdFx0ei1pbmRleDogMTtcblx0XHRcdC8vIFdpbmRvd3MgSGlnaCBDb250cmFzdCBtb2RlIHdpbGwgc2hvdyB0aGlzIG91dGxpbmUsIGJ1dCBub3QgdGhlIGJveC1zaGFkb3cuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogLTJweDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSA9IChcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+XG4pID0+IHtcblx0Y29uc3Qgc3R5bGVzID0ge1xuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDM2cHg7XG5cdFx0XHRwYWRkaW5nOiAycHg7XG5cdFx0YCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdFx0XHRwYWRkaW5nOiAzcHg7XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc3R5bGVzWyBzaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpc3VhbExhYmVsV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdC8vIE1ha2VzIHRoZSBpbmxpbmUgbGFiZWwgYmUgdGhlIGNvcnJlY3QgaGVpZ2h0LCBlcXVpdmFsZW50IHRvIHNldHRpbmcgbGluZS1oZWlnaHQ6IDBcblx0ZGlzcGxheTogZmxleDtcbmA7XG4iXX0= */"); 30490 }; 30491 var _ref4 = false ? { 30492 name: "1aqh2c7", 30493 styles: "min-height:40px;padding:3px" 30494 } : { 30495 name: "1g31npf-__unstable-large", 30496 styles: "min-height:40px;padding:3px;label:__unstable-large;", 30497 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR3lCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sID0gKCB7XG5cdGlzQmxvY2ssXG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRzaXplLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdpc0Jsb2NrJyB8ICdpc0Rlc2VsZWN0YWJsZScgPiAmIHtcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+O1xufSApID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JHsgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSggc2l6ZSApIH1cblx0JHsgISBpc0Rlc2VsZWN0YWJsZSAmJiBlbmNsb3NpbmdCb3JkZXJzKCBpc0Jsb2NrICkgfVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCZbZGF0YS1pbmRpY2F0b3ItYW5pbWF0ZWRdOjpiZWZvcmUge1xuXHRcdFx0dHJhbnNpdGlvbi1wcm9wZXJ0eTogdHJhbnNmb3JtLCBib3JkZXItcmFkaXVzO1xuXHRcdFx0dHJhbnNpdGlvbi1kdXJhdGlvbjogMC4ycztcblx0XHRcdHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiBlYXNlLW91dDtcblx0XHR9XG5cdH1cblxuXHQmOjpiZWZvcmUge1xuXHRcdGNvbnRlbnQ6ICcnO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9O1xuXG5cdFx0Ly8gV2luZG93cyBIaWdoIENvbnRyYXN0IG1vZGUgd2lsbCBzaG93IHRoaXMgb3V0bGluZSwgYnV0IG5vdCB0aGUgYm94LXNoYWRvdy5cblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XG5cblx0XHQvKiBVc2luZyBhIGxhcmdlIHZhbHVlIHRvIGF2b2lkIGFudGlhbGlhc2luZyByb3VuZGluZyBpc3N1ZXNcblx0XHRcdHdoZW4gc2NhbGluZyBpbiB0aGUgdHJhbnNmb3JtLCBzZWU6IGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vYS81MjE1OTEyMyAqL1xuXHRcdC0tYW50aWFsaWFzaW5nLWZhY3RvcjogMTAwO1xuXHRcdC8qIEFkanVzdGluZyB0aGUgYm9yZGVyIHJhZGl1cyB0byBtYXRjaCB0aGUgc2NhbGluZyBpbiB0aGUgeCBheGlzLiAqL1xuXHRcdGJvcmRlci1yYWRpdXM6IGNhbGMoXG5cdFx0XHRcdCR7IENPTkZJRy5yYWRpdXNYU21hbGwgfSAvXG5cdFx0XHRcdFx0KFxuXHRcdFx0XHRcdFx0dmFyKCAtLXNlbGVjdGVkLXdpZHRoLCAwICkgL1xuXHRcdFx0XHRcdFx0XHR2YXIoIC0tYW50aWFsaWFzaW5nLWZhY3RvciApXG5cdFx0XHRcdFx0KVxuXHRcdFx0KSAvICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRsZWZ0OiAtMXB4OyAvLyBDb3JyZWN0aW5nIGZvciBib3JkZXIuXG5cdFx0d2lkdGg6IGNhbGMoIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yICkgKiAxcHggKTtcblx0XHRoZWlnaHQ6IGNhbGMoIHZhciggLS1zZWxlY3RlZC1oZWlnaHQsIDAgKSAqIDFweCApO1xuXHRcdHRyYW5zZm9ybS1vcmlnaW46IGxlZnQgdG9wO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlWCggY2FsYyggdmFyKCAtLXNlbGVjdGVkLWxlZnQsIDAgKSAqIDFweCApIClcblx0XHRcdHNjYWxlWChcblx0XHRcdFx0Y2FsYyhcblx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0KVxuXHRcdFx0KTtcblx0fVxuYDtcblxuY29uc3QgZW5jbG9zaW5nQm9yZGVycyA9ICggaXNCbG9jazogVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdpc0Jsb2NrJyBdICkgPT4ge1xuXHRjb25zdCBlbmNsb3NpbmdCb3JkZXIgPSBjc3NgXG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyIH07XG5cdGA7XG5cblx0cmV0dXJuIGNzc2Bcblx0XHQkeyBpc0Jsb2NrICYmIGVuY2xvc2luZ0JvcmRlciB9XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckhvdmVyIH07XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy13aXRoaW4ge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdGJveC1zaGFkb3c6ICR7IENPTkZJRy5jb250cm9sQm94U2hhZG93Rm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0b3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvZ2dsZUdyb3VwQ29udHJvbFNpemUgPSAoXG5cdHNpemU6IE5vbk51bGxhYmxlPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ3NpemUnIF0gPlxuKSA9PiB7XG5cdGNvbnN0IHN0eWxlcyA9IHtcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiAzNnB4O1xuXHRcdFx0cGFkZGluZzogMnB4O1xuXHRcdGAsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiA0MHB4O1xuXHRcdFx0cGFkZGluZzogM3B4O1xuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHN0eWxlc1sgc2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaXN1YWxMYWJlbFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQvLyBNYWtlcyB0aGUgaW5saW5lIGxhYmVsIGJlIHRoZSBjb3JyZWN0IGhlaWdodCwgZXF1aXZhbGVudCB0byBzZXR0aW5nIGxpbmUtaGVpZ2h0OiAwXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuIl19 */", 30498 toString: _EMOTION_STRINGIFIED_CSS_ERROR__10 30499 }; 30500 var _ref22 = false ? { 30501 name: "1ndywgm", 30502 styles: "min-height:36px;padding:2px" 30503 } : { 30504 name: "sqqfy-default", 30505 styles: "min-height:36px;padding:2px;label:default;", 30506 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrR2MiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCB0b2dnbGVHcm91cENvbnRyb2wgPSAoIHtcblx0aXNCbG9jayxcblx0aXNEZXNlbGVjdGFibGUsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzQmxvY2snIHwgJ2lzRGVzZWxlY3RhYmxlJyA+ICYge1xuXHRzaXplOiBOb25OdWxsYWJsZTwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdzaXplJyBdID47XG59ICkgPT4gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9O1xuXHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtaW4td2lkdGg6IDA7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHQkeyB0b2dnbGVHcm91cENvbnRyb2xTaXplKCBzaXplICkgfVxuXHQkeyAhIGlzRGVzZWxlY3RhYmxlICYmIGVuY2xvc2luZ0JvcmRlcnMoIGlzQmxvY2sgKSB9XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0JltkYXRhLWluZGljYXRvci1hbmltYXRlZF06OmJlZm9yZSB7XG5cdFx0XHR0cmFuc2l0aW9uLXByb3BlcnR5OiB0cmFuc2Zvcm0sIGJvcmRlci1yYWRpdXM7XG5cdFx0XHR0cmFuc2l0aW9uLWR1cmF0aW9uOiAwLjJzO1xuXHRcdFx0dHJhbnNpdGlvbi10aW1pbmctZnVuY3Rpb246IGVhc2Utb3V0O1xuXHRcdH1cblx0fVxuXG5cdCY6OmJlZm9yZSB7XG5cdFx0Y29udGVudDogJyc7XG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRvdXRsaW5lLW9mZnNldDogLTNweDtcblxuXHRcdC8qIFVzaW5nIGEgbGFyZ2UgdmFsdWUgdG8gYXZvaWQgYW50aWFsaWFzaW5nIHJvdW5kaW5nIGlzc3Vlc1xuXHRcdFx0d2hlbiBzY2FsaW5nIGluIHRoZSB0cmFuc2Zvcm0sIHNlZTogaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9hLzUyMTU5MTIzICovXG5cdFx0LS1hbnRpYWxpYXNpbmctZmFjdG9yOiAxMDA7XG5cdFx0LyogQWRqdXN0aW5nIHRoZSBib3JkZXIgcmFkaXVzIHRvIG1hdGNoIHRoZSBzY2FsaW5nIGluIHRoZSB4IGF4aXMuICovXG5cdFx0Ym9yZGVyLXJhZGl1czogY2FsYyhcblx0XHRcdFx0JHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9IC9cblx0XHRcdFx0XHQoXG5cdFx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvXG5cdFx0XHRcdFx0XHRcdHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0XHQpXG5cdFx0XHQpIC8gJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGxlZnQ6IC0xcHg7IC8vIENvcnJlY3RpbmcgZm9yIGJvcmRlci5cblx0XHR3aWR0aDogY2FsYyggdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKSAqIDFweCApO1xuXHRcdGhlaWdodDogY2FsYyggdmFyKCAtLXNlbGVjdGVkLWhlaWdodCwgMCApICogMXB4ICk7XG5cdFx0dHJhbnNmb3JtLW9yaWdpbjogbGVmdCB0b3A7XG5cdFx0dHJhbnNmb3JtOiB0cmFuc2xhdGVYKCBjYWxjKCB2YXIoIC0tc2VsZWN0ZWQtbGVmdCwgMCApICogMXB4ICkgKVxuXHRcdFx0c2NhbGVYKFxuXHRcdFx0XHRjYWxjKFxuXHRcdFx0XHRcdHZhciggLS1zZWxlY3RlZC13aWR0aCwgMCApIC8gdmFyKCAtLWFudGlhbGlhc2luZy1mYWN0b3IgKVxuXHRcdFx0XHQpXG5cdFx0XHQpO1xuXHR9XG5gO1xuXG5jb25zdCBlbmNsb3NpbmdCb3JkZXJzID0gKCBpc0Jsb2NrOiBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ2lzQmxvY2snIF0gKSA9PiB7XG5cdGNvbnN0IGVuY2xvc2luZ0JvcmRlciA9IGNzc2Bcblx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblx0YDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdCR7IGlzQmxvY2sgJiYgZW5jbG9zaW5nQm9yZGVyIH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVySG92ZXIgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzLXdpdGhpbiB7XG5cdFx0XHRib3JkZXItY29sb3I6ICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0Ym94LXNoYWRvdzogJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuXHRcdFx0ei1pbmRleDogMTtcblx0XHRcdC8vIFdpbmRvd3MgSGlnaCBDb250cmFzdCBtb2RlIHdpbGwgc2hvdyB0aGlzIG91dGxpbmUsIGJ1dCBub3QgdGhlIGJveC1zaGFkb3cuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogLTJweDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSA9IChcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+XG4pID0+IHtcblx0Y29uc3Qgc3R5bGVzID0ge1xuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDM2cHg7XG5cdFx0XHRwYWRkaW5nOiAycHg7XG5cdFx0YCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IGNzc2Bcblx0XHRcdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdFx0XHRwYWRkaW5nOiAzcHg7XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc3R5bGVzWyBzaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgYmxvY2sgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpc3VhbExhYmVsV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdC8vIE1ha2VzIHRoZSBpbmxpbmUgbGFiZWwgYmUgdGhlIGNvcnJlY3QgaGVpZ2h0LCBlcXVpdmFsZW50IHRvIHNldHRpbmcgbGluZS1oZWlnaHQ6IDBcblx0ZGlzcGxheTogZmxleDtcbmA7XG4iXX0= */", 30507 toString: _EMOTION_STRINGIFIED_CSS_ERROR__10 30508 }; 30509 var toggleGroupControlSize = (size3) => { 30510 const styles3 = { 30511 default: _ref22, 30512 "__unstable-large": _ref4 30513 }; 30514 return styles3[size3]; 30515 }; 30516 var block3 = false ? { 30517 name: "7whenc", 30518 styles: "display:flex;width:100%" 30519 } : { 30520 name: "2dfrl8-block", 30521 styles: "display:flex;width:100%;label:block;", 30522 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErR3dCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sID0gKCB7XG5cdGlzQmxvY2ssXG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRzaXplLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdpc0Jsb2NrJyB8ICdpc0Rlc2VsZWN0YWJsZScgPiAmIHtcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+O1xufSApID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JHsgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSggc2l6ZSApIH1cblx0JHsgISBpc0Rlc2VsZWN0YWJsZSAmJiBlbmNsb3NpbmdCb3JkZXJzKCBpc0Jsb2NrICkgfVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCZbZGF0YS1pbmRpY2F0b3ItYW5pbWF0ZWRdOjpiZWZvcmUge1xuXHRcdFx0dHJhbnNpdGlvbi1wcm9wZXJ0eTogdHJhbnNmb3JtLCBib3JkZXItcmFkaXVzO1xuXHRcdFx0dHJhbnNpdGlvbi1kdXJhdGlvbjogMC4ycztcblx0XHRcdHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiBlYXNlLW91dDtcblx0XHR9XG5cdH1cblxuXHQmOjpiZWZvcmUge1xuXHRcdGNvbnRlbnQ6ICcnO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9O1xuXG5cdFx0Ly8gV2luZG93cyBIaWdoIENvbnRyYXN0IG1vZGUgd2lsbCBzaG93IHRoaXMgb3V0bGluZSwgYnV0IG5vdCB0aGUgYm94LXNoYWRvdy5cblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XG5cblx0XHQvKiBVc2luZyBhIGxhcmdlIHZhbHVlIHRvIGF2b2lkIGFudGlhbGlhc2luZyByb3VuZGluZyBpc3N1ZXNcblx0XHRcdHdoZW4gc2NhbGluZyBpbiB0aGUgdHJhbnNmb3JtLCBzZWU6IGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vYS81MjE1OTEyMyAqL1xuXHRcdC0tYW50aWFsaWFzaW5nLWZhY3RvcjogMTAwO1xuXHRcdC8qIEFkanVzdGluZyB0aGUgYm9yZGVyIHJhZGl1cyB0byBtYXRjaCB0aGUgc2NhbGluZyBpbiB0aGUgeCBheGlzLiAqL1xuXHRcdGJvcmRlci1yYWRpdXM6IGNhbGMoXG5cdFx0XHRcdCR7IENPTkZJRy5yYWRpdXNYU21hbGwgfSAvXG5cdFx0XHRcdFx0KFxuXHRcdFx0XHRcdFx0dmFyKCAtLXNlbGVjdGVkLXdpZHRoLCAwICkgL1xuXHRcdFx0XHRcdFx0XHR2YXIoIC0tYW50aWFsaWFzaW5nLWZhY3RvciApXG5cdFx0XHRcdFx0KVxuXHRcdFx0KSAvICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRsZWZ0OiAtMXB4OyAvLyBDb3JyZWN0aW5nIGZvciBib3JkZXIuXG5cdFx0d2lkdGg6IGNhbGMoIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yICkgKiAxcHggKTtcblx0XHRoZWlnaHQ6IGNhbGMoIHZhciggLS1zZWxlY3RlZC1oZWlnaHQsIDAgKSAqIDFweCApO1xuXHRcdHRyYW5zZm9ybS1vcmlnaW46IGxlZnQgdG9wO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlWCggY2FsYyggdmFyKCAtLXNlbGVjdGVkLWxlZnQsIDAgKSAqIDFweCApIClcblx0XHRcdHNjYWxlWChcblx0XHRcdFx0Y2FsYyhcblx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0KVxuXHRcdFx0KTtcblx0fVxuYDtcblxuY29uc3QgZW5jbG9zaW5nQm9yZGVycyA9ICggaXNCbG9jazogVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdpc0Jsb2NrJyBdICkgPT4ge1xuXHRjb25zdCBlbmNsb3NpbmdCb3JkZXIgPSBjc3NgXG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyIH07XG5cdGA7XG5cblx0cmV0dXJuIGNzc2Bcblx0XHQkeyBpc0Jsb2NrICYmIGVuY2xvc2luZ0JvcmRlciB9XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckhvdmVyIH07XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy13aXRoaW4ge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdGJveC1zaGFkb3c6ICR7IENPTkZJRy5jb250cm9sQm94U2hhZG93Rm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0b3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvZ2dsZUdyb3VwQ29udHJvbFNpemUgPSAoXG5cdHNpemU6IE5vbk51bGxhYmxlPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ3NpemUnIF0gPlxuKSA9PiB7XG5cdGNvbnN0IHN0eWxlcyA9IHtcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiAzNnB4O1xuXHRcdFx0cGFkZGluZzogMnB4O1xuXHRcdGAsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiA0MHB4O1xuXHRcdFx0cGFkZGluZzogM3B4O1xuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHN0eWxlc1sgc2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaXN1YWxMYWJlbFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQvLyBNYWtlcyB0aGUgaW5saW5lIGxhYmVsIGJlIHRoZSBjb3JyZWN0IGhlaWdodCwgZXF1aXZhbGVudCB0byBzZXR0aW5nIGxpbmUtaGVpZ2h0OiAwXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuIl19 */", 30523 toString: _EMOTION_STRINGIFIED_CSS_ERROR__10 30524 }; 30525 var VisualLabelWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 30526 target: "eakva830" 30527 } : { 30528 target: "eakva830", 30529 label: "VisualLabelWrapper" 30530 })(false ? { 30531 name: "zjik7", 30532 styles: "display:flex" 30533 } : { 30534 name: "zjik7", 30535 styles: "display:flex", 30536 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSDRDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgdG9nZ2xlR3JvdXBDb250cm9sID0gKCB7XG5cdGlzQmxvY2ssXG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRzaXplLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdpc0Jsb2NrJyB8ICdpc0Rlc2VsZWN0YWJsZScgPiAmIHtcblx0c2l6ZTogTm9uTnVsbGFibGU8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzWyAnc2l6ZScgXSA+O1xufSApID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JHsgdG9nZ2xlR3JvdXBDb250cm9sU2l6ZSggc2l6ZSApIH1cblx0JHsgISBpc0Rlc2VsZWN0YWJsZSAmJiBlbmNsb3NpbmdCb3JkZXJzKCBpc0Jsb2NrICkgfVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCZbZGF0YS1pbmRpY2F0b3ItYW5pbWF0ZWRdOjpiZWZvcmUge1xuXHRcdFx0dHJhbnNpdGlvbi1wcm9wZXJ0eTogdHJhbnNmb3JtLCBib3JkZXItcmFkaXVzO1xuXHRcdFx0dHJhbnNpdGlvbi1kdXJhdGlvbjogMC4ycztcblx0XHRcdHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiBlYXNlLW91dDtcblx0XHR9XG5cdH1cblxuXHQmOjpiZWZvcmUge1xuXHRcdGNvbnRlbnQ6ICcnO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9O1xuXG5cdFx0Ly8gV2luZG93cyBIaWdoIENvbnRyYXN0IG1vZGUgd2lsbCBzaG93IHRoaXMgb3V0bGluZSwgYnV0IG5vdCB0aGUgYm94LXNoYWRvdy5cblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0b3V0bGluZS1vZmZzZXQ6IC0zcHg7XG5cblx0XHQvKiBVc2luZyBhIGxhcmdlIHZhbHVlIHRvIGF2b2lkIGFudGlhbGlhc2luZyByb3VuZGluZyBpc3N1ZXNcblx0XHRcdHdoZW4gc2NhbGluZyBpbiB0aGUgdHJhbnNmb3JtLCBzZWU6IGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vYS81MjE1OTEyMyAqL1xuXHRcdC0tYW50aWFsaWFzaW5nLWZhY3RvcjogMTAwO1xuXHRcdC8qIEFkanVzdGluZyB0aGUgYm9yZGVyIHJhZGl1cyB0byBtYXRjaCB0aGUgc2NhbGluZyBpbiB0aGUgeCBheGlzLiAqL1xuXHRcdGJvcmRlci1yYWRpdXM6IGNhbGMoXG5cdFx0XHRcdCR7IENPTkZJRy5yYWRpdXNYU21hbGwgfSAvXG5cdFx0XHRcdFx0KFxuXHRcdFx0XHRcdFx0dmFyKCAtLXNlbGVjdGVkLXdpZHRoLCAwICkgL1xuXHRcdFx0XHRcdFx0XHR2YXIoIC0tYW50aWFsaWFzaW5nLWZhY3RvciApXG5cdFx0XHRcdFx0KVxuXHRcdFx0KSAvICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRsZWZ0OiAtMXB4OyAvLyBDb3JyZWN0aW5nIGZvciBib3JkZXIuXG5cdFx0d2lkdGg6IGNhbGMoIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yICkgKiAxcHggKTtcblx0XHRoZWlnaHQ6IGNhbGMoIHZhciggLS1zZWxlY3RlZC1oZWlnaHQsIDAgKSAqIDFweCApO1xuXHRcdHRyYW5zZm9ybS1vcmlnaW46IGxlZnQgdG9wO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlWCggY2FsYyggdmFyKCAtLXNlbGVjdGVkLWxlZnQsIDAgKSAqIDFweCApIClcblx0XHRcdHNjYWxlWChcblx0XHRcdFx0Y2FsYyhcblx0XHRcdFx0XHR2YXIoIC0tc2VsZWN0ZWQtd2lkdGgsIDAgKSAvIHZhciggLS1hbnRpYWxpYXNpbmctZmFjdG9yIClcblx0XHRcdFx0KVxuXHRcdFx0KTtcblx0fVxuYDtcblxuY29uc3QgZW5jbG9zaW5nQm9yZGVycyA9ICggaXNCbG9jazogVG9nZ2xlR3JvdXBDb250cm9sUHJvcHNbICdpc0Jsb2NrJyBdICkgPT4ge1xuXHRjb25zdCBlbmNsb3NpbmdCb3JkZXIgPSBjc3NgXG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyIH07XG5cdGA7XG5cblx0cmV0dXJuIGNzc2Bcblx0XHQkeyBpc0Jsb2NrICYmIGVuY2xvc2luZ0JvcmRlciB9XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckhvdmVyIH07XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy13aXRoaW4ge1xuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdGJveC1zaGFkb3c6ICR7IENPTkZJRy5jb250cm9sQm94U2hhZG93Rm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHQvLyBXaW5kb3dzIEhpZ2ggQ29udHJhc3QgbW9kZSB3aWxsIHNob3cgdGhpcyBvdXRsaW5lLCBidXQgbm90IHRoZSBib3gtc2hhZG93LlxuXHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0b3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IHRvZ2dsZUdyb3VwQ29udHJvbFNpemUgPSAoXG5cdHNpemU6IE5vbk51bGxhYmxlPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wc1sgJ3NpemUnIF0gPlxuKSA9PiB7XG5cdGNvbnN0IHN0eWxlcyA9IHtcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiAzNnB4O1xuXHRcdFx0cGFkZGluZzogMnB4O1xuXHRcdGAsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiBjc3NgXG5cdFx0XHRtaW4taGVpZ2h0OiA0MHB4O1xuXHRcdFx0cGFkZGluZzogM3B4O1xuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHN0eWxlc1sgc2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IGJsb2NrID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaXN1YWxMYWJlbFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQvLyBNYWtlcyB0aGUgaW5saW5lIGxhYmVsIGJlIHRoZSBjb3JyZWN0IGhlaWdodCwgZXF1aXZhbGVudCB0byBzZXR0aW5nIGxpbmUtaGVpZ2h0OiAwXG5cdGRpc3BsYXk6IGZsZXg7XG5gO1xuIl19 */", 30537 toString: _EMOTION_STRINGIFIED_CSS_ERROR__10 30538 }); 30539 30540 // packages/components/build-module/toggle-group-control/toggle-group-control/as-radio-group.js 30541 var import_compose23 = __toESM(require_compose()); 30542 var import_element58 = __toESM(require_element()); 30543 var import_i18n10 = __toESM(require_i18n()); 30544 30545 // packages/components/build-module/toggle-group-control/context.js 30546 var import_element56 = __toESM(require_element()); 30547 var ToggleGroupControlContext = (0, import_element56.createContext)({}); 30548 ToggleGroupControlContext.displayName = "ToggleGroupControlContext"; 30549 var useToggleGroupControlContext = () => (0, import_element56.useContext)(ToggleGroupControlContext); 30550 var context_default2 = ToggleGroupControlContext; 30551 30552 // packages/components/build-module/toggle-group-control/toggle-group-control/utils.js 30553 var import_compose22 = __toESM(require_compose()); 30554 var import_element57 = __toESM(require_element()); 30555 function useComputeControlledOrUncontrolledValue(valueProp) { 30556 const isInitialRenderRef = (0, import_element57.useRef)(true); 30557 const prevValueProp = (0, import_compose22.usePrevious)(valueProp); 30558 const prevIsControlledRef = (0, import_element57.useRef)(false); 30559 (0, import_element57.useEffect)(() => { 30560 if (isInitialRenderRef.current) { 30561 isInitialRenderRef.current = false; 30562 } 30563 }, []); 30564 const isControlled = prevIsControlledRef.current || !isInitialRenderRef.current && prevValueProp !== valueProp; 30565 (0, import_element57.useEffect)(() => { 30566 prevIsControlledRef.current = isControlled; 30567 }, [isControlled]); 30568 if (isControlled) { 30569 return { 30570 value: valueProp !== null && valueProp !== void 0 ? valueProp : "", 30571 defaultValue: void 0 30572 }; 30573 } 30574 return { 30575 value: void 0, 30576 defaultValue: valueProp 30577 }; 30578 } 30579 30580 // packages/components/build-module/toggle-group-control/toggle-group-control/as-radio-group.js 30581 var import_jsx_runtime115 = __toESM(require_jsx_runtime()); 30582 function UnforwardedToggleGroupControlAsRadioGroup({ 30583 children, 30584 isAdaptiveWidth, 30585 label, 30586 onChange: onChangeProp, 30587 size: size3, 30588 value: valueProp, 30589 id: idProp, 30590 setSelectedElement, 30591 ...otherProps 30592 }, forwardedRef) { 30593 const generatedId = (0, import_compose23.useInstanceId)(ToggleGroupControlAsRadioGroup, "toggle-group-control-as-radio-group"); 30594 const baseId = idProp || generatedId; 30595 const { 30596 value, 30597 defaultValue: defaultValue2 30598 } = useComputeControlledOrUncontrolledValue(valueProp); 30599 const wrappedOnChangeProp = onChangeProp ? (v3) => { 30600 onChangeProp(v3 !== null && v3 !== void 0 ? v3 : void 0); 30601 } : void 0; 30602 const radio = useRadioStore({ 30603 defaultValue: defaultValue2, 30604 value, 30605 setValue: wrappedOnChangeProp, 30606 rtl: (0, import_i18n10.isRTL)() 30607 }); 30608 const selectedValue = useStoreState(radio, "value"); 30609 const setValue = radio.setValue; 30610 (0, import_element58.useEffect)(() => { 30611 if (selectedValue === "") { 30612 radio.setActiveId(void 0); 30613 } 30614 }, [radio, selectedValue]); 30615 const groupContextValue = (0, import_element58.useMemo)(() => ({ 30616 activeItemIsNotFirstItem: () => radio.getState().activeId !== radio.first(), 30617 baseId, 30618 isBlock: !isAdaptiveWidth, 30619 size: size3, 30620 // @ts-expect-error - This is wrong and we should fix it. 30621 value: selectedValue, 30622 // @ts-expect-error - This is wrong and we should fix it. 30623 setValue, 30624 setSelectedElement 30625 }), [baseId, isAdaptiveWidth, radio, selectedValue, setSelectedElement, setValue, size3]); 30626 return /* @__PURE__ */ (0, import_jsx_runtime115.jsx)(context_default2.Provider, { 30627 value: groupContextValue, 30628 children: /* @__PURE__ */ (0, import_jsx_runtime115.jsx)(RadioGroup, { 30629 store: radio, 30630 "aria-label": label, 30631 render: /* @__PURE__ */ (0, import_jsx_runtime115.jsx)(component_default, {}), 30632 ...otherProps, 30633 id: baseId, 30634 ref: forwardedRef, 30635 children 30636 }) 30637 }); 30638 } 30639 var ToggleGroupControlAsRadioGroup = (0, import_element58.forwardRef)(UnforwardedToggleGroupControlAsRadioGroup); 30640 30641 // packages/components/build-module/toggle-group-control/toggle-group-control/as-button-group.js 30642 var import_compose24 = __toESM(require_compose()); 30643 var import_element59 = __toESM(require_element()); 30644 var import_jsx_runtime116 = __toESM(require_jsx_runtime()); 30645 function UnforwardedToggleGroupControlAsButtonGroup({ 30646 children, 30647 isAdaptiveWidth, 30648 label, 30649 onChange, 30650 size: size3, 30651 value: valueProp, 30652 id: idProp, 30653 setSelectedElement, 30654 ...otherProps 30655 }, forwardedRef) { 30656 const generatedId = (0, import_compose24.useInstanceId)(ToggleGroupControlAsButtonGroup, "toggle-group-control-as-button-group"); 30657 const baseId = idProp || generatedId; 30658 const { 30659 value, 30660 defaultValue: defaultValue2 30661 } = useComputeControlledOrUncontrolledValue(valueProp); 30662 const [selectedValue, setSelectedValue] = useControlledValue({ 30663 defaultValue: defaultValue2, 30664 value, 30665 onChange 30666 }); 30667 const groupContextValue = (0, import_element59.useMemo)(() => ({ 30668 baseId, 30669 value: selectedValue, 30670 setValue: setSelectedValue, 30671 isBlock: !isAdaptiveWidth, 30672 isDeselectable: true, 30673 size: size3, 30674 setSelectedElement 30675 }), [baseId, selectedValue, setSelectedValue, isAdaptiveWidth, size3, setSelectedElement]); 30676 return /* @__PURE__ */ (0, import_jsx_runtime116.jsx)(context_default2.Provider, { 30677 value: groupContextValue, 30678 children: /* @__PURE__ */ (0, import_jsx_runtime116.jsx)(component_default, { 30679 "aria-label": label, 30680 ...otherProps, 30681 ref: forwardedRef, 30682 role: "group", 30683 children 30684 }) 30685 }); 30686 } 30687 var ToggleGroupControlAsButtonGroup = (0, import_element59.forwardRef)(UnforwardedToggleGroupControlAsButtonGroup); 30688 30689 // packages/components/build-module/utils/element-rect.js 30690 var import_element60 = __toESM(require_element()); 30691 var import_compose25 = __toESM(require_compose()); 30692 var NULL_ELEMENT_OFFSET_RECT = { 30693 element: void 0, 30694 top: 0, 30695 right: 0, 30696 bottom: 0, 30697 left: 0, 30698 width: 0, 30699 height: 0 30700 }; 30701 function getElementOffsetRect(element) { 30702 var _offsetParent$getBoun, _offsetParent$scrollL, _offsetParent$scrollT; 30703 const rect = element.getBoundingClientRect(); 30704 if (rect.width === 0 || rect.height === 0) { 30705 return; 30706 } 30707 const offsetParent = element.offsetParent; 30708 const offsetParentRect = (_offsetParent$getBoun = offsetParent?.getBoundingClientRect()) !== null && _offsetParent$getBoun !== void 0 ? _offsetParent$getBoun : NULL_ELEMENT_OFFSET_RECT; 30709 const offsetParentScrollX = (_offsetParent$scrollL = offsetParent?.scrollLeft) !== null && _offsetParent$scrollL !== void 0 ? _offsetParent$scrollL : 0; 30710 const offsetParentScrollY = (_offsetParent$scrollT = offsetParent?.scrollTop) !== null && _offsetParent$scrollT !== void 0 ? _offsetParent$scrollT : 0; 30711 const computedWidth = parseFloat(getComputedStyle(element).width); 30712 const computedHeight = parseFloat(getComputedStyle(element).height); 30713 const scaleX = computedWidth / rect.width; 30714 const scaleY = computedHeight / rect.height; 30715 return { 30716 element, 30717 // To obtain the adjusted values for the position: 30718 // 1. Compute the element's position relative to the offset parent. 30719 // 2. Correct for the scale factor. 30720 // 3. Adjust for the scroll position of the offset parent. 30721 top: (rect.top - offsetParentRect?.top) * scaleY + offsetParentScrollY, 30722 right: (offsetParentRect?.right - rect.right) * scaleX - offsetParentScrollX, 30723 bottom: (offsetParentRect?.bottom - rect.bottom) * scaleY - offsetParentScrollY, 30724 left: (rect.left - offsetParentRect?.left) * scaleX + offsetParentScrollX, 30725 // Computed dimensions don't need any adjustments. 30726 width: computedWidth, 30727 height: computedHeight 30728 }; 30729 } 30730 var POLL_RATE = 100; 30731 function useTrackElementOffsetRect(targetElement, deps = []) { 30732 const [indicatorPosition, setIndicatorPosition] = (0, import_element60.useState)(NULL_ELEMENT_OFFSET_RECT); 30733 const intervalRef = (0, import_element60.useRef)(); 30734 const measure = (0, import_compose25.useEvent)(() => { 30735 if (targetElement && targetElement.isConnected) { 30736 const elementOffsetRect = getElementOffsetRect(targetElement); 30737 if (elementOffsetRect) { 30738 setIndicatorPosition(elementOffsetRect); 30739 clearInterval(intervalRef.current); 30740 return true; 30741 } 30742 } else { 30743 clearInterval(intervalRef.current); 30744 } 30745 return false; 30746 }); 30747 const setElement = (0, import_compose25.useResizeObserver)(() => { 30748 if (!measure()) { 30749 requestAnimationFrame(() => { 30750 if (!measure()) { 30751 intervalRef.current = setInterval(measure, POLL_RATE); 30752 } 30753 }); 30754 } 30755 }); 30756 (0, import_element60.useLayoutEffect)(() => { 30757 setElement(targetElement); 30758 if (!targetElement) { 30759 setIndicatorPosition(NULL_ELEMENT_OFFSET_RECT); 30760 } 30761 }, [setElement, targetElement]); 30762 (0, import_element60.useLayoutEffect)(() => { 30763 measure(); 30764 }, deps); 30765 return indicatorPosition; 30766 } 30767 30768 // packages/components/build-module/utils/hooks/use-animated-offset-rect.js 30769 var import_compose27 = __toESM(require_compose()); 30770 var import_element62 = __toESM(require_element()); 30771 30772 // packages/components/build-module/utils/hooks/use-on-value-update.js 30773 var import_compose26 = __toESM(require_compose()); 30774 var import_element61 = __toESM(require_element()); 30775 function useOnValueUpdate(value, onUpdate) { 30776 const previousValueRef = (0, import_element61.useRef)(value); 30777 const updateCallbackEvent = (0, import_compose26.useEvent)(onUpdate); 30778 (0, import_element61.useLayoutEffect)(() => { 30779 if (previousValueRef.current !== value) { 30780 updateCallbackEvent({ 30781 previousValue: previousValueRef.current 30782 }); 30783 previousValueRef.current = value; 30784 } 30785 }, [updateCallbackEvent, value]); 30786 } 30787 30788 // packages/components/build-module/utils/hooks/use-animated-offset-rect.js 30789 function useAnimatedOffsetRect(container, rect, { 30790 prefix: prefix2 = "subelement", 30791 dataAttribute = `$prefix2}-animated`, 30792 transitionEndFilter = () => true, 30793 roundRect = false 30794 } = {}) { 30795 const setProperties = (0, import_compose27.useEvent)(() => { 30796 Object.keys(rect).forEach((property) => property !== "element" && container?.style.setProperty(`--$prefix2}-$property}`, String(roundRect ? Math.floor(rect[property]) : rect[property]))); 30797 }); 30798 (0, import_element62.useLayoutEffect)(() => { 30799 setProperties(); 30800 }, [rect, setProperties]); 30801 useOnValueUpdate(rect.element, ({ 30802 previousValue 30803 }) => { 30804 if (rect.element && previousValue) { 30805 container?.setAttribute(`data-$dataAttribute}`, ""); 30806 } 30807 }); 30808 (0, import_element62.useLayoutEffect)(() => { 30809 function onTransitionEnd(event) { 30810 if (transitionEndFilter(event)) { 30811 container?.removeAttribute(`data-$dataAttribute}`); 30812 } 30813 } 30814 container?.addEventListener("transitionend", onTransitionEnd); 30815 return () => container?.removeEventListener("transitionend", onTransitionEnd); 30816 }, [dataAttribute, container, transitionEndFilter]); 30817 } 30818 30819 // packages/components/build-module/toggle-group-control/toggle-group-control/component.js 30820 var import_jsx_runtime117 = __toESM(require_jsx_runtime()); 30821 function UnconnectedToggleGroupControl(props, forwardedRef) { 30822 const { 30823 __nextHasNoMarginBottom: _, 30824 // Prevent passing this to the internal component 30825 __next40pxDefaultSize = false, 30826 __shouldNotWarnDeprecated36pxSize, 30827 className: className2, 30828 isAdaptiveWidth = false, 30829 isBlock = false, 30830 isDeselectable = false, 30831 label, 30832 hideLabelFromVision = false, 30833 help, 30834 onChange, 30835 size: size3 = "default", 30836 value, 30837 children, 30838 ...otherProps 30839 } = useContextSystem(props, "ToggleGroupControl"); 30840 const normalizedSize = __next40pxDefaultSize && size3 === "default" ? "__unstable-large" : size3; 30841 const [selectedElement, setSelectedElement] = (0, import_element63.useState)(); 30842 const [controlElement, setControlElement] = (0, import_element63.useState)(); 30843 const refs = (0, import_compose28.useMergeRefs)([setControlElement, forwardedRef]); 30844 const selectedRect = useTrackElementOffsetRect(value !== null && value !== void 0 ? selectedElement : void 0); 30845 useAnimatedOffsetRect(controlElement, selectedRect, { 30846 prefix: "selected", 30847 dataAttribute: "indicator-animated", 30848 transitionEndFilter: (event) => event.pseudoElement === "::before", 30849 roundRect: true 30850 }); 30851 const cx3 = useCx(); 30852 const classes = (0, import_element63.useMemo)(() => cx3(toggleGroupControl({ 30853 isBlock, 30854 isDeselectable, 30855 size: normalizedSize 30856 }), isBlock && block3, className2), [className2, cx3, isBlock, isDeselectable, normalizedSize]); 30857 const MainControl = isDeselectable ? ToggleGroupControlAsButtonGroup : ToggleGroupControlAsRadioGroup; 30858 maybeWarnDeprecated36pxSize({ 30859 componentName: "ToggleGroupControl", 30860 size: size3, 30861 __next40pxDefaultSize, 30862 __shouldNotWarnDeprecated36pxSize 30863 }); 30864 return /* @__PURE__ */ (0, import_jsx_runtime117.jsxs)(base_control_default, { 30865 help, 30866 children: [!hideLabelFromVision && /* @__PURE__ */ (0, import_jsx_runtime117.jsx)(VisualLabelWrapper, { 30867 children: /* @__PURE__ */ (0, import_jsx_runtime117.jsx)(base_control_default.VisualLabel, { 30868 children: label 30869 }) 30870 }), /* @__PURE__ */ (0, import_jsx_runtime117.jsx)(MainControl, { 30871 ...otherProps, 30872 setSelectedElement, 30873 className: classes, 30874 isAdaptiveWidth, 30875 label, 30876 onChange, 30877 ref: refs, 30878 size: normalizedSize, 30879 value, 30880 children 30881 })] 30882 }); 30883 } 30884 var ToggleGroupControl = contextConnect(UnconnectedToggleGroupControl, "ToggleGroupControl"); 30885 var component_default12 = ToggleGroupControl; 30886 30887 // packages/components/build-module/toggle-group-control/toggle-group-control-option/component.js 30888 var import_element65 = __toESM(require_element()); 30889 30890 // packages/components/build-module/toggle-group-control/toggle-group-control-option-base/component.js 30891 var import_compose29 = __toESM(require_compose()); 30892 var import_element64 = __toESM(require_element()); 30893 30894 // packages/components/build-module/toggle-group-control/toggle-group-control-option-base/styles.js 30895 var styles_exports6 = {}; 30896 __export(styles_exports6, { 30897 ButtonContentView: () => ButtonContentView, 30898 LabelView: () => LabelView, 30899 buttonView: () => buttonView, 30900 labelBlock: () => labelBlock 30901 }); 30902 function _EMOTION_STRINGIFIED_CSS_ERROR__11() { 30903 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 30904 } 30905 var LabelView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 30906 target: "et6ln9s1" 30907 } : { 30908 target: "et6ln9s1", 30909 label: "LabelView" 30910 })(false ? { 30911 name: "sln1fl", 30912 styles: "display:inline-flex;max-width:100%;min-width:0;position:relative" 30913 } : { 30914 name: "sln1fl", 30915 styles: "display:inline-flex;max-width:100%;min-width:0;position:relative", 30916 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlbUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHtcblx0VG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsXG5cdFRvZ2dsZUdyb3VwQ29udHJvbE9wdGlvbkJhc2VQcm9wcyxcbn0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgTGFiZWxWaWV3ID0gc3R5bGVkLmRpdmBcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgbGFiZWxCbG9jayA9IGNzc2Bcblx0ZmxleDogMTtcbmA7XG5cbmV4cG9ydCBjb25zdCBidXR0b25WaWV3ID0gKCB7XG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRpc0ljb24sXG5cdGlzUHJlc3NlZCxcblx0c2l6ZSxcbn06IFBpY2s8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLCAnaXNEZXNlbGVjdGFibGUnIHwgJ3NpemUnID4gJlxuXHRQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsICdpc0ljb24nID4gJiB7XG5cdFx0aXNQcmVzc2VkPzogYm9vbGVhbjtcblx0fSApID0+IGNzc2Bcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0YXBwZWFyYW5jZTogbm9uZTtcblx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdGJvcmRlcjogbm9uZTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDcwMCBdIH07XG5cdGZpbGw6IGN1cnJlbnRDb2xvcjtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0aGVpZ2h0OiAxMDAlO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblx0bGluZS1oZWlnaHQ6IDEwMCU7XG5cdG91dGxpbmU6IG5vbmU7XG5cdHBhZGRpbmc6IDAgMTJweDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdHRyYW5zaXRpb246XG5cdFx0XHRiYWNrZ3JvdW5kICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Y29sb3IgJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBsaW5lYXIsXG5cdFx0XHRmb250LXdlaWdodCA2MG1zIGxpbmVhcjtcblx0fVxuXHR1c2VyLXNlbGVjdDogbm9uZTtcblx0d2lkdGg6IDEwMCU7XG5cdHotaW5kZXg6IDI7XG5cblx0Jjo6LW1vei1mb2N1cy1pbm5lciB7XG5cdFx0Ym9yZGVyOiAwO1xuXHR9XG5cblx0JltkaXNhYmxlZF0ge1xuXHRcdG9wYWNpdHk6IDAuNDtcblx0XHRjdXJzb3I6IGRlZmF1bHQ7XG5cdH1cblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0fVxuXG5cdCR7IGlzRGVzZWxlY3RhYmxlICYmIGRlc2VsZWN0YWJsZSB9XG5cdCR7IGlzSWNvbiAmJiBpc0ljb25TdHlsZXMoIHsgc2l6ZSB9ICkgfVxuXHQkeyBpc1ByZXNzZWQgJiYgcHJlc3NlZCB9XG5gO1xuXG5jb25zdCBwcmVzc2VkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmRJbnZlcnRlZCB9O1xuXG5cdCY6YWN0aXZlIHtcblx0XHRiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgZGVzZWxlY3RhYmxlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblxuXHQmOmZvY3VzIHtcblx0XHRib3gtc2hhZG93OlxuXHRcdFx0aW5zZXQgMCAwIDAgMXB4ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH0sXG5cdFx0XHQwIDAgMCAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBCdXR0b25Db250ZW50VmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGxpbmUtaGVpZ2h0OiAxO1xuYDtcblxuY29uc3QgaXNJY29uU3R5bGVzID0gKCB7XG5cdHNpemUgPSAnZGVmYXVsdCcsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ3NpemUnID4gKSA9PiB7XG5cdGNvbnN0IGljb25CdXR0b25TaXplcyA9IHtcblx0XHRkZWZhdWx0OiAnMzBweCcsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiAnMzJweCcsXG5cdH07XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IGljb25CdXR0b25TaXplc1sgc2l6ZSBdIH07XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmctbGVmdDogMDtcblx0XHRwYWRkaW5nLXJpZ2h0OiAwO1xuXHRgO1xufTtcbiJdfQ== */", 30917 toString: _EMOTION_STRINGIFIED_CSS_ERROR__11 30918 }); 30919 var labelBlock = false ? { 30920 name: "82a6rk", 30921 styles: "flex:1" 30922 } : { 30923 name: "1sypmw-labelBlock", 30924 styles: "flex:1;label:labelBlock;", 30925 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQjZCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7XG5cdFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLFxuXHRUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsXG59IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IExhYmVsVmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtYXgtd2lkdGg6IDEwMCU7XG5cdG1pbi13aWR0aDogMDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuZXhwb3J0IGNvbnN0IGxhYmVsQmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgYnV0dG9uVmlldyA9ICgge1xuXHRpc0Rlc2VsZWN0YWJsZSxcblx0aXNJY29uLFxuXHRpc1ByZXNzZWQsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzRGVzZWxlY3RhYmxlJyB8ICdzaXplJyA+ICZcblx0UGljazwgVG9nZ2xlR3JvdXBDb250cm9sT3B0aW9uQmFzZVByb3BzLCAnaXNJY29uJyA+ICYge1xuXHRcdGlzUHJlc3NlZD86IGJvb2xlYW47XG5cdH0gKSA9PiBjc3NgXG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGFwcGVhcmFuY2U6IG5vbmU7XG5cdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRib3JkZXI6IG5vbmU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogZmxleDtcblx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cdGhlaWdodDogMTAwJTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdGxpbmUtaGVpZ2h0OiAxMDAlO1xuXHRvdXRsaW5lOiBub25lO1xuXHRwYWRkaW5nOiAwIDEycHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0dGV4dC1hbGlnbjogY2VudGVyO1xuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0YmFja2dyb3VuZCAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uRmFzdCB9IGxpbmVhcixcblx0XHRcdGNvbG9yICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Zm9udC13ZWlnaHQgNjBtcyBsaW5lYXI7XG5cdH1cblx0dXNlci1zZWxlY3Q6IG5vbmU7XG5cdHdpZHRoOiAxMDAlO1xuXHR6LWluZGV4OiAyO1xuXG5cdCY6Oi1tb3otZm9jdXMtaW5uZXIge1xuXHRcdGJvcmRlcjogMDtcblx0fVxuXG5cdCZbZGlzYWJsZWRdIHtcblx0XHRvcGFjaXR5OiAwLjQ7XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHR9XG5cblx0JjphY3RpdmUge1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH07XG5cdH1cblxuXHQkeyBpc0Rlc2VsZWN0YWJsZSAmJiBkZXNlbGVjdGFibGUgfVxuXHQkeyBpc0ljb24gJiYgaXNJY29uU3R5bGVzKCB7IHNpemUgfSApIH1cblx0JHsgaXNQcmVzc2VkICYmIHByZXNzZWQgfVxuYDtcblxuY29uc3QgcHJlc3NlZCA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGRlc2VsZWN0YWJsZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0Jjpmb2N1cyB7XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdGluc2V0IDAgMCAwIDFweCAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9LFxuXHRcdFx0MCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQnV0dG9uQ29udGVudFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogMTtcbmA7XG5cbmNvbnN0IGlzSWNvblN0eWxlcyA9ICgge1xuXHRzaXplID0gJ2RlZmF1bHQnLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdzaXplJyA+ICkgPT4ge1xuXHRjb25zdCBpY29uQnV0dG9uU2l6ZXMgPSB7XG5cdFx0ZGVmYXVsdDogJzMwcHgnLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogJzMycHgnLFxuXHR9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdFx0aGVpZ2h0OiAkeyBpY29uQnV0dG9uU2l6ZXNbIHNpemUgXSB9O1xuXHRcdGFzcGVjdC1yYXRpbzogMTtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0YDtcbn07XG4iXX0= */", 30926 toString: _EMOTION_STRINGIFIED_CSS_ERROR__11 30927 }; 30928 var buttonView = ({ 30929 isDeselectable, 30930 isIcon, 30931 isPressed, 30932 size: size3 30933 }) => /* @__PURE__ */ css("align-items:center;appearance:none;background:transparent;border:none;border-radius:", config_values_default.radiusXSmall, ";color:", COLORS.theme.gray[700], ";fill:currentColor;cursor:pointer;display:flex;font-family:inherit;height:100%;justify-content:center;line-height:100%;outline:none;padding:0 12px;position:relative;text-align:center;@media not ( prefers-reduced-motion ){transition:background ", config_values_default.transitionDurationFast, " linear,color ", config_values_default.transitionDurationFast, " linear,font-weight 60ms linear;}user-select:none;width:100%;z-index:2;&::-moz-focus-inner{border:0;}&[disabled]{opacity:0.4;cursor:default;}&:active{background:", COLORS.ui.background, ";}", isDeselectable && deselectable, " ", isIcon && isIconStyles({ 30934 size: size3 30935 }), " ", isPressed && pressed, ";" + (false ? "" : ";label:buttonView;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ1ciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHtcblx0VG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsXG5cdFRvZ2dsZUdyb3VwQ29udHJvbE9wdGlvbkJhc2VQcm9wcyxcbn0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgTGFiZWxWaWV3ID0gc3R5bGVkLmRpdmBcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgbGFiZWxCbG9jayA9IGNzc2Bcblx0ZmxleDogMTtcbmA7XG5cbmV4cG9ydCBjb25zdCBidXR0b25WaWV3ID0gKCB7XG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRpc0ljb24sXG5cdGlzUHJlc3NlZCxcblx0c2l6ZSxcbn06IFBpY2s8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLCAnaXNEZXNlbGVjdGFibGUnIHwgJ3NpemUnID4gJlxuXHRQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsICdpc0ljb24nID4gJiB7XG5cdFx0aXNQcmVzc2VkPzogYm9vbGVhbjtcblx0fSApID0+IGNzc2Bcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0YXBwZWFyYW5jZTogbm9uZTtcblx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdGJvcmRlcjogbm9uZTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDcwMCBdIH07XG5cdGZpbGw6IGN1cnJlbnRDb2xvcjtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0aGVpZ2h0OiAxMDAlO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblx0bGluZS1oZWlnaHQ6IDEwMCU7XG5cdG91dGxpbmU6IG5vbmU7XG5cdHBhZGRpbmc6IDAgMTJweDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdHRyYW5zaXRpb246XG5cdFx0XHRiYWNrZ3JvdW5kICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Y29sb3IgJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBsaW5lYXIsXG5cdFx0XHRmb250LXdlaWdodCA2MG1zIGxpbmVhcjtcblx0fVxuXHR1c2VyLXNlbGVjdDogbm9uZTtcblx0d2lkdGg6IDEwMCU7XG5cdHotaW5kZXg6IDI7XG5cblx0Jjo6LW1vei1mb2N1cy1pbm5lciB7XG5cdFx0Ym9yZGVyOiAwO1xuXHR9XG5cblx0JltkaXNhYmxlZF0ge1xuXHRcdG9wYWNpdHk6IDAuNDtcblx0XHRjdXJzb3I6IGRlZmF1bHQ7XG5cdH1cblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0fVxuXG5cdCR7IGlzRGVzZWxlY3RhYmxlICYmIGRlc2VsZWN0YWJsZSB9XG5cdCR7IGlzSWNvbiAmJiBpc0ljb25TdHlsZXMoIHsgc2l6ZSB9ICkgfVxuXHQkeyBpc1ByZXNzZWQgJiYgcHJlc3NlZCB9XG5gO1xuXG5jb25zdCBwcmVzc2VkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmRJbnZlcnRlZCB9O1xuXG5cdCY6YWN0aXZlIHtcblx0XHRiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgZGVzZWxlY3RhYmxlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblxuXHQmOmZvY3VzIHtcblx0XHRib3gtc2hhZG93OlxuXHRcdFx0aW5zZXQgMCAwIDAgMXB4ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH0sXG5cdFx0XHQwIDAgMCAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBCdXR0b25Db250ZW50VmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGxpbmUtaGVpZ2h0OiAxO1xuYDtcblxuY29uc3QgaXNJY29uU3R5bGVzID0gKCB7XG5cdHNpemUgPSAnZGVmYXVsdCcsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ3NpemUnID4gKSA9PiB7XG5cdGNvbnN0IGljb25CdXR0b25TaXplcyA9IHtcblx0XHRkZWZhdWx0OiAnMzBweCcsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiAnMzJweCcsXG5cdH07XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IGljb25CdXR0b25TaXplc1sgc2l6ZSBdIH07XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmctbGVmdDogMDtcblx0XHRwYWRkaW5nLXJpZ2h0OiAwO1xuXHRgO1xufTtcbiJdfQ== */"); 30936 var pressed = /* @__PURE__ */ css("color:", COLORS.theme.foregroundInverted, ";&:active{background:transparent;}" + (false ? "" : ";label:pressed;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRm1CIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7XG5cdFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLFxuXHRUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsXG59IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IExhYmVsVmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtYXgtd2lkdGg6IDEwMCU7XG5cdG1pbi13aWR0aDogMDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuZXhwb3J0IGNvbnN0IGxhYmVsQmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgYnV0dG9uVmlldyA9ICgge1xuXHRpc0Rlc2VsZWN0YWJsZSxcblx0aXNJY29uLFxuXHRpc1ByZXNzZWQsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzRGVzZWxlY3RhYmxlJyB8ICdzaXplJyA+ICZcblx0UGljazwgVG9nZ2xlR3JvdXBDb250cm9sT3B0aW9uQmFzZVByb3BzLCAnaXNJY29uJyA+ICYge1xuXHRcdGlzUHJlc3NlZD86IGJvb2xlYW47XG5cdH0gKSA9PiBjc3NgXG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGFwcGVhcmFuY2U6IG5vbmU7XG5cdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRib3JkZXI6IG5vbmU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogZmxleDtcblx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cdGhlaWdodDogMTAwJTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdGxpbmUtaGVpZ2h0OiAxMDAlO1xuXHRvdXRsaW5lOiBub25lO1xuXHRwYWRkaW5nOiAwIDEycHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0dGV4dC1hbGlnbjogY2VudGVyO1xuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0YmFja2dyb3VuZCAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uRmFzdCB9IGxpbmVhcixcblx0XHRcdGNvbG9yICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Zm9udC13ZWlnaHQgNjBtcyBsaW5lYXI7XG5cdH1cblx0dXNlci1zZWxlY3Q6IG5vbmU7XG5cdHdpZHRoOiAxMDAlO1xuXHR6LWluZGV4OiAyO1xuXG5cdCY6Oi1tb3otZm9jdXMtaW5uZXIge1xuXHRcdGJvcmRlcjogMDtcblx0fVxuXG5cdCZbZGlzYWJsZWRdIHtcblx0XHRvcGFjaXR5OiAwLjQ7XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHR9XG5cblx0JjphY3RpdmUge1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH07XG5cdH1cblxuXHQkeyBpc0Rlc2VsZWN0YWJsZSAmJiBkZXNlbGVjdGFibGUgfVxuXHQkeyBpc0ljb24gJiYgaXNJY29uU3R5bGVzKCB7IHNpemUgfSApIH1cblx0JHsgaXNQcmVzc2VkICYmIHByZXNzZWQgfVxuYDtcblxuY29uc3QgcHJlc3NlZCA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGRlc2VsZWN0YWJsZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0Jjpmb2N1cyB7XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdGluc2V0IDAgMCAwIDFweCAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9LFxuXHRcdFx0MCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQnV0dG9uQ29udGVudFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogMTtcbmA7XG5cbmNvbnN0IGlzSWNvblN0eWxlcyA9ICgge1xuXHRzaXplID0gJ2RlZmF1bHQnLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdzaXplJyA+ICkgPT4ge1xuXHRjb25zdCBpY29uQnV0dG9uU2l6ZXMgPSB7XG5cdFx0ZGVmYXVsdDogJzMwcHgnLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogJzMycHgnLFxuXHR9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdFx0aGVpZ2h0OiAkeyBpY29uQnV0dG9uU2l6ZXNbIHNpemUgXSB9O1xuXHRcdGFzcGVjdC1yYXRpbzogMTtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0YDtcbn07XG4iXX0= */"); 30937 var deselectable = /* @__PURE__ */ css("color:", COLORS.theme.foreground, ";&:focus{box-shadow:inset 0 0 0 1px ", COLORS.ui.background, ",0 0 0 ", config_values_default.borderWidthFocus, " ", COLORS.theme.accent, ";outline:2px solid transparent;}" + (false ? "" : ";label:deselectable;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RndCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7XG5cdFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLFxuXHRUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsXG59IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IExhYmVsVmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtYXgtd2lkdGg6IDEwMCU7XG5cdG1pbi13aWR0aDogMDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuZXhwb3J0IGNvbnN0IGxhYmVsQmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgYnV0dG9uVmlldyA9ICgge1xuXHRpc0Rlc2VsZWN0YWJsZSxcblx0aXNJY29uLFxuXHRpc1ByZXNzZWQsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzRGVzZWxlY3RhYmxlJyB8ICdzaXplJyA+ICZcblx0UGljazwgVG9nZ2xlR3JvdXBDb250cm9sT3B0aW9uQmFzZVByb3BzLCAnaXNJY29uJyA+ICYge1xuXHRcdGlzUHJlc3NlZD86IGJvb2xlYW47XG5cdH0gKSA9PiBjc3NgXG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGFwcGVhcmFuY2U6IG5vbmU7XG5cdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRib3JkZXI6IG5vbmU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogZmxleDtcblx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cdGhlaWdodDogMTAwJTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdGxpbmUtaGVpZ2h0OiAxMDAlO1xuXHRvdXRsaW5lOiBub25lO1xuXHRwYWRkaW5nOiAwIDEycHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0dGV4dC1hbGlnbjogY2VudGVyO1xuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0YmFja2dyb3VuZCAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uRmFzdCB9IGxpbmVhcixcblx0XHRcdGNvbG9yICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Zm9udC13ZWlnaHQgNjBtcyBsaW5lYXI7XG5cdH1cblx0dXNlci1zZWxlY3Q6IG5vbmU7XG5cdHdpZHRoOiAxMDAlO1xuXHR6LWluZGV4OiAyO1xuXG5cdCY6Oi1tb3otZm9jdXMtaW5uZXIge1xuXHRcdGJvcmRlcjogMDtcblx0fVxuXG5cdCZbZGlzYWJsZWRdIHtcblx0XHRvcGFjaXR5OiAwLjQ7XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHR9XG5cblx0JjphY3RpdmUge1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH07XG5cdH1cblxuXHQkeyBpc0Rlc2VsZWN0YWJsZSAmJiBkZXNlbGVjdGFibGUgfVxuXHQkeyBpc0ljb24gJiYgaXNJY29uU3R5bGVzKCB7IHNpemUgfSApIH1cblx0JHsgaXNQcmVzc2VkICYmIHByZXNzZWQgfVxuYDtcblxuY29uc3QgcHJlc3NlZCA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGRlc2VsZWN0YWJsZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0Jjpmb2N1cyB7XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdGluc2V0IDAgMCAwIDFweCAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9LFxuXHRcdFx0MCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQnV0dG9uQ29udGVudFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogMTtcbmA7XG5cbmNvbnN0IGlzSWNvblN0eWxlcyA9ICgge1xuXHRzaXplID0gJ2RlZmF1bHQnLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdzaXplJyA+ICkgPT4ge1xuXHRjb25zdCBpY29uQnV0dG9uU2l6ZXMgPSB7XG5cdFx0ZGVmYXVsdDogJzMwcHgnLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogJzMycHgnLFxuXHR9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdFx0aGVpZ2h0OiAkeyBpY29uQnV0dG9uU2l6ZXNbIHNpemUgXSB9O1xuXHRcdGFzcGVjdC1yYXRpbzogMTtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0YDtcbn07XG4iXX0= */"); 30938 var ButtonContentView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 30939 target: "et6ln9s0" 30940 } : { 30941 target: "et6ln9s0", 30942 label: "ButtonContentView" 30943 })("display:flex;font-size:", config_values_default.fontSize, ";line-height:1;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRzJDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7XG5cdFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLFxuXHRUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsXG59IGZyb20gJy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IExhYmVsVmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRtYXgtd2lkdGg6IDEwMCU7XG5cdG1pbi13aWR0aDogMDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuZXhwb3J0IGNvbnN0IGxhYmVsQmxvY2sgPSBjc3NgXG5cdGZsZXg6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgYnV0dG9uVmlldyA9ICgge1xuXHRpc0Rlc2VsZWN0YWJsZSxcblx0aXNJY29uLFxuXHRpc1ByZXNzZWQsXG5cdHNpemUsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ2lzRGVzZWxlY3RhYmxlJyB8ICdzaXplJyA+ICZcblx0UGljazwgVG9nZ2xlR3JvdXBDb250cm9sT3B0aW9uQmFzZVByb3BzLCAnaXNJY29uJyA+ICYge1xuXHRcdGlzUHJlc3NlZD86IGJvb2xlYW47XG5cdH0gKSA9PiBjc3NgXG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGFwcGVhcmFuY2U6IG5vbmU7XG5cdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRib3JkZXI6IG5vbmU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogZmxleDtcblx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cdGhlaWdodDogMTAwJTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdGxpbmUtaGVpZ2h0OiAxMDAlO1xuXHRvdXRsaW5lOiBub25lO1xuXHRwYWRkaW5nOiAwIDEycHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0dGV4dC1hbGlnbjogY2VudGVyO1xuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0YmFja2dyb3VuZCAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uRmFzdCB9IGxpbmVhcixcblx0XHRcdGNvbG9yICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Zm9udC13ZWlnaHQgNjBtcyBsaW5lYXI7XG5cdH1cblx0dXNlci1zZWxlY3Q6IG5vbmU7XG5cdHdpZHRoOiAxMDAlO1xuXHR6LWluZGV4OiAyO1xuXG5cdCY6Oi1tb3otZm9jdXMtaW5uZXIge1xuXHRcdGJvcmRlcjogMDtcblx0fVxuXG5cdCZbZGlzYWJsZWRdIHtcblx0XHRvcGFjaXR5OiAwLjQ7XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHR9XG5cblx0JjphY3RpdmUge1xuXHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH07XG5cdH1cblxuXHQkeyBpc0Rlc2VsZWN0YWJsZSAmJiBkZXNlbGVjdGFibGUgfVxuXHQkeyBpc0ljb24gJiYgaXNJY29uU3R5bGVzKCB7IHNpemUgfSApIH1cblx0JHsgaXNQcmVzc2VkICYmIHByZXNzZWQgfVxuYDtcblxuY29uc3QgcHJlc3NlZCA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGRlc2VsZWN0YWJsZSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cblx0Jjpmb2N1cyB7XG5cdFx0Ym94LXNoYWRvdzpcblx0XHRcdGluc2V0IDAgMCAwIDFweCAkeyBDT0xPUlMudWkuYmFja2dyb3VuZCB9LFxuXHRcdFx0MCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQnV0dG9uQ29udGVudFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogMTtcbmA7XG5cbmNvbnN0IGlzSWNvblN0eWxlcyA9ICgge1xuXHRzaXplID0gJ2RlZmF1bHQnLFxufTogUGljazwgVG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsICdzaXplJyA+ICkgPT4ge1xuXHRjb25zdCBpY29uQnV0dG9uU2l6ZXMgPSB7XG5cdFx0ZGVmYXVsdDogJzMwcHgnLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogJzMycHgnLFxuXHR9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdFx0aGVpZ2h0OiAkeyBpY29uQnV0dG9uU2l6ZXNbIHNpemUgXSB9O1xuXHRcdGFzcGVjdC1yYXRpbzogMTtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0YDtcbn07XG4iXX0= */")); 30944 var isIconStyles = ({ 30945 size: size3 = "default" 30946 }) => { 30947 const iconButtonSizes = { 30948 default: "30px", 30949 "__unstable-large": "32px" 30950 }; 30951 return /* @__PURE__ */ css("color:", COLORS.theme.foreground, ";height:", iconButtonSizes[size3], ";aspect-ratio:1;padding-left:0;padding-right:0;" + (false ? "" : ";label:isIconStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpSFciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHtcblx0VG9nZ2xlR3JvdXBDb250cm9sUHJvcHMsXG5cdFRvZ2dsZUdyb3VwQ29udHJvbE9wdGlvbkJhc2VQcm9wcyxcbn0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgTGFiZWxWaWV3ID0gc3R5bGVkLmRpdmBcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdG1heC13aWR0aDogMTAwJTtcblx0bWluLXdpZHRoOiAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgbGFiZWxCbG9jayA9IGNzc2Bcblx0ZmxleDogMTtcbmA7XG5cbmV4cG9ydCBjb25zdCBidXR0b25WaWV3ID0gKCB7XG5cdGlzRGVzZWxlY3RhYmxlLFxuXHRpc0ljb24sXG5cdGlzUHJlc3NlZCxcblx0c2l6ZSxcbn06IFBpY2s8IFRvZ2dsZUdyb3VwQ29udHJvbFByb3BzLCAnaXNEZXNlbGVjdGFibGUnIHwgJ3NpemUnID4gJlxuXHRQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xPcHRpb25CYXNlUHJvcHMsICdpc0ljb24nID4gJiB7XG5cdFx0aXNQcmVzc2VkPzogYm9vbGVhbjtcblx0fSApID0+IGNzc2Bcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0YXBwZWFyYW5jZTogbm9uZTtcblx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdGJvcmRlcjogbm9uZTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDcwMCBdIH07XG5cdGZpbGw6IGN1cnJlbnRDb2xvcjtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0aGVpZ2h0OiAxMDAlO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblx0bGluZS1oZWlnaHQ6IDEwMCU7XG5cdG91dGxpbmU6IG5vbmU7XG5cdHBhZGRpbmc6IDAgMTJweDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdHRyYW5zaXRpb246XG5cdFx0XHRiYWNrZ3JvdW5kICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb25GYXN0IH0gbGluZWFyLFxuXHRcdFx0Y29sb3IgJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBsaW5lYXIsXG5cdFx0XHRmb250LXdlaWdodCA2MG1zIGxpbmVhcjtcblx0fVxuXHR1c2VyLXNlbGVjdDogbm9uZTtcblx0d2lkdGg6IDEwMCU7XG5cdHotaW5kZXg6IDI7XG5cblx0Jjo6LW1vei1mb2N1cy1pbm5lciB7XG5cdFx0Ym9yZGVyOiAwO1xuXHR9XG5cblx0JltkaXNhYmxlZF0ge1xuXHRcdG9wYWNpdHk6IDAuNDtcblx0XHRjdXJzb3I6IGRlZmF1bHQ7XG5cdH1cblxuXHQmOmFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnVpLmJhY2tncm91bmQgfTtcblx0fVxuXG5cdCR7IGlzRGVzZWxlY3RhYmxlICYmIGRlc2VsZWN0YWJsZSB9XG5cdCR7IGlzSWNvbiAmJiBpc0ljb25TdHlsZXMoIHsgc2l6ZSB9ICkgfVxuXHQkeyBpc1ByZXNzZWQgJiYgcHJlc3NlZCB9XG5gO1xuXG5jb25zdCBwcmVzc2VkID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmRJbnZlcnRlZCB9O1xuXG5cdCY6YWN0aXZlIHtcblx0XHRiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgZGVzZWxlY3RhYmxlID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblxuXHQmOmZvY3VzIHtcblx0XHRib3gtc2hhZG93OlxuXHRcdFx0aW5zZXQgMCAwIDAgMXB4ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH0sXG5cdFx0XHQwIDAgMCAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBCdXR0b25Db250ZW50VmlldyA9IHN0eWxlZC5kaXZgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGxpbmUtaGVpZ2h0OiAxO1xuYDtcblxuY29uc3QgaXNJY29uU3R5bGVzID0gKCB7XG5cdHNpemUgPSAnZGVmYXVsdCcsXG59OiBQaWNrPCBUb2dnbGVHcm91cENvbnRyb2xQcm9wcywgJ3NpemUnID4gKSA9PiB7XG5cdGNvbnN0IGljb25CdXR0b25TaXplcyA9IHtcblx0XHRkZWZhdWx0OiAnMzBweCcsXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiAnMzJweCcsXG5cdH07XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IGljb25CdXR0b25TaXplc1sgc2l6ZSBdIH07XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmctbGVmdDogMDtcblx0XHRwYWRkaW5nLXJpZ2h0OiAwO1xuXHRgO1xufTtcbiJdfQ== */"); 30952 }; 30953 30954 // packages/components/build-module/toggle-group-control/toggle-group-control-option-base/component.js 30955 var import_jsx_runtime118 = __toESM(require_jsx_runtime()); 30956 var { 30957 ButtonContentView: ButtonContentView2, 30958 LabelView: LabelView2 30959 } = styles_exports6; 30960 var WithToolTip = ({ 30961 showTooltip, 30962 text, 30963 children 30964 }) => { 30965 if (showTooltip && text) { 30966 return /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(tooltip_default, { 30967 text, 30968 placement: "top", 30969 children 30970 }); 30971 } 30972 return /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(import_jsx_runtime118.Fragment, { 30973 children 30974 }); 30975 }; 30976 function ToggleGroupControlOptionBase(props, forwardedRef) { 30977 const toggleGroupControlContext = useToggleGroupControlContext(); 30978 const id3 = (0, import_compose29.useInstanceId)(ToggleGroupControlOptionBase, toggleGroupControlContext.baseId || "toggle-group-control-option-base"); 30979 const buttonProps = useContextSystem({ 30980 ...props, 30981 id: id3 30982 }, "ToggleGroupControlOptionBase"); 30983 const { 30984 isBlock = false, 30985 isDeselectable = false, 30986 size: size3 = "default" 30987 } = toggleGroupControlContext; 30988 const { 30989 className: className2, 30990 isIcon = false, 30991 value, 30992 children, 30993 showTooltip = false, 30994 disabled, 30995 ...otherButtonProps 30996 } = buttonProps; 30997 const isPressed = toggleGroupControlContext.value === value; 30998 const cx3 = useCx(); 30999 const labelViewClasses = (0, import_element64.useMemo)(() => cx3(isBlock && labelBlock), [cx3, isBlock]); 31000 const itemClasses = (0, import_element64.useMemo)(() => cx3(buttonView({ 31001 isDeselectable, 31002 isIcon, 31003 isPressed, 31004 size: size3 31005 }), className2), [cx3, isDeselectable, isIcon, isPressed, size3, className2]); 31006 const buttonOnClick = () => { 31007 if (isDeselectable && isPressed) { 31008 toggleGroupControlContext.setValue(void 0); 31009 } else { 31010 toggleGroupControlContext.setValue(value); 31011 } 31012 }; 31013 const commonProps = { 31014 ...otherButtonProps, 31015 className: itemClasses, 31016 "data-value": value, 31017 ref: forwardedRef 31018 }; 31019 const labelRef = (0, import_element64.useRef)(null); 31020 (0, import_element64.useLayoutEffect)(() => { 31021 if (isPressed && labelRef.current) { 31022 toggleGroupControlContext.setSelectedElement(labelRef.current); 31023 } 31024 }, [isPressed, toggleGroupControlContext]); 31025 return /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(LabelView2, { 31026 ref: labelRef, 31027 className: labelViewClasses, 31028 children: /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(WithToolTip, { 31029 showTooltip, 31030 text: otherButtonProps["aria-label"], 31031 children: isDeselectable ? /* @__PURE__ */ (0, import_jsx_runtime118.jsx)("button", { 31032 ...commonProps, 31033 disabled, 31034 "aria-pressed": isPressed, 31035 type: "button", 31036 onClick: buttonOnClick, 31037 children: /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(ButtonContentView2, { 31038 children 31039 }) 31040 }) : /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(Radio, { 31041 disabled, 31042 onFocusVisible: () => { 31043 const selectedValueIsEmpty = toggleGroupControlContext.value === null || toggleGroupControlContext.value === ""; 31044 if (!selectedValueIsEmpty || toggleGroupControlContext.activeItemIsNotFirstItem?.()) { 31045 toggleGroupControlContext.setValue(value); 31046 } 31047 }, 31048 render: /* @__PURE__ */ (0, import_jsx_runtime118.jsx)("button", { 31049 type: "button", 31050 ...commonProps 31051 }), 31052 value, 31053 children: /* @__PURE__ */ (0, import_jsx_runtime118.jsx)(ButtonContentView2, { 31054 children 31055 }) 31056 }) 31057 }) 31058 }); 31059 } 31060 var ConnectedToggleGroupControlOptionBase = contextConnect(ToggleGroupControlOptionBase, "ToggleGroupControlOptionBase"); 31061 var component_default13 = ConnectedToggleGroupControlOptionBase; 31062 31063 // packages/components/build-module/toggle-group-control/toggle-group-control-option/component.js 31064 var import_jsx_runtime119 = __toESM(require_jsx_runtime()); 31065 function UnforwardedToggleGroupControlOption(props, ref) { 31066 const { 31067 label, 31068 ...restProps 31069 } = props; 31070 const optionLabel = restProps["aria-label"] || label; 31071 return /* @__PURE__ */ (0, import_jsx_runtime119.jsx)(component_default13, { 31072 ...restProps, 31073 "aria-label": optionLabel, 31074 ref, 31075 children: label 31076 }); 31077 } 31078 var ToggleGroupControlOption = (0, import_element65.forwardRef)(UnforwardedToggleGroupControlOption); 31079 var component_default14 = ToggleGroupControlOption; 31080 31081 // packages/components/build-module/toggle-group-control/toggle-group-control-option-icon/component.js 31082 var import_element66 = __toESM(require_element()); 31083 var import_jsx_runtime120 = __toESM(require_jsx_runtime()); 31084 function UnforwardedToggleGroupControlOptionIcon(props, ref) { 31085 const { 31086 icon, 31087 label, 31088 ...restProps 31089 } = props; 31090 return /* @__PURE__ */ (0, import_jsx_runtime120.jsx)(component_default13, { 31091 ...restProps, 31092 isIcon: true, 31093 "aria-label": label, 31094 showTooltip: true, 31095 ref, 31096 children: /* @__PURE__ */ (0, import_jsx_runtime120.jsx)(icon_default3, { 31097 icon 31098 }) 31099 }); 31100 } 31101 var ToggleGroupControlOptionIcon = (0, import_element66.forwardRef)(UnforwardedToggleGroupControlOptionIcon); 31102 var component_default15 = ToggleGroupControlOptionIcon; 31103 31104 // packages/components/build-module/border-control/border-control-style-picker/component.js 31105 var import_jsx_runtime121 = __toESM(require_jsx_runtime()); 31106 var BORDER_STYLES = [{ 31107 label: (0, import_i18n11.__)("Solid"), 31108 icon: line_solid_default, 31109 value: "solid" 31110 }, { 31111 label: (0, import_i18n11.__)("Dashed"), 31112 icon: line_dashed_default, 31113 value: "dashed" 31114 }, { 31115 label: (0, import_i18n11.__)("Dotted"), 31116 icon: line_dotted_default, 31117 value: "dotted" 31118 }]; 31119 function UnconnectedBorderControlStylePicker({ 31120 onChange, 31121 ...restProps 31122 }, forwardedRef) { 31123 return /* @__PURE__ */ (0, import_jsx_runtime121.jsx)(component_default12, { 31124 __next40pxDefaultSize: true, 31125 ref: forwardedRef, 31126 isDeselectable: true, 31127 onChange: (value) => { 31128 onChange?.(value); 31129 }, 31130 ...restProps, 31131 children: BORDER_STYLES.map((borderStyle) => /* @__PURE__ */ (0, import_jsx_runtime121.jsx)(component_default15, { 31132 value: borderStyle.value, 31133 icon: borderStyle.icon, 31134 label: borderStyle.label 31135 }, borderStyle.value)) 31136 }); 31137 } 31138 var BorderControlStylePicker = contextConnect(UnconnectedBorderControlStylePicker, "BorderControlStylePicker"); 31139 var component_default16 = BorderControlStylePicker; 31140 31141 // packages/components/build-module/color-indicator/index.js 31142 var import_element67 = __toESM(require_element()); 31143 var import_jsx_runtime122 = __toESM(require_jsx_runtime()); 31144 function UnforwardedColorIndicator(props, forwardedRef) { 31145 const { 31146 className: className2, 31147 colorValue, 31148 ...additionalProps 31149 } = props; 31150 return /* @__PURE__ */ (0, import_jsx_runtime122.jsx)("span", { 31151 className: clsx_default("component-color-indicator", className2), 31152 style: { 31153 background: colorValue 31154 }, 31155 ref: forwardedRef, 31156 ...additionalProps 31157 }); 31158 } 31159 var ColorIndicator = (0, import_element67.forwardRef)(UnforwardedColorIndicator); 31160 var color_indicator_default = ColorIndicator; 31161 31162 // node_modules/colord/plugins/a11y.mjs 31163 var o2 = function(o4) { 31164 var t4 = o4 / 255; 31165 return t4 < 0.04045 ? t4 / 12.92 : Math.pow((t4 + 0.055) / 1.055, 2.4); 31166 }; 31167 var t2 = function(t4) { 31168 return 0.2126 * o2(t4.r) + 0.7152 * o2(t4.g) + 0.0722 * o2(t4.b); 31169 }; 31170 function a11y_default(o4) { 31171 o4.prototype.luminance = function() { 31172 return o5 = t2(this.rgba), void 0 === (r4 = 2) && (r4 = 0), void 0 === n3 && (n3 = Math.pow(10, r4)), Math.round(n3 * o5) / n3 + 0; 31173 var o5, r4, n3; 31174 }, o4.prototype.contrast = function(r4) { 31175 void 0 === r4 && (r4 = "#FFF"); 31176 var n3, a3, i3, e3, v3, u3, d3, c3 = r4 instanceof o4 ? r4 : new o4(r4); 31177 return e3 = this.rgba, v3 = c3.toRgb(), u3 = t2(e3), d3 = t2(v3), n3 = u3 > d3 ? (u3 + 0.05) / (d3 + 0.05) : (d3 + 0.05) / (u3 + 0.05), void 0 === (a3 = 2) && (a3 = 0), void 0 === i3 && (i3 = Math.pow(10, a3)), Math.floor(i3 * n3) / i3 + 0; 31178 }, o4.prototype.isReadable = function(o5, t4) { 31179 return void 0 === o5 && (o5 = "#FFF"), void 0 === t4 && (t4 = {}), this.contrast(o5) >= (e3 = void 0 === (i3 = (r4 = t4).size) ? "normal" : i3, "AAA" === (a3 = void 0 === (n3 = r4.level) ? "AA" : n3) && "normal" === e3 ? 7 : "AA" === a3 && "large" === e3 ? 3 : 4.5); 31180 var r4, n3, a3, i3, e3; 31181 }; 31182 } 31183 31184 // packages/components/build-module/color-palette/index.js 31185 var import_compose37 = __toESM(require_compose()); 31186 var import_i18n20 = __toESM(require_i18n()); 31187 var import_element82 = __toESM(require_element()); 31188 31189 // packages/components/build-module/dropdown/index.js 31190 var import_element68 = __toESM(require_element()); 31191 var import_compose30 = __toESM(require_compose()); 31192 var import_deprecated7 = __toESM(require_deprecated()); 31193 var import_jsx_runtime123 = __toESM(require_jsx_runtime()); 31194 var UnconnectedDropdown = (props, forwardedRef) => { 31195 const { 31196 renderContent, 31197 renderToggle, 31198 className: className2, 31199 contentClassName, 31200 expandOnMobile, 31201 headerTitle, 31202 focusOnMount, 31203 popoverProps, 31204 onClose, 31205 onToggle, 31206 style: style2, 31207 open, 31208 defaultOpen, 31209 // Deprecated props 31210 position: position2, 31211 // From context system 31212 variant 31213 } = useContextSystem(props, "Dropdown"); 31214 if (position2 !== void 0) { 31215 (0, import_deprecated7.default)("`position` prop in wp.components.Dropdown", { 31216 since: "6.2", 31217 alternative: "`popoverProps.placement` prop", 31218 hint: "Note that the `position` prop will override any values passed through the `popoverProps.placement` prop." 31219 }); 31220 } 31221 const [fallbackPopoverAnchor, setFallbackPopoverAnchor] = (0, import_element68.useState)(null); 31222 const containerRef = (0, import_element68.useRef)(); 31223 const [isOpen, setIsOpen] = useControlledValue({ 31224 defaultValue: defaultOpen, 31225 value: open, 31226 onChange: onToggle 31227 }); 31228 function closeIfFocusOutside() { 31229 if (!containerRef.current) { 31230 return; 31231 } 31232 const { 31233 ownerDocument 31234 } = containerRef.current; 31235 const dialog = ownerDocument?.activeElement?.closest('[role="dialog"]'); 31236 if (!containerRef.current.contains(ownerDocument.activeElement) && (!dialog || dialog.contains(containerRef.current))) { 31237 close(); 31238 } 31239 } 31240 function close() { 31241 onClose?.(); 31242 setIsOpen(false); 31243 } 31244 const args = { 31245 isOpen: !!isOpen, 31246 onToggle: () => setIsOpen(!isOpen), 31247 onClose: close 31248 }; 31249 const popoverPropsHaveAnchor = !!popoverProps?.anchor || // Note: `anchorRef`, `getAnchorRect` and `anchorRect` are deprecated and 31250 // be removed from `Popover` from WordPress 6.3 31251 !!popoverProps?.anchorRef || !!popoverProps?.getAnchorRect || !!popoverProps?.anchorRect; 31252 return /* @__PURE__ */ (0, import_jsx_runtime123.jsxs)("div", { 31253 className: className2, 31254 ref: (0, import_compose30.useMergeRefs)([containerRef, forwardedRef, setFallbackPopoverAnchor]), 31255 tabIndex: -1, 31256 style: style2, 31257 children: [renderToggle(args), isOpen && /* @__PURE__ */ (0, import_jsx_runtime123.jsx)(popover_default, { 31258 position: position2, 31259 onClose: close, 31260 onFocusOutside: closeIfFocusOutside, 31261 expandOnMobile, 31262 headerTitle, 31263 focusOnMount, 31264 offset: 13, 31265 anchor: !popoverPropsHaveAnchor ? fallbackPopoverAnchor : void 0, 31266 variant, 31267 ...popoverProps, 31268 className: clsx_default("components-dropdown__content", popoverProps?.className, contentClassName), 31269 children: renderContent(args) 31270 })] 31271 }); 31272 }; 31273 var Dropdown = contextConnect(UnconnectedDropdown, "Dropdown"); 31274 var dropdown_default = Dropdown; 31275 31276 // packages/components/build-module/color-picker/component.js 31277 var import_element77 = __toESM(require_element()); 31278 var import_compose34 = __toESM(require_compose()); 31279 var import_i18n16 = __toESM(require_i18n()); 31280 31281 // packages/components/build-module/select-control/index.js 31282 var import_compose31 = __toESM(require_compose()); 31283 var import_element69 = __toESM(require_element()); 31284 31285 // packages/components/build-module/select-control/styles/select-control-styles.js 31286 function _EMOTION_STRINGIFIED_CSS_ERROR__12() { 31287 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 31288 } 31289 var disabledStyles2 = ({ 31290 disabled 31291 }) => { 31292 if (!disabled) { 31293 return ""; 31294 } 31295 return /* @__PURE__ */ css("color:", COLORS.ui.textDisabled, ";cursor:default;" + (false ? "" : ";label:disabledStyles;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQlciLCJmaWxlIjoic2VsZWN0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIHJ0bCwgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdENvbnRyb2xQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtc3VmZml4LXdyYXBwZXInO1xuaW1wb3J0IHsgZm9udFNpemVTdHlsZXMgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgSW5wdXRCYXNlIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtYmFzZSc7XG5cbmludGVyZmFjZSBTZWxlY3RQcm9wc1xuXHRleHRlbmRzIFBpY2s8XG5cdFx0U2VsZWN0Q29udHJvbFByb3BzLFxuXHRcdCdfX25leHQ0MHB4RGVmYXVsdFNpemUnIHwgJ2Rpc2FibGVkJyB8ICdtdWx0aXBsZScgfCAndmFyaWFudCdcblx0PiB7XG5cdC8vIFVzaW5nIGBzZWxlY3RTaXplYCBpbnN0ZWFkIG9mIGBzaXplYCB0byBhdm9pZCBhIHR5cGUgY29uZmxpY3Qgd2l0aCB0aGVcblx0Ly8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxuXHRzZWxlY3RTaXplPzogU2VsZWN0Q29udHJvbFByb3BzWyAnc2l6ZScgXTtcbn1cblxuY29uc3QgZGlzYWJsZWRTdHlsZXMgPSAoIHsgZGlzYWJsZWQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggISBkaXNhYmxlZCApIHtcblx0XHRyZXR1cm4gJyc7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkudGV4dERpc2FibGVkIH07XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHRgO1xufTtcblxuY29uc3QgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyA9ICggeyB2YXJpYW50IH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoIHZhcmlhbnQgPT09ICdtaW5pbWFsJyApIHtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdFx0YDtcblx0fVxuXG5cdHJldHVybiAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dEJhc2UgPSBzdHlsZWQoIElucHV0QmFzZSApYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXG5cdCR7IGRpc2FibGVkU3R5bGVzIH1cblx0JHsgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyB9XG5gO1xuXG5jb25zdCBzaXplU3R5bGVzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCBtdWx0aXBsZSApIHtcblx0XHQvLyBXaGVuIGBtdWx0aXBsZWAsIGp1c3QgdXNlIHRoZSBuYXRpdmUgYnJvd3NlciBzdHlsZXNcblx0XHQvLyB3aXRob3V0IHNldHRpbmcgZXhwbGljaXQgaGVpZ2h0LlxuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdGRlZmF1bHQ6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRzbWFsbDoge1xuXHRcdFx0aGVpZ2h0OiAyNCxcblx0XHRcdG1pbkhlaWdodDogMjQsXG5cdFx0XHRwYWRkaW5nVG9wOiAwLFxuXHRcdFx0cGFkZGluZ0JvdHRvbTogMCxcblx0XHR9LFxuXHRcdGNvbXBhY3Q6IHtcblx0XHRcdGhlaWdodDogMzIsXG5cdFx0XHRtaW5IZWlnaHQ6IDMyLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHNpemVzLmRlZmF1bHQgPSBzaXplcy5jb21wYWN0O1xuXHR9XG5cblx0Y29uc3Qgc3R5bGUgPSBzaXplc1sgc2VsZWN0U2l6ZSBdIHx8IHNpemVzLmRlZmF1bHQ7XG5cblx0cmV0dXJuIGNzcyggc3R5bGUgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGV2cm9uSWNvblNpemUgPSAxODtcblxuY29uc3Qgc2l6ZVBhZGRpbmdzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3QgcGFkZGluZyA9IHtcblx0XHRkZWZhdWx0OiBDT05GSUcuY29udHJvbFBhZGRpbmdYLFxuXHRcdHNtYWxsOiBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwsXG5cdFx0Y29tcGFjdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHBhZGRpbmcuZGVmYXVsdCA9IHBhZGRpbmcuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHNlbGVjdGVkUGFkZGluZyA9IHBhZGRpbmdbIHNlbGVjdFNpemUgXSB8fCBwYWRkaW5nLmRlZmF1bHQ7XG5cblx0cmV0dXJuIHJ0bCgge1xuXHRcdHBhZGRpbmdMZWZ0OiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0cGFkZGluZ1JpZ2h0OiBzZWxlY3RlZFBhZGRpbmcgKyBjaGV2cm9uSWNvblNpemUsXG5cdFx0Li4uKCBtdWx0aXBsZVxuXHRcdFx0PyB7XG5cdFx0XHRcdFx0cGFkZGluZ1RvcDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdFx0XHRcdHBhZGRpbmdCb3R0b206IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdCAgfVxuXHRcdFx0OiB7fSApLFxuXHR9ICk7XG59O1xuXG5jb25zdCBvdmVyZmxvd1N0eWxlcyA9ICggeyBtdWx0aXBsZSB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0cmV0dXJuIHtcblx0XHRvdmVyZmxvdzogbXVsdGlwbGUgPyAnYXV0bycgOiAnaGlkZGVuJyxcblx0fTtcbn07XG5cbmNvbnN0IHZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzcygge1xuXHRcdFx0ZmllbGRTaXppbmc6ICdjb250ZW50Jyxcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG4vLyBUT0RPOiBSZXNvbHZlIG5lZWQgdG8gdXNlICYmJiB0byBpbmNyZWFzZSBzcGVjaWZpY2l0eVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzE4NDgzXG5cbmV4cG9ydCBjb25zdCBTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0Ym94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xuXHRcdGNvbG9yOiBjdXJyZW50Q29sb3I7IC8vIE92ZXJyaWRlcyBob3Zlci9mb2N1cyBzdHlsZXMgaW4gZm9ybXMuY3NzXG5cdFx0Y3Vyc29yOiBpbmhlcml0O1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdG1hcmdpbjogMDtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRtYXgtd2lkdGg6IG5vbmU7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblxuXHRcdCR7IGZvbnRTaXplU3R5bGVzIH07XG5cdFx0JHsgc2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVQYWRkaW5ncyB9O1xuXHRcdCR7IG92ZXJmbG93U3R5bGVzIH1cblx0XHQkeyB2YXJpYW50U3R5bGVzIH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvd25BcnJvd1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIC0xICkgfTsgLy8gb3B0aWNhbGx5IGFkanVzdCB0aGUgaWNvblxuXHRsaW5lLWhlaWdodDogMDtcblxuXHRwYXRoIHtcblx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyV2l0aENsaWNrVGhyb3VnaCA9IHN0eWxlZChcblx0SW5wdXRDb250cm9sU3VmZml4V3JhcHBlclxuKWBcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQkeyBydGwoIHsgcmlnaHQ6IDAgfSApIH1cbmA7XG4iXX0= */"); 31296 }; 31297 var _ref23 = false ? { 31298 name: "1lv1yo7", 31299 styles: "display:inline-flex" 31300 } : { 31301 name: "siqiia-inputBaseVariantStyles", 31302 styles: "display:inline-flex;label:inputBaseVariantStyles;", 31303 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q1kiLCJmaWxlIjoic2VsZWN0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIHJ0bCwgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdENvbnRyb2xQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtc3VmZml4LXdyYXBwZXInO1xuaW1wb3J0IHsgZm9udFNpemVTdHlsZXMgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgSW5wdXRCYXNlIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtYmFzZSc7XG5cbmludGVyZmFjZSBTZWxlY3RQcm9wc1xuXHRleHRlbmRzIFBpY2s8XG5cdFx0U2VsZWN0Q29udHJvbFByb3BzLFxuXHRcdCdfX25leHQ0MHB4RGVmYXVsdFNpemUnIHwgJ2Rpc2FibGVkJyB8ICdtdWx0aXBsZScgfCAndmFyaWFudCdcblx0PiB7XG5cdC8vIFVzaW5nIGBzZWxlY3RTaXplYCBpbnN0ZWFkIG9mIGBzaXplYCB0byBhdm9pZCBhIHR5cGUgY29uZmxpY3Qgd2l0aCB0aGVcblx0Ly8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxuXHRzZWxlY3RTaXplPzogU2VsZWN0Q29udHJvbFByb3BzWyAnc2l6ZScgXTtcbn1cblxuY29uc3QgZGlzYWJsZWRTdHlsZXMgPSAoIHsgZGlzYWJsZWQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggISBkaXNhYmxlZCApIHtcblx0XHRyZXR1cm4gJyc7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkudGV4dERpc2FibGVkIH07XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHRgO1xufTtcblxuY29uc3QgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyA9ICggeyB2YXJpYW50IH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoIHZhcmlhbnQgPT09ICdtaW5pbWFsJyApIHtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdFx0YDtcblx0fVxuXG5cdHJldHVybiAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dEJhc2UgPSBzdHlsZWQoIElucHV0QmFzZSApYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXG5cdCR7IGRpc2FibGVkU3R5bGVzIH1cblx0JHsgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyB9XG5gO1xuXG5jb25zdCBzaXplU3R5bGVzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCBtdWx0aXBsZSApIHtcblx0XHQvLyBXaGVuIGBtdWx0aXBsZWAsIGp1c3QgdXNlIHRoZSBuYXRpdmUgYnJvd3NlciBzdHlsZXNcblx0XHQvLyB3aXRob3V0IHNldHRpbmcgZXhwbGljaXQgaGVpZ2h0LlxuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdGRlZmF1bHQ6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRzbWFsbDoge1xuXHRcdFx0aGVpZ2h0OiAyNCxcblx0XHRcdG1pbkhlaWdodDogMjQsXG5cdFx0XHRwYWRkaW5nVG9wOiAwLFxuXHRcdFx0cGFkZGluZ0JvdHRvbTogMCxcblx0XHR9LFxuXHRcdGNvbXBhY3Q6IHtcblx0XHRcdGhlaWdodDogMzIsXG5cdFx0XHRtaW5IZWlnaHQ6IDMyLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHNpemVzLmRlZmF1bHQgPSBzaXplcy5jb21wYWN0O1xuXHR9XG5cblx0Y29uc3Qgc3R5bGUgPSBzaXplc1sgc2VsZWN0U2l6ZSBdIHx8IHNpemVzLmRlZmF1bHQ7XG5cblx0cmV0dXJuIGNzcyggc3R5bGUgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGV2cm9uSWNvblNpemUgPSAxODtcblxuY29uc3Qgc2l6ZVBhZGRpbmdzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3QgcGFkZGluZyA9IHtcblx0XHRkZWZhdWx0OiBDT05GSUcuY29udHJvbFBhZGRpbmdYLFxuXHRcdHNtYWxsOiBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwsXG5cdFx0Y29tcGFjdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHBhZGRpbmcuZGVmYXVsdCA9IHBhZGRpbmcuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHNlbGVjdGVkUGFkZGluZyA9IHBhZGRpbmdbIHNlbGVjdFNpemUgXSB8fCBwYWRkaW5nLmRlZmF1bHQ7XG5cblx0cmV0dXJuIHJ0bCgge1xuXHRcdHBhZGRpbmdMZWZ0OiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0cGFkZGluZ1JpZ2h0OiBzZWxlY3RlZFBhZGRpbmcgKyBjaGV2cm9uSWNvblNpemUsXG5cdFx0Li4uKCBtdWx0aXBsZVxuXHRcdFx0PyB7XG5cdFx0XHRcdFx0cGFkZGluZ1RvcDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdFx0XHRcdHBhZGRpbmdCb3R0b206IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdCAgfVxuXHRcdFx0OiB7fSApLFxuXHR9ICk7XG59O1xuXG5jb25zdCBvdmVyZmxvd1N0eWxlcyA9ICggeyBtdWx0aXBsZSB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0cmV0dXJuIHtcblx0XHRvdmVyZmxvdzogbXVsdGlwbGUgPyAnYXV0bycgOiAnaGlkZGVuJyxcblx0fTtcbn07XG5cbmNvbnN0IHZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzcygge1xuXHRcdFx0ZmllbGRTaXppbmc6ICdjb250ZW50Jyxcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG4vLyBUT0RPOiBSZXNvbHZlIG5lZWQgdG8gdXNlICYmJiB0byBpbmNyZWFzZSBzcGVjaWZpY2l0eVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzE4NDgzXG5cbmV4cG9ydCBjb25zdCBTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0Ym94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xuXHRcdGNvbG9yOiBjdXJyZW50Q29sb3I7IC8vIE92ZXJyaWRlcyBob3Zlci9mb2N1cyBzdHlsZXMgaW4gZm9ybXMuY3NzXG5cdFx0Y3Vyc29yOiBpbmhlcml0O1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdG1hcmdpbjogMDtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRtYXgtd2lkdGg6IG5vbmU7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblxuXHRcdCR7IGZvbnRTaXplU3R5bGVzIH07XG5cdFx0JHsgc2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVQYWRkaW5ncyB9O1xuXHRcdCR7IG92ZXJmbG93U3R5bGVzIH1cblx0XHQkeyB2YXJpYW50U3R5bGVzIH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvd25BcnJvd1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIC0xICkgfTsgLy8gb3B0aWNhbGx5IGFkanVzdCB0aGUgaWNvblxuXHRsaW5lLWhlaWdodDogMDtcblxuXHRwYXRoIHtcblx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyV2l0aENsaWNrVGhyb3VnaCA9IHN0eWxlZChcblx0SW5wdXRDb250cm9sU3VmZml4V3JhcHBlclxuKWBcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQkeyBydGwoIHsgcmlnaHQ6IDAgfSApIH1cbmA7XG4iXX0= */", 31304 toString: _EMOTION_STRINGIFIED_CSS_ERROR__12 31305 }; 31306 var inputBaseVariantStyles = ({ 31307 variant 31308 }) => { 31309 if (variant === "minimal") { 31310 return _ref23; 31311 } 31312 return ""; 31313 }; 31314 var StyledInputBase = /* @__PURE__ */ emotion_styled_base_browser_esm_default(input_base_default, false ? { 31315 target: "e1mv6sxx3" 31316 } : { 31317 target: "e1mv6sxx3", 31318 label: "StyledInputBase" 31319 })("color:", COLORS.theme.foreground, ";cursor:pointer;", disabledStyles2, " ", inputBaseVariantStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQ2tEIiwiZmlsZSI6InNlbGVjdC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHR5cGUgeyBTZWxlY3RDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlciBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LXN1ZmZpeC13cmFwcGVyJztcbmltcG9ydCB7IGZvbnRTaXplU3R5bGVzIH0gZnJvbSAnLi4vLi4vaW5wdXQtY29udHJvbC9zdHlsZXMvaW5wdXQtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IElucHV0QmFzZSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LWJhc2UnO1xuXG5pbnRlcmZhY2UgU2VsZWN0UHJvcHNcblx0ZXh0ZW5kcyBQaWNrPFxuXHRcdFNlbGVjdENvbnRyb2xQcm9wcyxcblx0XHQnX19uZXh0NDBweERlZmF1bHRTaXplJyB8ICdkaXNhYmxlZCcgfCAnbXVsdGlwbGUnIHwgJ3ZhcmlhbnQnXG5cdD4ge1xuXHQvLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG5cdC8vIGBzaXplYCBIVE1MIGF0dHJpYnV0ZSBvZiB0aGUgYHNlbGVjdGAgZWxlbWVudC5cblx0c2VsZWN0U2l6ZT86IFNlbGVjdENvbnRyb2xQcm9wc1sgJ3NpemUnIF07XG59XG5cbmNvbnN0IGRpc2FibGVkU3R5bGVzID0gKCB7IGRpc2FibGVkIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoICEgZGlzYWJsZWQgKSB7XG5cdFx0cmV0dXJuICcnO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLnRleHREaXNhYmxlZCB9O1xuXHRcdGN1cnNvcjogZGVmYXVsdDtcblx0YDtcbn07XG5cbmNvbnN0IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzc2Bcblx0XHRcdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRcdGA7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSW5wdXRCYXNlID0gc3R5bGVkKCBJbnB1dEJhc2UgKWBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblxuXHQkeyBkaXNhYmxlZFN0eWxlcyB9XG5cdCR7IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgfVxuYDtcblxuY29uc3Qgc2l6ZVN0eWxlcyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggbXVsdGlwbGUgKSB7XG5cdFx0Ly8gV2hlbiBgbXVsdGlwbGVgLCBqdXN0IHVzZSB0aGUgbmF0aXZlIGJyb3dzZXIgc3R5bGVzXG5cdFx0Ly8gd2l0aG91dCBzZXR0aW5nIGV4cGxpY2l0IGhlaWdodC5cblx0XHRyZXR1cm47XG5cdH1cblxuXHRjb25zdCBzaXplcyA9IHtcblx0XHRkZWZhdWx0OiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0c21hbGw6IHtcblx0XHRcdGhlaWdodDogMjQsXG5cdFx0XHRtaW5IZWlnaHQ6IDI0LFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRjb21wYWN0OiB7XG5cdFx0XHRoZWlnaHQ6IDMyLFxuXHRcdFx0bWluSGVpZ2h0OiAzMixcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRzaXplcy5kZWZhdWx0ID0gc2l6ZXMuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHN0eWxlID0gc2l6ZXNbIHNlbGVjdFNpemUgXSB8fCBzaXplcy5kZWZhdWx0O1xuXG5cdHJldHVybiBjc3MoIHN0eWxlICk7XG59O1xuXG5leHBvcnQgY29uc3QgY2hldnJvbkljb25TaXplID0gMTg7XG5cbmNvbnN0IHNpemVQYWRkaW5ncyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHBhZGRpbmcgPSB7XG5cdFx0ZGVmYXVsdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0XHRzbWFsbDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdGNvbXBhY3Q6IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IENPTkZJRy5jb250cm9sUGFkZGluZ1gsXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRwYWRkaW5nLmRlZmF1bHQgPSBwYWRkaW5nLmNvbXBhY3Q7XG5cdH1cblxuXHRjb25zdCBzZWxlY3RlZFBhZGRpbmcgPSBwYWRkaW5nWyBzZWxlY3RTaXplIF0gfHwgcGFkZGluZy5kZWZhdWx0O1xuXG5cdHJldHVybiBydGwoIHtcblx0XHRwYWRkaW5nTGVmdDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdHBhZGRpbmdSaWdodDogc2VsZWN0ZWRQYWRkaW5nICsgY2hldnJvbkljb25TaXplLFxuXHRcdC4uLiggbXVsdGlwbGVcblx0XHRcdD8ge1xuXHRcdFx0XHRcdHBhZGRpbmdUb3A6IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdFx0XHRwYWRkaW5nQm90dG9tOiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0XHQgIH1cblx0XHRcdDoge30gKSxcblx0fSApO1xufTtcblxuY29uc3Qgb3ZlcmZsb3dTdHlsZXMgPSAoIHsgbXVsdGlwbGUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdHJldHVybiB7XG5cdFx0b3ZlcmZsb3c6IG11bHRpcGxlID8gJ2F1dG8nIDogJ2hpZGRlbicsXG5cdH07XG59O1xuXG5jb25zdCB2YXJpYW50U3R5bGVzID0gKCB7IHZhcmlhbnQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggdmFyaWFudCA9PT0gJ21pbmltYWwnICkge1xuXHRcdHJldHVybiBjc3MoIHtcblx0XHRcdGZpZWxkU2l6aW5nOiAnY29udGVudCcsXG5cdFx0fSApO1xuXHR9XG5cblx0cmV0dXJuICcnO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgU2VsZWN0ID0gc3R5bGVkLnNlbGVjdDwgU2VsZWN0UHJvcHMgPmBcblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IG5vbmUgIWltcG9ydGFudDtcblx0XHRjb2xvcjogY3VycmVudENvbG9yOyAvLyBPdmVycmlkZXMgaG92ZXIvZm9jdXMgc3R5bGVzIGluIGZvcm1zLmNzc1xuXHRcdGN1cnNvcjogaW5oZXJpdDtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRtYXJnaW46IDA7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdFx0bWF4LXdpZHRoOiBub25lO1xuXHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cblx0XHQkeyBmb250U2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVTdHlsZXMgfTtcblx0XHQkeyBzaXplUGFkZGluZ3MgfTtcblx0XHQkeyBvdmVyZmxvd1N0eWxlcyB9XG5cdFx0JHsgdmFyaWFudFN0eWxlcyB9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEb3duQXJyb3dXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAtMSApIH07IC8vIG9wdGljYWxseSBhZGp1c3QgdGhlIGljb25cblx0bGluZS1oZWlnaHQ6IDA7XG5cblx0cGF0aCB7XG5cdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlcldpdGhDbGlja1Rocm91Z2ggPSBzdHlsZWQoXG5cdElucHV0Q29udHJvbFN1ZmZpeFdyYXBwZXJcbilgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSB9XG5gO1xuIl19 */")); 31320 var sizeStyles2 = ({ 31321 __next40pxDefaultSize, 31322 multiple, 31323 selectSize = "default" 31324 }) => { 31325 if (multiple) { 31326 return; 31327 } 31328 const sizes = { 31329 default: { 31330 height: 40, 31331 minHeight: 40, 31332 paddingTop: 0, 31333 paddingBottom: 0 31334 }, 31335 small: { 31336 height: 24, 31337 minHeight: 24, 31338 paddingTop: 0, 31339 paddingBottom: 0 31340 }, 31341 compact: { 31342 height: 32, 31343 minHeight: 32, 31344 paddingTop: 0, 31345 paddingBottom: 0 31346 }, 31347 "__unstable-large": { 31348 height: 40, 31349 minHeight: 40, 31350 paddingTop: 0, 31351 paddingBottom: 0 31352 } 31353 }; 31354 if (!__next40pxDefaultSize) { 31355 sizes.default = sizes.compact; 31356 } 31357 const style2 = sizes[selectSize] || sizes.default; 31358 return /* @__PURE__ */ css(style2, false ? "" : ";label:sizeStyles;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtR1EiLCJmaWxlIjoic2VsZWN0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIHJ0bCwgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdENvbnRyb2xQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtc3VmZml4LXdyYXBwZXInO1xuaW1wb3J0IHsgZm9udFNpemVTdHlsZXMgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgSW5wdXRCYXNlIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtYmFzZSc7XG5cbmludGVyZmFjZSBTZWxlY3RQcm9wc1xuXHRleHRlbmRzIFBpY2s8XG5cdFx0U2VsZWN0Q29udHJvbFByb3BzLFxuXHRcdCdfX25leHQ0MHB4RGVmYXVsdFNpemUnIHwgJ2Rpc2FibGVkJyB8ICdtdWx0aXBsZScgfCAndmFyaWFudCdcblx0PiB7XG5cdC8vIFVzaW5nIGBzZWxlY3RTaXplYCBpbnN0ZWFkIG9mIGBzaXplYCB0byBhdm9pZCBhIHR5cGUgY29uZmxpY3Qgd2l0aCB0aGVcblx0Ly8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxuXHRzZWxlY3RTaXplPzogU2VsZWN0Q29udHJvbFByb3BzWyAnc2l6ZScgXTtcbn1cblxuY29uc3QgZGlzYWJsZWRTdHlsZXMgPSAoIHsgZGlzYWJsZWQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggISBkaXNhYmxlZCApIHtcblx0XHRyZXR1cm4gJyc7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkudGV4dERpc2FibGVkIH07XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHRgO1xufTtcblxuY29uc3QgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyA9ICggeyB2YXJpYW50IH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoIHZhcmlhbnQgPT09ICdtaW5pbWFsJyApIHtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdFx0YDtcblx0fVxuXG5cdHJldHVybiAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dEJhc2UgPSBzdHlsZWQoIElucHV0QmFzZSApYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXG5cdCR7IGRpc2FibGVkU3R5bGVzIH1cblx0JHsgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyB9XG5gO1xuXG5jb25zdCBzaXplU3R5bGVzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCBtdWx0aXBsZSApIHtcblx0XHQvLyBXaGVuIGBtdWx0aXBsZWAsIGp1c3QgdXNlIHRoZSBuYXRpdmUgYnJvd3NlciBzdHlsZXNcblx0XHQvLyB3aXRob3V0IHNldHRpbmcgZXhwbGljaXQgaGVpZ2h0LlxuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdGRlZmF1bHQ6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRzbWFsbDoge1xuXHRcdFx0aGVpZ2h0OiAyNCxcblx0XHRcdG1pbkhlaWdodDogMjQsXG5cdFx0XHRwYWRkaW5nVG9wOiAwLFxuXHRcdFx0cGFkZGluZ0JvdHRvbTogMCxcblx0XHR9LFxuXHRcdGNvbXBhY3Q6IHtcblx0XHRcdGhlaWdodDogMzIsXG5cdFx0XHRtaW5IZWlnaHQ6IDMyLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHNpemVzLmRlZmF1bHQgPSBzaXplcy5jb21wYWN0O1xuXHR9XG5cblx0Y29uc3Qgc3R5bGUgPSBzaXplc1sgc2VsZWN0U2l6ZSBdIHx8IHNpemVzLmRlZmF1bHQ7XG5cblx0cmV0dXJuIGNzcyggc3R5bGUgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGV2cm9uSWNvblNpemUgPSAxODtcblxuY29uc3Qgc2l6ZVBhZGRpbmdzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3QgcGFkZGluZyA9IHtcblx0XHRkZWZhdWx0OiBDT05GSUcuY29udHJvbFBhZGRpbmdYLFxuXHRcdHNtYWxsOiBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwsXG5cdFx0Y29tcGFjdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHBhZGRpbmcuZGVmYXVsdCA9IHBhZGRpbmcuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHNlbGVjdGVkUGFkZGluZyA9IHBhZGRpbmdbIHNlbGVjdFNpemUgXSB8fCBwYWRkaW5nLmRlZmF1bHQ7XG5cblx0cmV0dXJuIHJ0bCgge1xuXHRcdHBhZGRpbmdMZWZ0OiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0cGFkZGluZ1JpZ2h0OiBzZWxlY3RlZFBhZGRpbmcgKyBjaGV2cm9uSWNvblNpemUsXG5cdFx0Li4uKCBtdWx0aXBsZVxuXHRcdFx0PyB7XG5cdFx0XHRcdFx0cGFkZGluZ1RvcDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdFx0XHRcdHBhZGRpbmdCb3R0b206IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdCAgfVxuXHRcdFx0OiB7fSApLFxuXHR9ICk7XG59O1xuXG5jb25zdCBvdmVyZmxvd1N0eWxlcyA9ICggeyBtdWx0aXBsZSB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0cmV0dXJuIHtcblx0XHRvdmVyZmxvdzogbXVsdGlwbGUgPyAnYXV0bycgOiAnaGlkZGVuJyxcblx0fTtcbn07XG5cbmNvbnN0IHZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzcygge1xuXHRcdFx0ZmllbGRTaXppbmc6ICdjb250ZW50Jyxcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG4vLyBUT0RPOiBSZXNvbHZlIG5lZWQgdG8gdXNlICYmJiB0byBpbmNyZWFzZSBzcGVjaWZpY2l0eVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzE4NDgzXG5cbmV4cG9ydCBjb25zdCBTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0Ym94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xuXHRcdGNvbG9yOiBjdXJyZW50Q29sb3I7IC8vIE92ZXJyaWRlcyBob3Zlci9mb2N1cyBzdHlsZXMgaW4gZm9ybXMuY3NzXG5cdFx0Y3Vyc29yOiBpbmhlcml0O1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdG1hcmdpbjogMDtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRtYXgtd2lkdGg6IG5vbmU7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblxuXHRcdCR7IGZvbnRTaXplU3R5bGVzIH07XG5cdFx0JHsgc2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVQYWRkaW5ncyB9O1xuXHRcdCR7IG92ZXJmbG93U3R5bGVzIH1cblx0XHQkeyB2YXJpYW50U3R5bGVzIH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvd25BcnJvd1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIC0xICkgfTsgLy8gb3B0aWNhbGx5IGFkanVzdCB0aGUgaWNvblxuXHRsaW5lLWhlaWdodDogMDtcblxuXHRwYXRoIHtcblx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyV2l0aENsaWNrVGhyb3VnaCA9IHN0eWxlZChcblx0SW5wdXRDb250cm9sU3VmZml4V3JhcHBlclxuKWBcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQkeyBydGwoIHsgcmlnaHQ6IDAgfSApIH1cbmA7XG4iXX0= */"); 31359 }; 31360 var chevronIconSize = 18; 31361 var sizePaddings = ({ 31362 __next40pxDefaultSize, 31363 multiple, 31364 selectSize = "default" 31365 }) => { 31366 const padding2 = { 31367 default: config_values_default.controlPaddingX, 31368 small: config_values_default.controlPaddingXSmall, 31369 compact: config_values_default.controlPaddingXSmall, 31370 "__unstable-large": config_values_default.controlPaddingX 31371 }; 31372 if (!__next40pxDefaultSize) { 31373 padding2.default = padding2.compact; 31374 } 31375 const selectedPadding = padding2[selectSize] || padding2.default; 31376 return rtl({ 31377 paddingLeft: selectedPadding, 31378 paddingRight: selectedPadding + chevronIconSize, 31379 ...multiple ? { 31380 paddingTop: selectedPadding, 31381 paddingBottom: selectedPadding 31382 } : {} 31383 }); 31384 }; 31385 var overflowStyles = ({ 31386 multiple 31387 }) => { 31388 return { 31389 overflow: multiple ? "auto" : "hidden" 31390 }; 31391 }; 31392 var _ref5 = false ? { 31393 name: "n1jncc", 31394 styles: "field-sizing:content" 31395 } : { 31396 name: "1n00qi9-variantStyles", 31397 styles: "field-sizing:content;label:variantStyles;", 31398 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4SVMiLCJmaWxlIjoic2VsZWN0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIHJ0bCwgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdENvbnRyb2xQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtc3VmZml4LXdyYXBwZXInO1xuaW1wb3J0IHsgZm9udFNpemVTdHlsZXMgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgSW5wdXRCYXNlIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtYmFzZSc7XG5cbmludGVyZmFjZSBTZWxlY3RQcm9wc1xuXHRleHRlbmRzIFBpY2s8XG5cdFx0U2VsZWN0Q29udHJvbFByb3BzLFxuXHRcdCdfX25leHQ0MHB4RGVmYXVsdFNpemUnIHwgJ2Rpc2FibGVkJyB8ICdtdWx0aXBsZScgfCAndmFyaWFudCdcblx0PiB7XG5cdC8vIFVzaW5nIGBzZWxlY3RTaXplYCBpbnN0ZWFkIG9mIGBzaXplYCB0byBhdm9pZCBhIHR5cGUgY29uZmxpY3Qgd2l0aCB0aGVcblx0Ly8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxuXHRzZWxlY3RTaXplPzogU2VsZWN0Q29udHJvbFByb3BzWyAnc2l6ZScgXTtcbn1cblxuY29uc3QgZGlzYWJsZWRTdHlsZXMgPSAoIHsgZGlzYWJsZWQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggISBkaXNhYmxlZCApIHtcblx0XHRyZXR1cm4gJyc7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkudGV4dERpc2FibGVkIH07XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHRgO1xufTtcblxuY29uc3QgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyA9ICggeyB2YXJpYW50IH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoIHZhcmlhbnQgPT09ICdtaW5pbWFsJyApIHtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdFx0YDtcblx0fVxuXG5cdHJldHVybiAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dEJhc2UgPSBzdHlsZWQoIElucHV0QmFzZSApYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXG5cdCR7IGRpc2FibGVkU3R5bGVzIH1cblx0JHsgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyB9XG5gO1xuXG5jb25zdCBzaXplU3R5bGVzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCBtdWx0aXBsZSApIHtcblx0XHQvLyBXaGVuIGBtdWx0aXBsZWAsIGp1c3QgdXNlIHRoZSBuYXRpdmUgYnJvd3NlciBzdHlsZXNcblx0XHQvLyB3aXRob3V0IHNldHRpbmcgZXhwbGljaXQgaGVpZ2h0LlxuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdGRlZmF1bHQ6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRzbWFsbDoge1xuXHRcdFx0aGVpZ2h0OiAyNCxcblx0XHRcdG1pbkhlaWdodDogMjQsXG5cdFx0XHRwYWRkaW5nVG9wOiAwLFxuXHRcdFx0cGFkZGluZ0JvdHRvbTogMCxcblx0XHR9LFxuXHRcdGNvbXBhY3Q6IHtcblx0XHRcdGhlaWdodDogMzIsXG5cdFx0XHRtaW5IZWlnaHQ6IDMyLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHNpemVzLmRlZmF1bHQgPSBzaXplcy5jb21wYWN0O1xuXHR9XG5cblx0Y29uc3Qgc3R5bGUgPSBzaXplc1sgc2VsZWN0U2l6ZSBdIHx8IHNpemVzLmRlZmF1bHQ7XG5cblx0cmV0dXJuIGNzcyggc3R5bGUgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGV2cm9uSWNvblNpemUgPSAxODtcblxuY29uc3Qgc2l6ZVBhZGRpbmdzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3QgcGFkZGluZyA9IHtcblx0XHRkZWZhdWx0OiBDT05GSUcuY29udHJvbFBhZGRpbmdYLFxuXHRcdHNtYWxsOiBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwsXG5cdFx0Y29tcGFjdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHBhZGRpbmcuZGVmYXVsdCA9IHBhZGRpbmcuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHNlbGVjdGVkUGFkZGluZyA9IHBhZGRpbmdbIHNlbGVjdFNpemUgXSB8fCBwYWRkaW5nLmRlZmF1bHQ7XG5cblx0cmV0dXJuIHJ0bCgge1xuXHRcdHBhZGRpbmdMZWZ0OiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0cGFkZGluZ1JpZ2h0OiBzZWxlY3RlZFBhZGRpbmcgKyBjaGV2cm9uSWNvblNpemUsXG5cdFx0Li4uKCBtdWx0aXBsZVxuXHRcdFx0PyB7XG5cdFx0XHRcdFx0cGFkZGluZ1RvcDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdFx0XHRcdHBhZGRpbmdCb3R0b206IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdCAgfVxuXHRcdFx0OiB7fSApLFxuXHR9ICk7XG59O1xuXG5jb25zdCBvdmVyZmxvd1N0eWxlcyA9ICggeyBtdWx0aXBsZSB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0cmV0dXJuIHtcblx0XHRvdmVyZmxvdzogbXVsdGlwbGUgPyAnYXV0bycgOiAnaGlkZGVuJyxcblx0fTtcbn07XG5cbmNvbnN0IHZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzcygge1xuXHRcdFx0ZmllbGRTaXppbmc6ICdjb250ZW50Jyxcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG4vLyBUT0RPOiBSZXNvbHZlIG5lZWQgdG8gdXNlICYmJiB0byBpbmNyZWFzZSBzcGVjaWZpY2l0eVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzE4NDgzXG5cbmV4cG9ydCBjb25zdCBTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0Ym94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xuXHRcdGNvbG9yOiBjdXJyZW50Q29sb3I7IC8vIE92ZXJyaWRlcyBob3Zlci9mb2N1cyBzdHlsZXMgaW4gZm9ybXMuY3NzXG5cdFx0Y3Vyc29yOiBpbmhlcml0O1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdG1hcmdpbjogMDtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRtYXgtd2lkdGg6IG5vbmU7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblxuXHRcdCR7IGZvbnRTaXplU3R5bGVzIH07XG5cdFx0JHsgc2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVQYWRkaW5ncyB9O1xuXHRcdCR7IG92ZXJmbG93U3R5bGVzIH1cblx0XHQkeyB2YXJpYW50U3R5bGVzIH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvd25BcnJvd1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIC0xICkgfTsgLy8gb3B0aWNhbGx5IGFkanVzdCB0aGUgaWNvblxuXHRsaW5lLWhlaWdodDogMDtcblxuXHRwYXRoIHtcblx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyV2l0aENsaWNrVGhyb3VnaCA9IHN0eWxlZChcblx0SW5wdXRDb250cm9sU3VmZml4V3JhcHBlclxuKWBcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQkeyBydGwoIHsgcmlnaHQ6IDAgfSApIH1cbmA7XG4iXX0= */", 31399 toString: _EMOTION_STRINGIFIED_CSS_ERROR__12 31400 }; 31401 var variantStyles = ({ 31402 variant 31403 }) => { 31404 if (variant === "minimal") { 31405 return _ref5; 31406 } 31407 return ""; 31408 }; 31409 var Select3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("select", false ? { 31410 target: "e1mv6sxx2" 31411 } : { 31412 target: "e1mv6sxx2", 31413 label: "Select" 31414 })("&&&{appearance:none;background:transparent;box-sizing:border-box;border:none;box-shadow:none!important;color:currentColor;cursor:inherit;display:block;font-family:inherit;margin:0;width:100%;max-width:none;white-space:nowrap;text-overflow:ellipsis;", fontSizeStyles, ";", sizeStyles2, ";", sizePaddings, ";", overflowStyles, " ", variantStyles, ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5SmtEIiwiZmlsZSI6InNlbGVjdC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHR5cGUgeyBTZWxlY3RDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlciBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LXN1ZmZpeC13cmFwcGVyJztcbmltcG9ydCB7IGZvbnRTaXplU3R5bGVzIH0gZnJvbSAnLi4vLi4vaW5wdXQtY29udHJvbC9zdHlsZXMvaW5wdXQtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IElucHV0QmFzZSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LWJhc2UnO1xuXG5pbnRlcmZhY2UgU2VsZWN0UHJvcHNcblx0ZXh0ZW5kcyBQaWNrPFxuXHRcdFNlbGVjdENvbnRyb2xQcm9wcyxcblx0XHQnX19uZXh0NDBweERlZmF1bHRTaXplJyB8ICdkaXNhYmxlZCcgfCAnbXVsdGlwbGUnIHwgJ3ZhcmlhbnQnXG5cdD4ge1xuXHQvLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG5cdC8vIGBzaXplYCBIVE1MIGF0dHJpYnV0ZSBvZiB0aGUgYHNlbGVjdGAgZWxlbWVudC5cblx0c2VsZWN0U2l6ZT86IFNlbGVjdENvbnRyb2xQcm9wc1sgJ3NpemUnIF07XG59XG5cbmNvbnN0IGRpc2FibGVkU3R5bGVzID0gKCB7IGRpc2FibGVkIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoICEgZGlzYWJsZWQgKSB7XG5cdFx0cmV0dXJuICcnO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLnRleHREaXNhYmxlZCB9O1xuXHRcdGN1cnNvcjogZGVmYXVsdDtcblx0YDtcbn07XG5cbmNvbnN0IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzc2Bcblx0XHRcdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRcdGA7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSW5wdXRCYXNlID0gc3R5bGVkKCBJbnB1dEJhc2UgKWBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblxuXHQkeyBkaXNhYmxlZFN0eWxlcyB9XG5cdCR7IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgfVxuYDtcblxuY29uc3Qgc2l6ZVN0eWxlcyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggbXVsdGlwbGUgKSB7XG5cdFx0Ly8gV2hlbiBgbXVsdGlwbGVgLCBqdXN0IHVzZSB0aGUgbmF0aXZlIGJyb3dzZXIgc3R5bGVzXG5cdFx0Ly8gd2l0aG91dCBzZXR0aW5nIGV4cGxpY2l0IGhlaWdodC5cblx0XHRyZXR1cm47XG5cdH1cblxuXHRjb25zdCBzaXplcyA9IHtcblx0XHRkZWZhdWx0OiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0c21hbGw6IHtcblx0XHRcdGhlaWdodDogMjQsXG5cdFx0XHRtaW5IZWlnaHQ6IDI0LFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRjb21wYWN0OiB7XG5cdFx0XHRoZWlnaHQ6IDMyLFxuXHRcdFx0bWluSGVpZ2h0OiAzMixcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRzaXplcy5kZWZhdWx0ID0gc2l6ZXMuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHN0eWxlID0gc2l6ZXNbIHNlbGVjdFNpemUgXSB8fCBzaXplcy5kZWZhdWx0O1xuXG5cdHJldHVybiBjc3MoIHN0eWxlICk7XG59O1xuXG5leHBvcnQgY29uc3QgY2hldnJvbkljb25TaXplID0gMTg7XG5cbmNvbnN0IHNpemVQYWRkaW5ncyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHBhZGRpbmcgPSB7XG5cdFx0ZGVmYXVsdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0XHRzbWFsbDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdGNvbXBhY3Q6IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IENPTkZJRy5jb250cm9sUGFkZGluZ1gsXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRwYWRkaW5nLmRlZmF1bHQgPSBwYWRkaW5nLmNvbXBhY3Q7XG5cdH1cblxuXHRjb25zdCBzZWxlY3RlZFBhZGRpbmcgPSBwYWRkaW5nWyBzZWxlY3RTaXplIF0gfHwgcGFkZGluZy5kZWZhdWx0O1xuXG5cdHJldHVybiBydGwoIHtcblx0XHRwYWRkaW5nTGVmdDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdHBhZGRpbmdSaWdodDogc2VsZWN0ZWRQYWRkaW5nICsgY2hldnJvbkljb25TaXplLFxuXHRcdC4uLiggbXVsdGlwbGVcblx0XHRcdD8ge1xuXHRcdFx0XHRcdHBhZGRpbmdUb3A6IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdFx0XHRwYWRkaW5nQm90dG9tOiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0XHQgIH1cblx0XHRcdDoge30gKSxcblx0fSApO1xufTtcblxuY29uc3Qgb3ZlcmZsb3dTdHlsZXMgPSAoIHsgbXVsdGlwbGUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdHJldHVybiB7XG5cdFx0b3ZlcmZsb3c6IG11bHRpcGxlID8gJ2F1dG8nIDogJ2hpZGRlbicsXG5cdH07XG59O1xuXG5jb25zdCB2YXJpYW50U3R5bGVzID0gKCB7IHZhcmlhbnQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggdmFyaWFudCA9PT0gJ21pbmltYWwnICkge1xuXHRcdHJldHVybiBjc3MoIHtcblx0XHRcdGZpZWxkU2l6aW5nOiAnY29udGVudCcsXG5cdFx0fSApO1xuXHR9XG5cblx0cmV0dXJuICcnO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgU2VsZWN0ID0gc3R5bGVkLnNlbGVjdDwgU2VsZWN0UHJvcHMgPmBcblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IG5vbmUgIWltcG9ydGFudDtcblx0XHRjb2xvcjogY3VycmVudENvbG9yOyAvLyBPdmVycmlkZXMgaG92ZXIvZm9jdXMgc3R5bGVzIGluIGZvcm1zLmNzc1xuXHRcdGN1cnNvcjogaW5oZXJpdDtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRtYXJnaW46IDA7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdFx0bWF4LXdpZHRoOiBub25lO1xuXHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cblx0XHQkeyBmb250U2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVTdHlsZXMgfTtcblx0XHQkeyBzaXplUGFkZGluZ3MgfTtcblx0XHQkeyBvdmVyZmxvd1N0eWxlcyB9XG5cdFx0JHsgdmFyaWFudFN0eWxlcyB9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEb3duQXJyb3dXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAtMSApIH07IC8vIG9wdGljYWxseSBhZGp1c3QgdGhlIGljb25cblx0bGluZS1oZWlnaHQ6IDA7XG5cblx0cGF0aCB7XG5cdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlcldpdGhDbGlja1Rocm91Z2ggPSBzdHlsZWQoXG5cdElucHV0Q29udHJvbFN1ZmZpeFdyYXBwZXJcbilgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSB9XG5gO1xuIl19 */")); 31415 var DownArrowWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 31416 target: "e1mv6sxx1" 31417 } : { 31418 target: "e1mv6sxx1", 31419 label: "DownArrowWrapper" 31420 })("margin-inline-end:", space(-1), ";line-height:0;path{fill:currentColor;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrTDBDIiwiZmlsZSI6InNlbGVjdC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHR5cGUgeyBTZWxlY3RDb250cm9sUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlciBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LXN1ZmZpeC13cmFwcGVyJztcbmltcG9ydCB7IGZvbnRTaXplU3R5bGVzIH0gZnJvbSAnLi4vLi4vaW5wdXQtY29udHJvbC9zdHlsZXMvaW5wdXQtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IElucHV0QmFzZSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL2lucHV0LWJhc2UnO1xuXG5pbnRlcmZhY2UgU2VsZWN0UHJvcHNcblx0ZXh0ZW5kcyBQaWNrPFxuXHRcdFNlbGVjdENvbnRyb2xQcm9wcyxcblx0XHQnX19uZXh0NDBweERlZmF1bHRTaXplJyB8ICdkaXNhYmxlZCcgfCAnbXVsdGlwbGUnIHwgJ3ZhcmlhbnQnXG5cdD4ge1xuXHQvLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG5cdC8vIGBzaXplYCBIVE1MIGF0dHJpYnV0ZSBvZiB0aGUgYHNlbGVjdGAgZWxlbWVudC5cblx0c2VsZWN0U2l6ZT86IFNlbGVjdENvbnRyb2xQcm9wc1sgJ3NpemUnIF07XG59XG5cbmNvbnN0IGRpc2FibGVkU3R5bGVzID0gKCB7IGRpc2FibGVkIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoICEgZGlzYWJsZWQgKSB7XG5cdFx0cmV0dXJuICcnO1xuXHR9XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLnRleHREaXNhYmxlZCB9O1xuXHRcdGN1cnNvcjogZGVmYXVsdDtcblx0YDtcbn07XG5cbmNvbnN0IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzc2Bcblx0XHRcdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRcdGA7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSW5wdXRCYXNlID0gc3R5bGVkKCBJbnB1dEJhc2UgKWBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblxuXHQkeyBkaXNhYmxlZFN0eWxlcyB9XG5cdCR7IGlucHV0QmFzZVZhcmlhbnRTdHlsZXMgfVxuYDtcblxuY29uc3Qgc2l6ZVN0eWxlcyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggbXVsdGlwbGUgKSB7XG5cdFx0Ly8gV2hlbiBgbXVsdGlwbGVgLCBqdXN0IHVzZSB0aGUgbmF0aXZlIGJyb3dzZXIgc3R5bGVzXG5cdFx0Ly8gd2l0aG91dCBzZXR0aW5nIGV4cGxpY2l0IGhlaWdodC5cblx0XHRyZXR1cm47XG5cdH1cblxuXHRjb25zdCBzaXplcyA9IHtcblx0XHRkZWZhdWx0OiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0c21hbGw6IHtcblx0XHRcdGhlaWdodDogMjQsXG5cdFx0XHRtaW5IZWlnaHQ6IDI0LFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRjb21wYWN0OiB7XG5cdFx0XHRoZWlnaHQ6IDMyLFxuXHRcdFx0bWluSGVpZ2h0OiAzMixcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdFx0J19fdW5zdGFibGUtbGFyZ2UnOiB7XG5cdFx0XHRoZWlnaHQ6IDQwLFxuXHRcdFx0bWluSGVpZ2h0OiA0MCxcblx0XHRcdHBhZGRpbmdUb3A6IDAsXG5cdFx0XHRwYWRkaW5nQm90dG9tOiAwLFxuXHRcdH0sXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRzaXplcy5kZWZhdWx0ID0gc2l6ZXMuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHN0eWxlID0gc2l6ZXNbIHNlbGVjdFNpemUgXSB8fCBzaXplcy5kZWZhdWx0O1xuXG5cdHJldHVybiBjc3MoIHN0eWxlICk7XG59O1xuXG5leHBvcnQgY29uc3QgY2hldnJvbkljb25TaXplID0gMTg7XG5cbmNvbnN0IHNpemVQYWRkaW5ncyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdG11bHRpcGxlLFxuXHRzZWxlY3RTaXplID0gJ2RlZmF1bHQnLFxufTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHBhZGRpbmcgPSB7XG5cdFx0ZGVmYXVsdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0XHRzbWFsbDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdGNvbXBhY3Q6IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IENPTkZJRy5jb250cm9sUGFkZGluZ1gsXG5cdH07XG5cblx0aWYgKCAhIF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSApIHtcblx0XHRwYWRkaW5nLmRlZmF1bHQgPSBwYWRkaW5nLmNvbXBhY3Q7XG5cdH1cblxuXHRjb25zdCBzZWxlY3RlZFBhZGRpbmcgPSBwYWRkaW5nWyBzZWxlY3RTaXplIF0gfHwgcGFkZGluZy5kZWZhdWx0O1xuXG5cdHJldHVybiBydGwoIHtcblx0XHRwYWRkaW5nTGVmdDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdHBhZGRpbmdSaWdodDogc2VsZWN0ZWRQYWRkaW5nICsgY2hldnJvbkljb25TaXplLFxuXHRcdC4uLiggbXVsdGlwbGVcblx0XHRcdD8ge1xuXHRcdFx0XHRcdHBhZGRpbmdUb3A6IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdFx0XHRwYWRkaW5nQm90dG9tOiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0XHQgIH1cblx0XHRcdDoge30gKSxcblx0fSApO1xufTtcblxuY29uc3Qgb3ZlcmZsb3dTdHlsZXMgPSAoIHsgbXVsdGlwbGUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdHJldHVybiB7XG5cdFx0b3ZlcmZsb3c6IG11bHRpcGxlID8gJ2F1dG8nIDogJ2hpZGRlbicsXG5cdH07XG59O1xuXG5jb25zdCB2YXJpYW50U3R5bGVzID0gKCB7IHZhcmlhbnQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggdmFyaWFudCA9PT0gJ21pbmltYWwnICkge1xuXHRcdHJldHVybiBjc3MoIHtcblx0XHRcdGZpZWxkU2l6aW5nOiAnY29udGVudCcsXG5cdFx0fSApO1xuXHR9XG5cblx0cmV0dXJuICcnO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgU2VsZWN0ID0gc3R5bGVkLnNlbGVjdDwgU2VsZWN0UHJvcHMgPmBcblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IG5vbmUgIWltcG9ydGFudDtcblx0XHRjb2xvcjogY3VycmVudENvbG9yOyAvLyBPdmVycmlkZXMgaG92ZXIvZm9jdXMgc3R5bGVzIGluIGZvcm1zLmNzc1xuXHRcdGN1cnNvcjogaW5oZXJpdDtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRtYXJnaW46IDA7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdFx0bWF4LXdpZHRoOiBub25lO1xuXHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cblx0XHQkeyBmb250U2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVTdHlsZXMgfTtcblx0XHQkeyBzaXplUGFkZGluZ3MgfTtcblx0XHQkeyBvdmVyZmxvd1N0eWxlcyB9XG5cdFx0JHsgdmFyaWFudFN0eWxlcyB9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEb3duQXJyb3dXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAtMSApIH07IC8vIG9wdGljYWxseSBhZGp1c3QgdGhlIGljb25cblx0bGluZS1oZWlnaHQ6IDA7XG5cblx0cGF0aCB7XG5cdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRDb250cm9sU3VmZml4V3JhcHBlcldpdGhDbGlja1Rocm91Z2ggPSBzdHlsZWQoXG5cdElucHV0Q29udHJvbFN1ZmZpeFdyYXBwZXJcbilgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0JHsgcnRsKCB7IHJpZ2h0OiAwIH0gKSB9XG5gO1xuIl19 */")); 31421 var InputControlSuffixWrapperWithClickThrough = /* @__PURE__ */ emotion_styled_base_browser_esm_default(input_suffix_wrapper_default, false ? { 31422 target: "e1mv6sxx0" 31423 } : { 31424 target: "e1mv6sxx0", 31425 label: "InputControlSuffixWrapperWithClickThrough" 31426 })("position:absolute;pointer-events:none;", rtl({ 31427 right: 0 31428 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNlbGVjdC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2TEMiLCJmaWxlIjoic2VsZWN0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIHJ0bCwgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdENvbnRyb2xQcm9wcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtc3VmZml4LXdyYXBwZXInO1xuaW1wb3J0IHsgZm9udFNpemVTdHlsZXMgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgSW5wdXRCYXNlIGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvaW5wdXQtYmFzZSc7XG5cbmludGVyZmFjZSBTZWxlY3RQcm9wc1xuXHRleHRlbmRzIFBpY2s8XG5cdFx0U2VsZWN0Q29udHJvbFByb3BzLFxuXHRcdCdfX25leHQ0MHB4RGVmYXVsdFNpemUnIHwgJ2Rpc2FibGVkJyB8ICdtdWx0aXBsZScgfCAndmFyaWFudCdcblx0PiB7XG5cdC8vIFVzaW5nIGBzZWxlY3RTaXplYCBpbnN0ZWFkIG9mIGBzaXplYCB0byBhdm9pZCBhIHR5cGUgY29uZmxpY3Qgd2l0aCB0aGVcblx0Ly8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxuXHRzZWxlY3RTaXplPzogU2VsZWN0Q29udHJvbFByb3BzWyAnc2l6ZScgXTtcbn1cblxuY29uc3QgZGlzYWJsZWRTdHlsZXMgPSAoIHsgZGlzYWJsZWQgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGlmICggISBkaXNhYmxlZCApIHtcblx0XHRyZXR1cm4gJyc7XG5cdH1cblxuXHRyZXR1cm4gY3NzYFxuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkudGV4dERpc2FibGVkIH07XG5cdFx0Y3Vyc29yOiBkZWZhdWx0O1xuXHRgO1xufTtcblxuY29uc3QgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyA9ICggeyB2YXJpYW50IH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRpZiAoIHZhcmlhbnQgPT09ICdtaW5pbWFsJyApIHtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdFx0YDtcblx0fVxuXG5cdHJldHVybiAnJztcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dEJhc2UgPSBzdHlsZWQoIElucHV0QmFzZSApYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXG5cdCR7IGRpc2FibGVkU3R5bGVzIH1cblx0JHsgaW5wdXRCYXNlVmFyaWFudFN0eWxlcyB9XG5gO1xuXG5jb25zdCBzaXplU3R5bGVzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCBtdWx0aXBsZSApIHtcblx0XHQvLyBXaGVuIGBtdWx0aXBsZWAsIGp1c3QgdXNlIHRoZSBuYXRpdmUgYnJvd3NlciBzdHlsZXNcblx0XHQvLyB3aXRob3V0IHNldHRpbmcgZXhwbGljaXQgaGVpZ2h0LlxuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdGRlZmF1bHQ6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHRzbWFsbDoge1xuXHRcdFx0aGVpZ2h0OiAyNCxcblx0XHRcdG1pbkhlaWdodDogMjQsXG5cdFx0XHRwYWRkaW5nVG9wOiAwLFxuXHRcdFx0cGFkZGluZ0JvdHRvbTogMCxcblx0XHR9LFxuXHRcdGNvbXBhY3Q6IHtcblx0XHRcdGhlaWdodDogMzIsXG5cdFx0XHRtaW5IZWlnaHQ6IDMyLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0XHQnX191bnN0YWJsZS1sYXJnZSc6IHtcblx0XHRcdGhlaWdodDogNDAsXG5cdFx0XHRtaW5IZWlnaHQ6IDQwLFxuXHRcdFx0cGFkZGluZ1RvcDogMCxcblx0XHRcdHBhZGRpbmdCb3R0b206IDAsXG5cdFx0fSxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHNpemVzLmRlZmF1bHQgPSBzaXplcy5jb21wYWN0O1xuXHR9XG5cblx0Y29uc3Qgc3R5bGUgPSBzaXplc1sgc2VsZWN0U2l6ZSBdIHx8IHNpemVzLmRlZmF1bHQ7XG5cblx0cmV0dXJuIGNzcyggc3R5bGUgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjaGV2cm9uSWNvblNpemUgPSAxODtcblxuY29uc3Qgc2l6ZVBhZGRpbmdzID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcblx0bXVsdGlwbGUsXG5cdHNlbGVjdFNpemUgPSAnZGVmYXVsdCcsXG59OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3QgcGFkZGluZyA9IHtcblx0XHRkZWZhdWx0OiBDT05GSUcuY29udHJvbFBhZGRpbmdYLFxuXHRcdHNtYWxsOiBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwsXG5cdFx0Y29tcGFjdDogQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsLFxuXHRcdCdfX3Vuc3RhYmxlLWxhcmdlJzogQ09ORklHLmNvbnRyb2xQYWRkaW5nWCxcblx0fTtcblxuXHRpZiAoICEgX19uZXh0NDBweERlZmF1bHRTaXplICkge1xuXHRcdHBhZGRpbmcuZGVmYXVsdCA9IHBhZGRpbmcuY29tcGFjdDtcblx0fVxuXG5cdGNvbnN0IHNlbGVjdGVkUGFkZGluZyA9IHBhZGRpbmdbIHNlbGVjdFNpemUgXSB8fCBwYWRkaW5nLmRlZmF1bHQ7XG5cblx0cmV0dXJuIHJ0bCgge1xuXHRcdHBhZGRpbmdMZWZ0OiBzZWxlY3RlZFBhZGRpbmcsXG5cdFx0cGFkZGluZ1JpZ2h0OiBzZWxlY3RlZFBhZGRpbmcgKyBjaGV2cm9uSWNvblNpemUsXG5cdFx0Li4uKCBtdWx0aXBsZVxuXHRcdFx0PyB7XG5cdFx0XHRcdFx0cGFkZGluZ1RvcDogc2VsZWN0ZWRQYWRkaW5nLFxuXHRcdFx0XHRcdHBhZGRpbmdCb3R0b206IHNlbGVjdGVkUGFkZGluZyxcblx0XHRcdCAgfVxuXHRcdFx0OiB7fSApLFxuXHR9ICk7XG59O1xuXG5jb25zdCBvdmVyZmxvd1N0eWxlcyA9ICggeyBtdWx0aXBsZSB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0cmV0dXJuIHtcblx0XHRvdmVyZmxvdzogbXVsdGlwbGUgPyAnYXV0bycgOiAnaGlkZGVuJyxcblx0fTtcbn07XG5cbmNvbnN0IHZhcmlhbnRTdHlsZXMgPSAoIHsgdmFyaWFudCB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0aWYgKCB2YXJpYW50ID09PSAnbWluaW1hbCcgKSB7XG5cdFx0cmV0dXJuIGNzcygge1xuXHRcdFx0ZmllbGRTaXppbmc6ICdjb250ZW50Jyxcblx0XHR9ICk7XG5cdH1cblxuXHRyZXR1cm4gJyc7XG59O1xuXG4vLyBUT0RPOiBSZXNvbHZlIG5lZWQgdG8gdXNlICYmJiB0byBpbmNyZWFzZSBzcGVjaWZpY2l0eVxuLy8gaHR0cHM6Ly9naXRodWIuY29tL1dvcmRQcmVzcy9ndXRlbmJlcmcvaXNzdWVzLzE4NDgzXG5cbmV4cG9ydCBjb25zdCBTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0Ym94LXNoYWRvdzogbm9uZSAhaW1wb3J0YW50O1xuXHRcdGNvbG9yOiBjdXJyZW50Q29sb3I7IC8vIE92ZXJyaWRlcyBob3Zlci9mb2N1cyBzdHlsZXMgaW4gZm9ybXMuY3NzXG5cdFx0Y3Vyc29yOiBpbmhlcml0O1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdG1hcmdpbjogMDtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRtYXgtd2lkdGg6IG5vbmU7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblxuXHRcdCR7IGZvbnRTaXplU3R5bGVzIH07XG5cdFx0JHsgc2l6ZVN0eWxlcyB9O1xuXHRcdCR7IHNpemVQYWRkaW5ncyB9O1xuXHRcdCR7IG92ZXJmbG93U3R5bGVzIH1cblx0XHQkeyB2YXJpYW50U3R5bGVzIH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvd25BcnJvd1dyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIC0xICkgfTsgLy8gb3B0aWNhbGx5IGFkanVzdCB0aGUgaWNvblxuXHRsaW5lLWhlaWdodDogMDtcblxuXHRwYXRoIHtcblx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dENvbnRyb2xTdWZmaXhXcmFwcGVyV2l0aENsaWNrVGhyb3VnaCA9IHN0eWxlZChcblx0SW5wdXRDb250cm9sU3VmZml4V3JhcHBlclxuKWBcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQkeyBydGwoIHsgcmlnaHQ6IDAgfSApIH1cbmA7XG4iXX0= */")); 31429 31430 // packages/components/build-module/select-control/chevron-down.js 31431 var import_jsx_runtime124 = __toESM(require_jsx_runtime()); 31432 var SelectControlChevronDown = () => { 31433 return /* @__PURE__ */ (0, import_jsx_runtime124.jsx)(InputControlSuffixWrapperWithClickThrough, { 31434 children: /* @__PURE__ */ (0, import_jsx_runtime124.jsx)(DownArrowWrapper, { 31435 children: /* @__PURE__ */ (0, import_jsx_runtime124.jsx)(icon_default2, { 31436 icon: chevron_down_default, 31437 size: chevronIconSize 31438 }) 31439 }) 31440 }); 31441 }; 31442 var chevron_down_default2 = SelectControlChevronDown; 31443 31444 // packages/components/build-module/select-control/index.js 31445 var import_jsx_runtime125 = __toESM(require_jsx_runtime()); 31446 function useUniqueId3(idProp) { 31447 const instanceId = (0, import_compose31.useInstanceId)(SelectControl); 31448 const id3 = `inspector-select-control-$instanceId}`; 31449 return idProp || id3; 31450 } 31451 function SelectOptions({ 31452 options: options2 31453 }) { 31454 return options2.map(({ 31455 id: id3, 31456 label, 31457 value, 31458 ...optionProps 31459 }, index2) => { 31460 const key = id3 || `$label}-$value}-$index2}`; 31461 return /* @__PURE__ */ (0, import_jsx_runtime125.jsx)("option", { 31462 value, 31463 ...optionProps, 31464 children: label 31465 }, key); 31466 }); 31467 } 31468 function UnforwardedSelectControl(props, ref) { 31469 const { 31470 className: className2, 31471 disabled = false, 31472 help, 31473 hideLabelFromVision, 31474 id: idProp, 31475 label, 31476 multiple = false, 31477 onChange, 31478 options: options2 = [], 31479 size: size3 = "default", 31480 value: valueProp, 31481 labelPosition = "top", 31482 children, 31483 prefix: prefix2, 31484 suffix, 31485 variant = "default", 31486 __next40pxDefaultSize = false, 31487 __nextHasNoMarginBottom: _, 31488 // Prevent passing to internal component 31489 __shouldNotWarnDeprecated36pxSize, 31490 ...restProps 31491 } = useDeprecated36pxDefaultSizeProp(props); 31492 const id3 = useUniqueId3(idProp); 31493 const helpId = help ? `$id3}__help` : void 0; 31494 if (!options2?.length && !children) { 31495 return null; 31496 } 31497 const handleOnChange = (event) => { 31498 if (props.multiple) { 31499 const selectedOptions = Array.from(event.target.options).filter(({ 31500 selected 31501 }) => selected); 31502 const newValues = selectedOptions.map(({ 31503 value 31504 }) => value); 31505 props.onChange?.(newValues, { 31506 event 31507 }); 31508 return; 31509 } 31510 props.onChange?.(event.target.value, { 31511 event 31512 }); 31513 }; 31514 const classes = clsx_default("components-select-control", className2); 31515 maybeWarnDeprecated36pxSize({ 31516 componentName: "SelectControl", 31517 __next40pxDefaultSize, 31518 size: size3, 31519 __shouldNotWarnDeprecated36pxSize 31520 }); 31521 return /* @__PURE__ */ (0, import_jsx_runtime125.jsx)(base_control_default, { 31522 help, 31523 id: id3, 31524 className: classes, 31525 children: /* @__PURE__ */ (0, import_jsx_runtime125.jsx)(StyledInputBase, { 31526 disabled, 31527 hideLabelFromVision, 31528 id: id3, 31529 isBorderless: variant === "minimal", 31530 label, 31531 size: size3, 31532 suffix: suffix || !multiple && /* @__PURE__ */ (0, import_jsx_runtime125.jsx)(chevron_down_default2, {}), 31533 prefix: prefix2, 31534 labelPosition, 31535 __unstableInputWidth: variant === "minimal" ? "auto" : void 0, 31536 variant, 31537 __next40pxDefaultSize, 31538 children: /* @__PURE__ */ (0, import_jsx_runtime125.jsx)(Select3, { 31539 ...restProps, 31540 __next40pxDefaultSize, 31541 "aria-describedby": helpId, 31542 className: "components-select-control__input", 31543 disabled, 31544 id: id3, 31545 multiple, 31546 onChange: handleOnChange, 31547 ref, 31548 selectSize: size3, 31549 value: valueProp, 31550 variant, 31551 children: children || /* @__PURE__ */ (0, import_jsx_runtime125.jsx)(SelectOptions, { 31552 options: options2 31553 }) 31554 }) 31555 }) 31556 }); 31557 } 31558 var SelectControl = (0, import_element69.forwardRef)(UnforwardedSelectControl); 31559 var select_control_default = SelectControl; 31560 31561 // packages/components/build-module/range-control/index.js 31562 var import_i18n13 = __toESM(require_i18n()); 31563 var import_element73 = __toESM(require_element()); 31564 var import_compose32 = __toESM(require_compose()); 31565 31566 // packages/components/build-module/range-control/utils.js 31567 var import_element70 = __toESM(require_element()); 31568 function floatClamp(value, min3, max3) { 31569 if (typeof value !== "number") { 31570 return null; 31571 } 31572 return parseFloat(`$clamp4(value, min3, max3)}`); 31573 } 31574 function useControlledRangeValue(settings) { 31575 const { 31576 min: min3, 31577 max: max3, 31578 value: valueProp, 31579 initial 31580 } = settings; 31581 const [state, setInternalState] = use_controlled_state_default(floatClamp(valueProp, min3, max3), { 31582 initial: floatClamp(initial !== null && initial !== void 0 ? initial : null, min3, max3), 31583 fallback: null 31584 }); 31585 const setState = (0, import_element70.useCallback)((nextValue) => { 31586 if (nextValue === null) { 31587 setInternalState(null); 31588 } else { 31589 setInternalState(floatClamp(nextValue, min3, max3)); 31590 } 31591 }, [min3, max3, setInternalState]); 31592 return [state, setState]; 31593 } 31594 31595 // packages/components/build-module/range-control/input-range.js 31596 var import_element71 = __toESM(require_element()); 31597 31598 // packages/components/build-module/range-control/styles/range-control-styles.js 31599 function _EMOTION_STRINGIFIED_CSS_ERROR__13() { 31600 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 31601 } 31602 var rangeHeightValue = 30; 31603 var railHeight = 4; 31604 var rangeHeight = () => /* @__PURE__ */ css({ 31605 height: rangeHeightValue, 31606 minHeight: rangeHeightValue 31607 }, false ? "" : ";label:rangeHeight;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA0BC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31608 var thumbSize = 12; 31609 var deprecatedHeight = ({ 31610 __next40pxDefaultSize 31611 }) => !__next40pxDefaultSize && /* @__PURE__ */ css({ 31612 minHeight: rangeHeightValue 31613 }, false ? "" : ";label:deprecatedHeight;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAgC4B","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31614 var Root2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 31615 target: "e1epgpqk14" 31616 } : { 31617 target: "e1epgpqk14", 31618 label: "Root" 31619 })("-webkit-tap-highlight-color:transparent;align-items:center;display:flex;justify-content:flex-start;padding:0;position:relative;touch-action:none;width:100%;min-height:40px;", deprecatedHeight, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAmC2C","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31620 var wrapperColor = ({ 31621 color: color2 = COLORS.ui.borderFocus 31622 }) => /* @__PURE__ */ css({ 31623 color: color2 31624 }, false ? "" : ";label:wrapperColor;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAkDC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31625 var Wrapper2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 31626 shouldForwardProp: (prop) => !["color", "marks"].includes(prop), 31627 target: "e1epgpqk13" 31628 } : { 31629 shouldForwardProp: (prop) => !["color", "marks"].includes(prop), 31630 target: "e1epgpqk13", 31631 label: "Wrapper" 31632 })("display:block;flex:1;position:relative;width:100%;", wrapperColor, ";", rangeHeight, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAuDmB","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31633 var BeforeIconWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31634 target: "e1epgpqk12" 31635 } : { 31636 target: "e1epgpqk12", 31637 label: "BeforeIconWrapper" 31638 })("display:flex;margin-top:", railHeight, "px;", rtl({ 31639 marginRight: 6 31640 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAiE4C","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31641 var AfterIconWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31642 target: "e1epgpqk11" 31643 } : { 31644 target: "e1epgpqk11", 31645 label: "AfterIconWrapper" 31646 })("display:flex;margin-top:", railHeight, "px;", rtl({ 31647 marginLeft: 6 31648 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAwE2C","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31649 var railBackgroundColor = ({ 31650 disabled, 31651 railColor 31652 }) => { 31653 let background2 = railColor || ""; 31654 if (disabled) { 31655 background2 = COLORS.ui.backgroundDisabled; 31656 } 31657 return /* @__PURE__ */ css({ 31658 background: background2 31659 }, false ? "" : ";label:railBackgroundColor;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAsFQ","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31660 }; 31661 var Rail = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31662 target: "e1epgpqk10" 31663 } : { 31664 target: "e1epgpqk10", 31665 label: "Rail" 31666 })("background-color:", COLORS.gray[300], ";left:0;pointer-events:none;right:0;display:block;height:", railHeight, "px;position:absolute;margin-top:", (rangeHeightValue - railHeight) / 2, "px;top:0;border-radius:", config_values_default.radiusFull, ";", railBackgroundColor, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAyF+B","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31667 var trackBackgroundColor = ({ 31668 disabled, 31669 trackColor 31670 }) => { 31671 let background2 = trackColor || "currentColor"; 31672 if (disabled) { 31673 background2 = COLORS.gray[400]; 31674 } 31675 return /* @__PURE__ */ css({ 31676 background: background2 31677 }, false ? "" : ";label:trackBackgroundColor;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA+GQ","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31678 }; 31679 var Track = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31680 target: "e1epgpqk9" 31681 } : { 31682 target: "e1epgpqk9", 31683 label: "Track" 31684 })("background-color:currentColor;border-radius:", config_values_default.radiusFull, ";height:", railHeight, "px;pointer-events:none;display:block;position:absolute;margin-top:", (rangeHeightValue - railHeight) / 2, "px;top:0;.is-marked &{@media not ( prefers-reduced-motion ){transition:width ease 0.1s;}}", trackBackgroundColor, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAkHgC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31685 var MarksWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31686 target: "e1epgpqk8" 31687 } : { 31688 target: "e1epgpqk8", 31689 label: "MarksWrapper" 31690 })(false ? { 31691 name: "g5kg28", 31692 styles: "display:block;pointer-events:none;position:relative;width:100%;user-select:none;margin-top:17px" 31693 } : { 31694 name: "g5kg28", 31695 styles: "display:block;pointer-events:none;position:relative;width:100%;user-select:none;margin-top:17px", 31696 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAqIuC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */", 31697 toString: _EMOTION_STRINGIFIED_CSS_ERROR__13 31698 }); 31699 var Mark = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31700 target: "e1epgpqk7" 31701 } : { 31702 target: "e1epgpqk7", 31703 label: "Mark" 31704 })("position:absolute;left:0;top:-4px;height:4px;width:2px;transform:translateX( -50% );background-color:", COLORS.ui.background, ";z-index:1;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA8I+B","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31705 var markLabelFill = ({ 31706 isFilled 31707 }) => { 31708 return /* @__PURE__ */ css({ 31709 color: isFilled ? COLORS.gray[700] : COLORS.gray[300] 31710 }, false ? "" : ";label:markLabelFill;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA0JQ","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31711 }; 31712 var MarkLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31713 target: "e1epgpqk6" 31714 } : { 31715 target: "e1epgpqk6", 31716 label: "MarkLabel" 31717 })("color:", COLORS.gray[300], ";font-size:11px;position:absolute;top:8px;white-space:nowrap;", rtl({ 31718 left: 0 31719 }), ";", rtl({ 31720 transform: "translateX( -50% )" 31721 }, { 31722 transform: "translateX( 50% )" 31723 }), ";", markLabelFill, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA+JoC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31724 var thumbColor = ({ 31725 disabled 31726 }) => disabled ? /* @__PURE__ */ css("background-color:", COLORS.gray[400], ";" + (false ? "" : ";label:thumbColor;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAiLO","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */") : /* @__PURE__ */ css("background-color:", COLORS.theme.accent, ";" + (false ? "" : ";label:thumbColor;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAoLO","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31727 var ThumbWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31728 target: "e1epgpqk5" 31729 } : { 31730 target: "e1epgpqk5", 31731 label: "ThumbWrapper" 31732 })("align-items:center;display:flex;height:", thumbSize, "px;justify-content:center;margin-top:", (rangeHeightValue - thumbSize) / 2, "px;outline:0;pointer-events:none;position:absolute;top:0;user-select:none;width:", thumbSize, "px;border-radius:", config_values_default.radiusRound, ";z-index:3;.is-marked &{@media not ( prefers-reduced-motion ){transition:left ease 0.1s;}}", thumbColor, ";", rtl({ 31733 marginLeft: -10 31734 }), ";", rtl({ 31735 transform: "translateX( 4.5px )" 31736 }, { 31737 transform: "translateX( -4.5px )" 31738 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAwLuC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31739 var thumbFocus = ({ 31740 isFocused 31741 }) => { 31742 return isFocused ? /* @__PURE__ */ css("&::before{content:' ';position:absolute;background-color:", COLORS.theme.accent, ";opacity:0.4;border-radius:", config_values_default.radiusRound, ";height:", thumbSize + 8, "px;width:", thumbSize + 8, "px;top:-4px;left:-4px;}" + (false ? "" : ";label:thumbFocus;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAuNO","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */") : ""; 31743 }; 31744 var Thumb = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31745 target: "e1epgpqk4" 31746 } : { 31747 target: "e1epgpqk4", 31748 label: "Thumb" 31749 })("align-items:center;border-radius:", config_values_default.radiusRound, ";height:100%;outline:0;position:absolute;user-select:none;width:100%;box-shadow:", config_values_default.elevationXSmall, ";", thumbColor, ";", thumbFocus, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAuO8C","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31750 var InputRange = /* @__PURE__ */ emotion_styled_base_browser_esm_default("input", false ? { 31751 target: "e1epgpqk3" 31752 } : { 31753 target: "e1epgpqk3", 31754 label: "InputRange" 31755 })("box-sizing:border-box;cursor:pointer;display:block;height:100%;left:0;margin:0 -", thumbSize / 2, "px;opacity:0;outline:none;position:absolute;right:0;top:0;width:calc( 100% + ", thumbSize, "px );" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAqPsC","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31756 var tooltipShow = ({ 31757 show 31758 }) => { 31759 return /* @__PURE__ */ css("display:", show ? "inline-block" : "none", ";opacity:", show ? 1 : 0, ";@media not ( prefers-reduced-motion ){transition:opacity 120ms ease,display 120ms ease allow-discrete;}@starting-style{opacity:0;}" + (false ? "" : ";label:tooltipShow;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAqQW","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */"); 31760 }; 31761 var _ref6 = false ? { 31762 name: "1cypxip", 31763 styles: "top:-80%" 31764 } : { 31765 name: "1g4vnux-tooltipPlacement", 31766 styles: "top:-80%;label:tooltipPlacement;", 31767 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA8RW","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */", 31768 toString: _EMOTION_STRINGIFIED_CSS_ERROR__13 31769 }; 31770 var _ref24 = false ? { 31771 name: "1lr98c4", 31772 styles: "bottom:-80%" 31773 } : { 31774 name: "1g13zjq-tooltipPlacement", 31775 styles: "bottom:-80%;label:tooltipPlacement;", 31776 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAyRY","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */", 31777 toString: _EMOTION_STRINGIFIED_CSS_ERROR__13 31778 }; 31779 var tooltipPlacement = ({ 31780 placement 31781 }) => { 31782 const isBottom = placement === "bottom"; 31783 if (isBottom) { 31784 return _ref24; 31785 } 31786 return _ref6; 31787 }; 31788 var Tooltip3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31789 target: "e1epgpqk2" 31790 } : { 31791 target: "e1epgpqk2", 31792 label: "Tooltip" 31793 })("background:rgba( 0, 0, 0, 0.8 );border-radius:", config_values_default.radiusSmall, ";color:white;font-size:12px;min-width:32px;padding:4px 8px;pointer-events:none;position:absolute;text-align:center;user-select:none;line-height:1.4;", tooltipShow, ";", tooltipPlacement, ";", rtl({ 31794 transform: "translateX(-50%)" 31795 }, { 31796 transform: "translateX(50%)" 31797 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAmSkD","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31798 var InputNumber = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 31799 target: "e1epgpqk1" 31800 } : { 31801 target: "e1epgpqk1", 31802 label: "InputNumber" 31803 })("display:inline-block;font-size:13px;margin-top:0;input[type='number']&{", rangeHeight, ";}", rtl({ 31804 marginLeft: `$space(4)} !important` 31805 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AA2TkD","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31806 var ActionRightWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 31807 target: "e1epgpqk0" 31808 } : { 31809 target: "e1epgpqk0", 31810 label: "ActionRightWrapper" 31811 })("display:block;margin-top:0;button,button.is-small{margin-left:0;", rangeHeight, ";}", rtl({ 31812 marginLeft: 8 31813 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["range-control-styles.ts"],"names":[],"mappings":"AAuU6C","file":"range-control-styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport NumberControl from '../../number-control';\nimport { COLORS, rtl, CONFIG } from '../../utils';\nimport { space } from '../../utils/space';\n\nimport type {\n\tRangeMarkProps,\n\tRailProps,\n\tThumbProps,\n\tTooltipProps,\n\tTrackProps,\n\tWrapperProps,\n\tRangeControlProps,\n} from '../types';\n\nconst rangeHeightValue = 30;\nconst railHeight = 4;\nconst rangeHeight = () =>\n\tcss( { height: rangeHeightValue, minHeight: rangeHeightValue } );\nconst thumbSize = 12;\n\nconst deprecatedHeight = ( {\n\t__next40pxDefaultSize,\n}: Pick< RangeControlProps, '__next40pxDefaultSize' > ) =>\n\t! __next40pxDefaultSize && css( { minHeight: rangeHeightValue } );\n\ntype RootProps = Pick< RangeControlProps, '__next40pxDefaultSize' >;\nexport const Root = styled.div< RootProps >`\n\t-webkit-tap-highlight-color: transparent;\n\talign-items: center;\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\tpadding: 0;\n\tposition: relative;\n\ttouch-action: none;\n\twidth: 100%;\n\tmin-height: 40px;\n\t/* TODO: remove after removing the __next40pxDefaultSize prop */\n\t${ deprecatedHeight };\n`;\n\nconst wrapperColor = ( { color = COLORS.ui.borderFocus }: WrapperProps ) =>\n\tcss( { color } );\n\nexport const Wrapper = styled( 'div', {\n\tshouldForwardProp: ( prop: string ) =>\n\t\t! [ 'color', 'marks' ].includes( prop ),\n} )< WrapperProps >`\n\tdisplay: block;\n\tflex: 1;\n\tposition: relative;\n\twidth: 100%;\n\n\t${ wrapperColor };\n\t${ rangeHeight };\n`;\n\nexport const BeforeIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginRight: 6 } ) }\n`;\n\nexport const AfterIconWrapper = styled.span`\n\tdisplay: flex; // ensures the height isn't affected by line-height\n\tmargin-top: ${ railHeight }px;\n\n\t${ rtl( { marginLeft: 6 } ) }\n`;\n\nconst railBackgroundColor = ( { disabled, railColor }: RailProps ) => {\n\tlet background = railColor || '';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.ui.backgroundDisabled;\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Rail = styled.span`\n\tbackground-color: ${ COLORS.gray[ 300 ] };\n\tleft: 0;\n\tpointer-events: none;\n\tright: 0;\n\tdisplay: block;\n\theight: ${ railHeight }px;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\tborder-radius: ${ CONFIG.radiusFull };\n\n\t${ railBackgroundColor };\n`;\n\nconst trackBackgroundColor = ( { disabled, trackColor }: TrackProps ) => {\n\tlet background = trackColor || 'currentColor';\n\n\tif ( disabled ) {\n\t\tbackground = COLORS.gray[ 400 ];\n\t}\n\n\treturn css( { background } );\n};\n\nexport const Track = styled.span`\n\tbackground-color: currentColor;\n\tborder-radius: ${ CONFIG.radiusFull };\n\theight: ${ railHeight }px;\n\tpointer-events: none;\n\tdisplay: block;\n\tposition: absolute;\n\tmargin-top: ${ ( rangeHeightValue - railHeight ) / 2 }px;\n\ttop: 0;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: width ease 0.1s;\n\t\t}\n\t}\n\n\t${ trackBackgroundColor };\n`;\n\nexport const MarksWrapper = styled.span`\n\tdisplay: block;\n\tpointer-events: none;\n\tposition: relative;\n\twidth: 100%;\n\tuser-select: none;\n\tmargin-top: 17px;\n`;\n\nexport const Mark = styled.span`\n\tposition: absolute;\n\tleft: 0;\n\ttop: -4px;\n\theight: 4px;\n\twidth: 2px;\n\ttransform: translateX( -50% );\n\tbackground-color: ${ COLORS.ui.background };\n\tz-index: 1;\n`;\n\nconst markLabelFill = ( { isFilled }: RangeMarkProps ) => {\n\treturn css( {\n\t\tcolor: isFilled ? COLORS.gray[ 700 ] : COLORS.gray[ 300 ],\n\t} );\n};\n\nexport const MarkLabel = styled.span`\n\tcolor: ${ COLORS.gray[ 300 ] };\n\tfont-size: 11px;\n\tposition: absolute;\n\ttop: 8px;\n\twhite-space: nowrap;\n\n\t${ rtl( { left: 0 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( -50% )' },\n\t\t{ transform: 'translateX( 50% )' }\n\t) };\n\n\t${ markLabelFill };\n`;\n\nconst thumbColor = ( { disabled }: ThumbProps ) =>\n\tdisabled\n\t\t? css`\n\t\t\t\tbackground-color: ${ COLORS.gray[ 400 ] };\n\t\t  `\n\t\t: css`\n\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t  `;\n\nexport const ThumbWrapper = styled.span`\n\talign-items: center;\n\tdisplay: flex;\n\theight: ${ thumbSize }px;\n\tjustify-content: center;\n\tmargin-top: ${ ( rangeHeightValue - thumbSize ) / 2 }px;\n\toutline: 0;\n\tpointer-events: none;\n\tposition: absolute;\n\ttop: 0;\n\tuser-select: none;\n\twidth: ${ thumbSize }px;\n\tborder-radius: ${ CONFIG.radiusRound };\n\tz-index: 3;\n\n\t.is-marked & {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition: left ease 0.1s;\n\t\t}\n\t}\n\n\t${ thumbColor };\n\t${ rtl( { marginLeft: -10 } ) };\n\t${ rtl(\n\t\t{ transform: 'translateX( 4.5px )' },\n\t\t{ transform: 'translateX( -4.5px )' }\n\t) };\n`;\n\nconst thumbFocus = ( { isFocused }: ThumbProps ) => {\n\treturn isFocused\n\t\t? css`\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: ' ';\n\t\t\t\t\tposition: absolute;\n\t\t\t\t\tbackground-color: ${ COLORS.theme.accent };\n\t\t\t\t\topacity: 0.4;\n\t\t\t\t\tborder-radius: ${ CONFIG.radiusRound };\n\t\t\t\t\theight: ${ thumbSize + 8 }px;\n\t\t\t\t\twidth: ${ thumbSize + 8 }px;\n\t\t\t\t\ttop: -4px;\n\t\t\t\t\tleft: -4px;\n\t\t\t\t}\n\t\t  `\n\t\t: '';\n};\n\nexport const Thumb = styled.span< ThumbProps >`\n\talign-items: center;\n\tborder-radius: ${ CONFIG.radiusRound };\n\theight: 100%;\n\toutline: 0;\n\tposition: absolute;\n\tuser-select: none;\n\twidth: 100%;\n\tbox-shadow: ${ CONFIG.elevationXSmall };\n\n\t${ thumbColor };\n\t${ thumbFocus };\n`;\n\nexport const InputRange = styled.input`\n\tbox-sizing: border-box;\n\tcursor: pointer;\n\tdisplay: block;\n\theight: 100%;\n\tleft: 0;\n\tmargin: 0 -${ thumbSize / 2 }px;\n\topacity: 0;\n\toutline: none;\n\tposition: absolute;\n\tright: 0;\n\ttop: 0;\n\twidth: calc( 100% + ${ thumbSize }px );\n`;\n\nconst tooltipShow = ( { show }: TooltipProps ) => {\n\treturn css`\n\t\tdisplay: ${ show ? 'inline-block' : 'none' };\n\t\topacity: ${ show ? 1 : 0 };\n\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\ttransition:\n\t\t\t\topacity 120ms ease,\n\t\t\t\tdisplay 120ms ease allow-discrete;\n\t\t}\n\n\t\t@starting-style {\n\t\t\topacity: 0;\n\t\t}\n\t`;\n};\n\nconst tooltipPlacement = ( { placement }: TooltipProps ) => {\n\tconst isBottom = placement === 'bottom';\n\n\tif ( isBottom ) {\n\t\treturn css`\n\t\t\tbottom: -80%;\n\t\t`;\n\t}\n\n\treturn css`\n\t\ttop: -80%;\n\t`;\n};\n\nexport const Tooltip = styled.span< TooltipProps >`\n\tbackground: rgba( 0, 0, 0, 0.8 );\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tcolor: white;\n\tfont-size: 12px;\n\tmin-width: 32px;\n\tpadding: 4px 8px;\n\tpointer-events: none;\n\tposition: absolute;\n\ttext-align: center;\n\tuser-select: none;\n\tline-height: 1.4;\n\n\t${ tooltipShow };\n\n\t${ tooltipPlacement };\n\t${ rtl(\n\t\t{ transform: 'translateX(-50%)' },\n\t\t{ transform: 'translateX(50%)' }\n\t) }\n`;\n\n// @todo Refactor RangeControl with latest HStack configuration\n// @see: packages/components/src/h-stack\nexport const InputNumber = styled( NumberControl )`\n\tdisplay: inline-block;\n\tfont-size: 13px;\n\tmargin-top: 0;\n\n\tinput[type='number']& {\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: `${ space( 4 ) } !important` } ) }\n`;\n\nexport const ActionRightWrapper = styled.span`\n\tdisplay: block;\n\tmargin-top: 0;\n\n\tbutton,\n\tbutton.is-small {\n\t\tmargin-left: 0;\n\t\t${ rangeHeight };\n\t}\n\n\t${ rtl( { marginLeft: 8 } ) }\n`;\n"]} */")); 31814 31815 // packages/components/build-module/range-control/input-range.js 31816 var import_jsx_runtime126 = __toESM(require_jsx_runtime()); 31817 function InputRange2(props, ref) { 31818 const { 31819 describedBy, 31820 label, 31821 value, 31822 ...otherProps 31823 } = props; 31824 return /* @__PURE__ */ (0, import_jsx_runtime126.jsx)(InputRange, { 31825 ...otherProps, 31826 "aria-describedby": describedBy, 31827 "aria-label": label, 31828 "aria-hidden": false, 31829 ref, 31830 tabIndex: 0, 31831 type: "range", 31832 value 31833 }); 31834 } 31835 var ForwardedComponent2 = (0, import_element71.forwardRef)(InputRange2); 31836 var input_range_default = ForwardedComponent2; 31837 31838 // packages/components/build-module/range-control/rail.js 31839 var import_i18n12 = __toESM(require_i18n()); 31840 31841 // packages/components/build-module/range-control/mark.js 31842 var import_jsx_runtime127 = __toESM(require_jsx_runtime()); 31843 function RangeMark(props) { 31844 const { 31845 className: className2, 31846 isFilled = false, 31847 label, 31848 style: style2 = {}, 31849 ...otherProps 31850 } = props; 31851 const classes = clsx_default("components-range-control__mark", isFilled && "is-filled", className2); 31852 const labelClasses = clsx_default("components-range-control__mark-label", isFilled && "is-filled"); 31853 return /* @__PURE__ */ (0, import_jsx_runtime127.jsxs)(import_jsx_runtime127.Fragment, { 31854 children: [/* @__PURE__ */ (0, import_jsx_runtime127.jsx)(Mark, { 31855 ...otherProps, 31856 "aria-hidden": "true", 31857 className: classes, 31858 style: style2 31859 }), label && /* @__PURE__ */ (0, import_jsx_runtime127.jsx)(MarkLabel, { 31860 "aria-hidden": "true", 31861 className: labelClasses, 31862 isFilled, 31863 style: style2, 31864 children: label 31865 })] 31866 }); 31867 } 31868 31869 // packages/components/build-module/range-control/rail.js 31870 var import_jsx_runtime128 = __toESM(require_jsx_runtime()); 31871 var import_react105 = __toESM(require_react()); 31872 function RangeRail(props) { 31873 const { 31874 disabled = false, 31875 marks = false, 31876 min: min3 = 0, 31877 max: max3 = 100, 31878 step = 1, 31879 value = 0, 31880 ...restProps 31881 } = props; 31882 return /* @__PURE__ */ (0, import_jsx_runtime128.jsxs)(import_jsx_runtime128.Fragment, { 31883 children: [/* @__PURE__ */ (0, import_jsx_runtime128.jsx)(Rail, { 31884 disabled, 31885 ...restProps 31886 }), marks && /* @__PURE__ */ (0, import_jsx_runtime128.jsx)(Marks, { 31887 disabled, 31888 marks, 31889 min: min3, 31890 max: max3, 31891 step, 31892 value 31893 })] 31894 }); 31895 } 31896 function Marks(props) { 31897 const { 31898 disabled = false, 31899 marks = false, 31900 min: min3 = 0, 31901 max: max3 = 100, 31902 step: stepProp = 1, 31903 value = 0 31904 } = props; 31905 const step = stepProp === "any" ? 1 : stepProp; 31906 const marksData = useMarks({ 31907 marks, 31908 min: min3, 31909 max: max3, 31910 step, 31911 value 31912 }); 31913 return /* @__PURE__ */ (0, import_jsx_runtime128.jsx)(MarksWrapper, { 31914 "aria-hidden": "true", 31915 className: "components-range-control__marks", 31916 children: marksData.map((mark) => /* @__PURE__ */ (0, import_react105.createElement)(RangeMark, { 31917 ...mark, 31918 key: mark.key, 31919 "aria-hidden": "true", 31920 disabled 31921 })) 31922 }); 31923 } 31924 function useMarks({ 31925 marks, 31926 min: min3 = 0, 31927 max: max3 = 100, 31928 step = 1, 31929 value = 0 31930 }) { 31931 if (!marks) { 31932 return []; 31933 } 31934 const range = max3 - min3; 31935 if (!Array.isArray(marks)) { 31936 marks = []; 31937 const count = 1 + Math.round(range / step); 31938 while (count > marks.push({ 31939 value: step * marks.length + min3 31940 })) { 31941 } 31942 } 31943 const placedMarks = []; 31944 marks.forEach((mark, index2) => { 31945 if (mark.value < min3 || mark.value > max3) { 31946 return; 31947 } 31948 const key = `mark-$index2}`; 31949 const isFilled = mark.value <= value; 31950 const offset3 = `${(mark.value - min3) / range * 100}%`; 31951 const offsetStyle = { 31952 [(0, import_i18n12.isRTL)() ? "right" : "left"]: offset3 31953 }; 31954 placedMarks.push({ 31955 ...mark, 31956 isFilled, 31957 key, 31958 style: offsetStyle 31959 }); 31960 }); 31961 return placedMarks; 31962 } 31963 31964 // packages/components/build-module/range-control/tooltip.js 31965 var import_element72 = __toESM(require_element()); 31966 var import_jsx_runtime129 = __toESM(require_jsx_runtime()); 31967 function SimpleTooltip(props) { 31968 const { 31969 className: className2, 31970 inputRef, 31971 tooltipPlacement: tooltipPlacement2, 31972 show = false, 31973 style: style2 = {}, 31974 value = 0, 31975 renderTooltipContent = (v3) => v3, 31976 zIndex = 100, 31977 ...restProps 31978 } = props; 31979 const placement = useTooltipPlacement({ 31980 inputRef, 31981 tooltipPlacement: tooltipPlacement2 31982 }); 31983 const classes = clsx_default("components-simple-tooltip", className2); 31984 const styles3 = { 31985 ...style2, 31986 zIndex 31987 }; 31988 return /* @__PURE__ */ (0, import_jsx_runtime129.jsx)(Tooltip3, { 31989 ...restProps, 31990 "aria-hidden": "false", 31991 className: classes, 31992 placement, 31993 show, 31994 role: "tooltip", 31995 style: styles3, 31996 children: renderTooltipContent(value) 31997 }); 31998 } 31999 function useTooltipPlacement({ 32000 inputRef, 32001 tooltipPlacement: tooltipPlacement2 32002 }) { 32003 const [placement, setPlacement] = (0, import_element72.useState)(); 32004 const setTooltipPlacement = (0, import_element72.useCallback)(() => { 32005 if (inputRef && inputRef.current) { 32006 setPlacement(tooltipPlacement2); 32007 } 32008 }, [tooltipPlacement2, inputRef]); 32009 (0, import_element72.useEffect)(() => { 32010 setTooltipPlacement(); 32011 }, [setTooltipPlacement]); 32012 (0, import_element72.useEffect)(() => { 32013 window.addEventListener("resize", setTooltipPlacement); 32014 return () => { 32015 window.removeEventListener("resize", setTooltipPlacement); 32016 }; 32017 }); 32018 return placement; 32019 } 32020 32021 // packages/components/build-module/range-control/index.js 32022 var import_jsx_runtime130 = __toESM(require_jsx_runtime()); 32023 var noop7 = () => { 32024 }; 32025 function computeResetValue({ 32026 resetFallbackValue, 32027 initialPosition 32028 }) { 32029 if (resetFallbackValue !== void 0) { 32030 return !Number.isNaN(resetFallbackValue) ? resetFallbackValue : null; 32031 } 32032 if (initialPosition !== void 0) { 32033 return !Number.isNaN(initialPosition) ? initialPosition : null; 32034 } 32035 return null; 32036 } 32037 function UnforwardedRangeControl(props, forwardedRef) { 32038 const { 32039 __nextHasNoMarginBottom: _, 32040 // Prevent passing to internal component 32041 afterIcon, 32042 allowReset = false, 32043 beforeIcon, 32044 className: className2, 32045 color: colorProp = COLORS.theme.accent, 32046 currentInput, 32047 disabled = false, 32048 help, 32049 hideLabelFromVision = false, 32050 initialPosition, 32051 isShiftStepEnabled = true, 32052 label, 32053 marks = false, 32054 max: max3 = 100, 32055 min: min3 = 0, 32056 onBlur = noop7, 32057 onChange = noop7, 32058 onFocus = noop7, 32059 onMouseLeave = noop7, 32060 onMouseMove = noop7, 32061 railColor, 32062 renderTooltipContent = (v3) => v3, 32063 resetFallbackValue, 32064 __next40pxDefaultSize = false, 32065 shiftStep = 10, 32066 showTooltip: showTooltipProp, 32067 step = 1, 32068 trackColor, 32069 value: valueProp, 32070 withInputField = true, 32071 __shouldNotWarnDeprecated36pxSize, 32072 ...otherProps 32073 } = props; 32074 const [value, setValue] = useControlledRangeValue({ 32075 min: min3, 32076 max: max3, 32077 value: valueProp !== null && valueProp !== void 0 ? valueProp : null, 32078 initial: initialPosition 32079 }); 32080 const isResetPendent = (0, import_element73.useRef)(false); 32081 let hasTooltip = showTooltipProp; 32082 let hasInputField = withInputField; 32083 if (step === "any") { 32084 hasTooltip = false; 32085 hasInputField = false; 32086 } 32087 const [showTooltip, setShowTooltip] = (0, import_element73.useState)(hasTooltip); 32088 const [isFocused, setIsFocused] = (0, import_element73.useState)(false); 32089 const inputRef = (0, import_element73.useRef)(); 32090 const isCurrentlyFocused = inputRef.current?.matches(":focus"); 32091 const isThumbFocused = !disabled && isFocused; 32092 const isValueReset = value === null; 32093 const currentValue = value !== void 0 ? value : currentInput; 32094 const inputSliderValue = isValueReset ? "" : currentValue; 32095 const rangeFillValue = isValueReset ? (max3 - min3) / 2 + min3 : value; 32096 const fillValue = isValueReset ? 50 : (value - min3) / (max3 - min3) * 100; 32097 const fillValueOffset = `$clamp4(fillValue, 0, 100)}%`; 32098 const classes = clsx_default("components-range-control", className2); 32099 const wrapperClasses = clsx_default("components-range-control__wrapper", !!marks && "is-marked"); 32100 const id3 = (0, import_compose32.useInstanceId)(UnforwardedRangeControl, "inspector-range-control"); 32101 const describedBy = !!help ? `$id3}__help` : void 0; 32102 const enableTooltip = hasTooltip !== false && Number.isFinite(value); 32103 const handleOnRangeChange = (event) => { 32104 const nextValue = parseFloat(event.target.value); 32105 setValue(nextValue); 32106 onChange(nextValue); 32107 }; 32108 const handleOnChange = (next2) => { 32109 let nextValue = parseFloat(next2); 32110 setValue(nextValue); 32111 if (!isNaN(nextValue)) { 32112 if (nextValue < min3 || nextValue > max3) { 32113 nextValue = floatClamp(nextValue, min3, max3); 32114 } 32115 onChange(nextValue); 32116 isResetPendent.current = false; 32117 } else if (allowReset) { 32118 isResetPendent.current = true; 32119 } 32120 }; 32121 const handleOnInputNumberBlur = () => { 32122 if (isResetPendent.current) { 32123 handleOnReset(); 32124 isResetPendent.current = false; 32125 } 32126 }; 32127 const handleOnReset = () => { 32128 const resetValue = Number.isNaN(resetFallbackValue) ? null : resetFallbackValue !== null && resetFallbackValue !== void 0 ? resetFallbackValue : null; 32129 setValue(resetValue); 32130 onChange(resetValue !== null && resetValue !== void 0 ? resetValue : void 0); 32131 }; 32132 const handleShowTooltip = () => setShowTooltip(true); 32133 const handleHideTooltip = () => setShowTooltip(false); 32134 const handleOnBlur = (event) => { 32135 onBlur(event); 32136 setIsFocused(false); 32137 handleHideTooltip(); 32138 }; 32139 const handleOnFocus = (event) => { 32140 onFocus(event); 32141 setIsFocused(true); 32142 handleShowTooltip(); 32143 }; 32144 const offsetStyle = { 32145 [(0, import_i18n13.isRTL)() ? "right" : "left"]: fillValueOffset 32146 }; 32147 maybeWarnDeprecated36pxSize({ 32148 componentName: "RangeControl", 32149 __next40pxDefaultSize, 32150 size: void 0, 32151 __shouldNotWarnDeprecated36pxSize 32152 }); 32153 return /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(base_control_default, { 32154 className: classes, 32155 label, 32156 hideLabelFromVision, 32157 id: `$id3}`, 32158 help, 32159 children: /* @__PURE__ */ (0, import_jsx_runtime130.jsxs)(Root2, { 32160 className: "components-range-control__root", 32161 __next40pxDefaultSize, 32162 children: [beforeIcon && /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(BeforeIconWrapper, { 32163 children: /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(icon_default3, { 32164 icon: beforeIcon 32165 }) 32166 }), /* @__PURE__ */ (0, import_jsx_runtime130.jsxs)(Wrapper2, { 32167 className: wrapperClasses, 32168 color: colorProp, 32169 marks: !!marks, 32170 children: [/* @__PURE__ */ (0, import_jsx_runtime130.jsx)(input_range_default, { 32171 ...otherProps, 32172 className: "components-range-control__slider", 32173 describedBy, 32174 disabled, 32175 id: `$id3}`, 32176 label, 32177 max: max3, 32178 min: min3, 32179 onBlur: handleOnBlur, 32180 onChange: handleOnRangeChange, 32181 onFocus: handleOnFocus, 32182 onMouseMove, 32183 onMouseLeave, 32184 ref: (0, import_compose32.useMergeRefs)([inputRef, forwardedRef]), 32185 step, 32186 value: inputSliderValue !== null && inputSliderValue !== void 0 ? inputSliderValue : void 0 32187 }), /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(RangeRail, { 32188 "aria-hidden": true, 32189 disabled, 32190 marks, 32191 max: max3, 32192 min: min3, 32193 railColor, 32194 step, 32195 value: rangeFillValue 32196 }), /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(Track, { 32197 "aria-hidden": true, 32198 className: "components-range-control__track", 32199 disabled, 32200 style: { 32201 width: fillValueOffset 32202 }, 32203 trackColor 32204 }), /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(ThumbWrapper, { 32205 className: "components-range-control__thumb-wrapper", 32206 style: offsetStyle, 32207 disabled, 32208 children: /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(Thumb, { 32209 "aria-hidden": true, 32210 isFocused: isThumbFocused, 32211 disabled 32212 }) 32213 }), enableTooltip && /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(SimpleTooltip, { 32214 className: "components-range-control__tooltip", 32215 inputRef, 32216 tooltipPlacement: "bottom", 32217 renderTooltipContent, 32218 show: isCurrentlyFocused || showTooltip, 32219 style: offsetStyle, 32220 value 32221 })] 32222 }), afterIcon && /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(AfterIconWrapper, { 32223 children: /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(icon_default3, { 32224 icon: afterIcon 32225 }) 32226 }), hasInputField && /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(InputNumber, { 32227 "aria-label": label, 32228 className: "components-range-control__number", 32229 disabled, 32230 inputMode: "decimal", 32231 isShiftStepEnabled, 32232 max: max3, 32233 min: min3, 32234 onBlur: handleOnInputNumberBlur, 32235 onChange: handleOnChange, 32236 shiftStep, 32237 size: __next40pxDefaultSize ? "__unstable-large" : "default", 32238 __unstableInputWidth: __next40pxDefaultSize ? space(20) : space(16), 32239 step, 32240 value: inputSliderValue, 32241 __shouldNotWarnDeprecated36pxSize: true 32242 }), allowReset && /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(ActionRightWrapper, { 32243 children: /* @__PURE__ */ (0, import_jsx_runtime130.jsx)(button_default, { 32244 className: "components-range-control__reset", 32245 accessibleWhenDisabled: !disabled, 32246 disabled: disabled || value === computeResetValue({ 32247 resetFallbackValue, 32248 initialPosition 32249 }), 32250 variant: "secondary", 32251 size: "small", 32252 onClick: handleOnReset, 32253 children: (0, import_i18n13.__)("Reset") 32254 }) 32255 })] 32256 }) 32257 }); 32258 } 32259 var RangeControl = (0, import_element73.forwardRef)(UnforwardedRangeControl); 32260 var range_control_default = RangeControl; 32261 32262 // packages/components/build-module/color-picker/styles.js 32263 var NumberControlWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 32264 target: "ez9hsf46" 32265 } : { 32266 target: "ez9hsf46", 32267 label: "NumberControlWrapper" 32268 })("width:", space(24), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQjJEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32269 var SelectControl2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(select_control_default, false ? { 32270 target: "ez9hsf45" 32271 } : { 32272 target: "ez9hsf45", 32273 label: "SelectControl" 32274 })("margin-left:", space(-2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnlEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32275 var RangeControl2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(range_control_default, false ? { 32276 target: "ez9hsf44" 32277 } : { 32278 target: "ez9hsf44", 32279 label: "RangeControl" 32280 })("flex:1;margin-right:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QnVEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32281 var interactiveHueStyles = ` 32282 .react-colorful__interactive { 32283 width: calc( 100% - $space(2)} ); 32284 margin-left: $space(1)}; 32285 }`; 32286 var AuxiliaryColorArtefactWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 32287 target: "ez9hsf43" 32288 } : { 32289 target: "ez9hsf43", 32290 label: "AuxiliaryColorArtefactWrapper" 32291 })("padding-top:", space(2), ";padding-right:0;padding-left:0;padding-bottom:0;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ3VEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32292 var AuxiliaryColorArtefactHStackHeader = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default9, false ? { 32293 target: "ez9hsf42" 32294 } : { 32295 target: "ez9hsf42", 32296 label: "AuxiliaryColorArtefactHStackHeader" 32297 })("padding-left:", space(4), ";padding-right:", space(4), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q2tFIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32298 var ColorInputWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default3, false ? { 32299 target: "ez9hsf41" 32300 } : { 32301 target: "ez9hsf41", 32302 label: "ColorInputWrapper" 32303 })("padding-top:", space(4), ";padding-left:", space(4), ";padding-right:", space(3), ";padding-bottom:", space(5), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRCtDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32304 var ColorfulWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 32305 target: "ez9hsf40" 32306 } : { 32307 target: "ez9hsf40", 32308 label: "ColorfulWrapper" 32309 })(boxSizingReset, ";width:216px;.react-colorful{display:flex;flex-direction:column;align-items:center;width:216px;height:auto;}.react-colorful__saturation{width:100%;border-radius:0;height:216px;margin-bottom:", space(4), ";border-bottom:none;}.react-colorful__hue,.react-colorful__alpha{width:184px;height:16px;border-radius:", config_values_default.radiusFull, ";margin-bottom:", space(2), ";}.react-colorful__pointer{height:16px;width:16px;border:none;box-shadow:0 0 2px 0 rgba( 0, 0, 0, 0.25 );outline:2px solid transparent;@media not ( prefers-reduced-motion ){transition:transform ", config_values_default.transitionDurationFast, " ease-in-out;}}.react-colorful__interactive:focus .react-colorful__pointer{box-shadow:0 0 0 ", config_values_default.borderWidthFocus, " ", config_values_default.surfaceColor, ";border:", config_values_default.borderWidthFocus, " solid black;transform:translate( -50%, -50% ) scale( 1.5 );}.react-colorful__pointer-fill{box-shadow:inset 0 0 0 ", config_values_default.borderWidthFocus, " #fff;}", interactiveHueStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RHlDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IElubmVyU2VsZWN0Q29udHJvbCBmcm9tICcuLi9zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgSW5uZXJSYW5nZUNvbnRyb2wgZnJvbSAnLi4vcmFuZ2UtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuXG5leHBvcnQgY29uc3QgTnVtYmVyQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0d2lkdGg6ICR7IHNwYWNlKCAyNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU2VsZWN0Q29udHJvbCA9IHN0eWxlZCggSW5uZXJTZWxlY3RDb250cm9sIClgXG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFJhbmdlQ29udHJvbCA9IHN0eWxlZCggSW5uZXJSYW5nZUNvbnRyb2wgKWBcblx0ZmxleDogMTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG4vLyBNYWtlIHRoZSBIdWUgY2lyY2xlIHBpY2tlciBub3QgZ28gb3V0IG9mIHRoZSBiYXIuXG5jb25zdCBpbnRlcmFjdGl2ZUh1ZVN0eWxlcyA9IGBcbi5yZWFjdC1jb2xvcmZ1bF9faW50ZXJhY3RpdmUge1xuXHR3aWR0aDogY2FsYyggMTAwJSAtICR7IHNwYWNlKCAyICkgfSApO1xuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIDEgKSB9O1xufWA7XG5cbmV4cG9ydCBjb25zdCBBdXhpbGlhcnlDb2xvckFydGVmYWN0V3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6IDA7XG5cdHBhZGRpbmctbGVmdDogMDtcblx0cGFkZGluZy1ib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgQXV4aWxpYXJ5Q29sb3JBcnRlZmFjdEhTdGFja0hlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDQgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgQ29sb3JJbnB1dFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZy10b3A6ICR7IHNwYWNlKCA0ICkgfTtcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggNCApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAzICkgfTtcblx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCA1ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBDb2xvcmZ1bFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9O1xuXG5cdHdpZHRoOiAyMTZweDtcblxuXHQucmVhY3QtY29sb3JmdWwge1xuXHRcdGRpc3BsYXk6IGZsZXg7XG5cdFx0ZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdHdpZHRoOiAyMTZweDtcblx0XHRoZWlnaHQ6IGF1dG87XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX3NhdHVyYXRpb24ge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHRcdGJvcmRlci1yYWRpdXM6IDA7XG5cdFx0aGVpZ2h0OiAyMTZweDtcblx0XHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5cdFx0Ym9yZGVyLWJvdHRvbTogbm9uZTtcblx0fVxuXG5cdC5yZWFjdC1jb2xvcmZ1bF9faHVlLFxuXHQucmVhY3QtY29sb3JmdWxfX2FscGhhIHtcblx0XHR3aWR0aDogMTg0cHg7XG5cdFx0aGVpZ2h0OiAxNnB4O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDIgKSB9O1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyIHtcblx0XHRoZWlnaHQ6IDE2cHg7XG5cdFx0d2lkdGg6IDE2cHg7XG5cdFx0Ym9yZGVyOiBub25lO1xuXHRcdGJveC1zaGFkb3c6IDAgMCAycHggMCByZ2JhKCAwLCAwLCAwLCAwLjI1ICk7XG5cblx0XHQvLyBTaG93biBpbnN0ZWFkIG9mIGJveC1zaGFkb3cgdG8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXG5cdFx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0XHR0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gJHsgQ09ORklHLnRyYW5zaXRpb25EdXJhdGlvbkZhc3QgfSBlYXNlLWluLW91dDtcblx0XHR9XG5cdH1cblxuXHQucmVhY3QtY29sb3JmdWxfX2ludGVyYWN0aXZlOmZvY3VzIC5yZWFjdC1jb2xvcmZ1bF9fcG9pbnRlciB7XG5cdFx0Ym94LXNoYWRvdzogMCAwIDAgJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAkeyBDT05GSUcuc3VyZmFjZUNvbG9yIH07XG5cdFx0Ym9yZGVyOiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9IHNvbGlkIGJsYWNrO1xuXHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKCAtNTAlLCAtNTAlICkgc2NhbGUoIDEuNSApO1xuXHR9XG5cblx0LnJlYWN0LWNvbG9yZnVsX19wb2ludGVyLWZpbGwge1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gI2ZmZjtcblx0fVxuXG5cdCR7IGludGVyYWN0aXZlSHVlU3R5bGVzIH1cbmA7XG4iXX0= */")); 32310 32311 // packages/components/build-module/color-picker/color-copy-button.js 32312 var import_compose33 = __toESM(require_compose()); 32313 var import_element74 = __toESM(require_element()); 32314 var import_i18n14 = __toESM(require_i18n()); 32315 var import_jsx_runtime131 = __toESM(require_jsx_runtime()); 32316 var ColorCopyButton = (props) => { 32317 const { 32318 color: color2, 32319 colorType 32320 } = props; 32321 const [copiedColor, setCopiedColor] = (0, import_element74.useState)(null); 32322 const copyTimerRef = (0, import_element74.useRef)(); 32323 const copyRef = (0, import_compose33.useCopyToClipboard)(() => { 32324 switch (colorType) { 32325 case "hsl": { 32326 return color2.toHslString(); 32327 } 32328 case "rgb": { 32329 return color2.toRgbString(); 32330 } 32331 default: 32332 case "hex": { 32333 return color2.toHex(); 32334 } 32335 } 32336 }, () => { 32337 if (copyTimerRef.current) { 32338 clearTimeout(copyTimerRef.current); 32339 } 32340 setCopiedColor(color2.toHex()); 32341 copyTimerRef.current = setTimeout(() => { 32342 setCopiedColor(null); 32343 copyTimerRef.current = void 0; 32344 }, 3e3); 32345 }); 32346 (0, import_element74.useEffect)(() => { 32347 return () => { 32348 if (copyTimerRef.current) { 32349 clearTimeout(copyTimerRef.current); 32350 } 32351 }; 32352 }, []); 32353 const isCopied = copiedColor === color2.toHex(); 32354 const label = isCopied ? (0, import_i18n14.__)("Copied!") : (0, import_i18n14.__)("Copy"); 32355 return /* @__PURE__ */ (0, import_jsx_runtime131.jsx)(tooltip_default, { 32356 delay: 0, 32357 hideOnClick: false, 32358 text: label, 32359 children: /* @__PURE__ */ (0, import_jsx_runtime131.jsx)(Button3, { 32360 size: "compact", 32361 "aria-label": label, 32362 ref: copyRef, 32363 icon: isCopied ? check_default : copy_default, 32364 showTooltip: false 32365 }) 32366 }); 32367 }; 32368 32369 // packages/components/build-module/color-picker/input-with-slider.js 32370 var import_jsx_runtime132 = __toESM(require_jsx_runtime()); 32371 var InputWithSlider = ({ 32372 min: min3, 32373 max: max3, 32374 label, 32375 abbreviation, 32376 onChange, 32377 value 32378 }) => { 32379 const onNumberControlChange = (newValue) => { 32380 if (!newValue) { 32381 onChange(0); 32382 return; 32383 } 32384 if (typeof newValue === "string") { 32385 onChange(parseInt(newValue, 10)); 32386 return; 32387 } 32388 onChange(newValue); 32389 }; 32390 return /* @__PURE__ */ (0, import_jsx_runtime132.jsxs)(component_default9, { 32391 spacing: 4, 32392 children: [/* @__PURE__ */ (0, import_jsx_runtime132.jsx)(NumberControlWrapper, { 32393 __next40pxDefaultSize: true, 32394 min: min3, 32395 max: max3, 32396 label, 32397 hideLabelFromVision: true, 32398 value, 32399 onChange: onNumberControlChange, 32400 prefix: /* @__PURE__ */ (0, import_jsx_runtime132.jsx)(input_prefix_wrapper_default, { 32401 children: /* @__PURE__ */ (0, import_jsx_runtime132.jsx)(component_default8, { 32402 color: COLORS.theme.accent, 32403 lineHeight: 1, 32404 children: abbreviation 32405 }) 32406 }), 32407 spinControls: "none" 32408 }), /* @__PURE__ */ (0, import_jsx_runtime132.jsx)(RangeControl2, { 32409 __next40pxDefaultSize: true, 32410 label, 32411 hideLabelFromVision: true, 32412 min: min3, 32413 max: max3, 32414 value, 32415 onChange, 32416 withInputField: false 32417 })] 32418 }); 32419 }; 32420 32421 // packages/components/build-module/color-picker/rgb-input.js 32422 var import_jsx_runtime133 = __toESM(require_jsx_runtime()); 32423 var RgbInput = ({ 32424 color: color2, 32425 onChange, 32426 enableAlpha 32427 }) => { 32428 const { 32429 r: r4, 32430 g: g3, 32431 b: b3, 32432 a: a3 32433 } = color2.toRgb(); 32434 return /* @__PURE__ */ (0, import_jsx_runtime133.jsxs)(import_jsx_runtime133.Fragment, { 32435 children: [/* @__PURE__ */ (0, import_jsx_runtime133.jsx)(InputWithSlider, { 32436 min: 0, 32437 max: 255, 32438 label: "Red", 32439 abbreviation: "R", 32440 value: r4, 32441 onChange: (nextR) => onChange(w({ 32442 r: nextR, 32443 g: g3, 32444 b: b3, 32445 a: a3 32446 })) 32447 }), /* @__PURE__ */ (0, import_jsx_runtime133.jsx)(InputWithSlider, { 32448 min: 0, 32449 max: 255, 32450 label: "Green", 32451 abbreviation: "G", 32452 value: g3, 32453 onChange: (nextG) => onChange(w({ 32454 r: r4, 32455 g: nextG, 32456 b: b3, 32457 a: a3 32458 })) 32459 }), /* @__PURE__ */ (0, import_jsx_runtime133.jsx)(InputWithSlider, { 32460 min: 0, 32461 max: 255, 32462 label: "Blue", 32463 abbreviation: "B", 32464 value: b3, 32465 onChange: (nextB) => onChange(w({ 32466 r: r4, 32467 g: g3, 32468 b: nextB, 32469 a: a3 32470 })) 32471 }), enableAlpha && /* @__PURE__ */ (0, import_jsx_runtime133.jsx)(InputWithSlider, { 32472 min: 0, 32473 max: 100, 32474 label: "Alpha", 32475 abbreviation: "A", 32476 value: Math.trunc(a3 * 100), 32477 onChange: (nextA) => onChange(w({ 32478 r: r4, 32479 g: g3, 32480 b: b3, 32481 a: nextA / 100 32482 })) 32483 })] 32484 }); 32485 }; 32486 32487 // packages/components/build-module/color-picker/hsl-input.js 32488 var import_element75 = __toESM(require_element()); 32489 var import_jsx_runtime134 = __toESM(require_jsx_runtime()); 32490 var HslInput = ({ 32491 color: color2, 32492 onChange, 32493 enableAlpha 32494 }) => { 32495 const colorPropHSLA = (0, import_element75.useMemo)(() => color2.toHsl(), [color2]); 32496 const [internalHSLA, setInternalHSLA] = (0, import_element75.useState)({ 32497 ...colorPropHSLA 32498 }); 32499 const isInternalColorSameAsReceivedColor = color2.isEqual(w(internalHSLA)); 32500 (0, import_element75.useEffect)(() => { 32501 if (!isInternalColorSameAsReceivedColor) { 32502 setInternalHSLA(colorPropHSLA); 32503 } 32504 }, [colorPropHSLA, isInternalColorSameAsReceivedColor]); 32505 const colorValue = isInternalColorSameAsReceivedColor ? internalHSLA : colorPropHSLA; 32506 const updateHSLAValue = (partialNewValue) => { 32507 const nextOnChangeValue = w({ 32508 ...colorValue, 32509 ...partialNewValue 32510 }); 32511 if (!color2.isEqual(nextOnChangeValue)) { 32512 onChange(nextOnChangeValue); 32513 } else { 32514 setInternalHSLA((prevHSLA) => ({ 32515 ...prevHSLA, 32516 ...partialNewValue 32517 })); 32518 } 32519 }; 32520 return /* @__PURE__ */ (0, import_jsx_runtime134.jsxs)(import_jsx_runtime134.Fragment, { 32521 children: [/* @__PURE__ */ (0, import_jsx_runtime134.jsx)(InputWithSlider, { 32522 min: 0, 32523 max: 359, 32524 label: "Hue", 32525 abbreviation: "H", 32526 value: colorValue.h, 32527 onChange: (nextH) => { 32528 updateHSLAValue({ 32529 h: nextH 32530 }); 32531 } 32532 }), /* @__PURE__ */ (0, import_jsx_runtime134.jsx)(InputWithSlider, { 32533 min: 0, 32534 max: 100, 32535 label: "Saturation", 32536 abbreviation: "S", 32537 value: colorValue.s, 32538 onChange: (nextS) => { 32539 updateHSLAValue({ 32540 s: nextS 32541 }); 32542 } 32543 }), /* @__PURE__ */ (0, import_jsx_runtime134.jsx)(InputWithSlider, { 32544 min: 0, 32545 max: 100, 32546 label: "Lightness", 32547 abbreviation: "L", 32548 value: colorValue.l, 32549 onChange: (nextL) => { 32550 updateHSLAValue({ 32551 l: nextL 32552 }); 32553 } 32554 }), enableAlpha && /* @__PURE__ */ (0, import_jsx_runtime134.jsx)(InputWithSlider, { 32555 min: 0, 32556 max: 100, 32557 label: "Alpha", 32558 abbreviation: "A", 32559 value: Math.trunc(100 * colorValue.a), 32560 onChange: (nextA) => { 32561 updateHSLAValue({ 32562 a: nextA / 100 32563 }); 32564 } 32565 })] 32566 }); 32567 }; 32568 32569 // packages/components/build-module/color-picker/hex-input.js 32570 var import_i18n15 = __toESM(require_i18n()); 32571 var import_jsx_runtime135 = __toESM(require_jsx_runtime()); 32572 var HexInput = ({ 32573 color: color2, 32574 onChange, 32575 enableAlpha 32576 }) => { 32577 const handleChange = (nextValue) => { 32578 if (!nextValue) { 32579 return; 32580 } 32581 const hexValue = nextValue.startsWith("#") ? nextValue : "#" + nextValue; 32582 onChange(w(hexValue)); 32583 }; 32584 const stateReducer = (state, action) => { 32585 const nativeEvent = action.payload?.event?.nativeEvent; 32586 if ("insertFromPaste" !== nativeEvent?.inputType) { 32587 return { 32588 ...state 32589 }; 32590 } 32591 const value = state.value?.startsWith("#") ? state.value.slice(1).toUpperCase() : state.value?.toUpperCase(); 32592 return { 32593 ...state, 32594 value 32595 }; 32596 }; 32597 return /* @__PURE__ */ (0, import_jsx_runtime135.jsx)(InputControl, { 32598 prefix: /* @__PURE__ */ (0, import_jsx_runtime135.jsx)(input_prefix_wrapper_default, { 32599 children: /* @__PURE__ */ (0, import_jsx_runtime135.jsx)(component_default8, { 32600 color: COLORS.theme.accent, 32601 lineHeight: 1, 32602 children: "#" 32603 }) 32604 }), 32605 value: color2.toHex().slice(1).toUpperCase(), 32606 onChange: handleChange, 32607 maxLength: enableAlpha ? 9 : 7, 32608 label: (0, import_i18n15.__)("Hex color"), 32609 hideLabelFromVision: true, 32610 size: "__unstable-large", 32611 __unstableStateReducer: stateReducer, 32612 __unstableInputWidth: "9em" 32613 }); 32614 }; 32615 32616 // packages/components/build-module/color-picker/color-input.js 32617 var import_jsx_runtime136 = __toESM(require_jsx_runtime()); 32618 var ColorInput = ({ 32619 colorType, 32620 color: color2, 32621 onChange, 32622 enableAlpha 32623 }) => { 32624 const props = { 32625 color: color2, 32626 onChange, 32627 enableAlpha 32628 }; 32629 switch (colorType) { 32630 case "hsl": 32631 return /* @__PURE__ */ (0, import_jsx_runtime136.jsx)(HslInput, { 32632 ...props 32633 }); 32634 case "rgb": 32635 return /* @__PURE__ */ (0, import_jsx_runtime136.jsx)(RgbInput, { 32636 ...props 32637 }); 32638 default: 32639 case "hex": 32640 return /* @__PURE__ */ (0, import_jsx_runtime136.jsx)(HexInput, { 32641 ...props 32642 }); 32643 } 32644 }; 32645 32646 // node_modules/react-colorful/dist/index.module.js 32647 var import_react106 = __toESM(require_react()); 32648 function u2() { 32649 return (u2 = Object.assign || function(e3) { 32650 for (var r4 = 1; r4 < arguments.length; r4++) { 32651 var t4 = arguments[r4]; 32652 for (var o4 in t4) Object.prototype.hasOwnProperty.call(t4, o4) && (e3[o4] = t4[o4]); 32653 } 32654 return e3; 32655 }).apply(this, arguments); 32656 } 32657 function c2(e3, r4) { 32658 if (null == e3) return {}; 32659 var t4, o4, n3 = {}, a3 = Object.keys(e3); 32660 for (o4 = 0; o4 < a3.length; o4++) r4.indexOf(t4 = a3[o4]) >= 0 || (n3[t4] = e3[t4]); 32661 return n3; 32662 } 32663 function s2(e3) { 32664 var t4 = (0, import_react106.useRef)(e3), o4 = (0, import_react106.useRef)(function(e4) { 32665 t4.current && t4.current(e4); 32666 }); 32667 return t4.current = e3, o4.current; 32668 } 32669 var i2 = function(e3, r4, t4) { 32670 return void 0 === r4 && (r4 = 0), void 0 === t4 && (t4 = 1), e3 > t4 ? t4 : e3 < r4 ? r4 : e3; 32671 }; 32672 var f2 = function(e3) { 32673 return "touches" in e3; 32674 }; 32675 var v2 = function(e3, r4) { 32676 var t4 = e3.getBoundingClientRect(), o4 = f2(r4) ? r4.touches[0] : r4; 32677 return { left: i2((o4.pageX - (t4.left + window.pageXOffset)) / t4.width), top: i2((o4.pageY - (t4.top + window.pageYOffset)) / t4.height) }; 32678 }; 32679 var d2 = function(e3) { 32680 !f2(e3) && e3.preventDefault(); 32681 }; 32682 var h2 = import_react106.default.memo(function(n3) { 32683 var a3 = n3.onMove, l3 = n3.onKey, i3 = c2(n3, ["onMove", "onKey"]), h3 = (0, import_react106.useRef)(null), m3 = s2(a3), g3 = s2(l3), p3 = (0, import_react106.useRef)(false), b3 = (0, import_react106.useMemo)(function() { 32684 var e3 = function(e4) { 32685 d2(e4), (f2(e4) ? e4.touches.length > 0 : e4.buttons > 0) && h3.current ? m3(v2(h3.current, e4)) : t4(false); 32686 }, r4 = function() { 32687 return t4(false); 32688 }; 32689 function t4(t5) { 32690 var o4 = p3.current, n4 = t5 ? self.addEventListener : self.removeEventListener; 32691 n4(o4 ? "touchmove" : "mousemove", e3), n4(o4 ? "touchend" : "mouseup", r4); 32692 } 32693 return [function(e4) { 32694 var r5 = e4.nativeEvent, o4 = h3.current; 32695 o4 && (d2(r5), !(function(e5, r6) { 32696 return r6 && !f2(e5); 32697 })(r5, p3.current) && o4 && (p3.current = f2(r5), o4.focus(), m3(v2(o4, r5)), t4(true))); 32698 }, function(e4) { 32699 var r5 = e4.which || e4.keyCode; 32700 r5 < 37 || r5 > 40 || (e4.preventDefault(), g3({ left: 39 === r5 ? 0.05 : 37 === r5 ? -0.05 : 0, top: 40 === r5 ? 0.05 : 38 === r5 ? -0.05 : 0 })); 32701 }, t4]; 32702 }, [g3, m3]), _ = b3[0], C = b3[1], x2 = b3[2]; 32703 return (0, import_react106.useEffect)(function() { 32704 return x2; 32705 }, [x2]), import_react106.default.createElement("div", u2({}, i3, { onTouchStart: _, onMouseDown: _, className: "react-colorful__interactive", ref: h3, onKeyDown: C, tabIndex: 0, role: "slider" })); 32706 }); 32707 var m2 = function(e3) { 32708 return e3.filter(Boolean).join(" "); 32709 }; 32710 var g2 = function(r4) { 32711 var t4 = r4.color, o4 = r4.left, n3 = r4.top, a3 = void 0 === n3 ? 0.5 : n3, l3 = m2(["react-colorful__pointer", r4.className]); 32712 return import_react106.default.createElement("div", { className: l3, style: { top: 100 * a3 + "%", left: 100 * o4 + "%" } }, import_react106.default.createElement("div", { className: "react-colorful__pointer-fill", style: { backgroundColor: t4 } })); 32713 }; 32714 var p2 = function(e3, r4, t4) { 32715 return void 0 === r4 && (r4 = 0), void 0 === t4 && (t4 = Math.pow(10, r4)), Math.round(t4 * e3) / t4; 32716 }; 32717 var b2 = { grad: 0.9, turn: 360, rad: 360 / (2 * Math.PI) }; 32718 var M2 = function(e3) { 32719 var r4 = e3.s, t4 = e3.v, o4 = e3.a, n3 = (200 - r4) * t4 / 100; 32720 return { h: p2(e3.h), s: p2(n3 > 0 && n3 < 200 ? r4 * t4 / 100 / (n3 <= 100 ? n3 : 200 - n3) * 100 : 0), l: p2(n3 / 2), a: p2(o4, 2) }; 32721 }; 32722 var N2 = function(e3) { 32723 var r4 = M2(e3); 32724 return "hsl(" + r4.h + ", " + r4.s + "%, " + r4.l + "%)"; 32725 }; 32726 var w2 = function(e3) { 32727 var r4 = M2(e3); 32728 return "hsla(" + r4.h + ", " + r4.s + "%, " + r4.l + "%, " + r4.a + ")"; 32729 }; 32730 var y2 = function(e3) { 32731 var r4 = e3.h, t4 = e3.s, o4 = e3.v, n3 = e3.a; 32732 r4 = r4 / 360 * 6, t4 /= 100, o4 /= 100; 32733 var a3 = Math.floor(r4), l3 = o4 * (1 - t4), u3 = o4 * (1 - (r4 - a3) * t4), c3 = o4 * (1 - (1 - r4 + a3) * t4), s3 = a3 % 6; 32734 return { r: p2(255 * [o4, u3, l3, l3, c3, o4][s3]), g: p2(255 * [c3, o4, o4, u3, l3, l3][s3]), b: p2(255 * [l3, l3, c3, o4, o4, u3][s3]), a: p2(n3, 2) }; 32735 }; 32736 var O = function(e3) { 32737 var r4 = /rgba?\(?\s*(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?[,\s]+(-?\d*\.?\d+)(%)?,?\s*[/\s]*(-?\d*\.?\d+)?(%)?\s*\)?/i.exec(e3); 32738 return r4 ? z({ r: Number(r4[1]) / (r4[2] ? 100 / 255 : 1), g: Number(r4[3]) / (r4[4] ? 100 / 255 : 1), b: Number(r4[5]) / (r4[6] ? 100 / 255 : 1), a: void 0 === r4[7] ? 1 : Number(r4[7]) / (r4[8] ? 100 : 1) }) : { h: 0, s: 0, v: 0, a: 1 }; 32739 }; 32740 var I2 = O; 32741 var z = function(e3) { 32742 var r4 = e3.r, t4 = e3.g, o4 = e3.b, n3 = e3.a, a3 = Math.max(r4, t4, o4), l3 = a3 - Math.min(r4, t4, o4), u3 = l3 ? a3 === r4 ? (t4 - o4) / l3 : a3 === t4 ? 2 + (o4 - r4) / l3 : 4 + (r4 - t4) / l3 : 0; 32743 return { h: p2(60 * (u3 < 0 ? u3 + 6 : u3)), s: p2(a3 ? l3 / a3 * 100 : 0), v: p2(a3 / 255 * 100), a: n3 }; 32744 }; 32745 var K = import_react106.default.memo(function(r4) { 32746 var t4 = r4.hue, o4 = r4.onChange, n3 = m2(["react-colorful__hue", r4.className]); 32747 return import_react106.default.createElement("div", { className: n3 }, import_react106.default.createElement(h2, { onMove: function(e3) { 32748 o4({ h: 360 * e3.left }); 32749 }, onKey: function(e3) { 32750 o4({ h: i2(t4 + 360 * e3.left, 0, 360) }); 32751 }, "aria-label": "Hue", "aria-valuetext": p2(t4) }, import_react106.default.createElement(g2, { className: "react-colorful__hue-pointer", left: t4 / 360, color: N2({ h: t4, s: 100, v: 100, a: 1 }) }))); 32752 }); 32753 var A = import_react106.default.memo(function(r4) { 32754 var t4 = r4.hsva, o4 = r4.onChange, n3 = { backgroundColor: N2({ h: t4.h, s: 100, v: 100, a: 1 }) }; 32755 return import_react106.default.createElement("div", { className: "react-colorful__saturation", style: n3 }, import_react106.default.createElement(h2, { onMove: function(e3) { 32756 o4({ s: 100 * e3.left, v: 100 - 100 * e3.top }); 32757 }, onKey: function(e3) { 32758 o4({ s: i2(t4.s + 100 * e3.left, 0, 100), v: i2(t4.v - 100 * e3.top, 0, 100) }); 32759 }, "aria-label": "Color", "aria-valuetext": "Saturation " + p2(t4.s) + "%, Brightness " + p2(t4.v) + "%" }, import_react106.default.createElement(g2, { className: "react-colorful__saturation-pointer", top: 1 - t4.v / 100, left: t4.s / 100, color: N2(t4) }))); 32760 }); 32761 var L = function(e3, r4) { 32762 if (e3 === r4) return true; 32763 for (var t4 in e3) if (e3[t4] !== r4[t4]) return false; 32764 return true; 32765 }; 32766 var D = function(e3, r4) { 32767 return e3.replace(/\s/g, "") === r4.replace(/\s/g, ""); 32768 }; 32769 function F(e3, t4, l3) { 32770 var u3 = s2(l3), c3 = (0, import_react106.useState)(function() { 32771 return e3.toHsva(t4); 32772 }), i3 = c3[0], f3 = c3[1], v3 = (0, import_react106.useRef)({ color: t4, hsva: i3 }); 32773 (0, import_react106.useEffect)(function() { 32774 if (!e3.equal(t4, v3.current.color)) { 32775 var r4 = e3.toHsva(t4); 32776 v3.current = { hsva: r4, color: t4 }, f3(r4); 32777 } 32778 }, [t4, e3]), (0, import_react106.useEffect)(function() { 32779 var r4; 32780 L(i3, v3.current.hsva) || e3.equal(r4 = e3.fromHsva(i3), v3.current.color) || (v3.current = { hsva: i3, color: r4 }, u3(r4)); 32781 }, [i3, e3, u3]); 32782 var d3 = (0, import_react106.useCallback)(function(e4) { 32783 f3(function(r4) { 32784 return Object.assign({}, r4, e4); 32785 }); 32786 }, []); 32787 return [i3, d3]; 32788 } 32789 var S2; 32790 var P; 32791 var T = "undefined" != typeof window ? import_react106.useLayoutEffect : import_react106.useEffect; 32792 var X = function() { 32793 return S2 || ("undefined" != typeof __webpack_nonce__ ? __webpack_nonce__ : void 0); 32794 }; 32795 var $2 = function() { 32796 T(function() { 32797 if ("undefined" != typeof document && !P) { 32798 (P = document.createElement("style")).innerHTML = `.react-colorful{position:relative;display:flex;flex-direction:column;width:200px;height:200px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:default}.react-colorful__saturation{position:relative;flex-grow:1;border-color:transparent;border-bottom:12px solid #000;border-radius:8px 8px 0 0;background-image:linear-gradient(0deg,#000,transparent),linear-gradient(90deg,#fff,hsla(0,0%,100%,0))}.react-colorful__alpha-gradient,.react-colorful__pointer-fill{content:"";position:absolute;left:0;top:0;right:0;bottom:0;pointer-events:none;border-radius:inherit}.react-colorful__alpha-gradient,.react-colorful__saturation{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}.react-colorful__alpha,.react-colorful__hue{position:relative;height:24px}.react-colorful__hue{background:linear-gradient(90deg,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red)}.react-colorful__last-control{border-radius:0 0 8px 8px}.react-colorful__interactive{position:absolute;left:0;top:0;right:0;bottom:0;border-radius:inherit;outline:none;touch-action:none}.react-colorful__pointer{position:absolute;z-index:1;box-sizing:border-box;width:28px;height:28px;transform:translate(-50%,-50%);background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2)}.react-colorful__interactive:focus .react-colorful__pointer{transform:translate(-50%,-50%) scale(1.1)}.react-colorful__alpha,.react-colorful__alpha-pointer{background-color:#fff;background-image:url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill-opacity=".05"><path d="M8 0h8v8H8zM0 8h8v8H0z"/></svg>')}.react-colorful__saturation-pointer{z-index:3}.react-colorful__hue-pointer{z-index:2}`; 32799 var e3 = X(); 32800 e3 && P.setAttribute("nonce", e3), document.head.appendChild(P); 32801 } 32802 }, []); 32803 }; 32804 var R = function(r4) { 32805 var t4 = r4.className, o4 = r4.colorModel, n3 = r4.color, a3 = void 0 === n3 ? o4.defaultColor : n3, l3 = r4.onChange, s3 = c2(r4, ["className", "colorModel", "color", "onChange"]); 32806 $2(); 32807 var i3 = F(o4, a3, l3), f3 = i3[0], v3 = i3[1], d3 = m2(["react-colorful", t4]); 32808 return import_react106.default.createElement("div", u2({}, s3, { className: d3 }), import_react106.default.createElement(A, { hsva: f3, onChange: v3 }), import_react106.default.createElement(K, { hue: f3.h, onChange: v3, className: "react-colorful__last-control" })); 32809 }; 32810 var Q = function(r4) { 32811 var t4 = r4.className, o4 = r4.hsva, n3 = r4.onChange, a3 = { backgroundImage: "linear-gradient(90deg, " + w2(Object.assign({}, o4, { a: 0 })) + ", " + w2(Object.assign({}, o4, { a: 1 })) + ")" }, l3 = m2(["react-colorful__alpha", t4]); 32812 return import_react106.default.createElement("div", { className: l3 }, import_react106.default.createElement("div", { className: "react-colorful__alpha-gradient", style: a3 }), import_react106.default.createElement(h2, { onMove: function(e3) { 32813 n3({ a: e3.left }); 32814 }, onKey: function(e3) { 32815 n3({ a: i2(o4.a + e3.left) }); 32816 }, "aria-label": "Alpha", "aria-valuetext": p2(100 * o4.a) + "%" }, import_react106.default.createElement(g2, { className: "react-colorful__alpha-pointer", left: o4.a, color: w2(o4) }))); 32817 }; 32818 var U = function(r4) { 32819 var t4 = r4.className, o4 = r4.colorModel, n3 = r4.color, a3 = void 0 === n3 ? o4.defaultColor : n3, l3 = r4.onChange, s3 = c2(r4, ["className", "colorModel", "color", "onChange"]); 32820 $2(); 32821 var i3 = F(o4, a3, l3), f3 = i3[0], v3 = i3[1], d3 = m2(["react-colorful", t4]); 32822 return import_react106.default.createElement("div", u2({}, s3, { className: d3 }), import_react106.default.createElement(A, { hsva: f3, onChange: v3 }), import_react106.default.createElement(K, { hue: f3.h, onChange: v3 }), import_react106.default.createElement(Q, { hsva: f3, onChange: v3, className: "react-colorful__last-control" })); 32823 }; 32824 var me = { defaultColor: "rgba(0, 0, 0, 1)", toHsva: O, fromHsva: function(e3) { 32825 var r4 = y2(e3); 32826 return "rgba(" + r4.r + ", " + r4.g + ", " + r4.b + ", " + r4.a + ")"; 32827 }, equal: D }; 32828 var ge = function(r4) { 32829 return import_react106.default.createElement(U, u2({}, r4, { colorModel: me })); 32830 }; 32831 var _e = { defaultColor: "rgb(0, 0, 0)", toHsva: I2, fromHsva: function(e3) { 32832 var r4 = y2(e3); 32833 return "rgb(" + r4.r + ", " + r4.g + ", " + r4.b + ")"; 32834 }, equal: D }; 32835 var Ce = function(r4) { 32836 return import_react106.default.createElement(R, u2({}, r4, { colorModel: _e })); 32837 }; 32838 32839 // packages/components/build-module/color-picker/picker.js 32840 var import_element76 = __toESM(require_element()); 32841 var import_jsx_runtime137 = __toESM(require_jsx_runtime()); 32842 var Picker = ({ 32843 color: color2, 32844 enableAlpha, 32845 onChange 32846 }) => { 32847 const Component9 = enableAlpha ? ge : Ce; 32848 const rgbColor = (0, import_element76.useMemo)(() => color2.toRgbString(), [color2]); 32849 return /* @__PURE__ */ (0, import_jsx_runtime137.jsx)(Component9, { 32850 color: rgbColor, 32851 onChange: (nextColor) => { 32852 onChange(w(nextColor)); 32853 }, 32854 onPointerDown: ({ 32855 currentTarget, 32856 pointerId: pointerId2 32857 }) => { 32858 currentTarget.setPointerCapture(pointerId2); 32859 }, 32860 onPointerUp: ({ 32861 currentTarget, 32862 pointerId: pointerId2 32863 }) => { 32864 currentTarget.releasePointerCapture(pointerId2); 32865 } 32866 }); 32867 }; 32868 32869 // packages/components/build-module/color-picker/component.js 32870 var import_jsx_runtime138 = __toESM(require_jsx_runtime()); 32871 k([names_default]); 32872 var options = [{ 32873 label: "RGB", 32874 value: "rgb" 32875 }, { 32876 label: "HSL", 32877 value: "hsl" 32878 }, { 32879 label: "Hex", 32880 value: "hex" 32881 }]; 32882 var UnconnectedColorPicker = (props, forwardedRef) => { 32883 const { 32884 enableAlpha = false, 32885 color: colorProp, 32886 onChange, 32887 defaultValue: defaultValue2 = "#fff", 32888 copyFormat, 32889 ...divProps 32890 } = useContextSystem(props, "ColorPicker"); 32891 const [color2, setColor] = useControlledValue({ 32892 onChange, 32893 value: colorProp, 32894 defaultValue: defaultValue2 32895 }); 32896 const safeColordColor = (0, import_element77.useMemo)(() => { 32897 return w(color2 || ""); 32898 }, [color2]); 32899 const debouncedSetColor = (0, import_compose34.useDebounce)(setColor); 32900 const handleChange = (0, import_element77.useCallback)((nextValue) => { 32901 debouncedSetColor(nextValue.toHex()); 32902 }, [debouncedSetColor]); 32903 const [colorType, setColorType] = (0, import_element77.useState)(copyFormat || "hex"); 32904 const maybeHandlePaste = (0, import_element77.useCallback)((event) => { 32905 const pastedText = event.clipboardData?.getData("text")?.trim(); 32906 if (!pastedText) { 32907 return; 32908 } 32909 const parsedColor = w(pastedText); 32910 if (!parsedColor.isValid()) { 32911 return; 32912 } 32913 handleChange(parsedColor); 32914 const supportedFormats = { 32915 hex: "hex", 32916 rgb: "rgb", 32917 hsl: "hsl" 32918 }; 32919 const detectedFormat = String(I(pastedText)); 32920 const newColorType = supportedFormats[detectedFormat]; 32921 if (newColorType) { 32922 setColorType(newColorType); 32923 } 32924 event.stopPropagation(); 32925 event.preventDefault(); 32926 }, [handleChange, setColorType]); 32927 return /* @__PURE__ */ (0, import_jsx_runtime138.jsxs)(ColorfulWrapper, { 32928 ref: forwardedRef, 32929 ...divProps, 32930 onPasteCapture: maybeHandlePaste, 32931 children: [/* @__PURE__ */ (0, import_jsx_runtime138.jsx)(Picker, { 32932 onChange: handleChange, 32933 color: safeColordColor, 32934 enableAlpha 32935 }), /* @__PURE__ */ (0, import_jsx_runtime138.jsxs)(AuxiliaryColorArtefactWrapper, { 32936 children: [/* @__PURE__ */ (0, import_jsx_runtime138.jsxs)(AuxiliaryColorArtefactHStackHeader, { 32937 justify: "space-between", 32938 children: [/* @__PURE__ */ (0, import_jsx_runtime138.jsx)(SelectControl2, { 32939 size: "compact", 32940 options, 32941 value: colorType, 32942 onChange: (nextColorType) => setColorType(nextColorType), 32943 label: (0, import_i18n16.__)("Color format"), 32944 hideLabelFromVision: true, 32945 variant: "minimal" 32946 }), /* @__PURE__ */ (0, import_jsx_runtime138.jsx)(ColorCopyButton, { 32947 color: safeColordColor, 32948 colorType: copyFormat || colorType 32949 })] 32950 }), /* @__PURE__ */ (0, import_jsx_runtime138.jsx)(ColorInputWrapper, { 32951 direction: "column", 32952 gap: 2, 32953 children: /* @__PURE__ */ (0, import_jsx_runtime138.jsx)(ColorInput, { 32954 colorType, 32955 color: safeColordColor, 32956 onChange: handleChange, 32957 enableAlpha 32958 }) 32959 })] 32960 })] 32961 }); 32962 }; 32963 var ColorPicker = contextConnect(UnconnectedColorPicker, "ColorPicker"); 32964 var component_default17 = ColorPicker; 32965 32966 // packages/components/build-module/color-picker/use-deprecated-props.js 32967 var import_element78 = __toESM(require_element()); 32968 function isLegacyProps(props) { 32969 return typeof props.onChangeComplete !== "undefined" || typeof props.disableAlpha !== "undefined" || typeof props.color?.hex === "string"; 32970 } 32971 function getColorFromLegacyProps(color2) { 32972 if (color2 === void 0) { 32973 return; 32974 } 32975 if (typeof color2 === "string") { 32976 return color2; 32977 } 32978 if (color2.hex) { 32979 return color2.hex; 32980 } 32981 return void 0; 32982 } 32983 var transformColorStringToLegacyColor = memize((color2) => { 32984 const colordColor = w(color2); 32985 const hex2 = colordColor.toHex(); 32986 const rgb = colordColor.toRgb(); 32987 const hsv = colordColor.toHsv(); 32988 const hsl = colordColor.toHsl(); 32989 return { 32990 hex: hex2, 32991 rgb, 32992 hsv, 32993 hsl, 32994 source: "hex", 32995 oldHue: hsl.h 32996 }; 32997 }); 32998 function useDeprecatedProps3(props) { 32999 const { 33000 onChangeComplete 33001 } = props; 33002 const legacyChangeHandler = (0, import_element78.useCallback)((color2) => { 33003 onChangeComplete(transformColorStringToLegacyColor(color2)); 33004 }, [onChangeComplete]); 33005 if (isLegacyProps(props)) { 33006 return { 33007 color: getColorFromLegacyProps(props.color), 33008 enableAlpha: !props.disableAlpha, 33009 onChange: legacyChangeHandler 33010 }; 33011 } 33012 return { 33013 ...props, 33014 color: props.color, 33015 enableAlpha: props.enableAlpha, 33016 onChange: props.onChange 33017 }; 33018 } 33019 33020 // packages/components/build-module/color-picker/legacy-adapter.js 33021 var import_jsx_runtime139 = __toESM(require_jsx_runtime()); 33022 var LegacyAdapter = (props) => { 33023 return /* @__PURE__ */ (0, import_jsx_runtime139.jsx)(component_default17, { 33024 ...useDeprecatedProps3(props) 33025 }); 33026 }; 33027 33028 // packages/components/build-module/circular-option-picker/circular-option-picker.js 33029 var import_compose36 = __toESM(require_compose()); 33030 var import_i18n17 = __toESM(require_i18n()); 33031 var import_element81 = __toESM(require_element()); 33032 33033 // packages/components/build-module/circular-option-picker/circular-option-picker-context.js 33034 var import_element79 = __toESM(require_element()); 33035 var CircularOptionPickerContext = (0, import_element79.createContext)({}); 33036 CircularOptionPickerContext.displayName = "CircularOptionPickerContext"; 33037 33038 // packages/components/build-module/circular-option-picker/circular-option-picker-option.js 33039 var import_compose35 = __toESM(require_compose()); 33040 var import_element80 = __toESM(require_element()); 33041 var import_jsx_runtime140 = __toESM(require_jsx_runtime()); 33042 function UnforwardedOptionAsButton(props, forwardedRef) { 33043 const { 33044 isPressed, 33045 label, 33046 ...additionalProps 33047 } = props; 33048 return /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(button_default, { 33049 ...additionalProps, 33050 "aria-pressed": isPressed, 33051 ref: forwardedRef, 33052 label 33053 }); 33054 } 33055 var OptionAsButton = (0, import_element80.forwardRef)(UnforwardedOptionAsButton); 33056 function UnforwardedOptionAsOption(props, forwardedRef) { 33057 const { 33058 id: id3, 33059 isSelected: isSelected2, 33060 label, 33061 ...additionalProps 33062 } = props; 33063 const { 33064 setActiveId, 33065 activeId 33066 } = (0, import_element80.useContext)(CircularOptionPickerContext); 33067 (0, import_element80.useEffect)(() => { 33068 if (isSelected2 && !activeId) { 33069 window.setTimeout(() => setActiveId?.(id3), 0); 33070 } 33071 }, [isSelected2, setActiveId, activeId, id3]); 33072 return /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(Composite22.Item, { 33073 render: /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(button_default, { 33074 ...additionalProps, 33075 role: "option", 33076 "aria-selected": !!isSelected2, 33077 ref: forwardedRef, 33078 label 33079 }), 33080 id: id3 33081 }); 33082 } 33083 var OptionAsOption = (0, import_element80.forwardRef)(UnforwardedOptionAsOption); 33084 function Option({ 33085 className: className2, 33086 isSelected: isSelected2, 33087 selectedIconProps = {}, 33088 tooltipText, 33089 ...additionalProps 33090 }) { 33091 const { 33092 baseId, 33093 setActiveId 33094 } = (0, import_element80.useContext)(CircularOptionPickerContext); 33095 const id3 = (0, import_compose35.useInstanceId)(Option, baseId || "components-circular-option-picker__option"); 33096 const commonProps = { 33097 id: id3, 33098 className: "components-circular-option-picker__option", 33099 __next40pxDefaultSize: true, 33100 ...additionalProps 33101 }; 33102 const isListbox = setActiveId !== void 0; 33103 const optionControl = isListbox ? /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(OptionAsOption, { 33104 ...commonProps, 33105 label: tooltipText, 33106 isSelected: isSelected2 33107 }) : /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(OptionAsButton, { 33108 ...commonProps, 33109 label: tooltipText, 33110 isPressed: isSelected2 33111 }); 33112 return /* @__PURE__ */ (0, import_jsx_runtime140.jsxs)("div", { 33113 className: clsx_default(className2, "components-circular-option-picker__option-wrapper"), 33114 children: [optionControl, isSelected2 && /* @__PURE__ */ (0, import_jsx_runtime140.jsx)(icon_default2, { 33115 icon: check_default, 33116 ...selectedIconProps 33117 })] 33118 }); 33119 } 33120 33121 // packages/components/build-module/circular-option-picker/circular-option-picker-option-group.js 33122 var import_jsx_runtime141 = __toESM(require_jsx_runtime()); 33123 function OptionGroup({ 33124 className: className2, 33125 options: options2, 33126 ...additionalProps 33127 }) { 33128 const role = "aria-label" in additionalProps || "aria-labelledby" in additionalProps ? "group" : void 0; 33129 return /* @__PURE__ */ (0, import_jsx_runtime141.jsx)("div", { 33130 ...additionalProps, 33131 role, 33132 className: clsx_default("components-circular-option-picker__option-group", "components-circular-option-picker__swatches", className2), 33133 children: options2 33134 }); 33135 } 33136 33137 // packages/components/build-module/circular-option-picker/circular-option-picker-actions.js 33138 var import_jsx_runtime142 = __toESM(require_jsx_runtime()); 33139 function DropdownLinkAction({ 33140 buttonProps, 33141 className: className2, 33142 dropdownProps, 33143 linkText 33144 }) { 33145 return /* @__PURE__ */ (0, import_jsx_runtime142.jsx)(dropdown_default, { 33146 className: clsx_default("components-circular-option-picker__dropdown-link-action", className2), 33147 renderToggle: ({ 33148 isOpen, 33149 onToggle 33150 }) => /* @__PURE__ */ (0, import_jsx_runtime142.jsx)(button_default, { 33151 "aria-expanded": isOpen, 33152 "aria-haspopup": "true", 33153 onClick: onToggle, 33154 variant: "link", 33155 ...buttonProps, 33156 children: linkText 33157 }), 33158 ...dropdownProps 33159 }); 33160 } 33161 function ButtonAction({ 33162 className: className2, 33163 children, 33164 ...additionalProps 33165 }) { 33166 return /* @__PURE__ */ (0, import_jsx_runtime142.jsx)(button_default, { 33167 __next40pxDefaultSize: true, 33168 className: clsx_default("components-circular-option-picker__clear", className2), 33169 variant: "tertiary", 33170 ...additionalProps, 33171 children 33172 }); 33173 } 33174 33175 // packages/components/build-module/circular-option-picker/circular-option-picker.js 33176 var import_jsx_runtime143 = __toESM(require_jsx_runtime()); 33177 function ListboxCircularOptionPicker(props) { 33178 const { 33179 actions, 33180 options: options2, 33181 baseId, 33182 className: className2, 33183 loop = true, 33184 children, 33185 ...additionalProps 33186 } = props; 33187 const [activeId, setActiveId] = (0, import_element81.useState)(void 0); 33188 const contextValue = (0, import_element81.useMemo)(() => ({ 33189 baseId, 33190 activeId, 33191 setActiveId 33192 }), [baseId, activeId, setActiveId]); 33193 return /* @__PURE__ */ (0, import_jsx_runtime143.jsx)("div", { 33194 className: className2, 33195 children: /* @__PURE__ */ (0, import_jsx_runtime143.jsxs)(CircularOptionPickerContext.Provider, { 33196 value: contextValue, 33197 children: [/* @__PURE__ */ (0, import_jsx_runtime143.jsx)(Composite22, { 33198 ...additionalProps, 33199 id: baseId, 33200 focusLoop: loop, 33201 rtl: (0, import_i18n17.isRTL)(), 33202 role: "listbox", 33203 activeId, 33204 setActiveId, 33205 children: options2 33206 }), children, actions] 33207 }) 33208 }); 33209 } 33210 function ButtonsCircularOptionPicker(props) { 33211 const { 33212 actions, 33213 options: options2, 33214 children, 33215 baseId, 33216 ...additionalProps 33217 } = props; 33218 const contextValue = (0, import_element81.useMemo)(() => ({ 33219 baseId 33220 }), [baseId]); 33221 return /* @__PURE__ */ (0, import_jsx_runtime143.jsx)("div", { 33222 ...additionalProps, 33223 role: "group", 33224 id: baseId, 33225 children: /* @__PURE__ */ (0, import_jsx_runtime143.jsxs)(CircularOptionPickerContext.Provider, { 33226 value: contextValue, 33227 children: [options2, children, actions] 33228 }) 33229 }); 33230 } 33231 function CircularOptionPicker(props) { 33232 const { 33233 asButtons, 33234 actions: actionsProp, 33235 options: optionsProp, 33236 children, 33237 className: className2, 33238 ...additionalProps 33239 } = props; 33240 const baseId = (0, import_compose36.useInstanceId)(CircularOptionPicker, "components-circular-option-picker", additionalProps.id); 33241 const OptionPickerImplementation = asButtons ? ButtonsCircularOptionPicker : ListboxCircularOptionPicker; 33242 const actions = actionsProp ? /* @__PURE__ */ (0, import_jsx_runtime143.jsx)("div", { 33243 className: "components-circular-option-picker__custom-clear-wrapper", 33244 children: actionsProp 33245 }) : void 0; 33246 const options2 = /* @__PURE__ */ (0, import_jsx_runtime143.jsx)("div", { 33247 className: "components-circular-option-picker__swatches", 33248 children: optionsProp 33249 }); 33250 return /* @__PURE__ */ (0, import_jsx_runtime143.jsx)(OptionPickerImplementation, { 33251 ...additionalProps, 33252 baseId, 33253 className: clsx_default("components-circular-option-picker", className2), 33254 actions, 33255 options: options2, 33256 children 33257 }); 33258 } 33259 CircularOptionPicker.Option = Option; 33260 CircularOptionPicker.OptionGroup = OptionGroup; 33261 CircularOptionPicker.ButtonAction = ButtonAction; 33262 CircularOptionPicker.DropdownLinkAction = DropdownLinkAction; 33263 var circular_option_picker_default = CircularOptionPicker; 33264 33265 // packages/components/build-module/circular-option-picker/utils.js 33266 var import_i18n18 = __toESM(require_i18n()); 33267 function getComputeCircularOptionPickerCommonProps(asButtons, loop, ariaLabel, ariaLabelledby) { 33268 const metaProps = asButtons ? { 33269 asButtons: true 33270 } : { 33271 asButtons: false, 33272 loop 33273 }; 33274 const labelProps = { 33275 "aria-labelledby": ariaLabelledby, 33276 "aria-label": ariaLabelledby ? void 0 : ariaLabel || (0, import_i18n18.__)("Custom color picker") 33277 }; 33278 return { 33279 metaProps, 33280 labelProps 33281 }; 33282 } 33283 33284 // packages/components/build-module/circular-option-picker/index.js 33285 var circular_option_picker_default2 = circular_option_picker_default; 33286 33287 // packages/components/build-module/v-stack/hook.js 33288 function useVStack(props) { 33289 const { 33290 expanded = false, 33291 alignment = "stretch", 33292 ...otherProps 33293 } = useContextSystem(props, "VStack"); 33294 const hStackProps = useHStack({ 33295 direction: "column", 33296 expanded, 33297 alignment, 33298 ...otherProps 33299 }); 33300 return hStackProps; 33301 } 33302 33303 // packages/components/build-module/v-stack/component.js 33304 var import_jsx_runtime144 = __toESM(require_jsx_runtime()); 33305 function UnconnectedVStack(props, forwardedRef) { 33306 const vStackProps = useVStack(props); 33307 return /* @__PURE__ */ (0, import_jsx_runtime144.jsx)(component_default, { 33308 ...vStackProps, 33309 ref: forwardedRef 33310 }); 33311 } 33312 var VStack = contextConnect(UnconnectedVStack, "VStack"); 33313 var component_default18 = VStack; 33314 33315 // packages/components/build-module/heading/hook.js 33316 function useHeading(props) { 33317 const { 33318 as: asProp, 33319 level = 2, 33320 color: color2 = COLORS.theme.foreground, 33321 isBlock = true, 33322 weight = config_values_default.fontWeightHeading, 33323 ...otherProps 33324 } = useContextSystem(props, "Heading"); 33325 const as = asProp || `h$level}`; 33326 const a11yProps = {}; 33327 if (typeof as === "string" && as[0] !== "h") { 33328 a11yProps.role = "heading"; 33329 a11yProps["aria-level"] = typeof level === "string" ? parseInt(level) : level; 33330 } 33331 const textProps = useText({ 33332 color: color2, 33333 isBlock, 33334 weight, 33335 size: getHeadingFontSize(level), 33336 ...otherProps 33337 }); 33338 return { 33339 ...textProps, 33340 ...a11yProps, 33341 as 33342 }; 33343 } 33344 33345 // packages/components/build-module/heading/component.js 33346 var import_jsx_runtime145 = __toESM(require_jsx_runtime()); 33347 function UnconnectedHeading(props, forwardedRef) { 33348 const headerProps = useHeading(props); 33349 return /* @__PURE__ */ (0, import_jsx_runtime145.jsx)(component_default, { 33350 ...headerProps, 33351 ref: forwardedRef 33352 }); 33353 } 33354 var Heading = contextConnect(UnconnectedHeading, "Heading"); 33355 var component_default19 = Heading; 33356 33357 // packages/components/build-module/color-palette/styles.js 33358 var ColorHeading = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default19, false ? { 33359 target: "ev9wop70" 33360 } : { 33361 target: "ev9wop70", 33362 label: "ColorHeading" 33363 })("text-transform:uppercase;line-height:24px;font-weight:", config_values_default.fontWeightMedium, ";&&&{font-size:11px;margin-bottom:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXNkMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb2xvckhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6IDI0cHg7XG5cdGZvbnQtd2VpZ2h0OiAkeyBDT05GSUcuZm9udFdlaWdodE1lZGl1bSB9O1xuXHQmJiYge1xuXHRcdGZvbnQtc2l6ZTogMTFweDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuIl19 */")); 33364 33365 // packages/components/build-module/dropdown/styles.js 33366 var padding = ({ 33367 paddingSize = "small" 33368 }) => { 33369 if (paddingSize === "none") { 33370 return; 33371 } 33372 const paddingValues = { 33373 small: space(2), 33374 medium: space(4) 33375 }; 33376 return /* @__PURE__ */ css("padding:", paddingValues[paddingSize] || paddingValues.small, ";" + (false ? "" : ";label:padding;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQlciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB0eXBlIHsgRHJvcGRvd25Db250ZW50V3JhcHBlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IHBhZGRpbmcgPSAoIHsgcGFkZGluZ1NpemUgPSAnc21hbGwnIH06IERyb3Bkb3duQ29udGVudFdyYXBwZXJQcm9wcyApID0+IHtcblx0aWYgKCBwYWRkaW5nU2l6ZSA9PT0gJ25vbmUnICkge1xuXHRcdHJldHVybjtcblx0fVxuXG5cdGNvbnN0IHBhZGRpbmdWYWx1ZXMgPSB7XG5cdFx0c21hbGw6IHNwYWNlKCAyICksXG5cdFx0bWVkaXVtOiBzcGFjZSggNCApLFxuXHR9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1ZhbHVlc1sgcGFkZGluZ1NpemUgXSB8fCBwYWRkaW5nVmFsdWVzLnNtYWxsIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgRHJvcGRvd25Db250ZW50V3JhcHBlckRpdiA9IHN0eWxlZC5kaXY8IERyb3Bkb3duQ29udGVudFdyYXBwZXJQcm9wcyA+YFxuXHQvLyBOZWdhdGl2ZSBtYXJnaW4gdG8gcmVzZXQgKG9mZnNldCkgdGhlIGRlZmF1bHQgcGFkZGluZyBvbiAuY29tcG9uZW50cy1wb3BvdmVyX19jb250ZW50XG5cdG1hcmdpbi1sZWZ0OiAkeyBzcGFjZSggLTIgKSB9O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAtMiApIH07XG5cdCY6Zmlyc3Qtb2YtdHlwZSB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIC0yICkgfTtcblx0fVxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIC0yICkgfTtcblx0fVxuXG5cdCR7IHBhZGRpbmcgfTtcbmA7XG4iXX0= */"); 33377 }; 33378 var DropdownContentWrapperDiv = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 33379 target: "eovvns30" 33380 } : { 33381 target: "eovvns30", 33382 label: "DropdownContentWrapperDiv" 33383 })("margin-left:", space(-2), ";margin-right:", space(-2), ";&:first-of-type{margin-top:", space(-2), ";}&:last-of-type{margin-bottom:", space(-2), ";}", padding, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmtGIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IERyb3Bkb3duQ29udGVudFdyYXBwZXJQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBwYWRkaW5nID0gKCB7IHBhZGRpbmdTaXplID0gJ3NtYWxsJyB9OiBEcm9wZG93bkNvbnRlbnRXcmFwcGVyUHJvcHMgKSA9PiB7XG5cdGlmICggcGFkZGluZ1NpemUgPT09ICdub25lJyApIHtcblx0XHRyZXR1cm47XG5cdH1cblxuXHRjb25zdCBwYWRkaW5nVmFsdWVzID0ge1xuXHRcdHNtYWxsOiBzcGFjZSggMiApLFxuXHRcdG1lZGl1bTogc3BhY2UoIDQgKSxcblx0fTtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdWYWx1ZXNbIHBhZGRpbmdTaXplIF0gfHwgcGFkZGluZ1ZhbHVlcy5zbWFsbCB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IERyb3Bkb3duQ29udGVudFdyYXBwZXJEaXYgPSBzdHlsZWQuZGl2PCBEcm9wZG93bkNvbnRlbnRXcmFwcGVyUHJvcHMgPmBcblx0Ly8gTmVnYXRpdmUgbWFyZ2luIHRvIHJlc2V0IChvZmZzZXQpIHRoZSBkZWZhdWx0IHBhZGRpbmcgb24gLmNvbXBvbmVudHMtcG9wb3Zlcl9fY29udGVudFxuXHRtYXJnaW4tbGVmdDogJHsgc3BhY2UoIC0yICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggLTIgKSB9O1xuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMiApIH07XG5cdH1cblx0JjpsYXN0LW9mLXR5cGUge1xuXHRcdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAtMiApIH07XG5cdH1cblxuXHQkeyBwYWRkaW5nIH07XG5gO1xuIl19 */")); 33384 33385 // packages/components/build-module/dropdown/dropdown-content-wrapper.js 33386 var import_jsx_runtime146 = __toESM(require_jsx_runtime()); 33387 function UnconnectedDropdownContentWrapper(props, forwardedRef) { 33388 const { 33389 paddingSize = "small", 33390 ...derivedProps 33391 } = useContextSystem(props, "DropdownContentWrapper"); 33392 return /* @__PURE__ */ (0, import_jsx_runtime146.jsx)(DropdownContentWrapperDiv, { 33393 ...derivedProps, 33394 paddingSize, 33395 ref: forwardedRef 33396 }); 33397 } 33398 var DropdownContentWrapper = contextConnect(UnconnectedDropdownContentWrapper, "DropdownContentWrapper"); 33399 var dropdown_content_wrapper_default = DropdownContentWrapper; 33400 33401 // packages/components/build-module/color-palette/utils.js 33402 var import_i18n19 = __toESM(require_i18n()); 33403 k([names_default, a11y_default]); 33404 var isSimpleCSSColor = (value) => { 33405 const valueIsCssVariable = /var\(/.test(value !== null && value !== void 0 ? value : ""); 33406 const valueIsColorMix = /color-mix\(/.test(value !== null && value !== void 0 ? value : ""); 33407 return !valueIsCssVariable && !valueIsColorMix; 33408 }; 33409 var extractColorNameFromCurrentValue = (currentValue, colors = [], showMultiplePalettes = false) => { 33410 if (!currentValue) { 33411 return ""; 33412 } 33413 const currentValueIsSimpleColor = currentValue ? isSimpleCSSColor(currentValue) : false; 33414 const normalizedCurrentValue = currentValueIsSimpleColor ? w(currentValue).toHex() : currentValue; 33415 const colorPalettes = showMultiplePalettes ? colors : [{ 33416 colors 33417 }]; 33418 for (const { 33419 colors: paletteColors 33420 } of colorPalettes) { 33421 for (const { 33422 name: colorName, 33423 color: colorValue 33424 } of paletteColors) { 33425 const normalizedColorValue = currentValueIsSimpleColor ? w(colorValue).toHex() : colorValue; 33426 if (normalizedCurrentValue === normalizedColorValue) { 33427 return colorName; 33428 } 33429 } 33430 } 33431 return (0, import_i18n19.__)("Custom"); 33432 }; 33433 var isMultiplePaletteObject = (obj) => Array.isArray(obj.colors) && !("color" in obj); 33434 var isMultiplePaletteArray = (arr) => { 33435 return arr.length > 0 && arr.every((colorObj) => isMultiplePaletteObject(colorObj)); 33436 }; 33437 var normalizeColorValue = (value, element) => { 33438 if (!value || !element || isSimpleCSSColor(value)) { 33439 return value; 33440 } 33441 const { 33442 ownerDocument 33443 } = element; 33444 const { 33445 defaultView 33446 } = ownerDocument; 33447 const computedBackgroundColor = defaultView?.getComputedStyle(element).backgroundColor; 33448 return computedBackgroundColor ? w(computedBackgroundColor).toHex() : value; 33449 }; 33450 33451 // packages/components/build-module/color-palette/index.js 33452 var import_jsx_runtime147 = __toESM(require_jsx_runtime()); 33453 k([names_default, a11y_default]); 33454 function SinglePalette({ 33455 className: className2, 33456 clearColor, 33457 colors, 33458 onChange, 33459 value, 33460 ...additionalProps 33461 }) { 33462 const colorOptions = (0, import_element82.useMemo)(() => { 33463 return colors.map(({ 33464 color: color2, 33465 name 33466 }, index2) => { 33467 const colordColor = w(color2); 33468 const isSelected2 = value === color2; 33469 return /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(circular_option_picker_default2.Option, { 33470 isSelected: isSelected2, 33471 selectedIconProps: isSelected2 ? { 33472 fill: colordColor.contrast() > colordColor.contrast("#000") ? "#fff" : "#000" 33473 } : {}, 33474 tooltipText: name || // translators: %s: color hex code e.g: "#f00". 33475 (0, import_i18n20.sprintf)((0, import_i18n20.__)("Color code: %s"), color2), 33476 style: { 33477 backgroundColor: color2, 33478 color: color2 33479 }, 33480 onClick: isSelected2 ? clearColor : () => onChange(color2, index2) 33481 }, `$color2}-$index2}`); 33482 }); 33483 }, [colors, value, onChange, clearColor]); 33484 return /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(circular_option_picker_default2.OptionGroup, { 33485 className: className2, 33486 options: colorOptions, 33487 ...additionalProps 33488 }); 33489 } 33490 function MultiplePalettes({ 33491 className: className2, 33492 clearColor, 33493 colors, 33494 onChange, 33495 value, 33496 headingLevel 33497 }) { 33498 const instanceId = (0, import_compose37.useInstanceId)(MultiplePalettes, "color-palette"); 33499 if (colors.length === 0) { 33500 return null; 33501 } 33502 return /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(component_default18, { 33503 spacing: 3, 33504 className: className2, 33505 children: colors.map(({ 33506 name, 33507 colors: colorPalette 33508 }, index2) => { 33509 const id3 = `$instanceId}-$index2}`; 33510 return /* @__PURE__ */ (0, import_jsx_runtime147.jsxs)(component_default18, { 33511 spacing: 2, 33512 children: [/* @__PURE__ */ (0, import_jsx_runtime147.jsx)(ColorHeading, { 33513 id: id3, 33514 level: headingLevel, 33515 children: name 33516 }), /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(SinglePalette, { 33517 clearColor, 33518 colors: colorPalette, 33519 onChange: (newColor) => onChange(newColor, index2), 33520 value, 33521 "aria-labelledby": id3 33522 })] 33523 }, index2); 33524 }) 33525 }); 33526 } 33527 function CustomColorPickerDropdown({ 33528 isRenderedInSidebar, 33529 popoverProps: receivedPopoverProps, 33530 ...props 33531 }) { 33532 const popoverProps = (0, import_element82.useMemo)(() => ({ 33533 shift: true, 33534 // Disabling resize as it would otherwise cause the popover to show 33535 // scrollbars while dragging the color picker's handle close to the 33536 // popover edge. 33537 resize: false, 33538 ...isRenderedInSidebar ? { 33539 // When in the sidebar: open to the left (stacking), 33540 // leaving the same gap as the parent popover. 33541 placement: "left-start", 33542 offset: 34 33543 } : { 33544 // Default behavior: open below the anchor 33545 placement: "bottom", 33546 offset: 8 33547 }, 33548 ...receivedPopoverProps 33549 }), [isRenderedInSidebar, receivedPopoverProps]); 33550 return /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(dropdown_default, { 33551 contentClassName: "components-color-palette__custom-color-dropdown-content", 33552 popoverProps, 33553 ...props 33554 }); 33555 } 33556 function UnforwardedColorPalette(props, forwardedRef) { 33557 const { 33558 asButtons, 33559 loop, 33560 clearable = true, 33561 colors = [], 33562 disableCustomColors = false, 33563 enableAlpha = false, 33564 onChange, 33565 value, 33566 __experimentalIsRenderedInSidebar = false, 33567 headingLevel = 2, 33568 "aria-label": ariaLabel, 33569 "aria-labelledby": ariaLabelledby, 33570 ...additionalProps 33571 } = props; 33572 const [normalizedColorValue, setNormalizedColorValue] = (0, import_element82.useState)(value); 33573 const clearColor = (0, import_element82.useCallback)(() => onChange(void 0), [onChange]); 33574 const customColorPaletteCallbackRef = (0, import_element82.useCallback)((node2) => { 33575 setNormalizedColorValue(normalizeColorValue(value, node2)); 33576 }, [value]); 33577 const hasMultipleColorOrigins = isMultiplePaletteArray(colors); 33578 const buttonLabelName = (0, import_element82.useMemo)(() => extractColorNameFromCurrentValue(value, colors, hasMultipleColorOrigins), [value, colors, hasMultipleColorOrigins]); 33579 const renderCustomColorPicker = () => /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(dropdown_content_wrapper_default, { 33580 paddingSize: "none", 33581 children: /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(LegacyAdapter, { 33582 color: normalizedColorValue, 33583 onChange: (color2) => onChange(color2), 33584 enableAlpha 33585 }) 33586 }); 33587 const isHex = value?.startsWith("#"); 33588 const displayValue = value?.replace(/^var\((.+)\)$/, "$1"); 33589 const customColorAccessibleLabel = !!displayValue ? (0, import_i18n20.sprintf)( 33590 // translators: 1: The name of the color e.g: "vivid red". 2: The color's hex code e.g: "#f00". 33591 (0, import_i18n20.__)('Custom color picker. The currently selected color is called "%1$s" and has a value of "%2$s".'), 33592 buttonLabelName, 33593 displayValue 33594 ) : (0, import_i18n20.__)("Custom color picker"); 33595 const paletteCommonProps = { 33596 clearColor, 33597 onChange, 33598 value 33599 }; 33600 const actions = !!clearable && /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(circular_option_picker_default2.ButtonAction, { 33601 onClick: clearColor, 33602 accessibleWhenDisabled: true, 33603 disabled: !value, 33604 children: (0, import_i18n20.__)("Clear") 33605 }); 33606 const { 33607 metaProps, 33608 labelProps 33609 } = getComputeCircularOptionPickerCommonProps(asButtons, loop, ariaLabel, ariaLabelledby); 33610 return /* @__PURE__ */ (0, import_jsx_runtime147.jsxs)(component_default18, { 33611 spacing: 3, 33612 ref: forwardedRef, 33613 ...additionalProps, 33614 children: [!disableCustomColors && /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(CustomColorPickerDropdown, { 33615 isRenderedInSidebar: __experimentalIsRenderedInSidebar, 33616 renderContent: renderCustomColorPicker, 33617 renderToggle: ({ 33618 isOpen, 33619 onToggle 33620 }) => /* @__PURE__ */ (0, import_jsx_runtime147.jsxs)(component_default18, { 33621 className: "components-color-palette__custom-color-wrapper", 33622 spacing: 0, 33623 children: [/* @__PURE__ */ (0, import_jsx_runtime147.jsx)("button", { 33624 ref: customColorPaletteCallbackRef, 33625 className: "components-color-palette__custom-color-button", 33626 "aria-expanded": isOpen, 33627 "aria-haspopup": "true", 33628 onClick: onToggle, 33629 "aria-label": customColorAccessibleLabel, 33630 style: { 33631 background: value 33632 }, 33633 type: "button" 33634 }), /* @__PURE__ */ (0, import_jsx_runtime147.jsxs)(component_default18, { 33635 className: "components-color-palette__custom-color-text-wrapper", 33636 spacing: 0.5, 33637 children: [/* @__PURE__ */ (0, import_jsx_runtime147.jsx)(component_default7, { 33638 className: "components-color-palette__custom-color-name", 33639 children: value ? buttonLabelName : (0, import_i18n20.__)("No color selected") 33640 }), /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(component_default7, { 33641 className: clsx_default("components-color-palette__custom-color-value", { 33642 "components-color-palette__custom-color-value--is-hex": isHex 33643 }), 33644 children: displayValue 33645 })] 33646 })] 33647 }) 33648 }), (colors.length > 0 || actions) && /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(circular_option_picker_default2, { 33649 ...metaProps, 33650 ...labelProps, 33651 actions, 33652 options: hasMultipleColorOrigins ? /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(MultiplePalettes, { 33653 ...paletteCommonProps, 33654 headingLevel, 33655 colors, 33656 value 33657 }) : /* @__PURE__ */ (0, import_jsx_runtime147.jsx)(SinglePalette, { 33658 ...paletteCommonProps, 33659 colors, 33660 value 33661 }) 33662 })] 33663 }); 33664 } 33665 var ColorPalette = (0, import_element82.forwardRef)(UnforwardedColorPalette); 33666 var color_palette_default = ColorPalette; 33667 33668 // packages/components/build-module/border-control/border-control-dropdown/hook.js 33669 var import_element84 = __toESM(require_element()); 33670 33671 // packages/components/build-module/unit-control/styles/unit-control-styles.js 33672 var ValueInput = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 33673 target: "e1bagdl32" 33674 } : { 33675 target: "e1bagdl32", 33676 label: "ValueInput" 33677 })("&&&{input{display:block;width:100%;}", BackdropUI, "{transition:box-shadow 0.1s linear;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUJpRCIsImZpbGUiOiJ1bml0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBOdW1iZXJDb250cm9sIGZyb20gJy4uLy4uL251bWJlci1jb250cm9sJztcbmltcG9ydCB7IEJhY2tkcm9wVUkgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdFNpemUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuLy8gVXNpbmcgYHNlbGVjdFNpemVgIGluc3RlYWQgb2YgYHNpemVgIHRvIGF2b2lkIGEgdHlwZSBjb25mbGljdCB3aXRoIHRoZVxuLy8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxudHlwZSBTZWxlY3RQcm9wcyA9IHtcblx0c2VsZWN0U2l6ZTogU2VsZWN0U2l6ZTtcbn07XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IFZhbHVlSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JiYmIHtcblx0XHRpbnB1dCB7XG5cdFx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRcdHdpZHRoOiAxMDAlO1xuXHRcdH1cblxuXHRcdCR7IEJhY2tkcm9wVUkgfSB7XG5cdFx0XHR0cmFuc2l0aW9uOiBib3gtc2hhZG93IDAuMXMgbGluZWFyO1xuXHRcdH1cblx0fVxuYDtcblxuY29uc3QgYmFzZVVuaXRMYWJlbFN0eWxlcyA9ICggeyBzZWxlY3RTaXplIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRcdHBhZGRpbmc6IDJweCAxcHg7XG5cdFx0XHR3aWR0aDogMjBweDtcblx0XHRcdGZvbnQtc2l6ZTogOHB4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHRsZXR0ZXItc3BhY2luZzogLTAuNXB4O1xuXHRcdFx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXG5cdFx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDgwMCBdIH07XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdFx0bWF4LXdpZHRoOiA0OHB4O1xuXHRcdFx0aGVpZ2h0OiAyNHB4O1xuXHRcdFx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHRcdHBhZGRpbmc6ICR7IHNwYWNlKCAxICkgfTtcblxuXHRcdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHR0ZXh0LWFsaWduLWxhc3Q6IGNlbnRlcjtcblx0XHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0XHRvdmVyZmxvdzogaGlkZGVuO1xuXHRcdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cdFx0XHRmaWVsZC1zaXppbmc6IGNvbnRlbnQ7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHR9XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc2l6ZXNbIHNlbGVjdFNpemUgXTtcbn07XG5cbmV4cG9ydCBjb25zdCBVbml0TGFiZWwgPSBzdHlsZWQuZGl2PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHR9XG5gO1xuXG5jb25zdCB1bml0U2VsZWN0U2l6ZXMgPSAoIHsgc2VsZWN0U2l6ZSA9ICdkZWZhdWx0JyB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3Qgc2l6ZXMgPSB7XG5cdFx0c21hbGw6IGNzc2Bcblx0XHRcdGhlaWdodDogMTAwJTtcblx0XHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0dHJhbnNpdGlvbjpcblx0XHRcdFx0Ym94LXNoYWRvdyAwLjFzIGxpbmVhcixcblx0XHRcdFx0Ym9yZGVyIDAuMXMgbGluZWFyO1xuXG5cdFx0XHQkeyBydGwoIHsgYm9yZGVyVG9wTGVmdFJhZGl1czogMCwgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogMCB9ICkoKSB9XG5cblx0XHRcdCY6bm90KDpkaXNhYmxlZCk6aG92ZXIge1xuXHRcdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRib3gtc2hhZG93OiBpbnNldCAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aCArICcgJyArIENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0fVxuXHRcdGAsXG5cdFx0ZGVmYXVsdDogY3NzYFxuXHRcdFx0ZGlzcGxheTogZmxleDtcblx0XHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdFx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblxuXHRcdFx0Jjp3aGVyZSggOm5vdCggOmRpc2FibGVkICkgKTpob3ZlciB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkIHRyYW5zcGFyZW50OyAvLyBGb3IgSGlnaCBDb250cmFzdCBNb2RlXG5cdFx0XHR9XG5cblx0XHRcdCY6Zm9jdXMge1xuXHRcdFx0XHRib3gtc2hhZG93OiAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQvLyBUaGUgJiYmIGNvdW50ZXJhY3RzIDxzZWxlY3Q+IHN0eWxlcyBpbiBXUCBmb3Jtcy5jc3Ncblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0b3V0bGluZTogbm9uZTtcblx0XHQvKiBSZW1vdmluZyBtYXJnaW4gZW5zdXJlcyBmb2N1cyBzdHlsZXMgbmVhdGx5IG92ZXJsYXkgdGhlIHdyYXBwZXIuICovXG5cdFx0bWFyZ2luOiAwO1xuXHRcdG1pbi1oZWlnaHQ6IGF1dG87XG5cdFx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cblx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdH1cblxuXHRcdCR7IGJhc2VVbml0TGFiZWxTdHlsZXMgfTtcblx0XHQkeyB1bml0U2VsZWN0U2l6ZXMgfTtcblx0fVxuYDtcbiJdfQ== */")); 33678 var baseUnitLabelStyles = ({ 33679 selectSize 33680 }) => { 33681 const sizes = { 33682 small: /* @__PURE__ */ css("box-sizing:border-box;padding:2px 1px;width:20px;font-size:8px;line-height:1;letter-spacing:-0.5px;text-transform:uppercase;text-align-last:center;&:not( :disabled ){color:", COLORS.gray[800], ";}" + (false ? "" : ";label:small;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NZIiwiZmlsZSI6InVuaXQtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IHsgQmFja2Ryb3BVSSB9IGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB0eXBlIHsgU2VsZWN0U2l6ZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG4vLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG4vLyBgc2l6ZWAgSFRNTCBhdHRyaWJ1dGUgb2YgdGhlIGBzZWxlY3RgIGVsZW1lbnQuXG50eXBlIFNlbGVjdFByb3BzID0ge1xuXHRzZWxlY3RTaXplOiBTZWxlY3RTaXplO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgVmFsdWVJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQmJiYge1xuXHRcdGlucHV0IHtcblx0XHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdFx0d2lkdGg6IDEwMCU7XG5cdFx0fVxuXG5cdFx0JHsgQmFja2Ryb3BVSSB9IHtcblx0XHRcdHRyYW5zaXRpb246IGJveC1zaGFkb3cgMC4xcyBsaW5lYXI7XG5cdFx0fVxuXHR9XG5gO1xuXG5jb25zdCBiYXNlVW5pdExhYmVsU3R5bGVzID0gKCB7IHNlbGVjdFNpemUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdHNtYWxsOiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0cGFkZGluZzogMnB4IDFweDtcblx0XHRcdHdpZHRoOiAyMHB4O1xuXHRcdFx0Zm9udC1zaXplOiA4cHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdGxldHRlci1zcGFjaW5nOiAtMC41cHg7XG5cdFx0XHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuXHRcdFx0dGV4dC1hbGlnbi1sYXN0OiBjZW50ZXI7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgODAwIF0gfTtcblx0XHRcdH1cblx0XHRgLFxuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0XHRtYXgtd2lkdGg6IDQ4cHg7XG5cdFx0XHRoZWlnaHQ6IDI0cHg7XG5cdFx0XHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIDEgKSB9O1xuXG5cdFx0XHRmb250LXNpemU6IDEzcHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXHRcdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHRcdG92ZXJmbG93OiBoaWRkZW47XG5cdFx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblx0XHRcdGZpZWxkLXNpemluZzogY29udGVudDtcblxuXHRcdFx0Jjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRMYWJlbCA9IHN0eWxlZC5kaXY8IFNlbGVjdFByb3BzID5gXG5cdCYmJiB7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0XHQkeyBiYXNlVW5pdExhYmVsU3R5bGVzIH07XG5cblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdH1cbmA7XG5cbmNvbnN0IHVuaXRTZWxlY3RTaXplcyA9ICggeyBzZWxlY3RTaXplID0gJ2RlZmF1bHQnIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0aGVpZ2h0OiAxMDAlO1xuXHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0XHRib3gtc2hhZG93IDAuMXMgbGluZWFyLFxuXHRcdFx0XHRib3JkZXIgMC4xcyBsaW5lYXI7XG5cblx0XHRcdCR7IHJ0bCggeyBib3JkZXJUb3BMZWZ0UmFkaXVzOiAwLCBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiAwIH0gKSgpIH1cblxuXHRcdFx0Jjpub3QoOmRpc2FibGVkKTpob3ZlciB7XG5cdFx0XHRcdGJhY2tncm91bmQtY29sb3I6ICR7IENPTE9SUy5ncmF5WyAxMDAgXSB9O1xuXHRcdFx0fVxuXG5cdFx0XHQmOmZvY3VzIHtcblx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXG5cdFx0XHQmOndoZXJlKCA6bm90KCA6ZGlzYWJsZWQgKSApOmhvdmVyIHtcblx0XHRcdFx0Ym94LXNoYWRvdzogMCAwIDBcblx0XHRcdFx0XHQkeyBDT05GSUcuYm9yZGVyV2lkdGggKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCB0cmFuc3BhcmVudDsgLy8gRm9yIEhpZ2ggQ29udHJhc3QgTW9kZVxuXHRcdFx0fVxuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHNpemVzWyBzZWxlY3RTaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgVW5pdFNlbGVjdCA9IHN0eWxlZC5zZWxlY3Q8IFNlbGVjdFByb3BzID5gXG5cdC8vIFRoZSAmJiYgY291bnRlcmFjdHMgPHNlbGVjdD4gc3R5bGVzIGluIFdQIGZvcm1zLmNzc1xuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGJvcmRlcjogbm9uZTtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRvdXRsaW5lOiBub25lO1xuXHRcdC8qIFJlbW92aW5nIG1hcmdpbiBlbnN1cmVzIGZvY3VzIHN0eWxlcyBuZWF0bHkgb3ZlcmxheSB0aGUgd3JhcHBlci4gKi9cblx0XHRtYXJnaW46IDA7XG5cdFx0bWluLWhlaWdodDogYXV0bztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblxuXHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRjdXJzb3I6IHBvaW50ZXI7XG5cdFx0fVxuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXHRcdCR7IHVuaXRTZWxlY3RTaXplcyB9O1xuXHR9XG5gO1xuIl19 */"), 33683 default: /* @__PURE__ */ css("box-sizing:border-box;min-width:24px;max-width:48px;height:24px;margin-inline-end:", space(2), ";padding:", space(1), ";font-size:13px;line-height:1;text-align-last:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;field-sizing:content;&:not( :disabled ){color:", COLORS.theme.accent, ";}" + (false ? "" : ";label:default;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0RjIiwiZmlsZSI6InVuaXQtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IHsgQmFja2Ryb3BVSSB9IGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB0eXBlIHsgU2VsZWN0U2l6ZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG4vLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG4vLyBgc2l6ZWAgSFRNTCBhdHRyaWJ1dGUgb2YgdGhlIGBzZWxlY3RgIGVsZW1lbnQuXG50eXBlIFNlbGVjdFByb3BzID0ge1xuXHRzZWxlY3RTaXplOiBTZWxlY3RTaXplO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgVmFsdWVJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQmJiYge1xuXHRcdGlucHV0IHtcblx0XHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdFx0d2lkdGg6IDEwMCU7XG5cdFx0fVxuXG5cdFx0JHsgQmFja2Ryb3BVSSB9IHtcblx0XHRcdHRyYW5zaXRpb246IGJveC1zaGFkb3cgMC4xcyBsaW5lYXI7XG5cdFx0fVxuXHR9XG5gO1xuXG5jb25zdCBiYXNlVW5pdExhYmVsU3R5bGVzID0gKCB7IHNlbGVjdFNpemUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdHNtYWxsOiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0cGFkZGluZzogMnB4IDFweDtcblx0XHRcdHdpZHRoOiAyMHB4O1xuXHRcdFx0Zm9udC1zaXplOiA4cHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdGxldHRlci1zcGFjaW5nOiAtMC41cHg7XG5cdFx0XHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuXHRcdFx0dGV4dC1hbGlnbi1sYXN0OiBjZW50ZXI7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgODAwIF0gfTtcblx0XHRcdH1cblx0XHRgLFxuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0XHRtYXgtd2lkdGg6IDQ4cHg7XG5cdFx0XHRoZWlnaHQ6IDI0cHg7XG5cdFx0XHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIDEgKSB9O1xuXG5cdFx0XHRmb250LXNpemU6IDEzcHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXHRcdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHRcdG92ZXJmbG93OiBoaWRkZW47XG5cdFx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblx0XHRcdGZpZWxkLXNpemluZzogY29udGVudDtcblxuXHRcdFx0Jjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRMYWJlbCA9IHN0eWxlZC5kaXY8IFNlbGVjdFByb3BzID5gXG5cdCYmJiB7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0XHQkeyBiYXNlVW5pdExhYmVsU3R5bGVzIH07XG5cblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdH1cbmA7XG5cbmNvbnN0IHVuaXRTZWxlY3RTaXplcyA9ICggeyBzZWxlY3RTaXplID0gJ2RlZmF1bHQnIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0aGVpZ2h0OiAxMDAlO1xuXHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0XHRib3gtc2hhZG93IDAuMXMgbGluZWFyLFxuXHRcdFx0XHRib3JkZXIgMC4xcyBsaW5lYXI7XG5cblx0XHRcdCR7IHJ0bCggeyBib3JkZXJUb3BMZWZ0UmFkaXVzOiAwLCBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiAwIH0gKSgpIH1cblxuXHRcdFx0Jjpub3QoOmRpc2FibGVkKTpob3ZlciB7XG5cdFx0XHRcdGJhY2tncm91bmQtY29sb3I6ICR7IENPTE9SUy5ncmF5WyAxMDAgXSB9O1xuXHRcdFx0fVxuXG5cdFx0XHQmOmZvY3VzIHtcblx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXG5cdFx0XHQmOndoZXJlKCA6bm90KCA6ZGlzYWJsZWQgKSApOmhvdmVyIHtcblx0XHRcdFx0Ym94LXNoYWRvdzogMCAwIDBcblx0XHRcdFx0XHQkeyBDT05GSUcuYm9yZGVyV2lkdGggKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCB0cmFuc3BhcmVudDsgLy8gRm9yIEhpZ2ggQ29udHJhc3QgTW9kZVxuXHRcdFx0fVxuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHNpemVzWyBzZWxlY3RTaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgVW5pdFNlbGVjdCA9IHN0eWxlZC5zZWxlY3Q8IFNlbGVjdFByb3BzID5gXG5cdC8vIFRoZSAmJiYgY291bnRlcmFjdHMgPHNlbGVjdD4gc3R5bGVzIGluIFdQIGZvcm1zLmNzc1xuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGJvcmRlcjogbm9uZTtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRvdXRsaW5lOiBub25lO1xuXHRcdC8qIFJlbW92aW5nIG1hcmdpbiBlbnN1cmVzIGZvY3VzIHN0eWxlcyBuZWF0bHkgb3ZlcmxheSB0aGUgd3JhcHBlci4gKi9cblx0XHRtYXJnaW46IDA7XG5cdFx0bWluLWhlaWdodDogYXV0bztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblxuXHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRjdXJzb3I6IHBvaW50ZXI7XG5cdFx0fVxuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXHRcdCR7IHVuaXRTZWxlY3RTaXplcyB9O1xuXHR9XG5gO1xuIl19 */") 33684 }; 33685 return sizes[selectSize]; 33686 }; 33687 var UnitLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 33688 target: "e1bagdl31" 33689 } : { 33690 target: "e1bagdl31", 33691 label: "UnitLabel" 33692 })("&&&{pointer-events:none;", baseUnitLabelStyles, ";color:", COLORS.gray[900], ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkVrRCIsImZpbGUiOiJ1bml0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBOdW1iZXJDb250cm9sIGZyb20gJy4uLy4uL251bWJlci1jb250cm9sJztcbmltcG9ydCB7IEJhY2tkcm9wVUkgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdFNpemUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuLy8gVXNpbmcgYHNlbGVjdFNpemVgIGluc3RlYWQgb2YgYHNpemVgIHRvIGF2b2lkIGEgdHlwZSBjb25mbGljdCB3aXRoIHRoZVxuLy8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxudHlwZSBTZWxlY3RQcm9wcyA9IHtcblx0c2VsZWN0U2l6ZTogU2VsZWN0U2l6ZTtcbn07XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IFZhbHVlSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JiYmIHtcblx0XHRpbnB1dCB7XG5cdFx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRcdHdpZHRoOiAxMDAlO1xuXHRcdH1cblxuXHRcdCR7IEJhY2tkcm9wVUkgfSB7XG5cdFx0XHR0cmFuc2l0aW9uOiBib3gtc2hhZG93IDAuMXMgbGluZWFyO1xuXHRcdH1cblx0fVxuYDtcblxuY29uc3QgYmFzZVVuaXRMYWJlbFN0eWxlcyA9ICggeyBzZWxlY3RTaXplIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRcdHBhZGRpbmc6IDJweCAxcHg7XG5cdFx0XHR3aWR0aDogMjBweDtcblx0XHRcdGZvbnQtc2l6ZTogOHB4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHRsZXR0ZXItc3BhY2luZzogLTAuNXB4O1xuXHRcdFx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXG5cdFx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDgwMCBdIH07XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdFx0bWF4LXdpZHRoOiA0OHB4O1xuXHRcdFx0aGVpZ2h0OiAyNHB4O1xuXHRcdFx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHRcdHBhZGRpbmc6ICR7IHNwYWNlKCAxICkgfTtcblxuXHRcdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHR0ZXh0LWFsaWduLWxhc3Q6IGNlbnRlcjtcblx0XHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0XHRvdmVyZmxvdzogaGlkZGVuO1xuXHRcdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cdFx0XHRmaWVsZC1zaXppbmc6IGNvbnRlbnQ7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHR9XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc2l6ZXNbIHNlbGVjdFNpemUgXTtcbn07XG5cbmV4cG9ydCBjb25zdCBVbml0TGFiZWwgPSBzdHlsZWQuZGl2PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHR9XG5gO1xuXG5jb25zdCB1bml0U2VsZWN0U2l6ZXMgPSAoIHsgc2VsZWN0U2l6ZSA9ICdkZWZhdWx0JyB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3Qgc2l6ZXMgPSB7XG5cdFx0c21hbGw6IGNzc2Bcblx0XHRcdGhlaWdodDogMTAwJTtcblx0XHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0dHJhbnNpdGlvbjpcblx0XHRcdFx0Ym94LXNoYWRvdyAwLjFzIGxpbmVhcixcblx0XHRcdFx0Ym9yZGVyIDAuMXMgbGluZWFyO1xuXG5cdFx0XHQkeyBydGwoIHsgYm9yZGVyVG9wTGVmdFJhZGl1czogMCwgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogMCB9ICkoKSB9XG5cblx0XHRcdCY6bm90KDpkaXNhYmxlZCk6aG92ZXIge1xuXHRcdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRib3gtc2hhZG93OiBpbnNldCAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aCArICcgJyArIENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0fVxuXHRcdGAsXG5cdFx0ZGVmYXVsdDogY3NzYFxuXHRcdFx0ZGlzcGxheTogZmxleDtcblx0XHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdFx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblxuXHRcdFx0Jjp3aGVyZSggOm5vdCggOmRpc2FibGVkICkgKTpob3ZlciB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkIHRyYW5zcGFyZW50OyAvLyBGb3IgSGlnaCBDb250cmFzdCBNb2RlXG5cdFx0XHR9XG5cblx0XHRcdCY6Zm9jdXMge1xuXHRcdFx0XHRib3gtc2hhZG93OiAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQvLyBUaGUgJiYmIGNvdW50ZXJhY3RzIDxzZWxlY3Q+IHN0eWxlcyBpbiBXUCBmb3Jtcy5jc3Ncblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0b3V0bGluZTogbm9uZTtcblx0XHQvKiBSZW1vdmluZyBtYXJnaW4gZW5zdXJlcyBmb2N1cyBzdHlsZXMgbmVhdGx5IG92ZXJsYXkgdGhlIHdyYXBwZXIuICovXG5cdFx0bWFyZ2luOiAwO1xuXHRcdG1pbi1oZWlnaHQ6IGF1dG87XG5cdFx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cblx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdH1cblxuXHRcdCR7IGJhc2VVbml0TGFiZWxTdHlsZXMgfTtcblx0XHQkeyB1bml0U2VsZWN0U2l6ZXMgfTtcblx0fVxuYDtcbiJdfQ== */")); 33693 var unitSelectSizes = ({ 33694 selectSize = "default" 33695 }) => { 33696 const sizes = { 33697 small: /* @__PURE__ */ css("height:100%;border:1px solid transparent;transition:box-shadow 0.1s linear,border 0.1s linear;", rtl({ 33698 borderTopLeftRadius: 0, 33699 borderBottomLeftRadius: 0 33700 })(), " &:not(:disabled):hover{background-color:", COLORS.gray[100], ";}&:focus{border:1px solid ", COLORS.ui.borderFocus, ";box-shadow:inset 0 0 0 ", config_values_default.borderWidth + " " + COLORS.ui.borderFocus, ";outline-offset:0;outline:2px solid transparent;z-index:1;}" + (false ? "" : ";label:small;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUZZIiwiZmlsZSI6InVuaXQtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IHsgQmFja2Ryb3BVSSB9IGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB0eXBlIHsgU2VsZWN0U2l6ZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG4vLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG4vLyBgc2l6ZWAgSFRNTCBhdHRyaWJ1dGUgb2YgdGhlIGBzZWxlY3RgIGVsZW1lbnQuXG50eXBlIFNlbGVjdFByb3BzID0ge1xuXHRzZWxlY3RTaXplOiBTZWxlY3RTaXplO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgVmFsdWVJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQmJiYge1xuXHRcdGlucHV0IHtcblx0XHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdFx0d2lkdGg6IDEwMCU7XG5cdFx0fVxuXG5cdFx0JHsgQmFja2Ryb3BVSSB9IHtcblx0XHRcdHRyYW5zaXRpb246IGJveC1zaGFkb3cgMC4xcyBsaW5lYXI7XG5cdFx0fVxuXHR9XG5gO1xuXG5jb25zdCBiYXNlVW5pdExhYmVsU3R5bGVzID0gKCB7IHNlbGVjdFNpemUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdHNtYWxsOiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0cGFkZGluZzogMnB4IDFweDtcblx0XHRcdHdpZHRoOiAyMHB4O1xuXHRcdFx0Zm9udC1zaXplOiA4cHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdGxldHRlci1zcGFjaW5nOiAtMC41cHg7XG5cdFx0XHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuXHRcdFx0dGV4dC1hbGlnbi1sYXN0OiBjZW50ZXI7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgODAwIF0gfTtcblx0XHRcdH1cblx0XHRgLFxuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0XHRtYXgtd2lkdGg6IDQ4cHg7XG5cdFx0XHRoZWlnaHQ6IDI0cHg7XG5cdFx0XHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIDEgKSB9O1xuXG5cdFx0XHRmb250LXNpemU6IDEzcHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXHRcdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHRcdG92ZXJmbG93OiBoaWRkZW47XG5cdFx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblx0XHRcdGZpZWxkLXNpemluZzogY29udGVudDtcblxuXHRcdFx0Jjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRMYWJlbCA9IHN0eWxlZC5kaXY8IFNlbGVjdFByb3BzID5gXG5cdCYmJiB7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0XHQkeyBiYXNlVW5pdExhYmVsU3R5bGVzIH07XG5cblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdH1cbmA7XG5cbmNvbnN0IHVuaXRTZWxlY3RTaXplcyA9ICggeyBzZWxlY3RTaXplID0gJ2RlZmF1bHQnIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0aGVpZ2h0OiAxMDAlO1xuXHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0XHRib3gtc2hhZG93IDAuMXMgbGluZWFyLFxuXHRcdFx0XHRib3JkZXIgMC4xcyBsaW5lYXI7XG5cblx0XHRcdCR7IHJ0bCggeyBib3JkZXJUb3BMZWZ0UmFkaXVzOiAwLCBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiAwIH0gKSgpIH1cblxuXHRcdFx0Jjpub3QoOmRpc2FibGVkKTpob3ZlciB7XG5cdFx0XHRcdGJhY2tncm91bmQtY29sb3I6ICR7IENPTE9SUy5ncmF5WyAxMDAgXSB9O1xuXHRcdFx0fVxuXG5cdFx0XHQmOmZvY3VzIHtcblx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXG5cdFx0XHQmOndoZXJlKCA6bm90KCA6ZGlzYWJsZWQgKSApOmhvdmVyIHtcblx0XHRcdFx0Ym94LXNoYWRvdzogMCAwIDBcblx0XHRcdFx0XHQkeyBDT05GSUcuYm9yZGVyV2lkdGggKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCB0cmFuc3BhcmVudDsgLy8gRm9yIEhpZ2ggQ29udHJhc3QgTW9kZVxuXHRcdFx0fVxuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHNpemVzWyBzZWxlY3RTaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgVW5pdFNlbGVjdCA9IHN0eWxlZC5zZWxlY3Q8IFNlbGVjdFByb3BzID5gXG5cdC8vIFRoZSAmJiYgY291bnRlcmFjdHMgPHNlbGVjdD4gc3R5bGVzIGluIFdQIGZvcm1zLmNzc1xuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGJvcmRlcjogbm9uZTtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRvdXRsaW5lOiBub25lO1xuXHRcdC8qIFJlbW92aW5nIG1hcmdpbiBlbnN1cmVzIGZvY3VzIHN0eWxlcyBuZWF0bHkgb3ZlcmxheSB0aGUgd3JhcHBlci4gKi9cblx0XHRtYXJnaW46IDA7XG5cdFx0bWluLWhlaWdodDogYXV0bztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblxuXHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRjdXJzb3I6IHBvaW50ZXI7XG5cdFx0fVxuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXHRcdCR7IHVuaXRTZWxlY3RTaXplcyB9O1xuXHR9XG5gO1xuIl19 */"), 33701 default: /* @__PURE__ */ css("display:flex;justify-content:center;align-items:center;&:where( :not( :disabled ) ):hover{box-shadow:0 0 0 ", config_values_default.borderWidth + " " + COLORS.ui.borderFocus, ";outline:", config_values_default.borderWidth, " solid transparent;}&:focus{box-shadow:0 0 0 ", config_values_default.borderWidthFocus + " " + COLORS.ui.borderFocus, ";outline:", config_values_default.borderWidthFocus, " solid transparent;}" + (false ? "" : ";label:default;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0djIiwiZmlsZSI6InVuaXQtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IE51bWJlckNvbnRyb2wgZnJvbSAnLi4vLi4vbnVtYmVyLWNvbnRyb2wnO1xuaW1wb3J0IHsgQmFja2Ryb3BVSSB9IGZyb20gJy4uLy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB0eXBlIHsgU2VsZWN0U2l6ZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG4vLyBVc2luZyBgc2VsZWN0U2l6ZWAgaW5zdGVhZCBvZiBgc2l6ZWAgdG8gYXZvaWQgYSB0eXBlIGNvbmZsaWN0IHdpdGggdGhlXG4vLyBgc2l6ZWAgSFRNTCBhdHRyaWJ1dGUgb2YgdGhlIGBzZWxlY3RgIGVsZW1lbnQuXG50eXBlIFNlbGVjdFByb3BzID0ge1xuXHRzZWxlY3RTaXplOiBTZWxlY3RTaXplO1xufTtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgVmFsdWVJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQmJiYge1xuXHRcdGlucHV0IHtcblx0XHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdFx0d2lkdGg6IDEwMCU7XG5cdFx0fVxuXG5cdFx0JHsgQmFja2Ryb3BVSSB9IHtcblx0XHRcdHRyYW5zaXRpb246IGJveC1zaGFkb3cgMC4xcyBsaW5lYXI7XG5cdFx0fVxuXHR9XG5gO1xuXG5jb25zdCBiYXNlVW5pdExhYmVsU3R5bGVzID0gKCB7IHNlbGVjdFNpemUgfTogU2VsZWN0UHJvcHMgKSA9PiB7XG5cdGNvbnN0IHNpemVzID0ge1xuXHRcdHNtYWxsOiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0cGFkZGluZzogMnB4IDFweDtcblx0XHRcdHdpZHRoOiAyMHB4O1xuXHRcdFx0Zm9udC1zaXplOiA4cHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdGxldHRlci1zcGFjaW5nOiAtMC41cHg7XG5cdFx0XHR0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuXHRcdFx0dGV4dC1hbGlnbi1sYXN0OiBjZW50ZXI7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgODAwIF0gfTtcblx0XHRcdH1cblx0XHRgLFxuXHRcdGRlZmF1bHQ6IGNzc2Bcblx0XHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0XHRtYXgtd2lkdGg6IDQ4cHg7XG5cdFx0XHRoZWlnaHQ6IDI0cHg7XG5cdFx0XHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdFx0cGFkZGluZzogJHsgc3BhY2UoIDEgKSB9O1xuXG5cdFx0XHRmb250LXNpemU6IDEzcHg7XG5cdFx0XHRsaW5lLWhlaWdodDogMTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXHRcdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0XHRcdG92ZXJmbG93OiBoaWRkZW47XG5cdFx0XHR0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcblx0XHRcdGZpZWxkLXNpemluZzogY29udGVudDtcblxuXHRcdFx0Jjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRMYWJlbCA9IHN0eWxlZC5kaXY8IFNlbGVjdFByb3BzID5gXG5cdCYmJiB7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cblx0XHQkeyBiYXNlVW5pdExhYmVsU3R5bGVzIH07XG5cblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdH1cbmA7XG5cbmNvbnN0IHVuaXRTZWxlY3RTaXplcyA9ICggeyBzZWxlY3RTaXplID0gJ2RlZmF1bHQnIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0aGVpZ2h0OiAxMDAlO1xuXHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHR0cmFuc2l0aW9uOlxuXHRcdFx0XHRib3gtc2hhZG93IDAuMXMgbGluZWFyLFxuXHRcdFx0XHRib3JkZXIgMC4xcyBsaW5lYXI7XG5cblx0XHRcdCR7IHJ0bCggeyBib3JkZXJUb3BMZWZ0UmFkaXVzOiAwLCBib3JkZXJCb3R0b21MZWZ0UmFkaXVzOiAwIH0gKSgpIH1cblxuXHRcdFx0Jjpub3QoOmRpc2FibGVkKTpob3ZlciB7XG5cdFx0XHRcdGJhY2tncm91bmQtY29sb3I6ICR7IENPTE9SUy5ncmF5WyAxMDAgXSB9O1xuXHRcdFx0fVxuXG5cdFx0XHQmOmZvY3VzIHtcblx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXG5cdFx0XHQmOndoZXJlKCA6bm90KCA6ZGlzYWJsZWQgKSApOmhvdmVyIHtcblx0XHRcdFx0Ym94LXNoYWRvdzogMCAwIDBcblx0XHRcdFx0XHQkeyBDT05GSUcuYm9yZGVyV2lkdGggKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgKyAnICcgKyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdFx0b3V0bGluZTogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCB0cmFuc3BhcmVudDsgLy8gRm9yIEhpZ2ggQ29udHJhc3QgTW9kZVxuXHRcdFx0fVxuXHRcdGAsXG5cdH07XG5cblx0cmV0dXJuIHNpemVzWyBzZWxlY3RTaXplIF07XG59O1xuXG5leHBvcnQgY29uc3QgVW5pdFNlbGVjdCA9IHN0eWxlZC5zZWxlY3Q8IFNlbGVjdFByb3BzID5gXG5cdC8vIFRoZSAmJiYgY291bnRlcmFjdHMgPHNlbGVjdD4gc3R5bGVzIGluIFdQIGZvcm1zLmNzc1xuXHQmJiYge1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdGJvcmRlcjogbm9uZTtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRvdXRsaW5lOiBub25lO1xuXHRcdC8qIFJlbW92aW5nIG1hcmdpbiBlbnN1cmVzIGZvY3VzIHN0eWxlcyBuZWF0bHkgb3ZlcmxheSB0aGUgd3JhcHBlci4gKi9cblx0XHRtYXJnaW46IDA7XG5cdFx0bWluLWhlaWdodDogYXV0bztcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblxuXHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRjdXJzb3I6IHBvaW50ZXI7XG5cdFx0fVxuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXHRcdCR7IHVuaXRTZWxlY3RTaXplcyB9O1xuXHR9XG5gO1xuIl19 */") 33702 }; 33703 return sizes[selectSize]; 33704 }; 33705 var UnitSelect = /* @__PURE__ */ emotion_styled_base_browser_esm_default("select", false ? { 33706 target: "e1bagdl30" 33707 } : { 33708 target: "e1bagdl30", 33709 label: "UnitSelect" 33710 })("&&&{appearance:none;background:transparent;border-radius:", config_values_default.radiusXSmall, ";border:none;display:block;outline:none;margin:0;min-height:auto;font-family:inherit;", baseUnitLabelStyles, ";", unitSelectSizes, ";&:not( :disabled ){cursor:pointer;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInVuaXQtY29udHJvbC1zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUlzRCIsImZpbGUiOiJ1bml0LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBOdW1iZXJDb250cm9sIGZyb20gJy4uLy4uL251bWJlci1jb250cm9sJztcbmltcG9ydCB7IEJhY2tkcm9wVUkgfSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgdHlwZSB7IFNlbGVjdFNpemUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuLy8gVXNpbmcgYHNlbGVjdFNpemVgIGluc3RlYWQgb2YgYHNpemVgIHRvIGF2b2lkIGEgdHlwZSBjb25mbGljdCB3aXRoIHRoZVxuLy8gYHNpemVgIEhUTUwgYXR0cmlidXRlIG9mIHRoZSBgc2VsZWN0YCBlbGVtZW50LlxudHlwZSBTZWxlY3RQcm9wcyA9IHtcblx0c2VsZWN0U2l6ZTogU2VsZWN0U2l6ZTtcbn07XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IFZhbHVlSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JiYmIHtcblx0XHRpbnB1dCB7XG5cdFx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRcdHdpZHRoOiAxMDAlO1xuXHRcdH1cblxuXHRcdCR7IEJhY2tkcm9wVUkgfSB7XG5cdFx0XHR0cmFuc2l0aW9uOiBib3gtc2hhZG93IDAuMXMgbGluZWFyO1xuXHRcdH1cblx0fVxuYDtcblxuY29uc3QgYmFzZVVuaXRMYWJlbFN0eWxlcyA9ICggeyBzZWxlY3RTaXplIH06IFNlbGVjdFByb3BzICkgPT4ge1xuXHRjb25zdCBzaXplcyA9IHtcblx0XHRzbWFsbDogY3NzYFxuXHRcdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRcdHBhZGRpbmc6IDJweCAxcHg7XG5cdFx0XHR3aWR0aDogMjBweDtcblx0XHRcdGZvbnQtc2l6ZTogOHB4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHRsZXR0ZXItc3BhY2luZzogLTAuNXB4O1xuXHRcdFx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0XHRcdHRleHQtYWxpZ24tbGFzdDogY2VudGVyO1xuXG5cdFx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDgwMCBdIH07XG5cdFx0XHR9XG5cdFx0YCxcblx0XHRkZWZhdWx0OiBjc3NgXG5cdFx0XHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRcdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdFx0bWF4LXdpZHRoOiA0OHB4O1xuXHRcdFx0aGVpZ2h0OiAyNHB4O1xuXHRcdFx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHRcdHBhZGRpbmc6ICR7IHNwYWNlKCAxICkgfTtcblxuXHRcdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdFx0bGluZS1oZWlnaHQ6IDE7XG5cdFx0XHR0ZXh0LWFsaWduLWxhc3Q6IGNlbnRlcjtcblx0XHRcdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdFx0XHRvdmVyZmxvdzogaGlkZGVuO1xuXHRcdFx0dGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG5cdFx0XHRmaWVsZC1zaXppbmc6IGNvbnRlbnQ7XG5cblx0XHRcdCY6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHR9XG5cdFx0YCxcblx0fTtcblxuXHRyZXR1cm4gc2l6ZXNbIHNlbGVjdFNpemUgXTtcbn07XG5cbmV4cG9ydCBjb25zdCBVbml0TGFiZWwgPSBzdHlsZWQuZGl2PCBTZWxlY3RQcm9wcyA+YFxuXHQmJiYge1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXG5cdFx0JHsgYmFzZVVuaXRMYWJlbFN0eWxlcyB9O1xuXG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHR9XG5gO1xuXG5jb25zdCB1bml0U2VsZWN0U2l6ZXMgPSAoIHsgc2VsZWN0U2l6ZSA9ICdkZWZhdWx0JyB9OiBTZWxlY3RQcm9wcyApID0+IHtcblx0Y29uc3Qgc2l6ZXMgPSB7XG5cdFx0c21hbGw6IGNzc2Bcblx0XHRcdGhlaWdodDogMTAwJTtcblx0XHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0dHJhbnNpdGlvbjpcblx0XHRcdFx0Ym94LXNoYWRvdyAwLjFzIGxpbmVhcixcblx0XHRcdFx0Ym9yZGVyIDAuMXMgbGluZWFyO1xuXG5cdFx0XHQkeyBydGwoIHsgYm9yZGVyVG9wTGVmdFJhZGl1czogMCwgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogMCB9ICkoKSB9XG5cblx0XHRcdCY6bm90KDpkaXNhYmxlZCk6aG92ZXIge1xuXHRcdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0XHRcdH1cblxuXHRcdFx0Jjpmb2N1cyB7XG5cdFx0XHRcdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRib3gtc2hhZG93OiBpbnNldCAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aCArICcgJyArIENPTE9SUy51aS5ib3JkZXJGb2N1cyB9O1xuXHRcdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0fVxuXHRcdGAsXG5cdFx0ZGVmYXVsdDogY3NzYFxuXHRcdFx0ZGlzcGxheTogZmxleDtcblx0XHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdFx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblxuXHRcdFx0Jjp3aGVyZSggOm5vdCggOmRpc2FibGVkICkgKTpob3ZlciB7XG5cdFx0XHRcdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0XHRcdFx0JHsgQ09ORklHLmJvcmRlcldpZHRoICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkIHRyYW5zcGFyZW50OyAvLyBGb3IgSGlnaCBDb250cmFzdCBNb2RlXG5cdFx0XHR9XG5cblx0XHRcdCY6Zm9jdXMge1xuXHRcdFx0XHRib3gtc2hhZG93OiAwIDAgMFxuXHRcdFx0XHRcdCR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzICsgJyAnICsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHRcdG91dGxpbmU6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgdHJhbnNwYXJlbnQ7IC8vIEZvciBIaWdoIENvbnRyYXN0IE1vZGVcblx0XHRcdH1cblx0XHRgLFxuXHR9O1xuXG5cdHJldHVybiBzaXplc1sgc2VsZWN0U2l6ZSBdO1xufTtcblxuZXhwb3J0IGNvbnN0IFVuaXRTZWxlY3QgPSBzdHlsZWQuc2VsZWN0PCBTZWxlY3RQcm9wcyA+YFxuXHQvLyBUaGUgJiYmIGNvdW50ZXJhY3RzIDxzZWxlY3Q+IHN0eWxlcyBpbiBXUCBmb3Jtcy5jc3Ncblx0JiYmIHtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJhY2tncm91bmQ6IHRyYW5zcGFyZW50O1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNYU21hbGwgfTtcblx0XHRib3JkZXI6IG5vbmU7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0b3V0bGluZTogbm9uZTtcblx0XHQvKiBSZW1vdmluZyBtYXJnaW4gZW5zdXJlcyBmb2N1cyBzdHlsZXMgbmVhdGx5IG92ZXJsYXkgdGhlIHdyYXBwZXIuICovXG5cdFx0bWFyZ2luOiAwO1xuXHRcdG1pbi1oZWlnaHQ6IGF1dG87XG5cdFx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cblx0XHQmOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdH1cblxuXHRcdCR7IGJhc2VVbml0TGFiZWxTdHlsZXMgfTtcblx0XHQkeyB1bml0U2VsZWN0U2l6ZXMgfTtcblx0fVxuYDtcbiJdfQ== */")); 33711 33712 // packages/components/build-module/border-control/styles.js 33713 function _EMOTION_STRINGIFIED_CSS_ERROR__14() { 33714 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 33715 } 33716 var focusBoxShadow = /* @__PURE__ */ css("box-shadow:inset ", config_values_default.controlBoxShadowFocus, ";" + (false ? "" : ";label:focusBoxShadow;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33717 var borderControl = /* @__PURE__ */ css("border:0;padding:0;margin:0;", boxSizingReset, ";" + (false ? "" : ";label:borderControl;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQmdDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33718 var innerWrapper = () => /* @__PURE__ */ css(ValueInput, "{flex:1 1 40%;}&& ", UnitSelect, "{min-height:0;}" + (false ? "" : ";label:innerWrapper;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QnFDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33719 var wrapperWidth = /* @__PURE__ */ css(ValueInput, "{flex:0 0 auto;}" + (false ? "" : ";label:wrapperWidth;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QytCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33720 var wrapperHeight = (size3) => { 33721 return /* @__PURE__ */ css("height:", size3 === "__unstable-large" ? "40px" : "30px", ";" + (false ? "" : ";label:wrapperHeight;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRFciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHtcblx0VmFsdWVJbnB1dCBhcyBVbml0Q29udHJvbFdyYXBwZXIsXG5cdFVuaXRTZWxlY3QsXG59IGZyb20gJy4uL3VuaXQtY29udHJvbC9zdHlsZXMvdW5pdC1jb250cm9sLXN0eWxlcyc7XG5cbmltcG9ydCB0eXBlIHsgQm9yZGVyIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGZvY3VzQm94U2hhZG93ID0gY3NzYFxuXHRib3gtc2hhZG93OiBpbnNldCAkeyBDT05GSUcuY29udHJvbEJveFNoYWRvd0ZvY3VzIH07XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbCA9IGNzc2Bcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBpbm5lcldyYXBwZXIgPSAoKSA9PiBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHRmbGV4OiAxIDEgNDAlO1xuXHR9XG5cdCYmICR7IFVuaXRTZWxlY3QgfSB7XG5cdFx0LyogUHJldmVudCB1bml0IHNlbGVjdCBmb3JjaW5nIG1pbiBoZWlnaHQgbGFyZ2VyIHRoYW4gaXRzIFVuaXRDb250cm9sICovXG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuLypcbiAqIFRoaXMgc3R5bGUgaXMgb25seSBhcHBsaWVkIHRvIHRoZSBVbml0Q29udHJvbCB3cmFwcGVyIHdoZW4gdGhlIGJvcmRlciB3aWR0aFxuICogZmllbGQgc2hvdWxkIGJlIGEgc2V0IHdpZHRoLiBPbWl0dGluZyB0aGlzIGFsbG93cyB0aGUgVW5pdENvbnRyb2wgJlxuICogUmFuZ2VDb250cm9sIHRvIHNoYXJlIHRoZSBhdmFpbGFibGUgd2lkdGggaW4gYSA0MC82MCBzcGxpdCByZXNwZWN0aXZlbHkuXG4gKi9cbmV4cG9ydCBjb25zdCB3cmFwcGVyV2lkdGggPSBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHQvKiBGb3JjZSB0aGUgVW5pdENvbnRyb2wncyBzZXQgd2lkdGguICovXG5cdFx0ZmxleDogMCAwIGF1dG87XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVySGVpZ2h0ID0gKCBzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzQwcHgnIDogJzMwcHgnIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbERyb3Bkb3duID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAjZmZmO1xuXG5cdCYmID4gYnV0dG9uIHtcblx0XHRhc3BlY3QtcmF0aW86IDE7XG5cdFx0cGFkZGluZzogMDtcblx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0JHsgcnRsKFxuXHRcdFx0eyBib3JkZXJSYWRpdXM6IGAycHggMCAwIDJweGAgfSxcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMCAycHggMnB4IDBgIH1cblx0XHQpKCkgfVxuXHRcdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlciB9O1xuXG5cdFx0Jjpmb2N1cyxcblx0XHQmOmhvdmVyOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0JHsgZm9jdXNCb3hTaGFkb3cgfVxuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JCb3JkZXIgPSAoIGJvcmRlcj86IEJvcmRlciApID0+IHtcblx0Y29uc3QgeyBjb2xvciwgc3R5bGUgfSA9IGJvcmRlciB8fCB7fTtcblxuXHRjb25zdCBmYWxsYmFja0NvbG9yID1cblx0XHQhISBzdHlsZSAmJiBzdHlsZSAhPT0gJ25vbmUnID8gQ09MT1JTLmdyYXlbIDMwMCBdIDogdW5kZWZpbmVkO1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXN0eWxlOiAkeyBzdHlsZSA9PT0gJ25vbmUnID8gJ3NvbGlkJyA6IHN0eWxlIH07XG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBjb2xvciB8fCBmYWxsYmFja0NvbG9yIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JXcmFwcGVyID0gKFxuXHRib3JkZXI/OiBCb3JkZXIsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRjb25zdCB7IHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzRnVsbCB9O1xuXHRcdGJvcmRlcjogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdCR7IHN0eWxlID8gY29sb3JJbmRpY2F0b3JCb3JkZXIoIGJvcmRlciApIDogdW5kZWZpbmVkIH1cblx0XHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0aGVpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjRweCcgOiAnMjJweCcgfTtcblx0XHRwYWRkaW5nOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMnB4JyA6ICcxcHgnIH07XG5cblx0XHQvKlxuXHRcdCAqIENvbG9ySW5kaWNhdG9yXG5cdFx0ICpcblx0XHQgKiBUaGUgdHJhbnNwYXJlbnQgY29sb3JzIHVzZWQgaGVyZSBlbnN1cmUgdmlzaWJpbGl0eSBvZiB0aGUgaW5kaWNhdG9yXG5cdFx0ICogb3ZlciB0aGUgYWN0aXZlIHN0YXRlIG9mIHRoZSBib3JkZXIgY29udHJvbCBkcm9wZG93bidzIHRvZ2dsZSBidXR0b24uXG5cdFx0ICovXG5cdFx0JiA+IHNwYW4ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5cdFx0XHR3aWR0aDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0YmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuXHRcdFx0XHQtNDVkZWcsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDUyJSxcblx0XHRcdFx0dHJhbnNwYXJlbnQgNTIlXG5cdFx0XHQpO1xuXHRcdH1cblx0YDtcbn07XG5cbi8vIE11c3QgZXF1YWwgJGNvbG9yLXBhbGV0dGUtY2lyY2xlLXNpemUgZnJvbTpcbi8vIEB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvY2lyY3VsYXItb3B0aW9uLXBpY2tlci9zdHlsZS5zY3NzXG5jb25zdCBzd2F0Y2hTaXplID0gMjg7XG5jb25zdCBzd2F0Y2hHYXAgPSAxMjtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udHJvbHMgPSBjc3NgXG5cdHdpZHRoOiAkeyBzd2F0Y2hTaXplICogNiArIHN3YXRjaEdhcCAqIDUgfXB4O1xuXG5cdD4gZGl2OmZpcnN0LW9mLXR5cGUgPiAkeyBTdHlsZWRMYWJlbCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5cblx0JiYgJHsgU3R5bGVkTGFiZWwgfSArIGJ1dHRvbjpub3QoIC5oYXMtdGV4dCApIHtcblx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0cGFkZGluZzogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udGVudCA9IGNzc2BgO1xuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9ySW5kaWNhdG9yID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCByZXNldEJ1dHRvbldyYXBwZXIgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG5cdG1hcmdpbi10b3A6IDEycHg7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyU2xpZGVyID0gKCkgPT4gY3NzYFxuXHRmbGV4OiAxIDEgNjAlO1xuXHQkeyBydGwoIHsgbWFyZ2luUmlnaHQ6IHNwYWNlKCAzICkgfSApKCkgfVxuYDtcbiJdfQ== */"); 33722 }; 33723 var borderControlDropdown = /* @__PURE__ */ css("background:#fff;&&>button{aspect-ratio:1;padding:0;display:flex;align-items:center;justify-content:center;", rtl({ 33724 borderRadius: `2px 0 0 2px` 33725 }, { 33726 borderRadius: `0 2px 2px 0` 33727 })(), " border:", config_values_default.borderWidth, " solid ", COLORS.ui.border, ";&:focus,&:hover:not( :disabled ){", focusBoxShadow, " border-color:", COLORS.ui.borderFocus, ";z-index:1;position:relative;}}" + (false ? "" : ";label:borderControlDropdown;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RHdDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33728 var colorIndicatorBorder = (border) => { 33729 const { 33730 color: color2, 33731 style: style2 33732 } = border || {}; 33733 const fallbackColor = !!style2 && style2 !== "none" ? COLORS.gray[300] : void 0; 33734 return /* @__PURE__ */ css("border-style:", style2 === "none" ? "solid" : style2, ";border-color:", color2 || fallbackColor, ";" + (false ? "" : ";label:colorIndicatorBorder;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RlciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHtcblx0VmFsdWVJbnB1dCBhcyBVbml0Q29udHJvbFdyYXBwZXIsXG5cdFVuaXRTZWxlY3QsXG59IGZyb20gJy4uL3VuaXQtY29udHJvbC9zdHlsZXMvdW5pdC1jb250cm9sLXN0eWxlcyc7XG5cbmltcG9ydCB0eXBlIHsgQm9yZGVyIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGZvY3VzQm94U2hhZG93ID0gY3NzYFxuXHRib3gtc2hhZG93OiBpbnNldCAkeyBDT05GSUcuY29udHJvbEJveFNoYWRvd0ZvY3VzIH07XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbCA9IGNzc2Bcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBpbm5lcldyYXBwZXIgPSAoKSA9PiBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHRmbGV4OiAxIDEgNDAlO1xuXHR9XG5cdCYmICR7IFVuaXRTZWxlY3QgfSB7XG5cdFx0LyogUHJldmVudCB1bml0IHNlbGVjdCBmb3JjaW5nIG1pbiBoZWlnaHQgbGFyZ2VyIHRoYW4gaXRzIFVuaXRDb250cm9sICovXG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuLypcbiAqIFRoaXMgc3R5bGUgaXMgb25seSBhcHBsaWVkIHRvIHRoZSBVbml0Q29udHJvbCB3cmFwcGVyIHdoZW4gdGhlIGJvcmRlciB3aWR0aFxuICogZmllbGQgc2hvdWxkIGJlIGEgc2V0IHdpZHRoLiBPbWl0dGluZyB0aGlzIGFsbG93cyB0aGUgVW5pdENvbnRyb2wgJlxuICogUmFuZ2VDb250cm9sIHRvIHNoYXJlIHRoZSBhdmFpbGFibGUgd2lkdGggaW4gYSA0MC82MCBzcGxpdCByZXNwZWN0aXZlbHkuXG4gKi9cbmV4cG9ydCBjb25zdCB3cmFwcGVyV2lkdGggPSBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHQvKiBGb3JjZSB0aGUgVW5pdENvbnRyb2wncyBzZXQgd2lkdGguICovXG5cdFx0ZmxleDogMCAwIGF1dG87XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVySGVpZ2h0ID0gKCBzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzQwcHgnIDogJzMwcHgnIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbERyb3Bkb3duID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAjZmZmO1xuXG5cdCYmID4gYnV0dG9uIHtcblx0XHRhc3BlY3QtcmF0aW86IDE7XG5cdFx0cGFkZGluZzogMDtcblx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0JHsgcnRsKFxuXHRcdFx0eyBib3JkZXJSYWRpdXM6IGAycHggMCAwIDJweGAgfSxcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMCAycHggMnB4IDBgIH1cblx0XHQpKCkgfVxuXHRcdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlciB9O1xuXG5cdFx0Jjpmb2N1cyxcblx0XHQmOmhvdmVyOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0JHsgZm9jdXNCb3hTaGFkb3cgfVxuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JCb3JkZXIgPSAoIGJvcmRlcj86IEJvcmRlciApID0+IHtcblx0Y29uc3QgeyBjb2xvciwgc3R5bGUgfSA9IGJvcmRlciB8fCB7fTtcblxuXHRjb25zdCBmYWxsYmFja0NvbG9yID1cblx0XHQhISBzdHlsZSAmJiBzdHlsZSAhPT0gJ25vbmUnID8gQ09MT1JTLmdyYXlbIDMwMCBdIDogdW5kZWZpbmVkO1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXN0eWxlOiAkeyBzdHlsZSA9PT0gJ25vbmUnID8gJ3NvbGlkJyA6IHN0eWxlIH07XG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBjb2xvciB8fCBmYWxsYmFja0NvbG9yIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JXcmFwcGVyID0gKFxuXHRib3JkZXI/OiBCb3JkZXIsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRjb25zdCB7IHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzRnVsbCB9O1xuXHRcdGJvcmRlcjogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdCR7IHN0eWxlID8gY29sb3JJbmRpY2F0b3JCb3JkZXIoIGJvcmRlciApIDogdW5kZWZpbmVkIH1cblx0XHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0aGVpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjRweCcgOiAnMjJweCcgfTtcblx0XHRwYWRkaW5nOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMnB4JyA6ICcxcHgnIH07XG5cblx0XHQvKlxuXHRcdCAqIENvbG9ySW5kaWNhdG9yXG5cdFx0ICpcblx0XHQgKiBUaGUgdHJhbnNwYXJlbnQgY29sb3JzIHVzZWQgaGVyZSBlbnN1cmUgdmlzaWJpbGl0eSBvZiB0aGUgaW5kaWNhdG9yXG5cdFx0ICogb3ZlciB0aGUgYWN0aXZlIHN0YXRlIG9mIHRoZSBib3JkZXIgY29udHJvbCBkcm9wZG93bidzIHRvZ2dsZSBidXR0b24uXG5cdFx0ICovXG5cdFx0JiA+IHNwYW4ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5cdFx0XHR3aWR0aDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0YmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuXHRcdFx0XHQtNDVkZWcsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDUyJSxcblx0XHRcdFx0dHJhbnNwYXJlbnQgNTIlXG5cdFx0XHQpO1xuXHRcdH1cblx0YDtcbn07XG5cbi8vIE11c3QgZXF1YWwgJGNvbG9yLXBhbGV0dGUtY2lyY2xlLXNpemUgZnJvbTpcbi8vIEB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvY2lyY3VsYXItb3B0aW9uLXBpY2tlci9zdHlsZS5zY3NzXG5jb25zdCBzd2F0Y2hTaXplID0gMjg7XG5jb25zdCBzd2F0Y2hHYXAgPSAxMjtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udHJvbHMgPSBjc3NgXG5cdHdpZHRoOiAkeyBzd2F0Y2hTaXplICogNiArIHN3YXRjaEdhcCAqIDUgfXB4O1xuXG5cdD4gZGl2OmZpcnN0LW9mLXR5cGUgPiAkeyBTdHlsZWRMYWJlbCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5cblx0JiYgJHsgU3R5bGVkTGFiZWwgfSArIGJ1dHRvbjpub3QoIC5oYXMtdGV4dCApIHtcblx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0cGFkZGluZzogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udGVudCA9IGNzc2BgO1xuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9ySW5kaWNhdG9yID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCByZXNldEJ1dHRvbldyYXBwZXIgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG5cdG1hcmdpbi10b3A6IDEycHg7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyU2xpZGVyID0gKCkgPT4gY3NzYFxuXHRmbGV4OiAxIDEgNjAlO1xuXHQkeyBydGwoIHsgbWFyZ2luUmlnaHQ6IHNwYWNlKCAzICkgfSApKCkgfVxuYDtcbiJdfQ== */"); 33735 }; 33736 var colorIndicatorWrapper = (border, size3) => { 33737 const { 33738 style: style2 33739 } = border || {}; 33740 return /* @__PURE__ */ css("border-radius:", config_values_default.radiusFull, ";border:2px solid transparent;", style2 ? colorIndicatorBorder(border) : void 0, " width:", size3 === "__unstable-large" ? "24px" : "22px", ";height:", size3 === "__unstable-large" ? "24px" : "22px", ";padding:", size3 === "__unstable-large" ? "2px" : "1px", ";&>span{height:", space(4), ";width:", space(4), ";background:linear-gradient(\n -45deg,\n transparent 48%,\n rgb( 0 0 0 / 20% ) 48%,\n rgb( 0 0 0 / 20% ) 52%,\n transparent 52%\n );}" + (false ? "" : ";label:colorIndicatorWrapper;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvR1ciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHtcblx0VmFsdWVJbnB1dCBhcyBVbml0Q29udHJvbFdyYXBwZXIsXG5cdFVuaXRTZWxlY3QsXG59IGZyb20gJy4uL3VuaXQtY29udHJvbC9zdHlsZXMvdW5pdC1jb250cm9sLXN0eWxlcyc7XG5cbmltcG9ydCB0eXBlIHsgQm9yZGVyIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGZvY3VzQm94U2hhZG93ID0gY3NzYFxuXHRib3gtc2hhZG93OiBpbnNldCAkeyBDT05GSUcuY29udHJvbEJveFNoYWRvd0ZvY3VzIH07XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbCA9IGNzc2Bcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBpbm5lcldyYXBwZXIgPSAoKSA9PiBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHRmbGV4OiAxIDEgNDAlO1xuXHR9XG5cdCYmICR7IFVuaXRTZWxlY3QgfSB7XG5cdFx0LyogUHJldmVudCB1bml0IHNlbGVjdCBmb3JjaW5nIG1pbiBoZWlnaHQgbGFyZ2VyIHRoYW4gaXRzIFVuaXRDb250cm9sICovXG5cdFx0bWluLWhlaWdodDogMDtcblx0fVxuYDtcblxuLypcbiAqIFRoaXMgc3R5bGUgaXMgb25seSBhcHBsaWVkIHRvIHRoZSBVbml0Q29udHJvbCB3cmFwcGVyIHdoZW4gdGhlIGJvcmRlciB3aWR0aFxuICogZmllbGQgc2hvdWxkIGJlIGEgc2V0IHdpZHRoLiBPbWl0dGluZyB0aGlzIGFsbG93cyB0aGUgVW5pdENvbnRyb2wgJlxuICogUmFuZ2VDb250cm9sIHRvIHNoYXJlIHRoZSBhdmFpbGFibGUgd2lkdGggaW4gYSA0MC82MCBzcGxpdCByZXNwZWN0aXZlbHkuXG4gKi9cbmV4cG9ydCBjb25zdCB3cmFwcGVyV2lkdGggPSBjc3NgXG5cdCR7IFVuaXRDb250cm9sV3JhcHBlciB9IHtcblx0XHQvKiBGb3JjZSB0aGUgVW5pdENvbnRyb2wncyBzZXQgd2lkdGguICovXG5cdFx0ZmxleDogMCAwIGF1dG87XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVySGVpZ2h0ID0gKCBzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzQwcHgnIDogJzMwcHgnIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgYm9yZGVyQ29udHJvbERyb3Bkb3duID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAjZmZmO1xuXG5cdCYmID4gYnV0dG9uIHtcblx0XHRhc3BlY3QtcmF0aW86IDE7XG5cdFx0cGFkZGluZzogMDtcblx0XHRkaXNwbGF5OiBmbGV4O1xuXHRcdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdFx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdFx0JHsgcnRsKFxuXHRcdFx0eyBib3JkZXJSYWRpdXM6IGAycHggMCAwIDJweGAgfSxcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMCAycHggMnB4IDBgIH1cblx0XHQpKCkgfVxuXHRcdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlciB9O1xuXG5cdFx0Jjpmb2N1cyxcblx0XHQmOmhvdmVyOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0JHsgZm9jdXNCb3hTaGFkb3cgfVxuXHRcdFx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudWkuYm9yZGVyRm9jdXMgfTtcblx0XHRcdHotaW5kZXg6IDE7XG5cdFx0XHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JCb3JkZXIgPSAoIGJvcmRlcj86IEJvcmRlciApID0+IHtcblx0Y29uc3QgeyBjb2xvciwgc3R5bGUgfSA9IGJvcmRlciB8fCB7fTtcblxuXHRjb25zdCBmYWxsYmFja0NvbG9yID1cblx0XHQhISBzdHlsZSAmJiBzdHlsZSAhPT0gJ25vbmUnID8gQ09MT1JTLmdyYXlbIDMwMCBdIDogdW5kZWZpbmVkO1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXN0eWxlOiAkeyBzdHlsZSA9PT0gJ25vbmUnID8gJ3NvbGlkJyA6IHN0eWxlIH07XG5cdFx0Ym9yZGVyLWNvbG9yOiAkeyBjb2xvciB8fCBmYWxsYmFja0NvbG9yIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgY29sb3JJbmRpY2F0b3JXcmFwcGVyID0gKFxuXHRib3JkZXI/OiBCb3JkZXIsXG5cdHNpemU/OiAnZGVmYXVsdCcgfCAnX191bnN0YWJsZS1sYXJnZSdcbikgPT4ge1xuXHRjb25zdCB7IHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0cmV0dXJuIGNzc2Bcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzRnVsbCB9O1xuXHRcdGJvcmRlcjogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdCR7IHN0eWxlID8gY29sb3JJbmRpY2F0b3JCb3JkZXIoIGJvcmRlciApIDogdW5kZWZpbmVkIH1cblx0XHR3aWR0aDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0aGVpZ2h0OiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMjRweCcgOiAnMjJweCcgfTtcblx0XHRwYWRkaW5nOiAkeyBzaXplID09PSAnX191bnN0YWJsZS1sYXJnZScgPyAnMnB4JyA6ICcxcHgnIH07XG5cblx0XHQvKlxuXHRcdCAqIENvbG9ySW5kaWNhdG9yXG5cdFx0ICpcblx0XHQgKiBUaGUgdHJhbnNwYXJlbnQgY29sb3JzIHVzZWQgaGVyZSBlbnN1cmUgdmlzaWJpbGl0eSBvZiB0aGUgaW5kaWNhdG9yXG5cdFx0ICogb3ZlciB0aGUgYWN0aXZlIHN0YXRlIG9mIHRoZSBib3JkZXIgY29udHJvbCBkcm9wZG93bidzIHRvZ2dsZSBidXR0b24uXG5cdFx0ICovXG5cdFx0JiA+IHNwYW4ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5cdFx0XHR3aWR0aDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0YmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuXHRcdFx0XHQtNDVkZWcsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDQ4JSxcblx0XHRcdFx0cmdiKCAwIDAgMCAvIDIwJSApIDUyJSxcblx0XHRcdFx0dHJhbnNwYXJlbnQgNTIlXG5cdFx0XHQpO1xuXHRcdH1cblx0YDtcbn07XG5cbi8vIE11c3QgZXF1YWwgJGNvbG9yLXBhbGV0dGUtY2lyY2xlLXNpemUgZnJvbTpcbi8vIEB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvY2lyY3VsYXItb3B0aW9uLXBpY2tlci9zdHlsZS5zY3NzXG5jb25zdCBzd2F0Y2hTaXplID0gMjg7XG5jb25zdCBzd2F0Y2hHYXAgPSAxMjtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udHJvbHMgPSBjc3NgXG5cdHdpZHRoOiAkeyBzd2F0Y2hTaXplICogNiArIHN3YXRjaEdhcCAqIDUgfXB4O1xuXG5cdD4gZGl2OmZpcnN0LW9mLXR5cGUgPiAkeyBTdHlsZWRMYWJlbCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5cblx0JiYgJHsgU3R5bGVkTGFiZWwgfSArIGJ1dHRvbjpub3QoIC5oYXMtdGV4dCApIHtcblx0XHRtaW4td2lkdGg6IDI0cHg7XG5cdFx0cGFkZGluZzogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xQb3BvdmVyQ29udGVudCA9IGNzc2BgO1xuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9ySW5kaWNhdG9yID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCByZXNldEJ1dHRvbldyYXBwZXIgPSBjc3NgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG5cdG1hcmdpbi10b3A6IDEycHg7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyU2xpZGVyID0gKCkgPT4gY3NzYFxuXHRmbGV4OiAxIDEgNjAlO1xuXHQkeyBydGwoIHsgbWFyZ2luUmlnaHQ6IHNwYWNlKCAzICkgfSApKCkgfVxuYDtcbiJdfQ== */"); 33741 }; 33742 var swatchSize = 28; 33743 var swatchGap = 12; 33744 var borderControlPopoverControls = /* @__PURE__ */ css("width:", swatchSize * 6 + swatchGap * 5, "px;>div:first-of-type>", StyledLabel, "{margin-bottom:0;}&& ", StyledLabel, "+button:not( .has-text ){min-width:24px;padding:0;}" + (false ? "" : ";label:borderControlPopoverControls;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSStDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33745 var borderControlPopoverContent = /* @__PURE__ */ css(false ? "" : ";label:borderControlPopoverContent;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrSjhDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33746 var borderColorIndicator = /* @__PURE__ */ css(false ? "" : ";label:borderColorIndicator;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtSnVDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33747 var resetButtonWrapper = false ? { 33748 name: "1ghe26v", 33749 styles: "display:flex;justify-content:flex-end;margin-top:12px" 33750 } : { 33751 name: "1a93xby-resetButtonWrapper", 33752 styles: "display:flex;justify-content:flex-end;margin-top:12px;label:resetButtonWrapper;", 33753 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSnFDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */", 33754 toString: _EMOTION_STRINGIFIED_CSS_ERROR__14 33755 }; 33756 var borderSlider = () => /* @__PURE__ */ css("flex:1 1 60%;", rtl({ 33757 marginRight: space(3) 33758 })(), ";" + (false ? "" : ";label:borderSlider;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEySnFDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIGJveFNpemluZ1Jlc2V0LCBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IFN0eWxlZExhYmVsIH0gZnJvbSAnLi4vYmFzZS1jb250cm9sL3N0eWxlcy9iYXNlLWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCB7XG5cdFZhbHVlSW5wdXQgYXMgVW5pdENvbnRyb2xXcmFwcGVyLFxuXHRVbml0U2VsZWN0LFxufSBmcm9tICcuLi91bml0LWNvbnRyb2wvc3R5bGVzL3VuaXQtY29udHJvbC1zdHlsZXMnO1xuXG5pbXBvcnQgdHlwZSB7IEJvcmRlciB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBmb2N1c0JveFNoYWRvdyA9IGNzc2Bcblx0Ym94LXNoYWRvdzogaW5zZXQgJHsgQ09ORklHLmNvbnRyb2xCb3hTaGFkb3dGb2N1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2wgPSBjc3NgXG5cdGJvcmRlcjogMDtcblx0cGFkZGluZzogMDtcblx0bWFyZ2luOiAwO1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgaW5uZXJXcmFwcGVyID0gKCkgPT4gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0ZmxleDogMSAxIDQwJTtcblx0fVxuXHQmJiAkeyBVbml0U2VsZWN0IH0ge1xuXHRcdC8qIFByZXZlbnQgdW5pdCBzZWxlY3QgZm9yY2luZyBtaW4gaGVpZ2h0IGxhcmdlciB0aGFuIGl0cyBVbml0Q29udHJvbCAqL1xuXHRcdG1pbi1oZWlnaHQ6IDA7XG5cdH1cbmA7XG5cbi8qXG4gKiBUaGlzIHN0eWxlIGlzIG9ubHkgYXBwbGllZCB0byB0aGUgVW5pdENvbnRyb2wgd3JhcHBlciB3aGVuIHRoZSBib3JkZXIgd2lkdGhcbiAqIGZpZWxkIHNob3VsZCBiZSBhIHNldCB3aWR0aC4gT21pdHRpbmcgdGhpcyBhbGxvd3MgdGhlIFVuaXRDb250cm9sICZcbiAqIFJhbmdlQ29udHJvbCB0byBzaGFyZSB0aGUgYXZhaWxhYmxlIHdpZHRoIGluIGEgNDAvNjAgc3BsaXQgcmVzcGVjdGl2ZWx5LlxuICovXG5leHBvcnQgY29uc3Qgd3JhcHBlcldpZHRoID0gY3NzYFxuXHQkeyBVbml0Q29udHJvbFdyYXBwZXIgfSB7XG5cdFx0LyogRm9yY2UgdGhlIFVuaXRDb250cm9sJ3Mgc2V0IHdpZHRoLiAqL1xuXHRcdGZsZXg6IDAgMCBhdXRvO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlckhlaWdodCA9ICggc2l6ZT86ICdkZWZhdWx0JyB8ICdfX3Vuc3RhYmxlLWxhcmdlJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRoZWlnaHQ6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICc0MHB4JyA6ICczMHB4JyB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbnRyb2xEcm9wZG93biA9IGNzc2Bcblx0YmFja2dyb3VuZDogI2ZmZjtcblxuXHQmJiA+IGJ1dHRvbiB7XG5cdFx0YXNwZWN0LXJhdGlvOiAxO1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0ZGlzcGxheTogZmxleDtcblx0XHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRcdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRcdCR7IHJ0bChcblx0XHRcdHsgYm9yZGVyUmFkaXVzOiBgMnB4IDAgMCAycHhgIH0sXG5cdFx0XHR7IGJvcmRlclJhZGl1czogYDAgMnB4IDJweCAwYCB9XG5cdFx0KSgpIH1cblx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRcdCY6Zm9jdXMsXG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdCR7IGZvY3VzQm94U2hhZG93IH1cblx0XHRcdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnVpLmJvcmRlckZvY3VzIH07XG5cdFx0XHR6LWluZGV4OiAxO1xuXHRcdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yQm9yZGVyID0gKCBib3JkZXI/OiBCb3JkZXIgKSA9PiB7XG5cdGNvbnN0IHsgY29sb3IsIHN0eWxlIH0gPSBib3JkZXIgfHwge307XG5cblx0Y29uc3QgZmFsbGJhY2tDb2xvciA9XG5cdFx0ISEgc3R5bGUgJiYgc3R5bGUgIT09ICdub25lJyA/IENPTE9SUy5ncmF5WyAzMDAgXSA6IHVuZGVmaW5lZDtcblxuXHRyZXR1cm4gY3NzYFxuXHRcdGJvcmRlci1zdHlsZTogJHsgc3R5bGUgPT09ICdub25lJyA/ICdzb2xpZCcgOiBzdHlsZSB9O1xuXHRcdGJvcmRlci1jb2xvcjogJHsgY29sb3IgfHwgZmFsbGJhY2tDb2xvciB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvbG9ySW5kaWNhdG9yV3JhcHBlciA9IChcblx0Ym9yZGVyPzogQm9yZGVyLFxuXHRzaXplPzogJ2RlZmF1bHQnIHwgJ19fdW5zdGFibGUtbGFyZ2UnXG4pID0+IHtcblx0Y29uc3QgeyBzdHlsZSB9ID0gYm9yZGVyIHx8IHt9O1xuXG5cdHJldHVybiBjc3NgXG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0XHRib3JkZXI6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHQkeyBzdHlsZSA/IGNvbG9ySW5kaWNhdG9yQm9yZGVyKCBib3JkZXIgKSA6IHVuZGVmaW5lZCB9XG5cdFx0d2lkdGg6ICR7IHNpemUgPT09ICdfX3Vuc3RhYmxlLWxhcmdlJyA/ICcyNHB4JyA6ICcyMnB4JyB9O1xuXHRcdGhlaWdodDogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzI0cHgnIDogJzIycHgnIH07XG5cdFx0cGFkZGluZzogJHsgc2l6ZSA9PT0gJ19fdW5zdGFibGUtbGFyZ2UnID8gJzJweCcgOiAnMXB4JyB9O1xuXG5cdFx0Lypcblx0XHQgKiBDb2xvckluZGljYXRvclxuXHRcdCAqXG5cdFx0ICogVGhlIHRyYW5zcGFyZW50IGNvbG9ycyB1c2VkIGhlcmUgZW5zdXJlIHZpc2liaWxpdHkgb2YgdGhlIGluZGljYXRvclxuXHRcdCAqIG92ZXIgdGhlIGFjdGl2ZSBzdGF0ZSBvZiB0aGUgYm9yZGVyIGNvbnRyb2wgZHJvcGRvd24ncyB0b2dnbGUgYnV0dG9uLlxuXHRcdCAqL1xuXHRcdCYgPiBzcGFuIHtcblx0XHRcdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuXHRcdFx0d2lkdGg6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRcdGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcblx0XHRcdFx0LTQ1ZGVnLFxuXHRcdFx0XHR0cmFuc3BhcmVudCA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA0OCUsXG5cdFx0XHRcdHJnYiggMCAwIDAgLyAyMCUgKSA1MiUsXG5cdFx0XHRcdHRyYW5zcGFyZW50IDUyJVxuXHRcdFx0KTtcblx0XHR9XG5cdGA7XG59O1xuXG4vLyBNdXN0IGVxdWFsICRjb2xvci1wYWxldHRlLWNpcmNsZS1zaXplIGZyb206XG4vLyBAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2NpcmN1bGFyLW9wdGlvbi1waWNrZXIvc3R5bGUuc2Nzc1xuY29uc3Qgc3dhdGNoU2l6ZSA9IDI4O1xuY29uc3Qgc3dhdGNoR2FwID0gMTI7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRyb2xzID0gY3NzYFxuXHR3aWR0aDogJHsgc3dhdGNoU2l6ZSAqIDYgKyBzd2F0Y2hHYXAgKiA1IH1weDtcblxuXHQ+IGRpdjpmaXJzdC1vZi10eXBlID4gJHsgU3R5bGVkTGFiZWwgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblx0fVxuXG5cdCYmICR7IFN0eWxlZExhYmVsIH0gKyBidXR0b246bm90KCAuaGFzLXRleHQgKSB7XG5cdFx0bWluLXdpZHRoOiAyNHB4O1xuXHRcdHBhZGRpbmc6IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJDb250cm9sUG9wb3ZlckNvbnRlbnQgPSBjc3NgYDtcbmV4cG9ydCBjb25zdCBib3JkZXJDb2xvckluZGljYXRvciA9IGNzc2BgO1xuXG5leHBvcnQgY29uc3QgcmVzZXRCdXR0b25XcmFwcGVyID0gY3NzYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtZW5kO1xuXHRtYXJnaW4tdG9wOiAxMnB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlclNsaWRlciA9ICgpID0+IGNzc2Bcblx0ZmxleDogMSAxIDYwJTtcblx0JHsgcnRsKCB7IG1hcmdpblJpZ2h0OiBzcGFjZSggMyApIH0gKSgpIH1cbmA7XG4iXX0= */"); 33759 33760 // packages/components/build-module/unit-control/utils.js 33761 var import_i18n21 = __toESM(require_i18n()); 33762 var import_element83 = __toESM(require_element()); 33763 var isWeb = import_element83.Platform.OS === "web"; 33764 var allUnits = { 33765 px: { 33766 value: "px", 33767 label: isWeb ? "px" : (0, import_i18n21.__)("Pixels (px)"), 33768 a11yLabel: (0, import_i18n21.__)("Pixels (px)"), 33769 step: 1 33770 }, 33771 "%": { 33772 value: "%", 33773 label: isWeb ? "%" : (0, import_i18n21.__)("Percentage (%)"), 33774 a11yLabel: (0, import_i18n21.__)("Percent (%)"), 33775 step: 0.1 33776 }, 33777 em: { 33778 value: "em", 33779 label: isWeb ? "em" : (0, import_i18n21.__)("Relative to parent font size (em)"), 33780 a11yLabel: (0, import_i18n21._x)("ems", "Relative to parent font size (em)"), 33781 step: 0.01 33782 }, 33783 rem: { 33784 value: "rem", 33785 label: isWeb ? "rem" : (0, import_i18n21.__)("Relative to root font size (rem)"), 33786 a11yLabel: (0, import_i18n21._x)("rems", "Relative to root font size (rem)"), 33787 step: 0.01 33788 }, 33789 vw: { 33790 value: "vw", 33791 label: isWeb ? "vw" : (0, import_i18n21.__)("Viewport width (vw)"), 33792 a11yLabel: (0, import_i18n21.__)("Viewport width (vw)"), 33793 step: 0.1 33794 }, 33795 vh: { 33796 value: "vh", 33797 label: isWeb ? "vh" : (0, import_i18n21.__)("Viewport height (vh)"), 33798 a11yLabel: (0, import_i18n21.__)("Viewport height (vh)"), 33799 step: 0.1 33800 }, 33801 vmin: { 33802 value: "vmin", 33803 label: isWeb ? "vmin" : (0, import_i18n21.__)("Viewport smallest dimension (vmin)"), 33804 a11yLabel: (0, import_i18n21.__)("Viewport smallest dimension (vmin)"), 33805 step: 0.1 33806 }, 33807 vmax: { 33808 value: "vmax", 33809 label: isWeb ? "vmax" : (0, import_i18n21.__)("Viewport largest dimension (vmax)"), 33810 a11yLabel: (0, import_i18n21.__)("Viewport largest dimension (vmax)"), 33811 step: 0.1 33812 }, 33813 ch: { 33814 value: "ch", 33815 label: isWeb ? "ch" : (0, import_i18n21.__)("Width of the zero (0) character (ch)"), 33816 a11yLabel: (0, import_i18n21.__)("Width of the zero (0) character (ch)"), 33817 step: 0.01 33818 }, 33819 ex: { 33820 value: "ex", 33821 label: isWeb ? "ex" : (0, import_i18n21.__)("x-height of the font (ex)"), 33822 a11yLabel: (0, import_i18n21.__)("x-height of the font (ex)"), 33823 step: 0.01 33824 }, 33825 cm: { 33826 value: "cm", 33827 label: isWeb ? "cm" : (0, import_i18n21.__)("Centimeters (cm)"), 33828 a11yLabel: (0, import_i18n21.__)("Centimeters (cm)"), 33829 step: 1e-3 33830 }, 33831 mm: { 33832 value: "mm", 33833 label: isWeb ? "mm" : (0, import_i18n21.__)("Millimeters (mm)"), 33834 a11yLabel: (0, import_i18n21.__)("Millimeters (mm)"), 33835 step: 0.1 33836 }, 33837 in: { 33838 value: "in", 33839 label: isWeb ? "in" : (0, import_i18n21.__)("Inches (in)"), 33840 a11yLabel: (0, import_i18n21.__)("Inches (in)"), 33841 step: 1e-3 33842 }, 33843 pc: { 33844 value: "pc", 33845 label: isWeb ? "pc" : (0, import_i18n21.__)("Picas (pc)"), 33846 a11yLabel: (0, import_i18n21.__)("Picas (pc)"), 33847 step: 1 33848 }, 33849 pt: { 33850 value: "pt", 33851 label: isWeb ? "pt" : (0, import_i18n21.__)("Points (pt)"), 33852 a11yLabel: (0, import_i18n21.__)("Points (pt)"), 33853 step: 1 33854 }, 33855 svw: { 33856 value: "svw", 33857 label: isWeb ? "svw" : (0, import_i18n21.__)("Small viewport width (svw)"), 33858 a11yLabel: (0, import_i18n21.__)("Small viewport width (svw)"), 33859 step: 0.1 33860 }, 33861 svh: { 33862 value: "svh", 33863 label: isWeb ? "svh" : (0, import_i18n21.__)("Small viewport height (svh)"), 33864 a11yLabel: (0, import_i18n21.__)("Small viewport height (svh)"), 33865 step: 0.1 33866 }, 33867 svi: { 33868 value: "svi", 33869 label: isWeb ? "svi" : (0, import_i18n21.__)("Viewport smallest size in the inline direction (svi)"), 33870 a11yLabel: (0, import_i18n21.__)("Small viewport width or height (svi)"), 33871 step: 0.1 33872 }, 33873 svb: { 33874 value: "svb", 33875 label: isWeb ? "svb" : (0, import_i18n21.__)("Viewport smallest size in the block direction (svb)"), 33876 a11yLabel: (0, import_i18n21.__)("Small viewport width or height (svb)"), 33877 step: 0.1 33878 }, 33879 svmin: { 33880 value: "svmin", 33881 label: isWeb ? "svmin" : (0, import_i18n21.__)("Small viewport smallest dimension (svmin)"), 33882 a11yLabel: (0, import_i18n21.__)("Small viewport smallest dimension (svmin)"), 33883 step: 0.1 33884 }, 33885 lvw: { 33886 value: "lvw", 33887 label: isWeb ? "lvw" : (0, import_i18n21.__)("Large viewport width (lvw)"), 33888 a11yLabel: (0, import_i18n21.__)("Large viewport width (lvw)"), 33889 step: 0.1 33890 }, 33891 lvh: { 33892 value: "lvh", 33893 label: isWeb ? "lvh" : (0, import_i18n21.__)("Large viewport height (lvh)"), 33894 a11yLabel: (0, import_i18n21.__)("Large viewport height (lvh)"), 33895 step: 0.1 33896 }, 33897 lvi: { 33898 value: "lvi", 33899 label: isWeb ? "lvi" : (0, import_i18n21.__)("Large viewport width or height (lvi)"), 33900 a11yLabel: (0, import_i18n21.__)("Large viewport width or height (lvi)"), 33901 step: 0.1 33902 }, 33903 lvb: { 33904 value: "lvb", 33905 label: isWeb ? "lvb" : (0, import_i18n21.__)("Large viewport width or height (lvb)"), 33906 a11yLabel: (0, import_i18n21.__)("Large viewport width or height (lvb)"), 33907 step: 0.1 33908 }, 33909 lvmin: { 33910 value: "lvmin", 33911 label: isWeb ? "lvmin" : (0, import_i18n21.__)("Large viewport smallest dimension (lvmin)"), 33912 a11yLabel: (0, import_i18n21.__)("Large viewport smallest dimension (lvmin)"), 33913 step: 0.1 33914 }, 33915 dvw: { 33916 value: "dvw", 33917 label: isWeb ? "dvw" : (0, import_i18n21.__)("Dynamic viewport width (dvw)"), 33918 a11yLabel: (0, import_i18n21.__)("Dynamic viewport width (dvw)"), 33919 step: 0.1 33920 }, 33921 dvh: { 33922 value: "dvh", 33923 label: isWeb ? "dvh" : (0, import_i18n21.__)("Dynamic viewport height (dvh)"), 33924 a11yLabel: (0, import_i18n21.__)("Dynamic viewport height (dvh)"), 33925 step: 0.1 33926 }, 33927 dvi: { 33928 value: "dvi", 33929 label: isWeb ? "dvi" : (0, import_i18n21.__)("Dynamic viewport width or height (dvi)"), 33930 a11yLabel: (0, import_i18n21.__)("Dynamic viewport width or height (dvi)"), 33931 step: 0.1 33932 }, 33933 dvb: { 33934 value: "dvb", 33935 label: isWeb ? "dvb" : (0, import_i18n21.__)("Dynamic viewport width or height (dvb)"), 33936 a11yLabel: (0, import_i18n21.__)("Dynamic viewport width or height (dvb)"), 33937 step: 0.1 33938 }, 33939 dvmin: { 33940 value: "dvmin", 33941 label: isWeb ? "dvmin" : (0, import_i18n21.__)("Dynamic viewport smallest dimension (dvmin)"), 33942 a11yLabel: (0, import_i18n21.__)("Dynamic viewport smallest dimension (dvmin)"), 33943 step: 0.1 33944 }, 33945 dvmax: { 33946 value: "dvmax", 33947 label: isWeb ? "dvmax" : (0, import_i18n21.__)("Dynamic viewport largest dimension (dvmax)"), 33948 a11yLabel: (0, import_i18n21.__)("Dynamic viewport largest dimension (dvmax)"), 33949 step: 0.1 33950 }, 33951 svmax: { 33952 value: "svmax", 33953 label: isWeb ? "svmax" : (0, import_i18n21.__)("Small viewport largest dimension (svmax)"), 33954 a11yLabel: (0, import_i18n21.__)("Small viewport largest dimension (svmax)"), 33955 step: 0.1 33956 }, 33957 lvmax: { 33958 value: "lvmax", 33959 label: isWeb ? "lvmax" : (0, import_i18n21.__)("Large viewport largest dimension (lvmax)"), 33960 a11yLabel: (0, import_i18n21.__)("Large viewport largest dimension (lvmax)"), 33961 step: 0.1 33962 } 33963 }; 33964 var ALL_CSS_UNITS = Object.values(allUnits); 33965 var CSS_UNITS = [allUnits.px, allUnits["%"], allUnits.em, allUnits.rem, allUnits.vw, allUnits.vh]; 33966 var DEFAULT_UNIT = allUnits.px; 33967 function getParsedQuantityAndUnit(rawValue, fallbackUnit, allowedUnits) { 33968 const initialValue2 = fallbackUnit ? `$rawValue !== null && rawValue !== void 0 ? rawValue : ""}$fallbackUnit}` : rawValue; 33969 return parseQuantityAndUnitFromRawValue(initialValue2, allowedUnits); 33970 } 33971 function hasUnits(units) { 33972 return Array.isArray(units) && !!units.length; 33973 } 33974 function parseQuantityAndUnitFromRawValue(rawValue, allowedUnits = ALL_CSS_UNITS) { 33975 let trimmedValue; 33976 let quantityToReturn; 33977 if (typeof rawValue !== "undefined" || rawValue === null) { 33978 trimmedValue = `$rawValue}`.trim(); 33979 const parsedQuantity = parseFloat(trimmedValue); 33980 quantityToReturn = !isFinite(parsedQuantity) ? void 0 : parsedQuantity; 33981 } 33982 const unitMatch = trimmedValue?.match(/[\d.\-\+]*\s*(.*)/); 33983 const matchedUnit = unitMatch?.[1]?.toLowerCase(); 33984 let unitToReturn; 33985 if (hasUnits(allowedUnits)) { 33986 const match5 = allowedUnits.find((item2) => item2.value === matchedUnit); 33987 unitToReturn = match5?.value; 33988 } else { 33989 unitToReturn = DEFAULT_UNIT.value; 33990 } 33991 return [quantityToReturn, unitToReturn]; 33992 } 33993 function getValidParsedQuantityAndUnit(rawValue, allowedUnits, fallbackQuantity, fallbackUnit) { 33994 const [parsedQuantity, parsedUnit] = parseQuantityAndUnitFromRawValue(rawValue, allowedUnits); 33995 const quantityToReturn = parsedQuantity !== null && parsedQuantity !== void 0 ? parsedQuantity : fallbackQuantity; 33996 let unitToReturn = parsedUnit || fallbackUnit; 33997 if (!unitToReturn && hasUnits(allowedUnits)) { 33998 unitToReturn = allowedUnits[0].value; 33999 } 34000 return [quantityToReturn, unitToReturn]; 34001 } 34002 function filterUnitsWithSettings(allowedUnitValues = [], availableUnits) { 34003 return Array.isArray(availableUnits) ? availableUnits.filter((unit) => allowedUnitValues.includes(unit.value)) : []; 34004 } 34005 var useCustomUnits = ({ 34006 units = ALL_CSS_UNITS, 34007 availableUnits = [], 34008 defaultValues 34009 }) => { 34010 const customUnitsToReturn = filterUnitsWithSettings(availableUnits, units); 34011 if (!defaultValues) { 34012 return customUnitsToReturn; 34013 } 34014 return customUnitsToReturn.map((unit) => { 34015 const [defaultValue2] = defaultValues[unit.value] ? parseQuantityAndUnitFromRawValue(defaultValues[unit.value]) : []; 34016 return { 34017 ...unit, 34018 default: defaultValue2 34019 }; 34020 }); 34021 }; 34022 function getUnitsWithCurrentUnit(rawValue, legacyUnit, units = ALL_CSS_UNITS) { 34023 const unitsToReturn = Array.isArray(units) ? [...units] : []; 34024 const [, currentUnit] = getParsedQuantityAndUnit(rawValue, legacyUnit, ALL_CSS_UNITS); 34025 if (currentUnit && !unitsToReturn.some((unit) => unit.value === currentUnit)) { 34026 if (allUnits[currentUnit]) { 34027 unitsToReturn.unshift(allUnits[currentUnit]); 34028 } 34029 } 34030 return unitsToReturn; 34031 } 34032 34033 // packages/components/build-module/border-control/border-control-dropdown/hook.js 34034 function useBorderControlDropdown(props) { 34035 const { 34036 border, 34037 className: className2, 34038 colors = [], 34039 enableAlpha = false, 34040 enableStyle = true, 34041 onChange, 34042 previousStyleSelection, 34043 size: size3 = "default", 34044 __experimentalIsRenderedInSidebar = false, 34045 ...otherProps 34046 } = useContextSystem(props, "BorderControlDropdown"); 34047 const [widthValue] = parseQuantityAndUnitFromRawValue(border?.width); 34048 const hasZeroWidth = widthValue === 0; 34049 const onColorChange = (color2) => { 34050 const style2 = border?.style === "none" ? previousStyleSelection : border?.style; 34051 const width = hasZeroWidth && !!color2 ? "1px" : border?.width; 34052 onChange({ 34053 color: color2, 34054 style: style2, 34055 width 34056 }); 34057 }; 34058 const onStyleChange = (style2) => { 34059 const width = hasZeroWidth && !!style2 ? "1px" : border?.width; 34060 onChange({ 34061 ...border, 34062 style: style2, 34063 width 34064 }); 34065 }; 34066 const onReset = () => { 34067 onChange({ 34068 ...border, 34069 color: void 0, 34070 style: void 0 34071 }); 34072 }; 34073 const cx3 = useCx(); 34074 const classes = (0, import_element84.useMemo)(() => { 34075 return cx3(borderControlDropdown, className2); 34076 }, [className2, cx3]); 34077 const indicatorClassName = (0, import_element84.useMemo)(() => { 34078 return cx3(borderColorIndicator); 34079 }, [cx3]); 34080 const indicatorWrapperClassName = (0, import_element84.useMemo)(() => { 34081 return cx3(colorIndicatorWrapper(border, size3)); 34082 }, [border, cx3, size3]); 34083 const popoverControlsClassName = (0, import_element84.useMemo)(() => { 34084 return cx3(borderControlPopoverControls); 34085 }, [cx3]); 34086 const popoverContentClassName = (0, import_element84.useMemo)(() => { 34087 return cx3(borderControlPopoverContent); 34088 }, [cx3]); 34089 const resetButtonWrapperClassName = (0, import_element84.useMemo)(() => { 34090 return cx3(resetButtonWrapper); 34091 }, [cx3]); 34092 return { 34093 ...otherProps, 34094 border, 34095 className: classes, 34096 colors, 34097 enableAlpha, 34098 enableStyle, 34099 indicatorClassName, 34100 indicatorWrapperClassName, 34101 onColorChange, 34102 onStyleChange, 34103 onReset, 34104 popoverContentClassName, 34105 popoverControlsClassName, 34106 resetButtonWrapperClassName, 34107 size: size3, 34108 __experimentalIsRenderedInSidebar 34109 }; 34110 } 34111 34112 // packages/components/build-module/border-control/border-control-dropdown/component.js 34113 var import_jsx_runtime148 = __toESM(require_jsx_runtime()); 34114 var getAriaLabelColorValue = (colorValue) => { 34115 return colorValue.replace(/^var\((.+)\)$/, "$1"); 34116 }; 34117 var getColorObject = (colorValue, colors) => { 34118 if (!colorValue || !colors) { 34119 return; 34120 } 34121 if (isMultiplePaletteArray(colors)) { 34122 let matchedColor; 34123 colors.some((origin) => origin.colors.some((color2) => { 34124 if (color2.color === colorValue) { 34125 matchedColor = color2; 34126 return true; 34127 } 34128 return false; 34129 })); 34130 return matchedColor; 34131 } 34132 return colors.find((color2) => color2.color === colorValue); 34133 }; 34134 var getToggleAriaLabel = (colorValue, colorObject, style2, isStyleEnabled) => { 34135 if (isStyleEnabled) { 34136 if (colorObject) { 34137 const ariaLabelValue = getAriaLabelColorValue(colorObject.color); 34138 return style2 ? (0, import_i18n22.sprintf)( 34139 // translators: 1: The name of the color e.g. "vivid red". 2: The color's hex code e.g.: "#f00:". 3: The current border style selection e.g. "solid". 34140 (0, import_i18n22.__)('Border color and style picker. The currently selected color is called "%1$s" and has a value of "%2$s". The currently selected style is "%3$s".'), 34141 colorObject.name, 34142 ariaLabelValue, 34143 style2 34144 ) : (0, import_i18n22.sprintf)( 34145 // translators: 1: The name of the color e.g. "vivid red". 2: The color's hex code e.g.: "#f00:". 34146 (0, import_i18n22.__)('Border color and style picker. The currently selected color is called "%1$s" and has a value of "%2$s".'), 34147 colorObject.name, 34148 ariaLabelValue 34149 ); 34150 } 34151 if (colorValue) { 34152 const ariaLabelValue = getAriaLabelColorValue(colorValue); 34153 return style2 ? (0, import_i18n22.sprintf)( 34154 // translators: 1: The color's hex code e.g.: "#f00:". 2: The current border style selection e.g. "solid". 34155 (0, import_i18n22.__)('Border color and style picker. The currently selected color has a value of "%1$s". The currently selected style is "%2$s".'), 34156 ariaLabelValue, 34157 style2 34158 ) : (0, import_i18n22.sprintf)( 34159 // translators: %s: The color's hex code e.g: "#f00". 34160 (0, import_i18n22.__)('Border color and style picker. The currently selected color has a value of "%s".'), 34161 ariaLabelValue 34162 ); 34163 } 34164 return (0, import_i18n22.__)("Border color and style picker."); 34165 } 34166 if (colorObject) { 34167 return (0, import_i18n22.sprintf)( 34168 // translators: 1: The name of the color e.g. "vivid red". 2: The color's hex code e.g: "#f00". 34169 (0, import_i18n22.__)('Border color picker. The currently selected color is called "%1$s" and has a value of "%2$s".'), 34170 colorObject.name, 34171 getAriaLabelColorValue(colorObject.color) 34172 ); 34173 } 34174 if (colorValue) { 34175 return (0, import_i18n22.sprintf)( 34176 // translators: %s: The color's hex code e.g: "#f00". 34177 (0, import_i18n22.__)('Border color picker. The currently selected color has a value of "%s".'), 34178 getAriaLabelColorValue(colorValue) 34179 ); 34180 } 34181 return (0, import_i18n22.__)("Border color picker."); 34182 }; 34183 var BorderControlDropdown = (props, forwardedRef) => { 34184 const { 34185 __experimentalIsRenderedInSidebar, 34186 border, 34187 colors, 34188 disableCustomColors, 34189 enableAlpha, 34190 enableStyle, 34191 indicatorClassName, 34192 indicatorWrapperClassName, 34193 isStyleSettable, 34194 onReset, 34195 onColorChange, 34196 onStyleChange, 34197 popoverContentClassName, 34198 popoverControlsClassName, 34199 resetButtonWrapperClassName, 34200 size: size3, 34201 __unstablePopoverProps, 34202 ...otherProps 34203 } = useBorderControlDropdown(props); 34204 const { 34205 color: color2, 34206 style: style2 34207 } = border || {}; 34208 const colorObject = getColorObject(color2, colors); 34209 const toggleAriaLabel = getToggleAriaLabel(color2, colorObject, style2, enableStyle); 34210 const enableResetButton = color2 || style2 && style2 !== "none"; 34211 const dropdownPosition = __experimentalIsRenderedInSidebar ? "bottom left" : void 0; 34212 const renderToggle = ({ 34213 onToggle 34214 }) => /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(button_default, { 34215 onClick: onToggle, 34216 variant: "tertiary", 34217 "aria-label": toggleAriaLabel, 34218 tooltipPosition: dropdownPosition, 34219 label: (0, import_i18n22.__)("Border color and style picker"), 34220 showTooltip: true, 34221 __next40pxDefaultSize: size3 === "__unstable-large", 34222 children: /* @__PURE__ */ (0, import_jsx_runtime148.jsx)("span", { 34223 className: indicatorWrapperClassName, 34224 children: /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(color_indicator_default, { 34225 className: indicatorClassName, 34226 colorValue: color2 34227 }) 34228 }) 34229 }); 34230 const renderContent = () => /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(import_jsx_runtime148.Fragment, { 34231 children: /* @__PURE__ */ (0, import_jsx_runtime148.jsxs)(dropdown_content_wrapper_default, { 34232 paddingSize: "medium", 34233 children: [/* @__PURE__ */ (0, import_jsx_runtime148.jsxs)(component_default18, { 34234 className: popoverControlsClassName, 34235 spacing: 6, 34236 children: [/* @__PURE__ */ (0, import_jsx_runtime148.jsx)(color_palette_default, { 34237 className: popoverContentClassName, 34238 value: color2, 34239 onChange: onColorChange, 34240 colors, 34241 disableCustomColors, 34242 __experimentalIsRenderedInSidebar, 34243 clearable: false, 34244 enableAlpha 34245 }), enableStyle && isStyleSettable && /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(component_default16, { 34246 label: (0, import_i18n22.__)("Style"), 34247 value: style2, 34248 onChange: onStyleChange 34249 })] 34250 }), /* @__PURE__ */ (0, import_jsx_runtime148.jsx)("div", { 34251 className: resetButtonWrapperClassName, 34252 children: /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(button_default, { 34253 variant: "tertiary", 34254 onClick: () => { 34255 onReset(); 34256 }, 34257 disabled: !enableResetButton, 34258 accessibleWhenDisabled: true, 34259 __next40pxDefaultSize: true, 34260 children: (0, import_i18n22.__)("Reset") 34261 }) 34262 })] 34263 }) 34264 }); 34265 return /* @__PURE__ */ (0, import_jsx_runtime148.jsx)(dropdown_default, { 34266 renderToggle, 34267 renderContent, 34268 popoverProps: { 34269 ...__unstablePopoverProps 34270 }, 34271 ...otherProps, 34272 ref: forwardedRef 34273 }); 34274 }; 34275 var ConnectedBorderControlDropdown = contextConnect(BorderControlDropdown, "BorderControlDropdown"); 34276 var component_default20 = ConnectedBorderControlDropdown; 34277 34278 // packages/components/build-module/unit-control/index.js 34279 var import_deprecated8 = __toESM(require_deprecated()); 34280 var import_element86 = __toESM(require_element()); 34281 var import_i18n23 = __toESM(require_i18n()); 34282 34283 // packages/components/build-module/unit-control/unit-select-control.js 34284 var import_element85 = __toESM(require_element()); 34285 var import_jsx_runtime149 = __toESM(require_jsx_runtime()); 34286 function UnitSelectControl({ 34287 className: className2, 34288 isUnitSelectTabbable: isTabbable2 = true, 34289 onChange, 34290 size: size3 = "default", 34291 unit = "px", 34292 units = CSS_UNITS, 34293 ...props 34294 }, ref) { 34295 if (!hasUnits(units) || units?.length === 1) { 34296 return /* @__PURE__ */ (0, import_jsx_runtime149.jsx)(UnitLabel, { 34297 className: "components-unit-control__unit-label", 34298 selectSize: size3, 34299 children: unit 34300 }); 34301 } 34302 const handleOnChange = (event) => { 34303 const { 34304 value: unitValue 34305 } = event.target; 34306 const data = units.find((option) => option.value === unitValue); 34307 onChange?.(unitValue, { 34308 event, 34309 data 34310 }); 34311 }; 34312 const classes = clsx_default("components-unit-control__select", className2); 34313 return /* @__PURE__ */ (0, import_jsx_runtime149.jsx)(UnitSelect, { 34314 ref, 34315 className: classes, 34316 onChange: handleOnChange, 34317 selectSize: size3, 34318 tabIndex: isTabbable2 ? void 0 : -1, 34319 value: unit, 34320 ...props, 34321 children: units.map((option) => /* @__PURE__ */ (0, import_jsx_runtime149.jsx)("option", { 34322 value: option.value, 34323 children: option.label 34324 }, option.value)) 34325 }); 34326 } 34327 var unit_select_control_default = (0, import_element85.forwardRef)(UnitSelectControl); 34328 34329 // packages/components/build-module/unit-control/index.js 34330 var import_jsx_runtime150 = __toESM(require_jsx_runtime()); 34331 function UnforwardedUnitControl(unitControlProps, forwardedRef) { 34332 const { 34333 __unstableStateReducer, 34334 autoComplete = "off", 34335 // @ts-expect-error Ensure that children is omitted from restProps 34336 children, 34337 className: className2, 34338 disabled = false, 34339 disableUnits = false, 34340 isPressEnterToChange = false, 34341 isResetValueOnUnitChange = false, 34342 isUnitSelectTabbable = true, 34343 label, 34344 onChange: onChangeProp, 34345 onUnitChange, 34346 size: size3 = "default", 34347 unit: unitProp, 34348 units: unitsProp = CSS_UNITS, 34349 value: valueProp, 34350 onFocus: onFocusProp, 34351 __shouldNotWarnDeprecated36pxSize, 34352 ...props 34353 } = useDeprecated36pxDefaultSizeProp(unitControlProps); 34354 maybeWarnDeprecated36pxSize({ 34355 componentName: "UnitControl", 34356 __next40pxDefaultSize: props.__next40pxDefaultSize, 34357 size: size3, 34358 __shouldNotWarnDeprecated36pxSize 34359 }); 34360 if ("unit" in unitControlProps) { 34361 (0, import_deprecated8.default)("UnitControl unit prop", { 34362 since: "5.6", 34363 hint: "The unit should be provided within the `value` prop.", 34364 version: "6.2" 34365 }); 34366 } 34367 const nonNullValueProp = valueProp !== null && valueProp !== void 0 ? valueProp : void 0; 34368 const [units, reFirstCharacterOfUnits] = (0, import_element86.useMemo)(() => { 34369 const list = getUnitsWithCurrentUnit(nonNullValueProp, unitProp, unitsProp); 34370 const [{ 34371 value: firstUnitValue = "" 34372 } = {}, ...rest] = list; 34373 const firstCharacters = rest.reduce((carry, { 34374 value 34375 }) => { 34376 const first = escapeRegExp(value?.substring(0, 1) || ""); 34377 return carry.includes(first) ? carry : `$carry}|$first}`; 34378 }, escapeRegExp(firstUnitValue.substring(0, 1))); 34379 return [list, new RegExp(`^(?:$firstCharacters})$`, "i")]; 34380 }, [nonNullValueProp, unitProp, unitsProp]); 34381 const [parsedQuantity, parsedUnit] = getParsedQuantityAndUnit(nonNullValueProp, unitProp, units); 34382 const [unit, setUnit] = use_controlled_state_default(units.length === 1 ? units[0].value : unitProp, { 34383 initial: parsedUnit, 34384 fallback: "" 34385 }); 34386 (0, import_element86.useEffect)(() => { 34387 if (parsedUnit !== void 0) { 34388 setUnit(parsedUnit); 34389 } 34390 }, [parsedUnit, setUnit]); 34391 const classes = clsx_default( 34392 "components-unit-control", 34393 // This class is added for legacy purposes to maintain it on the outer 34394 // wrapper. See: https://github.com/WordPress/gutenberg/pull/45139 34395 "components-unit-control-wrapper", 34396 className2 34397 ); 34398 const handleOnQuantityChange = (nextQuantityValue, changeProps) => { 34399 if (nextQuantityValue === "" || typeof nextQuantityValue === "undefined" || nextQuantityValue === null) { 34400 onChangeProp?.("", changeProps); 34401 return; 34402 } 34403 const onChangeValue = getValidParsedQuantityAndUnit(nextQuantityValue, units, parsedQuantity, unit).join(""); 34404 onChangeProp?.(onChangeValue, changeProps); 34405 }; 34406 const handleOnUnitChange = (nextUnitValue, changeProps) => { 34407 const { 34408 data 34409 } = changeProps; 34410 let nextValue = `$parsedQuantity !== null && parsedQuantity !== void 0 ? parsedQuantity : ""}$nextUnitValue}`; 34411 if (isResetValueOnUnitChange && data?.default !== void 0) { 34412 nextValue = `$data.default}$nextUnitValue}`; 34413 } 34414 onChangeProp?.(nextValue, changeProps); 34415 onUnitChange?.(nextUnitValue, changeProps); 34416 setUnit(nextUnitValue); 34417 }; 34418 let handleOnKeyDown; 34419 if (!disableUnits && isUnitSelectTabbable && units.length) { 34420 handleOnKeyDown = (event) => { 34421 props.onKeyDown?.(event); 34422 if (!event.metaKey && !event.ctrlKey && reFirstCharacterOfUnits.test(event.key)) { 34423 refInputSuffix.current?.focus(); 34424 } 34425 }; 34426 } 34427 const refInputSuffix = (0, import_element86.useRef)(null); 34428 const inputSuffix = !disableUnits ? /* @__PURE__ */ (0, import_jsx_runtime150.jsx)(unit_select_control_default, { 34429 ref: refInputSuffix, 34430 "aria-label": (0, import_i18n23.__)("Select unit"), 34431 disabled, 34432 isUnitSelectTabbable, 34433 onChange: handleOnUnitChange, 34434 size: ["small", "compact"].includes(size3) || size3 === "default" && !props.__next40pxDefaultSize ? "small" : "default", 34435 unit, 34436 units, 34437 onFocus: onFocusProp, 34438 onBlur: unitControlProps.onBlur 34439 }) : null; 34440 let step = props.step; 34441 if (!step && units) { 34442 var _activeUnit$step; 34443 const activeUnit = units.find((option) => option.value === unit); 34444 step = (_activeUnit$step = activeUnit?.step) !== null && _activeUnit$step !== void 0 ? _activeUnit$step : 1; 34445 } 34446 return /* @__PURE__ */ (0, import_jsx_runtime150.jsx)(ValueInput, { 34447 ...props, 34448 __shouldNotWarnDeprecated36pxSize: true, 34449 autoComplete, 34450 className: classes, 34451 disabled, 34452 spinControls: "none", 34453 isPressEnterToChange, 34454 label, 34455 onKeyDown: handleOnKeyDown, 34456 onChange: handleOnQuantityChange, 34457 ref: forwardedRef, 34458 size: size3, 34459 suffix: inputSuffix, 34460 type: isPressEnterToChange ? "text" : "number", 34461 value: parsedQuantity !== null && parsedQuantity !== void 0 ? parsedQuantity : "", 34462 step, 34463 onFocus: onFocusProp, 34464 __unstableStateReducer 34465 }); 34466 } 34467 var UnitControl = (0, import_element86.forwardRef)(UnforwardedUnitControl); 34468 var unit_control_default = UnitControl; 34469 34470 // packages/components/build-module/border-control/border-control/hook.js 34471 var import_element87 = __toESM(require_element()); 34472 var isValidBorder = (border) => { 34473 const hasWidth = border?.width !== void 0 && border.width !== ""; 34474 const hasColor = border?.color !== void 0; 34475 return hasWidth || hasColor; 34476 }; 34477 function useBorderControl(props) { 34478 const { 34479 className: className2, 34480 colors = [], 34481 isCompact, 34482 onChange, 34483 enableAlpha = true, 34484 enableStyle = true, 34485 shouldSanitizeBorder = true, 34486 size: size3 = "default", 34487 value: border, 34488 width, 34489 __experimentalIsRenderedInSidebar = false, 34490 __next40pxDefaultSize, 34491 __shouldNotWarnDeprecated36pxSize, 34492 ...otherProps 34493 } = useContextSystem(props, "BorderControl"); 34494 maybeWarnDeprecated36pxSize({ 34495 componentName: "BorderControl", 34496 __next40pxDefaultSize, 34497 size: size3, 34498 __shouldNotWarnDeprecated36pxSize 34499 }); 34500 const computedSize = size3 === "default" && __next40pxDefaultSize ? "__unstable-large" : size3; 34501 const [widthValue, originalWidthUnit] = parseQuantityAndUnitFromRawValue(border?.width); 34502 const widthUnit = originalWidthUnit || "px"; 34503 const hadPreviousZeroWidth = widthValue === 0; 34504 const [colorSelection, setColorSelection] = (0, import_element87.useState)(); 34505 const [styleSelection, setStyleSelection] = (0, import_element87.useState)(); 34506 const isStyleSettable = shouldSanitizeBorder ? isValidBorder(border) : true; 34507 const onBorderChange = (0, import_element87.useCallback)((newBorder) => { 34508 if (shouldSanitizeBorder && !isValidBorder(newBorder)) { 34509 onChange(void 0); 34510 return; 34511 } 34512 onChange(newBorder); 34513 }, [onChange, shouldSanitizeBorder]); 34514 const onWidthChange = (0, import_element87.useCallback)((newWidth) => { 34515 const newWidthValue = newWidth === "" ? void 0 : newWidth; 34516 const [parsedValue] = parseQuantityAndUnitFromRawValue(newWidth); 34517 const hasZeroWidth = parsedValue === 0; 34518 const updatedBorder = { 34519 ...border, 34520 width: newWidthValue 34521 }; 34522 if (hasZeroWidth && !hadPreviousZeroWidth) { 34523 setColorSelection(border?.color); 34524 setStyleSelection(border?.style); 34525 updatedBorder.color = void 0; 34526 updatedBorder.style = "none"; 34527 } 34528 if (!hasZeroWidth && hadPreviousZeroWidth) { 34529 if (updatedBorder.color === void 0) { 34530 updatedBorder.color = colorSelection; 34531 } 34532 if (updatedBorder.style === "none") { 34533 updatedBorder.style = styleSelection; 34534 } 34535 } 34536 onBorderChange(updatedBorder); 34537 }, [border, hadPreviousZeroWidth, colorSelection, styleSelection, onBorderChange]); 34538 const onSliderChange = (0, import_element87.useCallback)((value) => { 34539 onWidthChange(`$value}$widthUnit}`); 34540 }, [onWidthChange, widthUnit]); 34541 const cx3 = useCx(); 34542 const classes = (0, import_element87.useMemo)(() => { 34543 return cx3(borderControl, className2); 34544 }, [className2, cx3]); 34545 let wrapperWidth2 = width; 34546 if (isCompact) { 34547 wrapperWidth2 = size3 === "__unstable-large" ? "116px" : "90px"; 34548 } 34549 const innerWrapperClassName = (0, import_element87.useMemo)(() => { 34550 const widthStyle = !!wrapperWidth2 && wrapperWidth; 34551 const heightStyle = wrapperHeight(computedSize); 34552 return cx3(innerWrapper(), widthStyle, heightStyle); 34553 }, [wrapperWidth2, cx3, computedSize]); 34554 const sliderClassName = (0, import_element87.useMemo)(() => { 34555 return cx3(borderSlider()); 34556 }, [cx3]); 34557 return { 34558 ...otherProps, 34559 className: classes, 34560 colors, 34561 enableAlpha, 34562 enableStyle, 34563 innerWrapperClassName, 34564 inputWidth: wrapperWidth2, 34565 isStyleSettable, 34566 onBorderChange, 34567 onSliderChange, 34568 onWidthChange, 34569 previousStyleSelection: styleSelection, 34570 sliderClassName, 34571 value: border, 34572 widthUnit, 34573 widthValue, 34574 size: computedSize, 34575 __experimentalIsRenderedInSidebar, 34576 __next40pxDefaultSize 34577 }; 34578 } 34579 34580 // packages/components/build-module/border-control/border-control/component.js 34581 var import_jsx_runtime151 = __toESM(require_jsx_runtime()); 34582 var BorderLabel = (props) => { 34583 const { 34584 label, 34585 hideLabelFromVision 34586 } = props; 34587 if (!label) { 34588 return null; 34589 } 34590 return hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime151.jsx)(component_default2, { 34591 as: "legend", 34592 children: label 34593 }) : /* @__PURE__ */ (0, import_jsx_runtime151.jsx)(StyledLabel, { 34594 as: "legend", 34595 children: label 34596 }); 34597 }; 34598 var UnconnectedBorderControl = (props, forwardedRef) => { 34599 const { 34600 __next40pxDefaultSize = false, 34601 colors, 34602 disableCustomColors, 34603 disableUnits, 34604 enableAlpha, 34605 enableStyle, 34606 hideLabelFromVision, 34607 innerWrapperClassName, 34608 inputWidth, 34609 isStyleSettable, 34610 label, 34611 onBorderChange, 34612 onSliderChange, 34613 onWidthChange, 34614 placeholder, 34615 __unstablePopoverProps, 34616 previousStyleSelection, 34617 showDropdownHeader, 34618 size: size3, 34619 sliderClassName, 34620 value: border, 34621 widthUnit, 34622 widthValue, 34623 withSlider, 34624 __experimentalIsRenderedInSidebar, 34625 ...otherProps 34626 } = useBorderControl(props); 34627 return /* @__PURE__ */ (0, import_jsx_runtime151.jsxs)(component_default, { 34628 as: "fieldset", 34629 ...otherProps, 34630 ref: forwardedRef, 34631 children: [/* @__PURE__ */ (0, import_jsx_runtime151.jsx)(BorderLabel, { 34632 label, 34633 hideLabelFromVision 34634 }), /* @__PURE__ */ (0, import_jsx_runtime151.jsxs)(component_default9, { 34635 spacing: 4, 34636 className: innerWrapperClassName, 34637 children: [/* @__PURE__ */ (0, import_jsx_runtime151.jsx)(unit_control_default, { 34638 __next40pxDefaultSize, 34639 __shouldNotWarnDeprecated36pxSize: true, 34640 prefix: /* @__PURE__ */ (0, import_jsx_runtime151.jsx)(component_default6, { 34641 marginRight: 1, 34642 marginBottom: 0, 34643 children: /* @__PURE__ */ (0, import_jsx_runtime151.jsx)(component_default20, { 34644 border, 34645 colors, 34646 __unstablePopoverProps, 34647 disableCustomColors, 34648 enableAlpha, 34649 enableStyle, 34650 isStyleSettable, 34651 onChange: onBorderChange, 34652 previousStyleSelection, 34653 __experimentalIsRenderedInSidebar, 34654 size: size3 34655 }) 34656 }), 34657 label: (0, import_i18n24.__)("Border width"), 34658 hideLabelFromVision: true, 34659 min: 0, 34660 onChange: onWidthChange, 34661 value: border?.width || "", 34662 placeholder, 34663 disableUnits, 34664 __unstableInputWidth: inputWidth, 34665 size: size3 34666 }), withSlider && /* @__PURE__ */ (0, import_jsx_runtime151.jsx)(range_control_default, { 34667 label: (0, import_i18n24.__)("Border width"), 34668 hideLabelFromVision: true, 34669 className: sliderClassName, 34670 initialPosition: 0, 34671 max: 100, 34672 min: 0, 34673 onChange: onSliderChange, 34674 step: ["px", "%"].includes(widthUnit) ? 1 : 0.1, 34675 value: widthValue || void 0, 34676 withInputField: false, 34677 __next40pxDefaultSize, 34678 __shouldNotWarnDeprecated36pxSize: true 34679 })] 34680 })] 34681 }); 34682 }; 34683 var BorderControl = contextConnect(UnconnectedBorderControl, "BorderControl"); 34684 var component_default21 = BorderControl; 34685 34686 // packages/components/build-module/grid/hook.js 34687 var import_element88 = __toESM(require_element()); 34688 34689 // packages/components/build-module/grid/utils.js 34690 var ALIGNMENTS2 = { 34691 bottom: { 34692 alignItems: "flex-end", 34693 justifyContent: "center" 34694 }, 34695 bottomLeft: { 34696 alignItems: "flex-start", 34697 justifyContent: "flex-end" 34698 }, 34699 bottomRight: { 34700 alignItems: "flex-end", 34701 justifyContent: "flex-end" 34702 }, 34703 center: { 34704 alignItems: "center", 34705 justifyContent: "center" 34706 }, 34707 spaced: { 34708 alignItems: "center", 34709 justifyContent: "space-between" 34710 }, 34711 left: { 34712 alignItems: "center", 34713 justifyContent: "flex-start" 34714 }, 34715 right: { 34716 alignItems: "center", 34717 justifyContent: "flex-end" 34718 }, 34719 stretch: { 34720 alignItems: "stretch" 34721 }, 34722 top: { 34723 alignItems: "flex-start", 34724 justifyContent: "center" 34725 }, 34726 topLeft: { 34727 alignItems: "flex-start", 34728 justifyContent: "flex-start" 34729 }, 34730 topRight: { 34731 alignItems: "flex-start", 34732 justifyContent: "flex-end" 34733 } 34734 }; 34735 function getAlignmentProps2(alignment) { 34736 const alignmentProps = alignment ? ALIGNMENTS2[alignment] : {}; 34737 return alignmentProps; 34738 } 34739 34740 // packages/components/build-module/grid/hook.js 34741 function useGrid(props) { 34742 const { 34743 align, 34744 alignment, 34745 className: className2, 34746 columnGap, 34747 columns = 2, 34748 gap = 3, 34749 isInline = false, 34750 justify, 34751 rowGap, 34752 rows, 34753 templateColumns, 34754 templateRows, 34755 ...otherProps 34756 } = useContextSystem(props, "Grid"); 34757 const columnsAsArray = Array.isArray(columns) ? columns : [columns]; 34758 const column2 = useResponsiveValue(columnsAsArray); 34759 const rowsAsArray = Array.isArray(rows) ? rows : [rows]; 34760 const row = useResponsiveValue(rowsAsArray); 34761 const gridTemplateColumns = templateColumns || !!columns && `repeat( $column2}, 1fr )`; 34762 const gridTemplateRows = templateRows || !!rows && `repeat( $row}, 1fr )`; 34763 const cx3 = useCx(); 34764 const classes = (0, import_element88.useMemo)(() => { 34765 const alignmentProps = getAlignmentProps2(alignment); 34766 const gridClasses = /* @__PURE__ */ css({ 34767 alignItems: align, 34768 display: isInline ? "inline-grid" : "grid", 34769 gap: `calc( $config_values_default.gridBase} * $gap} )`, 34770 gridTemplateColumns: gridTemplateColumns || void 0, 34771 gridTemplateRows: gridTemplateRows || void 0, 34772 gridRowGap: rowGap, 34773 gridColumnGap: columnGap, 34774 justifyContent: justify, 34775 verticalAlign: isInline ? "middle" : void 0, 34776 ...alignmentProps 34777 }, false ? "" : ";label:gridClasses;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURzQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IGdldEFsaWdubWVudFByb3BzIH0gZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgeyB1c2VSZXNwb25zaXZlVmFsdWUgfSBmcm9tICcuLi91dGlscy91c2UtcmVzcG9uc2l2ZS12YWx1ZSc7XG5pbXBvcnQgQ09ORklHIGZyb20gJy4uL3V0aWxzL2NvbmZpZy12YWx1ZXMnO1xuaW1wb3J0IHsgdXNlQ3ggfSBmcm9tICcuLi91dGlscy9ob29rcy91c2UtY3gnO1xuaW1wb3J0IHR5cGUgeyBHcmlkUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gdXNlR3JpZChcblx0cHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBHcmlkUHJvcHMsICdkaXYnID5cbikge1xuXHRjb25zdCB7XG5cdFx0YWxpZ24sXG5cdFx0YWxpZ25tZW50LFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjb2x1bW5HYXAsXG5cdFx0Y29sdW1ucyA9IDIsXG5cdFx0Z2FwID0gMyxcblx0XHRpc0lubGluZSA9IGZhbHNlLFxuXHRcdGp1c3RpZnksXG5cdFx0cm93R2FwLFxuXHRcdHJvd3MsXG5cdFx0dGVtcGxhdGVDb2x1bW5zLFxuXHRcdHRlbXBsYXRlUm93cyxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ0dyaWQnICk7XG5cblx0Y29uc3QgY29sdW1uc0FzQXJyYXkgPSBBcnJheS5pc0FycmF5KCBjb2x1bW5zICkgPyBjb2x1bW5zIDogWyBjb2x1bW5zIF07XG5cdGNvbnN0IGNvbHVtbiA9IHVzZVJlc3BvbnNpdmVWYWx1ZSggY29sdW1uc0FzQXJyYXkgKTtcblx0Y29uc3Qgcm93c0FzQXJyYXkgPSBBcnJheS5pc0FycmF5KCByb3dzICkgPyByb3dzIDogWyByb3dzIF07XG5cdGNvbnN0IHJvdyA9IHVzZVJlc3BvbnNpdmVWYWx1ZSggcm93c0FzQXJyYXkgKTtcblxuXHRjb25zdCBncmlkVGVtcGxhdGVDb2x1bW5zID1cblx0XHR0ZW1wbGF0ZUNvbHVtbnMgfHwgKCAhISBjb2x1bW5zICYmIGByZXBlYXQoICR7IGNvbHVtbiB9LCAxZnIgKWAgKTtcblx0Y29uc3QgZ3JpZFRlbXBsYXRlUm93cyA9XG5cdFx0dGVtcGxhdGVSb3dzIHx8ICggISEgcm93cyAmJiBgcmVwZWF0KCAkeyByb3cgfSwgMWZyIClgICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0Y29uc3QgYWxpZ25tZW50UHJvcHMgPSBnZXRBbGlnbm1lbnRQcm9wcyggYWxpZ25tZW50ICk7XG5cblx0XHRjb25zdCBncmlkQ2xhc3NlcyA9IGNzcygge1xuXHRcdFx0YWxpZ25JdGVtczogYWxpZ24sXG5cdFx0XHRkaXNwbGF5OiBpc0lubGluZSA/ICdpbmxpbmUtZ3JpZCcgOiAnZ3JpZCcsXG5cdFx0XHRnYXA6IGBjYWxjKCAkeyBDT05GSUcuZ3JpZEJhc2UgfSAqICR7IGdhcCB9IClgLFxuXHRcdFx0Z3JpZFRlbXBsYXRlQ29sdW1uczogZ3JpZFRlbXBsYXRlQ29sdW1ucyB8fCB1bmRlZmluZWQsXG5cdFx0XHRncmlkVGVtcGxhdGVSb3dzOiBncmlkVGVtcGxhdGVSb3dzIHx8IHVuZGVmaW5lZCxcblx0XHRcdGdyaWRSb3dHYXA6IHJvd0dhcCxcblx0XHRcdGdyaWRDb2x1bW5HYXA6IGNvbHVtbkdhcCxcblx0XHRcdGp1c3RpZnlDb250ZW50OiBqdXN0aWZ5LFxuXHRcdFx0dmVydGljYWxBbGlnbjogaXNJbmxpbmUgPyAnbWlkZGxlJyA6IHVuZGVmaW5lZCxcblx0XHRcdC4uLmFsaWdubWVudFByb3BzLFxuXHRcdH0gKTtcblxuXHRcdHJldHVybiBjeCggZ3JpZENsYXNzZXMsIGNsYXNzTmFtZSApO1xuXHR9LCBbXG5cdFx0YWxpZ24sXG5cdFx0YWxpZ25tZW50LFxuXHRcdGNsYXNzTmFtZSxcblx0XHRjb2x1bW5HYXAsXG5cdFx0Y3gsXG5cdFx0Z2FwLFxuXHRcdGdyaWRUZW1wbGF0ZUNvbHVtbnMsXG5cdFx0Z3JpZFRlbXBsYXRlUm93cyxcblx0XHRpc0lubGluZSxcblx0XHRqdXN0aWZ5LFxuXHRcdHJvd0dhcCxcblx0XSApO1xuXG5cdHJldHVybiB7IC4uLm90aGVyUHJvcHMsIGNsYXNzTmFtZTogY2xhc3NlcyB9O1xufVxuIl19 */"); 34778 return cx3(gridClasses, className2); 34779 }, [align, alignment, className2, columnGap, cx3, gap, gridTemplateColumns, gridTemplateRows, isInline, justify, rowGap]); 34780 return { 34781 ...otherProps, 34782 className: classes 34783 }; 34784 } 34785 34786 // packages/components/build-module/grid/component.js 34787 var import_jsx_runtime152 = __toESM(require_jsx_runtime()); 34788 function UnconnectedGrid(props, forwardedRef) { 34789 const gridProps = useGrid(props); 34790 return /* @__PURE__ */ (0, import_jsx_runtime152.jsx)(component_default, { 34791 ...gridProps, 34792 ref: forwardedRef 34793 }); 34794 } 34795 var Grid = contextConnect(UnconnectedGrid, "Grid"); 34796 var component_default22 = Grid; 34797 34798 // packages/components/build-module/border-box-control/border-box-control-split-controls/hook.js 34799 var import_element89 = __toESM(require_element()); 34800 function useBorderBoxControlSplitControls(props) { 34801 const { 34802 className: className2, 34803 colors = [], 34804 enableAlpha = false, 34805 enableStyle = true, 34806 size: size3 = "default", 34807 __experimentalIsRenderedInSidebar = false, 34808 ...otherProps 34809 } = useContextSystem(props, "BorderBoxControlSplitControls"); 34810 const cx3 = useCx(); 34811 const classes = (0, import_element89.useMemo)(() => { 34812 return cx3(borderBoxControlSplitControls(size3), className2); 34813 }, [cx3, className2, size3]); 34814 const centeredClassName = (0, import_element89.useMemo)(() => { 34815 return cx3(centeredBorderControl, className2); 34816 }, [cx3, className2]); 34817 const rightAlignedClassName = (0, import_element89.useMemo)(() => { 34818 return cx3(rightBorderControl(), className2); 34819 }, [cx3, className2]); 34820 return { 34821 ...otherProps, 34822 centeredClassName, 34823 className: classes, 34824 colors, 34825 enableAlpha, 34826 enableStyle, 34827 rightAlignedClassName, 34828 size: size3, 34829 __experimentalIsRenderedInSidebar 34830 }; 34831 } 34832 34833 // packages/components/build-module/border-box-control/border-box-control-split-controls/component.js 34834 var import_jsx_runtime153 = __toESM(require_jsx_runtime()); 34835 var BorderBoxControlSplitControls = (props, forwardedRef) => { 34836 const { 34837 centeredClassName, 34838 colors, 34839 disableCustomColors, 34840 enableAlpha, 34841 enableStyle, 34842 onChange, 34843 popoverPlacement, 34844 popoverOffset, 34845 rightAlignedClassName, 34846 size: size3 = "default", 34847 value, 34848 __experimentalIsRenderedInSidebar, 34849 ...otherProps 34850 } = useBorderBoxControlSplitControls(props); 34851 const [popoverAnchor, setPopoverAnchor] = (0, import_element90.useState)(null); 34852 const popoverProps = (0, import_element90.useMemo)(() => popoverPlacement ? { 34853 placement: popoverPlacement, 34854 offset: popoverOffset, 34855 anchor: popoverAnchor, 34856 shift: true 34857 } : void 0, [popoverPlacement, popoverOffset, popoverAnchor]); 34858 const sharedBorderControlProps = { 34859 colors, 34860 disableCustomColors, 34861 enableAlpha, 34862 enableStyle, 34863 isCompact: true, 34864 __experimentalIsRenderedInSidebar, 34865 size: size3, 34866 __shouldNotWarnDeprecated36pxSize: true 34867 }; 34868 const mergedRef = (0, import_compose38.useMergeRefs)([setPopoverAnchor, forwardedRef]); 34869 return /* @__PURE__ */ (0, import_jsx_runtime153.jsxs)(component_default22, { 34870 ...otherProps, 34871 ref: mergedRef, 34872 gap: 3, 34873 children: [/* @__PURE__ */ (0, import_jsx_runtime153.jsx)(component_default11, { 34874 value, 34875 size: size3 34876 }), /* @__PURE__ */ (0, import_jsx_runtime153.jsx)(component_default21, { 34877 className: centeredClassName, 34878 hideLabelFromVision: true, 34879 label: (0, import_i18n25.__)("Top border"), 34880 onChange: (newBorder) => onChange(newBorder, "top"), 34881 __unstablePopoverProps: popoverProps, 34882 value: value?.top, 34883 ...sharedBorderControlProps 34884 }), /* @__PURE__ */ (0, import_jsx_runtime153.jsx)(component_default21, { 34885 hideLabelFromVision: true, 34886 label: (0, import_i18n25.__)("Left border"), 34887 onChange: (newBorder) => onChange(newBorder, "left"), 34888 __unstablePopoverProps: popoverProps, 34889 value: value?.left, 34890 ...sharedBorderControlProps 34891 }), /* @__PURE__ */ (0, import_jsx_runtime153.jsx)(component_default21, { 34892 className: rightAlignedClassName, 34893 hideLabelFromVision: true, 34894 label: (0, import_i18n25.__)("Right border"), 34895 onChange: (newBorder) => onChange(newBorder, "right"), 34896 __unstablePopoverProps: popoverProps, 34897 value: value?.right, 34898 ...sharedBorderControlProps 34899 }), /* @__PURE__ */ (0, import_jsx_runtime153.jsx)(component_default21, { 34900 className: centeredClassName, 34901 hideLabelFromVision: true, 34902 label: (0, import_i18n25.__)("Bottom border"), 34903 onChange: (newBorder) => onChange(newBorder, "bottom"), 34904 __unstablePopoverProps: popoverProps, 34905 value: value?.bottom, 34906 ...sharedBorderControlProps 34907 })] 34908 }); 34909 }; 34910 var ConnectedBorderBoxControlSplitControls = contextConnect(BorderBoxControlSplitControls, "BorderBoxControlSplitControls"); 34911 var component_default23 = ConnectedBorderBoxControlSplitControls; 34912 34913 // packages/components/build-module/border-box-control/border-box-control/hook.js 34914 var import_element91 = __toESM(require_element()); 34915 34916 // packages/components/build-module/utils/unit-values.js 34917 var UNITED_VALUE_REGEX = /^([\d.\-+]*)\s*(fr|cm|mm|Q|in|pc|pt|px|em|ex|ch|rem|lh|vw|vh|vmin|vmax|%|cap|ic|rlh|vi|vb|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx|svw|lvw|dvw|svh|lvh|dvh|svi|lvi|dvi|svb|lvb|dvb|svmin|lvmin|dvmin|svmax|lvmax|dvmax)?$/; 34918 function parseCSSUnitValue(toParse) { 34919 const value = toParse.trim(); 34920 const matched = value.match(UNITED_VALUE_REGEX); 34921 if (!matched) { 34922 return [void 0, void 0]; 34923 } 34924 const [, num, unit] = matched; 34925 let numParsed = parseFloat(num); 34926 numParsed = Number.isNaN(numParsed) ? void 0 : numParsed; 34927 return [numParsed, unit]; 34928 } 34929 34930 // packages/components/build-module/border-box-control/utils.js 34931 var sides2 = ["top", "right", "bottom", "left"]; 34932 var borderProps = ["color", "style", "width"]; 34933 var isEmptyBorder = (border) => { 34934 if (!border) { 34935 return true; 34936 } 34937 return !borderProps.some((prop) => border[prop] !== void 0); 34938 }; 34939 var isDefinedBorder = (border) => { 34940 if (!border) { 34941 return false; 34942 } 34943 if (hasSplitBorders(border)) { 34944 const allSidesEmpty = sides2.every((side) => isEmptyBorder(border[side])); 34945 return !allSidesEmpty; 34946 } 34947 return !isEmptyBorder(border); 34948 }; 34949 var isCompleteBorder = (border) => { 34950 if (!border) { 34951 return false; 34952 } 34953 return borderProps.every((prop) => border[prop] !== void 0); 34954 }; 34955 var hasSplitBorders = (border = {}) => { 34956 return Object.keys(border).some((side) => sides2.indexOf(side) !== -1); 34957 }; 34958 var hasMixedBorders = (borders2) => { 34959 if (!hasSplitBorders(borders2)) { 34960 return false; 34961 } 34962 const shorthandBorders = sides2.map((side) => getShorthandBorderStyle(borders2?.[side])); 34963 return !shorthandBorders.every((border) => border === shorthandBorders[0]); 34964 }; 34965 var getSplitBorders = (border) => { 34966 if (!border || isEmptyBorder(border)) { 34967 return void 0; 34968 } 34969 return { 34970 top: border, 34971 right: border, 34972 bottom: border, 34973 left: border 34974 }; 34975 }; 34976 var getBorderDiff = (original, updated) => { 34977 const diff = {}; 34978 if (original.color !== updated.color) { 34979 diff.color = updated.color; 34980 } 34981 if (original.style !== updated.style) { 34982 diff.style = updated.style; 34983 } 34984 if (original.width !== updated.width) { 34985 diff.width = updated.width; 34986 } 34987 return diff; 34988 }; 34989 var getCommonBorder = (borders2) => { 34990 if (!borders2) { 34991 return void 0; 34992 } 34993 const colors = []; 34994 const styles3 = []; 34995 const widths = []; 34996 sides2.forEach((side) => { 34997 colors.push(borders2[side]?.color); 34998 styles3.push(borders2[side]?.style); 34999 widths.push(borders2[side]?.width); 35000 }); 35001 const allColorsMatch = colors.every((value) => value === colors[0]); 35002 const allStylesMatch = styles3.every((value) => value === styles3[0]); 35003 const allWidthsMatch = widths.every((value) => value === widths[0]); 35004 return { 35005 color: allColorsMatch ? colors[0] : void 0, 35006 style: allStylesMatch ? styles3[0] : void 0, 35007 width: allWidthsMatch ? widths[0] : getMostCommonUnit(widths) 35008 }; 35009 }; 35010 var getShorthandBorderStyle = (border, fallbackBorder) => { 35011 if (isEmptyBorder(border)) { 35012 return fallbackBorder; 35013 } 35014 const { 35015 color: fallbackColor, 35016 style: fallbackStyle, 35017 width: fallbackWidth 35018 } = fallbackBorder || {}; 35019 const { 35020 color: color2 = fallbackColor, 35021 style: style2 = fallbackStyle, 35022 width = fallbackWidth 35023 } = border; 35024 const hasVisibleBorder = !!width && width !== "0" || !!color2; 35025 const borderStyle = hasVisibleBorder ? style2 || "solid" : style2; 35026 return [width, borderStyle, color2].filter(Boolean).join(" "); 35027 }; 35028 var getMostCommonUnit = (values) => { 35029 const units = values.map((value) => value === void 0 ? void 0 : parseCSSUnitValue(`$value}`)[1]); 35030 const filteredUnits = units.filter((value) => value !== void 0); 35031 return mode(filteredUnits); 35032 }; 35033 function mode(values) { 35034 if (values.length === 0) { 35035 return void 0; 35036 } 35037 const map = {}; 35038 let maxCount = 0; 35039 let currentMode; 35040 values.forEach((value) => { 35041 map[value] = map[value] === void 0 ? 1 : map[value] + 1; 35042 if (map[value] > maxCount) { 35043 currentMode = value; 35044 maxCount = map[value]; 35045 } 35046 }); 35047 return currentMode; 35048 } 35049 35050 // packages/components/build-module/border-box-control/border-box-control/hook.js 35051 function useBorderBoxControl(props) { 35052 const { 35053 className: className2, 35054 colors = [], 35055 onChange, 35056 enableAlpha = false, 35057 enableStyle = true, 35058 size: size3 = "default", 35059 value, 35060 __experimentalIsRenderedInSidebar = false, 35061 __next40pxDefaultSize, 35062 ...otherProps 35063 } = useContextSystem(props, "BorderBoxControl"); 35064 maybeWarnDeprecated36pxSize({ 35065 componentName: "BorderBoxControl", 35066 __next40pxDefaultSize, 35067 size: size3 35068 }); 35069 const computedSize = size3 === "default" && __next40pxDefaultSize ? "__unstable-large" : size3; 35070 const mixedBorders = hasMixedBorders(value); 35071 const splitBorders = hasSplitBorders(value); 35072 const linkedValue = splitBorders ? getCommonBorder(value) : value; 35073 const splitValue = splitBorders ? value : getSplitBorders(value); 35074 const hasWidthValue = !isNaN(parseFloat(`$linkedValue?.width}`)); 35075 const [isLinked, setIsLinked] = (0, import_element91.useState)(!mixedBorders); 35076 const toggleLinked = () => setIsLinked(!isLinked); 35077 const onLinkedChange = (newBorder) => { 35078 if (!newBorder) { 35079 return onChange(void 0); 35080 } 35081 if (!mixedBorders || isCompleteBorder(newBorder)) { 35082 return onChange(isEmptyBorder(newBorder) ? void 0 : newBorder); 35083 } 35084 const changes = getBorderDiff(linkedValue, newBorder); 35085 const updatedBorders = { 35086 top: { 35087 ...value?.top, 35088 ...changes 35089 }, 35090 right: { 35091 ...value?.right, 35092 ...changes 35093 }, 35094 bottom: { 35095 ...value?.bottom, 35096 ...changes 35097 }, 35098 left: { 35099 ...value?.left, 35100 ...changes 35101 } 35102 }; 35103 if (hasMixedBorders(updatedBorders)) { 35104 return onChange(updatedBorders); 35105 } 35106 const filteredResult = isEmptyBorder(updatedBorders.top) ? void 0 : updatedBorders.top; 35107 onChange(filteredResult); 35108 }; 35109 const onSplitChange = (newBorder, side) => { 35110 const updatedBorders = { 35111 ...splitValue, 35112 [side]: newBorder 35113 }; 35114 if (hasMixedBorders(updatedBorders)) { 35115 onChange(updatedBorders); 35116 } else { 35117 onChange(newBorder); 35118 } 35119 }; 35120 const cx3 = useCx(); 35121 const classes = (0, import_element91.useMemo)(() => { 35122 return cx3(borderBoxControl, className2); 35123 }, [cx3, className2]); 35124 const linkedControlClassName = (0, import_element91.useMemo)(() => { 35125 return cx3(linkedBorderControl()); 35126 }, [cx3]); 35127 const wrapperClassName = (0, import_element91.useMemo)(() => { 35128 return cx3(wrapper); 35129 }, [cx3]); 35130 return { 35131 ...otherProps, 35132 className: classes, 35133 colors, 35134 disableUnits: mixedBorders && !hasWidthValue, 35135 enableAlpha, 35136 enableStyle, 35137 hasMixedBorders: mixedBorders, 35138 isLinked, 35139 linkedControlClassName, 35140 onLinkedChange, 35141 onSplitChange, 35142 toggleLinked, 35143 linkedValue, 35144 size: computedSize, 35145 splitValue, 35146 wrapperClassName, 35147 __experimentalIsRenderedInSidebar 35148 }; 35149 } 35150 35151 // packages/components/build-module/border-box-control/border-box-control/component.js 35152 var import_jsx_runtime154 = __toESM(require_jsx_runtime()); 35153 var BorderLabel2 = (props) => { 35154 const { 35155 label, 35156 hideLabelFromVision 35157 } = props; 35158 if (!label) { 35159 return null; 35160 } 35161 return hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime154.jsx)(component_default2, { 35162 as: "label", 35163 children: label 35164 }) : /* @__PURE__ */ (0, import_jsx_runtime154.jsx)(StyledLabel, { 35165 children: label 35166 }); 35167 }; 35168 var UnconnectedBorderBoxControl = (props, forwardedRef) => { 35169 const { 35170 className: className2, 35171 colors, 35172 disableCustomColors, 35173 disableUnits, 35174 enableAlpha, 35175 enableStyle, 35176 hasMixedBorders: hasMixedBorders2, 35177 hideLabelFromVision, 35178 isLinked, 35179 label, 35180 linkedControlClassName, 35181 linkedValue, 35182 onLinkedChange, 35183 onSplitChange, 35184 popoverPlacement, 35185 popoverOffset, 35186 size: size3, 35187 splitValue, 35188 toggleLinked, 35189 wrapperClassName, 35190 __experimentalIsRenderedInSidebar, 35191 ...otherProps 35192 } = useBorderBoxControl(props); 35193 const [popoverAnchor, setPopoverAnchor] = (0, import_element92.useState)(null); 35194 const popoverProps = (0, import_element92.useMemo)(() => popoverPlacement ? { 35195 placement: popoverPlacement, 35196 offset: popoverOffset, 35197 anchor: popoverAnchor, 35198 shift: true 35199 } : void 0, [popoverPlacement, popoverOffset, popoverAnchor]); 35200 const mergedRef = (0, import_compose39.useMergeRefs)([setPopoverAnchor, forwardedRef]); 35201 return /* @__PURE__ */ (0, import_jsx_runtime154.jsxs)(component_default, { 35202 className: className2, 35203 ...otherProps, 35204 ref: mergedRef, 35205 children: [/* @__PURE__ */ (0, import_jsx_runtime154.jsx)(BorderLabel2, { 35206 label, 35207 hideLabelFromVision 35208 }), /* @__PURE__ */ (0, import_jsx_runtime154.jsxs)(component_default, { 35209 className: wrapperClassName, 35210 children: [isLinked ? /* @__PURE__ */ (0, import_jsx_runtime154.jsx)(component_default21, { 35211 className: linkedControlClassName, 35212 colors, 35213 disableUnits, 35214 disableCustomColors, 35215 enableAlpha, 35216 enableStyle, 35217 onChange: onLinkedChange, 35218 placeholder: hasMixedBorders2 ? (0, import_i18n26.__)("Mixed") : void 0, 35219 __unstablePopoverProps: popoverProps, 35220 shouldSanitizeBorder: false, 35221 value: linkedValue, 35222 withSlider: true, 35223 width: size3 === "__unstable-large" ? "116px" : "110px", 35224 __experimentalIsRenderedInSidebar, 35225 __shouldNotWarnDeprecated36pxSize: true, 35226 size: size3 35227 }) : /* @__PURE__ */ (0, import_jsx_runtime154.jsx)(component_default23, { 35228 colors, 35229 disableCustomColors, 35230 enableAlpha, 35231 enableStyle, 35232 onChange: onSplitChange, 35233 popoverPlacement, 35234 popoverOffset, 35235 value: splitValue, 35236 __experimentalIsRenderedInSidebar, 35237 size: size3 35238 }), /* @__PURE__ */ (0, import_jsx_runtime154.jsx)(component_default10, { 35239 onClick: toggleLinked, 35240 isLinked, 35241 size: size3 35242 })] 35243 })] 35244 }); 35245 }; 35246 var BorderBoxControl = contextConnect(UnconnectedBorderBoxControl, "BorderBoxControl"); 35247 var component_default24 = BorderBoxControl; 35248 35249 // packages/components/build-module/box-control/index.js 35250 var import_compose41 = __toESM(require_compose()); 35251 var import_element94 = __toESM(require_element()); 35252 var import_i18n30 = __toESM(require_i18n()); 35253 var import_warning5 = __toESM(require_warning()); 35254 35255 // packages/components/build-module/box-control/input-control.js 35256 var import_compose40 = __toESM(require_compose()); 35257 var import_i18n28 = __toESM(require_i18n()); 35258 var import_element93 = __toESM(require_element()); 35259 35260 // packages/components/build-module/box-control/utils.js 35261 var import_i18n27 = __toESM(require_i18n()); 35262 var import_deprecated9 = __toESM(require_deprecated()); 35263 var CUSTOM_VALUE_SETTINGS = { 35264 px: { 35265 max: 300, 35266 step: 1 35267 }, 35268 "%": { 35269 max: 100, 35270 step: 1 35271 }, 35272 vw: { 35273 max: 100, 35274 step: 1 35275 }, 35276 vh: { 35277 max: 100, 35278 step: 1 35279 }, 35280 em: { 35281 max: 10, 35282 step: 0.1 35283 }, 35284 rm: { 35285 max: 10, 35286 step: 0.1 35287 }, 35288 svw: { 35289 max: 100, 35290 step: 1 35291 }, 35292 lvw: { 35293 max: 100, 35294 step: 1 35295 }, 35296 dvw: { 35297 max: 100, 35298 step: 1 35299 }, 35300 svh: { 35301 max: 100, 35302 step: 1 35303 }, 35304 lvh: { 35305 max: 100, 35306 step: 1 35307 }, 35308 dvh: { 35309 max: 100, 35310 step: 1 35311 }, 35312 vi: { 35313 max: 100, 35314 step: 1 35315 }, 35316 svi: { 35317 max: 100, 35318 step: 1 35319 }, 35320 lvi: { 35321 max: 100, 35322 step: 1 35323 }, 35324 dvi: { 35325 max: 100, 35326 step: 1 35327 }, 35328 vb: { 35329 max: 100, 35330 step: 1 35331 }, 35332 svb: { 35333 max: 100, 35334 step: 1 35335 }, 35336 lvb: { 35337 max: 100, 35338 step: 1 35339 }, 35340 dvb: { 35341 max: 100, 35342 step: 1 35343 }, 35344 vmin: { 35345 max: 100, 35346 step: 1 35347 }, 35348 svmin: { 35349 max: 100, 35350 step: 1 35351 }, 35352 lvmin: { 35353 max: 100, 35354 step: 1 35355 }, 35356 dvmin: { 35357 max: 100, 35358 step: 1 35359 }, 35360 vmax: { 35361 max: 100, 35362 step: 1 35363 }, 35364 svmax: { 35365 max: 100, 35366 step: 1 35367 }, 35368 lvmax: { 35369 max: 100, 35370 step: 1 35371 }, 35372 dvmax: { 35373 max: 100, 35374 step: 1 35375 } 35376 }; 35377 var LABELS = { 35378 all: (0, import_i18n27.__)("All sides"), 35379 top: (0, import_i18n27.__)("Top side"), 35380 bottom: (0, import_i18n27.__)("Bottom side"), 35381 left: (0, import_i18n27.__)("Left side"), 35382 right: (0, import_i18n27.__)("Right side"), 35383 vertical: (0, import_i18n27.__)("Top and bottom sides"), 35384 horizontal: (0, import_i18n27.__)("Left and right sides") 35385 }; 35386 var DEFAULT_VALUES = { 35387 top: void 0, 35388 right: void 0, 35389 bottom: void 0, 35390 left: void 0 35391 }; 35392 var ALL_SIDES = ["top", "right", "bottom", "left"]; 35393 function getMergedValue(values = {}, availableSides = ALL_SIDES) { 35394 const sides3 = normalizeSides(availableSides); 35395 if (sides3.every((side) => values[side] === values[sides3[0]])) { 35396 return values[sides3[0]]; 35397 } 35398 return void 0; 35399 } 35400 function isValueMixed(values = {}, availableSides = ALL_SIDES) { 35401 const sides3 = normalizeSides(availableSides); 35402 return sides3.some((side) => values[side] !== values[sides3[0]]); 35403 } 35404 function isValuesDefined(values) { 35405 return values && Object.values(values).filter( 35406 // Switching units when input is empty causes values only 35407 // containing units. This gives false positive on mixed values 35408 // unless filtered. 35409 (value) => !!value && /\d/.test(value) 35410 ).length > 0; 35411 } 35412 function getInitialSide(isLinked, splitOnAxis) { 35413 let initialSide = "all"; 35414 if (!isLinked) { 35415 initialSide = splitOnAxis ? "vertical" : "top"; 35416 } 35417 return initialSide; 35418 } 35419 function normalizeSides(sides3) { 35420 const filteredSides = []; 35421 if (!sides3?.length) { 35422 return ALL_SIDES; 35423 } 35424 if (sides3.includes("vertical")) { 35425 filteredSides.push(...["top", "bottom"]); 35426 } else if (sides3.includes("horizontal")) { 35427 filteredSides.push(...["left", "right"]); 35428 } else { 35429 const newSides = ALL_SIDES.filter((side) => sides3.includes(side)); 35430 filteredSides.push(...newSides); 35431 } 35432 return filteredSides; 35433 } 35434 function applyValueToSides(currentValues, newValue, sides3) { 35435 (0, import_deprecated9.default)("applyValueToSides", { 35436 since: "6.8", 35437 version: "7.0" 35438 }); 35439 const newValues = { 35440 ...currentValues 35441 }; 35442 if (sides3?.length) { 35443 sides3.forEach((side) => { 35444 if (side === "vertical") { 35445 newValues.top = newValue; 35446 newValues.bottom = newValue; 35447 } else if (side === "horizontal") { 35448 newValues.left = newValue; 35449 newValues.right = newValue; 35450 } else { 35451 newValues[side] = newValue; 35452 } 35453 }); 35454 } else { 35455 ALL_SIDES.forEach((side) => newValues[side] = newValue); 35456 } 35457 return newValues; 35458 } 35459 function getAllowedSides(sides3) { 35460 const allowedSides = new Set(!sides3 ? ALL_SIDES : []); 35461 sides3?.forEach((allowedSide) => { 35462 if (allowedSide === "vertical") { 35463 allowedSides.add("top"); 35464 allowedSides.add("bottom"); 35465 } else if (allowedSide === "horizontal") { 35466 allowedSides.add("right"); 35467 allowedSides.add("left"); 35468 } else { 35469 allowedSides.add(allowedSide); 35470 } 35471 }); 35472 return allowedSides; 35473 } 35474 function isValuePreset(value, presetKey) { 35475 return value.startsWith(`var:preset|$presetKey}|`); 35476 } 35477 function getPresetIndexFromValue(value, presetKey, presets) { 35478 if (!isValuePreset(value, presetKey)) { 35479 return void 0; 35480 } 35481 const match5 = value.match(new RegExp(`^var:preset\\|$presetKey}\\|(.+)$`)); 35482 if (!match5) { 35483 return void 0; 35484 } 35485 const slug = match5[1]; 35486 const index2 = presets.findIndex((preset) => { 35487 return preset.slug === slug; 35488 }); 35489 return index2 !== -1 ? index2 : void 0; 35490 } 35491 function getPresetValueFromIndex(index2, presetKey, presets) { 35492 const preset = presets[index2]; 35493 return `var:preset|$presetKey}|$preset.slug}`; 35494 } 35495 35496 // packages/components/build-module/box-control/styles/box-control-icon-styles.js 35497 function _EMOTION_STRINGIFIED_CSS_ERROR__15() { 35498 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 35499 } 35500 var Root3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 35501 target: "e1j5nr4z8" 35502 } : { 35503 target: "e1j5nr4z8", 35504 label: "Root" 35505 })(false ? { 35506 name: "1w884gc", 35507 styles: "box-sizing:border-box;display:block;width:24px;height:24px;position:relative;padding:4px" 35508 } : { 35509 name: "1w884gc", 35510 styles: "box-sizing:border-box;display:block;width:24px;height:24px;position:relative;padding:4px", 35511 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU0rQiIsImZpbGUiOiJib3gtY29udHJvbC1pY29uLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFJvb3QgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHdpZHRoOiAyNHB4O1xuXHRoZWlnaHQ6IDI0cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0cGFkZGluZzogNHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdib3ggPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0d2lkdGg6IDEwMCU7XG5cdGhlaWdodDogMTAwJTtcbmA7XG5cbmNvbnN0IHN0cm9rZUZvY3VzID0gKCB7IGlzRm9jdXNlZCB9OiB7IGlzRm9jdXNlZDogYm9vbGVhbiB9ICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0YmFja2dyb3VuZENvbG9yOiAnY3VycmVudENvbG9yJyxcblx0XHRvcGFjaXR5OiBpc0ZvY3VzZWQgPyAxIDogMC4zLFxuXHR9ICk7XG59O1xuXG5jb25zdCBTdHJva2UgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdCR7IHN0cm9rZUZvY3VzIH07XG5gO1xuXG5jb25zdCBWZXJ0aWNhbFN0cm9rZSA9IHN0eWxlZCggU3Ryb2tlIClgXG5cdGJvdHRvbTogM3B4O1xuXHR0b3A6IDNweDtcblx0d2lkdGg6IDJweDtcbmA7XG5cbmNvbnN0IEhvcml6b250YWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRoZWlnaHQ6IDJweDtcblx0bGVmdDogM3B4O1xuXHRyaWdodDogM3B4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvcFN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHR0b3A6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgUmlnaHRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdHJpZ2h0OiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IEJvdHRvbVN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHRib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgTGVmdFN0cm9rZSA9IHN0eWxlZCggVmVydGljYWxTdHJva2UgKWBcblx0bGVmdDogMDtcbmA7XG4iXX0= */", 35512 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35513 }); 35514 var Viewbox = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 35515 target: "e1j5nr4z7" 35516 } : { 35517 target: "e1j5nr4z7", 35518 label: "Viewbox" 35519 })(false ? { 35520 name: "i6vjox", 35521 styles: "box-sizing:border-box;display:block;position:relative;width:100%;height:100%" 35522 } : { 35523 name: "i6vjox", 35524 styles: "box-sizing:border-box;display:block;position:relative;width:100%;height:100%", 35525 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVrQyIsImZpbGUiOiJib3gtY29udHJvbC1pY29uLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFJvb3QgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHdpZHRoOiAyNHB4O1xuXHRoZWlnaHQ6IDI0cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0cGFkZGluZzogNHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdib3ggPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0d2lkdGg6IDEwMCU7XG5cdGhlaWdodDogMTAwJTtcbmA7XG5cbmNvbnN0IHN0cm9rZUZvY3VzID0gKCB7IGlzRm9jdXNlZCB9OiB7IGlzRm9jdXNlZDogYm9vbGVhbiB9ICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0YmFja2dyb3VuZENvbG9yOiAnY3VycmVudENvbG9yJyxcblx0XHRvcGFjaXR5OiBpc0ZvY3VzZWQgPyAxIDogMC4zLFxuXHR9ICk7XG59O1xuXG5jb25zdCBTdHJva2UgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdCR7IHN0cm9rZUZvY3VzIH07XG5gO1xuXG5jb25zdCBWZXJ0aWNhbFN0cm9rZSA9IHN0eWxlZCggU3Ryb2tlIClgXG5cdGJvdHRvbTogM3B4O1xuXHR0b3A6IDNweDtcblx0d2lkdGg6IDJweDtcbmA7XG5cbmNvbnN0IEhvcml6b250YWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRoZWlnaHQ6IDJweDtcblx0bGVmdDogM3B4O1xuXHRyaWdodDogM3B4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvcFN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHR0b3A6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgUmlnaHRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdHJpZ2h0OiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IEJvdHRvbVN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHRib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgTGVmdFN0cm9rZSA9IHN0eWxlZCggVmVydGljYWxTdHJva2UgKWBcblx0bGVmdDogMDtcbmA7XG4iXX0= */", 35526 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35527 }); 35528 var strokeFocus = ({ 35529 isFocused 35530 }) => { 35531 return /* @__PURE__ */ css({ 35532 backgroundColor: "currentColor", 35533 opacity: isFocused ? 1 : 0.3 35534 }, false ? "" : ";label:strokeFocus;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdCUSIsImZpbGUiOiJib3gtY29udHJvbC1pY29uLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFJvb3QgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHdpZHRoOiAyNHB4O1xuXHRoZWlnaHQ6IDI0cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0cGFkZGluZzogNHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdib3ggPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0d2lkdGg6IDEwMCU7XG5cdGhlaWdodDogMTAwJTtcbmA7XG5cbmNvbnN0IHN0cm9rZUZvY3VzID0gKCB7IGlzRm9jdXNlZCB9OiB7IGlzRm9jdXNlZDogYm9vbGVhbiB9ICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0YmFja2dyb3VuZENvbG9yOiAnY3VycmVudENvbG9yJyxcblx0XHRvcGFjaXR5OiBpc0ZvY3VzZWQgPyAxIDogMC4zLFxuXHR9ICk7XG59O1xuXG5jb25zdCBTdHJva2UgPSBzdHlsZWQuc3BhbmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdCR7IHN0cm9rZUZvY3VzIH07XG5gO1xuXG5jb25zdCBWZXJ0aWNhbFN0cm9rZSA9IHN0eWxlZCggU3Ryb2tlIClgXG5cdGJvdHRvbTogM3B4O1xuXHR0b3A6IDNweDtcblx0d2lkdGg6IDJweDtcbmA7XG5cbmNvbnN0IEhvcml6b250YWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRoZWlnaHQ6IDJweDtcblx0bGVmdDogM3B4O1xuXHRyaWdodDogM3B4O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvcFN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHR0b3A6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgUmlnaHRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdHJpZ2h0OiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IEJvdHRvbVN0cm9rZSA9IHN0eWxlZCggSG9yaXpvbnRhbFN0cm9rZSApYFxuXHRib3R0b206IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgTGVmdFN0cm9rZSA9IHN0eWxlZCggVmVydGljYWxTdHJva2UgKWBcblx0bGVmdDogMDtcbmA7XG4iXX0= */"); 35535 }; 35536 var Stroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 35537 target: "e1j5nr4z6" 35538 } : { 35539 target: "e1j5nr4z6", 35540 label: "Stroke" 35541 })("box-sizing:border-box;display:block;pointer-events:none;position:absolute;", strokeFocus, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCMEIiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */")); 35542 var VerticalStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(Stroke, false ? { 35543 target: "e1j5nr4z5" 35544 } : { 35545 target: "e1j5nr4z5", 35546 label: "VerticalStroke" 35547 })(false ? { 35548 name: "1k2w39q", 35549 styles: "bottom:3px;top:3px;width:2px" 35550 } : { 35551 name: "1k2w39q", 35552 styles: "bottom:3px;top:3px;width:2px", 35553 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDdUMiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35554 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35555 }); 35556 var HorizontalStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(Stroke, false ? { 35557 target: "e1j5nr4z4" 35558 } : { 35559 target: "e1j5nr4z4", 35560 label: "HorizontalStroke" 35561 })(false ? { 35562 name: "1q9b07k", 35563 styles: "height:2px;left:3px;right:3px" 35564 } : { 35565 name: "1q9b07k", 35566 styles: "height:2px;left:3px;right:3px", 35567 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDeUMiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35568 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35569 }); 35570 var TopStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(HorizontalStroke, false ? { 35571 target: "e1j5nr4z3" 35572 } : { 35573 target: "e1j5nr4z3", 35574 label: "TopStroke" 35575 })(false ? { 35576 name: "abcix4", 35577 styles: "top:0" 35578 } : { 35579 name: "abcix4", 35580 styles: "top:0", 35581 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtEbUQiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35582 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35583 }); 35584 var RightStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(VerticalStroke, false ? { 35585 target: "e1j5nr4z2" 35586 } : { 35587 target: "e1j5nr4z2", 35588 label: "RightStroke" 35589 })(false ? { 35590 name: "1wf8jf", 35591 styles: "right:0" 35592 } : { 35593 name: "1wf8jf", 35594 styles: "right:0", 35595 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEbUQiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35596 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35597 }); 35598 var BottomStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(HorizontalStroke, false ? { 35599 target: "e1j5nr4z1" 35600 } : { 35601 target: "e1j5nr4z1", 35602 label: "BottomStroke" 35603 })(false ? { 35604 name: "8tapst", 35605 styles: "bottom:0" 35606 } : { 35607 name: "8tapst", 35608 styles: "bottom:0", 35609 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBEc0QiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35610 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35611 }); 35612 var LeftStroke = /* @__PURE__ */ emotion_styled_base_browser_esm_default(VerticalStroke, false ? { 35613 target: "e1j5nr4z0" 35614 } : { 35615 target: "e1j5nr4z0", 35616 label: "LeftStroke" 35617 })(false ? { 35618 name: "1ode3cm", 35619 styles: "left:0" 35620 } : { 35621 name: "1ode3cm", 35622 styles: "left:0", 35623 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLWljb24tc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEa0QiLCJmaWxlIjoiYm94LWNvbnRyb2wtaWNvbi1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHR3aWR0aDogMjRweDtcblx0aGVpZ2h0OiAyNHB4O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHBhZGRpbmc6IDRweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBWaWV3Ym94ID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdHdpZHRoOiAxMDAlO1xuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5jb25zdCBzdHJva2VGb2N1cyA9ICggeyBpc0ZvY3VzZWQgfTogeyBpc0ZvY3VzZWQ6IGJvb2xlYW4gfSApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdGJhY2tncm91bmRDb2xvcjogJ2N1cnJlbnRDb2xvcicsXG5cdFx0b3BhY2l0eTogaXNGb2N1c2VkID8gMSA6IDAuMyxcblx0fSApO1xufTtcblxuY29uc3QgU3Ryb2tlID0gc3R5bGVkLnNwYW5gXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHQkeyBzdHJva2VGb2N1cyB9O1xuYDtcblxuY29uc3QgVmVydGljYWxTdHJva2UgPSBzdHlsZWQoIFN0cm9rZSApYFxuXHRib3R0b206IDNweDtcblx0dG9wOiAzcHg7XG5cdHdpZHRoOiAycHg7XG5gO1xuXG5jb25zdCBIb3Jpem9udGFsU3Ryb2tlID0gc3R5bGVkKCBTdHJva2UgKWBcblx0aGVpZ2h0OiAycHg7XG5cdGxlZnQ6IDNweDtcblx0cmlnaHQ6IDNweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb3BTdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJpZ2h0U3Ryb2tlID0gc3R5bGVkKCBWZXJ0aWNhbFN0cm9rZSApYFxuXHRyaWdodDogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBCb3R0b21TdHJva2UgPSBzdHlsZWQoIEhvcml6b250YWxTdHJva2UgKWBcblx0Ym90dG9tOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IExlZnRTdHJva2UgPSBzdHlsZWQoIFZlcnRpY2FsU3Ryb2tlIClgXG5cdGxlZnQ6IDA7XG5gO1xuIl19 */", 35624 toString: _EMOTION_STRINGIFIED_CSS_ERROR__15 35625 }); 35626 35627 // packages/components/build-module/box-control/icon.js 35628 var import_jsx_runtime155 = __toESM(require_jsx_runtime()); 35629 var BASE_ICON_SIZE = 24; 35630 function BoxControlIcon({ 35631 size: size3 = 24, 35632 side = "all", 35633 sides: sides3, 35634 ...props 35635 }) { 35636 const isSideDisabled = (value) => sides3?.length && !sides3.includes(value); 35637 const hasSide = (value) => { 35638 if (isSideDisabled(value)) { 35639 return false; 35640 } 35641 return side === "all" || side === value; 35642 }; 35643 const top = hasSide("top") || hasSide("vertical"); 35644 const right = hasSide("right") || hasSide("horizontal"); 35645 const bottom = hasSide("bottom") || hasSide("vertical"); 35646 const left = hasSide("left") || hasSide("horizontal"); 35647 const scale2 = size3 / BASE_ICON_SIZE; 35648 return /* @__PURE__ */ (0, import_jsx_runtime155.jsx)(Root3, { 35649 style: { 35650 transform: `scale($scale2})` 35651 }, 35652 ...props, 35653 children: /* @__PURE__ */ (0, import_jsx_runtime155.jsxs)(Viewbox, { 35654 children: [/* @__PURE__ */ (0, import_jsx_runtime155.jsx)(TopStroke, { 35655 isFocused: top 35656 }), /* @__PURE__ */ (0, import_jsx_runtime155.jsx)(RightStroke, { 35657 isFocused: right 35658 }), /* @__PURE__ */ (0, import_jsx_runtime155.jsx)(BottomStroke, { 35659 isFocused: bottom 35660 }), /* @__PURE__ */ (0, import_jsx_runtime155.jsx)(LeftStroke, { 35661 isFocused: left 35662 })] 35663 }) 35664 }); 35665 } 35666 35667 // packages/components/build-module/box-control/styles/box-control-styles.js 35668 function _EMOTION_STRINGIFIED_CSS_ERROR__16() { 35669 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 35670 } 35671 var StyledUnitControl = /* @__PURE__ */ emotion_styled_base_browser_esm_default(unit_control_default, false ? { 35672 target: "e1jovhle5" 35673 } : { 35674 target: "e1jovhle5", 35675 label: "StyledUnitControl" 35676 })(false ? { 35677 name: "1ejyr19", 35678 styles: "max-width:90px" 35679 } : { 35680 name: "1ejyr19", 35681 styles: "max-width:90px", 35682 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjc0QiLCJmaWxlIjoiYm94LWNvbnRyb2wtc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJveENvbnRyb2xJY29uIGZyb20gJy4uL2ljb24nO1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgUmFuZ2VDb250cm9sIGZyb20gJy4uLy4uL3JhbmdlLWNvbnRyb2wnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFVuaXRDb250cm9sID0gc3R5bGVkKCBVbml0Q29udHJvbCApYFxuXHRtYXgtd2lkdGg6IDkwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRXcmFwcGVyID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Z3JpZC1jb2x1bW46IDEgLyBzcGFuIDM7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWFyZWE6IDEgLyAyO1xuXHRqdXN0aWZ5LXNlbGY6IGVuZDtcbmA7XG5cbmV4cG9ydCBjb25zdCBMaW5rZWRCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Z3JpZC1hcmVhOiAxIC8gMztcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgRmxleGVkQm94Q29udHJvbEljb24gPSBzdHlsZWQoIEJveENvbnRyb2xJY29uIClgXG5cdGZsZXg6IDAgMCBhdXRvO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZFJhbmdlQ29udHJvbCA9IHN0eWxlZCggUmFuZ2VDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuXHRtYXJnaW4taW5saW5lLWVuZDogJHsgc3BhY2UoIDIgKSB9O1xuYDtcbiJdfQ== */", 35683 toString: _EMOTION_STRINGIFIED_CSS_ERROR__16 35684 }); 35685 var InputWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default9, false ? { 35686 target: "e1jovhle4" 35687 } : { 35688 target: "e1jovhle4", 35689 label: "InputWrapper" 35690 })(false ? { 35691 name: "1j1lmoi", 35692 styles: "grid-column:1/span 3" 35693 } : { 35694 name: "1j1lmoi", 35695 styles: "grid-column:1/span 3", 35696 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQjRDIiwiZmlsZSI6ImJveC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBCb3hDb250cm9sSWNvbiBmcm9tICcuLi9pY29uJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IEhTdGFjayB9IGZyb20gJy4uLy4uL2gtc3RhY2snO1xuaW1wb3J0IFJhbmdlQ29udHJvbCBmcm9tICcuLi8uLi9yYW5nZS1jb250cm9sJztcbmltcG9ydCBVbml0Q29udHJvbCBmcm9tICcuLi8uLi91bml0LWNvbnRyb2wnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0bWF4LXdpZHRoOiA5MHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGdyaWQtY29sdW1uOiAxIC8gc3BhbiAzO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJlc2V0QnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1hcmVhOiAxIC8gMjtcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgTGlua2VkQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGdyaWQtYXJlYTogMSAvIDM7XG5cdGp1c3RpZnktc2VsZjogZW5kO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZEJveENvbnRyb2xJY29uID0gc3R5bGVkKCBCb3hDb250cm9sSWNvbiApYFxuXHRmbGV4OiAwIDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBGbGV4ZWRSYW5nZUNvbnRyb2wgPSBzdHlsZWQoIFJhbmdlQ29udHJvbCApYFxuXHR3aWR0aDogMTAwJTtcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG4iXX0= */", 35697 toString: _EMOTION_STRINGIFIED_CSS_ERROR__16 35698 }); 35699 var ResetButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 35700 target: "e1jovhle3" 35701 } : { 35702 target: "e1jovhle3", 35703 label: "ResetButton" 35704 })(false ? { 35705 name: "tkya7b", 35706 styles: "grid-area:1/2;justify-self:end" 35707 } : { 35708 name: "tkya7b", 35709 styles: "grid-area:1/2;justify-self:end", 35710 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQjJDIiwiZmlsZSI6ImJveC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBCb3hDb250cm9sSWNvbiBmcm9tICcuLi9pY29uJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IEhTdGFjayB9IGZyb20gJy4uLy4uL2gtc3RhY2snO1xuaW1wb3J0IFJhbmdlQ29udHJvbCBmcm9tICcuLi8uLi9yYW5nZS1jb250cm9sJztcbmltcG9ydCBVbml0Q29udHJvbCBmcm9tICcuLi8uLi91bml0LWNvbnRyb2wnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0bWF4LXdpZHRoOiA5MHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGdyaWQtY29sdW1uOiAxIC8gc3BhbiAzO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJlc2V0QnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1hcmVhOiAxIC8gMjtcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgTGlua2VkQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGdyaWQtYXJlYTogMSAvIDM7XG5cdGp1c3RpZnktc2VsZjogZW5kO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZEJveENvbnRyb2xJY29uID0gc3R5bGVkKCBCb3hDb250cm9sSWNvbiApYFxuXHRmbGV4OiAwIDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBGbGV4ZWRSYW5nZUNvbnRyb2wgPSBzdHlsZWQoIFJhbmdlQ29udHJvbCApYFxuXHR3aWR0aDogMTAwJTtcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG4iXX0= */", 35711 toString: _EMOTION_STRINGIFIED_CSS_ERROR__16 35712 }); 35713 var LinkedButtonWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 35714 target: "e1jovhle2" 35715 } : { 35716 target: "e1jovhle2", 35717 label: "LinkedButtonWrapper" 35718 })(false ? { 35719 name: "1dfa8al", 35720 styles: "grid-area:1/3;justify-self:end" 35721 } : { 35722 name: "1dfa8al", 35723 styles: "grid-area:1/3;justify-self:end", 35724 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQjZDIiwiZmlsZSI6ImJveC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBCb3hDb250cm9sSWNvbiBmcm9tICcuLi9pY29uJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IEhTdGFjayB9IGZyb20gJy4uLy4uL2gtc3RhY2snO1xuaW1wb3J0IFJhbmdlQ29udHJvbCBmcm9tICcuLi8uLi9yYW5nZS1jb250cm9sJztcbmltcG9ydCBVbml0Q29udHJvbCBmcm9tICcuLi8uLi91bml0LWNvbnRyb2wnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0bWF4LXdpZHRoOiA5MHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGdyaWQtY29sdW1uOiAxIC8gc3BhbiAzO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJlc2V0QnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1hcmVhOiAxIC8gMjtcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgTGlua2VkQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGdyaWQtYXJlYTogMSAvIDM7XG5cdGp1c3RpZnktc2VsZjogZW5kO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZEJveENvbnRyb2xJY29uID0gc3R5bGVkKCBCb3hDb250cm9sSWNvbiApYFxuXHRmbGV4OiAwIDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBGbGV4ZWRSYW5nZUNvbnRyb2wgPSBzdHlsZWQoIFJhbmdlQ29udHJvbCApYFxuXHR3aWR0aDogMTAwJTtcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG4iXX0= */", 35725 toString: _EMOTION_STRINGIFIED_CSS_ERROR__16 35726 }); 35727 var FlexedBoxControlIcon = /* @__PURE__ */ emotion_styled_base_browser_esm_default(BoxControlIcon, false ? { 35728 target: "e1jovhle1" 35729 } : { 35730 target: "e1jovhle1", 35731 label: "FlexedBoxControlIcon" 35732 })(false ? { 35733 name: "ou8xsw", 35734 styles: "flex:0 0 auto" 35735 } : { 35736 name: "ou8xsw", 35737 styles: "flex:0 0 auto", 35738 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzREIiwiZmlsZSI6ImJveC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBCb3hDb250cm9sSWNvbiBmcm9tICcuLi9pY29uJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IEhTdGFjayB9IGZyb20gJy4uLy4uL2gtc3RhY2snO1xuaW1wb3J0IFJhbmdlQ29udHJvbCBmcm9tICcuLi8uLi9yYW5nZS1jb250cm9sJztcbmltcG9ydCBVbml0Q29udHJvbCBmcm9tICcuLi8uLi91bml0LWNvbnRyb2wnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0bWF4LXdpZHRoOiA5MHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGdyaWQtY29sdW1uOiAxIC8gc3BhbiAzO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJlc2V0QnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1hcmVhOiAxIC8gMjtcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgTGlua2VkQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGdyaWQtYXJlYTogMSAvIDM7XG5cdGp1c3RpZnktc2VsZjogZW5kO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZEJveENvbnRyb2xJY29uID0gc3R5bGVkKCBCb3hDb250cm9sSWNvbiApYFxuXHRmbGV4OiAwIDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBGbGV4ZWRSYW5nZUNvbnRyb2wgPSBzdHlsZWQoIFJhbmdlQ29udHJvbCApYFxuXHR3aWR0aDogMTAwJTtcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG4iXX0= */", 35739 toString: _EMOTION_STRINGIFIED_CSS_ERROR__16 35740 }); 35741 var FlexedRangeControl = /* @__PURE__ */ emotion_styled_base_browser_esm_default(range_control_default, false ? { 35742 target: "e1jovhle0" 35743 } : { 35744 target: "e1jovhle0", 35745 label: "FlexedRangeControl" 35746 })("width:100%;margin-inline-end:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJveC1jb250cm9sLXN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ3dEIiwiZmlsZSI6ImJveC1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBCb3hDb250cm9sSWNvbiBmcm9tICcuLi9pY29uJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vLi4vYnV0dG9uJztcbmltcG9ydCB7IEhTdGFjayB9IGZyb20gJy4uLy4uL2gtc3RhY2snO1xuaW1wb3J0IFJhbmdlQ29udHJvbCBmcm9tICcuLi8uLi9yYW5nZS1jb250cm9sJztcbmltcG9ydCBVbml0Q29udHJvbCBmcm9tICcuLi8uLi91bml0LWNvbnRyb2wnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi8uLi91dGlscy9zcGFjZSc7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0bWF4LXdpZHRoOiA5MHB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IElucHV0V3JhcHBlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGdyaWQtY29sdW1uOiAxIC8gc3BhbiAzO1xuYDtcblxuZXhwb3J0IGNvbnN0IFJlc2V0QnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1hcmVhOiAxIC8gMjtcblx0anVzdGlmeS1zZWxmOiBlbmQ7XG5gO1xuXG5leHBvcnQgY29uc3QgTGlua2VkQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGdyaWQtYXJlYTogMSAvIDM7XG5cdGp1c3RpZnktc2VsZjogZW5kO1xuYDtcblxuZXhwb3J0IGNvbnN0IEZsZXhlZEJveENvbnRyb2xJY29uID0gc3R5bGVkKCBCb3hDb250cm9sSWNvbiApYFxuXHRmbGV4OiAwIDAgYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBGbGV4ZWRSYW5nZUNvbnRyb2wgPSBzdHlsZWQoIFJhbmdlQ29udHJvbCApYFxuXHR3aWR0aDogMTAwJTtcblx0bWFyZ2luLWlubGluZS1lbmQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG4iXX0= */")); 35747 35748 // packages/components/build-module/box-control/input-control.js 35749 var import_jsx_runtime156 = __toESM(require_jsx_runtime()); 35750 var noop8 = () => { 35751 }; 35752 function getSidesToModify(side, sides3, isAlt) { 35753 const allowedSides = getAllowedSides(sides3); 35754 let modifiedSides = []; 35755 switch (side) { 35756 case "all": 35757 modifiedSides = ["top", "bottom", "left", "right"]; 35758 break; 35759 case "horizontal": 35760 modifiedSides = ["left", "right"]; 35761 break; 35762 case "vertical": 35763 modifiedSides = ["top", "bottom"]; 35764 break; 35765 default: 35766 modifiedSides = [side]; 35767 } 35768 if (isAlt) { 35769 switch (side) { 35770 case "top": 35771 modifiedSides.push("bottom"); 35772 break; 35773 case "bottom": 35774 modifiedSides.push("top"); 35775 break; 35776 case "left": 35777 modifiedSides.push("left"); 35778 break; 35779 case "right": 35780 modifiedSides.push("right"); 35781 break; 35782 } 35783 } 35784 return modifiedSides.filter((s3) => allowedSides.has(s3)); 35785 } 35786 function BoxInputControl({ 35787 __next40pxDefaultSize, 35788 onChange = noop8, 35789 onFocus = noop8, 35790 values, 35791 selectedUnits, 35792 setSelectedUnits, 35793 sides: sides3, 35794 side, 35795 min: min3 = 0, 35796 presets, 35797 presetKey, 35798 ...props 35799 }) { 35800 var _CUSTOM_VALUE_SETTING, _CUSTOM_VALUE_SETTING2; 35801 const defaultValuesToModify = getSidesToModify(side, sides3); 35802 const handleOnFocus = (event) => { 35803 onFocus(event, { 35804 side 35805 }); 35806 }; 35807 const handleOnChange = (nextValues) => { 35808 onChange(nextValues); 35809 }; 35810 const handleRawOnValueChange = (next2) => { 35811 const nextValues = { 35812 ...values 35813 }; 35814 defaultValuesToModify.forEach((modifiedSide) => { 35815 nextValues[modifiedSide] = next2; 35816 }); 35817 handleOnChange(nextValues); 35818 }; 35819 const handleOnValueChange = (next2, extra) => { 35820 const nextValues = { 35821 ...values 35822 }; 35823 const isNumeric = next2 !== void 0 && !isNaN(parseFloat(next2)); 35824 const nextValue = isNumeric ? next2 : void 0; 35825 const modifiedSides = getSidesToModify( 35826 side, 35827 sides3, 35828 /** 35829 * Supports changing pair sides. For example, holding the ALT key 35830 * when changing the TOP will also update BOTTOM. 35831 */ 35832 // @ts-expect-error - TODO: event.altKey is only present when the change event was 35833 // triggered by a keyboard event. Should this feature be implemented differently so 35834 // it also works with drag events? 35835 !!extra?.event.altKey 35836 ); 35837 modifiedSides.forEach((modifiedSide) => { 35838 nextValues[modifiedSide] = nextValue; 35839 }); 35840 handleOnChange(nextValues); 35841 }; 35842 const handleOnUnitChange = (next2) => { 35843 const newUnits = { 35844 ...selectedUnits 35845 }; 35846 defaultValuesToModify.forEach((modifiedSide) => { 35847 newUnits[modifiedSide] = next2; 35848 }); 35849 setSelectedUnits(newUnits); 35850 }; 35851 const mergedValue = getMergedValue(values, defaultValuesToModify); 35852 const hasValues = isValuesDefined(values); 35853 const isMixed = hasValues && defaultValuesToModify.length > 1 && isValueMixed(values, defaultValuesToModify); 35854 const [parsedQuantity, parsedUnit] = parseQuantityAndUnitFromRawValue(mergedValue); 35855 const computedUnit = hasValues ? parsedUnit : selectedUnits[defaultValuesToModify[0]]; 35856 const generatedId = (0, import_compose40.useInstanceId)(BoxInputControl, "box-control-input"); 35857 const inputId = [generatedId, side].join("-"); 35858 const isMixedUnit = defaultValuesToModify.length > 1 && mergedValue === void 0 && defaultValuesToModify.some((s3) => selectedUnits[s3] !== computedUnit); 35859 const usedValue = mergedValue === void 0 && computedUnit ? computedUnit : mergedValue; 35860 const mixedPlaceholder = isMixed || isMixedUnit ? (0, import_i18n28.__)("Mixed") : void 0; 35861 const hasPresets = presets && presets.length > 0 && presetKey; 35862 const hasPresetValue = hasPresets && mergedValue !== void 0 && !isMixed && isValuePreset(mergedValue, presetKey); 35863 const [showCustomValueControl, setShowCustomValueControl] = (0, import_element93.useState)(!hasPresets || !hasPresetValue && !isMixed && mergedValue !== void 0); 35864 const presetIndex = hasPresetValue ? getPresetIndexFromValue(mergedValue, presetKey, presets) : void 0; 35865 const marks = hasPresets ? [{ 35866 value: 0, 35867 label: "", 35868 tooltip: (0, import_i18n28.__)("None") 35869 }, ...presets.map((preset, index2) => { 35870 var _preset$name; 35871 return { 35872 value: index2 + 1, 35873 label: "", 35874 tooltip: (_preset$name = preset.name) !== null && _preset$name !== void 0 ? _preset$name : preset.slug 35875 }; 35876 })] : []; 35877 return /* @__PURE__ */ (0, import_jsx_runtime156.jsxs)(InputWrapper, { 35878 expanded: true, 35879 children: [/* @__PURE__ */ (0, import_jsx_runtime156.jsx)(FlexedBoxControlIcon, { 35880 side, 35881 sides: sides3 35882 }), showCustomValueControl && /* @__PURE__ */ (0, import_jsx_runtime156.jsxs)(import_jsx_runtime156.Fragment, { 35883 children: [/* @__PURE__ */ (0, import_jsx_runtime156.jsx)(tooltip_default, { 35884 placement: "top-end", 35885 text: LABELS[side], 35886 children: /* @__PURE__ */ (0, import_jsx_runtime156.jsx)(StyledUnitControl, { 35887 ...props, 35888 min: min3, 35889 __shouldNotWarnDeprecated36pxSize: true, 35890 __next40pxDefaultSize, 35891 className: "component-box-control__unit-control", 35892 id: inputId, 35893 isPressEnterToChange: true, 35894 disableUnits: isMixed || isMixedUnit, 35895 value: usedValue, 35896 onChange: handleOnValueChange, 35897 onUnitChange: handleOnUnitChange, 35898 onFocus: handleOnFocus, 35899 label: LABELS[side], 35900 placeholder: mixedPlaceholder, 35901 hideLabelFromVision: true 35902 }) 35903 }), /* @__PURE__ */ (0, import_jsx_runtime156.jsx)(FlexedRangeControl, { 35904 __next40pxDefaultSize, 35905 __shouldNotWarnDeprecated36pxSize: true, 35906 "aria-controls": inputId, 35907 label: LABELS[side], 35908 hideLabelFromVision: true, 35909 onChange: (newValue) => { 35910 handleOnValueChange(newValue !== void 0 ? [newValue, computedUnit].join("") : void 0); 35911 }, 35912 min: isFinite(min3) ? min3 : 0, 35913 max: (_CUSTOM_VALUE_SETTING = CUSTOM_VALUE_SETTINGS[computedUnit !== null && computedUnit !== void 0 ? computedUnit : "px"]?.max) !== null && _CUSTOM_VALUE_SETTING !== void 0 ? _CUSTOM_VALUE_SETTING : 10, 35914 step: (_CUSTOM_VALUE_SETTING2 = CUSTOM_VALUE_SETTINGS[computedUnit !== null && computedUnit !== void 0 ? computedUnit : "px"]?.step) !== null && _CUSTOM_VALUE_SETTING2 !== void 0 ? _CUSTOM_VALUE_SETTING2 : 0.1, 35915 value: parsedQuantity !== null && parsedQuantity !== void 0 ? parsedQuantity : 0, 35916 withInputField: false 35917 })] 35918 }), hasPresets && !showCustomValueControl && /* @__PURE__ */ (0, import_jsx_runtime156.jsx)(FlexedRangeControl, { 35919 __next40pxDefaultSize: true, 35920 className: "spacing-sizes-control__range-control", 35921 value: presetIndex !== void 0 ? presetIndex + 1 : 0, 35922 onChange: (newIndex) => { 35923 const newValue = newIndex === 0 || newIndex === void 0 ? void 0 : getPresetValueFromIndex(newIndex - 1, presetKey, presets); 35924 handleRawOnValueChange(newValue); 35925 }, 35926 withInputField: false, 35927 "aria-valuenow": presetIndex !== void 0 ? presetIndex + 1 : 0, 35928 "aria-valuetext": marks[presetIndex !== void 0 ? presetIndex + 1 : 0].tooltip, 35929 renderTooltipContent: (index2) => marks[!index2 ? 0 : index2].tooltip, 35930 min: 0, 35931 max: marks.length - 1, 35932 marks, 35933 label: LABELS[side], 35934 hideLabelFromVision: true 35935 }), hasPresets && /* @__PURE__ */ (0, import_jsx_runtime156.jsx)(button_default, { 35936 label: showCustomValueControl ? (0, import_i18n28.__)("Use size preset") : (0, import_i18n28.__)("Set custom size"), 35937 icon: settings_default, 35938 onClick: () => { 35939 setShowCustomValueControl(!showCustomValueControl); 35940 }, 35941 isPressed: showCustomValueControl, 35942 size: "small", 35943 iconSize: 24 35944 })] 35945 }, `box-control-$side}`); 35946 } 35947 35948 // packages/components/build-module/box-control/linked-button.js 35949 var import_i18n29 = __toESM(require_i18n()); 35950 var import_jsx_runtime157 = __toESM(require_jsx_runtime()); 35951 function LinkedButton({ 35952 isLinked, 35953 ...props 35954 }) { 35955 const label = isLinked ? (0, import_i18n29.__)("Unlink sides") : (0, import_i18n29.__)("Link sides"); 35956 return /* @__PURE__ */ (0, import_jsx_runtime157.jsx)(button_default, { 35957 ...props, 35958 className: "component-box-control__linked-button", 35959 size: "small", 35960 icon: isLinked ? link_default : link_off_default, 35961 iconSize: 24, 35962 label 35963 }); 35964 } 35965 35966 // packages/components/build-module/box-control/index.js 35967 var import_jsx_runtime158 = __toESM(require_jsx_runtime()); 35968 var defaultInputProps = { 35969 min: 0 35970 }; 35971 var noop9 = () => { 35972 }; 35973 function useUniqueId4(idProp) { 35974 const instanceId = (0, import_compose41.useInstanceId)(BoxControl, "inspector-box-control"); 35975 return idProp || instanceId; 35976 } 35977 function BoxControl({ 35978 __next40pxDefaultSize = false, 35979 id: idProp, 35980 inputProps = defaultInputProps, 35981 onChange = noop9, 35982 label = (0, import_i18n30.__)("Box Control"), 35983 values: valuesProp, 35984 units, 35985 sides: sides3, 35986 splitOnAxis = false, 35987 allowReset = true, 35988 resetValues = DEFAULT_VALUES, 35989 presets, 35990 presetKey, 35991 onMouseOver, 35992 onMouseOut 35993 }) { 35994 const [values, setValues] = use_controlled_state_default(valuesProp, { 35995 fallback: DEFAULT_VALUES 35996 }); 35997 const inputValues = values || DEFAULT_VALUES; 35998 const hasInitialValue = isValuesDefined(valuesProp); 35999 const hasOneSide = sides3?.length === 1; 36000 const [isDirty, setIsDirty] = (0, import_element94.useState)(hasInitialValue); 36001 const [isLinked, setIsLinked] = (0, import_element94.useState)(!hasInitialValue || !isValueMixed(inputValues) || hasOneSide); 36002 const [side, setSide] = (0, import_element94.useState)(getInitialSide(isLinked, splitOnAxis)); 36003 const [selectedUnits, setSelectedUnits] = (0, import_element94.useState)({ 36004 top: parseQuantityAndUnitFromRawValue(valuesProp?.top)[1], 36005 right: parseQuantityAndUnitFromRawValue(valuesProp?.right)[1], 36006 bottom: parseQuantityAndUnitFromRawValue(valuesProp?.bottom)[1], 36007 left: parseQuantityAndUnitFromRawValue(valuesProp?.left)[1] 36008 }); 36009 const id3 = useUniqueId4(idProp); 36010 const headingId = `$id3}-heading`; 36011 const toggleLinked = () => { 36012 setIsLinked(!isLinked); 36013 setSide(getInitialSide(!isLinked, splitOnAxis)); 36014 }; 36015 const handleOnFocus = (_event, { 36016 side: nextSide 36017 }) => { 36018 setSide(nextSide); 36019 }; 36020 const handleOnChange = (nextValues) => { 36021 onChange(nextValues); 36022 setValues(nextValues); 36023 setIsDirty(true); 36024 }; 36025 const handleOnReset = () => { 36026 onChange(resetValues); 36027 setValues(resetValues); 36028 setSelectedUnits(resetValues); 36029 setIsDirty(false); 36030 }; 36031 const inputControlProps = { 36032 onMouseOver, 36033 onMouseOut, 36034 ...inputProps, 36035 onChange: handleOnChange, 36036 onFocus: handleOnFocus, 36037 isLinked, 36038 units, 36039 selectedUnits, 36040 setSelectedUnits, 36041 sides: sides3, 36042 values: inputValues, 36043 __next40pxDefaultSize, 36044 presets, 36045 presetKey 36046 }; 36047 maybeWarnDeprecated36pxSize({ 36048 componentName: "BoxControl", 36049 __next40pxDefaultSize, 36050 size: void 0 36051 }); 36052 const sidesToRender = getAllowedSides(sides3); 36053 if (presets && !presetKey || !presets && presetKey) { 36054 const definedProp = presets ? "presets" : "presetKey"; 36055 const missingProp = presets ? "presetKey" : "presets"; 36056 true ? (0, import_warning5.default)(`wp.components.BoxControl: the '$missingProp}' prop is required when the '$definedProp}' prop is defined.`) : void 0; 36057 } 36058 return /* @__PURE__ */ (0, import_jsx_runtime158.jsxs)(component_default22, { 36059 id: id3, 36060 columns: 3, 36061 templateColumns: "1fr min-content min-content", 36062 role: "group", 36063 "aria-labelledby": headingId, 36064 children: [/* @__PURE__ */ (0, import_jsx_runtime158.jsx)(BaseControl.VisualLabel, { 36065 id: headingId, 36066 children: label 36067 }), isLinked && /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(InputWrapper, { 36068 children: /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(BoxInputControl, { 36069 side: "all", 36070 ...inputControlProps 36071 }) 36072 }), !hasOneSide && /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(LinkedButtonWrapper, { 36073 children: /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(LinkedButton, { 36074 onClick: toggleLinked, 36075 isLinked 36076 }) 36077 }), !isLinked && splitOnAxis && ["vertical", "horizontal"].map((axis) => /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(BoxInputControl, { 36078 side: axis, 36079 ...inputControlProps 36080 }, axis)), !isLinked && !splitOnAxis && Array.from(sidesToRender).map((axis) => /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(BoxInputControl, { 36081 side: axis, 36082 ...inputControlProps 36083 }, axis)), allowReset && /* @__PURE__ */ (0, import_jsx_runtime158.jsx)(ResetButton, { 36084 className: "component-box-control__reset-button", 36085 variant: "secondary", 36086 size: "small", 36087 onClick: handleOnReset, 36088 disabled: !isDirty, 36089 children: (0, import_i18n30.__)("Reset") 36090 })] 36091 }); 36092 } 36093 var box_control_default = BoxControl; 36094 36095 // packages/components/build-module/button-group/index.js 36096 var import_element95 = __toESM(require_element()); 36097 var import_deprecated10 = __toESM(require_deprecated()); 36098 var import_jsx_runtime159 = __toESM(require_jsx_runtime()); 36099 function UnforwardedButtonGroup(props, ref) { 36100 const { 36101 className: className2, 36102 __shouldNotWarnDeprecated, 36103 ...restProps 36104 } = props; 36105 const classes = clsx_default("components-button-group", className2); 36106 if (!__shouldNotWarnDeprecated) { 36107 (0, import_deprecated10.default)("wp.components.ButtonGroup", { 36108 since: "6.8", 36109 alternative: "wp.components.__experimentalToggleGroupControl" 36110 }); 36111 } 36112 return /* @__PURE__ */ (0, import_jsx_runtime159.jsx)("div", { 36113 ref, 36114 role: "group", 36115 className: classes, 36116 ...restProps 36117 }); 36118 } 36119 var ButtonGroup = (0, import_element95.forwardRef)(UnforwardedButtonGroup); 36120 var button_group_default = ButtonGroup; 36121 36122 // packages/components/build-module/card/card/component.js 36123 var import_element99 = __toESM(require_element()); 36124 36125 // packages/components/build-module/elevation/hook.js 36126 var import_element96 = __toESM(require_element()); 36127 36128 // packages/components/build-module/elevation/styles.js 36129 function _EMOTION_STRINGIFIED_CSS_ERROR__17() { 36130 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 36131 } 36132 var Elevation = false ? { 36133 name: "12ip69d", 36134 styles: "background:transparent;display:block;margin:0!important;pointer-events:none;position:absolute;will-change:box-shadow" 36135 } : { 36136 name: "1n58bsy-Elevation", 36137 styles: "background:transparent;display:block;margin:0!important;pointer-events:none;position:absolute;will-change:box-shadow;label:Elevation;", 36138 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLNEIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgRWxldmF0aW9uID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMCAhaW1wb3J0YW50O1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHR3aWxsLWNoYW5nZTogYm94LXNoYWRvdztcbmA7XG4iXX0= */", 36139 toString: _EMOTION_STRINGIFIED_CSS_ERROR__17 36140 }; 36141 36142 // packages/components/build-module/elevation/hook.js 36143 function getBoxShadow(value) { 36144 const boxShadowColor = `rgba(0, 0, 0, $value / 20})`; 36145 const boxShadow = `0 $value}px $value * 2}px 0 36146 $boxShadowColor}`; 36147 return boxShadow; 36148 } 36149 function useElevation(props) { 36150 const { 36151 active, 36152 borderRadius: borderRadius3 = "inherit", 36153 className: className2, 36154 focus: focus4, 36155 hover: hover2, 36156 isInteractive = false, 36157 offset: offset3 = 0, 36158 value = 0, 36159 ...otherProps 36160 } = useContextSystem(props, "Elevation"); 36161 const cx3 = useCx(); 36162 const classes = (0, import_element96.useMemo)(() => { 36163 let hoverValue = isValueDefined(hover2) ? hover2 : value * 2; 36164 let activeValue = isValueDefined(active) ? active : value / 2; 36165 if (!isInteractive) { 36166 hoverValue = isValueDefined(hover2) ? hover2 : void 0; 36167 activeValue = isValueDefined(active) ? active : void 0; 36168 } 36169 const transition = `box-shadow $config_values_default.transitionDuration} $config_values_default.transitionTimingFunction}`; 36170 const sx = {}; 36171 sx.Base = /* @__PURE__ */ css({ 36172 borderRadius: borderRadius3, 36173 bottom: offset3, 36174 boxShadow: getBoxShadow(value), 36175 opacity: config_values_default.elevationIntensity, 36176 left: offset3, 36177 right: offset3, 36178 top: offset3 36179 }, /* @__PURE__ */ css("@media not ( prefers-reduced-motion ){transition:", transition, ";}" + (false ? "" : ";label:sx-Base;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0VNIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgdXNlQ29udGV4dFN5c3RlbSB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vc3R5bGVzJztcbmltcG9ydCB7IENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB7IGlzVmFsdWVEZWZpbmVkIH0gZnJvbSAnLi4vdXRpbHMvdmFsdWVzJztcbmltcG9ydCB0eXBlIHsgRWxldmF0aW9uUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJveFNoYWRvdyggdmFsdWU6IG51bWJlciApIHtcblx0Y29uc3QgYm94U2hhZG93Q29sb3IgPSBgcmdiYSgwLCAwLCAwLCAkeyB2YWx1ZSAvIDIwIH0pYDtcblx0Y29uc3QgYm94U2hhZG93ID0gYDAgJHsgdmFsdWUgfXB4ICR7IHZhbHVlICogMiB9cHggMFxuXHQkeyBib3hTaGFkb3dDb2xvciB9YDtcblxuXHRyZXR1cm4gYm94U2hhZG93O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlRWxldmF0aW9uKFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IEVsZXZhdGlvblByb3BzLCAnZGl2JyA+XG4pIHtcblx0Y29uc3Qge1xuXHRcdGFjdGl2ZSxcblx0XHRib3JkZXJSYWRpdXMgPSAnaW5oZXJpdCcsXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGZvY3VzLFxuXHRcdGhvdmVyLFxuXHRcdGlzSW50ZXJhY3RpdmUgPSBmYWxzZSxcblx0XHRvZmZzZXQgPSAwLFxuXHRcdHZhbHVlID0gMCxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ0VsZXZhdGlvbicgKTtcblxuXHRjb25zdCBjeCA9IHVzZUN4KCk7XG5cblx0Y29uc3QgY2xhc3NlcyA9IHVzZU1lbW8oICgpID0+IHtcblx0XHRsZXQgaG92ZXJWYWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkID0gaXNWYWx1ZURlZmluZWQoIGhvdmVyIClcblx0XHRcdD8gaG92ZXJcblx0XHRcdDogdmFsdWUgKiAyO1xuXHRcdGxldCBhY3RpdmVWYWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkID0gaXNWYWx1ZURlZmluZWQoIGFjdGl2ZSApXG5cdFx0XHQ/IGFjdGl2ZVxuXHRcdFx0OiB2YWx1ZSAvIDI7XG5cblx0XHRpZiAoICEgaXNJbnRlcmFjdGl2ZSApIHtcblx0XHRcdGhvdmVyVmFsdWUgPSBpc1ZhbHVlRGVmaW5lZCggaG92ZXIgKSA/IGhvdmVyIDogdW5kZWZpbmVkO1xuXHRcdFx0YWN0aXZlVmFsdWUgPSBpc1ZhbHVlRGVmaW5lZCggYWN0aXZlICkgPyBhY3RpdmUgOiB1bmRlZmluZWQ7XG5cdFx0fVxuXG5cdFx0Y29uc3QgdHJhbnNpdGlvbiA9IGBib3gtc2hhZG93ICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb24gfSAkeyBDT05GSUcudHJhbnNpdGlvblRpbWluZ0Z1bmN0aW9uIH1gO1xuXG5cdFx0Y29uc3Qgc3g6IHtcblx0XHRcdEJhc2U/OiBTZXJpYWxpemVkU3R5bGVzO1xuXHRcdFx0aG92ZXI/OiBTZXJpYWxpemVkU3R5bGVzO1xuXHRcdFx0YWN0aXZlPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGZvY3VzPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHR9ID0ge307XG5cblx0XHRzeC5CYXNlID0gY3NzKFxuXHRcdFx0e1xuXHRcdFx0XHRib3JkZXJSYWRpdXMsXG5cdFx0XHRcdGJvdHRvbTogb2Zmc2V0LFxuXHRcdFx0XHRib3hTaGFkb3c6IGdldEJveFNoYWRvdyggdmFsdWUgKSxcblx0XHRcdFx0b3BhY2l0eTogQ09ORklHLmVsZXZhdGlvbkludGVuc2l0eSxcblx0XHRcdFx0bGVmdDogb2Zmc2V0LFxuXHRcdFx0XHRyaWdodDogb2Zmc2V0LFxuXHRcdFx0XHR0b3A6IG9mZnNldCxcblx0XHRcdH0sXG5cdFx0XHRjc3NgXG5cdFx0XHRcdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdFx0XHRcdHRyYW5zaXRpb246ICR7IHRyYW5zaXRpb24gfTtcblx0XHRcdFx0fVxuXHRcdFx0YFxuXHRcdCk7XG5cblx0XHRpZiAoIGlzVmFsdWVEZWZpbmVkKCBob3ZlclZhbHVlICkgKSB7XG5cdFx0XHRzeC5ob3ZlciA9IGNzc2Bcblx0XHRcdFx0Kjpob3ZlciA+ICYge1xuXHRcdFx0XHRcdGJveC1zaGFkb3c6ICR7IGdldEJveFNoYWRvdyggaG92ZXJWYWx1ZSApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggYWN0aXZlVmFsdWUgKSApIHtcblx0XHRcdHN4LmFjdGl2ZSA9IGNzc2Bcblx0XHRcdFx0KjphY3RpdmUgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGFjdGl2ZVZhbHVlICkgfTtcblx0XHRcdFx0fVxuXHRcdFx0YDtcblx0XHR9XG5cblx0XHRpZiAoIGlzVmFsdWVEZWZpbmVkKCBmb2N1cyApICkge1xuXHRcdFx0c3guZm9jdXMgPSBjc3NgXG5cdFx0XHRcdCo6Zm9jdXMgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGZvY3VzICkgfTtcblx0XHRcdFx0fVxuXHRcdFx0YDtcblx0XHR9XG5cblx0XHRyZXR1cm4gY3goXG5cdFx0XHRzdHlsZXMuRWxldmF0aW9uLFxuXHRcdFx0c3guQmFzZSxcblx0XHRcdHN4LmhvdmVyLFxuXHRcdFx0c3guZm9jdXMsXG5cdFx0XHRzeC5hY3RpdmUsXG5cdFx0XHRjbGFzc05hbWVcblx0XHQpO1xuXHR9LCBbXG5cdFx0YWN0aXZlLFxuXHRcdGJvcmRlclJhZGl1cyxcblx0XHRjbGFzc05hbWUsXG5cdFx0Y3gsXG5cdFx0Zm9jdXMsXG5cdFx0aG92ZXIsXG5cdFx0aXNJbnRlcmFjdGl2ZSxcblx0XHRvZmZzZXQsXG5cdFx0dmFsdWUsXG5cdF0gKTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMsICdhcmlhLWhpZGRlbic6IHRydWUgfTtcbn1cbiJdfQ== */"), false ? "" : ";label:sx-Base;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUVZIiwiZmlsZSI6Imhvb2sudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFNlcmlhbGl6ZWRTdHlsZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAnQHdvcmRwcmVzcy9lbGVtZW50JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBXb3JkUHJlc3NDb21wb25lbnRQcm9wcyB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0IHsgdXNlQ29udGV4dFN5c3RlbSB9IGZyb20gJy4uL2NvbnRleHQnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vc3R5bGVzJztcbmltcG9ydCB7IENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHVzZUN4IH0gZnJvbSAnLi4vdXRpbHMvaG9va3MvdXNlLWN4JztcbmltcG9ydCB7IGlzVmFsdWVEZWZpbmVkIH0gZnJvbSAnLi4vdXRpbHMvdmFsdWVzJztcbmltcG9ydCB0eXBlIHsgRWxldmF0aW9uUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJveFNoYWRvdyggdmFsdWU6IG51bWJlciApIHtcblx0Y29uc3QgYm94U2hhZG93Q29sb3IgPSBgcmdiYSgwLCAwLCAwLCAkeyB2YWx1ZSAvIDIwIH0pYDtcblx0Y29uc3QgYm94U2hhZG93ID0gYDAgJHsgdmFsdWUgfXB4ICR7IHZhbHVlICogMiB9cHggMFxuXHQkeyBib3hTaGFkb3dDb2xvciB9YDtcblxuXHRyZXR1cm4gYm94U2hhZG93O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlRWxldmF0aW9uKFxuXHRwcm9wczogV29yZFByZXNzQ29tcG9uZW50UHJvcHM8IEVsZXZhdGlvblByb3BzLCAnZGl2JyA+XG4pIHtcblx0Y29uc3Qge1xuXHRcdGFjdGl2ZSxcblx0XHRib3JkZXJSYWRpdXMgPSAnaW5oZXJpdCcsXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGZvY3VzLFxuXHRcdGhvdmVyLFxuXHRcdGlzSW50ZXJhY3RpdmUgPSBmYWxzZSxcblx0XHRvZmZzZXQgPSAwLFxuXHRcdHZhbHVlID0gMCxcblx0XHQuLi5vdGhlclByb3BzXG5cdH0gPSB1c2VDb250ZXh0U3lzdGVtKCBwcm9wcywgJ0VsZXZhdGlvbicgKTtcblxuXHRjb25zdCBjeCA9IHVzZUN4KCk7XG5cblx0Y29uc3QgY2xhc3NlcyA9IHVzZU1lbW8oICgpID0+IHtcblx0XHRsZXQgaG92ZXJWYWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkID0gaXNWYWx1ZURlZmluZWQoIGhvdmVyIClcblx0XHRcdD8gaG92ZXJcblx0XHRcdDogdmFsdWUgKiAyO1xuXHRcdGxldCBhY3RpdmVWYWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkID0gaXNWYWx1ZURlZmluZWQoIGFjdGl2ZSApXG5cdFx0XHQ/IGFjdGl2ZVxuXHRcdFx0OiB2YWx1ZSAvIDI7XG5cblx0XHRpZiAoICEgaXNJbnRlcmFjdGl2ZSApIHtcblx0XHRcdGhvdmVyVmFsdWUgPSBpc1ZhbHVlRGVmaW5lZCggaG92ZXIgKSA/IGhvdmVyIDogdW5kZWZpbmVkO1xuXHRcdFx0YWN0aXZlVmFsdWUgPSBpc1ZhbHVlRGVmaW5lZCggYWN0aXZlICkgPyBhY3RpdmUgOiB1bmRlZmluZWQ7XG5cdFx0fVxuXG5cdFx0Y29uc3QgdHJhbnNpdGlvbiA9IGBib3gtc2hhZG93ICR7IENPTkZJRy50cmFuc2l0aW9uRHVyYXRpb24gfSAkeyBDT05GSUcudHJhbnNpdGlvblRpbWluZ0Z1bmN0aW9uIH1gO1xuXG5cdFx0Y29uc3Qgc3g6IHtcblx0XHRcdEJhc2U/OiBTZXJpYWxpemVkU3R5bGVzO1xuXHRcdFx0aG92ZXI/OiBTZXJpYWxpemVkU3R5bGVzO1xuXHRcdFx0YWN0aXZlPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGZvY3VzPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHR9ID0ge307XG5cblx0XHRzeC5CYXNlID0gY3NzKFxuXHRcdFx0e1xuXHRcdFx0XHRib3JkZXJSYWRpdXMsXG5cdFx0XHRcdGJvdHRvbTogb2Zmc2V0LFxuXHRcdFx0XHRib3hTaGFkb3c6IGdldEJveFNoYWRvdyggdmFsdWUgKSxcblx0XHRcdFx0b3BhY2l0eTogQ09ORklHLmVsZXZhdGlvbkludGVuc2l0eSxcblx0XHRcdFx0bGVmdDogb2Zmc2V0LFxuXHRcdFx0XHRyaWdodDogb2Zmc2V0LFxuXHRcdFx0XHR0b3A6IG9mZnNldCxcblx0XHRcdH0sXG5cdFx0XHRjc3NgXG5cdFx0XHRcdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdFx0XHRcdHRyYW5zaXRpb246ICR7IHRyYW5zaXRpb24gfTtcblx0XHRcdFx0fVxuXHRcdFx0YFxuXHRcdCk7XG5cblx0XHRpZiAoIGlzVmFsdWVEZWZpbmVkKCBob3ZlclZhbHVlICkgKSB7XG5cdFx0XHRzeC5ob3ZlciA9IGNzc2Bcblx0XHRcdFx0Kjpob3ZlciA+ICYge1xuXHRcdFx0XHRcdGJveC1zaGFkb3c6ICR7IGdldEJveFNoYWRvdyggaG92ZXJWYWx1ZSApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggYWN0aXZlVmFsdWUgKSApIHtcblx0XHRcdHN4LmFjdGl2ZSA9IGNzc2Bcblx0XHRcdFx0KjphY3RpdmUgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGFjdGl2ZVZhbHVlICkgfTtcblx0XHRcdFx0fVxuXHRcdFx0YDtcblx0XHR9XG5cblx0XHRpZiAoIGlzVmFsdWVEZWZpbmVkKCBmb2N1cyApICkge1xuXHRcdFx0c3guZm9jdXMgPSBjc3NgXG5cdFx0XHRcdCo6Zm9jdXMgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGZvY3VzICkgfTtcblx0XHRcdFx0fVxuXHRcdFx0YDtcblx0XHR9XG5cblx0XHRyZXR1cm4gY3goXG5cdFx0XHRzdHlsZXMuRWxldmF0aW9uLFxuXHRcdFx0c3guQmFzZSxcblx0XHRcdHN4LmhvdmVyLFxuXHRcdFx0c3guZm9jdXMsXG5cdFx0XHRzeC5hY3RpdmUsXG5cdFx0XHRjbGFzc05hbWVcblx0XHQpO1xuXHR9LCBbXG5cdFx0YWN0aXZlLFxuXHRcdGJvcmRlclJhZGl1cyxcblx0XHRjbGFzc05hbWUsXG5cdFx0Y3gsXG5cdFx0Zm9jdXMsXG5cdFx0aG92ZXIsXG5cdFx0aXNJbnRlcmFjdGl2ZSxcblx0XHRvZmZzZXQsXG5cdFx0dmFsdWUsXG5cdF0gKTtcblxuXHRyZXR1cm4geyAuLi5vdGhlclByb3BzLCBjbGFzc05hbWU6IGNsYXNzZXMsICdhcmlhLWhpZGRlbic6IHRydWUgfTtcbn1cbiJdfQ== */"); 36180 if (isValueDefined(hoverValue)) { 36181 sx.hover = /* @__PURE__ */ css("*:hover>&{box-shadow:", getBoxShadow(hoverValue), ";}" + (false ? "" : ";label:sx-hover;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUZpQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgeyBpc1ZhbHVlRGVmaW5lZCB9IGZyb20gJy4uL3V0aWxzL3ZhbHVlcyc7XG5pbXBvcnQgdHlwZSB7IEVsZXZhdGlvblByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3hTaGFkb3coIHZhbHVlOiBudW1iZXIgKSB7XG5cdGNvbnN0IGJveFNoYWRvd0NvbG9yID0gYHJnYmEoMCwgMCwgMCwgJHsgdmFsdWUgLyAyMCB9KWA7XG5cdGNvbnN0IGJveFNoYWRvdyA9IGAwICR7IHZhbHVlIH1weCAkeyB2YWx1ZSAqIDIgfXB4IDBcblx0JHsgYm94U2hhZG93Q29sb3IgfWA7XG5cblx0cmV0dXJuIGJveFNoYWRvdztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUVsZXZhdGlvbihcblx0cHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBFbGV2YXRpb25Qcm9wcywgJ2RpdicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhY3RpdmUsXG5cdFx0Ym9yZGVyUmFkaXVzID0gJ2luaGVyaXQnLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRmb2N1cyxcblx0XHRob3Zlcixcblx0XHRpc0ludGVyYWN0aXZlID0gZmFsc2UsXG5cdFx0b2Zmc2V0ID0gMCxcblx0XHR2YWx1ZSA9IDAsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdFbGV2YXRpb24nICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0bGV0IGhvdmVyVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBob3ZlciApXG5cdFx0XHQ/IGhvdmVyXG5cdFx0XHQ6IHZhbHVlICogMjtcblx0XHRsZXQgYWN0aXZlVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBhY3RpdmUgKVxuXHRcdFx0PyBhY3RpdmVcblx0XHRcdDogdmFsdWUgLyAyO1xuXG5cdFx0aWYgKCAhIGlzSW50ZXJhY3RpdmUgKSB7XG5cdFx0XHRob3ZlclZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGhvdmVyICkgPyBob3ZlciA6IHVuZGVmaW5lZDtcblx0XHRcdGFjdGl2ZVZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGFjdGl2ZSApID8gYWN0aXZlIDogdW5kZWZpbmVkO1xuXHRcdH1cblxuXHRcdGNvbnN0IHRyYW5zaXRpb24gPSBgYm94LXNoYWRvdyAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uIH0gJHsgQ09ORklHLnRyYW5zaXRpb25UaW1pbmdGdW5jdGlvbiB9YDtcblxuXHRcdGNvbnN0IHN4OiB7XG5cdFx0XHRCYXNlPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGhvdmVyPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGFjdGl2ZT86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0XHRmb2N1cz86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0fSA9IHt9O1xuXG5cdFx0c3guQmFzZSA9IGNzcyhcblx0XHRcdHtcblx0XHRcdFx0Ym9yZGVyUmFkaXVzLFxuXHRcdFx0XHRib3R0b206IG9mZnNldCxcblx0XHRcdFx0Ym94U2hhZG93OiBnZXRCb3hTaGFkb3coIHZhbHVlICksXG5cdFx0XHRcdG9wYWNpdHk6IENPTkZJRy5lbGV2YXRpb25JbnRlbnNpdHksXG5cdFx0XHRcdGxlZnQ6IG9mZnNldCxcblx0XHRcdFx0cmlnaHQ6IG9mZnNldCxcblx0XHRcdFx0dG9wOiBvZmZzZXQsXG5cdFx0XHR9LFxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRcdFx0XHR0cmFuc2l0aW9uOiAkeyB0cmFuc2l0aW9uIH07XG5cdFx0XHRcdH1cblx0XHRcdGBcblx0XHQpO1xuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggaG92ZXJWYWx1ZSApICkge1xuXHRcdFx0c3guaG92ZXIgPSBjc3NgXG5cdFx0XHRcdCo6aG92ZXIgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGhvdmVyVmFsdWUgKSB9O1xuXHRcdFx0XHR9XG5cdFx0XHRgO1xuXHRcdH1cblxuXHRcdGlmICggaXNWYWx1ZURlZmluZWQoIGFjdGl2ZVZhbHVlICkgKSB7XG5cdFx0XHRzeC5hY3RpdmUgPSBjc3NgXG5cdFx0XHRcdCo6YWN0aXZlID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBhY3RpdmVWYWx1ZSApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggZm9jdXMgKSApIHtcblx0XHRcdHN4LmZvY3VzID0gY3NzYFxuXHRcdFx0XHQqOmZvY3VzID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBmb2N1cyApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0cmV0dXJuIGN4KFxuXHRcdFx0c3R5bGVzLkVsZXZhdGlvbixcblx0XHRcdHN4LkJhc2UsXG5cdFx0XHRzeC5ob3Zlcixcblx0XHRcdHN4LmZvY3VzLFxuXHRcdFx0c3guYWN0aXZlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFjdGl2ZSxcblx0XHRib3JkZXJSYWRpdXMsXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGN4LFxuXHRcdGZvY3VzLFxuXHRcdGhvdmVyLFxuXHRcdGlzSW50ZXJhY3RpdmUsXG5cdFx0b2Zmc2V0LFxuXHRcdHZhbHVlLFxuXHRdICk7XG5cblx0cmV0dXJuIHsgLi4ub3RoZXJQcm9wcywgY2xhc3NOYW1lOiBjbGFzc2VzLCAnYXJpYS1oaWRkZW4nOiB0cnVlIH07XG59XG4iXX0= */"); 36182 } 36183 if (isValueDefined(activeValue)) { 36184 sx.active = /* @__PURE__ */ css("*:active>&{box-shadow:", getBoxShadow(activeValue), ";}" + (false ? "" : ";label:sx-active;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0ZrQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgeyBpc1ZhbHVlRGVmaW5lZCB9IGZyb20gJy4uL3V0aWxzL3ZhbHVlcyc7XG5pbXBvcnQgdHlwZSB7IEVsZXZhdGlvblByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3hTaGFkb3coIHZhbHVlOiBudW1iZXIgKSB7XG5cdGNvbnN0IGJveFNoYWRvd0NvbG9yID0gYHJnYmEoMCwgMCwgMCwgJHsgdmFsdWUgLyAyMCB9KWA7XG5cdGNvbnN0IGJveFNoYWRvdyA9IGAwICR7IHZhbHVlIH1weCAkeyB2YWx1ZSAqIDIgfXB4IDBcblx0JHsgYm94U2hhZG93Q29sb3IgfWA7XG5cblx0cmV0dXJuIGJveFNoYWRvdztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUVsZXZhdGlvbihcblx0cHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBFbGV2YXRpb25Qcm9wcywgJ2RpdicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhY3RpdmUsXG5cdFx0Ym9yZGVyUmFkaXVzID0gJ2luaGVyaXQnLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRmb2N1cyxcblx0XHRob3Zlcixcblx0XHRpc0ludGVyYWN0aXZlID0gZmFsc2UsXG5cdFx0b2Zmc2V0ID0gMCxcblx0XHR2YWx1ZSA9IDAsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdFbGV2YXRpb24nICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0bGV0IGhvdmVyVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBob3ZlciApXG5cdFx0XHQ/IGhvdmVyXG5cdFx0XHQ6IHZhbHVlICogMjtcblx0XHRsZXQgYWN0aXZlVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBhY3RpdmUgKVxuXHRcdFx0PyBhY3RpdmVcblx0XHRcdDogdmFsdWUgLyAyO1xuXG5cdFx0aWYgKCAhIGlzSW50ZXJhY3RpdmUgKSB7XG5cdFx0XHRob3ZlclZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGhvdmVyICkgPyBob3ZlciA6IHVuZGVmaW5lZDtcblx0XHRcdGFjdGl2ZVZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGFjdGl2ZSApID8gYWN0aXZlIDogdW5kZWZpbmVkO1xuXHRcdH1cblxuXHRcdGNvbnN0IHRyYW5zaXRpb24gPSBgYm94LXNoYWRvdyAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uIH0gJHsgQ09ORklHLnRyYW5zaXRpb25UaW1pbmdGdW5jdGlvbiB9YDtcblxuXHRcdGNvbnN0IHN4OiB7XG5cdFx0XHRCYXNlPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGhvdmVyPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGFjdGl2ZT86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0XHRmb2N1cz86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0fSA9IHt9O1xuXG5cdFx0c3guQmFzZSA9IGNzcyhcblx0XHRcdHtcblx0XHRcdFx0Ym9yZGVyUmFkaXVzLFxuXHRcdFx0XHRib3R0b206IG9mZnNldCxcblx0XHRcdFx0Ym94U2hhZG93OiBnZXRCb3hTaGFkb3coIHZhbHVlICksXG5cdFx0XHRcdG9wYWNpdHk6IENPTkZJRy5lbGV2YXRpb25JbnRlbnNpdHksXG5cdFx0XHRcdGxlZnQ6IG9mZnNldCxcblx0XHRcdFx0cmlnaHQ6IG9mZnNldCxcblx0XHRcdFx0dG9wOiBvZmZzZXQsXG5cdFx0XHR9LFxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRcdFx0XHR0cmFuc2l0aW9uOiAkeyB0cmFuc2l0aW9uIH07XG5cdFx0XHRcdH1cblx0XHRcdGBcblx0XHQpO1xuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggaG92ZXJWYWx1ZSApICkge1xuXHRcdFx0c3guaG92ZXIgPSBjc3NgXG5cdFx0XHRcdCo6aG92ZXIgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGhvdmVyVmFsdWUgKSB9O1xuXHRcdFx0XHR9XG5cdFx0XHRgO1xuXHRcdH1cblxuXHRcdGlmICggaXNWYWx1ZURlZmluZWQoIGFjdGl2ZVZhbHVlICkgKSB7XG5cdFx0XHRzeC5hY3RpdmUgPSBjc3NgXG5cdFx0XHRcdCo6YWN0aXZlID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBhY3RpdmVWYWx1ZSApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggZm9jdXMgKSApIHtcblx0XHRcdHN4LmZvY3VzID0gY3NzYFxuXHRcdFx0XHQqOmZvY3VzID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBmb2N1cyApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0cmV0dXJuIGN4KFxuXHRcdFx0c3R5bGVzLkVsZXZhdGlvbixcblx0XHRcdHN4LkJhc2UsXG5cdFx0XHRzeC5ob3Zlcixcblx0XHRcdHN4LmZvY3VzLFxuXHRcdFx0c3guYWN0aXZlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFjdGl2ZSxcblx0XHRib3JkZXJSYWRpdXMsXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGN4LFxuXHRcdGZvY3VzLFxuXHRcdGhvdmVyLFxuXHRcdGlzSW50ZXJhY3RpdmUsXG5cdFx0b2Zmc2V0LFxuXHRcdHZhbHVlLFxuXHRdICk7XG5cblx0cmV0dXJuIHsgLi4ub3RoZXJQcm9wcywgY2xhc3NOYW1lOiBjbGFzc2VzLCAnYXJpYS1oaWRkZW4nOiB0cnVlIH07XG59XG4iXX0= */"); 36185 } 36186 if (isValueDefined(focus4)) { 36187 sx.focus = /* @__PURE__ */ css("*:focus>&{box-shadow:", getBoxShadow(focus4), ";}" + (false ? "" : ";label:sx-focus;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhvb2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUdpQiIsImZpbGUiOiJob29rLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gJ0B3b3JkcHJlc3MvZWxlbWVudCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB0eXBlIHsgV29yZFByZXNzQ29tcG9uZW50UHJvcHMgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IHVzZUNvbnRleHRTeXN0ZW0gfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCAqIGFzIHN0eWxlcyBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgeyBpc1ZhbHVlRGVmaW5lZCB9IGZyb20gJy4uL3V0aWxzL3ZhbHVlcyc7XG5pbXBvcnQgdHlwZSB7IEVsZXZhdGlvblByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3hTaGFkb3coIHZhbHVlOiBudW1iZXIgKSB7XG5cdGNvbnN0IGJveFNoYWRvd0NvbG9yID0gYHJnYmEoMCwgMCwgMCwgJHsgdmFsdWUgLyAyMCB9KWA7XG5cdGNvbnN0IGJveFNoYWRvdyA9IGAwICR7IHZhbHVlIH1weCAkeyB2YWx1ZSAqIDIgfXB4IDBcblx0JHsgYm94U2hhZG93Q29sb3IgfWA7XG5cblx0cmV0dXJuIGJveFNoYWRvdztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZUVsZXZhdGlvbihcblx0cHJvcHM6IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzPCBFbGV2YXRpb25Qcm9wcywgJ2RpdicgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRhY3RpdmUsXG5cdFx0Ym9yZGVyUmFkaXVzID0gJ2luaGVyaXQnLFxuXHRcdGNsYXNzTmFtZSxcblx0XHRmb2N1cyxcblx0XHRob3Zlcixcblx0XHRpc0ludGVyYWN0aXZlID0gZmFsc2UsXG5cdFx0b2Zmc2V0ID0gMCxcblx0XHR2YWx1ZSA9IDAsXG5cdFx0Li4ub3RoZXJQcm9wc1xuXHR9ID0gdXNlQ29udGV4dFN5c3RlbSggcHJvcHMsICdFbGV2YXRpb24nICk7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGNsYXNzZXMgPSB1c2VNZW1vKCAoKSA9PiB7XG5cdFx0bGV0IGhvdmVyVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBob3ZlciApXG5cdFx0XHQ/IGhvdmVyXG5cdFx0XHQ6IHZhbHVlICogMjtcblx0XHRsZXQgYWN0aXZlVmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCA9IGlzVmFsdWVEZWZpbmVkKCBhY3RpdmUgKVxuXHRcdFx0PyBhY3RpdmVcblx0XHRcdDogdmFsdWUgLyAyO1xuXG5cdFx0aWYgKCAhIGlzSW50ZXJhY3RpdmUgKSB7XG5cdFx0XHRob3ZlclZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGhvdmVyICkgPyBob3ZlciA6IHVuZGVmaW5lZDtcblx0XHRcdGFjdGl2ZVZhbHVlID0gaXNWYWx1ZURlZmluZWQoIGFjdGl2ZSApID8gYWN0aXZlIDogdW5kZWZpbmVkO1xuXHRcdH1cblxuXHRcdGNvbnN0IHRyYW5zaXRpb24gPSBgYm94LXNoYWRvdyAkeyBDT05GSUcudHJhbnNpdGlvbkR1cmF0aW9uIH0gJHsgQ09ORklHLnRyYW5zaXRpb25UaW1pbmdGdW5jdGlvbiB9YDtcblxuXHRcdGNvbnN0IHN4OiB7XG5cdFx0XHRCYXNlPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGhvdmVyPzogU2VyaWFsaXplZFN0eWxlcztcblx0XHRcdGFjdGl2ZT86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0XHRmb2N1cz86IFNlcmlhbGl6ZWRTdHlsZXM7XG5cdFx0fSA9IHt9O1xuXG5cdFx0c3guQmFzZSA9IGNzcyhcblx0XHRcdHtcblx0XHRcdFx0Ym9yZGVyUmFkaXVzLFxuXHRcdFx0XHRib3R0b206IG9mZnNldCxcblx0XHRcdFx0Ym94U2hhZG93OiBnZXRCb3hTaGFkb3coIHZhbHVlICksXG5cdFx0XHRcdG9wYWNpdHk6IENPTkZJRy5lbGV2YXRpb25JbnRlbnNpdHksXG5cdFx0XHRcdGxlZnQ6IG9mZnNldCxcblx0XHRcdFx0cmlnaHQ6IG9mZnNldCxcblx0XHRcdFx0dG9wOiBvZmZzZXQsXG5cdFx0XHR9LFxuXHRcdFx0Y3NzYFxuXHRcdFx0XHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRcdFx0XHR0cmFuc2l0aW9uOiAkeyB0cmFuc2l0aW9uIH07XG5cdFx0XHRcdH1cblx0XHRcdGBcblx0XHQpO1xuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggaG92ZXJWYWx1ZSApICkge1xuXHRcdFx0c3guaG92ZXIgPSBjc3NgXG5cdFx0XHRcdCo6aG92ZXIgPiAmIHtcblx0XHRcdFx0XHRib3gtc2hhZG93OiAkeyBnZXRCb3hTaGFkb3coIGhvdmVyVmFsdWUgKSB9O1xuXHRcdFx0XHR9XG5cdFx0XHRgO1xuXHRcdH1cblxuXHRcdGlmICggaXNWYWx1ZURlZmluZWQoIGFjdGl2ZVZhbHVlICkgKSB7XG5cdFx0XHRzeC5hY3RpdmUgPSBjc3NgXG5cdFx0XHRcdCo6YWN0aXZlID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBhY3RpdmVWYWx1ZSApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0aWYgKCBpc1ZhbHVlRGVmaW5lZCggZm9jdXMgKSApIHtcblx0XHRcdHN4LmZvY3VzID0gY3NzYFxuXHRcdFx0XHQqOmZvY3VzID4gJiB7XG5cdFx0XHRcdFx0Ym94LXNoYWRvdzogJHsgZ2V0Qm94U2hhZG93KCBmb2N1cyApIH07XG5cdFx0XHRcdH1cblx0XHRcdGA7XG5cdFx0fVxuXG5cdFx0cmV0dXJuIGN4KFxuXHRcdFx0c3R5bGVzLkVsZXZhdGlvbixcblx0XHRcdHN4LkJhc2UsXG5cdFx0XHRzeC5ob3Zlcixcblx0XHRcdHN4LmZvY3VzLFxuXHRcdFx0c3guYWN0aXZlLFxuXHRcdFx0Y2xhc3NOYW1lXG5cdFx0KTtcblx0fSwgW1xuXHRcdGFjdGl2ZSxcblx0XHRib3JkZXJSYWRpdXMsXG5cdFx0Y2xhc3NOYW1lLFxuXHRcdGN4LFxuXHRcdGZvY3VzLFxuXHRcdGhvdmVyLFxuXHRcdGlzSW50ZXJhY3RpdmUsXG5cdFx0b2Zmc2V0LFxuXHRcdHZhbHVlLFxuXHRdICk7XG5cblx0cmV0dXJuIHsgLi4ub3RoZXJQcm9wcywgY2xhc3NOYW1lOiBjbGFzc2VzLCAnYXJpYS1oaWRkZW4nOiB0cnVlIH07XG59XG4iXX0= */"); 36188 } 36189 return cx3(Elevation, sx.Base, sx.hover, sx.focus, sx.active, className2); 36190 }, [active, borderRadius3, className2, cx3, focus4, hover2, isInteractive, offset3, value]); 36191 return { 36192 ...otherProps, 36193 className: classes, 36194 "aria-hidden": true 36195 }; 36196 } 36197 36198 // packages/components/build-module/elevation/component.js 36199 var import_jsx_runtime160 = __toESM(require_jsx_runtime()); 36200 function UnconnectedElevation(props, forwardedRef) { 36201 const elevationProps = useElevation(props); 36202 return /* @__PURE__ */ (0, import_jsx_runtime160.jsx)(component_default, { 36203 ...elevationProps, 36204 ref: forwardedRef 36205 }); 36206 } 36207 var Elevation2 = contextConnect(UnconnectedElevation, "Elevation"); 36208 var component_default25 = Elevation2; 36209 36210 // packages/components/build-module/card/styles.js 36211 function _EMOTION_STRINGIFIED_CSS_ERROR__18() { 36212 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 36213 } 36214 var adjustedBorderRadius = `calc($config_values_default.radiusLarge} - 1px)`; 36215 var Card = /* @__PURE__ */ css("box-shadow:0 0 0 1px ", config_values_default.surfaceBorderColor, ";outline:none;" + (false ? "" : ";label:Card;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQnVCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */"); 36216 var Header = false ? { 36217 name: "1showjb", 36218 styles: "border-bottom:1px solid;box-sizing:border-box;&:last-child{border-bottom:none;}" 36219 } : { 36220 name: "euqiwd-Header", 36221 styles: "border-bottom:1px solid;box-sizing:border-box;&:last-child{border-bottom:none;};label:Header;", 36222 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnlCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36223 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36224 }; 36225 var Footer = false ? { 36226 name: "14n5oej", 36227 styles: "border-top:1px solid;box-sizing:border-box;&:first-of-type{border-top:none;}" 36228 } : { 36229 name: "1rianq6-Footer", 36230 styles: "border-top:1px solid;box-sizing:border-box;&:first-of-type{border-top:none;};label:Footer;", 36231 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4QnlCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36232 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36233 }; 36234 var Content = false ? { 36235 name: "13udsys", 36236 styles: "height:100%" 36237 } : { 36238 name: "1ruapvy-Content", 36239 styles: "height:100%;label:Content;", 36240 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QzBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36241 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36242 }; 36243 var Body = false ? { 36244 name: "6ywzd", 36245 styles: "box-sizing:border-box;height:auto;max-height:100%" 36246 } : { 36247 name: "1klm29z-Body", 36248 styles: "box-sizing:border-box;height:auto;max-height:100%;label:Body;", 36249 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ3VCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36250 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36251 }; 36252 var Media = false ? { 36253 name: "dq805e", 36254 styles: "box-sizing:border-box;overflow:hidden;&>img,&>iframe{display:block;height:auto;max-width:100%;width:100%;}" 36255 } : { 36256 name: "6f4wyb-Media", 36257 styles: "box-sizing:border-box;overflow:hidden;&>img,&>iframe{display:block;height:auto;max-width:100%;width:100%;};label:Media;", 36258 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRHdCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36259 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36260 }; 36261 var Divider = false ? { 36262 name: "c990dr", 36263 styles: "box-sizing:border-box;display:block;width:100%" 36264 } : { 36265 name: "c5mt54-Divider", 36266 styles: "box-sizing:border-box;display:block;width:100%;label:Divider;", 36267 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RDBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36268 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36269 }; 36270 var borderRadius = /* @__PURE__ */ css("&:first-of-type{border-top-left-radius:", adjustedBorderRadius, ";border-top-right-radius:", adjustedBorderRadius, ";}&:last-of-type{border-bottom-left-radius:", adjustedBorderRadius, ";border-bottom-right-radius:", adjustedBorderRadius, ";}" + (false ? "" : ";label:borderRadius;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRStCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */"); 36271 var borderColor = /* @__PURE__ */ css("border-color:", config_values_default.colorDivider, ";" + (false ? "" : ";label:borderColor;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRjhCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */"); 36272 var boxShadowless = false ? { 36273 name: "1t90u8d", 36274 styles: "box-shadow:none" 36275 } : { 36276 name: "14zofrl-boxShadowless", 36277 styles: "box-shadow:none;label:boxShadowless;", 36278 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRmdDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36279 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36280 }; 36281 var borderless = false ? { 36282 name: "1e1ncky", 36283 styles: "border:none" 36284 } : { 36285 name: "kyy9w8-borderless", 36286 styles: "border:none;label:borderless;", 36287 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RjZCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */", 36288 toString: _EMOTION_STRINGIFIED_CSS_ERROR__18 36289 }; 36290 var rounded = /* @__PURE__ */ css("border-radius:", adjustedBorderRadius, ";" + (false ? "" : ";label:rounded;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RjBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */"); 36291 var shady = /* @__PURE__ */ css("background-color:", COLORS.ui.backgroundDisabled, ";" + (false ? "" : ";label:shady;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnR3dCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbi8vIFNpbmNlIHRoZSBib3JkZXIgZm9yIGBDYXJkYCBpcyByZW5kZXJlZCB2aWEgdGhlIGBib3gtc2hhZG93YCBwcm9wZXJ0eVxuLy8gKGFzIG9wcG9zZWQgdG8gdGhlIGBib3JkZXJgIHByb3BlcnR5KSwgdGhlIHZhbHVlIG9mIHRoZSBib3JkZXIgcmFkaXVzIG5lZWRzXG4vLyB0byBiZSBhZGp1c3RlZCBieSByZW1vdmluZyAxcHggKHRoaXMgaXMgYmVjYXVzZSB0aGUgYGJveC1zaGFkb3dgIHJlbmRlcnNcbi8vIGFzIGFuIFwib3V0ZXIgcmFkaXVzXCIpLlxuY29uc3QgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgPSBgY2FsYygkeyBDT05GSUcucmFkaXVzTGFyZ2UgfSAtIDFweClgO1xuXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgMXB4ICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0b3V0bGluZTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXIgPSBjc3NgXG5cdGJvcmRlci1ib3R0b206IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmxhc3QtY2hpbGQge1xuXHRcdGJvcmRlci1ib3R0b206IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBGb290ZXIgPSBjc3NgXG5cdGJvcmRlci10b3A6IDFweCBzb2xpZDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3A6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQm9keSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiBhdXRvO1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuXG5cdCYgPiBpbWcsXG5cdCYgPiBpZnJhbWUge1xuXHRcdGRpc3BsYXk6IGJsb2NrO1xuXHRcdGhlaWdodDogYXV0bztcblx0XHRtYXgtd2lkdGg6IDEwMCU7XG5cdFx0d2lkdGg6IDEwMCU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBibG9jaztcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyUmFkaXVzID0gY3NzYFxuXHQmOmZpcnN0LW9mLXR5cGUge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGFkanVzdGVkQm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQmOmxhc3Qtb2YtdHlwZSB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYWRqdXN0ZWRCb3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlckNvbG9yID0gY3NzYFxuXHRib3JkZXItY29sb3I6ICR7IENPTkZJRy5jb2xvckRpdmlkZXIgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3hTaGFkb3dsZXNzID0gY3NzYFxuXHRib3gtc2hhZG93OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmxlc3MgPSBjc3NgXG5cdGJvcmRlcjogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBhZGp1c3RlZEJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNoYWR5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkuYmFja2dyb3VuZERpc2FibGVkIH07XG5gO1xuIl19 */"); 36292 36293 // packages/components/build-module/card/card/hook.js 36294 var import_deprecated11 = __toESM(require_deprecated()); 36295 var import_element98 = __toESM(require_element()); 36296 36297 // packages/components/build-module/surface/hook.js 36298 var import_element97 = __toESM(require_element()); 36299 36300 // packages/components/build-module/surface/styles.js 36301 var Surface = /* @__PURE__ */ css("background-color:", config_values_default.surfaceColor, ";color:", COLORS.gray[900], ";position:relative;" + (false ? "" : ";label:Surface;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXMEIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3VyZmFjZVZhcmlhbnQsIFN1cmZhY2VQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgU3VyZmFjZSA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VDb2xvciB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBiYWNrZ3JvdW5kID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJvcmRlcnMoIHtcblx0Ym9yZGVyQm90dG9tLFxuXHRib3JkZXJMZWZ0LFxuXHRib3JkZXJSaWdodCxcblx0Ym9yZGVyVG9wLFxufTogUGljazxcblx0U3VyZmFjZVByb3BzLFxuXHQnYm9yZGVyQm90dG9tJyB8ICdib3JkZXJMZWZ0JyB8ICdib3JkZXJSaWdodCcgfCAnYm9yZGVyVG9wJ1xuPiApIHtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBgMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfWA7XG5cblx0cmV0dXJuIGNzcygge1xuXHRcdGJvcmRlckJvdHRvbTogYm9yZGVyQm90dG9tID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdFx0Ym9yZGVyTGVmdDogYm9yZGVyTGVmdCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclJpZ2h0OiBib3JkZXJSaWdodCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclRvcDogYm9yZGVyVG9wID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdH0gKTtcbn1cblxuZXhwb3J0IGNvbnN0IHByaW1hcnkgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IHNlY29uZGFyeSA9IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kVGludENvbG9yIH07XG5gO1xuXG5leHBvcnQgY29uc3QgdGVydGlhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRlcnRpYXJ5Q29sb3IgfTtcbmA7XG5cbmNvbnN0IGN1c3RvbUJhY2tncm91bmRTaXplID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+XG5cdFsgc3VyZmFjZUJhY2tncm91bmRTaXplLCBzdXJmYWNlQmFja2dyb3VuZFNpemUgXS5qb2luKCAnICcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDEgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdCc5MGRlZycsXG5cdFx0WyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciwgc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkIF0uam9pbihcblx0XHRcdCcgJ1xuXHRcdCksXG5cdFx0J3RyYW5zcGFyZW50IDElJyxcblx0XS5qb2luKCAnLCcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDIgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmcgKSA9PlxuXHRbXG5cdFx0YGxpbmVhci1ncmFkaWVudCggJHsgZG90dGVkQmFja2dyb3VuZDEoXG5cdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHQpIH0gKSBjZW50ZXJgLFxuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQyKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRDT05GSUcuc3VyZmFjZUJvcmRlckJvbGRDb2xvcixcblx0XS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldERvdHRlZCA9IChcblx0c3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nXG4pID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgZG90dGVkQmFja2dyb3VuZENvbWJpbmVkKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgKSB9O1xuXHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuYDtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQxID0gW1xuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQyID0gW1xuXHQnOTBkZWcnLFxuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmRDb21iaW5lZCA9IFtcblx0YGxpbmVhci1ncmFkaWVudCggJHsgZ3JpZEJhY2tncm91bmQxIH0gKWAsXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMiB9IClgLFxuXS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldEdyaWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yIH07XG5cdFx0YmFja2dyb3VuZC1pbWFnZTogJHsgZ3JpZEJhY2tncm91bmRDb21iaW5lZCB9O1xuXHRcdGJhY2tncm91bmQtc2l6ZTogJHsgY3VzdG9tQmFja2dyb3VuZFNpemUoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VmFyaWFudCA9IChcblx0dmFyaWFudDogU3VyZmFjZVZhcmlhbnQsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiB7XG5cdHN3aXRjaCAoIHZhcmlhbnQgKSB7XG5cdFx0Y2FzZSAnZG90dGVkJzoge1xuXHRcdFx0cmV0dXJuIGdldERvdHRlZChcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplLFxuXHRcdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHRcdCk7XG5cdFx0fVxuXHRcdGNhc2UgJ2dyaWQnOiB7XG5cdFx0XHRyZXR1cm4gZ2V0R3JpZCggc3VyZmFjZUJhY2tncm91bmRTaXplICk7XG5cdFx0fVxuXHRcdGNhc2UgJ3ByaW1hcnknOiB7XG5cdFx0XHRyZXR1cm4gcHJpbWFyeTtcblx0XHR9XG5cdFx0Y2FzZSAnc2Vjb25kYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHNlY29uZGFyeTtcblx0XHR9XG5cdFx0Y2FzZSAndGVydGlhcnknOiB7XG5cdFx0XHRyZXR1cm4gdGVydGlhcnk7XG5cdFx0fVxuXHR9XG59O1xuIl19 */"); 36302 var background = /* @__PURE__ */ css("background-color:", config_values_default.surfaceBackgroundColor, ";" + (false ? "" : ";label:background;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQjZCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFN1cmZhY2VWYXJpYW50LCBTdXJmYWNlUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IFN1cmZhY2UgPSBjc3NgXG5cdGJhY2tncm91bmQtY29sb3I6ICR7IENPTkZJRy5zdXJmYWNlQ29sb3IgfTtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFja2dyb3VuZCA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3JkZXJzKCB7XG5cdGJvcmRlckJvdHRvbSxcblx0Ym9yZGVyTGVmdCxcblx0Ym9yZGVyUmlnaHQsXG5cdGJvcmRlclRvcCxcbn06IFBpY2s8XG5cdFN1cmZhY2VQcm9wcyxcblx0J2JvcmRlckJvdHRvbScgfCAnYm9yZGVyTGVmdCcgfCAnYm9yZGVyUmlnaHQnIHwgJ2JvcmRlclRvcCdcbj4gKSB7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gYDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH1gO1xuXG5cdHJldHVybiBjc3MoIHtcblx0XHRib3JkZXJCb3R0b206IGJvcmRlckJvdHRvbSA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlckxlZnQ6IGJvcmRlckxlZnQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJSaWdodDogYm9yZGVyUmlnaHQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJUb3A6IGJvcmRlclRvcCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHR9ICk7XG59XG5cbmV4cG9ydCBjb25zdCBwcmltYXJ5ID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCBzZWNvbmRhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRpbnRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHRlcnRpYXJ5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRUZXJ0aWFyeUNvbG9yIH07XG5gO1xuXG5jb25zdCBjdXN0b21CYWNrZ3JvdW5kU2l6ZSA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcgKSA9PlxuXHRbIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSwgc3VyZmFjZUJhY2tncm91bmRTaXplIF0uam9pbiggJyAnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQxID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHQnOTBkZWcnLFxuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQyID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHRbIENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yLCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgXS5qb2luKFxuXHRcdFx0JyAnXG5cdFx0KSxcblx0XHQndHJhbnNwYXJlbnQgMSUnLFxuXHRdLmpvaW4oICcsJyApO1xuXG5jb25zdCBkb3R0ZWRCYWNrZ3JvdW5kQ29tYmluZWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQxKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRgbGluZWFyLWdyYWRpZW50KCAkeyBkb3R0ZWRCYWNrZ3JvdW5kMihcblx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZFxuXHRcdCkgfSApIGNlbnRlcmAsXG5cdFx0Q09ORklHLnN1cmZhY2VCb3JkZXJCb2xkQ29sb3IsXG5cdF0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXREb3R0ZWQgPSAoXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkICkgfTtcblx0YmFja2dyb3VuZC1zaXplOiAkeyBjdXN0b21CYWNrZ3JvdW5kU2l6ZSggc3VyZmFjZUJhY2tncm91bmRTaXplICkgfTtcbmA7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMSA9IFtcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMiA9IFtcblx0JzkwZGVnJyxcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgPSBbXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMSB9IClgLFxuXHRgbGluZWFyLWdyYWRpZW50KCAkeyBncmlkQmFja2dyb3VuZDIgfSApYCxcbl0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXRHcmlkID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuXHRcdGJhY2tncm91bmQtaW1hZ2U6ICR7IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgfTtcblx0XHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFZhcmlhbnQgPSAoXG5cdHZhcmlhbnQ6IFN1cmZhY2VWYXJpYW50LFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyxcblx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmdcbikgPT4ge1xuXHRzd2l0Y2ggKCB2YXJpYW50ICkge1xuXHRcdGNhc2UgJ2RvdHRlZCc6IHtcblx0XHRcdHJldHVybiBnZXREb3R0ZWQoXG5cdFx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSxcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0XHQpO1xuXHRcdH1cblx0XHRjYXNlICdncmlkJzoge1xuXHRcdFx0cmV0dXJuIGdldEdyaWQoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApO1xuXHRcdH1cblx0XHRjYXNlICdwcmltYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHByaW1hcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3NlY29uZGFyeSc6IHtcblx0XHRcdHJldHVybiBzZWNvbmRhcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3RlcnRpYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHRlcnRpYXJ5O1xuXHRcdH1cblx0fVxufTtcbiJdfQ== */"); 36303 function getBorders({ 36304 borderBottom, 36305 borderLeft, 36306 borderRight, 36307 borderTop 36308 }) { 36309 const borderStyle = `1px solid $config_values_default.surfaceBorderColor}`; 36310 return /* @__PURE__ */ css({ 36311 borderBottom: borderBottom ? borderStyle : void 0, 36312 borderLeft: borderLeft ? borderStyle : void 0, 36313 borderRight: borderRight ? borderStyle : void 0, 36314 borderTop: borderTop ? borderStyle : void 0 36315 }, false ? "" : ";label:getBorders;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ1EiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3VyZmFjZVZhcmlhbnQsIFN1cmZhY2VQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgU3VyZmFjZSA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VDb2xvciB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBiYWNrZ3JvdW5kID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJvcmRlcnMoIHtcblx0Ym9yZGVyQm90dG9tLFxuXHRib3JkZXJMZWZ0LFxuXHRib3JkZXJSaWdodCxcblx0Ym9yZGVyVG9wLFxufTogUGljazxcblx0U3VyZmFjZVByb3BzLFxuXHQnYm9yZGVyQm90dG9tJyB8ICdib3JkZXJMZWZ0JyB8ICdib3JkZXJSaWdodCcgfCAnYm9yZGVyVG9wJ1xuPiApIHtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBgMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfWA7XG5cblx0cmV0dXJuIGNzcygge1xuXHRcdGJvcmRlckJvdHRvbTogYm9yZGVyQm90dG9tID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdFx0Ym9yZGVyTGVmdDogYm9yZGVyTGVmdCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclJpZ2h0OiBib3JkZXJSaWdodCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclRvcDogYm9yZGVyVG9wID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdH0gKTtcbn1cblxuZXhwb3J0IGNvbnN0IHByaW1hcnkgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IHNlY29uZGFyeSA9IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kVGludENvbG9yIH07XG5gO1xuXG5leHBvcnQgY29uc3QgdGVydGlhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRlcnRpYXJ5Q29sb3IgfTtcbmA7XG5cbmNvbnN0IGN1c3RvbUJhY2tncm91bmRTaXplID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+XG5cdFsgc3VyZmFjZUJhY2tncm91bmRTaXplLCBzdXJmYWNlQmFja2dyb3VuZFNpemUgXS5qb2luKCAnICcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDEgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdCc5MGRlZycsXG5cdFx0WyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciwgc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkIF0uam9pbihcblx0XHRcdCcgJ1xuXHRcdCksXG5cdFx0J3RyYW5zcGFyZW50IDElJyxcblx0XS5qb2luKCAnLCcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDIgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmcgKSA9PlxuXHRbXG5cdFx0YGxpbmVhci1ncmFkaWVudCggJHsgZG90dGVkQmFja2dyb3VuZDEoXG5cdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHQpIH0gKSBjZW50ZXJgLFxuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQyKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRDT05GSUcuc3VyZmFjZUJvcmRlckJvbGRDb2xvcixcblx0XS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldERvdHRlZCA9IChcblx0c3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nXG4pID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgZG90dGVkQmFja2dyb3VuZENvbWJpbmVkKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgKSB9O1xuXHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuYDtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQxID0gW1xuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQyID0gW1xuXHQnOTBkZWcnLFxuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmRDb21iaW5lZCA9IFtcblx0YGxpbmVhci1ncmFkaWVudCggJHsgZ3JpZEJhY2tncm91bmQxIH0gKWAsXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMiB9IClgLFxuXS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldEdyaWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yIH07XG5cdFx0YmFja2dyb3VuZC1pbWFnZTogJHsgZ3JpZEJhY2tncm91bmRDb21iaW5lZCB9O1xuXHRcdGJhY2tncm91bmQtc2l6ZTogJHsgY3VzdG9tQmFja2dyb3VuZFNpemUoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VmFyaWFudCA9IChcblx0dmFyaWFudDogU3VyZmFjZVZhcmlhbnQsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiB7XG5cdHN3aXRjaCAoIHZhcmlhbnQgKSB7XG5cdFx0Y2FzZSAnZG90dGVkJzoge1xuXHRcdFx0cmV0dXJuIGdldERvdHRlZChcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplLFxuXHRcdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHRcdCk7XG5cdFx0fVxuXHRcdGNhc2UgJ2dyaWQnOiB7XG5cdFx0XHRyZXR1cm4gZ2V0R3JpZCggc3VyZmFjZUJhY2tncm91bmRTaXplICk7XG5cdFx0fVxuXHRcdGNhc2UgJ3ByaW1hcnknOiB7XG5cdFx0XHRyZXR1cm4gcHJpbWFyeTtcblx0XHR9XG5cdFx0Y2FzZSAnc2Vjb25kYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHNlY29uZGFyeTtcblx0XHR9XG5cdFx0Y2FzZSAndGVydGlhcnknOiB7XG5cdFx0XHRyZXR1cm4gdGVydGlhcnk7XG5cdFx0fVxuXHR9XG59O1xuIl19 */"); 36316 } 36317 var primary = /* @__PURE__ */ css(false ? "" : ";label:primary;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QzBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFN1cmZhY2VWYXJpYW50LCBTdXJmYWNlUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IFN1cmZhY2UgPSBjc3NgXG5cdGJhY2tncm91bmQtY29sb3I6ICR7IENPTkZJRy5zdXJmYWNlQ29sb3IgfTtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFja2dyb3VuZCA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3JkZXJzKCB7XG5cdGJvcmRlckJvdHRvbSxcblx0Ym9yZGVyTGVmdCxcblx0Ym9yZGVyUmlnaHQsXG5cdGJvcmRlclRvcCxcbn06IFBpY2s8XG5cdFN1cmZhY2VQcm9wcyxcblx0J2JvcmRlckJvdHRvbScgfCAnYm9yZGVyTGVmdCcgfCAnYm9yZGVyUmlnaHQnIHwgJ2JvcmRlclRvcCdcbj4gKSB7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gYDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH1gO1xuXG5cdHJldHVybiBjc3MoIHtcblx0XHRib3JkZXJCb3R0b206IGJvcmRlckJvdHRvbSA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlckxlZnQ6IGJvcmRlckxlZnQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJSaWdodDogYm9yZGVyUmlnaHQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJUb3A6IGJvcmRlclRvcCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHR9ICk7XG59XG5cbmV4cG9ydCBjb25zdCBwcmltYXJ5ID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCBzZWNvbmRhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRpbnRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHRlcnRpYXJ5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRUZXJ0aWFyeUNvbG9yIH07XG5gO1xuXG5jb25zdCBjdXN0b21CYWNrZ3JvdW5kU2l6ZSA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcgKSA9PlxuXHRbIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSwgc3VyZmFjZUJhY2tncm91bmRTaXplIF0uam9pbiggJyAnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQxID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHQnOTBkZWcnLFxuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQyID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHRbIENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yLCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgXS5qb2luKFxuXHRcdFx0JyAnXG5cdFx0KSxcblx0XHQndHJhbnNwYXJlbnQgMSUnLFxuXHRdLmpvaW4oICcsJyApO1xuXG5jb25zdCBkb3R0ZWRCYWNrZ3JvdW5kQ29tYmluZWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQxKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRgbGluZWFyLWdyYWRpZW50KCAkeyBkb3R0ZWRCYWNrZ3JvdW5kMihcblx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZFxuXHRcdCkgfSApIGNlbnRlcmAsXG5cdFx0Q09ORklHLnN1cmZhY2VCb3JkZXJCb2xkQ29sb3IsXG5cdF0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXREb3R0ZWQgPSAoXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkICkgfTtcblx0YmFja2dyb3VuZC1zaXplOiAkeyBjdXN0b21CYWNrZ3JvdW5kU2l6ZSggc3VyZmFjZUJhY2tncm91bmRTaXplICkgfTtcbmA7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMSA9IFtcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMiA9IFtcblx0JzkwZGVnJyxcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgPSBbXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMSB9IClgLFxuXHRgbGluZWFyLWdyYWRpZW50KCAkeyBncmlkQmFja2dyb3VuZDIgfSApYCxcbl0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXRHcmlkID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuXHRcdGJhY2tncm91bmQtaW1hZ2U6ICR7IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgfTtcblx0XHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFZhcmlhbnQgPSAoXG5cdHZhcmlhbnQ6IFN1cmZhY2VWYXJpYW50LFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyxcblx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmdcbikgPT4ge1xuXHRzd2l0Y2ggKCB2YXJpYW50ICkge1xuXHRcdGNhc2UgJ2RvdHRlZCc6IHtcblx0XHRcdHJldHVybiBnZXREb3R0ZWQoXG5cdFx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSxcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0XHQpO1xuXHRcdH1cblx0XHRjYXNlICdncmlkJzoge1xuXHRcdFx0cmV0dXJuIGdldEdyaWQoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApO1xuXHRcdH1cblx0XHRjYXNlICdwcmltYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHByaW1hcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3NlY29uZGFyeSc6IHtcblx0XHRcdHJldHVybiBzZWNvbmRhcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3RlcnRpYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHRlcnRpYXJ5O1xuXHRcdH1cblx0fVxufTtcbiJdfQ== */"); 36318 var secondary = /* @__PURE__ */ css("background:", config_values_default.surfaceBackgroundTintColor, ";" + (false ? "" : ";label:secondary;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQzRCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFN1cmZhY2VWYXJpYW50LCBTdXJmYWNlUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IFN1cmZhY2UgPSBjc3NgXG5cdGJhY2tncm91bmQtY29sb3I6ICR7IENPTkZJRy5zdXJmYWNlQ29sb3IgfTtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFja2dyb3VuZCA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3JkZXJzKCB7XG5cdGJvcmRlckJvdHRvbSxcblx0Ym9yZGVyTGVmdCxcblx0Ym9yZGVyUmlnaHQsXG5cdGJvcmRlclRvcCxcbn06IFBpY2s8XG5cdFN1cmZhY2VQcm9wcyxcblx0J2JvcmRlckJvdHRvbScgfCAnYm9yZGVyTGVmdCcgfCAnYm9yZGVyUmlnaHQnIHwgJ2JvcmRlclRvcCdcbj4gKSB7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gYDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH1gO1xuXG5cdHJldHVybiBjc3MoIHtcblx0XHRib3JkZXJCb3R0b206IGJvcmRlckJvdHRvbSA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlckxlZnQ6IGJvcmRlckxlZnQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJSaWdodDogYm9yZGVyUmlnaHQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJUb3A6IGJvcmRlclRvcCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHR9ICk7XG59XG5cbmV4cG9ydCBjb25zdCBwcmltYXJ5ID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCBzZWNvbmRhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRpbnRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHRlcnRpYXJ5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRUZXJ0aWFyeUNvbG9yIH07XG5gO1xuXG5jb25zdCBjdXN0b21CYWNrZ3JvdW5kU2l6ZSA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcgKSA9PlxuXHRbIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSwgc3VyZmFjZUJhY2tncm91bmRTaXplIF0uam9pbiggJyAnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQxID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHQnOTBkZWcnLFxuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQyID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHRbIENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yLCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgXS5qb2luKFxuXHRcdFx0JyAnXG5cdFx0KSxcblx0XHQndHJhbnNwYXJlbnQgMSUnLFxuXHRdLmpvaW4oICcsJyApO1xuXG5jb25zdCBkb3R0ZWRCYWNrZ3JvdW5kQ29tYmluZWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQxKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRgbGluZWFyLWdyYWRpZW50KCAkeyBkb3R0ZWRCYWNrZ3JvdW5kMihcblx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZFxuXHRcdCkgfSApIGNlbnRlcmAsXG5cdFx0Q09ORklHLnN1cmZhY2VCb3JkZXJCb2xkQ29sb3IsXG5cdF0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXREb3R0ZWQgPSAoXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkICkgfTtcblx0YmFja2dyb3VuZC1zaXplOiAkeyBjdXN0b21CYWNrZ3JvdW5kU2l6ZSggc3VyZmFjZUJhY2tncm91bmRTaXplICkgfTtcbmA7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMSA9IFtcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMiA9IFtcblx0JzkwZGVnJyxcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgPSBbXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMSB9IClgLFxuXHRgbGluZWFyLWdyYWRpZW50KCAkeyBncmlkQmFja2dyb3VuZDIgfSApYCxcbl0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXRHcmlkID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuXHRcdGJhY2tncm91bmQtaW1hZ2U6ICR7IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgfTtcblx0XHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFZhcmlhbnQgPSAoXG5cdHZhcmlhbnQ6IFN1cmZhY2VWYXJpYW50LFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyxcblx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmdcbikgPT4ge1xuXHRzd2l0Y2ggKCB2YXJpYW50ICkge1xuXHRcdGNhc2UgJ2RvdHRlZCc6IHtcblx0XHRcdHJldHVybiBnZXREb3R0ZWQoXG5cdFx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSxcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0XHQpO1xuXHRcdH1cblx0XHRjYXNlICdncmlkJzoge1xuXHRcdFx0cmV0dXJuIGdldEdyaWQoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApO1xuXHRcdH1cblx0XHRjYXNlICdwcmltYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHByaW1hcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3NlY29uZGFyeSc6IHtcblx0XHRcdHJldHVybiBzZWNvbmRhcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3RlcnRpYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHRlcnRpYXJ5O1xuXHRcdH1cblx0fVxufTtcbiJdfQ== */"); 36319 var tertiary = /* @__PURE__ */ css("background:", config_values_default.surfaceBackgroundTertiaryColor, ";" + (false ? "" : ";label:tertiary;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4QzJCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IFN1cmZhY2VWYXJpYW50LCBTdXJmYWNlUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IFN1cmZhY2UgPSBjc3NgXG5cdGJhY2tncm91bmQtY29sb3I6ICR7IENPTkZJRy5zdXJmYWNlQ29sb3IgfTtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFja2dyb3VuZCA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRCb3JkZXJzKCB7XG5cdGJvcmRlckJvdHRvbSxcblx0Ym9yZGVyTGVmdCxcblx0Ym9yZGVyUmlnaHQsXG5cdGJvcmRlclRvcCxcbn06IFBpY2s8XG5cdFN1cmZhY2VQcm9wcyxcblx0J2JvcmRlckJvdHRvbScgfCAnYm9yZGVyTGVmdCcgfCAnYm9yZGVyUmlnaHQnIHwgJ2JvcmRlclRvcCdcbj4gKSB7XG5cdGNvbnN0IGJvcmRlclN0eWxlID0gYDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH1gO1xuXG5cdHJldHVybiBjc3MoIHtcblx0XHRib3JkZXJCb3R0b206IGJvcmRlckJvdHRvbSA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlckxlZnQ6IGJvcmRlckxlZnQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJSaWdodDogYm9yZGVyUmlnaHQgPyBib3JkZXJTdHlsZSA6IHVuZGVmaW5lZCxcblx0XHRib3JkZXJUb3A6IGJvcmRlclRvcCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHR9ICk7XG59XG5cbmV4cG9ydCBjb25zdCBwcmltYXJ5ID0gY3NzYGA7XG5cbmV4cG9ydCBjb25zdCBzZWNvbmRhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRpbnRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHRlcnRpYXJ5ID0gY3NzYFxuXHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRUZXJ0aWFyeUNvbG9yIH07XG5gO1xuXG5jb25zdCBjdXN0b21CYWNrZ3JvdW5kU2l6ZSA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcgKSA9PlxuXHRbIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSwgc3VyZmFjZUJhY2tncm91bmRTaXplIF0uam9pbiggJyAnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQxID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHQnOTBkZWcnLFxuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmQyID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZyApID0+XG5cdFtcblx0XHRbIENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yLCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgXS5qb2luKFxuXHRcdFx0JyAnXG5cdFx0KSxcblx0XHQndHJhbnNwYXJlbnQgMSUnLFxuXHRdLmpvaW4oICcsJyApO1xuXG5jb25zdCBkb3R0ZWRCYWNrZ3JvdW5kQ29tYmluZWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQxKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRgbGluZWFyLWdyYWRpZW50KCAkeyBkb3R0ZWRCYWNrZ3JvdW5kMihcblx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZFxuXHRcdCkgfSApIGNlbnRlcmAsXG5cdFx0Q09ORklHLnN1cmZhY2VCb3JkZXJCb2xkQ29sb3IsXG5cdF0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXREb3R0ZWQgPSAoXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkICkgfTtcblx0YmFja2dyb3VuZC1zaXplOiAkeyBjdXN0b21CYWNrZ3JvdW5kU2l6ZSggc3VyZmFjZUJhY2tncm91bmRTaXplICkgfTtcbmA7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMSA9IFtcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kMiA9IFtcblx0JzkwZGVnJyxcblx0YCR7IENPTkZJRy5zdXJmYWNlQm9yZGVyU3VidGxlQ29sb3IgfSAxcHhgLFxuXHQndHJhbnNwYXJlbnQgMXB4Jyxcbl0uam9pbiggJywnICk7XG5cbmNvbnN0IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgPSBbXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMSB9IClgLFxuXHRgbGluZWFyLWdyYWRpZW50KCAkeyBncmlkQmFja2dyb3VuZDIgfSApYCxcbl0uam9pbiggJywnICk7XG5cbmV4cG9ydCBjb25zdCBnZXRHcmlkID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuXHRcdGJhY2tncm91bmQtaW1hZ2U6ICR7IGdyaWRCYWNrZ3JvdW5kQ29tYmluZWQgfTtcblx0XHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFZhcmlhbnQgPSAoXG5cdHZhcmlhbnQ6IFN1cmZhY2VWYXJpYW50LFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyxcblx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmdcbikgPT4ge1xuXHRzd2l0Y2ggKCB2YXJpYW50ICkge1xuXHRcdGNhc2UgJ2RvdHRlZCc6IHtcblx0XHRcdHJldHVybiBnZXREb3R0ZWQoXG5cdFx0XHRcdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSxcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0XHQpO1xuXHRcdH1cblx0XHRjYXNlICdncmlkJzoge1xuXHRcdFx0cmV0dXJuIGdldEdyaWQoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApO1xuXHRcdH1cblx0XHRjYXNlICdwcmltYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHByaW1hcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3NlY29uZGFyeSc6IHtcblx0XHRcdHJldHVybiBzZWNvbmRhcnk7XG5cdFx0fVxuXHRcdGNhc2UgJ3RlcnRpYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHRlcnRpYXJ5O1xuXHRcdH1cblx0fVxufTtcbiJdfQ== */"); 36320 var customBackgroundSize = (surfaceBackgroundSize) => [surfaceBackgroundSize, surfaceBackgroundSize].join(" "); 36321 var dottedBackground1 = (surfaceBackgroundSizeDotted) => ["90deg", [config_values_default.surfaceBackgroundColor, surfaceBackgroundSizeDotted].join(" "), "transparent 1%"].join(","); 36322 var dottedBackground2 = (surfaceBackgroundSizeDotted) => [[config_values_default.surfaceBackgroundColor, surfaceBackgroundSizeDotted].join(" "), "transparent 1%"].join(","); 36323 var dottedBackgroundCombined = (surfaceBackgroundSizeDotted) => [`linear-gradient( $dottedBackground1(surfaceBackgroundSizeDotted)} ) center`, `linear-gradient( $dottedBackground2(surfaceBackgroundSizeDotted)} ) center`, config_values_default.surfaceBorderBoldColor].join(","); 36324 var getDotted = (surfaceBackgroundSize, surfaceBackgroundSizeDotted) => /* @__PURE__ */ css("background:", dottedBackgroundCombined(surfaceBackgroundSizeDotted), ";background-size:", customBackgroundSize(surfaceBackgroundSize), ";" + (false ? "" : ";label:getDotted;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRlEiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3VyZmFjZVZhcmlhbnQsIFN1cmZhY2VQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgU3VyZmFjZSA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VDb2xvciB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBiYWNrZ3JvdW5kID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJvcmRlcnMoIHtcblx0Ym9yZGVyQm90dG9tLFxuXHRib3JkZXJMZWZ0LFxuXHRib3JkZXJSaWdodCxcblx0Ym9yZGVyVG9wLFxufTogUGljazxcblx0U3VyZmFjZVByb3BzLFxuXHQnYm9yZGVyQm90dG9tJyB8ICdib3JkZXJMZWZ0JyB8ICdib3JkZXJSaWdodCcgfCAnYm9yZGVyVG9wJ1xuPiApIHtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBgMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfWA7XG5cblx0cmV0dXJuIGNzcygge1xuXHRcdGJvcmRlckJvdHRvbTogYm9yZGVyQm90dG9tID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdFx0Ym9yZGVyTGVmdDogYm9yZGVyTGVmdCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclJpZ2h0OiBib3JkZXJSaWdodCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclRvcDogYm9yZGVyVG9wID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdH0gKTtcbn1cblxuZXhwb3J0IGNvbnN0IHByaW1hcnkgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IHNlY29uZGFyeSA9IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kVGludENvbG9yIH07XG5gO1xuXG5leHBvcnQgY29uc3QgdGVydGlhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRlcnRpYXJ5Q29sb3IgfTtcbmA7XG5cbmNvbnN0IGN1c3RvbUJhY2tncm91bmRTaXplID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+XG5cdFsgc3VyZmFjZUJhY2tncm91bmRTaXplLCBzdXJmYWNlQmFja2dyb3VuZFNpemUgXS5qb2luKCAnICcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDEgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdCc5MGRlZycsXG5cdFx0WyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciwgc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkIF0uam9pbihcblx0XHRcdCcgJ1xuXHRcdCksXG5cdFx0J3RyYW5zcGFyZW50IDElJyxcblx0XS5qb2luKCAnLCcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDIgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmcgKSA9PlxuXHRbXG5cdFx0YGxpbmVhci1ncmFkaWVudCggJHsgZG90dGVkQmFja2dyb3VuZDEoXG5cdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHQpIH0gKSBjZW50ZXJgLFxuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQyKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRDT05GSUcuc3VyZmFjZUJvcmRlckJvbGRDb2xvcixcblx0XS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldERvdHRlZCA9IChcblx0c3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nXG4pID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgZG90dGVkQmFja2dyb3VuZENvbWJpbmVkKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgKSB9O1xuXHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuYDtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQxID0gW1xuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQyID0gW1xuXHQnOTBkZWcnLFxuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmRDb21iaW5lZCA9IFtcblx0YGxpbmVhci1ncmFkaWVudCggJHsgZ3JpZEJhY2tncm91bmQxIH0gKWAsXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMiB9IClgLFxuXS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldEdyaWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yIH07XG5cdFx0YmFja2dyb3VuZC1pbWFnZTogJHsgZ3JpZEJhY2tncm91bmRDb21iaW5lZCB9O1xuXHRcdGJhY2tncm91bmQtc2l6ZTogJHsgY3VzdG9tQmFja2dyb3VuZFNpemUoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VmFyaWFudCA9IChcblx0dmFyaWFudDogU3VyZmFjZVZhcmlhbnQsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiB7XG5cdHN3aXRjaCAoIHZhcmlhbnQgKSB7XG5cdFx0Y2FzZSAnZG90dGVkJzoge1xuXHRcdFx0cmV0dXJuIGdldERvdHRlZChcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplLFxuXHRcdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHRcdCk7XG5cdFx0fVxuXHRcdGNhc2UgJ2dyaWQnOiB7XG5cdFx0XHRyZXR1cm4gZ2V0R3JpZCggc3VyZmFjZUJhY2tncm91bmRTaXplICk7XG5cdFx0fVxuXHRcdGNhc2UgJ3ByaW1hcnknOiB7XG5cdFx0XHRyZXR1cm4gcHJpbWFyeTtcblx0XHR9XG5cdFx0Y2FzZSAnc2Vjb25kYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHNlY29uZGFyeTtcblx0XHR9XG5cdFx0Y2FzZSAndGVydGlhcnknOiB7XG5cdFx0XHRyZXR1cm4gdGVydGlhcnk7XG5cdFx0fVxuXHR9XG59O1xuIl19 */"); 36325 var gridBackground1 = [`$config_values_default.surfaceBorderSubtleColor} 1px`, "transparent 1px"].join(","); 36326 var gridBackground2 = ["90deg", `$config_values_default.surfaceBorderSubtleColor} 1px`, "transparent 1px"].join(","); 36327 var gridBackgroundCombined = [`linear-gradient( $gridBackground1} )`, `linear-gradient( $gridBackground2} )`].join(","); 36328 var getGrid = (surfaceBackgroundSize) => { 36329 return /* @__PURE__ */ css("background:", config_values_default.surfaceBackgroundColor, ";background-image:", gridBackgroundCombined, ";background-size:", customBackgroundSize(surfaceBackgroundSize), ";" + (false ? "" : ";label:getGrid;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwR1ciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgU3VyZmFjZVZhcmlhbnQsIFN1cmZhY2VQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgU3VyZmFjZSA9IGNzc2Bcblx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLnN1cmZhY2VDb2xvciB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBiYWNrZ3JvdW5kID0gY3NzYFxuXHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciB9O1xuYDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldEJvcmRlcnMoIHtcblx0Ym9yZGVyQm90dG9tLFxuXHRib3JkZXJMZWZ0LFxuXHRib3JkZXJSaWdodCxcblx0Ym9yZGVyVG9wLFxufTogUGljazxcblx0U3VyZmFjZVByb3BzLFxuXHQnYm9yZGVyQm90dG9tJyB8ICdib3JkZXJMZWZ0JyB8ICdib3JkZXJSaWdodCcgfCAnYm9yZGVyVG9wJ1xuPiApIHtcblx0Y29uc3QgYm9yZGVyU3R5bGUgPSBgMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfWA7XG5cblx0cmV0dXJuIGNzcygge1xuXHRcdGJvcmRlckJvdHRvbTogYm9yZGVyQm90dG9tID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdFx0Ym9yZGVyTGVmdDogYm9yZGVyTGVmdCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclJpZ2h0OiBib3JkZXJSaWdodCA/IGJvcmRlclN0eWxlIDogdW5kZWZpbmVkLFxuXHRcdGJvcmRlclRvcDogYm9yZGVyVG9wID8gYm9yZGVyU3R5bGUgOiB1bmRlZmluZWQsXG5cdH0gKTtcbn1cblxuZXhwb3J0IGNvbnN0IHByaW1hcnkgPSBjc3NgYDtcblxuZXhwb3J0IGNvbnN0IHNlY29uZGFyeSA9IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kVGludENvbG9yIH07XG5gO1xuXG5leHBvcnQgY29uc3QgdGVydGlhcnkgPSBjc3NgXG5cdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZFRlcnRpYXJ5Q29sb3IgfTtcbmA7XG5cbmNvbnN0IGN1c3RvbUJhY2tncm91bmRTaXplID0gKCBzdXJmYWNlQmFja2dyb3VuZFNpemU6IHN0cmluZyApID0+XG5cdFsgc3VyZmFjZUJhY2tncm91bmRTaXplLCBzdXJmYWNlQmFja2dyb3VuZFNpemUgXS5qb2luKCAnICcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDEgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdCc5MGRlZycsXG5cdFx0WyBDT05GSUcuc3VyZmFjZUJhY2tncm91bmRDb2xvciwgc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkIF0uam9pbihcblx0XHRcdCcgJ1xuXHRcdCksXG5cdFx0J3RyYW5zcGFyZW50IDElJyxcblx0XS5qb2luKCAnLCcgKTtcblxuY29uc3QgZG90dGVkQmFja2dyb3VuZDIgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nICkgPT5cblx0W1xuXHRcdFsgQ09ORklHLnN1cmZhY2VCYWNrZ3JvdW5kQ29sb3IsIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZCBdLmpvaW4oXG5cdFx0XHQnICdcblx0XHQpLFxuXHRcdCd0cmFuc3BhcmVudCAxJScsXG5cdF0uam9pbiggJywnICk7XG5cbmNvbnN0IGRvdHRlZEJhY2tncm91bmRDb21iaW5lZCA9ICggc3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkOiBzdHJpbmcgKSA9PlxuXHRbXG5cdFx0YGxpbmVhci1ncmFkaWVudCggJHsgZG90dGVkQmFja2dyb3VuZDEoXG5cdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHQpIH0gKSBjZW50ZXJgLFxuXHRcdGBsaW5lYXItZ3JhZGllbnQoICR7IGRvdHRlZEJhY2tncm91bmQyKFxuXHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplRG90dGVkXG5cdFx0KSB9ICkgY2VudGVyYCxcblx0XHRDT05GSUcuc3VyZmFjZUJvcmRlckJvbGRDb2xvcixcblx0XS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldERvdHRlZCA9IChcblx0c3VyZmFjZUJhY2tncm91bmRTaXplOiBzdHJpbmcsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZURvdHRlZDogc3RyaW5nXG4pID0+IGNzc2Bcblx0YmFja2dyb3VuZDogJHsgZG90dGVkQmFja2dyb3VuZENvbWJpbmVkKCBzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQgKSB9O1xuXHRiYWNrZ3JvdW5kLXNpemU6ICR7IGN1c3RvbUJhY2tncm91bmRTaXplKCBzdXJmYWNlQmFja2dyb3VuZFNpemUgKSB9O1xuYDtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQxID0gW1xuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmQyID0gW1xuXHQnOTBkZWcnLFxuXHRgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJTdWJ0bGVDb2xvciB9IDFweGAsXG5cdCd0cmFuc3BhcmVudCAxcHgnLFxuXS5qb2luKCAnLCcgKTtcblxuY29uc3QgZ3JpZEJhY2tncm91bmRDb21iaW5lZCA9IFtcblx0YGxpbmVhci1ncmFkaWVudCggJHsgZ3JpZEJhY2tncm91bmQxIH0gKWAsXG5cdGBsaW5lYXItZ3JhZGllbnQoICR7IGdyaWRCYWNrZ3JvdW5kMiB9IClgLFxuXS5qb2luKCAnLCcgKTtcblxuZXhwb3J0IGNvbnN0IGdldEdyaWQgPSAoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGJhY2tncm91bmQ6ICR7IENPTkZJRy5zdXJmYWNlQmFja2dyb3VuZENvbG9yIH07XG5cdFx0YmFja2dyb3VuZC1pbWFnZTogJHsgZ3JpZEJhY2tncm91bmRDb21iaW5lZCB9O1xuXHRcdGJhY2tncm91bmQtc2l6ZTogJHsgY3VzdG9tQmFja2dyb3VuZFNpemUoIHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZSApIH07XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VmFyaWFudCA9IChcblx0dmFyaWFudDogU3VyZmFjZVZhcmlhbnQsXG5cdHN1cmZhY2VCYWNrZ3JvdW5kU2l6ZTogc3RyaW5nLFxuXHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWQ6IHN0cmluZ1xuKSA9PiB7XG5cdHN3aXRjaCAoIHZhcmlhbnQgKSB7XG5cdFx0Y2FzZSAnZG90dGVkJzoge1xuXHRcdFx0cmV0dXJuIGdldERvdHRlZChcblx0XHRcdFx0c3VyZmFjZUJhY2tncm91bmRTaXplLFxuXHRcdFx0XHRzdXJmYWNlQmFja2dyb3VuZFNpemVEb3R0ZWRcblx0XHRcdCk7XG5cdFx0fVxuXHRcdGNhc2UgJ2dyaWQnOiB7XG5cdFx0XHRyZXR1cm4gZ2V0R3JpZCggc3VyZmFjZUJhY2tncm91bmRTaXplICk7XG5cdFx0fVxuXHRcdGNhc2UgJ3ByaW1hcnknOiB7XG5cdFx0XHRyZXR1cm4gcHJpbWFyeTtcblx0XHR9XG5cdFx0Y2FzZSAnc2Vjb25kYXJ5Jzoge1xuXHRcdFx0cmV0dXJuIHNlY29uZGFyeTtcblx0XHR9XG5cdFx0Y2FzZSAndGVydGlhcnknOiB7XG5cdFx0XHRyZXR1cm4gdGVydGlhcnk7XG5cdFx0fVxuXHR9XG59O1xuIl19 */"); 36330 }; 36331 var getVariant = (variant, surfaceBackgroundSize, surfaceBackgroundSizeDotted) => { 36332 switch (variant) { 36333 case "dotted": { 36334 return getDotted(surfaceBackgroundSize, surfaceBackgroundSizeDotted); 36335 } 36336 case "grid": { 36337 return getGrid(surfaceBackgroundSize); 36338 } 36339 case "primary": { 36340 return primary; 36341 } 36342 case "secondary": { 36343 return secondary; 36344 } 36345 case "tertiary": { 36346 return tertiary; 36347 } 36348 } 36349 }; 36350 36351 // packages/components/build-module/surface/hook.js 36352 function useSurface(props) { 36353 const { 36354 backgroundSize = 12, 36355 borderBottom = false, 36356 borderLeft = false, 36357 borderRight = false, 36358 borderTop = false, 36359 className: className2, 36360 variant = "primary", 36361 ...otherProps 36362 } = useContextSystem(props, "Surface"); 36363 const cx3 = useCx(); 36364 const classes = (0, import_element97.useMemo)(() => { 36365 const sx = { 36366 borders: getBorders({ 36367 borderBottom, 36368 borderLeft, 36369 borderRight, 36370 borderTop 36371 }) 36372 }; 36373 return cx3(Surface, sx.borders, getVariant(variant, `$backgroundSize}px`, `$backgroundSize - 1}px`), className2); 36374 }, [backgroundSize, borderBottom, borderLeft, borderRight, borderTop, className2, cx3, variant]); 36375 return { 36376 ...otherProps, 36377 className: classes 36378 }; 36379 } 36380 36381 // packages/components/build-module/surface/component.js 36382 var import_jsx_runtime161 = __toESM(require_jsx_runtime()); 36383 function UnconnectedSurface(props, forwardedRef) { 36384 const surfaceProps = useSurface(props); 36385 return /* @__PURE__ */ (0, import_jsx_runtime161.jsx)(component_default, { 36386 ...surfaceProps, 36387 ref: forwardedRef 36388 }); 36389 } 36390 var Surface2 = contextConnect(UnconnectedSurface, "Surface"); 36391 var component_default26 = Surface2; 36392 36393 // packages/components/build-module/card/card/hook.js 36394 function useDeprecatedProps4({ 36395 elevation, 36396 isElevated, 36397 ...otherProps 36398 }) { 36399 const propsToReturn = { 36400 ...otherProps 36401 }; 36402 let computedElevation = elevation; 36403 if (isElevated) { 36404 var _computedElevation; 36405 (0, import_deprecated11.default)("Card isElevated prop", { 36406 since: "5.9", 36407 alternative: "elevation" 36408 }); 36409 (_computedElevation = computedElevation) !== null && _computedElevation !== void 0 ? _computedElevation : computedElevation = 2; 36410 } 36411 if (typeof computedElevation !== "undefined") { 36412 propsToReturn.elevation = computedElevation; 36413 } 36414 return propsToReturn; 36415 } 36416 function useCard(props) { 36417 const { 36418 className: className2, 36419 elevation = 0, 36420 isBorderless = false, 36421 isRounded = true, 36422 size: size3 = "medium", 36423 ...otherProps 36424 } = useContextSystem(useDeprecatedProps4(props), "Card"); 36425 const cx3 = useCx(); 36426 const classes = (0, import_element98.useMemo)(() => { 36427 return cx3(Card, isBorderless && boxShadowless, isRounded && rounded, className2); 36428 }, [className2, cx3, isBorderless, isRounded]); 36429 const surfaceProps = useSurface({ 36430 ...otherProps, 36431 className: classes 36432 }); 36433 return { 36434 ...surfaceProps, 36435 elevation, 36436 isBorderless, 36437 isRounded, 36438 size: size3 36439 }; 36440 } 36441 36442 // packages/components/build-module/card/card/component.js 36443 var import_jsx_runtime162 = __toESM(require_jsx_runtime()); 36444 function UnconnectedCard(props, forwardedRef) { 36445 const { 36446 children, 36447 elevation, 36448 isBorderless, 36449 isRounded, 36450 size: size3, 36451 ...otherProps 36452 } = useCard(props); 36453 const elevationBorderRadius = isRounded ? config_values_default.radiusLarge : 0; 36454 const cx3 = useCx(); 36455 const elevationClassName = (0, import_element99.useMemo)(() => cx3(/* @__PURE__ */ css({ 36456 borderRadius: elevationBorderRadius 36457 }, false ? "" : ";label:elevationClassName;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUNZIiwiZmlsZSI6ImNvbXBvbmVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgdHlwZSB7IEZvcndhcmRlZFJlZiB9IGZyb20gJ3JlYWN0JztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdAd29yZHByZXNzL2VsZW1lbnQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFdvcmRQcmVzc0NvbXBvbmVudFByb3BzIH0gZnJvbSAnLi4vLi4vY29udGV4dCc7XG5pbXBvcnQgeyBjb250ZXh0Q29ubmVjdCwgQ29udGV4dFN5c3RlbVByb3ZpZGVyIH0gZnJvbSAnLi4vLi4vY29udGV4dCc7XG5pbXBvcnQgeyBFbGV2YXRpb24gfSBmcm9tICcuLi8uLi9lbGV2YXRpb24nO1xuaW1wb3J0IHsgVmlldyB9IGZyb20gJy4uLy4uL3ZpZXcnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4uL3N0eWxlcyc7XG5pbXBvcnQgeyB1c2VDYXJkIH0gZnJvbSAnLi9ob29rJztcbmltcG9ydCBDT05GSUcgZnJvbSAnLi4vLi4vdXRpbHMvY29uZmlnLXZhbHVlcyc7XG5pbXBvcnQgeyB1c2VDeCB9IGZyb20gJy4uLy4uL3V0aWxzL2hvb2tzL3VzZS1jeCc7XG5pbXBvcnQgdHlwZSB7IFByb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5mdW5jdGlvbiBVbmNvbm5lY3RlZENhcmQoXG5cdHByb3BzOiBXb3JkUHJlc3NDb21wb25lbnRQcm9wczwgUHJvcHMsICdkaXYnID4sXG5cdGZvcndhcmRlZFJlZjogRm9yd2FyZGVkUmVmPCBhbnkgPlxuKSB7XG5cdGNvbnN0IHtcblx0XHRjaGlsZHJlbixcblx0XHRlbGV2YXRpb24sXG5cdFx0aXNCb3JkZXJsZXNzLFxuXHRcdGlzUm91bmRlZCxcblx0XHRzaXplLFxuXHRcdC4uLm90aGVyUHJvcHNcblx0fSA9IHVzZUNhcmQoIHByb3BzICk7XG5cdGNvbnN0IGVsZXZhdGlvbkJvcmRlclJhZGl1cyA9IGlzUm91bmRlZCA/IENPTkZJRy5yYWRpdXNMYXJnZSA6IDA7XG5cblx0Y29uc3QgY3ggPSB1c2VDeCgpO1xuXG5cdGNvbnN0IGVsZXZhdGlvbkNsYXNzTmFtZSA9IHVzZU1lbW8oXG5cdFx0KCkgPT4gY3goIGNzcyggeyBib3JkZXJSYWRpdXM6IGVsZXZhdGlvbkJvcmRlclJhZGl1cyB9ICkgKSxcblx0XHRbIGN4LCBlbGV2YXRpb25Cb3JkZXJSYWRpdXMgXVxuXHQpO1xuXG5cdGNvbnN0IGNvbnRleHRQcm92aWRlclZhbHVlID0gdXNlTWVtbyggKCkgPT4ge1xuXHRcdGNvbnN0IGNvbnRleHRQcm9wcyA9IHtcblx0XHRcdHNpemUsXG5cdFx0XHRpc0JvcmRlcmxlc3MsXG5cdFx0fTtcblx0XHRyZXR1cm4ge1xuXHRcdFx0Q2FyZEJvZHk6IGNvbnRleHRQcm9wcyxcblx0XHRcdENhcmRIZWFkZXI6IGNvbnRleHRQcm9wcyxcblx0XHRcdENhcmRGb290ZXI6IGNvbnRleHRQcm9wcyxcblx0XHR9O1xuXHR9LCBbIGlzQm9yZGVybGVzcywgc2l6ZSBdICk7XG5cblx0cmV0dXJuIChcblx0XHQ8Q29udGV4dFN5c3RlbVByb3ZpZGVyIHZhbHVlPXsgY29udGV4dFByb3ZpZGVyVmFsdWUgfT5cblx0XHRcdDxWaWV3IHsgLi4ub3RoZXJQcm9wcyB9IHJlZj17IGZvcndhcmRlZFJlZiB9PlxuXHRcdFx0XHQ8VmlldyBjbGFzc05hbWU9eyBjeCggc3R5bGVzLkNvbnRlbnQgKSB9PnsgY2hpbGRyZW4gfTwvVmlldz5cblx0XHRcdFx0PEVsZXZhdGlvblxuXHRcdFx0XHRcdGNsYXNzTmFtZT17IGVsZXZhdGlvbkNsYXNzTmFtZSB9XG5cdFx0XHRcdFx0aXNJbnRlcmFjdGl2ZT17IGZhbHNlIH1cblx0XHRcdFx0XHR2YWx1ZT17IGVsZXZhdGlvbiA/IDEgOiAwIH1cblx0XHRcdFx0Lz5cblx0XHRcdFx0PEVsZXZhdGlvblxuXHRcdFx0XHRcdGNsYXNzTmFtZT17IGVsZXZhdGlvbkNsYXNzTmFtZSB9XG5cdFx0XHRcdFx0aXNJbnRlcmFjdGl2ZT17IGZhbHNlIH1cblx0XHRcdFx0XHR2YWx1ZT17IGVsZXZhdGlvbiB9XG5cdFx0XHRcdC8+XG5cdFx0XHQ8L1ZpZXc+XG5cdFx0PC9Db250ZXh0U3lzdGVtUHJvdmlkZXI+XG5cdCk7XG59XG5cbi8qKlxuICogYENhcmRgIHByb3ZpZGVzIGEgZmxleGlibGUgYW5kIGV4dGVuc2libGUgY29udGVudCBjb250YWluZXIuXG4gKiBgQ2FyZGAgYWxzbyBwcm92aWRlcyBhIGNvbnZlbmllbnQgc2V0IG9mIHN1Yi1jb21wb25lbnRzIHN1Y2ggYXMgYENhcmRCb2R5YCxcbiAqIGBDYXJkSGVhZGVyYCwgYENhcmRGb290ZXJgLCBhbmQgbW9yZS5cbiAqXG4gKiBgYGBqc3hcbiAqIGltcG9ydCB7XG4gKiAgIENhcmQsXG4gKiAgIENhcmRIZWFkZXIsXG4gKiAgIENhcmRCb2R5LFxuICogICBDYXJkRm9vdGVyLFxuICogICBfX2V4cGVyaW1lbnRhbFRleHQgYXMgVGV4dCxcbiAqICAgX19leHBlcmltZW50YWxIZWFkaW5nIGFzIEhlYWRpbmcsXG4gKiB9IGZyb20gYEB3b3JkcHJlc3MvY29tcG9uZW50c2A7XG4gKlxuICogZnVuY3Rpb24gRXhhbXBsZSgpIHtcbiAqICAgcmV0dXJuIChcbiAqICAgICA8Q2FyZD5cbiAqICAgICAgIDxDYXJkSGVhZGVyPlxuICogICAgICAgICA8SGVhZGluZyBsZXZlbD17IDQgfT5DYXJkIFRpdGxlPC9IZWFkaW5nPlxuICogICAgICAgPC9DYXJkSGVhZGVyPlxuICogICAgICAgPENhcmRCb2R5PlxuICogICAgICAgICA8VGV4dD5DYXJkIENvbnRlbnQ8L1RleHQ+XG4gKiAgICAgICA8L0NhcmRCb2R5PlxuICogICAgICAgPENhcmRGb290ZXI+XG4gKiAgICAgICAgIDxUZXh0PkNhcmQgRm9vdGVyPC9UZXh0PlxuICogICAgICAgPC9DYXJkRm9vdGVyPlxuICogICAgIDwvQ2FyZD5cbiAqICAgKTtcbiAqIH1cbiAqIGBgYFxuICovXG5leHBvcnQgY29uc3QgQ2FyZCA9IGNvbnRleHRDb25uZWN0KCBVbmNvbm5lY3RlZENhcmQsICdDYXJkJyApO1xuXG5leHBvcnQgZGVmYXVsdCBDYXJkO1xuIl19 */")), [cx3, elevationBorderRadius]); 36458 const contextProviderValue = (0, import_element99.useMemo)(() => { 36459 const contextProps = { 36460 size: size3, 36461 isBorderless 36462 }; 36463 return { 36464 CardBody: contextProps, 36465 CardHeader: contextProps, 36466 CardFooter: contextProps 36467 }; 36468 }, [isBorderless, size3]); 36469 return /* @__PURE__ */ (0, import_jsx_runtime162.jsx)(ContextSystemProvider, { 36470 value: contextProviderValue, 36471 children: /* @__PURE__ */ (0, import_jsx_runtime162.jsxs)(component_default, { 36472 ...otherProps, 36473 ref: forwardedRef, 36474 children: [/* @__PURE__ */ (0, import_jsx_runtime162.jsx)(component_default, { 36475 className: cx3(Content), 36476 children 36477 }), /* @__PURE__ */ (0, import_jsx_runtime162.jsx)(component_default25, { 36478 className: elevationClassName, 36479 isInteractive: false, 36480 value: elevation ? 1 : 0 36481 }), /* @__PURE__ */ (0, import_jsx_runtime162.jsx)(component_default25, { 36482 className: elevationClassName, 36483 isInteractive: false, 36484 value: elevation 36485 })] 36486 }) 36487 }); 36488 } 36489 var Card2 = contextConnect(UnconnectedCard, "Card"); 36490 var component_default27 = Card2; 36491 36492 // packages/components/build-module/scrollable/hook.js 36493 var import_element100 = __toESM(require_element()); 36494 36495 // packages/components/build-module/scrollable/styles.js 36496 function _EMOTION_STRINGIFIED_CSS_ERROR__19() { 36497 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 36498 } 36499 var scrollableScrollbar = /* @__PURE__ */ css("@media only screen and ( min-device-width: 40em ){&::-webkit-scrollbar{height:12px;width:12px;}&::-webkit-scrollbar-track{background-color:transparent;}&::-webkit-scrollbar-track{background:", config_values_default.colorScrollbarTrack, ";border-radius:8px;}&::-webkit-scrollbar-thumb{background-clip:padding-box;background-color:", config_values_default.colorScrollbarThumb, ";border:2px solid rgba( 0, 0, 0, 0 );border-radius:7px;}&:hover::-webkit-scrollbar-thumb{background-color:", config_values_default.colorScrollbarThumbHover, ";}}" + (false ? "" : ";label:scrollableScrollbar;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVc0MiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxhYmxlU2Nyb2xsYmFyID0gY3NzYFxuXHRAbWVkaWEgb25seSBzY3JlZW4gYW5kICggbWluLWRldmljZS13aWR0aDogNDBlbSApIHtcblx0XHQmOjotd2Via2l0LXNjcm9sbGJhciB7XG5cdFx0XHRoZWlnaHQ6IDEycHg7XG5cdFx0XHR3aWR0aDogMTJweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10cmFjayB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10cmFjayB7XG5cdFx0XHRiYWNrZ3JvdW5kOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUcmFjayB9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogOHB4O1xuXHRcdH1cblxuXHRcdCY6Oi13ZWJraXQtc2Nyb2xsYmFyLXRodW1iIHtcblx0XHRcdGJhY2tncm91bmQtY2xpcDogcGFkZGluZy1ib3g7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYiB9O1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgcmdiYSggMCwgMCwgMCwgMCApO1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogN3B4O1xuXHRcdH1cblxuXHRcdCY6aG92ZXI6Oi13ZWJraXQtc2Nyb2xsYmFyLXRodW1iIHtcblx0XHRcdGJhY2tncm91bmQtY29sb3I6ICR7IENPTkZJRy5jb2xvclNjcm9sbGJhclRodW1iSG92ZXIgfTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBTY3JvbGxhYmxlID0gY3NzYFxuXHRoZWlnaHQ6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgQ29udGVudCA9IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNtb290aFNjcm9sbCA9IGNzc2Bcblx0c2Nyb2xsLWJlaGF2aW9yOiBzbW9vdGg7XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsWCA9IGNzc2Bcblx0b3ZlcmZsb3cteDogYXV0bztcblx0b3ZlcmZsb3cteTogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFkgPSBjc3NgXG5cdG92ZXJmbG93LXg6IGhpZGRlbjtcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxBdXRvID0gY3NzYFxuXHRvdmVyZmxvdy15OiBhdXRvO1xuYDtcbiJdfQ== */"); 36500 var Scrollable = false ? { 36501 name: "13udsys", 36502 styles: "height:100%" 36503 } : { 36504 name: "drdujb-Scrollable", 36505 styles: "height:100%;label:Scrollable;", 36506 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QzZCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsYWJsZVNjcm9sbGJhciA9IGNzc2Bcblx0QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAoIG1pbi1kZXZpY2Utd2lkdGg6IDQwZW0gKSB7XG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuXHRcdFx0aGVpZ2h0OiAxMnB4O1xuXHRcdFx0d2lkdGg6IDEycHg7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVHJhY2sgfTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDhweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNsaXA6IHBhZGRpbmctYm94O1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVGh1bWIgfTtcblx0XHRcdGJvcmRlcjogMnB4IHNvbGlkIHJnYmEoIDAsIDAsIDAsIDAgKTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDdweDtcblx0XHR9XG5cblx0XHQmOmhvdmVyOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYkhvdmVyIH07XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU2Nyb2xsYWJsZSA9IGNzc2Bcblx0aGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IENvbnRlbnQgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzbW9vdGhTY3JvbGwgPSBjc3NgXG5cdHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFggPSBjc3NgXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdG92ZXJmbG93LXk6IGhpZGRlbjtcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxZID0gY3NzYFxuXHRvdmVyZmxvdy14OiBoaWRkZW47XG5cdG92ZXJmbG93LXk6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsQXV0byA9IGNzc2Bcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG4iXX0= */", 36507 toString: _EMOTION_STRINGIFIED_CSS_ERROR__19 36508 }; 36509 var smoothScroll = false ? { 36510 name: "7zq9w", 36511 styles: "scroll-behavior:smooth" 36512 } : { 36513 name: "rnnynm-smoothScroll", 36514 styles: "scroll-behavior:smooth;label:smoothScroll;", 36515 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQytCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsYWJsZVNjcm9sbGJhciA9IGNzc2Bcblx0QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAoIG1pbi1kZXZpY2Utd2lkdGg6IDQwZW0gKSB7XG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuXHRcdFx0aGVpZ2h0OiAxMnB4O1xuXHRcdFx0d2lkdGg6IDEycHg7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVHJhY2sgfTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDhweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNsaXA6IHBhZGRpbmctYm94O1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVGh1bWIgfTtcblx0XHRcdGJvcmRlcjogMnB4IHNvbGlkIHJnYmEoIDAsIDAsIDAsIDAgKTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDdweDtcblx0XHR9XG5cblx0XHQmOmhvdmVyOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYkhvdmVyIH07XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU2Nyb2xsYWJsZSA9IGNzc2Bcblx0aGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IENvbnRlbnQgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzbW9vdGhTY3JvbGwgPSBjc3NgXG5cdHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFggPSBjc3NgXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdG92ZXJmbG93LXk6IGhpZGRlbjtcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxZID0gY3NzYFxuXHRvdmVyZmxvdy14OiBoaWRkZW47XG5cdG92ZXJmbG93LXk6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsQXV0byA9IGNzc2Bcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG4iXX0= */", 36516 toString: _EMOTION_STRINGIFIED_CSS_ERROR__19 36517 }; 36518 var scrollX = false ? { 36519 name: "q33xhg", 36520 styles: "overflow-x:auto;overflow-y:hidden" 36521 } : { 36522 name: "17z0rvw-scrollX", 36523 styles: "overflow-x:auto;overflow-y:hidden;label:scrollX;", 36524 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRDBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsYWJsZVNjcm9sbGJhciA9IGNzc2Bcblx0QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAoIG1pbi1kZXZpY2Utd2lkdGg6IDQwZW0gKSB7XG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuXHRcdFx0aGVpZ2h0OiAxMnB4O1xuXHRcdFx0d2lkdGg6IDEycHg7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVHJhY2sgfTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDhweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNsaXA6IHBhZGRpbmctYm94O1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVGh1bWIgfTtcblx0XHRcdGJvcmRlcjogMnB4IHNvbGlkIHJnYmEoIDAsIDAsIDAsIDAgKTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDdweDtcblx0XHR9XG5cblx0XHQmOmhvdmVyOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYkhvdmVyIH07XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU2Nyb2xsYWJsZSA9IGNzc2Bcblx0aGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IENvbnRlbnQgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzbW9vdGhTY3JvbGwgPSBjc3NgXG5cdHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFggPSBjc3NgXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdG92ZXJmbG93LXk6IGhpZGRlbjtcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxZID0gY3NzYFxuXHRvdmVyZmxvdy14OiBoaWRkZW47XG5cdG92ZXJmbG93LXk6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsQXV0byA9IGNzc2Bcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG4iXX0= */", 36525 toString: _EMOTION_STRINGIFIED_CSS_ERROR__19 36526 }; 36527 var scrollY = false ? { 36528 name: "103x71s", 36529 styles: "overflow-x:hidden;overflow-y:auto" 36530 } : { 36531 name: "flie1-scrollY", 36532 styles: "overflow-x:hidden;overflow-y:auto;label:scrollY;", 36533 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RDBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsYWJsZVNjcm9sbGJhciA9IGNzc2Bcblx0QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAoIG1pbi1kZXZpY2Utd2lkdGg6IDQwZW0gKSB7XG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuXHRcdFx0aGVpZ2h0OiAxMnB4O1xuXHRcdFx0d2lkdGg6IDEycHg7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVHJhY2sgfTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDhweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNsaXA6IHBhZGRpbmctYm94O1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVGh1bWIgfTtcblx0XHRcdGJvcmRlcjogMnB4IHNvbGlkIHJnYmEoIDAsIDAsIDAsIDAgKTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDdweDtcblx0XHR9XG5cblx0XHQmOmhvdmVyOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYkhvdmVyIH07XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU2Nyb2xsYWJsZSA9IGNzc2Bcblx0aGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IENvbnRlbnQgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzbW9vdGhTY3JvbGwgPSBjc3NgXG5cdHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFggPSBjc3NgXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdG92ZXJmbG93LXk6IGhpZGRlbjtcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxZID0gY3NzYFxuXHRvdmVyZmxvdy14OiBoaWRkZW47XG5cdG92ZXJmbG93LXk6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsQXV0byA9IGNzc2Bcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG4iXX0= */", 36534 toString: _EMOTION_STRINGIFIED_CSS_ERROR__19 36535 }; 36536 var scrollAuto = false ? { 36537 name: "umwchj", 36538 styles: "overflow-y:auto" 36539 } : { 36540 name: "1lcuu7v-scrollAuto", 36541 styles: "overflow-y:auto;label:scrollAuto;", 36542 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RDZCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsYWJsZVNjcm9sbGJhciA9IGNzc2Bcblx0QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAoIG1pbi1kZXZpY2Utd2lkdGg6IDQwZW0gKSB7XG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuXHRcdFx0aGVpZ2h0OiAxMnB4O1xuXHRcdFx0d2lkdGg6IDEycHg7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdFx0fVxuXG5cdFx0Jjo6LXdlYmtpdC1zY3JvbGxiYXItdHJhY2sge1xuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVHJhY2sgfTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDhweDtcblx0XHR9XG5cblx0XHQmOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNsaXA6IHBhZGRpbmctYm94O1xuXHRcdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09ORklHLmNvbG9yU2Nyb2xsYmFyVGh1bWIgfTtcblx0XHRcdGJvcmRlcjogMnB4IHNvbGlkIHJnYmEoIDAsIDAsIDAsIDAgKTtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDdweDtcblx0XHR9XG5cblx0XHQmOmhvdmVyOjotd2Via2l0LXNjcm9sbGJhci10aHVtYiB7XG5cdFx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT05GSUcuY29sb3JTY3JvbGxiYXJUaHVtYkhvdmVyIH07XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU2Nyb2xsYWJsZSA9IGNzc2Bcblx0aGVpZ2h0OiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IENvbnRlbnQgPSBjc3NgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzbW9vdGhTY3JvbGwgPSBjc3NgXG5cdHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuYDtcblxuZXhwb3J0IGNvbnN0IHNjcm9sbFggPSBjc3NgXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdG92ZXJmbG93LXk6IGhpZGRlbjtcbmA7XG5cbmV4cG9ydCBjb25zdCBzY3JvbGxZID0gY3NzYFxuXHRvdmVyZmxvdy14OiBoaWRkZW47XG5cdG92ZXJmbG93LXk6IGF1dG87XG5gO1xuXG5leHBvcnQgY29uc3Qgc2Nyb2xsQXV0byA9IGNzc2Bcblx0b3ZlcmZsb3cteTogYXV0bztcbmA7XG4iXX0= */", 36543 toString: _EMOTION_STRINGIFIED_CSS_ERROR__19 36544 }; 36545 36546 // packages/components/build-module/scrollable/hook.js 36547 function useScrollable(props) { 36548 const { 36549 className: className2, 36550 scrollDirection = "y", 36551 smoothScroll: smoothScroll2 = false, 36552 ...otherProps 36553 } = useContextSystem(props, "Scrollable"); 36554 const cx3 = useCx(); 36555 const classes = (0, import_element100.useMemo)(() => cx3(Scrollable, scrollableScrollbar, smoothScroll2 && smoothScroll, scrollDirection === "x" && scrollX, scrollDirection === "y" && scrollY, scrollDirection === "auto" && scrollAuto, className2), [className2, cx3, scrollDirection, smoothScroll2]); 36556 return { 36557 ...otherProps, 36558 className: classes 36559 }; 36560 } 36561 36562 // packages/components/build-module/scrollable/component.js 36563 var import_jsx_runtime163 = __toESM(require_jsx_runtime()); 36564 function UnconnectedScrollable(props, forwardedRef) { 36565 const scrollableProps = useScrollable(props); 36566 return /* @__PURE__ */ (0, import_jsx_runtime163.jsx)(component_default, { 36567 ...scrollableProps, 36568 ref: forwardedRef 36569 }); 36570 } 36571 var Scrollable2 = contextConnect(UnconnectedScrollable, "Scrollable"); 36572 var component_default28 = Scrollable2; 36573 36574 // packages/components/build-module/card/card-body/hook.js 36575 var import_element101 = __toESM(require_element()); 36576 36577 // packages/components/build-module/card/get-padding-by-size.js 36578 function _EMOTION_STRINGIFIED_CSS_ERROR__20() { 36579 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 36580 } 36581 var xSmallCardPadding = /* @__PURE__ */ css("padding:", space(2), ";" + (false ? "" : ";label:xSmallCardPadding;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzZCIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */"); 36582 var cardPaddings = { 36583 none: false ? { 36584 name: "1hcx8jb", 36585 styles: "padding:0" 36586 } : { 36587 name: "1nt59cd-none", 36588 styles: "padding:0;label:none;", 36589 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JVIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */", 36590 toString: _EMOTION_STRINGIFIED_CSS_ERROR__20 36591 }, 36592 large: /* @__PURE__ */ css("padding:", space(6), " ", space(8), ";" + (false ? "" : ";label:large;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJXIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */"), 36593 medium: /* @__PURE__ */ css("padding:", space(4), " ", space(6), ";" + (false ? "" : ";label:medium;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JZIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */"), 36594 small: /* @__PURE__ */ css("padding:", space(4), ";" + (false ? "" : ";label:small;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJXIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */"), 36595 xSmall: xSmallCardPadding, 36596 // The `extraSmall` size is not officially documented, but the following styles 36597 // are kept for legacy reasons to support older values of the `size` prop. 36598 extraSmall: xSmallCardPadding 36599 }; 36600 var getSinglePaddingValue = (size3) => { 36601 switch (size3) { 36602 case "xSmall": 36603 return space(2); 36604 case "small": 36605 return space(4); 36606 case "medium": 36607 return space(6); 36608 case "large": 36609 return space(8); 36610 case "none": 36611 return "0"; 36612 default: 36613 return space(6); 36614 } 36615 }; 36616 var getPaddingBySize = (size3) => { 36617 if (typeof size3 === "string") { 36618 return cardPaddings[size3]; 36619 } 36620 if (size3) { 36621 const { 36622 blockStart, 36623 blockEnd, 36624 inlineStart, 36625 inlineEnd 36626 } = size3; 36627 return /* @__PURE__ */ css("padding-block-start:", getSinglePaddingValue(blockStart), ";padding-block-end:", getSinglePaddingValue(blockEnd), ";padding-inline-start:", getSinglePaddingValue(inlineStart), ";padding-inline-end:", getSinglePaddingValue(inlineEnd), ";" + (false ? "" : ";label:getPaddingBySize;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImdldC1wYWRkaW5nLWJ5LXNpemUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRZIiwiZmlsZSI6ImdldC1wYWRkaW5nLWJ5LXNpemUudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MsIHR5cGUgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBQcm9wcywgU2l6ZVRva2VuIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuY29uc3QgeFNtYWxsQ2FyZFBhZGRpbmcgPSBjc3NgXG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBjYXJkUGFkZGluZ3MgPSB7XG5cdG5vbmU6IGNzc2Bcblx0XHRwYWRkaW5nOiAwO1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA2ICkgfSAkeyBzcGFjZSggOCApIH07XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHNwYWNlKCA0ICkgfSAkeyBzcGFjZSggNiApIH07XG5cdGAsXG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHR4U21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxuXHQvLyBUaGUgYGV4dHJhU21hbGxgIHNpemUgaXMgbm90IG9mZmljaWFsbHkgZG9jdW1lbnRlZCwgYnV0IHRoZSBmb2xsb3dpbmcgc3R5bGVzXG5cdC8vIGFyZSBrZXB0IGZvciBsZWdhY3kgcmVhc29ucyB0byBzdXBwb3J0IG9sZGVyIHZhbHVlcyBvZiB0aGUgYHNpemVgIHByb3AuXG5cdGV4dHJhU21hbGw6IHhTbWFsbENhcmRQYWRkaW5nLFxufTtcblxuY29uc3QgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlID0gKCBzaXplOiBTaXplVG9rZW4gKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IHtcblx0c3dpdGNoICggc2l6ZSApIHtcblx0XHRjYXNlICd4U21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCAyICk7XG5cdFx0Y2FzZSAnc21hbGwnOlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA0ICk7XG5cdFx0Y2FzZSAnbWVkaXVtJzpcblx0XHRcdHJldHVybiBzcGFjZSggNiApO1xuXHRcdGNhc2UgJ2xhcmdlJzpcblx0XHRcdHJldHVybiBzcGFjZSggOCApO1xuXHRcdGNhc2UgJ25vbmUnOlxuXHRcdFx0cmV0dXJuICcwJztcblx0XHRkZWZhdWx0OlxuXHRcdFx0cmV0dXJuIHNwYWNlKCA2ICk7XG5cdH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nQnlTaXplID0gKCBzaXplOiBQcm9wc1sgJ3NpemUnIF0gKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG5cdC8vIEhhbmRsZSBzdHJpbmctYmFzZWQgc2l6ZXMgKGJvdGggc3RhbmRhcmQgYW5kIGRlcHJlY2F0ZWQpXG5cdGlmICggdHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICkge1xuXHRcdHJldHVybiBjYXJkUGFkZGluZ3NbIHNpemUgYXMgU2l6ZVRva2VuIF07XG5cdH1cblxuXHRpZiAoIHNpemUgKSB7XG5cdFx0Y29uc3QgeyBibG9ja1N0YXJ0LCBibG9ja0VuZCwgaW5saW5lU3RhcnQsIGlubGluZUVuZCB9ID0gc2l6ZTtcblx0XHRyZXR1cm4gY3NzYFxuXHRcdFx0cGFkZGluZy1ibG9jay1zdGFydDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBibG9ja1N0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctYmxvY2stZW5kOiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGJsb2NrRW5kICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBnZXRTaW5nbGVQYWRkaW5nVmFsdWUoIGlubGluZVN0YXJ0ICkgfTtcblx0XHRcdHBhZGRpbmctaW5saW5lLWVuZDogJHsgZ2V0U2luZ2xlUGFkZGluZ1ZhbHVlKCBpbmxpbmVFbmQgKSB9O1xuXHRcdGA7XG5cdH1cblxuXHQvLyBEZWZhdWx0IHRvIG1lZGl1bSBpZiBubyBzaXplIGlzIHByb3ZpZGVkXG5cdHJldHVybiBjYXJkUGFkZGluZ3MubWVkaXVtO1xufTtcbiJdfQ== */"); 36628 } 36629 return cardPaddings.medium; 36630 }; 36631 36632 // packages/components/build-module/card/card-body/hook.js 36633 function useCardBody(props) { 36634 const { 36635 className: className2, 36636 isScrollable = false, 36637 isShady = false, 36638 size: size3 = "medium", 36639 ...otherProps 36640 } = useContextSystem(props, "CardBody"); 36641 const cx3 = useCx(); 36642 const classes = (0, import_element101.useMemo)(() => cx3( 36643 Body, 36644 borderRadius, 36645 getPaddingBySize(size3), 36646 isShady && shady, 36647 // This classname is added for legacy compatibility reasons. 36648 "components-card__body", 36649 className2 36650 ), [className2, cx3, isShady, size3]); 36651 return { 36652 ...otherProps, 36653 className: classes, 36654 isScrollable 36655 }; 36656 } 36657 36658 // packages/components/build-module/card/card-body/component.js 36659 var import_jsx_runtime164 = __toESM(require_jsx_runtime()); 36660 function UnconnectedCardBody(props, forwardedRef) { 36661 const { 36662 isScrollable, 36663 ...otherProps 36664 } = useCardBody(props); 36665 if (isScrollable) { 36666 return /* @__PURE__ */ (0, import_jsx_runtime164.jsx)(component_default28, { 36667 ...otherProps, 36668 ref: forwardedRef 36669 }); 36670 } 36671 return /* @__PURE__ */ (0, import_jsx_runtime164.jsx)(component_default, { 36672 ...otherProps, 36673 ref: forwardedRef 36674 }); 36675 } 36676 var CardBody = contextConnect(UnconnectedCardBody, "CardBody"); 36677 var component_default29 = CardBody; 36678 36679 // packages/components/build-module/divider/styles.js 36680 function _EMOTION_STRINGIFIED_CSS_ERROR__21() { 36681 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 36682 } 36683 var MARGIN_DIRECTIONS = { 36684 vertical: { 36685 start: "marginLeft", 36686 end: "marginRight" 36687 }, 36688 horizontal: { 36689 start: "marginTop", 36690 end: "marginBottom" 36691 } 36692 }; 36693 var renderMargin = ({ 36694 "aria-orientation": orientation = "horizontal", 36695 margin, 36696 marginStart, 36697 marginEnd 36698 }) => /* @__PURE__ */ css(rtl({ 36699 [MARGIN_DIRECTIONS[orientation].start]: space(marginStart !== null && marginStart !== void 0 ? marginStart : margin), 36700 [MARGIN_DIRECTIONS[orientation].end]: space(marginEnd !== null && marginEnd !== void 0 ? marginEnd : margin) 36701 })(), false ? "" : ";label:renderMargin;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQ0MiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRGl2aWRlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IE1BUkdJTl9ESVJFQ1RJT05TOiBSZWNvcmQ8XG5cdE5vbk51bGxhYmxlPCBEaXZpZGVyUHJvcHNbICdvcmllbnRhdGlvbicgXSA+LFxuXHRSZWNvcmQ8ICdzdGFydCcgfCAnZW5kJywgc3RyaW5nID5cbj4gPSB7XG5cdHZlcnRpY2FsOiB7XG5cdFx0c3RhcnQ6ICdtYXJnaW5MZWZ0Jyxcblx0XHRlbmQ6ICdtYXJnaW5SaWdodCcsXG5cdH0sXG5cdGhvcml6b250YWw6IHtcblx0XHRzdGFydDogJ21hcmdpblRvcCcsXG5cdFx0ZW5kOiAnbWFyZ2luQm90dG9tJyxcblx0fSxcbn07XG5cbi8vIFJlbmRlcnMgdGhlIGNvcnJlY3QgbWFyZ2lucyBnaXZlbiB0aGUgRGl2aWRlcidzIGBvcmllbnRhdGlvbmAgYW5kIHRoZSB3cml0aW5nIGRpcmVjdGlvbi5cbi8vIFdoZW4gYm90aCB0aGUgZ2VuZXJpYyBgbWFyZ2luYCBhbmQgdGhlIHNwZWNpZmljIGBtYXJnaW5TdGFydHxtYXJnaW5FbmRgIHByb3BzIGFyZSBkZWZpbmVkLFxuLy8gdGhlIGxhdHRlciB3aWxsIHRha2UgcHJpb3JpdHkuXG5jb25zdCByZW5kZXJNYXJnaW4gPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcblx0bWFyZ2luLFxuXHRtYXJnaW5TdGFydCxcblx0bWFyZ2luRW5kLFxufTogRGl2aWRlclByb3BzICkgPT5cblx0Y3NzKFxuXHRcdHJ0bCgge1xuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5zdGFydCBdOiBzcGFjZShcblx0XHRcdFx0bWFyZ2luU3RhcnQgPz8gbWFyZ2luXG5cdFx0XHQpLFxuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5lbmQgXTogc3BhY2UoXG5cdFx0XHRcdG1hcmdpbkVuZCA/PyBtYXJnaW5cblx0XHRcdCksXG5cdFx0fSApKClcblx0KTtcblxuY29uc3QgcmVuZGVyRGlzcGxheSA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcblx0XHQ/IGNzcyggeyBkaXNwbGF5OiAnaW5saW5lJyB9IClcblx0XHQ6IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IHJlbmRlckJvcmRlciA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0WyBvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdib3JkZXJSaWdodCcgOiAnYm9yZGVyQm90dG9tJyBdOlxuXHRcdFx0JzFweCBzb2xpZCBjdXJyZW50Q29sb3InLFxuXHR9ICk7XG59O1xuXG5jb25zdCByZW5kZXJTaXplID0gKCB7XG5cdCdhcmlhLW9yaWVudGF0aW9uJzogb3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCcsXG59OiBEaXZpZGVyUHJvcHMgKSA9PlxuXHRjc3MoIHtcblx0XHRoZWlnaHQ6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnID8gJ2F1dG8nIDogMCxcblx0XHR3aWR0aDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCcgPyAwIDogJ2F1dG8nLFxuXHR9ICk7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyVmlldyA9IHN0eWxlZC5ocjwgRGl2aWRlclByb3BzID5gXG5cdGJvcmRlcjogMDtcblx0bWFyZ2luOiAwO1xuXG5cdCR7IHJlbmRlckRpc3BsYXkgfVxuXHQkeyByZW5kZXJCb3JkZXIgfVxuXHQkeyByZW5kZXJTaXplIH1cblx0JHsgcmVuZGVyTWFyZ2luIH1cbmA7XG4iXX0= */"); 36702 var _ref7 = false ? { 36703 name: "1u4hpl4", 36704 styles: "display:inline" 36705 } : { 36706 name: "9r0jm7-renderDisplay", 36707 styles: "display:inline;label:renderDisplay;", 36708 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtREkiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRGl2aWRlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IE1BUkdJTl9ESVJFQ1RJT05TOiBSZWNvcmQ8XG5cdE5vbk51bGxhYmxlPCBEaXZpZGVyUHJvcHNbICdvcmllbnRhdGlvbicgXSA+LFxuXHRSZWNvcmQ8ICdzdGFydCcgfCAnZW5kJywgc3RyaW5nID5cbj4gPSB7XG5cdHZlcnRpY2FsOiB7XG5cdFx0c3RhcnQ6ICdtYXJnaW5MZWZ0Jyxcblx0XHRlbmQ6ICdtYXJnaW5SaWdodCcsXG5cdH0sXG5cdGhvcml6b250YWw6IHtcblx0XHRzdGFydDogJ21hcmdpblRvcCcsXG5cdFx0ZW5kOiAnbWFyZ2luQm90dG9tJyxcblx0fSxcbn07XG5cbi8vIFJlbmRlcnMgdGhlIGNvcnJlY3QgbWFyZ2lucyBnaXZlbiB0aGUgRGl2aWRlcidzIGBvcmllbnRhdGlvbmAgYW5kIHRoZSB3cml0aW5nIGRpcmVjdGlvbi5cbi8vIFdoZW4gYm90aCB0aGUgZ2VuZXJpYyBgbWFyZ2luYCBhbmQgdGhlIHNwZWNpZmljIGBtYXJnaW5TdGFydHxtYXJnaW5FbmRgIHByb3BzIGFyZSBkZWZpbmVkLFxuLy8gdGhlIGxhdHRlciB3aWxsIHRha2UgcHJpb3JpdHkuXG5jb25zdCByZW5kZXJNYXJnaW4gPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcblx0bWFyZ2luLFxuXHRtYXJnaW5TdGFydCxcblx0bWFyZ2luRW5kLFxufTogRGl2aWRlclByb3BzICkgPT5cblx0Y3NzKFxuXHRcdHJ0bCgge1xuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5zdGFydCBdOiBzcGFjZShcblx0XHRcdFx0bWFyZ2luU3RhcnQgPz8gbWFyZ2luXG5cdFx0XHQpLFxuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5lbmQgXTogc3BhY2UoXG5cdFx0XHRcdG1hcmdpbkVuZCA/PyBtYXJnaW5cblx0XHRcdCksXG5cdFx0fSApKClcblx0KTtcblxuY29uc3QgcmVuZGVyRGlzcGxheSA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcblx0XHQ/IGNzcyggeyBkaXNwbGF5OiAnaW5saW5lJyB9IClcblx0XHQ6IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IHJlbmRlckJvcmRlciA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0WyBvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdib3JkZXJSaWdodCcgOiAnYm9yZGVyQm90dG9tJyBdOlxuXHRcdFx0JzFweCBzb2xpZCBjdXJyZW50Q29sb3InLFxuXHR9ICk7XG59O1xuXG5jb25zdCByZW5kZXJTaXplID0gKCB7XG5cdCdhcmlhLW9yaWVudGF0aW9uJzogb3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCcsXG59OiBEaXZpZGVyUHJvcHMgKSA9PlxuXHRjc3MoIHtcblx0XHRoZWlnaHQ6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnID8gJ2F1dG8nIDogMCxcblx0XHR3aWR0aDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCcgPyAwIDogJ2F1dG8nLFxuXHR9ICk7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyVmlldyA9IHN0eWxlZC5ocjwgRGl2aWRlclByb3BzID5gXG5cdGJvcmRlcjogMDtcblx0bWFyZ2luOiAwO1xuXG5cdCR7IHJlbmRlckRpc3BsYXkgfVxuXHQkeyByZW5kZXJCb3JkZXIgfVxuXHQkeyByZW5kZXJTaXplIH1cblx0JHsgcmVuZGVyTWFyZ2luIH1cbmA7XG4iXX0= */", 36709 toString: _EMOTION_STRINGIFIED_CSS_ERROR__21 36710 }; 36711 var renderDisplay = ({ 36712 "aria-orientation": orientation = "horizontal" 36713 }) => { 36714 return orientation === "vertical" ? _ref7 : void 0; 36715 }; 36716 var renderBorder = ({ 36717 "aria-orientation": orientation = "horizontal" 36718 }) => { 36719 return /* @__PURE__ */ css({ 36720 [orientation === "vertical" ? "borderRight" : "borderBottom"]: "1px solid currentColor" 36721 }, false ? "" : ";label:renderBorder;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRFEiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRGl2aWRlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IE1BUkdJTl9ESVJFQ1RJT05TOiBSZWNvcmQ8XG5cdE5vbk51bGxhYmxlPCBEaXZpZGVyUHJvcHNbICdvcmllbnRhdGlvbicgXSA+LFxuXHRSZWNvcmQ8ICdzdGFydCcgfCAnZW5kJywgc3RyaW5nID5cbj4gPSB7XG5cdHZlcnRpY2FsOiB7XG5cdFx0c3RhcnQ6ICdtYXJnaW5MZWZ0Jyxcblx0XHRlbmQ6ICdtYXJnaW5SaWdodCcsXG5cdH0sXG5cdGhvcml6b250YWw6IHtcblx0XHRzdGFydDogJ21hcmdpblRvcCcsXG5cdFx0ZW5kOiAnbWFyZ2luQm90dG9tJyxcblx0fSxcbn07XG5cbi8vIFJlbmRlcnMgdGhlIGNvcnJlY3QgbWFyZ2lucyBnaXZlbiB0aGUgRGl2aWRlcidzIGBvcmllbnRhdGlvbmAgYW5kIHRoZSB3cml0aW5nIGRpcmVjdGlvbi5cbi8vIFdoZW4gYm90aCB0aGUgZ2VuZXJpYyBgbWFyZ2luYCBhbmQgdGhlIHNwZWNpZmljIGBtYXJnaW5TdGFydHxtYXJnaW5FbmRgIHByb3BzIGFyZSBkZWZpbmVkLFxuLy8gdGhlIGxhdHRlciB3aWxsIHRha2UgcHJpb3JpdHkuXG5jb25zdCByZW5kZXJNYXJnaW4gPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcblx0bWFyZ2luLFxuXHRtYXJnaW5TdGFydCxcblx0bWFyZ2luRW5kLFxufTogRGl2aWRlclByb3BzICkgPT5cblx0Y3NzKFxuXHRcdHJ0bCgge1xuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5zdGFydCBdOiBzcGFjZShcblx0XHRcdFx0bWFyZ2luU3RhcnQgPz8gbWFyZ2luXG5cdFx0XHQpLFxuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5lbmQgXTogc3BhY2UoXG5cdFx0XHRcdG1hcmdpbkVuZCA/PyBtYXJnaW5cblx0XHRcdCksXG5cdFx0fSApKClcblx0KTtcblxuY29uc3QgcmVuZGVyRGlzcGxheSA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcblx0XHQ/IGNzcyggeyBkaXNwbGF5OiAnaW5saW5lJyB9IClcblx0XHQ6IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IHJlbmRlckJvcmRlciA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0WyBvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdib3JkZXJSaWdodCcgOiAnYm9yZGVyQm90dG9tJyBdOlxuXHRcdFx0JzFweCBzb2xpZCBjdXJyZW50Q29sb3InLFxuXHR9ICk7XG59O1xuXG5jb25zdCByZW5kZXJTaXplID0gKCB7XG5cdCdhcmlhLW9yaWVudGF0aW9uJzogb3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCcsXG59OiBEaXZpZGVyUHJvcHMgKSA9PlxuXHRjc3MoIHtcblx0XHRoZWlnaHQ6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnID8gJ2F1dG8nIDogMCxcblx0XHR3aWR0aDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCcgPyAwIDogJ2F1dG8nLFxuXHR9ICk7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyVmlldyA9IHN0eWxlZC5ocjwgRGl2aWRlclByb3BzID5gXG5cdGJvcmRlcjogMDtcblx0bWFyZ2luOiAwO1xuXG5cdCR7IHJlbmRlckRpc3BsYXkgfVxuXHQkeyByZW5kZXJCb3JkZXIgfVxuXHQkeyByZW5kZXJTaXplIH1cblx0JHsgcmVuZGVyTWFyZ2luIH1cbmA7XG4iXX0= */"); 36722 }; 36723 var renderSize = ({ 36724 "aria-orientation": orientation = "horizontal" 36725 }) => /* @__PURE__ */ css({ 36726 height: orientation === "vertical" ? "auto" : 0, 36727 width: orientation === "vertical" ? 0 : "auto" 36728 }, false ? "" : ";label:renderSize;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRGl2aWRlclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IE1BUkdJTl9ESVJFQ1RJT05TOiBSZWNvcmQ8XG5cdE5vbk51bGxhYmxlPCBEaXZpZGVyUHJvcHNbICdvcmllbnRhdGlvbicgXSA+LFxuXHRSZWNvcmQ8ICdzdGFydCcgfCAnZW5kJywgc3RyaW5nID5cbj4gPSB7XG5cdHZlcnRpY2FsOiB7XG5cdFx0c3RhcnQ6ICdtYXJnaW5MZWZ0Jyxcblx0XHRlbmQ6ICdtYXJnaW5SaWdodCcsXG5cdH0sXG5cdGhvcml6b250YWw6IHtcblx0XHRzdGFydDogJ21hcmdpblRvcCcsXG5cdFx0ZW5kOiAnbWFyZ2luQm90dG9tJyxcblx0fSxcbn07XG5cbi8vIFJlbmRlcnMgdGhlIGNvcnJlY3QgbWFyZ2lucyBnaXZlbiB0aGUgRGl2aWRlcidzIGBvcmllbnRhdGlvbmAgYW5kIHRoZSB3cml0aW5nIGRpcmVjdGlvbi5cbi8vIFdoZW4gYm90aCB0aGUgZ2VuZXJpYyBgbWFyZ2luYCBhbmQgdGhlIHNwZWNpZmljIGBtYXJnaW5TdGFydHxtYXJnaW5FbmRgIHByb3BzIGFyZSBkZWZpbmVkLFxuLy8gdGhlIGxhdHRlciB3aWxsIHRha2UgcHJpb3JpdHkuXG5jb25zdCByZW5kZXJNYXJnaW4gPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcblx0bWFyZ2luLFxuXHRtYXJnaW5TdGFydCxcblx0bWFyZ2luRW5kLFxufTogRGl2aWRlclByb3BzICkgPT5cblx0Y3NzKFxuXHRcdHJ0bCgge1xuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5zdGFydCBdOiBzcGFjZShcblx0XHRcdFx0bWFyZ2luU3RhcnQgPz8gbWFyZ2luXG5cdFx0XHQpLFxuXHRcdFx0WyBNQVJHSU5fRElSRUNUSU9OU1sgb3JpZW50YXRpb24gXS5lbmQgXTogc3BhY2UoXG5cdFx0XHRcdG1hcmdpbkVuZCA/PyBtYXJnaW5cblx0XHRcdCksXG5cdFx0fSApKClcblx0KTtcblxuY29uc3QgcmVuZGVyRGlzcGxheSA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcblx0XHQ/IGNzcyggeyBkaXNwbGF5OiAnaW5saW5lJyB9IClcblx0XHQ6IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IHJlbmRlckJvcmRlciA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT4ge1xuXHRyZXR1cm4gY3NzKCB7XG5cdFx0WyBvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdib3JkZXJSaWdodCcgOiAnYm9yZGVyQm90dG9tJyBdOlxuXHRcdFx0JzFweCBzb2xpZCBjdXJyZW50Q29sb3InLFxuXHR9ICk7XG59O1xuXG5jb25zdCByZW5kZXJTaXplID0gKCB7XG5cdCdhcmlhLW9yaWVudGF0aW9uJzogb3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCcsXG59OiBEaXZpZGVyUHJvcHMgKSA9PlxuXHRjc3MoIHtcblx0XHRoZWlnaHQ6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnID8gJ2F1dG8nIDogMCxcblx0XHR3aWR0aDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCcgPyAwIDogJ2F1dG8nLFxuXHR9ICk7XG5cbmV4cG9ydCBjb25zdCBEaXZpZGVyVmlldyA9IHN0eWxlZC5ocjwgRGl2aWRlclByb3BzID5gXG5cdGJvcmRlcjogMDtcblx0bWFyZ2luOiAwO1xuXG5cdCR7IHJlbmRlckRpc3BsYXkgfVxuXHQkeyByZW5kZXJCb3JkZXIgfVxuXHQkeyByZW5kZXJTaXplIH1cblx0JHsgcmVuZGVyTWFyZ2luIH1cbmA7XG4iXX0= */"); 36729 var DividerView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("hr", false ? { 36730 target: "e19on6iw0" 36731 } : { 36732 target: "e19on6iw0", 36733 label: "DividerView" 36734 })("border:0;margin:0;", renderDisplay, " ", renderBorder, " ", renderSize, " ", renderMargin, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RW9EIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBydGwgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IERpdmlkZXJQcm9wcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5jb25zdCBNQVJHSU5fRElSRUNUSU9OUzogUmVjb3JkPFxuXHROb25OdWxsYWJsZTwgRGl2aWRlclByb3BzWyAnb3JpZW50YXRpb24nIF0gPixcblx0UmVjb3JkPCAnc3RhcnQnIHwgJ2VuZCcsIHN0cmluZyA+XG4+ID0ge1xuXHR2ZXJ0aWNhbDoge1xuXHRcdHN0YXJ0OiAnbWFyZ2luTGVmdCcsXG5cdFx0ZW5kOiAnbWFyZ2luUmlnaHQnLFxuXHR9LFxuXHRob3Jpem9udGFsOiB7XG5cdFx0c3RhcnQ6ICdtYXJnaW5Ub3AnLFxuXHRcdGVuZDogJ21hcmdpbkJvdHRvbScsXG5cdH0sXG59O1xuXG4vLyBSZW5kZXJzIHRoZSBjb3JyZWN0IG1hcmdpbnMgZ2l2ZW4gdGhlIERpdmlkZXIncyBgb3JpZW50YXRpb25gIGFuZCB0aGUgd3JpdGluZyBkaXJlY3Rpb24uXG4vLyBXaGVuIGJvdGggdGhlIGdlbmVyaWMgYG1hcmdpbmAgYW5kIHRoZSBzcGVjaWZpYyBgbWFyZ2luU3RhcnR8bWFyZ2luRW5kYCBwcm9wcyBhcmUgZGVmaW5lZCxcbi8vIHRoZSBsYXR0ZXIgd2lsbCB0YWtlIHByaW9yaXR5LlxuY29uc3QgcmVuZGVyTWFyZ2luID0gKCB7XG5cdCdhcmlhLW9yaWVudGF0aW9uJzogb3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCcsXG5cdG1hcmdpbixcblx0bWFyZ2luU3RhcnQsXG5cdG1hcmdpbkVuZCxcbn06IERpdmlkZXJQcm9wcyApID0+XG5cdGNzcyhcblx0XHRydGwoIHtcblx0XHRcdFsgTUFSR0lOX0RJUkVDVElPTlNbIG9yaWVudGF0aW9uIF0uc3RhcnQgXTogc3BhY2UoXG5cdFx0XHRcdG1hcmdpblN0YXJ0ID8/IG1hcmdpblxuXHRcdFx0KSxcblx0XHRcdFsgTUFSR0lOX0RJUkVDVElPTlNbIG9yaWVudGF0aW9uIF0uZW5kIF06IHNwYWNlKFxuXHRcdFx0XHRtYXJnaW5FbmQgPz8gbWFyZ2luXG5cdFx0XHQpLFxuXHRcdH0gKSgpXG5cdCk7XG5cbmNvbnN0IHJlbmRlckRpc3BsYXkgPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcbn06IERpdmlkZXJQcm9wcyApID0+IHtcblx0cmV0dXJuIG9yaWVudGF0aW9uID09PSAndmVydGljYWwnXG5cdFx0PyBjc3MoIHsgZGlzcGxheTogJ2lubGluZScgfSApXG5cdFx0OiB1bmRlZmluZWQ7XG59O1xuXG5jb25zdCByZW5kZXJCb3JkZXIgPSAoIHtcblx0J2FyaWEtb3JpZW50YXRpb24nOiBvcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJyxcbn06IERpdmlkZXJQcm9wcyApID0+IHtcblx0cmV0dXJuIGNzcygge1xuXHRcdFsgb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCcgPyAnYm9yZGVyUmlnaHQnIDogJ2JvcmRlckJvdHRvbScgXTpcblx0XHRcdCcxcHggc29saWQgY3VycmVudENvbG9yJyxcblx0fSApO1xufTtcblxuY29uc3QgcmVuZGVyU2l6ZSA9ICgge1xuXHQnYXJpYS1vcmllbnRhdGlvbic6IG9yaWVudGF0aW9uID0gJ2hvcml6b250YWwnLFxufTogRGl2aWRlclByb3BzICkgPT5cblx0Y3NzKCB7XG5cdFx0aGVpZ2h0OiBvcmllbnRhdGlvbiA9PT0gJ3ZlcnRpY2FsJyA/ICdhdXRvJyA6IDAsXG5cdFx0d2lkdGg6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnID8gMCA6ICdhdXRvJyxcblx0fSApO1xuXG5leHBvcnQgY29uc3QgRGl2aWRlclZpZXcgPSBzdHlsZWQuaHI8IERpdmlkZXJQcm9wcyA+YFxuXHRib3JkZXI6IDA7XG5cdG1hcmdpbjogMDtcblxuXHQkeyByZW5kZXJEaXNwbGF5IH1cblx0JHsgcmVuZGVyQm9yZGVyIH1cblx0JHsgcmVuZGVyU2l6ZSB9XG5cdCR7IHJlbmRlck1hcmdpbiB9XG5gO1xuIl19 */")); 36735 36736 // packages/components/build-module/divider/component.js 36737 var import_jsx_runtime165 = __toESM(require_jsx_runtime()); 36738 function UnconnectedDivider(props, forwardedRef) { 36739 const contextProps = useContextSystem(props, "Divider"); 36740 return /* @__PURE__ */ (0, import_jsx_runtime165.jsx)(Separator, { 36741 render: /* @__PURE__ */ (0, import_jsx_runtime165.jsx)(DividerView, {}), 36742 ...contextProps, 36743 ref: forwardedRef 36744 }); 36745 } 36746 var Divider2 = contextConnect(UnconnectedDivider, "Divider"); 36747 var component_default30 = Divider2; 36748 36749 // packages/components/build-module/card/card-divider/hook.js 36750 var import_element102 = __toESM(require_element()); 36751 function useCardDivider(props) { 36752 const { 36753 className: className2, 36754 ...otherProps 36755 } = useContextSystem(props, "CardDivider"); 36756 const cx3 = useCx(); 36757 const classes = (0, import_element102.useMemo)(() => cx3( 36758 Divider, 36759 borderColor, 36760 // This classname is added for legacy compatibility reasons. 36761 "components-card__divider", 36762 className2 36763 ), [className2, cx3]); 36764 return { 36765 ...otherProps, 36766 className: classes 36767 }; 36768 } 36769 36770 // packages/components/build-module/card/card-divider/component.js 36771 var import_jsx_runtime166 = __toESM(require_jsx_runtime()); 36772 function UnconnectedCardDivider(props, forwardedRef) { 36773 const dividerProps = useCardDivider(props); 36774 return /* @__PURE__ */ (0, import_jsx_runtime166.jsx)(component_default30, { 36775 ...dividerProps, 36776 ref: forwardedRef 36777 }); 36778 } 36779 var CardDivider = contextConnect(UnconnectedCardDivider, "CardDivider"); 36780 var component_default31 = CardDivider; 36781 36782 // packages/components/build-module/card/card-footer/hook.js 36783 var import_element103 = __toESM(require_element()); 36784 function useCardFooter(props) { 36785 const { 36786 className: className2, 36787 justify, 36788 isBorderless = false, 36789 isShady = false, 36790 size: size3 = "medium", 36791 ...otherProps 36792 } = useContextSystem(props, "CardFooter"); 36793 const cx3 = useCx(); 36794 const classes = (0, import_element103.useMemo)(() => cx3( 36795 Footer, 36796 borderRadius, 36797 borderColor, 36798 getPaddingBySize(size3), 36799 isBorderless && borderless, 36800 isShady && shady, 36801 // This classname is added for legacy compatibility reasons. 36802 "components-card__footer", 36803 className2 36804 ), [className2, cx3, isBorderless, isShady, size3]); 36805 return { 36806 ...otherProps, 36807 className: classes, 36808 justify 36809 }; 36810 } 36811 36812 // packages/components/build-module/card/card-footer/component.js 36813 var import_jsx_runtime167 = __toESM(require_jsx_runtime()); 36814 function UnconnectedCardFooter(props, forwardedRef) { 36815 const footerProps = useCardFooter(props); 36816 return /* @__PURE__ */ (0, import_jsx_runtime167.jsx)(component_default3, { 36817 ...footerProps, 36818 ref: forwardedRef 36819 }); 36820 } 36821 var CardFooter = contextConnect(UnconnectedCardFooter, "CardFooter"); 36822 var component_default32 = CardFooter; 36823 36824 // packages/components/build-module/card/card-header/hook.js 36825 var import_element104 = __toESM(require_element()); 36826 function useCardHeader(props) { 36827 const { 36828 className: className2, 36829 isBorderless = false, 36830 isShady = false, 36831 size: size3 = "medium", 36832 ...otherProps 36833 } = useContextSystem(props, "CardHeader"); 36834 const cx3 = useCx(); 36835 const classes = (0, import_element104.useMemo)(() => cx3( 36836 Header, 36837 borderRadius, 36838 borderColor, 36839 getPaddingBySize(size3), 36840 isBorderless && borderless, 36841 isShady && shady, 36842 // This classname is added for legacy compatibility reasons. 36843 "components-card__header", 36844 className2 36845 ), [className2, cx3, isBorderless, isShady, size3]); 36846 return { 36847 ...otherProps, 36848 className: classes 36849 }; 36850 } 36851 36852 // packages/components/build-module/card/card-header/component.js 36853 var import_jsx_runtime168 = __toESM(require_jsx_runtime()); 36854 function UnconnectedCardHeader(props, forwardedRef) { 36855 const headerProps = useCardHeader(props); 36856 return /* @__PURE__ */ (0, import_jsx_runtime168.jsx)(component_default3, { 36857 ...headerProps, 36858 ref: forwardedRef 36859 }); 36860 } 36861 var CardHeader = contextConnect(UnconnectedCardHeader, "CardHeader"); 36862 var component_default33 = CardHeader; 36863 36864 // packages/components/build-module/card/card-media/hook.js 36865 var import_element105 = __toESM(require_element()); 36866 function useCardMedia(props) { 36867 const { 36868 className: className2, 36869 ...otherProps 36870 } = useContextSystem(props, "CardMedia"); 36871 const cx3 = useCx(); 36872 const classes = (0, import_element105.useMemo)(() => cx3( 36873 Media, 36874 borderRadius, 36875 // This classname is added for legacy compatibility reasons. 36876 "components-card__media", 36877 className2 36878 ), [className2, cx3]); 36879 return { 36880 ...otherProps, 36881 className: classes 36882 }; 36883 } 36884 36885 // packages/components/build-module/card/card-media/component.js 36886 var import_jsx_runtime169 = __toESM(require_jsx_runtime()); 36887 function UnconnectedCardMedia(props, forwardedRef) { 36888 const cardMediaProps = useCardMedia(props); 36889 return /* @__PURE__ */ (0, import_jsx_runtime169.jsx)(component_default, { 36890 ...cardMediaProps, 36891 ref: forwardedRef 36892 }); 36893 } 36894 var CardMedia = contextConnect(UnconnectedCardMedia, "CardMedia"); 36895 var component_default34 = CardMedia; 36896 36897 // packages/components/build-module/checkbox-control/index.js 36898 var import_element106 = __toESM(require_element()); 36899 var import_compose42 = __toESM(require_compose()); 36900 var import_deprecated12 = __toESM(require_deprecated()); 36901 var import_jsx_runtime170 = __toESM(require_jsx_runtime()); 36902 function CheckboxControl(props) { 36903 const { 36904 // Prevent passing this to `input`. 36905 __nextHasNoMarginBottom: _, 36906 label, 36907 className: className2, 36908 heading, 36909 checked, 36910 indeterminate, 36911 help, 36912 id: idProp, 36913 onChange, 36914 onClick, 36915 ...additionalProps 36916 } = props; 36917 if (heading) { 36918 (0, import_deprecated12.default)("`heading` prop in `CheckboxControl`", { 36919 alternative: "a separate element to implement a heading", 36920 since: "5.8" 36921 }); 36922 } 36923 const [showCheckedIcon, setShowCheckedIcon] = (0, import_element106.useState)(false); 36924 const [showIndeterminateIcon, setShowIndeterminateIcon] = (0, import_element106.useState)(false); 36925 const ref = (0, import_compose42.useRefEffect)((node2) => { 36926 if (!node2) { 36927 return; 36928 } 36929 node2.indeterminate = !!indeterminate; 36930 setShowCheckedIcon(node2.matches(":checked")); 36931 setShowIndeterminateIcon(node2.matches(":indeterminate")); 36932 }, [checked, indeterminate]); 36933 const id3 = (0, import_compose42.useInstanceId)(CheckboxControl, "inspector-checkbox-control", idProp); 36934 const onChangeValue = (event) => onChange(event.target.checked); 36935 return /* @__PURE__ */ (0, import_jsx_runtime170.jsx)(base_control_default, { 36936 label: heading, 36937 id: id3, 36938 help: help && /* @__PURE__ */ (0, import_jsx_runtime170.jsx)("span", { 36939 className: "components-checkbox-control__help", 36940 children: help 36941 }), 36942 className: clsx_default("components-checkbox-control", className2), 36943 children: /* @__PURE__ */ (0, import_jsx_runtime170.jsxs)(component_default9, { 36944 spacing: 0, 36945 justify: "start", 36946 alignment: "top", 36947 children: [/* @__PURE__ */ (0, import_jsx_runtime170.jsxs)("span", { 36948 className: "components-checkbox-control__input-container", 36949 children: [/* @__PURE__ */ (0, import_jsx_runtime170.jsx)("input", { 36950 ref, 36951 id: id3, 36952 className: "components-checkbox-control__input", 36953 type: "checkbox", 36954 value: "1", 36955 onChange: onChangeValue, 36956 checked, 36957 "aria-describedby": !!help ? id3 + "__help" : void 0, 36958 onClick: (event) => { 36959 event.currentTarget.focus(); 36960 onClick?.(event); 36961 }, 36962 ...additionalProps 36963 }), showIndeterminateIcon ? /* @__PURE__ */ (0, import_jsx_runtime170.jsx)(icon_default2, { 36964 icon: reset_default, 36965 className: "components-checkbox-control__indeterminate", 36966 role: "presentation" 36967 }) : null, showCheckedIcon ? /* @__PURE__ */ (0, import_jsx_runtime170.jsx)(icon_default2, { 36968 icon: check_default, 36969 className: "components-checkbox-control__checked", 36970 role: "presentation" 36971 }) : null] 36972 }), label && /* @__PURE__ */ (0, import_jsx_runtime170.jsx)("label", { 36973 className: "components-checkbox-control__label", 36974 htmlFor: id3, 36975 children: label 36976 })] 36977 }) 36978 }); 36979 } 36980 var checkbox_control_default = CheckboxControl; 36981 36982 // packages/components/build-module/clipboard-button/index.js 36983 var import_element107 = __toESM(require_element()); 36984 var import_compose43 = __toESM(require_compose()); 36985 var import_deprecated13 = __toESM(require_deprecated()); 36986 var import_jsx_runtime171 = __toESM(require_jsx_runtime()); 36987 var TIMEOUT = 4e3; 36988 function ClipboardButton({ 36989 className: className2, 36990 children, 36991 onCopy, 36992 onFinishCopy, 36993 text, 36994 ...buttonProps 36995 }) { 36996 (0, import_deprecated13.default)("wp.components.ClipboardButton", { 36997 since: "5.8", 36998 alternative: "wp.compose.useCopyToClipboard" 36999 }); 37000 const timeoutIdRef = (0, import_element107.useRef)(); 37001 const ref = (0, import_compose43.useCopyToClipboard)(text, () => { 37002 onCopy(); 37003 if (timeoutIdRef.current) { 37004 clearTimeout(timeoutIdRef.current); 37005 } 37006 if (onFinishCopy) { 37007 timeoutIdRef.current = setTimeout(() => onFinishCopy(), TIMEOUT); 37008 } 37009 }); 37010 (0, import_element107.useEffect)(() => { 37011 return () => { 37012 if (timeoutIdRef.current) { 37013 clearTimeout(timeoutIdRef.current); 37014 } 37015 }; 37016 }, []); 37017 const classes = clsx_default("components-clipboard-button", className2); 37018 const focusOnCopyEventTarget = (event) => { 37019 event.target.focus(); 37020 }; 37021 return /* @__PURE__ */ (0, import_jsx_runtime171.jsx)(button_default, { 37022 ...buttonProps, 37023 className: classes, 37024 ref, 37025 onCopy: focusOnCopyEventTarget, 37026 children 37027 }); 37028 } 37029 37030 // packages/components/build-module/palette-edit/index.js 37031 var import_element116 = __toESM(require_element()); 37032 var import_i18n35 = __toESM(require_i18n()); 37033 var import_compose46 = __toESM(require_compose()); 37034 37035 // packages/components/build-module/item-group/item/hook.js 37036 var import_element109 = __toESM(require_element()); 37037 37038 // packages/components/build-module/item-group/styles.js 37039 function _EMOTION_STRINGIFIED_CSS_ERROR__22() { 37040 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 37041 } 37042 var unstyledButton = (as) => { 37043 return /* @__PURE__ */ css("font-size:", font("default.fontSize"), ";font-family:inherit;appearance:none;border:1px solid transparent;cursor:pointer;background:none;text-align:start;text-decoration:", as === "a" ? "none" : void 0, ";svg,path{fill:currentColor;}&:hover{color:", COLORS.theme.accent, ";}&:focus{box-shadow:none;outline:none;}&:focus-visible{box-shadow:0 0 0 var( --wp-admin-border-width-focus ) ", COLORS.theme.accent, ";outline:2px solid transparent;outline-offset:0;}" + (false ? "" : ";label:unstyledButton;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXVyIsImZpbGUiOiJzdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IENPTkZJRywgQ09MT1JTLCBmb250IH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3QgdW5zdHlsZWRCdXR0b24gPSAoIGFzOiAnYScgfCAnYnV0dG9uJyApID0+IHtcblx0cmV0dXJuIGNzc2Bcblx0XHRmb250LXNpemU6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRTaXplJyApIH07XG5cdFx0Zm9udC1mYW1pbHk6IGluaGVyaXQ7XG5cdFx0YXBwZWFyYW5jZTogbm9uZTtcblx0XHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRjdXJzb3I6IHBvaW50ZXI7XG5cdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHR0ZXh0LWFsaWduOiBzdGFydDtcblx0XHR0ZXh0LWRlY29yYXRpb246ICR7IGFzID09PSAnYScgPyAnbm9uZScgOiB1bmRlZmluZWQgfTtcblxuXHRcdHN2Zyxcblx0XHRwYXRoIHtcblx0XHRcdGZpbGw6IGN1cnJlbnRDb2xvcjtcblx0XHR9XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cyB7XG5cdFx0XHRib3gtc2hhZG93OiBub25lO1xuXHRcdFx0b3V0bGluZTogbm9uZTtcblx0XHR9XG5cblx0XHQmOmZvY3VzLXZpc2libGUge1xuXHRcdFx0Ym94LXNoYWRvdzogMCAwIDAgdmFyKCAtLXdwLWFkbWluLWJvcmRlci13aWR0aC1mb2N1cyApXG5cdFx0XHRcdCR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHRcdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRcdFx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdFx0b3V0bGluZS1vZmZzZXQ6IDA7XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IGl0ZW1XcmFwcGVyID0gY3NzYFxuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5gO1xuXG5leHBvcnQgY29uc3QgaXRlbSA9IGNzc2Bcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRtYXJnaW46IDA7XG5cdGNvbG9yOiBpbmhlcml0O1xuYDtcblxuZXhwb3J0IGNvbnN0IGJvcmRlcmVkID0gY3NzYFxuXHRib3JkZXI6IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgc2VwYXJhdGVkID0gY3NzYFxuXHQ+ICo6bm90KCBtYXJxdWVlICkgPiAqIHtcblx0XHRib3JkZXItYm90dG9tOiAxcHggc29saWQgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJDb2xvciB9O1xuXHR9XG5cblx0PiAqOmxhc3Qtb2YtdHlwZSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b20tY29sb3I6IHRyYW5zcGFyZW50O1xuXHR9XG5gO1xuXG5jb25zdCBib3JkZXJSYWRpdXMgPSBDT05GSUcucmFkaXVzU21hbGw7XG5cbmV4cG9ydCBjb25zdCBzcGFjZWRBcm91bmQgPSBjc3NgXG5cdGJvcmRlci1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHJvdW5kZWQgPSBjc3NgXG5cdGJvcmRlci1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXG5cdD4gKjpmaXJzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLXRvcC1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5cblx0PiAqOmxhc3Qtb2YtdHlwZSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHRcdGJvcmRlci1ib3R0b20tcmlnaHQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0fVxuYDtcblxuY29uc3QgYmFzZUZvbnRIZWlnaHQgPSBgY2FsYygkeyBDT05GSUcuZm9udFNpemUgfSAqICR7IENPTkZJRy5mb250TGluZUhlaWdodEJhc2UgfSlgO1xuXG4vKlxuICogTWF0aDpcbiAqIC0gVXNlIHRoZSBkZXNpcmVkIGhlaWdodCBhcyB0aGUgYmFzZSB2YWx1ZVxuICogLSBTdWJ0cmFjdCB0aGUgY29tcHV0ZWQgaGVpZ2h0IG9mIChkZWZhdWx0KSB0ZXh0XG4gKiAtIFN1YnRyYWN0IHRoZSBlZmZlY3RzIG9mIGJvcmRlclxuICogLSBEaXZpZGUgdGhlIGNhbGN1bGF0ZWQgbnVtYmVyIGJ5IDIsIGluIG9yZGVyIHRvIGdldCBhbiBpbmRpdmlkdWFsIHRvcC9ib3R0b20gcGFkZGluZ1xuICovXG5jb25zdCBwYWRkaW5nWSA9IGBjYWxjKCgkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWVNtYWxsID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0U21hbGwgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuY29uc3QgcGFkZGluZ1lMYXJnZSA9IGBjYWxjKCgkeyBDT05GSUcuY29udHJvbEhlaWdodExhcmdlIH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcblxuZXhwb3J0IGNvbnN0IGl0ZW1TaXplcyA9IHtcblx0c21hbGw6IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWVNtYWxsIH0gJHsgQ09ORklHLmNvbnRyb2xQYWRkaW5nWFNtYWxsIH1weDtcblx0YCxcblx0bWVkaXVtOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1kgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYIH1weDtcblx0YCxcblx0bGFyZ2U6IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWUxhcmdlIH0gJHsgQ09ORklHLmNvbnRyb2xQYWRkaW5nWExhcmdlIH1weDtcblx0YCxcbn07XG4iXX0= */"); 37044 }; 37045 var itemWrapper = false ? { 37046 name: "1bcj5ek", 37047 styles: "width:100%;display:block" 37048 } : { 37049 name: "dcjs67-itemWrapper", 37050 styles: "width:100%;display:block;label:itemWrapper;", 37051 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QzhCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */", 37052 toString: _EMOTION_STRINGIFIED_CSS_ERROR__22 37053 }; 37054 var item = false ? { 37055 name: "150ruhm", 37056 styles: "box-sizing:border-box;width:100%;display:block;margin:0;color:inherit" 37057 } : { 37058 name: "1izz8ne-item", 37059 styles: "box-sizing:border-box;width:100%;display:block;margin:0;color:inherit;label:item;", 37060 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRHVCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */", 37061 toString: _EMOTION_STRINGIFIED_CSS_ERROR__22 37062 }; 37063 var bordered = /* @__PURE__ */ css("border:1px solid ", config_values_default.surfaceBorderColor, ";" + (false ? "" : ";label:bordered;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRDJCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */"); 37064 var separated = /* @__PURE__ */ css(">*:not( marquee )>*{border-bottom:1px solid ", config_values_default.surfaceBorderColor, ";}>*:last-of-type>*{border-bottom-color:transparent;}" + (false ? "" : ";label:separated;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RDRCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */"); 37065 var borderRadius2 = config_values_default.radiusSmall; 37066 var spacedAround = /* @__PURE__ */ css("border-radius:", borderRadius2, ";" + (false ? "" : ";label:spacedAround;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRStCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */"); 37067 var rounded2 = /* @__PURE__ */ css("border-radius:", borderRadius2, ";>*:first-of-type>*{border-top-left-radius:", borderRadius2, ";border-top-right-radius:", borderRadius2, ";}>*:last-of-type>*{border-bottom-left-radius:", borderRadius2, ";border-bottom-right-radius:", borderRadius2, ";}" + (false ? "" : ";label:rounded;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4RTBCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHLCBDT0xPUlMsIGZvbnQgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB1bnN0eWxlZEJ1dHRvbiA9ICggYXM6ICdhJyB8ICdidXR0b24nICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0XHRmb250LWZhbWlseTogaW5oZXJpdDtcblx0XHRhcHBlYXJhbmNlOiBub25lO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRcdGN1cnNvcjogcG9pbnRlcjtcblx0XHRiYWNrZ3JvdW5kOiBub25lO1xuXHRcdHRleHQtYWxpZ246IHN0YXJ0O1xuXHRcdHRleHQtZGVjb3JhdGlvbjogJHsgYXMgPT09ICdhJyA/ICdub25lJyA6IHVuZGVmaW5lZCB9O1xuXG5cdFx0c3ZnLFxuXHRcdHBhdGgge1xuXHRcdFx0ZmlsbDogY3VycmVudENvbG9yO1xuXHRcdH1cblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0XHR9XG5cblx0XHQmOmZvY3VzIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvdXRsaW5lOiBub25lO1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMtdmlzaWJsZSB7XG5cdFx0XHRib3gtc2hhZG93OiAwIDAgMCB2YXIoIC0td3AtYWRtaW4tYm9yZGVyLXdpZHRoLWZvY3VzIClcblx0XHRcdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdFx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdFx0XHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRvdXRsaW5lLW9mZnNldDogMDtcblx0XHR9XG5cdGA7XG59O1xuXG5leHBvcnQgY29uc3QgaXRlbVdyYXBwZXIgPSBjc3NgXG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBpdGVtID0gY3NzYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdG1hcmdpbjogMDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuXG5leHBvcnQgY29uc3QgYm9yZGVyZWQgPSBjc3NgXG5cdGJvcmRlcjogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBzZXBhcmF0ZWQgPSBjc3NgXG5cdD4gKjpub3QoIG1hcnF1ZWUgKSA+ICoge1xuXHRcdGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAkeyBDT05GSUcuc3VyZmFjZUJvcmRlckNvbG9yIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdH1cbmA7XG5cbmNvbnN0IGJvcmRlclJhZGl1cyA9IENPTkZJRy5yYWRpdXNTbWFsbDtcblxuZXhwb3J0IGNvbnN0IHNwYWNlZEFyb3VuZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5gO1xuXG5leHBvcnQgY29uc3Qgcm91bmRlZCA9IGNzc2Bcblx0Ym9yZGVyLXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cblx0PiAqOmZpcnN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cblxuXHQ+ICo6bGFzdC1vZi10eXBlID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdFx0Ym9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHR9XG5gO1xuXG5jb25zdCBiYXNlRm9udEhlaWdodCA9IGBjYWxjKCR7IENPTkZJRy5mb250U2l6ZSB9ICogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9KWA7XG5cbi8qXG4gKiBNYXRoOlxuICogLSBVc2UgdGhlIGRlc2lyZWQgaGVpZ2h0IGFzIHRoZSBiYXNlIHZhbHVlXG4gKiAtIFN1YnRyYWN0IHRoZSBjb21wdXRlZCBoZWlnaHQgb2YgKGRlZmF1bHQpIHRleHRcbiAqIC0gU3VidHJhY3QgdGhlIGVmZmVjdHMgb2YgYm9yZGVyXG4gKiAtIERpdmlkZSB0aGUgY2FsY3VsYXRlZCBudW1iZXIgYnkgMiwgaW4gb3JkZXIgdG8gZ2V0IGFuIGluZGl2aWR1YWwgdG9wL2JvdHRvbSBwYWRkaW5nXG4gKi9cbmNvbnN0IHBhZGRpbmdZID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0IH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZU21hbGwgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRTbWFsbCB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5jb25zdCBwYWRkaW5nWUxhcmdlID0gYGNhbGMoKCR7IENPTkZJRy5jb250cm9sSGVpZ2h0TGFyZ2UgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuXG5leHBvcnQgY29uc3QgaXRlbVNpemVzID0ge1xuXHRzbWFsbDogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZU21hbGwgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYU21hbGwgfXB4O1xuXHRgLFxuXHRtZWRpdW06IGNzc2Bcblx0XHRwYWRkaW5nOiAkeyBwYWRkaW5nWSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1ggfXB4O1xuXHRgLFxuXHRsYXJnZTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZTGFyZ2UgfSAkeyBDT05GSUcuY29udHJvbFBhZGRpbmdYTGFyZ2UgfXB4O1xuXHRgLFxufTtcbiJdfQ== */"); 37068 var baseFontHeight = `calc($config_values_default.fontSize} * $config_values_default.fontLineHeightBase})`; 37069 var paddingY = `calc(($config_values_default.controlHeight} - $baseFontHeight} - 2px) / 2)`; 37070 var paddingYSmall = `calc(($config_values_default.controlHeightSmall} - $baseFontHeight} - 2px) / 2)`; 37071 var paddingYLarge = `calc(($config_values_default.controlHeightLarge} - $baseFontHeight} - 2px) / 2)`; 37072 var itemSizes = { 37073 small: /* @__PURE__ */ css("padding:", paddingYSmall, " ", config_values_default.controlPaddingXSmall, "px;" + (false ? "" : ";label:small;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwR1ciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUywgZm9udCB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IHVuc3R5bGVkQnV0dG9uID0gKCBhczogJ2EnIHwgJ2J1dHRvbicgKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdGJhY2tncm91bmQ6IG5vbmU7XG5cdFx0dGV4dC1hbGlnbjogc3RhcnQ7XG5cdFx0dGV4dC1kZWNvcmF0aW9uOiAkeyBhcyA9PT0gJ2EnID8gJ25vbmUnIDogdW5kZWZpbmVkIH07XG5cblx0XHRzdmcsXG5cdFx0cGF0aCB7XG5cdFx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdFx0fVxuXG5cdFx0Jjpob3ZlciB7XG5cdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMge1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdG91dGxpbmU6IG5vbmU7XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy12aXNpYmxlIHtcblx0XHRcdGJveC1zaGFkb3c6IDAgMCAwIHZhciggLS13cC1hZG1pbi1ib3JkZXItd2lkdGgtZm9jdXMgKVxuXHRcdFx0XHQkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHQvLyBXaW5kb3dzIGhpZ2ggY29udHJhc3QgbW9kZS5cblx0XHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBpdGVtV3JhcHBlciA9IGNzc2Bcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuYDtcblxuZXhwb3J0IGNvbnN0IGl0ZW0gPSBjc3NgXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luOiAwO1xuXHRjb2xvcjogaW5oZXJpdDtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJlZCA9IGNzc2Bcblx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNlcGFyYXRlZCA9IGNzc2Bcblx0PiAqOm5vdCggbWFycXVlZSApID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWNvbG9yOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgYm9yZGVyUmFkaXVzID0gQ09ORklHLnJhZGl1c1NtYWxsO1xuXG5leHBvcnQgY29uc3Qgc3BhY2VkQXJvdW5kID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblxuXHQ+ICo6Zmlyc3Qtb2YtdHlwZSA+ICoge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHRcdGJvcmRlci10b3AtcmlnaHQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cbmA7XG5cbmNvbnN0IGJhc2VGb250SGVpZ2h0ID0gYGNhbGMoJHsgQ09ORklHLmZvbnRTaXplIH0gKiAkeyBDT05GSUcuZm9udExpbmVIZWlnaHRCYXNlIH0pYDtcblxuLypcbiAqIE1hdGg6XG4gKiAtIFVzZSB0aGUgZGVzaXJlZCBoZWlnaHQgYXMgdGhlIGJhc2UgdmFsdWVcbiAqIC0gU3VidHJhY3QgdGhlIGNvbXB1dGVkIGhlaWdodCBvZiAoZGVmYXVsdCkgdGV4dFxuICogLSBTdWJ0cmFjdCB0aGUgZWZmZWN0cyBvZiBib3JkZXJcbiAqIC0gRGl2aWRlIHRoZSBjYWxjdWxhdGVkIG51bWJlciBieSAyLCBpbiBvcmRlciB0byBnZXQgYW4gaW5kaXZpZHVhbCB0b3AvYm90dG9tIHBhZGRpbmdcbiAqL1xuY29uc3QgcGFkZGluZ1kgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHQgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuY29uc3QgcGFkZGluZ1lTbWFsbCA9IGBjYWxjKCgkeyBDT05GSUcuY29udHJvbEhlaWdodFNtYWxsIH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZTGFyZ2UgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRMYXJnZSB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5cbmV4cG9ydCBjb25zdCBpdGVtU2l6ZXMgPSB7XG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lTbWFsbCB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCB9cHg7XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZIH0gJHsgQ09ORklHLmNvbnRyb2xQYWRkaW5nWCB9cHg7XG5cdGAsXG5cdGxhcmdlOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lMYXJnZSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hMYXJnZSB9cHg7XG5cdGAsXG59O1xuIl19 */"), 37074 medium: /* @__PURE__ */ css("padding:", paddingY, " ", config_values_default.controlPaddingX, "px;" + (false ? "" : ";label:medium;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2R1kiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUywgZm9udCB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IHVuc3R5bGVkQnV0dG9uID0gKCBhczogJ2EnIHwgJ2J1dHRvbicgKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdGJhY2tncm91bmQ6IG5vbmU7XG5cdFx0dGV4dC1hbGlnbjogc3RhcnQ7XG5cdFx0dGV4dC1kZWNvcmF0aW9uOiAkeyBhcyA9PT0gJ2EnID8gJ25vbmUnIDogdW5kZWZpbmVkIH07XG5cblx0XHRzdmcsXG5cdFx0cGF0aCB7XG5cdFx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdFx0fVxuXG5cdFx0Jjpob3ZlciB7XG5cdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMge1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdG91dGxpbmU6IG5vbmU7XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy12aXNpYmxlIHtcblx0XHRcdGJveC1zaGFkb3c6IDAgMCAwIHZhciggLS13cC1hZG1pbi1ib3JkZXItd2lkdGgtZm9jdXMgKVxuXHRcdFx0XHQkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHQvLyBXaW5kb3dzIGhpZ2ggY29udHJhc3QgbW9kZS5cblx0XHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBpdGVtV3JhcHBlciA9IGNzc2Bcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuYDtcblxuZXhwb3J0IGNvbnN0IGl0ZW0gPSBjc3NgXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luOiAwO1xuXHRjb2xvcjogaW5oZXJpdDtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJlZCA9IGNzc2Bcblx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNlcGFyYXRlZCA9IGNzc2Bcblx0PiAqOm5vdCggbWFycXVlZSApID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWNvbG9yOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgYm9yZGVyUmFkaXVzID0gQ09ORklHLnJhZGl1c1NtYWxsO1xuXG5leHBvcnQgY29uc3Qgc3BhY2VkQXJvdW5kID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblxuXHQ+ICo6Zmlyc3Qtb2YtdHlwZSA+ICoge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHRcdGJvcmRlci10b3AtcmlnaHQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cbmA7XG5cbmNvbnN0IGJhc2VGb250SGVpZ2h0ID0gYGNhbGMoJHsgQ09ORklHLmZvbnRTaXplIH0gKiAkeyBDT05GSUcuZm9udExpbmVIZWlnaHRCYXNlIH0pYDtcblxuLypcbiAqIE1hdGg6XG4gKiAtIFVzZSB0aGUgZGVzaXJlZCBoZWlnaHQgYXMgdGhlIGJhc2UgdmFsdWVcbiAqIC0gU3VidHJhY3QgdGhlIGNvbXB1dGVkIGhlaWdodCBvZiAoZGVmYXVsdCkgdGV4dFxuICogLSBTdWJ0cmFjdCB0aGUgZWZmZWN0cyBvZiBib3JkZXJcbiAqIC0gRGl2aWRlIHRoZSBjYWxjdWxhdGVkIG51bWJlciBieSAyLCBpbiBvcmRlciB0byBnZXQgYW4gaW5kaXZpZHVhbCB0b3AvYm90dG9tIHBhZGRpbmdcbiAqL1xuY29uc3QgcGFkZGluZ1kgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHQgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuY29uc3QgcGFkZGluZ1lTbWFsbCA9IGBjYWxjKCgkeyBDT05GSUcuY29udHJvbEhlaWdodFNtYWxsIH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZTGFyZ2UgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRMYXJnZSB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5cbmV4cG9ydCBjb25zdCBpdGVtU2l6ZXMgPSB7XG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lTbWFsbCB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCB9cHg7XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZIH0gJHsgQ09ORklHLmNvbnRyb2xQYWRkaW5nWCB9cHg7XG5cdGAsXG5cdGxhcmdlOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lMYXJnZSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hMYXJnZSB9cHg7XG5cdGAsXG59O1xuIl19 */"), 37075 large: /* @__PURE__ */ css("padding:", paddingYLarge, " ", config_values_default.controlPaddingXLarge, "px;" + (false ? "" : ";label:large;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSFciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT05GSUcsIENPTE9SUywgZm9udCB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IHVuc3R5bGVkQnV0dG9uID0gKCBhczogJ2EnIHwgJ2J1dHRvbicgKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXHRcdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRcdGFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0Y3Vyc29yOiBwb2ludGVyO1xuXHRcdGJhY2tncm91bmQ6IG5vbmU7XG5cdFx0dGV4dC1hbGlnbjogc3RhcnQ7XG5cdFx0dGV4dC1kZWNvcmF0aW9uOiAkeyBhcyA9PT0gJ2EnID8gJ25vbmUnIDogdW5kZWZpbmVkIH07XG5cblx0XHRzdmcsXG5cdFx0cGF0aCB7XG5cdFx0XHRmaWxsOiBjdXJyZW50Q29sb3I7XG5cdFx0fVxuXG5cdFx0Jjpob3ZlciB7XG5cdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdH1cblxuXHRcdCY6Zm9jdXMge1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdG91dGxpbmU6IG5vbmU7XG5cdFx0fVxuXG5cdFx0Jjpmb2N1cy12aXNpYmxlIHtcblx0XHRcdGJveC1zaGFkb3c6IDAgMCAwIHZhciggLS13cC1hZG1pbi1ib3JkZXItd2lkdGgtZm9jdXMgKVxuXHRcdFx0XHQkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdFx0XHQvLyBXaW5kb3dzIGhpZ2ggY29udHJhc3QgbW9kZS5cblx0XHRcdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRcdG91dGxpbmUtb2Zmc2V0OiAwO1xuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBpdGVtV3JhcHBlciA9IGNzc2Bcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuYDtcblxuZXhwb3J0IGNvbnN0IGl0ZW0gPSBjc3NgXG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHdpZHRoOiAxMDAlO1xuXHRkaXNwbGF5OiBibG9jaztcblx0bWFyZ2luOiAwO1xuXHRjb2xvcjogaW5oZXJpdDtcbmA7XG5cbmV4cG9ydCBjb25zdCBib3JkZXJlZCA9IGNzc2Bcblx0Ym9yZGVyOiAxcHggc29saWQgJHsgQ09ORklHLnN1cmZhY2VCb3JkZXJDb2xvciB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHNlcGFyYXRlZCA9IGNzc2Bcblx0PiAqOm5vdCggbWFycXVlZSApID4gKiB7XG5cdFx0Ym9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7IENPTkZJRy5zdXJmYWNlQm9yZGVyQ29sb3IgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWNvbG9yOiB0cmFuc3BhcmVudDtcblx0fVxuYDtcblxuY29uc3QgYm9yZGVyUmFkaXVzID0gQ09ORklHLnJhZGl1c1NtYWxsO1xuXG5leHBvcnQgY29uc3Qgc3BhY2VkQXJvdW5kID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCByb3VuZGVkID0gY3NzYFxuXHRib3JkZXItcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblxuXHQ+ICo6Zmlyc3Qtb2YtdHlwZSA+ICoge1xuXHRcdGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7IGJvcmRlclJhZGl1cyB9O1xuXHRcdGJvcmRlci10b3AtcmlnaHQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0fVxuXG5cdD4gKjpsYXN0LW9mLXR5cGUgPiAqIHtcblx0XHRib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAkeyBib3JkZXJSYWRpdXMgfTtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogJHsgYm9yZGVyUmFkaXVzIH07XG5cdH1cbmA7XG5cbmNvbnN0IGJhc2VGb250SGVpZ2h0ID0gYGNhbGMoJHsgQ09ORklHLmZvbnRTaXplIH0gKiAkeyBDT05GSUcuZm9udExpbmVIZWlnaHRCYXNlIH0pYDtcblxuLypcbiAqIE1hdGg6XG4gKiAtIFVzZSB0aGUgZGVzaXJlZCBoZWlnaHQgYXMgdGhlIGJhc2UgdmFsdWVcbiAqIC0gU3VidHJhY3QgdGhlIGNvbXB1dGVkIGhlaWdodCBvZiAoZGVmYXVsdCkgdGV4dFxuICogLSBTdWJ0cmFjdCB0aGUgZWZmZWN0cyBvZiBib3JkZXJcbiAqIC0gRGl2aWRlIHRoZSBjYWxjdWxhdGVkIG51bWJlciBieSAyLCBpbiBvcmRlciB0byBnZXQgYW4gaW5kaXZpZHVhbCB0b3AvYm90dG9tIHBhZGRpbmdcbiAqL1xuY29uc3QgcGFkZGluZ1kgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHQgfSAtICR7IGJhc2VGb250SGVpZ2h0IH0gLSAycHgpIC8gMilgO1xuY29uc3QgcGFkZGluZ1lTbWFsbCA9IGBjYWxjKCgkeyBDT05GSUcuY29udHJvbEhlaWdodFNtYWxsIH0gLSAkeyBiYXNlRm9udEhlaWdodCB9IC0gMnB4KSAvIDIpYDtcbmNvbnN0IHBhZGRpbmdZTGFyZ2UgPSBgY2FsYygoJHsgQ09ORklHLmNvbnRyb2xIZWlnaHRMYXJnZSB9IC0gJHsgYmFzZUZvbnRIZWlnaHQgfSAtIDJweCkgLyAyKWA7XG5cbmV4cG9ydCBjb25zdCBpdGVtU2l6ZXMgPSB7XG5cdHNtYWxsOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lTbWFsbCB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hTbWFsbCB9cHg7XG5cdGAsXG5cdG1lZGl1bTogY3NzYFxuXHRcdHBhZGRpbmc6ICR7IHBhZGRpbmdZIH0gJHsgQ09ORklHLmNvbnRyb2xQYWRkaW5nWCB9cHg7XG5cdGAsXG5cdGxhcmdlOiBjc3NgXG5cdFx0cGFkZGluZzogJHsgcGFkZGluZ1lMYXJnZSB9ICR7IENPTkZJRy5jb250cm9sUGFkZGluZ1hMYXJnZSB9cHg7XG5cdGAsXG59O1xuIl19 */") 37076 }; 37077 37078 // packages/components/build-module/item-group/context.js 37079 var import_element108 = __toESM(require_element()); 37080 var ItemGroupContext = (0, import_element108.createContext)({ 37081 size: "medium" 37082 }); 37083 ItemGroupContext.displayName = "ItemGroupContext"; 37084 var useItemGroupContext = () => (0, import_element108.useContext)(ItemGroupContext); 37085 37086 // packages/components/build-module/item-group/item/hook.js 37087 function useItem(props) { 37088 const { 37089 as: asProp, 37090 className: className2, 37091 onClick, 37092 role = "listitem", 37093 size: sizeProp, 37094 ...otherProps 37095 } = useContextSystem(props, "Item"); 37096 const { 37097 spacedAround: spacedAround2, 37098 size: contextSize 37099 } = useItemGroupContext(); 37100 const size3 = sizeProp || contextSize; 37101 const as = asProp || (typeof onClick !== "undefined" ? "button" : "div"); 37102 const cx3 = useCx(); 37103 const classes = (0, import_element109.useMemo)(() => cx3((as === "button" || as === "a") && unstyledButton(as), itemSizes[size3] || itemSizes.medium, item, spacedAround2 && spacedAround, className2), [as, className2, cx3, size3, spacedAround2]); 37104 const wrapperClassName = cx3(itemWrapper); 37105 return { 37106 as, 37107 className: classes, 37108 onClick, 37109 wrapperClassName, 37110 role, 37111 ...otherProps 37112 }; 37113 } 37114 37115 // packages/components/build-module/item-group/item/component.js 37116 var import_jsx_runtime172 = __toESM(require_jsx_runtime()); 37117 function UnconnectedItem(props, forwardedRef) { 37118 const { 37119 role, 37120 wrapperClassName, 37121 ...otherProps 37122 } = useItem(props); 37123 return /* @__PURE__ */ (0, import_jsx_runtime172.jsx)("div", { 37124 role, 37125 className: wrapperClassName, 37126 children: /* @__PURE__ */ (0, import_jsx_runtime172.jsx)(component_default, { 37127 ...otherProps, 37128 ref: forwardedRef 37129 }) 37130 }); 37131 } 37132 var Item2 = contextConnect(UnconnectedItem, "Item"); 37133 var component_default35 = Item2; 37134 37135 // packages/components/build-module/item-group/item-group/hook.js 37136 function useItemGroup(props) { 37137 const { 37138 className: className2, 37139 isBordered = false, 37140 isRounded = true, 37141 isSeparated = false, 37142 role = "list", 37143 ...otherProps 37144 } = useContextSystem(props, "ItemGroup"); 37145 const cx3 = useCx(); 37146 const classes = cx3(isBordered && bordered, isSeparated && separated, isRounded && rounded2, className2); 37147 return { 37148 isBordered, 37149 className: classes, 37150 role, 37151 isSeparated, 37152 ...otherProps 37153 }; 37154 } 37155 37156 // packages/components/build-module/item-group/item-group/component.js 37157 var import_jsx_runtime173 = __toESM(require_jsx_runtime()); 37158 function UnconnectedItemGroup(props, forwardedRef) { 37159 const { 37160 isBordered, 37161 isSeparated, 37162 size: sizeProp, 37163 ...otherProps 37164 } = useItemGroup(props); 37165 const { 37166 size: contextSize 37167 } = useItemGroupContext(); 37168 const spacedAround2 = !isBordered && !isSeparated; 37169 const size3 = sizeProp || contextSize; 37170 const contextValue = { 37171 spacedAround: spacedAround2, 37172 size: size3 37173 }; 37174 return /* @__PURE__ */ (0, import_jsx_runtime173.jsx)(ItemGroupContext.Provider, { 37175 value: contextValue, 37176 children: /* @__PURE__ */ (0, import_jsx_runtime173.jsx)(component_default, { 37177 ...otherProps, 37178 ref: forwardedRef 37179 }) 37180 }); 37181 } 37182 var ItemGroup = contextConnect(UnconnectedItemGroup, "ItemGroup"); 37183 var component_default36 = ItemGroup; 37184 37185 // packages/components/build-module/gradient-picker/index.js 37186 var import_i18n34 = __toESM(require_i18n()); 37187 var import_compose45 = __toESM(require_compose()); 37188 var import_element112 = __toESM(require_element()); 37189 37190 // packages/components/build-module/custom-gradient-picker/index.js 37191 var import_i18n33 = __toESM(require_i18n()); 37192 37193 // packages/components/build-module/custom-gradient-picker/gradient-bar/index.js 37194 var import_element111 = __toESM(require_element()); 37195 37196 // packages/components/build-module/custom-gradient-picker/gradient-bar/control-points.js 37197 var import_compose44 = __toESM(require_compose()); 37198 var import_element110 = __toESM(require_element()); 37199 var import_i18n31 = __toESM(require_i18n()); 37200 37201 // packages/components/build-module/custom-gradient-picker/gradient-bar/constants.js 37202 var GRADIENT_MARKERS_WIDTH = 16; 37203 var INSERT_POINT_WIDTH = 16; 37204 var MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT = 10; 37205 var MINIMUM_DISTANCE_BETWEEN_POINTS = 0; 37206 var MINIMUM_SIGNIFICANT_MOVE = 5; 37207 var KEYBOARD_CONTROL_POINT_VARIATION = MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT; 37208 var MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_MARKER = (INSERT_POINT_WIDTH + GRADIENT_MARKERS_WIDTH) / 2; 37209 37210 // packages/components/build-module/custom-gradient-picker/gradient-bar/utils.js 37211 function clampPercent(value) { 37212 return Math.max(0, Math.min(100, value)); 37213 } 37214 function isOverlapping(value, initialIndex, newPosition, minDistance = MINIMUM_DISTANCE_BETWEEN_POINTS) { 37215 const initialPosition = value[initialIndex].position; 37216 const minPosition = Math.min(initialPosition, newPosition); 37217 const maxPosition = Math.max(initialPosition, newPosition); 37218 return value.some(({ 37219 position: position2 37220 }, index2) => { 37221 return index2 !== initialIndex && (Math.abs(position2 - newPosition) < minDistance || minPosition < position2 && position2 < maxPosition); 37222 }); 37223 } 37224 function addControlPoint(points, position2, color2) { 37225 const nextIndex = points.findIndex((point) => point.position > position2); 37226 const newPoint = { 37227 color: color2, 37228 position: position2 37229 }; 37230 const newPoints = points.slice(); 37231 newPoints.splice(nextIndex - 1, 0, newPoint); 37232 return newPoints; 37233 } 37234 function removeControlPoint(points, index2) { 37235 return points.filter((_point, pointIndex) => { 37236 return pointIndex !== index2; 37237 }); 37238 } 37239 function updateControlPoint(points, index2, newPoint) { 37240 const newValue = points.slice(); 37241 newValue[index2] = newPoint; 37242 return newValue; 37243 } 37244 function updateControlPointPosition(points, index2, newPosition) { 37245 if (isOverlapping(points, index2, newPosition)) { 37246 return points; 37247 } 37248 const newPoint = { 37249 ...points[index2], 37250 position: newPosition 37251 }; 37252 return updateControlPoint(points, index2, newPoint); 37253 } 37254 function updateControlPointColor(points, index2, newColor) { 37255 const newPoint = { 37256 ...points[index2], 37257 color: newColor 37258 }; 37259 return updateControlPoint(points, index2, newPoint); 37260 } 37261 function updateControlPointColorByPosition(points, position2, newColor) { 37262 const index2 = points.findIndex((point) => point.position === position2); 37263 return updateControlPointColor(points, index2, newColor); 37264 } 37265 function getHorizontalRelativeGradientPosition(mouseXCoordinate, containerElement) { 37266 if (!containerElement) { 37267 return; 37268 } 37269 const { 37270 x: x2, 37271 width 37272 } = containerElement.getBoundingClientRect(); 37273 const absolutePositionValue = mouseXCoordinate - x2; 37274 return Math.round(clampPercent(absolutePositionValue * 100 / width)); 37275 } 37276 37277 // packages/components/build-module/custom-gradient-picker/gradient-bar/control-points.js 37278 var import_jsx_runtime174 = __toESM(require_jsx_runtime()); 37279 function ControlPointButton({ 37280 isOpen, 37281 position: position2, 37282 color: color2, 37283 ...additionalProps 37284 }) { 37285 const instanceId = (0, import_compose44.useInstanceId)(ControlPointButton); 37286 const descriptionId = `components-custom-gradient-picker__control-point-button-description-$instanceId}`; 37287 return /* @__PURE__ */ (0, import_jsx_runtime174.jsxs)(import_jsx_runtime174.Fragment, { 37288 children: [/* @__PURE__ */ (0, import_jsx_runtime174.jsx)(button_default, { 37289 "aria-label": (0, import_i18n31.sprintf)( 37290 // translators: 1: gradient position e.g: 70. 2: gradient color code e.g: rgb(52,121,151). 37291 (0, import_i18n31.__)("Gradient control point at position %1$d%% with color code %2$s."), 37292 position2, 37293 color2 37294 ), 37295 "aria-describedby": descriptionId, 37296 "aria-haspopup": "true", 37297 "aria-expanded": isOpen, 37298 __next40pxDefaultSize: true, 37299 className: clsx_default("components-custom-gradient-picker__control-point-button", { 37300 "is-active": isOpen 37301 }), 37302 ...additionalProps 37303 }), /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(component_default2, { 37304 id: descriptionId, 37305 children: (0, import_i18n31.__)("Use your left or right arrow keys or drag and drop with the mouse to change the gradient position. Press the button to change the color or remove the control point.") 37306 })] 37307 }); 37308 } 37309 function GradientColorPickerDropdown({ 37310 isRenderedInSidebar, 37311 className: className2, 37312 ...props 37313 }) { 37314 const popoverProps = (0, import_element110.useMemo)(() => ({ 37315 placement: "bottom", 37316 offset: 8, 37317 // Disabling resize as it would otherwise cause the popover to show 37318 // scrollbars while dragging the color picker's handle close to the 37319 // popover edge. 37320 resize: false 37321 }), []); 37322 const mergedClassName = clsx_default("components-custom-gradient-picker__control-point-dropdown", className2); 37323 return /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(CustomColorPickerDropdown, { 37324 isRenderedInSidebar, 37325 popoverProps, 37326 className: mergedClassName, 37327 ...props 37328 }); 37329 } 37330 function ControlPoints({ 37331 disableRemove, 37332 disableAlpha, 37333 gradientPickerDomRef, 37334 ignoreMarkerPosition, 37335 value: controlPoints, 37336 onChange, 37337 onStartControlPointChange, 37338 onStopControlPointChange, 37339 __experimentalIsRenderedInSidebar 37340 }) { 37341 const controlPointMoveStateRef = (0, import_element110.useRef)(); 37342 const onMouseMove = (event) => { 37343 if (controlPointMoveStateRef.current === void 0 || gradientPickerDomRef.current === null) { 37344 return; 37345 } 37346 const relativePosition = getHorizontalRelativeGradientPosition(event.clientX, gradientPickerDomRef.current); 37347 const { 37348 initialPosition, 37349 index: index2, 37350 significantMoveHappened 37351 } = controlPointMoveStateRef.current; 37352 if (!significantMoveHappened && Math.abs(initialPosition - relativePosition) >= MINIMUM_SIGNIFICANT_MOVE) { 37353 controlPointMoveStateRef.current.significantMoveHappened = true; 37354 } 37355 onChange(updateControlPointPosition(controlPoints, index2, relativePosition)); 37356 }; 37357 const cleanEventListeners = () => { 37358 if (window && window.removeEventListener && controlPointMoveStateRef.current && controlPointMoveStateRef.current.listenersActivated) { 37359 window.removeEventListener("mousemove", onMouseMove); 37360 window.removeEventListener("mouseup", cleanEventListeners); 37361 onStopControlPointChange(); 37362 controlPointMoveStateRef.current.listenersActivated = false; 37363 } 37364 }; 37365 const cleanEventListenersRef = (0, import_element110.useRef)(); 37366 cleanEventListenersRef.current = cleanEventListeners; 37367 (0, import_element110.useEffect)(() => { 37368 return () => { 37369 cleanEventListenersRef.current?.(); 37370 }; 37371 }, []); 37372 return /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(import_jsx_runtime174.Fragment, { 37373 children: controlPoints.map((point, index2) => { 37374 const initialPosition = point?.position; 37375 return ignoreMarkerPosition !== initialPosition && /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(GradientColorPickerDropdown, { 37376 isRenderedInSidebar: __experimentalIsRenderedInSidebar, 37377 onClose: onStopControlPointChange, 37378 renderToggle: ({ 37379 isOpen, 37380 onToggle 37381 }) => /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(ControlPointButton, { 37382 onClick: () => { 37383 if (controlPointMoveStateRef.current && controlPointMoveStateRef.current.significantMoveHappened) { 37384 return; 37385 } 37386 if (isOpen) { 37387 onStopControlPointChange(); 37388 } else { 37389 onStartControlPointChange(); 37390 } 37391 onToggle(); 37392 }, 37393 onMouseDown: () => { 37394 if (window && window.addEventListener) { 37395 controlPointMoveStateRef.current = { 37396 initialPosition, 37397 index: index2, 37398 significantMoveHappened: false, 37399 listenersActivated: true 37400 }; 37401 onStartControlPointChange(); 37402 window.addEventListener("mousemove", onMouseMove); 37403 window.addEventListener("mouseup", cleanEventListeners); 37404 } 37405 }, 37406 onKeyDown: (event) => { 37407 if (event.code === "ArrowLeft") { 37408 event.stopPropagation(); 37409 onChange(updateControlPointPosition(controlPoints, index2, clampPercent(point.position - KEYBOARD_CONTROL_POINT_VARIATION))); 37410 } else if (event.code === "ArrowRight") { 37411 event.stopPropagation(); 37412 onChange(updateControlPointPosition(controlPoints, index2, clampPercent(point.position + KEYBOARD_CONTROL_POINT_VARIATION))); 37413 } 37414 }, 37415 isOpen, 37416 position: point.position, 37417 color: point.color 37418 }, index2), 37419 renderContent: ({ 37420 onClose 37421 }) => /* @__PURE__ */ (0, import_jsx_runtime174.jsxs)(dropdown_content_wrapper_default, { 37422 paddingSize: "none", 37423 children: [/* @__PURE__ */ (0, import_jsx_runtime174.jsx)(LegacyAdapter, { 37424 enableAlpha: !disableAlpha, 37425 color: point.color, 37426 onChange: (color2) => { 37427 onChange(updateControlPointColor(controlPoints, index2, w(color2).toRgbString())); 37428 } 37429 }), !disableRemove && controlPoints.length > 2 && /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(component_default9, { 37430 className: "components-custom-gradient-picker__remove-control-point-wrapper", 37431 alignment: "center", 37432 children: /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(button_default, { 37433 onClick: () => { 37434 onChange(removeControlPoint(controlPoints, index2)); 37435 onClose(); 37436 }, 37437 variant: "link", 37438 children: (0, import_i18n31.__)("Remove Control Point") 37439 }) 37440 })] 37441 }), 37442 style: { 37443 left: `$point.position}%`, 37444 transform: "translateX( -50% )" 37445 } 37446 }, index2); 37447 }) 37448 }); 37449 } 37450 function InsertPoint({ 37451 value: controlPoints, 37452 onChange, 37453 onOpenInserter, 37454 onCloseInserter, 37455 insertPosition, 37456 disableAlpha, 37457 __experimentalIsRenderedInSidebar 37458 }) { 37459 const [alreadyInsertedPoint, setAlreadyInsertedPoint] = (0, import_element110.useState)(false); 37460 return /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(GradientColorPickerDropdown, { 37461 isRenderedInSidebar: __experimentalIsRenderedInSidebar, 37462 className: "components-custom-gradient-picker__inserter", 37463 onClose: () => { 37464 onCloseInserter(); 37465 }, 37466 renderToggle: ({ 37467 isOpen, 37468 onToggle 37469 }) => /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(button_default, { 37470 __next40pxDefaultSize: true, 37471 "aria-expanded": isOpen, 37472 "aria-haspopup": "true", 37473 onClick: () => { 37474 if (isOpen) { 37475 onCloseInserter(); 37476 } else { 37477 setAlreadyInsertedPoint(false); 37478 onOpenInserter(); 37479 } 37480 onToggle(); 37481 }, 37482 className: "components-custom-gradient-picker__insert-point-dropdown", 37483 icon: plus_default 37484 }), 37485 renderContent: () => /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(dropdown_content_wrapper_default, { 37486 paddingSize: "none", 37487 children: /* @__PURE__ */ (0, import_jsx_runtime174.jsx)(LegacyAdapter, { 37488 enableAlpha: !disableAlpha, 37489 onChange: (color2) => { 37490 if (!alreadyInsertedPoint) { 37491 onChange(addControlPoint(controlPoints, insertPosition, w(color2).toRgbString())); 37492 setAlreadyInsertedPoint(true); 37493 } else { 37494 onChange(updateControlPointColorByPosition(controlPoints, insertPosition, w(color2).toRgbString())); 37495 } 37496 } 37497 }) 37498 }), 37499 style: insertPosition !== null ? { 37500 left: `$insertPosition}%`, 37501 transform: "translateX( -50% )" 37502 } : void 0 37503 }); 37504 } 37505 ControlPoints.InsertPoint = InsertPoint; 37506 var control_points_default = ControlPoints; 37507 37508 // packages/components/build-module/custom-gradient-picker/gradient-bar/index.js 37509 var import_jsx_runtime175 = __toESM(require_jsx_runtime()); 37510 var customGradientBarReducer = (state, action) => { 37511 switch (action.type) { 37512 case "MOVE_INSERTER": 37513 if (state.id === "IDLE" || state.id === "MOVING_INSERTER") { 37514 return { 37515 id: "MOVING_INSERTER", 37516 insertPosition: action.insertPosition 37517 }; 37518 } 37519 break; 37520 case "STOP_INSERTER_MOVE": 37521 if (state.id === "MOVING_INSERTER") { 37522 return { 37523 id: "IDLE" 37524 }; 37525 } 37526 break; 37527 case "OPEN_INSERTER": 37528 if (state.id === "MOVING_INSERTER") { 37529 return { 37530 id: "INSERTING_CONTROL_POINT", 37531 insertPosition: state.insertPosition 37532 }; 37533 } 37534 break; 37535 case "CLOSE_INSERTER": 37536 if (state.id === "INSERTING_CONTROL_POINT") { 37537 return { 37538 id: "IDLE" 37539 }; 37540 } 37541 break; 37542 case "START_CONTROL_CHANGE": 37543 if (state.id === "IDLE") { 37544 return { 37545 id: "MOVING_CONTROL_POINT" 37546 }; 37547 } 37548 break; 37549 case "STOP_CONTROL_CHANGE": 37550 if (state.id === "MOVING_CONTROL_POINT") { 37551 return { 37552 id: "IDLE" 37553 }; 37554 } 37555 break; 37556 } 37557 return state; 37558 }; 37559 var customGradientBarReducerInitialState = { 37560 id: "IDLE" 37561 }; 37562 function CustomGradientBar({ 37563 background: background2, 37564 hasGradient, 37565 value: controlPoints, 37566 onChange, 37567 disableInserter = false, 37568 disableAlpha = false, 37569 __experimentalIsRenderedInSidebar = false 37570 }) { 37571 const gradientMarkersContainerDomRef = (0, import_element111.useRef)(null); 37572 const [gradientBarState, gradientBarStateDispatch] = (0, import_element111.useReducer)(customGradientBarReducer, customGradientBarReducerInitialState); 37573 const onMouseEnterAndMove = (event) => { 37574 if (!gradientMarkersContainerDomRef.current) { 37575 return; 37576 } 37577 const insertPosition = getHorizontalRelativeGradientPosition(event.clientX, gradientMarkersContainerDomRef.current); 37578 if (controlPoints.some(({ 37579 position: position2 37580 }) => { 37581 return Math.abs(insertPosition - position2) < MINIMUM_DISTANCE_BETWEEN_INSERTER_AND_POINT; 37582 })) { 37583 if (gradientBarState.id === "MOVING_INSERTER") { 37584 gradientBarStateDispatch({ 37585 type: "STOP_INSERTER_MOVE" 37586 }); 37587 } 37588 return; 37589 } 37590 gradientBarStateDispatch({ 37591 type: "MOVE_INSERTER", 37592 insertPosition 37593 }); 37594 }; 37595 const onMouseLeave = () => { 37596 gradientBarStateDispatch({ 37597 type: "STOP_INSERTER_MOVE" 37598 }); 37599 }; 37600 const isMovingInserter = gradientBarState.id === "MOVING_INSERTER"; 37601 const isInsertingControlPoint = gradientBarState.id === "INSERTING_CONTROL_POINT"; 37602 return /* @__PURE__ */ (0, import_jsx_runtime175.jsxs)("div", { 37603 className: clsx_default("components-custom-gradient-picker__gradient-bar", { 37604 "has-gradient": hasGradient 37605 }), 37606 onMouseEnter: onMouseEnterAndMove, 37607 onMouseMove: onMouseEnterAndMove, 37608 onMouseLeave, 37609 children: [/* @__PURE__ */ (0, import_jsx_runtime175.jsx)("div", { 37610 className: "components-custom-gradient-picker__gradient-bar-background", 37611 style: { 37612 background: background2, 37613 opacity: hasGradient ? 1 : 0.4 37614 } 37615 }), /* @__PURE__ */ (0, import_jsx_runtime175.jsxs)("div", { 37616 ref: gradientMarkersContainerDomRef, 37617 className: "components-custom-gradient-picker__markers-container", 37618 children: [!disableInserter && (isMovingInserter || isInsertingControlPoint) && /* @__PURE__ */ (0, import_jsx_runtime175.jsx)(control_points_default.InsertPoint, { 37619 __experimentalIsRenderedInSidebar, 37620 disableAlpha, 37621 insertPosition: gradientBarState.insertPosition, 37622 value: controlPoints, 37623 onChange, 37624 onOpenInserter: () => { 37625 gradientBarStateDispatch({ 37626 type: "OPEN_INSERTER" 37627 }); 37628 }, 37629 onCloseInserter: () => { 37630 gradientBarStateDispatch({ 37631 type: "CLOSE_INSERTER" 37632 }); 37633 } 37634 }), /* @__PURE__ */ (0, import_jsx_runtime175.jsx)(control_points_default, { 37635 __experimentalIsRenderedInSidebar, 37636 disableAlpha, 37637 disableRemove: disableInserter, 37638 gradientPickerDomRef: gradientMarkersContainerDomRef, 37639 ignoreMarkerPosition: isInsertingControlPoint ? gradientBarState.insertPosition : void 0, 37640 value: controlPoints, 37641 onChange, 37642 onStartControlPointChange: () => { 37643 gradientBarStateDispatch({ 37644 type: "START_CONTROL_CHANGE" 37645 }); 37646 }, 37647 onStopControlPointChange: () => { 37648 gradientBarStateDispatch({ 37649 type: "STOP_CONTROL_CHANGE" 37650 }); 37651 } 37652 })] 37653 })] 37654 }); 37655 } 37656 37657 // packages/components/build-module/custom-gradient-picker/utils.js 37658 var import_gradient_parser = __toESM(require_node()); 37659 37660 // packages/components/build-module/custom-gradient-picker/constants.js 37661 var import_i18n32 = __toESM(require_i18n()); 37662 var DEFAULT_GRADIENT = "linear-gradient(135deg, rgba(6, 147, 227, 1) 0%, rgb(155, 81, 224) 100%)"; 37663 var DEFAULT_LINEAR_GRADIENT_ANGLE = 180; 37664 var HORIZONTAL_GRADIENT_ORIENTATION = { 37665 type: "angular", 37666 value: "90" 37667 }; 37668 var GRADIENT_OPTIONS = [{ 37669 value: "linear-gradient", 37670 label: (0, import_i18n32.__)("Linear") 37671 }, { 37672 value: "radial-gradient", 37673 label: (0, import_i18n32.__)("Radial") 37674 }]; 37675 var DIRECTIONAL_ORIENTATION_ANGLE_MAP = { 37676 top: 0, 37677 "top right": 45, 37678 "right top": 45, 37679 right: 90, 37680 "right bottom": 135, 37681 "bottom right": 135, 37682 bottom: 180, 37683 "bottom left": 225, 37684 "left bottom": 225, 37685 left: 270, 37686 "top left": 315, 37687 "left top": 315 37688 }; 37689 37690 // packages/components/build-module/custom-gradient-picker/serializer.js 37691 function serializeGradientColor({ 37692 type, 37693 value 37694 }) { 37695 if (type === "literal") { 37696 return value; 37697 } 37698 if (type === "hex") { 37699 return `#$value}`; 37700 } 37701 if (type === "var") { 37702 return `var($value})`; 37703 } 37704 if (type === "hsl") { 37705 const [hue, saturation, lightness] = value; 37706 return `hsl($hue},$saturation}%,$lightness}%)`; 37707 } 37708 if (type === "hsla") { 37709 const [hue, saturation, lightness, alpha2] = value; 37710 return `hsla($hue},$saturation}%,$lightness}%,$alpha2})`; 37711 } 37712 return `$type}($value.join(",")})`; 37713 } 37714 function serializeGradientPosition(position2) { 37715 if (!position2) { 37716 return ""; 37717 } 37718 const { 37719 value, 37720 type 37721 } = position2; 37722 if (type === "calc") { 37723 return `calc($value})`; 37724 } 37725 return `$value}$type}`; 37726 } 37727 function serializeGradientColorStop({ 37728 type, 37729 value, 37730 length: length2 37731 }) { 37732 return `$serializeGradientColor({ 37733 type, 37734 value 37735 })} $serializeGradientPosition(length2)}`; 37736 } 37737 function serializeGradientOrientation(orientation) { 37738 if (Array.isArray(orientation) || !orientation || orientation.type !== "angular") { 37739 return; 37740 } 37741 return `$orientation.value}deg`; 37742 } 37743 function serializeGradient({ 37744 type, 37745 orientation, 37746 colorStops 37747 }) { 37748 const serializedOrientation = serializeGradientOrientation(orientation); 37749 const serializedColorStops = colorStops.sort((colorStop1, colorStop2) => { 37750 const getNumericStopValue = (colorStop) => { 37751 return colorStop?.length?.value === void 0 ? 0 : parseInt(colorStop.length.value); 37752 }; 37753 return getNumericStopValue(colorStop1) - getNumericStopValue(colorStop2); 37754 }).map(serializeGradientColorStop); 37755 return `$type}(${[serializedOrientation, ...serializedColorStops].filter(Boolean).join(",")})`; 37756 } 37757 37758 // packages/components/build-module/custom-gradient-picker/utils.js 37759 k([names_default]); 37760 function getLinearGradientRepresentation(gradientAST) { 37761 return serializeGradient({ 37762 type: "linear-gradient", 37763 orientation: HORIZONTAL_GRADIENT_ORIENTATION, 37764 colorStops: gradientAST.colorStops 37765 }); 37766 } 37767 function hasUnsupportedLength(item2) { 37768 return item2.length === void 0 || item2.length.type !== "%"; 37769 } 37770 function getGradientAstWithDefault(value) { 37771 let gradientAST; 37772 let hasGradient = !!value; 37773 const valueToParse = value !== null && value !== void 0 ? value : DEFAULT_GRADIENT; 37774 try { 37775 gradientAST = import_gradient_parser.default.parse(valueToParse)[0]; 37776 } catch (error) { 37777 console.warn("wp.components.CustomGradientPicker failed to parse the gradient with error", error); 37778 gradientAST = import_gradient_parser.default.parse(DEFAULT_GRADIENT)[0]; 37779 hasGradient = false; 37780 } 37781 if (!Array.isArray(gradientAST.orientation) && gradientAST.orientation?.type === "directional") { 37782 gradientAST.orientation = { 37783 type: "angular", 37784 value: DIRECTIONAL_ORIENTATION_ANGLE_MAP[gradientAST.orientation.value].toString() 37785 }; 37786 } 37787 if (gradientAST.colorStops.some(hasUnsupportedLength)) { 37788 const { 37789 colorStops 37790 } = gradientAST; 37791 const step = 100 / (colorStops.length - 1); 37792 colorStops.forEach((stop, index2) => { 37793 stop.length = { 37794 value: `$step * index2}`, 37795 type: "%" 37796 }; 37797 }); 37798 } 37799 return { 37800 gradientAST, 37801 hasGradient 37802 }; 37803 } 37804 function getGradientAstWithControlPoints(gradientAST, newControlPoints) { 37805 return { 37806 ...gradientAST, 37807 colorStops: newControlPoints.map(({ 37808 position: position2, 37809 color: color2 37810 }) => { 37811 const { 37812 r: r4, 37813 g: g3, 37814 b: b3, 37815 a: a3 37816 } = w(color2).toRgb(); 37817 return { 37818 length: { 37819 type: "%", 37820 value: position2?.toString() 37821 }, 37822 type: a3 < 1 ? "rgba" : "rgb", 37823 value: a3 < 1 ? [`$r4}`, `$g3}`, `$b3}`, `$a3}`] : [`$r4}`, `$g3}`, `$b3}`] 37824 }; 37825 }) 37826 }; 37827 } 37828 function getStopCssColor(colorStop) { 37829 switch (colorStop.type) { 37830 case "hex": 37831 return `#$colorStop.value}`; 37832 case "literal": 37833 return colorStop.value; 37834 case "var": 37835 return `$colorStop.type}($colorStop.value})`; 37836 case "rgb": 37837 case "rgba": 37838 return `$colorStop.type}($colorStop.value.join(",")})`; 37839 case "hsl": { 37840 const [hue, saturation, lightness] = colorStop.value; 37841 return `hsl($hue},$saturation}%,$lightness}%)`; 37842 } 37843 case "hsla": { 37844 const [hue, saturation, lightness, alpha2] = colorStop.value; 37845 return `hsla($hue},$saturation}%,$lightness}%,$alpha2})`; 37846 } 37847 default: 37848 return "transparent"; 37849 } 37850 } 37851 37852 // packages/components/build-module/custom-gradient-picker/styles/custom-gradient-picker-styles.js 37853 function _EMOTION_STRINGIFIED_CSS_ERROR__23() { 37854 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 37855 } 37856 var SelectWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default5, false ? { 37857 target: "e10bzpgi1" 37858 } : { 37859 target: "e10bzpgi1", 37860 label: "SelectWrapper" 37861 })(false ? { 37862 name: "1gvx10y", 37863 styles: "flex-grow:5" 37864 } : { 37865 name: "1gvx10y", 37866 styles: "flex-grow:5", 37867 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImN1c3RvbS1ncmFkaWVudC1waWNrZXItc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTZ0QiLCJmaWxlIjoiY3VzdG9tLWdyYWRpZW50LXBpY2tlci1zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleEJsb2NrIH0gZnJvbSAnLi4vLi4vZmxleCc7XG5cbmV4cG9ydCBjb25zdCBTZWxlY3RXcmFwcGVyID0gc3R5bGVkKCBGbGV4QmxvY2sgKWBcblx0ZmxleC1ncm93OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IEFjY2Vzc29yeVdyYXBwZXIgPSBzdHlsZWQoIEZsZXhCbG9jayApYFxuXHRmbGV4LWdyb3c6IDU7XG5gO1xuIl19 */", 37868 toString: _EMOTION_STRINGIFIED_CSS_ERROR__23 37869 }); 37870 var AccessoryWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default5, false ? { 37871 target: "e10bzpgi0" 37872 } : { 37873 target: "e10bzpgi0", 37874 label: "AccessoryWrapper" 37875 })(false ? { 37876 name: "1gvx10y", 37877 styles: "flex-grow:5" 37878 } : { 37879 name: "1gvx10y", 37880 styles: "flex-grow:5", 37881 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImN1c3RvbS1ncmFkaWVudC1waWNrZXItc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhbUQiLCJmaWxlIjoiY3VzdG9tLWdyYWRpZW50LXBpY2tlci1zdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleEJsb2NrIH0gZnJvbSAnLi4vLi4vZmxleCc7XG5cbmV4cG9ydCBjb25zdCBTZWxlY3RXcmFwcGVyID0gc3R5bGVkKCBGbGV4QmxvY2sgKWBcblx0ZmxleC1ncm93OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IEFjY2Vzc29yeVdyYXBwZXIgPSBzdHlsZWQoIEZsZXhCbG9jayApYFxuXHRmbGV4LWdyb3c6IDU7XG5gO1xuIl19 */", 37882 toString: _EMOTION_STRINGIFIED_CSS_ERROR__23 37883 }); 37884 37885 // packages/components/build-module/custom-gradient-picker/index.js 37886 var import_jsx_runtime176 = __toESM(require_jsx_runtime()); 37887 var GradientAnglePicker = ({ 37888 gradientAST, 37889 hasGradient, 37890 onChange 37891 }) => { 37892 var _gradientAST$orientat; 37893 const angle = (_gradientAST$orientat = gradientAST?.orientation?.value) !== null && _gradientAST$orientat !== void 0 ? _gradientAST$orientat : DEFAULT_LINEAR_GRADIENT_ANGLE; 37894 const onAngleChange = (newAngle) => { 37895 onChange(serializeGradient({ 37896 ...gradientAST, 37897 orientation: { 37898 type: "angular", 37899 value: `$newAngle}` 37900 } 37901 })); 37902 }; 37903 return /* @__PURE__ */ (0, import_jsx_runtime176.jsx)(angle_picker_control_default, { 37904 onChange: onAngleChange, 37905 value: hasGradient ? angle : "" 37906 }); 37907 }; 37908 var GradientTypePicker = ({ 37909 gradientAST, 37910 hasGradient, 37911 onChange 37912 }) => { 37913 const { 37914 type 37915 } = gradientAST; 37916 const onSetLinearGradient = () => { 37917 onChange(serializeGradient({ 37918 ...gradientAST, 37919 orientation: gradientAST.orientation ? void 0 : HORIZONTAL_GRADIENT_ORIENTATION, 37920 type: "linear-gradient" 37921 })); 37922 }; 37923 const onSetRadialGradient = () => { 37924 const { 37925 orientation, 37926 ...restGradientAST 37927 } = gradientAST; 37928 onChange(serializeGradient({ 37929 ...restGradientAST, 37930 type: "radial-gradient" 37931 })); 37932 }; 37933 const handleOnChange = (next2) => { 37934 if (next2 === "linear-gradient") { 37935 onSetLinearGradient(); 37936 } 37937 if (next2 === "radial-gradient") { 37938 onSetRadialGradient(); 37939 } 37940 }; 37941 return /* @__PURE__ */ (0, import_jsx_runtime176.jsx)(select_control_default, { 37942 className: "components-custom-gradient-picker__type-picker", 37943 label: (0, import_i18n33.__)("Type"), 37944 labelPosition: "top", 37945 onChange: handleOnChange, 37946 options: GRADIENT_OPTIONS, 37947 size: "__unstable-large", 37948 value: hasGradient ? type : void 0 37949 }); 37950 }; 37951 function CustomGradientPicker({ 37952 value, 37953 onChange, 37954 enableAlpha = true, 37955 __experimentalIsRenderedInSidebar = false 37956 }) { 37957 const { 37958 gradientAST, 37959 hasGradient 37960 } = getGradientAstWithDefault(value); 37961 const background2 = getLinearGradientRepresentation(gradientAST); 37962 const controlPoints = gradientAST.colorStops.map((colorStop) => { 37963 return { 37964 color: getStopCssColor(colorStop), 37965 // Although it's already been checked by `hasUnsupportedLength` in `getGradientAstWithDefault`, 37966 // TypeScript doesn't know that `colorStop.length` is not undefined here. 37967 // @ts-expect-error 37968 position: parseInt(colorStop.length.value) 37969 }; 37970 }); 37971 return /* @__PURE__ */ (0, import_jsx_runtime176.jsxs)(component_default18, { 37972 spacing: 4, 37973 className: "components-custom-gradient-picker", 37974 children: [/* @__PURE__ */ (0, import_jsx_runtime176.jsx)(CustomGradientBar, { 37975 __experimentalIsRenderedInSidebar, 37976 disableAlpha: !enableAlpha, 37977 background: background2, 37978 hasGradient, 37979 value: controlPoints, 37980 onChange: (newControlPoints) => { 37981 onChange(serializeGradient(getGradientAstWithControlPoints(gradientAST, newControlPoints))); 37982 } 37983 }), /* @__PURE__ */ (0, import_jsx_runtime176.jsxs)(component_default3, { 37984 gap: 3, 37985 className: "components-custom-gradient-picker__ui-line", 37986 children: [/* @__PURE__ */ (0, import_jsx_runtime176.jsx)(SelectWrapper, { 37987 children: /* @__PURE__ */ (0, import_jsx_runtime176.jsx)(GradientTypePicker, { 37988 gradientAST, 37989 hasGradient, 37990 onChange 37991 }) 37992 }), /* @__PURE__ */ (0, import_jsx_runtime176.jsx)(AccessoryWrapper, { 37993 children: gradientAST.type === "linear-gradient" && /* @__PURE__ */ (0, import_jsx_runtime176.jsx)(GradientAnglePicker, { 37994 gradientAST, 37995 hasGradient, 37996 onChange 37997 }) 37998 })] 37999 })] 38000 }); 38001 } 38002 var custom_gradient_picker_default = CustomGradientPicker; 38003 38004 // packages/components/build-module/gradient-picker/index.js 38005 var import_jsx_runtime177 = __toESM(require_jsx_runtime()); 38006 var isMultipleOriginObject = (obj) => Array.isArray(obj.gradients) && !("gradient" in obj); 38007 var isMultipleOriginArray = (arr) => { 38008 return arr.length > 0 && arr.every((gradientObj) => isMultipleOriginObject(gradientObj)); 38009 }; 38010 function SingleOrigin({ 38011 className: className2, 38012 clearGradient, 38013 gradients, 38014 onChange, 38015 value, 38016 ...additionalProps 38017 }) { 38018 const gradientOptions = (0, import_element112.useMemo)(() => { 38019 return gradients.map(({ 38020 gradient, 38021 name, 38022 slug 38023 }, index2) => /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(circular_option_picker_default2.Option, { 38024 value: gradient, 38025 isSelected: value === gradient, 38026 tooltipText: name || // translators: %s: gradient code e.g: "linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);". 38027 (0, import_i18n34.sprintf)((0, import_i18n34.__)("Gradient code: %s"), gradient), 38028 style: { 38029 color: "rgba( 0,0,0,0 )", 38030 background: gradient 38031 }, 38032 onClick: value === gradient ? clearGradient : () => onChange(gradient, index2), 38033 "aria-label": name ? ( 38034 // translators: %s: The name of the gradient e.g: "Angular red to blue". 38035 (0, import_i18n34.sprintf)((0, import_i18n34.__)("Gradient: %s"), name) 38036 ) : ( 38037 // translators: %s: gradient code e.g: "linear-gradient(90deg, rgba(98,16,153,1) 0%, rgba(172,110,22,1) 100%);". 38038 (0, import_i18n34.sprintf)((0, import_i18n34.__)("Gradient code: %s"), gradient) 38039 ) 38040 }, slug)); 38041 }, [gradients, value, onChange, clearGradient]); 38042 return /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(circular_option_picker_default2.OptionGroup, { 38043 className: className2, 38044 options: gradientOptions, 38045 ...additionalProps 38046 }); 38047 } 38048 function MultipleOrigin({ 38049 className: className2, 38050 clearGradient, 38051 gradients, 38052 onChange, 38053 value, 38054 headingLevel 38055 }) { 38056 const instanceId = (0, import_compose45.useInstanceId)(MultipleOrigin); 38057 return /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(component_default18, { 38058 spacing: 3, 38059 className: className2, 38060 children: gradients.map(({ 38061 name, 38062 gradients: gradientSet 38063 }, index2) => { 38064 const id3 = `color-palette-$instanceId}-$index2}`; 38065 return /* @__PURE__ */ (0, import_jsx_runtime177.jsxs)(component_default18, { 38066 spacing: 2, 38067 children: [/* @__PURE__ */ (0, import_jsx_runtime177.jsx)(ColorHeading, { 38068 level: headingLevel, 38069 id: id3, 38070 children: name 38071 }), /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(SingleOrigin, { 38072 clearGradient, 38073 gradients: gradientSet, 38074 onChange: (gradient) => onChange(gradient, index2), 38075 value, 38076 "aria-labelledby": id3 38077 })] 38078 }, index2); 38079 }) 38080 }); 38081 } 38082 function Component3(props) { 38083 const { 38084 asButtons, 38085 loop, 38086 actions, 38087 headingLevel, 38088 "aria-label": ariaLabel, 38089 "aria-labelledby": ariaLabelledby, 38090 ...additionalProps 38091 } = props; 38092 const options2 = isMultipleOriginArray(props.gradients) ? /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(MultipleOrigin, { 38093 headingLevel, 38094 ...additionalProps 38095 }) : /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(SingleOrigin, { 38096 ...additionalProps 38097 }); 38098 const { 38099 metaProps, 38100 labelProps 38101 } = getComputeCircularOptionPickerCommonProps(asButtons, loop, ariaLabel, ariaLabelledby); 38102 return /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(circular_option_picker_default2, { 38103 ...metaProps, 38104 ...labelProps, 38105 actions, 38106 options: options2 38107 }); 38108 } 38109 function GradientPicker({ 38110 className: className2, 38111 gradients = [], 38112 onChange, 38113 value, 38114 clearable = true, 38115 enableAlpha = true, 38116 disableCustomGradients = false, 38117 __experimentalIsRenderedInSidebar, 38118 headingLevel = 2, 38119 ...additionalProps 38120 }) { 38121 const clearGradient = (0, import_element112.useCallback)(() => onChange(void 0), [onChange]); 38122 return /* @__PURE__ */ (0, import_jsx_runtime177.jsxs)(component_default18, { 38123 spacing: gradients.length ? 4 : 0, 38124 children: [!disableCustomGradients && /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(custom_gradient_picker_default, { 38125 __experimentalIsRenderedInSidebar, 38126 enableAlpha, 38127 value, 38128 onChange 38129 }), (gradients.length > 0 || clearable) && /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(Component3, { 38130 ...additionalProps, 38131 className: className2, 38132 clearGradient, 38133 gradients, 38134 onChange, 38135 value, 38136 actions: clearable && !disableCustomGradients && /* @__PURE__ */ (0, import_jsx_runtime177.jsx)(circular_option_picker_default2.ButtonAction, { 38137 onClick: clearGradient, 38138 accessibleWhenDisabled: true, 38139 disabled: !value, 38140 children: (0, import_i18n34.__)("Clear") 38141 }), 38142 headingLevel 38143 })] 38144 }); 38145 } 38146 var gradient_picker_default = GradientPicker; 38147 38148 // packages/components/build-module/navigable-container/menu.js 38149 var import_element114 = __toESM(require_element()); 38150 38151 // packages/components/build-module/navigable-container/container.js 38152 var import_element113 = __toESM(require_element()); 38153 var import_dom29 = __toESM(require_dom()); 38154 var import_jsx_runtime178 = __toESM(require_jsx_runtime()); 38155 var noop10 = () => { 38156 }; 38157 var MENU_ITEM_ROLES = ["menuitem", "menuitemradio", "menuitemcheckbox"]; 38158 function cycleValue(value, total, offset3) { 38159 const nextValue = value + offset3; 38160 if (nextValue < 0) { 38161 return total + nextValue; 38162 } else if (nextValue >= total) { 38163 return nextValue - total; 38164 } 38165 return nextValue; 38166 } 38167 var NavigableContainer = class extends import_element113.Component { 38168 constructor(args) { 38169 super(args); 38170 this.onKeyDown = this.onKeyDown.bind(this); 38171 this.bindContainer = this.bindContainer.bind(this); 38172 this.getFocusableContext = this.getFocusableContext.bind(this); 38173 this.getFocusableIndex = this.getFocusableIndex.bind(this); 38174 } 38175 componentDidMount() { 38176 if (!this.container) { 38177 return; 38178 } 38179 this.container.addEventListener("keydown", this.onKeyDown); 38180 } 38181 componentWillUnmount() { 38182 if (!this.container) { 38183 return; 38184 } 38185 this.container.removeEventListener("keydown", this.onKeyDown); 38186 } 38187 bindContainer(ref) { 38188 const { 38189 forwardedRef 38190 } = this.props; 38191 this.container = ref; 38192 if (typeof forwardedRef === "function") { 38193 forwardedRef(ref); 38194 } else if (forwardedRef && "current" in forwardedRef) { 38195 forwardedRef.current = ref; 38196 } 38197 } 38198 getFocusableContext(target) { 38199 if (!this.container) { 38200 return null; 38201 } 38202 const { 38203 onlyBrowserTabstops 38204 } = this.props; 38205 const finder = onlyBrowserTabstops ? import_dom29.focus.tabbable : import_dom29.focus.focusable; 38206 const focusables = finder.find(this.container); 38207 const index2 = this.getFocusableIndex(focusables, target); 38208 if (index2 > -1 && target) { 38209 return { 38210 index: index2, 38211 target, 38212 focusables 38213 }; 38214 } 38215 return null; 38216 } 38217 getFocusableIndex(focusables, target) { 38218 return focusables.indexOf(target); 38219 } 38220 onKeyDown(event) { 38221 if (this.props.onKeyDown) { 38222 this.props.onKeyDown(event); 38223 } 38224 const { 38225 getFocusableContext 38226 } = this; 38227 const { 38228 cycle = true, 38229 eventToOffset, 38230 onNavigate = noop10, 38231 stopNavigationEvents 38232 } = this.props; 38233 const offset3 = eventToOffset(event); 38234 if (offset3 !== void 0 && stopNavigationEvents) { 38235 event.stopImmediatePropagation(); 38236 const targetRole = event.target?.getAttribute("role"); 38237 const targetHasMenuItemRole = !!targetRole && MENU_ITEM_ROLES.includes(targetRole); 38238 if (targetHasMenuItemRole) { 38239 event.preventDefault(); 38240 } 38241 } 38242 if (!offset3) { 38243 return; 38244 } 38245 const activeElement = event.target?.ownerDocument?.activeElement; 38246 if (!activeElement) { 38247 return; 38248 } 38249 const context = getFocusableContext(activeElement); 38250 if (!context) { 38251 return; 38252 } 38253 const { 38254 index: index2, 38255 focusables 38256 } = context; 38257 const nextIndex = cycle ? cycleValue(index2, focusables.length, offset3) : index2 + offset3; 38258 if (nextIndex >= 0 && nextIndex < focusables.length) { 38259 focusables[nextIndex].focus(); 38260 onNavigate(nextIndex, focusables[nextIndex]); 38261 if (event.code === "Tab") { 38262 event.preventDefault(); 38263 } 38264 } 38265 } 38266 render() { 38267 const { 38268 children, 38269 stopNavigationEvents, 38270 eventToOffset, 38271 onNavigate, 38272 onKeyDown, 38273 cycle, 38274 onlyBrowserTabstops, 38275 forwardedRef, 38276 ...restProps 38277 } = this.props; 38278 return /* @__PURE__ */ (0, import_jsx_runtime178.jsx)("div", { 38279 ref: this.bindContainer, 38280 ...restProps, 38281 children 38282 }); 38283 } 38284 }; 38285 var forwardedNavigableContainer = (props, ref) => { 38286 return /* @__PURE__ */ (0, import_jsx_runtime178.jsx)(NavigableContainer, { 38287 ...props, 38288 forwardedRef: ref 38289 }); 38290 }; 38291 forwardedNavigableContainer.displayName = "NavigableContainer"; 38292 var container_default = (0, import_element113.forwardRef)(forwardedNavigableContainer); 38293 38294 // packages/components/build-module/navigable-container/menu.js 38295 var import_jsx_runtime179 = __toESM(require_jsx_runtime()); 38296 function UnforwardedNavigableMenu({ 38297 role = "menu", 38298 orientation = "vertical", 38299 ...rest 38300 }, ref) { 38301 const eventToOffset = (evt) => { 38302 const { 38303 code 38304 } = evt; 38305 let next2 = ["ArrowDown"]; 38306 let previous = ["ArrowUp"]; 38307 if (orientation === "horizontal") { 38308 next2 = ["ArrowRight"]; 38309 previous = ["ArrowLeft"]; 38310 } 38311 if (orientation === "both") { 38312 next2 = ["ArrowRight", "ArrowDown"]; 38313 previous = ["ArrowLeft", "ArrowUp"]; 38314 } 38315 if (next2.includes(code)) { 38316 return 1; 38317 } else if (previous.includes(code)) { 38318 return -1; 38319 } else if (["ArrowDown", "ArrowUp", "ArrowLeft", "ArrowRight"].includes(code)) { 38320 return 0; 38321 } 38322 return void 0; 38323 }; 38324 return /* @__PURE__ */ (0, import_jsx_runtime179.jsx)(container_default, { 38325 ref, 38326 stopNavigationEvents: true, 38327 onlyBrowserTabstops: false, 38328 role, 38329 "aria-orientation": role !== "presentation" && (orientation === "vertical" || orientation === "horizontal") ? orientation : void 0, 38330 eventToOffset, 38331 ...rest 38332 }); 38333 } 38334 var NavigableMenu = (0, import_element114.forwardRef)(UnforwardedNavigableMenu); 38335 var menu_default2 = NavigableMenu; 38336 38337 // packages/components/build-module/navigable-container/tabbable.js 38338 var import_element115 = __toESM(require_element()); 38339 var import_jsx_runtime180 = __toESM(require_jsx_runtime()); 38340 function UnforwardedTabbableContainer({ 38341 eventToOffset, 38342 ...props 38343 }, ref) { 38344 const innerEventToOffset = (evt) => { 38345 const { 38346 code, 38347 shiftKey 38348 } = evt; 38349 if ("Tab" === code) { 38350 return shiftKey ? -1 : 1; 38351 } 38352 if (eventToOffset) { 38353 return eventToOffset(evt); 38354 } 38355 return void 0; 38356 }; 38357 return /* @__PURE__ */ (0, import_jsx_runtime180.jsx)(container_default, { 38358 ref, 38359 stopNavigationEvents: true, 38360 onlyBrowserTabstops: true, 38361 eventToOffset: innerEventToOffset, 38362 ...props 38363 }); 38364 } 38365 var TabbableContainer = (0, import_element115.forwardRef)(UnforwardedTabbableContainer); 38366 var tabbable_default = TabbableContainer; 38367 38368 // packages/components/build-module/dropdown-menu/index.js 38369 var import_jsx_runtime181 = __toESM(require_jsx_runtime()); 38370 function mergeProps2(defaultProps = {}, props = {}) { 38371 const mergedProps = { 38372 ...defaultProps, 38373 ...props 38374 }; 38375 if (props.className && defaultProps.className) { 38376 mergedProps.className = clsx_default(props.className, defaultProps.className); 38377 } 38378 return mergedProps; 38379 } 38380 function isFunction2(maybeFunc) { 38381 return typeof maybeFunc === "function"; 38382 } 38383 function UnconnectedDropdownMenu(dropdownMenuProps) { 38384 const { 38385 children, 38386 className: className2, 38387 controls, 38388 icon = menu_default, 38389 label, 38390 popoverProps, 38391 toggleProps, 38392 menuProps, 38393 disableOpenOnArrowDown = false, 38394 text, 38395 noIcons, 38396 open, 38397 defaultOpen, 38398 onToggle: onToggleProp, 38399 // Context 38400 variant 38401 } = useContextSystem(dropdownMenuProps, "DropdownMenu"); 38402 if (!controls?.length && !isFunction2(children)) { 38403 return null; 38404 } 38405 let controlSets; 38406 if (controls?.length) { 38407 controlSets = controls; 38408 if (!Array.isArray(controlSets[0])) { 38409 controlSets = [controls]; 38410 } 38411 } 38412 const mergedPopoverProps = mergeProps2({ 38413 className: "components-dropdown-menu__popover", 38414 variant 38415 }, popoverProps); 38416 return /* @__PURE__ */ (0, import_jsx_runtime181.jsx)(dropdown_default, { 38417 className: className2, 38418 popoverProps: mergedPopoverProps, 38419 renderToggle: ({ 38420 isOpen, 38421 onToggle 38422 }) => { 38423 var _toggleProps$showTool; 38424 const openOnArrowDown = (event) => { 38425 if (disableOpenOnArrowDown) { 38426 return; 38427 } 38428 if (!isOpen && event.code === "ArrowDown") { 38429 event.preventDefault(); 38430 onToggle(); 38431 } 38432 }; 38433 const { 38434 as: Toggle = button_default, 38435 ...restToggleProps 38436 } = toggleProps !== null && toggleProps !== void 0 ? toggleProps : {}; 38437 const mergedToggleProps = mergeProps2({ 38438 className: clsx_default("components-dropdown-menu__toggle", { 38439 "is-opened": isOpen 38440 }) 38441 }, restToggleProps); 38442 return /* @__PURE__ */ (0, import_jsx_runtime181.jsx)(Toggle, { 38443 ...mergedToggleProps, 38444 icon, 38445 onClick: (event) => { 38446 onToggle(); 38447 if (mergedToggleProps.onClick) { 38448 mergedToggleProps.onClick(event); 38449 } 38450 }, 38451 onKeyDown: (event) => { 38452 openOnArrowDown(event); 38453 if (mergedToggleProps.onKeyDown) { 38454 mergedToggleProps.onKeyDown(event); 38455 } 38456 }, 38457 "aria-haspopup": "true", 38458 "aria-expanded": isOpen, 38459 label, 38460 text, 38461 showTooltip: (_toggleProps$showTool = toggleProps?.showTooltip) !== null && _toggleProps$showTool !== void 0 ? _toggleProps$showTool : true, 38462 children: mergedToggleProps.children 38463 }); 38464 }, 38465 renderContent: (props) => { 38466 const mergedMenuProps = mergeProps2({ 38467 "aria-label": label, 38468 className: clsx_default("components-dropdown-menu__menu", { 38469 "no-icons": noIcons 38470 }) 38471 }, menuProps); 38472 return /* @__PURE__ */ (0, import_jsx_runtime181.jsxs)(menu_default2, { 38473 ...mergedMenuProps, 38474 role: "menu", 38475 children: [isFunction2(children) ? children(props) : null, controlSets?.flatMap((controlSet, indexOfSet) => controlSet.map((control, indexOfControl) => /* @__PURE__ */ (0, import_jsx_runtime181.jsx)(button_default, { 38476 size: "compact", 38477 onClick: (event) => { 38478 event.stopPropagation(); 38479 props.onClose(); 38480 if (control.onClick) { 38481 control.onClick(); 38482 } 38483 }, 38484 className: clsx_default("components-dropdown-menu__menu-item", { 38485 "has-separator": indexOfSet > 0 && indexOfControl === 0, 38486 "is-active": control.isActive, 38487 "is-icon-only": !control.title 38488 }), 38489 icon: control.icon, 38490 label: control.label, 38491 "aria-checked": control.role === "menuitemcheckbox" || control.role === "menuitemradio" ? control.isActive : void 0, 38492 role: control.role === "menuitemcheckbox" || control.role === "menuitemradio" ? control.role : "menuitem", 38493 accessibleWhenDisabled: true, 38494 disabled: control.isDisabled, 38495 children: control.title 38496 }, [indexOfSet, indexOfControl].join())))] 38497 }); 38498 }, 38499 open, 38500 defaultOpen, 38501 onToggle: onToggleProp 38502 }); 38503 } 38504 var DropdownMenu = contextConnectWithoutRef(UnconnectedDropdownMenu, "DropdownMenu"); 38505 var dropdown_menu_default = DropdownMenu; 38506 38507 // packages/components/build-module/palette-edit/styles.js 38508 function _EMOTION_STRINGIFIED_CSS_ERROR__24() { 38509 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 38510 } 38511 var IndicatorStyled = /* @__PURE__ */ emotion_styled_base_browser_esm_default(color_indicator_default, false ? { 38512 target: "e1lpqc908" 38513 } : { 38514 target: "e1lpqc908", 38515 label: "IndicatorStyled" 38516 })("&&{flex-shrink:0;width:", space(6), ";height:", space(6), ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnVEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38517 var NameInputControl = /* @__PURE__ */ emotion_styled_base_browser_esm_default(input_control_default, false ? { 38518 target: "e1lpqc907" 38519 } : { 38520 target: "e1lpqc907", 38521 label: "NameInputControl" 38522 })(Container, "{background:", COLORS.gray[100], ";border-radius:", config_values_default.radiusXSmall, ";", Input, Input, Input, Input, "{height:", space(8), ";}", BackdropUI, BackdropUI, BackdropUI, "{border-color:transparent;box-shadow:none;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QnNEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38523 var NameContainer = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 38524 target: "e1lpqc906" 38525 } : { 38526 target: "e1lpqc906", 38527 label: "NameContainer" 38528 })("line-height:", space(8), ";margin-left:", space(2), ";margin-right:", space(2), ";white-space:nowrap;overflow:hidden;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ3VDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38529 var PaletteHeading = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default19, false ? { 38530 target: "e1lpqc905" 38531 } : { 38532 target: "e1lpqc905", 38533 label: "PaletteHeading" 38534 })("text-transform:uppercase;line-height:", space(6), ";font-weight:", config_values_default.fontWeightMedium, ";&&&{font-size:11px;margin-bottom:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRCtDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38535 var PaletteActionsContainer = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default, false ? { 38536 target: "e1lpqc904" 38537 } : { 38538 target: "e1lpqc904", 38539 label: "PaletteActionsContainer" 38540 })("height:", space(6), ";display:flex;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RHFEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38541 var PaletteEditContents = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default, false ? { 38542 target: "e1lpqc903" 38543 } : { 38544 target: "e1lpqc903", 38545 label: "PaletteEditContents" 38546 })("margin-top:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRWlEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38547 var PaletteEditStyles = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default, false ? { 38548 target: "e1lpqc902" 38549 } : { 38550 target: "e1lpqc902", 38551 label: "PaletteEditStyles" 38552 })(false ? { 38553 name: "u6wnko", 38554 styles: "&&&{.components-button.has-icon{min-width:0;padding:0;}}" 38555 } : { 38556 name: "u6wnko", 38557 styles: "&&&{.components-button.has-icon{min-width:0;padding:0;}}", 38558 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRStDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */", 38559 toString: _EMOTION_STRINGIFIED_CSS_ERROR__24 38560 }); 38561 var DoneButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 38562 target: "e1lpqc901" 38563 } : { 38564 target: "e1lpqc901", 38565 label: "DoneButton" 38566 })("&&{color:", COLORS.theme.accent, ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRTBDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38567 var RemoveButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 38568 target: "e1lpqc900" 38569 } : { 38570 target: "e1lpqc900", 38571 label: "RemoveButton" 38572 })("&&{margin-top:", space(1), ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRjRDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi9idXR0b24nO1xuaW1wb3J0IHsgSGVhZGluZyB9IGZyb20gJy4uL2hlYWRpbmcnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi92aWV3JztcbmltcG9ydCBJbnB1dENvbnRyb2wgZnJvbSAnLi4vaW5wdXQtY29udHJvbCc7XG5pbXBvcnQge1xuXHRDb250YWluZXIgYXMgSW5wdXRDb250cm9sQ29udGFpbmVyLFxuXHRJbnB1dCxcblx0QmFja2Ryb3BVSSBhcyBJbnB1dEJhY2tkcm9wVUksXG59IGZyb20gJy4uL2lucHV0LWNvbnRyb2wvc3R5bGVzL2lucHV0LWNvbnRyb2wtc3R5bGVzJztcbmltcG9ydCBDb2xvckluZGljYXRvciBmcm9tICcuLi9jb2xvci1pbmRpY2F0b3InO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yU3R5bGVkID0gc3R5bGVkKCBDb2xvckluZGljYXRvciApYFxuXHQmJiB7XG5cdFx0ZmxleC1zaHJpbms6IDA7XG5cdFx0d2lkdGg6ICR7IHNwYWNlKCA2ICkgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE5hbWVJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHQkeyBJbnB1dENvbnRyb2xDb250YWluZXIgfSB7XG5cdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLmdyYXlbIDEwMCBdIH07XG5cdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1hTbWFsbCB9O1xuXHRcdCR7IElucHV0IH0keyBJbnB1dCB9JHsgSW5wdXQgfSR7IElucHV0IH0ge1xuXHRcdFx0aGVpZ2h0OiAkeyBzcGFjZSggOCApIH07XG5cdFx0fVxuXHRcdCR7IElucHV0QmFja2Ryb3BVSSB9JHsgSW5wdXRCYWNrZHJvcFVJIH0keyBJbnB1dEJhY2tkcm9wVUkgfSB7XG5cdFx0XHRib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYW1lQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA4ICkgfTtcblx0bWFyZ2luLWxlZnQ6ICR7IHNwYWNlKCAyICkgfTtcblx0bWFyZ2luLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cdHdoaXRlLXNwYWNlOiBub3dyYXA7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgUGFsZXR0ZUhlYWRpbmcgPSBzdHlsZWQoIEhlYWRpbmcgKWBcblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcblx0bGluZS1oZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdCYmJiB7XG5cdFx0Zm9udC1zaXplOiAxMXB4O1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlQWN0aW9uc0NvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRoZWlnaHQ6ICR7IHNwYWNlKCA2ICkgfTtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdENvbnRlbnRzID0gc3R5bGVkKCBWaWV3IClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQYWxldHRlRWRpdFN0eWxlcyA9IHN0eWxlZCggVmlldyApYFxuXHQmJiYge1xuXHRcdC5jb21wb25lbnRzLWJ1dHRvbi5oYXMtaWNvbiB7XG5cdFx0XHRtaW4td2lkdGg6IDA7XG5cdFx0XHRwYWRkaW5nOiAwO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IERvbmVCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHQmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnQgfTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFJlbW92ZUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYmIHtcblx0XHRtYXJnaW4tdG9wOiAkeyBzcGFjZSggMSApIH07XG5cdH1cbmA7XG4iXX0= */")); 38573 38574 // packages/components/build-module/palette-edit/index.js 38575 var import_jsx_runtime182 = __toESM(require_jsx_runtime()); 38576 var DEFAULT_COLOR = "#000"; 38577 function NameInput({ 38578 value, 38579 onChange, 38580 label 38581 }) { 38582 return /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(NameInputControl, { 38583 size: "compact", 38584 label, 38585 hideLabelFromVision: true, 38586 value, 38587 onChange 38588 }); 38589 } 38590 function deduplicateElementSlugs(elements2) { 38591 const slugCounts = {}; 38592 return elements2.map((element) => { 38593 var _newSlug; 38594 let newSlug; 38595 const { 38596 slug 38597 } = element; 38598 slugCounts[slug] = (slugCounts[slug] || 0) + 1; 38599 if (slugCounts[slug] > 1) { 38600 newSlug = `$slug}-$slugCounts[slug] - 1}`; 38601 } 38602 return { 38603 ...element, 38604 slug: (_newSlug = newSlug) !== null && _newSlug !== void 0 ? _newSlug : slug 38605 }; 38606 }); 38607 } 38608 function getNameAndSlugForPosition(elements2, slugPrefix) { 38609 const nameRegex = new RegExp(`^$slugPrefix}color-([\\d]+)$`); 38610 const position2 = elements2.reduce((previousValue, currentValue) => { 38611 if (typeof currentValue?.slug === "string") { 38612 const matches = currentValue?.slug.match(nameRegex); 38613 if (matches) { 38614 const id3 = parseInt(matches[1], 10); 38615 if (id3 >= previousValue) { 38616 return id3 + 1; 38617 } 38618 } 38619 } 38620 return previousValue; 38621 }, 1); 38622 return { 38623 name: (0, import_i18n35.sprintf)( 38624 /* translators: %d: is an id for a custom color */ 38625 (0, import_i18n35.__)("Color %d"), 38626 position2 38627 ), 38628 slug: `$slugPrefix}color-$position2}` 38629 }; 38630 } 38631 function ColorPickerPopover({ 38632 isGradient, 38633 element, 38634 onChange, 38635 popoverProps: receivedPopoverProps, 38636 onClose = () => { 38637 } 38638 }) { 38639 const popoverProps = (0, import_element116.useMemo)(() => ({ 38640 shift: true, 38641 offset: 20, 38642 // Disabling resize as it would otherwise cause the popover to show 38643 // scrollbars while dragging the color picker's handle close to the 38644 // popover edge. 38645 resize: false, 38646 placement: "left-start", 38647 ...receivedPopoverProps, 38648 className: clsx_default("components-palette-edit__popover", receivedPopoverProps?.className) 38649 }), [receivedPopoverProps]); 38650 return /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(popover_default, { 38651 ...popoverProps, 38652 onClose, 38653 children: [!isGradient && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(LegacyAdapter, { 38654 color: element.color, 38655 enableAlpha: true, 38656 onChange: (newColor) => { 38657 onChange({ 38658 ...element, 38659 color: newColor 38660 }); 38661 } 38662 }), isGradient && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)("div", { 38663 className: "components-palette-edit__popover-gradient-picker", 38664 children: /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(custom_gradient_picker_default, { 38665 __experimentalIsRenderedInSidebar: true, 38666 value: element.gradient, 38667 onChange: (newGradient) => { 38668 onChange({ 38669 ...element, 38670 gradient: newGradient 38671 }); 38672 } 38673 }) 38674 })] 38675 }); 38676 } 38677 function Option2({ 38678 canOnlyChangeValues, 38679 element, 38680 onChange, 38681 onRemove, 38682 popoverProps: receivedPopoverProps, 38683 slugPrefix, 38684 isGradient 38685 }) { 38686 const value = isGradient ? element.gradient : element.color; 38687 const [isEditingColor, setIsEditingColor] = (0, import_element116.useState)(false); 38688 const [popoverAnchor, setPopoverAnchor] = (0, import_element116.useState)(null); 38689 const popoverProps = (0, import_element116.useMemo)(() => ({ 38690 ...receivedPopoverProps, 38691 // Use the custom palette color item as the popover anchor. 38692 anchor: popoverAnchor 38693 }), [popoverAnchor, receivedPopoverProps]); 38694 return /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(component_default35, { 38695 ref: setPopoverAnchor, 38696 size: "small", 38697 children: [/* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(component_default9, { 38698 justify: "flex-start", 38699 children: [/* @__PURE__ */ (0, import_jsx_runtime182.jsx)(button_default, { 38700 size: "small", 38701 onClick: () => { 38702 setIsEditingColor(true); 38703 }, 38704 "aria-label": (0, import_i18n35.sprintf)( 38705 // translators: %s is a color or gradient name, e.g. "Red". 38706 (0, import_i18n35.__)("Edit: %s"), 38707 element.name.trim().length ? element.name : value || "" 38708 ), 38709 style: { 38710 padding: 0 38711 }, 38712 children: /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(IndicatorStyled, { 38713 colorValue: value 38714 }) 38715 }), /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(component_default5, { 38716 children: !canOnlyChangeValues ? /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(NameInput, { 38717 label: isGradient ? (0, import_i18n35.__)("Gradient name") : (0, import_i18n35.__)("Color name"), 38718 value: element.name, 38719 onChange: (nextName) => onChange({ 38720 ...element, 38721 name: nextName, 38722 slug: slugPrefix + kebabCase(nextName !== null && nextName !== void 0 ? nextName : "") 38723 }) 38724 }) : /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(NameContainer, { 38725 children: element.name.trim().length ? element.name : ( 38726 /* Fall back to non-breaking space to maintain height */ 38727 "\xA0" 38728 ) 38729 }) 38730 }), !canOnlyChangeValues && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(component_default4, { 38731 children: /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(RemoveButton, { 38732 size: "small", 38733 icon: line_solid_default, 38734 label: (0, import_i18n35.sprintf)( 38735 // translators: %s is a color or gradient name, e.g. "Red". 38736 (0, import_i18n35.__)("Remove color: %s"), 38737 element.name.trim().length ? element.name : value || "" 38738 ), 38739 onClick: onRemove 38740 }) 38741 })] 38742 }), isEditingColor && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(ColorPickerPopover, { 38743 isGradient, 38744 onChange, 38745 element, 38746 popoverProps, 38747 onClose: () => setIsEditingColor(false) 38748 })] 38749 }); 38750 } 38751 function PaletteEditListView({ 38752 elements: elements2, 38753 onChange, 38754 canOnlyChangeValues, 38755 slugPrefix, 38756 isGradient, 38757 popoverProps, 38758 addColorRef 38759 }) { 38760 const elementsReferenceRef = (0, import_element116.useRef)(); 38761 (0, import_element116.useEffect)(() => { 38762 elementsReferenceRef.current = elements2; 38763 }, [elements2]); 38764 const debounceOnChange = (0, import_compose46.useDebounce)((updatedElements) => onChange(deduplicateElementSlugs(updatedElements)), 100); 38765 return /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(component_default18, { 38766 spacing: 3, 38767 children: /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(component_default36, { 38768 isRounded: true, 38769 isBordered: true, 38770 isSeparated: true, 38771 children: elements2.map((element, index2) => /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(Option2, { 38772 isGradient, 38773 canOnlyChangeValues, 38774 element, 38775 onChange: (newElement) => { 38776 debounceOnChange(elements2.map((currentElement, currentIndex) => { 38777 if (currentIndex === index2) { 38778 return newElement; 38779 } 38780 return currentElement; 38781 })); 38782 }, 38783 onRemove: () => { 38784 const newElements = elements2.filter((_currentElement, currentIndex) => { 38785 if (currentIndex === index2) { 38786 return false; 38787 } 38788 return true; 38789 }); 38790 onChange(newElements.length ? newElements : void 0); 38791 addColorRef.current?.focus(); 38792 }, 38793 slugPrefix, 38794 popoverProps 38795 }, index2)) 38796 }) 38797 }); 38798 } 38799 var EMPTY_ARRAY = []; 38800 function PaletteEdit({ 38801 gradients, 38802 colors = EMPTY_ARRAY, 38803 onChange, 38804 paletteLabel, 38805 paletteLabelHeadingLevel = 2, 38806 emptyMessage, 38807 canOnlyChangeValues, 38808 canReset, 38809 slugPrefix = "", 38810 popoverProps 38811 }) { 38812 const isGradient = !!gradients; 38813 const elements2 = isGradient ? gradients : colors; 38814 const [isEditing, setIsEditing] = (0, import_element116.useState)(false); 38815 const [editingElement, setEditingElement] = (0, import_element116.useState)(null); 38816 const isAdding = isEditing && !!editingElement && elements2[editingElement] && !elements2[editingElement].slug; 38817 const elementsLength = elements2.length; 38818 const hasElements = elementsLength > 0; 38819 const debounceOnChange = (0, import_compose46.useDebounce)(onChange, 100); 38820 const onSelectPaletteItem = (0, import_element116.useCallback)((value, newEditingElementIndex) => { 38821 const selectedElement = newEditingElementIndex === void 0 ? void 0 : elements2[newEditingElementIndex]; 38822 const key = isGradient ? "gradient" : "color"; 38823 if (!!selectedElement && selectedElement[key] === value) { 38824 setEditingElement(newEditingElementIndex); 38825 } else { 38826 setIsEditing(true); 38827 } 38828 }, [isGradient, elements2]); 38829 const addColorRef = (0, import_element116.useRef)(null); 38830 return /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(PaletteEditStyles, { 38831 children: [/* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(component_default9, { 38832 children: [/* @__PURE__ */ (0, import_jsx_runtime182.jsx)(PaletteHeading, { 38833 level: paletteLabelHeadingLevel, 38834 children: paletteLabel 38835 }), /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(PaletteActionsContainer, { 38836 children: [hasElements && isEditing && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(DoneButton, { 38837 size: "small", 38838 onClick: () => { 38839 setIsEditing(false); 38840 setEditingElement(null); 38841 }, 38842 children: (0, import_i18n35.__)("Done") 38843 }), !canOnlyChangeValues && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(button_default, { 38844 ref: addColorRef, 38845 size: "small", 38846 isPressed: isAdding, 38847 icon: plus_default, 38848 label: isGradient ? (0, import_i18n35.__)("Add gradient") : (0, import_i18n35.__)("Add color"), 38849 onClick: () => { 38850 const { 38851 name, 38852 slug 38853 } = getNameAndSlugForPosition(elements2, slugPrefix); 38854 if (!!gradients) { 38855 onChange([...gradients, { 38856 gradient: DEFAULT_GRADIENT, 38857 name, 38858 slug 38859 }]); 38860 } else { 38861 onChange([...colors, { 38862 color: DEFAULT_COLOR, 38863 name, 38864 slug 38865 }]); 38866 } 38867 setIsEditing(true); 38868 setEditingElement(elements2.length); 38869 } 38870 }), hasElements && (!isEditing || !canOnlyChangeValues || canReset) && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(dropdown_menu_default, { 38871 icon: more_vertical_default, 38872 label: isGradient ? (0, import_i18n35.__)("Gradient options") : (0, import_i18n35.__)("Color options"), 38873 toggleProps: { 38874 size: "small" 38875 }, 38876 children: ({ 38877 onClose 38878 }) => /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(import_jsx_runtime182.Fragment, { 38879 children: /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(menu_default2, { 38880 role: "menu", 38881 children: [!isEditing && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(button_default, { 38882 __next40pxDefaultSize: true, 38883 variant: "tertiary", 38884 onClick: () => { 38885 setIsEditing(true); 38886 onClose(); 38887 }, 38888 className: "components-palette-edit__menu-button", 38889 children: (0, import_i18n35.__)("Show details") 38890 }), !canOnlyChangeValues && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(button_default, { 38891 __next40pxDefaultSize: true, 38892 variant: "tertiary", 38893 onClick: () => { 38894 setEditingElement(null); 38895 setIsEditing(false); 38896 onChange(); 38897 onClose(); 38898 }, 38899 className: "components-palette-edit__menu-button", 38900 children: isGradient ? (0, import_i18n35.__)("Remove all gradients") : (0, import_i18n35.__)("Remove all colors") 38901 }), canReset && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(button_default, { 38902 __next40pxDefaultSize: true, 38903 className: "components-palette-edit__menu-button", 38904 variant: "tertiary", 38905 onClick: () => { 38906 setEditingElement(null); 38907 onChange(); 38908 onClose(); 38909 }, 38910 children: isGradient ? (0, import_i18n35.__)("Reset gradient") : (0, import_i18n35.__)("Reset colors") 38911 })] 38912 }) 38913 }) 38914 })] 38915 })] 38916 }), hasElements && /* @__PURE__ */ (0, import_jsx_runtime182.jsxs)(PaletteEditContents, { 38917 children: [isEditing && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(PaletteEditListView, { 38918 canOnlyChangeValues, 38919 elements: elements2, 38920 onChange, 38921 slugPrefix, 38922 isGradient, 38923 popoverProps, 38924 addColorRef 38925 }), !isEditing && editingElement !== null && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(ColorPickerPopover, { 38926 isGradient, 38927 onClose: () => setEditingElement(null), 38928 onChange: (newElement) => { 38929 debounceOnChange( 38930 // @ts-expect-error TODO: Don't know how to resolve 38931 elements2.map((currentElement, currentIndex) => { 38932 if (currentIndex === editingElement) { 38933 return newElement; 38934 } 38935 return currentElement; 38936 }) 38937 ); 38938 }, 38939 element: elements2[editingElement !== null && editingElement !== void 0 ? editingElement : -1], 38940 popoverProps 38941 }), !isEditing && (isGradient ? /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(gradient_picker_default, { 38942 gradients, 38943 onChange: onSelectPaletteItem, 38944 clearable: false, 38945 disableCustomGradients: true 38946 }) : /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(color_palette_default, { 38947 colors, 38948 onChange: onSelectPaletteItem, 38949 clearable: false, 38950 disableCustomColors: true 38951 }))] 38952 }), !hasElements && emptyMessage && /* @__PURE__ */ (0, import_jsx_runtime182.jsx)(PaletteEditContents, { 38953 children: emptyMessage 38954 })] 38955 }); 38956 } 38957 var palette_edit_default = PaletteEdit; 38958 38959 // packages/components/build-module/combobox-control/index.js 38960 var import_i18n37 = __toESM(require_i18n()); 38961 var import_element120 = __toESM(require_element()); 38962 var import_compose49 = __toESM(require_compose()); 38963 var import_a11y5 = __toESM(require_a11y()); 38964 38965 // packages/components/build-module/combobox-control/styles.js 38966 var deprecatedDefaultSize = ({ 38967 __next40pxDefaultSize 38968 }) => !__next40pxDefaultSize && /* @__PURE__ */ css("height:28px;padding-left:", space(1), ";padding-right:", space(1), ";" + (false ? "" : ";label:deprecatedDefaultSize;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQkkiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vZmxleCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB0eXBlIHsgQ29tYm9ib3hDb250cm9sUHJvcHMgfSBmcm9tICcuL3R5cGVzJztcblxuY29uc3QgZGVwcmVjYXRlZERlZmF1bHRTaXplID0gKCB7XG5cdF9fbmV4dDQwcHhEZWZhdWx0U2l6ZSxcbn06IFBpY2s8IENvbWJvYm94Q29udHJvbFByb3BzLCAnX19uZXh0NDBweERlZmF1bHRTaXplJyA+ICkgPT5cblx0ISBfX25leHQ0MHB4RGVmYXVsdFNpemUgJiZcblx0Y3NzYFxuXHRcdGhlaWdodDogMjhweDsgLy8gMzBweCAtIDJweCB2ZXJ0aWNhbCBib3JkZXJzIG9uIHBhcmVudCBjb250YWluZXJcblx0XHRwYWRkaW5nLWxlZnQ6ICR7IHNwYWNlKCAxICkgfTtcblx0XHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggMSApIH07XG5cdGA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dFdyYXBwZXJGbGV4ID0gc3R5bGVkKCBGbGV4IClgXG5cdGhlaWdodDogMzhweDsgLy8gNDBweCAtIDJweCB2ZXJ0aWNhbCBib3JkZXJzIG9uIHBhcmVudCBjb250YWluZXJcblx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggMiApIH07XG5cdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblxuXHQkeyBkZXByZWNhdGVkRGVmYXVsdFNpemUgfVxuYDtcbiJdfQ== */"); 38969 var InputWrapperFlex = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default3, false ? { 38970 target: "evuatpg0" 38971 } : { 38972 target: "evuatpg0", 38973 label: "InputWrapperFlex" 38974 })("height:38px;padding-left:", space(2), ";padding-right:", space(2), ";", deprecatedDefaultSize, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QjhDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgdHlwZSB7IENvbWJvYm94Q29udHJvbFByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmNvbnN0IGRlcHJlY2F0ZWREZWZhdWx0U2l6ZSA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG59OiBQaWNrPCBDb21ib2JveENvbnRyb2xQcm9wcywgJ19fbmV4dDQwcHhEZWZhdWx0U2l6ZScgPiApID0+XG5cdCEgX19uZXh0NDBweERlZmF1bHRTaXplICYmXG5cdGNzc2Bcblx0XHRoZWlnaHQ6IDI4cHg7IC8vIDMwcHggLSAycHggdmVydGljYWwgYm9yZGVycyBvbiBwYXJlbnQgY29udGFpbmVyXG5cdFx0cGFkZGluZy1sZWZ0OiAkeyBzcGFjZSggMSApIH07XG5cdFx0cGFkZGluZy1yaWdodDogJHsgc3BhY2UoIDEgKSB9O1xuXHRgO1xuXG5leHBvcnQgY29uc3QgSW5wdXRXcmFwcGVyRmxleCA9IHN0eWxlZCggRmxleCApYFxuXHRoZWlnaHQ6IDM4cHg7IC8vIDQwcHggLSAycHggdmVydGljYWwgYm9yZGVycyBvbiBwYXJlbnQgY29udGFpbmVyXG5cdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRwYWRkaW5nLXJpZ2h0OiAkeyBzcGFjZSggMiApIH07XG5cblx0JHsgZGVwcmVjYXRlZERlZmF1bHRTaXplIH1cbmA7XG4iXX0= */")); 38975 38976 // packages/components/build-module/form-token-field/token-input.js 38977 var import_element117 = __toESM(require_element()); 38978 var import_jsx_runtime183 = __toESM(require_jsx_runtime()); 38979 function UnForwardedTokenInput(props, ref) { 38980 const { 38981 value, 38982 isExpanded, 38983 instanceId, 38984 selectedSuggestionIndex, 38985 className: className2, 38986 onChange, 38987 onFocus, 38988 onBlur, 38989 ...restProps 38990 } = props; 38991 const [hasFocus2, setHasFocus] = (0, import_element117.useState)(false); 38992 const size3 = value ? value.length + 1 : 0; 38993 const onChangeHandler = (event) => { 38994 if (onChange) { 38995 onChange({ 38996 value: event.target.value 38997 }); 38998 } 38999 }; 39000 const onFocusHandler = (e3) => { 39001 setHasFocus(true); 39002 onFocus?.(e3); 39003 }; 39004 const onBlurHandler = (e3) => { 39005 setHasFocus(false); 39006 onBlur?.(e3); 39007 }; 39008 return /* @__PURE__ */ (0, import_jsx_runtime183.jsx)("input", { 39009 ref, 39010 id: `components-form-token-input-$instanceId}`, 39011 type: "text", 39012 ...restProps, 39013 value: value || "", 39014 onChange: onChangeHandler, 39015 onFocus: onFocusHandler, 39016 onBlur: onBlurHandler, 39017 size: size3, 39018 className: clsx_default(className2, "components-form-token-field__input"), 39019 autoComplete: "off", 39020 role: "combobox", 39021 "aria-expanded": isExpanded, 39022 "aria-autocomplete": "list", 39023 "aria-owns": isExpanded ? `components-form-token-suggestions-$instanceId}` : void 0, 39024 "aria-activedescendant": ( 39025 // Only add the `aria-activedescendant` attribute when: 39026 // - the user is actively interacting with the input (`hasFocus`) 39027 // - there is a selected suggestion (`selectedSuggestionIndex !== -1`) 39028 // - the list of suggestions are rendered in the DOM (`isExpanded`) 39029 hasFocus2 && selectedSuggestionIndex !== -1 && isExpanded ? `components-form-token-suggestions-$instanceId}-$selectedSuggestionIndex}` : void 0 39030 ), 39031 "aria-describedby": `components-form-token-suggestions-howto-$instanceId}` 39032 }); 39033 } 39034 var TokenInput = (0, import_element117.forwardRef)(UnForwardedTokenInput); 39035 var token_input_default = TokenInput; 39036 39037 // packages/components/build-module/form-token-field/suggestions-list.js 39038 var import_compose47 = __toESM(require_compose()); 39039 var import_i18n36 = __toESM(require_i18n()); 39040 var import_jsx_runtime184 = __toESM(require_jsx_runtime()); 39041 var handleMouseDown = (e3) => { 39042 e3.preventDefault(); 39043 }; 39044 function SuggestionsList({ 39045 selectedIndex, 39046 scrollIntoView, 39047 match: match5, 39048 onHover, 39049 onSelect, 39050 suggestions = [], 39051 displayTransform, 39052 instanceId, 39053 __experimentalRenderItem 39054 }) { 39055 const listRef = (0, import_compose47.useRefEffect)((listNode) => { 39056 if (selectedIndex > -1 && scrollIntoView && listNode.children[selectedIndex]) { 39057 listNode.children[selectedIndex].scrollIntoView({ 39058 behavior: "instant", 39059 block: "nearest", 39060 inline: "nearest" 39061 }); 39062 } 39063 }, [selectedIndex, scrollIntoView]); 39064 const handleHover = (suggestion) => { 39065 return () => { 39066 onHover?.(suggestion); 39067 }; 39068 }; 39069 const handleClick = (suggestion) => { 39070 return () => { 39071 onSelect?.(suggestion); 39072 }; 39073 }; 39074 const computeSuggestionMatch = (suggestion) => { 39075 const matchText = displayTransform(match5).normalize("NFKC").toLocaleLowerCase(); 39076 if (matchText.length === 0) { 39077 return null; 39078 } 39079 const transformedSuggestion = displayTransform(suggestion); 39080 const indexOfMatch = transformedSuggestion.normalize("NFKC").toLocaleLowerCase().indexOf(matchText); 39081 return { 39082 suggestionBeforeMatch: transformedSuggestion.substring(0, indexOfMatch), 39083 suggestionMatch: transformedSuggestion.substring(indexOfMatch, indexOfMatch + matchText.length), 39084 suggestionAfterMatch: transformedSuggestion.substring(indexOfMatch + matchText.length) 39085 }; 39086 }; 39087 return /* @__PURE__ */ (0, import_jsx_runtime184.jsxs)("ul", { 39088 ref: listRef, 39089 className: "components-form-token-field__suggestions-list", 39090 id: `components-form-token-suggestions-$instanceId}`, 39091 role: "listbox", 39092 children: [suggestions.map((suggestion, index2) => { 39093 const matchText = computeSuggestionMatch(suggestion); 39094 const isSelected2 = index2 === selectedIndex; 39095 const isDisabled = typeof suggestion === "object" && suggestion?.disabled; 39096 const key = typeof suggestion === "object" && "value" in suggestion ? suggestion?.value : displayTransform(suggestion); 39097 const className2 = clsx_default("components-form-token-field__suggestion", { 39098 "is-selected": isSelected2 39099 }); 39100 let output; 39101 if (typeof __experimentalRenderItem === "function") { 39102 output = __experimentalRenderItem({ 39103 item: suggestion 39104 }); 39105 } else if (matchText) { 39106 output = /* @__PURE__ */ (0, import_jsx_runtime184.jsxs)("span", { 39107 "aria-label": displayTransform(suggestion), 39108 children: [matchText.suggestionBeforeMatch, /* @__PURE__ */ (0, import_jsx_runtime184.jsx)("strong", { 39109 className: "components-form-token-field__suggestion-match", 39110 children: matchText.suggestionMatch 39111 }), matchText.suggestionAfterMatch] 39112 }); 39113 } else { 39114 output = displayTransform(suggestion); 39115 } 39116 return /* @__PURE__ */ (0, import_jsx_runtime184.jsx)("li", { 39117 id: `components-form-token-suggestions-$instanceId}-$index2}`, 39118 role: "option", 39119 className: className2, 39120 onMouseDown: handleMouseDown, 39121 onClick: handleClick(suggestion), 39122 onMouseEnter: handleHover(suggestion), 39123 "aria-selected": index2 === selectedIndex, 39124 "aria-disabled": isDisabled, 39125 children: output 39126 }, key); 39127 }), suggestions.length === 0 && /* @__PURE__ */ (0, import_jsx_runtime184.jsx)("li", { 39128 className: "components-form-token-field__suggestion is-empty", 39129 children: (0, import_i18n36.__)("No items found") 39130 })] 39131 }); 39132 } 39133 var suggestions_list_default = SuggestionsList; 39134 39135 // packages/components/build-module/higher-order/with-focus-outside/index.js 39136 var import_element118 = __toESM(require_element()); 39137 var import_compose48 = __toESM(require_compose()); 39138 var import_jsx_runtime185 = __toESM(require_jsx_runtime()); 39139 var with_focus_outside_default = (0, import_compose48.createHigherOrderComponent)((WrappedComponent) => (props) => { 39140 const [handleFocusOutside, setHandleFocusOutside] = (0, import_element118.useState)(void 0); 39141 const bindFocusOutsideHandler = (0, import_element118.useCallback)((node2) => setHandleFocusOutside(() => node2?.handleFocusOutside ? node2.handleFocusOutside.bind(node2) : void 0), []); 39142 return /* @__PURE__ */ (0, import_jsx_runtime185.jsx)("div", { 39143 ...(0, import_compose48.__experimentalUseFocusOutside)(handleFocusOutside), 39144 children: /* @__PURE__ */ (0, import_jsx_runtime185.jsx)(WrappedComponent, { 39145 ref: bindFocusOutsideHandler, 39146 ...props 39147 }) 39148 }); 39149 }, "withFocusOutside"); 39150 39151 // packages/components/build-module/spinner/styles.js 39152 function _EMOTION_STRINGIFIED_CSS_ERROR__25() { 39153 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 39154 } 39155 var spinAnimation = keyframes2` 39156 from { 39157 transform: rotate(0deg); 39158 } 39159 to { 39160 transform: rotate(360deg); 39161 } 39162 `; 39163 var StyledSpinner = /* @__PURE__ */ emotion_styled_base_browser_esm_default("svg", false ? { 39164 target: "ea4tfvq2" 39165 } : { 39166 target: "ea4tfvq2", 39167 label: "StyledSpinner" 39168 })("width:", config_values_default.spinnerSize, "px;height:", config_values_default.spinnerSize, "px;display:inline-block;margin:5px 11px 0;position:relative;color:", COLORS.theme.accent, ";overflow:visible;opacity:1;background-color:transparent;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQnVDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuY29uc3Qgc3BpbkFuaW1hdGlvbiA9IGtleWZyYW1lc2Bcblx0ZnJvbSB7XG5cdFx0dHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG5cdH1cblx0dG8ge1xuXHRcdHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG5cdH1cbiBgO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zdmdgXG5cdHdpZHRoOiAkeyBDT05GSUcuc3Bpbm5lclNpemUgfXB4O1xuXHRoZWlnaHQ6ICR7IENPTkZJRy5zcGlubmVyU2l6ZSB9cHg7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0bWFyZ2luOiA1cHggMTFweCAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdG92ZXJmbG93OiB2aXNpYmxlO1xuXHRvcGFjaXR5OiAxO1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbmA7XG5cbmNvbnN0IGNvbW1vblBhdGhQcm9wcyA9IGNzc2Bcblx0ZmlsbDogdHJhbnNwYXJlbnQ7XG5cdHN0cm9rZS13aWR0aDogMS41cHg7XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lclRyYWNrID0gc3R5bGVkLmNpcmNsZWBcblx0JHsgY29tbW9uUGF0aFByb3BzIH07XG5cdHN0cm9rZTogJHsgQ09MT1JTLmdyYXlbIDMwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lckluZGljYXRvciA9IHN0eWxlZC5wYXRoYFxuXHQkeyBjb21tb25QYXRoUHJvcHMgfTtcblx0c3Ryb2tlOiBjdXJyZW50Q29sb3I7XG5cdHN0cm9rZS1saW5lY2FwOiByb3VuZDtcblx0dHJhbnNmb3JtLW9yaWdpbjogNTAlIDUwJTtcblx0YW5pbWF0aW9uOiAxLjRzIGxpbmVhciBpbmZpbml0ZSBib3RoICR7IHNwaW5BbmltYXRpb24gfTtcbmA7XG4iXX0= */")); 39169 var commonPathProps = false ? { 39170 name: "9s4963", 39171 styles: "fill:transparent;stroke-width:1.5px" 39172 } : { 39173 name: "o2zng0-commonPathProps", 39174 styles: "fill:transparent;stroke-width:1.5px;label:commonPathProps;", 39175 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzJCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuY29uc3Qgc3BpbkFuaW1hdGlvbiA9IGtleWZyYW1lc2Bcblx0ZnJvbSB7XG5cdFx0dHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG5cdH1cblx0dG8ge1xuXHRcdHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG5cdH1cbiBgO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zdmdgXG5cdHdpZHRoOiAkeyBDT05GSUcuc3Bpbm5lclNpemUgfXB4O1xuXHRoZWlnaHQ6ICR7IENPTkZJRy5zcGlubmVyU2l6ZSB9cHg7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0bWFyZ2luOiA1cHggMTFweCAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdG92ZXJmbG93OiB2aXNpYmxlO1xuXHRvcGFjaXR5OiAxO1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbmA7XG5cbmNvbnN0IGNvbW1vblBhdGhQcm9wcyA9IGNzc2Bcblx0ZmlsbDogdHJhbnNwYXJlbnQ7XG5cdHN0cm9rZS13aWR0aDogMS41cHg7XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lclRyYWNrID0gc3R5bGVkLmNpcmNsZWBcblx0JHsgY29tbW9uUGF0aFByb3BzIH07XG5cdHN0cm9rZTogJHsgQ09MT1JTLmdyYXlbIDMwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lckluZGljYXRvciA9IHN0eWxlZC5wYXRoYFxuXHQkeyBjb21tb25QYXRoUHJvcHMgfTtcblx0c3Ryb2tlOiBjdXJyZW50Q29sb3I7XG5cdHN0cm9rZS1saW5lY2FwOiByb3VuZDtcblx0dHJhbnNmb3JtLW9yaWdpbjogNTAlIDUwJTtcblx0YW5pbWF0aW9uOiAxLjRzIGxpbmVhciBpbmZpbml0ZSBib3RoICR7IHNwaW5BbmltYXRpb24gfTtcbmA7XG4iXX0= */", 39176 toString: _EMOTION_STRINGIFIED_CSS_ERROR__25 39177 }; 39178 var SpinnerTrack = /* @__PURE__ */ emotion_styled_base_browser_esm_default("circle", false ? { 39179 target: "ea4tfvq1" 39180 } : { 39181 target: "ea4tfvq1", 39182 label: "SpinnerTrack" 39183 })(commonPathProps, ";stroke:", COLORS.gray[300], ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ3lDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuY29uc3Qgc3BpbkFuaW1hdGlvbiA9IGtleWZyYW1lc2Bcblx0ZnJvbSB7XG5cdFx0dHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG5cdH1cblx0dG8ge1xuXHRcdHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG5cdH1cbiBgO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zdmdgXG5cdHdpZHRoOiAkeyBDT05GSUcuc3Bpbm5lclNpemUgfXB4O1xuXHRoZWlnaHQ6ICR7IENPTkZJRy5zcGlubmVyU2l6ZSB9cHg7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0bWFyZ2luOiA1cHggMTFweCAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdG92ZXJmbG93OiB2aXNpYmxlO1xuXHRvcGFjaXR5OiAxO1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbmA7XG5cbmNvbnN0IGNvbW1vblBhdGhQcm9wcyA9IGNzc2Bcblx0ZmlsbDogdHJhbnNwYXJlbnQ7XG5cdHN0cm9rZS13aWR0aDogMS41cHg7XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lclRyYWNrID0gc3R5bGVkLmNpcmNsZWBcblx0JHsgY29tbW9uUGF0aFByb3BzIH07XG5cdHN0cm9rZTogJHsgQ09MT1JTLmdyYXlbIDMwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lckluZGljYXRvciA9IHN0eWxlZC5wYXRoYFxuXHQkeyBjb21tb25QYXRoUHJvcHMgfTtcblx0c3Ryb2tlOiBjdXJyZW50Q29sb3I7XG5cdHN0cm9rZS1saW5lY2FwOiByb3VuZDtcblx0dHJhbnNmb3JtLW9yaWdpbjogNTAlIDUwJTtcblx0YW5pbWF0aW9uOiAxLjRzIGxpbmVhciBpbmZpbml0ZSBib3RoICR7IHNwaW5BbmltYXRpb24gfTtcbmA7XG4iXX0= */")); 39184 var SpinnerIndicator = /* @__PURE__ */ emotion_styled_base_browser_esm_default("path", false ? { 39185 target: "ea4tfvq0" 39186 } : { 39187 target: "ea4tfvq0", 39188 label: "SpinnerIndicator" 39189 })(commonPathProps, ";stroke:currentColor;stroke-linecap:round;transform-origin:50% 50%;animation:1.4s linear infinite both ", spinAnimation, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQzJDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuY29uc3Qgc3BpbkFuaW1hdGlvbiA9IGtleWZyYW1lc2Bcblx0ZnJvbSB7XG5cdFx0dHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG5cdH1cblx0dG8ge1xuXHRcdHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG5cdH1cbiBgO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zdmdgXG5cdHdpZHRoOiAkeyBDT05GSUcuc3Bpbm5lclNpemUgfXB4O1xuXHRoZWlnaHQ6ICR7IENPTkZJRy5zcGlubmVyU2l6ZSB9cHg7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0bWFyZ2luOiA1cHggMTFweCAwO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdG92ZXJmbG93OiB2aXNpYmxlO1xuXHRvcGFjaXR5OiAxO1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbmA7XG5cbmNvbnN0IGNvbW1vblBhdGhQcm9wcyA9IGNzc2Bcblx0ZmlsbDogdHJhbnNwYXJlbnQ7XG5cdHN0cm9rZS13aWR0aDogMS41cHg7XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lclRyYWNrID0gc3R5bGVkLmNpcmNsZWBcblx0JHsgY29tbW9uUGF0aFByb3BzIH07XG5cdHN0cm9rZTogJHsgQ09MT1JTLmdyYXlbIDMwMCBdIH07XG5gO1xuXG5leHBvcnQgY29uc3QgU3Bpbm5lckluZGljYXRvciA9IHN0eWxlZC5wYXRoYFxuXHQkeyBjb21tb25QYXRoUHJvcHMgfTtcblx0c3Ryb2tlOiBjdXJyZW50Q29sb3I7XG5cdHN0cm9rZS1saW5lY2FwOiByb3VuZDtcblx0dHJhbnNmb3JtLW9yaWdpbjogNTAlIDUwJTtcblx0YW5pbWF0aW9uOiAxLjRzIGxpbmVhciBpbmZpbml0ZSBib3RoICR7IHNwaW5BbmltYXRpb24gfTtcbmA7XG4iXX0= */")); 39190 39191 // packages/components/build-module/spinner/index.js 39192 var import_element119 = __toESM(require_element()); 39193 var import_jsx_runtime186 = __toESM(require_jsx_runtime()); 39194 function UnforwardedSpinner({ 39195 className: className2, 39196 ...props 39197 }, forwardedRef) { 39198 return /* @__PURE__ */ (0, import_jsx_runtime186.jsxs)(StyledSpinner, { 39199 className: clsx_default("components-spinner", className2), 39200 viewBox: "0 0 100 100", 39201 width: "16", 39202 height: "16", 39203 xmlns: "http://www.w3.org/2000/svg", 39204 role: "presentation", 39205 focusable: "false", 39206 ...props, 39207 ref: forwardedRef, 39208 children: [/* @__PURE__ */ (0, import_jsx_runtime186.jsx)(SpinnerTrack, { 39209 cx: "50", 39210 cy: "50", 39211 r: "50", 39212 vectorEffect: "non-scaling-stroke" 39213 }), /* @__PURE__ */ (0, import_jsx_runtime186.jsx)(SpinnerIndicator, { 39214 d: "m 50 0 a 50 50 0 0 1 50 50", 39215 vectorEffect: "non-scaling-stroke" 39216 })] 39217 }); 39218 } 39219 var Spinner = (0, import_element119.forwardRef)(UnforwardedSpinner); 39220 var spinner_default = Spinner; 39221 39222 // packages/components/build-module/combobox-control/index.js 39223 var import_jsx_runtime187 = __toESM(require_jsx_runtime()); 39224 var noop11 = () => { 39225 }; 39226 var DetectOutside = with_focus_outside_default(class extends import_element120.Component { 39227 handleFocusOutside(event) { 39228 this.props.onFocusOutside(event); 39229 } 39230 render() { 39231 return this.props.children; 39232 } 39233 }); 39234 var getIndexOfMatchingSuggestion = (selectedSuggestion, matchingSuggestions) => selectedSuggestion === null ? -1 : matchingSuggestions.indexOf(selectedSuggestion); 39235 function ComboboxControl(props) { 39236 var _currentOption$label; 39237 const { 39238 __next40pxDefaultSize = false, 39239 value: valueProp, 39240 label, 39241 options: options2, 39242 onChange: onChangeProp, 39243 onFilterValueChange = noop11, 39244 hideLabelFromVision, 39245 help, 39246 allowReset = true, 39247 className: className2, 39248 isLoading = false, 39249 messages = { 39250 selected: (0, import_i18n37.__)("Item selected.") 39251 }, 39252 __experimentalRenderItem, 39253 expandOnFocus = true, 39254 placeholder 39255 } = useDeprecated36pxDefaultSizeProp(props); 39256 const [value, setValue] = useControlledValue({ 39257 value: valueProp, 39258 onChange: onChangeProp 39259 }); 39260 const currentOption = options2.find((option) => option.value === value); 39261 const currentLabel = (_currentOption$label = currentOption?.label) !== null && _currentOption$label !== void 0 ? _currentOption$label : ""; 39262 const instanceId = (0, import_compose49.useInstanceId)(ComboboxControl, "combobox-control"); 39263 const [selectedSuggestion, setSelectedSuggestion] = (0, import_element120.useState)(currentOption || null); 39264 const [isExpanded, setIsExpanded] = (0, import_element120.useState)(false); 39265 const [inputHasFocus, setInputHasFocus] = (0, import_element120.useState)(false); 39266 const [inputValue, setInputValue] = (0, import_element120.useState)(""); 39267 const inputContainer = (0, import_element120.useRef)(null); 39268 const matchingSuggestions = (0, import_element120.useMemo)(() => { 39269 const startsWithMatch = []; 39270 const containsMatch = []; 39271 const match5 = normalizeTextString(inputValue); 39272 options2.forEach((option) => { 39273 const index2 = normalizeTextString(option.label).indexOf(match5); 39274 if (index2 === 0) { 39275 startsWithMatch.push(option); 39276 } else if (index2 > 0) { 39277 containsMatch.push(option); 39278 } 39279 }); 39280 return startsWithMatch.concat(containsMatch); 39281 }, [inputValue, options2]); 39282 const onSuggestionSelected = (newSelectedSuggestion) => { 39283 if (newSelectedSuggestion.disabled) { 39284 return; 39285 } 39286 setValue(newSelectedSuggestion.value); 39287 (0, import_a11y5.speak)(messages.selected, "assertive"); 39288 setSelectedSuggestion(newSelectedSuggestion); 39289 setInputValue(""); 39290 setIsExpanded(false); 39291 }; 39292 const handleArrowNavigation = (offset3 = 1) => { 39293 const index2 = getIndexOfMatchingSuggestion(selectedSuggestion, matchingSuggestions); 39294 let nextIndex = index2 + offset3; 39295 if (nextIndex < 0) { 39296 nextIndex = matchingSuggestions.length - 1; 39297 } else if (nextIndex >= matchingSuggestions.length) { 39298 nextIndex = 0; 39299 } 39300 setSelectedSuggestion(matchingSuggestions[nextIndex]); 39301 setIsExpanded(true); 39302 }; 39303 const onKeyDown = withIgnoreIMEEvents((event) => { 39304 let preventDefault = false; 39305 if (event.defaultPrevented) { 39306 return; 39307 } 39308 switch (event.code) { 39309 case "Enter": 39310 if (selectedSuggestion) { 39311 onSuggestionSelected(selectedSuggestion); 39312 preventDefault = true; 39313 } 39314 break; 39315 case "ArrowUp": 39316 handleArrowNavigation(-1); 39317 preventDefault = true; 39318 break; 39319 case "ArrowDown": 39320 handleArrowNavigation(1); 39321 preventDefault = true; 39322 break; 39323 case "Escape": 39324 setIsExpanded(false); 39325 setSelectedSuggestion(null); 39326 preventDefault = true; 39327 break; 39328 default: 39329 break; 39330 } 39331 if (preventDefault) { 39332 event.preventDefault(); 39333 } 39334 }); 39335 const onBlur = () => { 39336 setInputHasFocus(false); 39337 }; 39338 const onFocus = () => { 39339 setInputHasFocus(true); 39340 if (expandOnFocus) { 39341 setIsExpanded(true); 39342 } 39343 onFilterValueChange(""); 39344 setInputValue(""); 39345 }; 39346 const onClick = () => { 39347 setIsExpanded(true); 39348 }; 39349 const onFocusOutside = () => { 39350 setIsExpanded(false); 39351 }; 39352 const onInputChange = (event) => { 39353 const text = event.value; 39354 setInputValue(text); 39355 onFilterValueChange(text); 39356 if (inputHasFocus) { 39357 setIsExpanded(true); 39358 } 39359 }; 39360 const handleOnReset = () => { 39361 setValue(null); 39362 inputContainer.current?.focus(); 39363 }; 39364 const handleResetStopPropagation = (event) => { 39365 event.stopPropagation(); 39366 }; 39367 (0, import_element120.useEffect)(() => { 39368 const hasMatchingSuggestions = matchingSuggestions.length > 0; 39369 const hasSelectedMatchingSuggestions = getIndexOfMatchingSuggestion(selectedSuggestion, matchingSuggestions) > 0; 39370 if (hasMatchingSuggestions && !hasSelectedMatchingSuggestions) { 39371 setSelectedSuggestion(matchingSuggestions[0]); 39372 } 39373 }, [matchingSuggestions, selectedSuggestion]); 39374 (0, import_element120.useEffect)(() => { 39375 const hasMatchingSuggestions = matchingSuggestions.length > 0; 39376 if (isExpanded) { 39377 const message3 = hasMatchingSuggestions ? (0, import_i18n37.sprintf)( 39378 /* translators: %d: number of results. */ 39379 (0, import_i18n37._n)("%d result found, use up and down arrow keys to navigate.", "%d results found, use up and down arrow keys to navigate.", matchingSuggestions.length), 39380 matchingSuggestions.length 39381 ) : (0, import_i18n37.__)("No results."); 39382 (0, import_a11y5.speak)(message3, "polite"); 39383 } 39384 }, [matchingSuggestions, isExpanded]); 39385 maybeWarnDeprecated36pxSize({ 39386 componentName: "ComboboxControl", 39387 __next40pxDefaultSize, 39388 size: void 0 39389 }); 39390 return /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(DetectOutside, { 39391 onFocusOutside, 39392 children: /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(base_control_default, { 39393 className: clsx_default(className2, "components-combobox-control"), 39394 label, 39395 id: `components-form-token-input-$instanceId}`, 39396 hideLabelFromVision, 39397 help, 39398 children: /* @__PURE__ */ (0, import_jsx_runtime187.jsxs)("div", { 39399 className: "components-combobox-control__suggestions-container", 39400 tabIndex: -1, 39401 onKeyDown, 39402 children: [/* @__PURE__ */ (0, import_jsx_runtime187.jsxs)(InputWrapperFlex, { 39403 __next40pxDefaultSize, 39404 children: [/* @__PURE__ */ (0, import_jsx_runtime187.jsx)(component_default5, { 39405 children: /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(token_input_default, { 39406 className: "components-combobox-control__input", 39407 instanceId, 39408 ref: inputContainer, 39409 placeholder, 39410 value: isExpanded ? inputValue : currentLabel, 39411 onFocus, 39412 onBlur, 39413 onClick, 39414 isExpanded, 39415 selectedSuggestionIndex: getIndexOfMatchingSuggestion(selectedSuggestion, matchingSuggestions), 39416 onChange: onInputChange 39417 }) 39418 }), isLoading && /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(spinner_default, {}), allowReset && Boolean(value) && !isExpanded && /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(button_default, { 39419 size: "small", 39420 icon: close_small_default, 39421 onClick: handleOnReset, 39422 onKeyDown: handleResetStopPropagation, 39423 label: (0, import_i18n37.__)("Reset") 39424 })] 39425 }), isExpanded && !isLoading && /* @__PURE__ */ (0, import_jsx_runtime187.jsx)(suggestions_list_default, { 39426 instanceId, 39427 match: { 39428 label: inputValue, 39429 value: "" 39430 }, 39431 displayTransform: (suggestion) => suggestion.label, 39432 suggestions: matchingSuggestions, 39433 selectedIndex: getIndexOfMatchingSuggestion(selectedSuggestion, matchingSuggestions), 39434 onHover: setSelectedSuggestion, 39435 onSelect: onSuggestionSelected, 39436 scrollIntoView: true, 39437 __experimentalRenderItem 39438 })] 39439 }) 39440 }) 39441 }); 39442 } 39443 var combobox_control_default = ComboboxControl; 39444 39445 // packages/components/build-module/composite/legacy/index.js 39446 var import_element121 = __toESM(require_element()); 39447 var import_compose50 = __toESM(require_compose()); 39448 var import_deprecated14 = __toESM(require_deprecated()); 39449 var import_jsx_runtime188 = __toESM(require_jsx_runtime()); 39450 function mapLegacyStatePropsToComponentProps(legacyProps) { 39451 if (legacyProps.state) { 39452 const { 39453 state, 39454 ...rest 39455 } = legacyProps; 39456 const { 39457 store, 39458 ...props 39459 } = mapLegacyStatePropsToComponentProps(state); 39460 return { 39461 ...rest, 39462 ...props, 39463 store 39464 }; 39465 } 39466 return legacyProps; 39467 } 39468 var LEGACY_TO_NEW_DISPLAY_NAME = { 39469 __unstableComposite: "Composite", 39470 __unstableCompositeGroup: "Composite.Group or Composite.Row", 39471 __unstableCompositeItem: "Composite.Item", 39472 __unstableUseCompositeState: "Composite" 39473 }; 39474 function proxyComposite(ProxiedComponent, propMap = {}) { 39475 var _ProxiedComponent$dis; 39476 const displayName = (_ProxiedComponent$dis = ProxiedComponent.displayName) !== null && _ProxiedComponent$dis !== void 0 ? _ProxiedComponent$dis : ""; 39477 const Component9 = (legacyProps) => { 39478 (0, import_deprecated14.default)(`wp.components.$displayName}`, { 39479 since: "6.7", 39480 alternative: LEGACY_TO_NEW_DISPLAY_NAME.hasOwnProperty(displayName) ? LEGACY_TO_NEW_DISPLAY_NAME[displayName] : void 0 39481 }); 39482 const { 39483 store, 39484 ...rest 39485 } = mapLegacyStatePropsToComponentProps(legacyProps); 39486 let props = rest; 39487 props = { 39488 ...props, 39489 id: (0, import_compose50.useInstanceId)(store, props.baseId, props.id) 39490 }; 39491 Object.entries(propMap).forEach(([from2, to]) => { 39492 if (props.hasOwnProperty(from2)) { 39493 Object.assign(props, { 39494 [to]: props[from2] 39495 }); 39496 delete props[from2]; 39497 } 39498 }); 39499 delete props.baseId; 39500 return /* @__PURE__ */ (0, import_jsx_runtime188.jsx)(ProxiedComponent, { 39501 ...props, 39502 store 39503 }); 39504 }; 39505 Component9.displayName = displayName; 39506 return Component9; 39507 } 39508 var UnproxiedCompositeGroup = (0, import_element121.forwardRef)(({ 39509 role, 39510 ...props 39511 }, ref) => { 39512 const Component9 = role === "row" ? Composite22.Row : Composite22.Group; 39513 return /* @__PURE__ */ (0, import_jsx_runtime188.jsx)(Component9, { 39514 ref, 39515 role, 39516 ...props 39517 }); 39518 }); 39519 var Composite4 = proxyComposite(Object.assign(Composite22, { 39520 displayName: "__unstableComposite" 39521 }), { 39522 baseId: "id" 39523 }); 39524 var CompositeGroup4 = proxyComposite(Object.assign(UnproxiedCompositeGroup, { 39525 displayName: "__unstableCompositeGroup" 39526 })); 39527 var CompositeItem4 = proxyComposite(Object.assign(Composite22.Item, { 39528 displayName: "__unstableCompositeItem" 39529 }), { 39530 focusable: "accessibleWhenDisabled" 39531 }); 39532 function useCompositeState(legacyStateOptions = {}) { 39533 (0, import_deprecated14.default)(`wp.components.__unstableUseCompositeState`, { 39534 since: "6.7", 39535 alternative: LEGACY_TO_NEW_DISPLAY_NAME.__unstableUseCompositeState 39536 }); 39537 const { 39538 baseId, 39539 currentId: defaultActiveId, 39540 orientation, 39541 rtl: rtl2 = false, 39542 loop: focusLoop = false, 39543 wrap: focusWrap = false, 39544 shift: focusShift = false, 39545 unstable_virtual: virtualFocus 39546 } = legacyStateOptions; 39547 return { 39548 baseId: (0, import_compose50.useInstanceId)(Composite4, "composite", baseId), 39549 store: useCompositeStore({ 39550 defaultActiveId, 39551 rtl: rtl2, 39552 orientation, 39553 focusLoop, 39554 focusShift, 39555 focusWrap, 39556 virtualFocus 39557 }) 39558 }; 39559 } 39560 39561 // packages/components/build-module/confirm-dialog/component.js 39562 var import_i18n39 = __toESM(require_i18n()); 39563 var import_element124 = __toESM(require_element()); 39564 39565 // packages/components/build-module/modal/index.js 39566 var import_element123 = __toESM(require_element()); 39567 var import_compose52 = __toESM(require_compose()); 39568 var import_i18n38 = __toESM(require_i18n()); 39569 var import_dom30 = __toESM(require_dom()); 39570 39571 // packages/components/build-module/modal/aria-helper.js 39572 var LIVE_REGION_ARIA_ROLES = /* @__PURE__ */ new Set(["alert", "status", "log", "marquee", "timer"]); 39573 var hiddenElementsByDepth = []; 39574 function modalize(modalElement) { 39575 const elements2 = Array.from(document.body.children); 39576 const hiddenElements = []; 39577 hiddenElementsByDepth.push(hiddenElements); 39578 for (const element of elements2) { 39579 if (element === modalElement) { 39580 continue; 39581 } 39582 if (elementShouldBeHidden(element)) { 39583 element.setAttribute("aria-hidden", "true"); 39584 hiddenElements.push(element); 39585 } 39586 } 39587 } 39588 function elementShouldBeHidden(element) { 39589 const role = element.getAttribute("role"); 39590 return !(element.tagName === "SCRIPT" || element.hasAttribute("hidden") || element.hasAttribute("aria-hidden") || element.hasAttribute("aria-live") || role && LIVE_REGION_ARIA_ROLES.has(role)); 39591 } 39592 function unmodalize() { 39593 const hiddenElements = hiddenElementsByDepth.pop(); 39594 if (!hiddenElements) { 39595 return; 39596 } 39597 for (const element of hiddenElements) { 39598 element.removeAttribute("aria-hidden"); 39599 } 39600 } 39601 39602 // packages/components/build-module/modal/use-modal-exit-animation.js 39603 var import_compose51 = __toESM(require_compose()); 39604 var import_element122 = __toESM(require_element()); 39605 var import_warning6 = __toESM(require_warning()); 39606 var FRAME_ANIMATION_DURATION = config_values_default.transitionDuration; 39607 var FRAME_ANIMATION_DURATION_NUMBER = Number.parseInt(config_values_default.transitionDuration); 39608 var EXIT_ANIMATION_NAME = "components-modal__disappear-animation"; 39609 function useModalExitAnimation() { 39610 const frameRef = (0, import_element122.useRef)(); 39611 const [isAnimatingOut, setIsAnimatingOut] = (0, import_element122.useState)(false); 39612 const isReducedMotion = (0, import_compose51.useReducedMotion)(); 39613 const closeModal = (0, import_element122.useCallback)(() => new Promise((closeModalResolve) => { 39614 const frameEl = frameRef.current; 39615 if (isReducedMotion) { 39616 closeModalResolve(); 39617 return; 39618 } 39619 if (!frameEl) { 39620 true ? (0, import_warning6.default)("wp.components.Modal: the Modal component can't be closed with an exit animation because of a missing reference to the modal frame element.") : void 0; 39621 closeModalResolve(); 39622 return; 39623 } 39624 let handleAnimationEnd; 39625 const startAnimation = () => new Promise((animationResolve) => { 39626 handleAnimationEnd = (e3) => { 39627 if (e3.animationName === EXIT_ANIMATION_NAME) { 39628 animationResolve(); 39629 } 39630 }; 39631 frameEl.addEventListener("animationend", handleAnimationEnd); 39632 setIsAnimatingOut(true); 39633 }); 39634 const animationTimeout = () => new Promise((timeoutResolve) => { 39635 setTimeout( 39636 () => timeoutResolve(), 39637 // Allow an extra 20% of the animation duration for the 39638 // animationend event to fire, in case the animation frame is 39639 // slightly delayes by some other events in the event loop. 39640 FRAME_ANIMATION_DURATION_NUMBER * 1.2 39641 ); 39642 }); 39643 Promise.race([startAnimation(), animationTimeout()]).then(() => { 39644 if (handleAnimationEnd) { 39645 frameEl.removeEventListener("animationend", handleAnimationEnd); 39646 } 39647 setIsAnimatingOut(false); 39648 closeModalResolve(); 39649 }); 39650 }), [isReducedMotion]); 39651 return { 39652 overlayClassname: isAnimatingOut ? "is-animating-out" : void 0, 39653 frameRef, 39654 frameStyle: { 39655 "--modal-frame-animation-duration": `$FRAME_ANIMATION_DURATION}` 39656 }, 39657 closeModal 39658 }; 39659 } 39660 39661 // packages/components/build-module/modal/index.js 39662 var import_jsx_runtime189 = __toESM(require_jsx_runtime()); 39663 var ModalContext = (0, import_element123.createContext)(/* @__PURE__ */ new Set()); 39664 ModalContext.displayName = "ModalContext"; 39665 var bodyOpenClasses = /* @__PURE__ */ new Map(); 39666 function UnforwardedModal(props, forwardedRef) { 39667 const { 39668 bodyOpenClassName = "modal-open", 39669 role = "dialog", 39670 title = null, 39671 focusOnMount = true, 39672 shouldCloseOnEsc = true, 39673 shouldCloseOnClickOutside = true, 39674 isDismissible = true, 39675 /* Accessibility. */ 39676 aria = { 39677 labelledby: void 0, 39678 describedby: void 0 39679 }, 39680 onRequestClose, 39681 icon, 39682 closeButtonLabel, 39683 children, 39684 style: style2, 39685 overlayClassName: overlayClassnameProp, 39686 className: className2, 39687 contentLabel, 39688 onKeyDown, 39689 isFullScreen = false, 39690 size: size3, 39691 headerActions = null, 39692 __experimentalHideHeader = false 39693 } = props; 39694 const ref = (0, import_element123.useRef)(); 39695 const instanceId = (0, import_compose52.useInstanceId)(Modal); 39696 const headingId = title ? `components-modal-header-$instanceId}` : aria.labelledby; 39697 const focusOnMountRef = (0, import_compose52.useFocusOnMount)(focusOnMount === "firstContentElement" ? "firstElement" : focusOnMount); 39698 const constrainedTabbingRef = (0, import_compose52.useConstrainedTabbing)(); 39699 const focusReturnRef = (0, import_compose52.useFocusReturn)(); 39700 const contentRef = (0, import_element123.useRef)(null); 39701 const childrenContainerRef = (0, import_element123.useRef)(null); 39702 const [hasScrolledContent, setHasScrolledContent] = (0, import_element123.useState)(false); 39703 const [hasScrollableContent, setHasScrollableContent] = (0, import_element123.useState)(false); 39704 let sizeClass; 39705 if (isFullScreen || size3 === "fill") { 39706 sizeClass = "is-full-screen"; 39707 } else if (size3) { 39708 sizeClass = `has-size-$size3}`; 39709 } 39710 const isContentScrollable = (0, import_element123.useCallback)(() => { 39711 if (!contentRef.current) { 39712 return; 39713 } 39714 const closestScrollContainer = (0, import_dom30.getScrollContainer)(contentRef.current); 39715 if (contentRef.current === closestScrollContainer) { 39716 setHasScrollableContent(true); 39717 } else { 39718 setHasScrollableContent(false); 39719 } 39720 }, [contentRef]); 39721 (0, import_element123.useEffect)(() => { 39722 modalize(ref.current); 39723 return () => unmodalize(); 39724 }, []); 39725 const onRequestCloseRef = (0, import_element123.useRef)(); 39726 (0, import_element123.useEffect)(() => { 39727 onRequestCloseRef.current = onRequestClose; 39728 }, [onRequestClose]); 39729 const dismissers = (0, import_element123.useContext)(ModalContext); 39730 const [nestedDismissers] = (0, import_element123.useState)(() => /* @__PURE__ */ new Set()); 39731 (0, import_element123.useEffect)(() => { 39732 dismissers.add(onRequestCloseRef); 39733 for (const dismisser of dismissers) { 39734 if (dismisser !== onRequestCloseRef) { 39735 dismisser.current?.(); 39736 } 39737 } 39738 return () => { 39739 for (const dismisser of nestedDismissers) { 39740 dismisser.current?.(); 39741 } 39742 dismissers.delete(onRequestCloseRef); 39743 }; 39744 }, [dismissers, nestedDismissers]); 39745 (0, import_element123.useEffect)(() => { 39746 var _bodyOpenClasses$get; 39747 const theClass = bodyOpenClassName; 39748 const oneMore = 1 + ((_bodyOpenClasses$get = bodyOpenClasses.get(theClass)) !== null && _bodyOpenClasses$get !== void 0 ? _bodyOpenClasses$get : 0); 39749 bodyOpenClasses.set(theClass, oneMore); 39750 document.body.classList.add(bodyOpenClassName); 39751 return () => { 39752 const oneLess = bodyOpenClasses.get(theClass) - 1; 39753 if (oneLess === 0) { 39754 document.body.classList.remove(theClass); 39755 bodyOpenClasses.delete(theClass); 39756 } else { 39757 bodyOpenClasses.set(theClass, oneLess); 39758 } 39759 }; 39760 }, [bodyOpenClassName]); 39761 const { 39762 closeModal, 39763 frameRef, 39764 frameStyle, 39765 overlayClassname 39766 } = useModalExitAnimation(); 39767 (0, import_element123.useLayoutEffect)(() => { 39768 if (!window.ResizeObserver || !childrenContainerRef.current) { 39769 return; 39770 } 39771 const resizeObserver = new ResizeObserver(isContentScrollable); 39772 resizeObserver.observe(childrenContainerRef.current); 39773 isContentScrollable(); 39774 return () => { 39775 resizeObserver.disconnect(); 39776 }; 39777 }, [isContentScrollable, childrenContainerRef]); 39778 function handleEscapeKeyDown(event) { 39779 if (shouldCloseOnEsc && (event.code === "Escape" || event.key === "Escape") && !event.defaultPrevented) { 39780 event.preventDefault(); 39781 closeModal().then(() => onRequestClose(event)); 39782 } 39783 } 39784 const onContentContainerScroll = (0, import_element123.useCallback)((e3) => { 39785 var _e$currentTarget$scro; 39786 const scrollY2 = (_e$currentTarget$scro = e3?.currentTarget?.scrollTop) !== null && _e$currentTarget$scro !== void 0 ? _e$currentTarget$scro : -1; 39787 if (!hasScrolledContent && scrollY2 > 0) { 39788 setHasScrolledContent(true); 39789 } else if (hasScrolledContent && scrollY2 <= 0) { 39790 setHasScrolledContent(false); 39791 } 39792 }, [hasScrolledContent]); 39793 let pressTarget = null; 39794 const overlayPressHandlers = { 39795 onPointerDown: (event) => { 39796 if (event.target === event.currentTarget) { 39797 pressTarget = event.target; 39798 event.preventDefault(); 39799 } 39800 }, 39801 // Closes the modal with two exceptions. 1. Opening the context menu on 39802 // the overlay. 2. Pressing on the overlay then dragging the pointer 39803 // over the modal and releasing. Due to the modal being a child of the 39804 // overlay, such a gesture is a `click` on the overlay and cannot be 39805 // excepted by a `click` handler. Thus the tactic of handling 39806 // `pointerup` and comparing its target to that of the `pointerdown`. 39807 onPointerUp: ({ 39808 target, 39809 button 39810 }) => { 39811 const isSameTarget = target === pressTarget; 39812 pressTarget = null; 39813 if (button === 0 && isSameTarget) { 39814 closeModal().then(() => onRequestClose()); 39815 } 39816 } 39817 }; 39818 const modal = ( 39819 // eslint-disable-next-line jsx-a11y/no-static-element-interactions 39820 /* @__PURE__ */ (0, import_jsx_runtime189.jsx)("div", { 39821 ref: (0, import_compose52.useMergeRefs)([ref, forwardedRef]), 39822 className: clsx_default("components-modal__screen-overlay", overlayClassname, overlayClassnameProp), 39823 onKeyDown: withIgnoreIMEEvents(handleEscapeKeyDown), 39824 ...shouldCloseOnClickOutside ? overlayPressHandlers : {}, 39825 children: /* @__PURE__ */ (0, import_jsx_runtime189.jsx)(style_provider_default, { 39826 document, 39827 children: /* @__PURE__ */ (0, import_jsx_runtime189.jsx)("div", { 39828 className: clsx_default("components-modal__frame", sizeClass, className2), 39829 style: { 39830 ...frameStyle, 39831 ...style2 39832 }, 39833 ref: (0, import_compose52.useMergeRefs)([frameRef, constrainedTabbingRef, focusReturnRef, focusOnMount !== "firstContentElement" ? focusOnMountRef : null]), 39834 role, 39835 "aria-label": contentLabel, 39836 "aria-labelledby": contentLabel ? void 0 : headingId, 39837 "aria-describedby": aria.describedby, 39838 tabIndex: -1, 39839 onKeyDown, 39840 children: /* @__PURE__ */ (0, import_jsx_runtime189.jsxs)("div", { 39841 className: clsx_default("components-modal__content", { 39842 "hide-header": __experimentalHideHeader, 39843 "is-scrollable": hasScrollableContent, 39844 "has-scrolled-content": hasScrolledContent 39845 }), 39846 role: "document", 39847 onScroll: onContentContainerScroll, 39848 ref: contentRef, 39849 "aria-label": hasScrollableContent ? (0, import_i18n38.__)("Scrollable section") : void 0, 39850 tabIndex: hasScrollableContent ? 0 : void 0, 39851 children: [!__experimentalHideHeader && /* @__PURE__ */ (0, import_jsx_runtime189.jsxs)("div", { 39852 className: "components-modal__header", 39853 children: [/* @__PURE__ */ (0, import_jsx_runtime189.jsxs)("div", { 39854 className: "components-modal__header-heading-container", 39855 children: [icon && /* @__PURE__ */ (0, import_jsx_runtime189.jsx)("span", { 39856 className: "components-modal__icon-container", 39857 "aria-hidden": true, 39858 children: icon 39859 }), title && /* @__PURE__ */ (0, import_jsx_runtime189.jsx)("h1", { 39860 id: headingId, 39861 className: "components-modal__header-heading", 39862 children: title 39863 })] 39864 }), headerActions, isDismissible && /* @__PURE__ */ (0, import_jsx_runtime189.jsxs)(import_jsx_runtime189.Fragment, { 39865 children: [/* @__PURE__ */ (0, import_jsx_runtime189.jsx)(component_default6, { 39866 marginBottom: 0, 39867 marginLeft: 2 39868 }), /* @__PURE__ */ (0, import_jsx_runtime189.jsx)(button_default, { 39869 size: "compact", 39870 onClick: (event) => closeModal().then(() => onRequestClose(event)), 39871 icon: close_default, 39872 label: closeButtonLabel || (0, import_i18n38.__)("Close") 39873 })] 39874 })] 39875 }), /* @__PURE__ */ (0, import_jsx_runtime189.jsx)("div", { 39876 ref: (0, import_compose52.useMergeRefs)([childrenContainerRef, focusOnMount === "firstContentElement" ? focusOnMountRef : null]), 39877 className: "components-modal__children-container", 39878 children 39879 })] 39880 }) 39881 }) 39882 }) 39883 }) 39884 ); 39885 return (0, import_element123.createPortal)(/* @__PURE__ */ (0, import_jsx_runtime189.jsx)(ModalContext.Provider, { 39886 value: nestedDismissers, 39887 children: modal 39888 }), document.body); 39889 } 39890 var Modal = (0, import_element123.forwardRef)(UnforwardedModal); 39891 var modal_default = Modal; 39892 39893 // packages/components/build-module/confirm-dialog/styles.js 39894 function _EMOTION_STRINGIFIED_CSS_ERROR__26() { 39895 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 39896 } 39897 var wrapper2 = false ? { 39898 name: "7g5ii0", 39899 styles: "&&{z-index:1000001;}" 39900 } : { 39901 name: "1gucf3d-wrapper", 39902 styles: "&&{z-index:1000001;};label:wrapper;", 39903 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhMEIiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFRoZSB6LWluZGV4IGZvciBDb25maXJtRGlhbG9nIGlzIGJlaW5nIHNldCBoZXJlIGluc3RlYWQgb2YgaW5cbiAqIHBhY2thZ2VzL2Jhc2Utc3R5bGVzL196LWluZGV4LnNjc3MsIGJlY2F1c2UgdGhpcyBjb21wb25lbnQgdXNlc1xuICogZW1vdGlvbiBpbnN0ZWFkIG9mIHNhc3MuXG4gKlxuICogQ29uZmlybURpYWxvZyBuZWVkcyB0aGlzIGhpZ2hlciB6LWluZGV4IHRvIGVuc3VyZSBpdCByZW5kZXJzIG9uIHRvcCBvZlxuICogYW55IHBhcmVudCBQb3BvdmVyIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXIgPSBjc3NgXG5cdCYmIHtcblx0XHR6LWluZGV4OiAxMDAwMDAxO1xuXHR9XG5gO1xuIl19 */", 39904 toString: _EMOTION_STRINGIFIED_CSS_ERROR__26 39905 }; 39906 39907 // packages/components/build-module/confirm-dialog/component.js 39908 var import_jsx_runtime190 = __toESM(require_jsx_runtime()); 39909 var UnconnectedConfirmDialog = (props, forwardedRef) => { 39910 const { 39911 isOpen: isOpenProp, 39912 onConfirm, 39913 onCancel, 39914 children, 39915 confirmButtonText, 39916 cancelButtonText, 39917 isBusy, 39918 ...otherProps 39919 } = useContextSystem(props, "ConfirmDialog"); 39920 const cx3 = useCx(); 39921 const wrapperClassName = cx3(wrapper2); 39922 const cancelButtonRef = (0, import_element124.useRef)(); 39923 const confirmButtonRef = (0, import_element124.useRef)(); 39924 const [isOpen, setIsOpen] = (0, import_element124.useState)(); 39925 const [shouldSelfClose, setShouldSelfClose] = (0, import_element124.useState)(); 39926 (0, import_element124.useEffect)(() => { 39927 const isIsOpenSet = typeof isOpenProp !== "undefined"; 39928 setIsOpen(isIsOpenSet ? isOpenProp : true); 39929 setShouldSelfClose(!isIsOpenSet); 39930 }, [isOpenProp]); 39931 const handleEvent = (0, import_element124.useCallback)((callback) => (event) => { 39932 callback?.(event); 39933 if (shouldSelfClose) { 39934 setIsOpen(false); 39935 } 39936 }, [shouldSelfClose, setIsOpen]); 39937 const handleEnter = (0, import_element124.useCallback)((event) => { 39938 const isConfirmOrCancelButton = event.target === cancelButtonRef.current || event.target === confirmButtonRef.current; 39939 if (!isConfirmOrCancelButton && event.key === "Enter") { 39940 handleEvent(onConfirm)(event); 39941 } 39942 }, [handleEvent, onConfirm]); 39943 const cancelLabel = cancelButtonText !== null && cancelButtonText !== void 0 ? cancelButtonText : (0, import_i18n39.__)("Cancel"); 39944 const confirmLabel = confirmButtonText !== null && confirmButtonText !== void 0 ? confirmButtonText : (0, import_i18n39.__)("OK"); 39945 return /* @__PURE__ */ (0, import_jsx_runtime190.jsx)(import_jsx_runtime190.Fragment, { 39946 children: isOpen && /* @__PURE__ */ (0, import_jsx_runtime190.jsx)(modal_default, { 39947 onRequestClose: handleEvent(onCancel), 39948 onKeyDown: handleEnter, 39949 closeButtonLabel: cancelLabel, 39950 isDismissible: true, 39951 ref: forwardedRef, 39952 overlayClassName: wrapperClassName, 39953 __experimentalHideHeader: true, 39954 ...otherProps, 39955 children: /* @__PURE__ */ (0, import_jsx_runtime190.jsxs)(component_default18, { 39956 spacing: 8, 39957 children: [/* @__PURE__ */ (0, import_jsx_runtime190.jsx)(component_default8, { 39958 children 39959 }), /* @__PURE__ */ (0, import_jsx_runtime190.jsxs)(component_default3, { 39960 direction: "row", 39961 justify: "flex-end", 39962 children: [/* @__PURE__ */ (0, import_jsx_runtime190.jsx)(button_default, { 39963 __next40pxDefaultSize: true, 39964 ref: cancelButtonRef, 39965 variant: "tertiary", 39966 onClick: handleEvent(onCancel), 39967 accessibleWhenDisabled: true, 39968 disabled: isBusy, 39969 children: cancelLabel 39970 }), /* @__PURE__ */ (0, import_jsx_runtime190.jsx)(button_default, { 39971 __next40pxDefaultSize: true, 39972 ref: confirmButtonRef, 39973 variant: "primary", 39974 onClick: handleEvent(onConfirm), 39975 accessibleWhenDisabled: true, 39976 disabled: isBusy, 39977 isBusy, 39978 children: confirmLabel 39979 })] 39980 })] 39981 }) 39982 }) 39983 }); 39984 }; 39985 var ConfirmDialog = contextConnect(UnconnectedConfirmDialog, "ConfirmDialog"); 39986 var component_default37 = ConfirmDialog; 39987 39988 // packages/components/build-module/custom-select-control/index.js 39989 var import_compose53 = __toESM(require_compose()); 39990 var import_i18n41 = __toESM(require_i18n()); 39991 39992 // packages/components/build-module/custom-select-control-v2/custom-select.js 39993 var import_element125 = __toESM(require_element()); 39994 var import_i18n40 = __toESM(require_i18n()); 39995 39996 // packages/components/build-module/custom-select-control-v2/styles.js 39997 function _EMOTION_STRINGIFIED_CSS_ERROR__27() { 39998 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 39999 } 40000 var ANIMATION_PARAMS = { 40001 SLIDE_AMOUNT: "2px", 40002 DURATION: "400ms", 40003 EASING: "cubic-bezier( 0.16, 1, 0.3, 1 )" 40004 }; 40005 var INLINE_PADDING = { 40006 compact: config_values_default.controlPaddingXSmall, 40007 small: config_values_default.controlPaddingXSmall, 40008 default: config_values_default.controlPaddingX 40009 }; 40010 var getSelectSize = (size3, heightProperty) => { 40011 const sizes = { 40012 compact: { 40013 [heightProperty]: 32, 40014 paddingInlineStart: INLINE_PADDING.compact, 40015 paddingInlineEnd: INLINE_PADDING.compact + chevronIconSize 40016 }, 40017 default: { 40018 [heightProperty]: 40, 40019 paddingInlineStart: INLINE_PADDING.default, 40020 paddingInlineEnd: INLINE_PADDING.default + chevronIconSize 40021 }, 40022 small: { 40023 [heightProperty]: 24, 40024 paddingInlineStart: INLINE_PADDING.small, 40025 paddingInlineEnd: INLINE_PADDING.small + chevronIconSize 40026 } 40027 }; 40028 return sizes[size3] || sizes.default; 40029 }; 40030 var getSelectItemSize = (size3) => { 40031 const checkmarkCorrection = 6; 40032 const sizes = { 40033 compact: { 40034 paddingInlineStart: INLINE_PADDING.compact, 40035 paddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection 40036 }, 40037 default: { 40038 paddingInlineStart: INLINE_PADDING.default, 40039 paddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection 40040 }, 40041 small: { 40042 paddingInlineStart: INLINE_PADDING.small, 40043 paddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection 40044 } 40045 }; 40046 return sizes[size3] || sizes.default; 40047 }; 40048 var Select22 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(Select, false ? { 40049 // Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component 40050 shouldForwardProp: (prop) => prop !== "hasCustomRenderProp", 40051 target: "e1p3eej77" 40052 } : { 40053 // Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component 40054 shouldForwardProp: (prop) => prop !== "hasCustomRenderProp", 40055 target: "e1p3eej77", 40056 label: "Select" 40057 })(({ 40058 size: size3, 40059 hasCustomRenderProp 40060 }) => /* @__PURE__ */ css("display:block;background-color:", COLORS.theme.background, ";border:none;color:", COLORS.theme.foreground, ";cursor:pointer;font-family:inherit;text-align:start;user-select:none;width:100%;&[data-focus-visible]{outline:none;}", getSelectSize(size3, hasCustomRenderProp ? "minHeight" : "height"), " ", !hasCustomRenderProp && truncateStyles, " ", fontSizeStyles({ 40061 inputSize: size3 40062 }), ";" + (false ? "" : ";label:Select;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsFW","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA4EsB","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */"); 40063 var slideDownAndFade = keyframes2({ 40064 "0%": { 40065 opacity: 0, 40066 transform: `translateY(-$ANIMATION_PARAMS.SLIDE_AMOUNT})` 40067 }, 40068 "100%": { 40069 opacity: 1, 40070 transform: "translateY(0)" 40071 } 40072 }); 40073 var SelectPopover22 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(SelectPopover, false ? { 40074 target: "e1p3eej76" 40075 } : { 40076 target: "e1p3eej76", 40077 label: "SelectPopover" 40078 })("display:flex;flex-direction:column;background-color:", COLORS.theme.background, ";border-radius:", config_values_default.radiusSmall, ";border:1px solid ", COLORS.theme.foreground, ";box-shadow:", config_values_default.elevationMedium, ";z-index:1000000;max-height:min( var( --popover-available-height, 400px ), 400px );overflow:auto;overscroll-behavior:contain;min-width:min-content;&[data-open]{@media not ( prefers-reduced-motion ){animation-duration:", ANIMATION_PARAMS.DURATION, ";animation-timing-function:", ANIMATION_PARAMS.EASING, ";animation-name:", slideDownAndFade, ";will-change:transform,opacity;}}&[data-focus-visible]{outline:none;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAmH4D","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40079 var SelectItem22 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(SelectItem, false ? { 40080 target: "e1p3eej75" 40081 } : { 40082 target: "e1p3eej75", 40083 label: "SelectItem" 40084 })(({ 40085 size: size3 40086 }) => /* @__PURE__ */ css("cursor:default;display:flex;align-items:center;justify-content:space-between;font-size:", config_values_default.fontSize, ";line-height:28px;padding-block:", space(2), ";scroll-margin:", space(1), ";user-select:none;&[aria-disabled='true']{cursor:not-allowed;}&[data-active-item]{background-color:", COLORS.theme.gray[300], ";}", getSelectItemSize(size3), ";" + (false ? "" : ";label:SelectItem;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA2JW","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsJ0B","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */"); 40087 var truncateStyles = false ? { 40088 name: "1h52dri", 40089 styles: "overflow:hidden;text-overflow:ellipsis;white-space:nowrap" 40090 } : { 40091 name: "5u3cjr-truncateStyles", 40092 styles: "overflow:hidden;text-overflow:ellipsis;white-space:nowrap;label:truncateStyles;", 40093 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAmL0B","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */", 40094 toString: _EMOTION_STRINGIFIED_CSS_ERROR__27 40095 }; 40096 var SelectedExperimentalHintWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 40097 target: "e1p3eej74" 40098 } : { 40099 target: "e1p3eej74", 40100 label: "SelectedExperimentalHintWrapper" 40101 })(truncateStyles, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAyLyD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40102 var SelectedExperimentalHintItem = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 40103 target: "e1p3eej73" 40104 } : { 40105 target: "e1p3eej73", 40106 label: "SelectedExperimentalHintItem" 40107 })("color:", COLORS.theme.gray[600], ";margin-inline-start:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA6LuD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40108 var WithHintItemWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 40109 target: "e1p3eej72" 40110 } : { 40111 target: "e1p3eej72", 40112 label: "WithHintItemWrapper" 40113 })("display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;flex:1;column-gap:", space(4), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAkM6C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40114 var WithHintItemHint = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 40115 target: "e1p3eej71" 40116 } : { 40117 target: "e1p3eej71", 40118 label: "WithHintItemHint" 40119 })("color:", COLORS.theme.gray[600], ";text-align:initial;line-height:", config_values_default.fontLineHeightBase, ";padding-inline-end:", space(1), ";margin-block:", space(1), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA2M2C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40120 var SelectedItemCheck = /* @__PURE__ */ emotion_styled_base_browser_esm_default(SelectItemCheck, false ? { 40121 target: "e1p3eej70" 40122 } : { 40123 target: "e1p3eej70", 40124 label: "SelectedItemCheck" 40125 })("display:flex;align-items:center;margin-inline-start:", space(2), ";fill:currentColor;align-self:start;margin-block-start:2px;font-size:0;", WithHintItemWrapper, "~&,&:not(:empty){font-size:24px;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAmNkE","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport { chevronIconSize } from '../select-control/styles/select-control-styles';\nimport { fontSizeStyles } from '../input-control/styles/input-control-styles';\nimport type { CustomSelectButtonSize } from './types';\n\n// TODO: extract to common utils and apply to relevant components\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst INLINE_PADDING = {\n\tcompact: CONFIG.controlPaddingXSmall,\n\tsmall: CONFIG.controlPaddingXSmall,\n\tdefault: CONFIG.controlPaddingX,\n};\n\nconst getSelectSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >,\n\theightProperty: 'minHeight' | 'height'\n) => {\n\tconst sizes = {\n\t\tcompact: {\n\t\t\t[ heightProperty ]: 32,\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact + chevronIconSize,\n\t\t},\n\t\tdefault: {\n\t\t\t[ heightProperty ]: 40,\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default + chevronIconSize,\n\t\t},\n\t\tsmall: {\n\t\t\t[ heightProperty ]: 24,\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small + chevronIconSize,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nconst getSelectItemSize = (\n\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >\n) => {\n\t// Used to visually align the checkmark with the chevron\n\tconst checkmarkCorrection = 6;\n\tconst sizes = {\n\t\tcompact: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.compact,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.compact - checkmarkCorrection,\n\t\t},\n\t\tdefault: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.default,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.default - checkmarkCorrection,\n\t\t},\n\t\tsmall: {\n\t\t\tpaddingInlineStart: INLINE_PADDING.small,\n\t\t\tpaddingInlineEnd: INLINE_PADDING.small - checkmarkCorrection,\n\t\t},\n\t};\n\n\treturn sizes[ size ] || sizes.default;\n};\n\nexport const Select = styled( Ariakit.Select, {\n\t// Do not forward `hasCustomRenderProp` to the underlying Ariakit.Select component\n\tshouldForwardProp: ( prop ) => prop !== 'hasCustomRenderProp',\n} )(\n\t( {\n\t\tsize,\n\t\thasCustomRenderProp,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t\thasCustomRenderProp: boolean;\n\t} ) => css`\n\t\tdisplay: block;\n\t\tbackground-color: ${ COLORS.theme.background };\n\t\tborder: none;\n\t\tcolor: ${ COLORS.theme.foreground };\n\t\tcursor: pointer;\n\t\tfont-family: inherit;\n\t\ttext-align: start;\n\t\tuser-select: none;\n\t\twidth: 100%;\n\n\t\t&[data-focus-visible] {\n\t\t\toutline: none; // handled by InputBase component\n\t\t}\n\n\t\t${ getSelectSize( size, hasCustomRenderProp ? 'minHeight' : 'height' ) }\n\t\t${ ! hasCustomRenderProp && truncateStyles }\n\t\t${ fontSizeStyles( { inputSize: size } ) }\n\t`\n);\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nexport const SelectPopover = styled( Ariakit.SelectPopover )`\n\tdisplay: flex;\n\tflex-direction: column;\n\n\tbackground-color: ${ COLORS.theme.background };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\tborder: 1px solid ${ COLORS.theme.foreground };\n\tbox-shadow: ${ CONFIG.elevationMedium };\n\n\t/* z-index(\".components-popover\") */\n\tz-index: 1000000;\n\n\tmax-height: min( var( --popover-available-height, 400px ), 400px );\n\toverflow: auto;\n\toverscroll-behavior: contain;\n\n\t/* The smallest size without overflowing the container. */\n\tmin-width: min-content;\n\n\t/* Animation */\n\t&[data-open] {\n\t\t@media not ( prefers-reduced-motion ) {\n\t\t\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\t\t\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\t\tanimation-name: ${ slideDownAndFade };\n\t\t\twill-change: transform, opacity;\n\t\t}\n\t}\n\n\t&[data-focus-visible] {\n\t\t/* The outline will be on the trigger, rather than the popover. */\n\t\toutline: none;\n\t}\n`;\n\nexport const SelectItem = styled( Ariakit.SelectItem )(\n\t( {\n\t\tsize,\n\t}: {\n\t\tsize: NonNullable< CustomSelectButtonSize[ 'size' ] >;\n\t} ) => css`\n\t\tcursor: default;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tjustify-content: space-between;\n\t\tfont-size: ${ CONFIG.fontSize };\n\t\t// TODO: reassess line-height for non-legacy v2\n\t\tline-height: 28px;\n\t\tpadding-block: ${ space( 2 ) };\n\t\tscroll-margin: ${ space( 1 ) };\n\t\tuser-select: none;\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: not-allowed;\n\t\t}\n\n\t\t&[data-active-item] {\n\t\t\tbackground-color: ${ COLORS.theme.gray[ 300 ] };\n\t\t}\n\n\t\t${ getSelectItemSize( size ) }\n\t`\n);\n\nconst truncateStyles = css`\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n`;\n\nexport const SelectedExperimentalHintWrapper = styled.div`\n\t${ truncateStyles }\n`;\n\nexport const SelectedExperimentalHintItem = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\tmargin-inline-start: ${ space( 2 ) };\n`;\n\nexport const WithHintItemWrapper = styled.div`\n\tdisplay: flex;\n\tjustify-content: space-between;\n\talign-items: center;\n\tflex-wrap: wrap;\n\tflex: 1;\n\tcolumn-gap: ${ space( 4 ) };\n`;\n\nexport const WithHintItemHint = styled.span`\n\tcolor: ${ COLORS.theme.gray[ 600 ] };\n\ttext-align: initial;\n\tline-height: ${ CONFIG.fontLineHeightBase };\n\tpadding-inline-end: ${ space( 1 ) };\n\tmargin-block: ${ space( 1 ) };\n`;\n\nexport const SelectedItemCheck = styled( Ariakit.SelectItemCheck )`\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-inline-start: ${ space( 2 ) };\n\tfill: currentColor;\n\n\t// Keep the checkmark vertically aligned at the top. Since the item text has a\n\t// 28px line height and the checkmark is 24px tall, a (28-24)/2 = 2px margin\n\t// is applied to keep the correct alignment between the text and the checkmark.\n\talign-self: start;\n\tmargin-block-start: 2px;\n\n\t// Since the checkmark's dimensions are applied with 'em' units, setting a\n\t// font size of 0 allows the space reserved for the checkmark to collapse for\n\t// items that are not selected or that don't have an associated item hint.\n\tfont-size: 0;\n\t${ WithHintItemWrapper } ~ &,\n\t&:not(:empty) {\n\t\tfont-size: 24px; // Size of checkmark icon\n\t}\n`;\n"]} */")); 40126 40127 // packages/components/build-module/custom-select-control-v2/custom-select.js 40128 var import_jsx_runtime191 = __toESM(require_jsx_runtime()); 40129 var CustomSelectContext = (0, import_element125.createContext)(void 0); 40130 CustomSelectContext.displayName = "CustomSelectContext"; 40131 function defaultRenderSelectedValue(value) { 40132 const isValueEmpty2 = Array.isArray(value) ? value.length === 0 : value === void 0 || value === null; 40133 if (isValueEmpty2) { 40134 return (0, import_i18n40.__)("Select an item"); 40135 } 40136 if (Array.isArray(value)) { 40137 return value.length === 1 ? value[0] : (0, import_i18n40.sprintf)( 40138 // translators: %d: number of items selected (it will always be 2 or more items) 40139 (0, import_i18n40._n)("%d item selected", "%d items selected", value.length), 40140 value.length 40141 ); 40142 } 40143 return value; 40144 } 40145 var CustomSelectButton = ({ 40146 renderSelectedValue, 40147 size: size3 = "default", 40148 store, 40149 ...restProps 40150 }) => { 40151 const { 40152 value: currentValue 40153 } = useStoreState(store); 40154 const computedRenderSelectedValue = (0, import_element125.useMemo)(() => renderSelectedValue !== null && renderSelectedValue !== void 0 ? renderSelectedValue : defaultRenderSelectedValue, [renderSelectedValue]); 40155 return /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(Select22, { 40156 ...restProps, 40157 size: size3, 40158 hasCustomRenderProp: !!renderSelectedValue, 40159 store, 40160 children: computedRenderSelectedValue(currentValue) 40161 }); 40162 }; 40163 function _CustomSelect(props) { 40164 const { 40165 children, 40166 hideLabelFromVision = false, 40167 label, 40168 size: size3, 40169 store, 40170 className: className2, 40171 isLegacy = false, 40172 ...restProps 40173 } = props; 40174 const onSelectPopoverKeyDown = (0, import_element125.useCallback)((e3) => { 40175 if (isLegacy) { 40176 e3.stopPropagation(); 40177 } 40178 }, [isLegacy]); 40179 const contextValue = (0, import_element125.useMemo)(() => ({ 40180 store, 40181 size: size3 40182 }), [store, size3]); 40183 return ( 40184 // Where should `restProps` be forwarded to? 40185 /* @__PURE__ */ (0, import_jsx_runtime191.jsxs)("div", { 40186 className: className2, 40187 children: [/* @__PURE__ */ (0, import_jsx_runtime191.jsx)(SelectLabel, { 40188 store, 40189 render: hideLabelFromVision ? ( 40190 // @ts-expect-error `children` are passed via the render prop 40191 /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(component_default2, {}) 40192 ) : ( 40193 // @ts-expect-error `children` are passed via the render prop 40194 /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(base_control_default.VisualLabel, { 40195 as: "div" 40196 }) 40197 ), 40198 children: label 40199 }), /* @__PURE__ */ (0, import_jsx_runtime191.jsxs)(input_base_default, { 40200 __next40pxDefaultSize: true, 40201 size: size3, 40202 suffix: /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(chevron_down_default2, {}), 40203 children: [/* @__PURE__ */ (0, import_jsx_runtime191.jsx)(CustomSelectButton, { 40204 ...restProps, 40205 size: size3, 40206 store, 40207 showOnKeyDown: !isLegacy 40208 }), /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(SelectPopover22, { 40209 gutter: 12, 40210 store, 40211 sameWidth: true, 40212 slide: false, 40213 onKeyDown: onSelectPopoverKeyDown, 40214 flip: !isLegacy, 40215 children: /* @__PURE__ */ (0, import_jsx_runtime191.jsx)(CustomSelectContext.Provider, { 40216 value: contextValue, 40217 children 40218 }) 40219 })] 40220 })] 40221 }) 40222 ); 40223 } 40224 var custom_select_default = _CustomSelect; 40225 40226 // packages/components/build-module/custom-select-control-v2/item.js 40227 var import_element126 = __toESM(require_element()); 40228 var import_jsx_runtime192 = __toESM(require_jsx_runtime()); 40229 function CustomSelectItem({ 40230 children, 40231 ...props 40232 }) { 40233 var _customSelectContext$; 40234 const customSelectContext = (0, import_element126.useContext)(CustomSelectContext); 40235 return /* @__PURE__ */ (0, import_jsx_runtime192.jsxs)(SelectItem22, { 40236 store: customSelectContext?.store, 40237 size: (_customSelectContext$ = customSelectContext?.size) !== null && _customSelectContext$ !== void 0 ? _customSelectContext$ : "default", 40238 ...props, 40239 children: [children !== null && children !== void 0 ? children : props.value, /* @__PURE__ */ (0, import_jsx_runtime192.jsx)(SelectedItemCheck, { 40240 children: /* @__PURE__ */ (0, import_jsx_runtime192.jsx)(icon_default2, { 40241 icon: check_default 40242 }) 40243 })] 40244 }); 40245 } 40246 CustomSelectItem.displayName = "CustomSelectControlV2.Item"; 40247 var item_default = CustomSelectItem; 40248 40249 // packages/components/build-module/custom-select-control/index.js 40250 var import_jsx_runtime193 = __toESM(require_jsx_runtime()); 40251 function useDeprecatedProps5({ 40252 __experimentalShowSelectedHint, 40253 ...otherProps 40254 }) { 40255 return { 40256 showSelectedHint: __experimentalShowSelectedHint, 40257 ...otherProps 40258 }; 40259 } 40260 function applyOptionDeprecations({ 40261 __experimentalHint, 40262 ...rest 40263 }) { 40264 return { 40265 hint: __experimentalHint, 40266 ...rest 40267 }; 40268 } 40269 function getDescribedBy(currentName, describedBy) { 40270 if (describedBy) { 40271 return describedBy; 40272 } 40273 return (0, import_i18n41.sprintf)((0, import_i18n41.__)("Currently selected: %s"), currentName); 40274 } 40275 function CustomSelectControl(props) { 40276 var _options$map$find; 40277 const { 40278 __next40pxDefaultSize = false, 40279 __shouldNotWarnDeprecated36pxSize, 40280 describedBy, 40281 options: options2, 40282 onChange, 40283 size: size3 = "default", 40284 value, 40285 className: classNameProp, 40286 showSelectedHint = false, 40287 ...restProps 40288 } = useDeprecatedProps5(props); 40289 maybeWarnDeprecated36pxSize({ 40290 componentName: "CustomSelectControl", 40291 __next40pxDefaultSize, 40292 size: size3, 40293 __shouldNotWarnDeprecated36pxSize 40294 }); 40295 const descriptionId = (0, import_compose53.useInstanceId)(CustomSelectControl, "custom-select-control__description"); 40296 const store = useSelectStore({ 40297 async setValue(nextValue) { 40298 const nextOption = options2.find((item2) => item2.key === nextValue); 40299 if (!onChange || !nextOption) { 40300 return; 40301 } 40302 await Promise.resolve(); 40303 const state = store.getState(); 40304 const changeObject = { 40305 highlightedIndex: state.renderedItems.findIndex((item2) => item2.value === nextValue), 40306 inputValue: "", 40307 isOpen: state.open, 40308 selectedItem: nextOption, 40309 type: "" 40310 }; 40311 onChange(changeObject); 40312 }, 40313 value: value?.key, 40314 // Setting the first option as a default value when no value is provided 40315 // is already done natively by the underlying Ariakit component, 40316 // but doing this explicitly avoids the `onChange` callback from firing 40317 // on initial render, thus making this implementation closer to the v1. 40318 defaultValue: options2[0]?.key 40319 }); 40320 const children = options2.map(applyOptionDeprecations).map(({ 40321 name, 40322 key, 40323 hint, 40324 style: style2, 40325 className: className2 40326 }) => { 40327 const withHint = /* @__PURE__ */ (0, import_jsx_runtime193.jsxs)(WithHintItemWrapper, { 40328 children: [/* @__PURE__ */ (0, import_jsx_runtime193.jsx)("span", { 40329 children: name 40330 }), /* @__PURE__ */ (0, import_jsx_runtime193.jsx)(WithHintItemHint, { 40331 // Keeping the classname for legacy reasons 40332 className: "components-custom-select-control__item-hint", 40333 children: hint 40334 })] 40335 }); 40336 return /* @__PURE__ */ (0, import_jsx_runtime193.jsx)(item_default, { 40337 value: key, 40338 children: hint ? withHint : name, 40339 style: style2, 40340 className: clsx_default( 40341 className2, 40342 // Keeping the classnames for legacy reasons 40343 "components-custom-select-control__item", 40344 { 40345 "has-hint": hint 40346 } 40347 ) 40348 }, key); 40349 }); 40350 const currentValue = useStoreState(store, "value"); 40351 const selectedOption = (_options$map$find = options2?.map(applyOptionDeprecations)?.find(({ 40352 key 40353 }) => currentValue === key)) !== null && _options$map$find !== void 0 ? _options$map$find : options2[0]; 40354 const renderSelectedValue = () => { 40355 if (!showSelectedHint || !selectedOption.hint) { 40356 return selectedOption?.name; 40357 } 40358 return /* @__PURE__ */ (0, import_jsx_runtime193.jsxs)(SelectedExperimentalHintWrapper, { 40359 children: [selectedOption?.name, /* @__PURE__ */ (0, import_jsx_runtime193.jsx)(SelectedExperimentalHintItem, { 40360 // Keeping the classname for legacy reasons 40361 className: "components-custom-select-control__hint", 40362 children: selectedOption?.hint 40363 })] 40364 }); 40365 }; 40366 const translatedSize = (() => { 40367 if (__next40pxDefaultSize && size3 === "default" || size3 === "__unstable-large") { 40368 return "default"; 40369 } 40370 if (!__next40pxDefaultSize && size3 === "default") { 40371 return "compact"; 40372 } 40373 return size3; 40374 })(); 40375 return /* @__PURE__ */ (0, import_jsx_runtime193.jsxs)(import_jsx_runtime193.Fragment, { 40376 children: [/* @__PURE__ */ (0, import_jsx_runtime193.jsx)(custom_select_default, { 40377 "aria-describedby": descriptionId, 40378 renderSelectedValue, 40379 size: translatedSize, 40380 store, 40381 className: clsx_default( 40382 // Keeping the classname for legacy reasons 40383 "components-custom-select-control", 40384 classNameProp 40385 ), 40386 isLegacy: true, 40387 ...restProps, 40388 children 40389 }), /* @__PURE__ */ (0, import_jsx_runtime193.jsx)(component_default2, { 40390 children: /* @__PURE__ */ (0, import_jsx_runtime193.jsx)("span", { 40391 id: descriptionId, 40392 children: getDescribedBy(selectedOption?.name, describedBy) 40393 }) 40394 })] 40395 }); 40396 } 40397 var custom_select_control_default = CustomSelectControl; 40398 40399 // node_modules/date-fns/toDate.mjs 40400 function toDate(argument) { 40401 const argStr = Object.prototype.toString.call(argument); 40402 if (argument instanceof Date || typeof argument === "object" && argStr === "[object Date]") { 40403 return new argument.constructor(+argument); 40404 } else if (typeof argument === "number" || argStr === "[object Number]" || typeof argument === "string" || argStr === "[object String]") { 40405 return new Date(argument); 40406 } else { 40407 return /* @__PURE__ */ new Date(NaN); 40408 } 40409 } 40410 40411 // node_modules/date-fns/constructFrom.mjs 40412 function constructFrom(date, value) { 40413 if (date instanceof Date) { 40414 return new date.constructor(value); 40415 } else { 40416 return new Date(value); 40417 } 40418 } 40419 40420 // node_modules/date-fns/addDays.mjs 40421 function addDays(date, amount) { 40422 const _date = toDate(date); 40423 if (isNaN(amount)) return constructFrom(date, NaN); 40424 if (!amount) { 40425 return _date; 40426 } 40427 _date.setDate(_date.getDate() + amount); 40428 return _date; 40429 } 40430 40431 // node_modules/date-fns/addMonths.mjs 40432 function addMonths(date, amount) { 40433 const _date = toDate(date); 40434 if (isNaN(amount)) return constructFrom(date, NaN); 40435 if (!amount) { 40436 return _date; 40437 } 40438 const dayOfMonth = _date.getDate(); 40439 const endOfDesiredMonth = constructFrom(date, _date.getTime()); 40440 endOfDesiredMonth.setMonth(_date.getMonth() + amount + 1, 0); 40441 const daysInMonth = endOfDesiredMonth.getDate(); 40442 if (dayOfMonth >= daysInMonth) { 40443 return endOfDesiredMonth; 40444 } else { 40445 _date.setFullYear( 40446 endOfDesiredMonth.getFullYear(), 40447 endOfDesiredMonth.getMonth(), 40448 dayOfMonth 40449 ); 40450 return _date; 40451 } 40452 } 40453 40454 // node_modules/date-fns/constants.mjs 40455 var daysInYear = 365.2425; 40456 var maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1e3; 40457 var minTime = -maxTime; 40458 var millisecondsInWeek = 6048e5; 40459 var millisecondsInDay = 864e5; 40460 var secondsInHour = 3600; 40461 var secondsInDay = secondsInHour * 24; 40462 var secondsInWeek = secondsInDay * 7; 40463 var secondsInYear = secondsInDay * daysInYear; 40464 var secondsInMonth = secondsInYear / 12; 40465 var secondsInQuarter = secondsInMonth * 3; 40466 40467 // node_modules/date-fns/_lib/defaultOptions.mjs 40468 var defaultOptions2 = {}; 40469 function getDefaultOptions() { 40470 return defaultOptions2; 40471 } 40472 40473 // node_modules/date-fns/startOfWeek.mjs 40474 function startOfWeek(date, options2) { 40475 const defaultOptions4 = getDefaultOptions(); 40476 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 40477 const _date = toDate(date); 40478 const day = _date.getDay(); 40479 const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn; 40480 _date.setDate(_date.getDate() - diff); 40481 _date.setHours(0, 0, 0, 0); 40482 return _date; 40483 } 40484 40485 // node_modules/date-fns/startOfISOWeek.mjs 40486 function startOfISOWeek(date) { 40487 return startOfWeek(date, { weekStartsOn: 1 }); 40488 } 40489 40490 // node_modules/date-fns/getISOWeekYear.mjs 40491 function getISOWeekYear(date) { 40492 const _date = toDate(date); 40493 const year = _date.getFullYear(); 40494 const fourthOfJanuaryOfNextYear = constructFrom(date, 0); 40495 fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4); 40496 fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0); 40497 const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear); 40498 const fourthOfJanuaryOfThisYear = constructFrom(date, 0); 40499 fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4); 40500 fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0); 40501 const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear); 40502 if (_date.getTime() >= startOfNextYear.getTime()) { 40503 return year + 1; 40504 } else if (_date.getTime() >= startOfThisYear.getTime()) { 40505 return year; 40506 } else { 40507 return year - 1; 40508 } 40509 } 40510 40511 // node_modules/date-fns/startOfDay.mjs 40512 function startOfDay(date) { 40513 const _date = toDate(date); 40514 _date.setHours(0, 0, 0, 0); 40515 return _date; 40516 } 40517 40518 // node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.mjs 40519 function getTimezoneOffsetInMilliseconds(date) { 40520 const _date = toDate(date); 40521 const utcDate = new Date( 40522 Date.UTC( 40523 _date.getFullYear(), 40524 _date.getMonth(), 40525 _date.getDate(), 40526 _date.getHours(), 40527 _date.getMinutes(), 40528 _date.getSeconds(), 40529 _date.getMilliseconds() 40530 ) 40531 ); 40532 utcDate.setUTCFullYear(_date.getFullYear()); 40533 return +date - +utcDate; 40534 } 40535 40536 // node_modules/date-fns/differenceInCalendarDays.mjs 40537 function differenceInCalendarDays(dateLeft, dateRight) { 40538 const startOfDayLeft = startOfDay(dateLeft); 40539 const startOfDayRight = startOfDay(dateRight); 40540 const timestampLeft = +startOfDayLeft - getTimezoneOffsetInMilliseconds(startOfDayLeft); 40541 const timestampRight = +startOfDayRight - getTimezoneOffsetInMilliseconds(startOfDayRight); 40542 return Math.round((timestampLeft - timestampRight) / millisecondsInDay); 40543 } 40544 40545 // node_modules/date-fns/startOfISOWeekYear.mjs 40546 function startOfISOWeekYear(date) { 40547 const year = getISOWeekYear(date); 40548 const fourthOfJanuary = constructFrom(date, 0); 40549 fourthOfJanuary.setFullYear(year, 0, 4); 40550 fourthOfJanuary.setHours(0, 0, 0, 0); 40551 return startOfISOWeek(fourthOfJanuary); 40552 } 40553 40554 // node_modules/date-fns/addWeeks.mjs 40555 function addWeeks(date, amount) { 40556 const days = amount * 7; 40557 return addDays(date, days); 40558 } 40559 40560 // node_modules/date-fns/addYears.mjs 40561 function addYears(date, amount) { 40562 return addMonths(date, amount * 12); 40563 } 40564 40565 // node_modules/date-fns/isSameDay.mjs 40566 function isSameDay(dateLeft, dateRight) { 40567 const dateLeftStartOfDay = startOfDay(dateLeft); 40568 const dateRightStartOfDay = startOfDay(dateRight); 40569 return +dateLeftStartOfDay === +dateRightStartOfDay; 40570 } 40571 40572 // node_modules/date-fns/isDate.mjs 40573 function isDate(value) { 40574 return value instanceof Date || typeof value === "object" && Object.prototype.toString.call(value) === "[object Date]"; 40575 } 40576 40577 // node_modules/date-fns/isValid.mjs 40578 function isValid(date) { 40579 if (!isDate(date) && typeof date !== "number") { 40580 return false; 40581 } 40582 const _date = toDate(date); 40583 return !isNaN(Number(_date)); 40584 } 40585 40586 // node_modules/date-fns/endOfMonth.mjs 40587 function endOfMonth(date) { 40588 const _date = toDate(date); 40589 const month = _date.getMonth(); 40590 _date.setFullYear(_date.getFullYear(), month + 1, 0); 40591 _date.setHours(23, 59, 59, 999); 40592 return _date; 40593 } 40594 40595 // node_modules/date-fns/eachDayOfInterval.mjs 40596 function eachDayOfInterval(interval, options2) { 40597 const startDate = toDate(interval.start); 40598 const endDate = toDate(interval.end); 40599 let reversed = +startDate > +endDate; 40600 const endTime = reversed ? +startDate : +endDate; 40601 const currentDate = reversed ? endDate : startDate; 40602 currentDate.setHours(0, 0, 0, 0); 40603 let step = options2?.step ?? 1; 40604 if (!step) return []; 40605 if (step < 0) { 40606 step = -step; 40607 reversed = !reversed; 40608 } 40609 const dates = []; 40610 while (+currentDate <= endTime) { 40611 dates.push(toDate(currentDate)); 40612 currentDate.setDate(currentDate.getDate() + step); 40613 currentDate.setHours(0, 0, 0, 0); 40614 } 40615 return reversed ? dates.reverse() : dates; 40616 } 40617 40618 // node_modules/date-fns/startOfMinute.mjs 40619 function startOfMinute(date) { 40620 const _date = toDate(date); 40621 _date.setSeconds(0, 0); 40622 return _date; 40623 } 40624 40625 // node_modules/date-fns/eachMonthOfInterval.mjs 40626 function eachMonthOfInterval(interval, options2) { 40627 const startDate = toDate(interval.start); 40628 const endDate = toDate(interval.end); 40629 let reversed = +startDate > +endDate; 40630 const endTime = reversed ? +startDate : +endDate; 40631 const currentDate = reversed ? endDate : startDate; 40632 currentDate.setHours(0, 0, 0, 0); 40633 currentDate.setDate(1); 40634 let step = options2?.step ?? 1; 40635 if (!step) return []; 40636 if (step < 0) { 40637 step = -step; 40638 reversed = !reversed; 40639 } 40640 const dates = []; 40641 while (+currentDate <= endTime) { 40642 dates.push(toDate(currentDate)); 40643 currentDate.setMonth(currentDate.getMonth() + step); 40644 } 40645 return reversed ? dates.reverse() : dates; 40646 } 40647 40648 // node_modules/date-fns/eachWeekOfInterval.mjs 40649 function eachWeekOfInterval(interval, options2) { 40650 const startDate = toDate(interval.start); 40651 const endDate = toDate(interval.end); 40652 let reversed = +startDate > +endDate; 40653 const startDateWeek = reversed ? startOfWeek(endDate, options2) : startOfWeek(startDate, options2); 40654 const endDateWeek = reversed ? startOfWeek(startDate, options2) : startOfWeek(endDate, options2); 40655 startDateWeek.setHours(15); 40656 endDateWeek.setHours(15); 40657 const endTime = +endDateWeek.getTime(); 40658 let currentDate = startDateWeek; 40659 let step = options2?.step ?? 1; 40660 if (!step) return []; 40661 if (step < 0) { 40662 step = -step; 40663 reversed = !reversed; 40664 } 40665 const dates = []; 40666 while (+currentDate <= endTime) { 40667 currentDate.setHours(0); 40668 dates.push(toDate(currentDate)); 40669 currentDate = addWeeks(currentDate, step); 40670 currentDate.setHours(15); 40671 } 40672 return reversed ? dates.reverse() : dates; 40673 } 40674 40675 // node_modules/date-fns/startOfMonth.mjs 40676 function startOfMonth(date) { 40677 const _date = toDate(date); 40678 _date.setDate(1); 40679 _date.setHours(0, 0, 0, 0); 40680 return _date; 40681 } 40682 40683 // node_modules/date-fns/startOfYear.mjs 40684 function startOfYear(date) { 40685 const cleanDate = toDate(date); 40686 const _date = constructFrom(date, 0); 40687 _date.setFullYear(cleanDate.getFullYear(), 0, 1); 40688 _date.setHours(0, 0, 0, 0); 40689 return _date; 40690 } 40691 40692 // node_modules/date-fns/endOfWeek.mjs 40693 function endOfWeek(date, options2) { 40694 const defaultOptions4 = getDefaultOptions(); 40695 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 40696 const _date = toDate(date); 40697 const day = _date.getDay(); 40698 const diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn); 40699 _date.setDate(_date.getDate() + diff); 40700 _date.setHours(23, 59, 59, 999); 40701 return _date; 40702 } 40703 40704 // node_modules/date-fns/locale/en-US/_lib/formatDistance.mjs 40705 var formatDistanceLocale = { 40706 lessThanXSeconds: { 40707 one: "less than a second", 40708 other: "less than {{count}} seconds" 40709 }, 40710 xSeconds: { 40711 one: "1 second", 40712 other: "{{count}} seconds" 40713 }, 40714 halfAMinute: "half a minute", 40715 lessThanXMinutes: { 40716 one: "less than a minute", 40717 other: "less than {{count}} minutes" 40718 }, 40719 xMinutes: { 40720 one: "1 minute", 40721 other: "{{count}} minutes" 40722 }, 40723 aboutXHours: { 40724 one: "about 1 hour", 40725 other: "about {{count}} hours" 40726 }, 40727 xHours: { 40728 one: "1 hour", 40729 other: "{{count}} hours" 40730 }, 40731 xDays: { 40732 one: "1 day", 40733 other: "{{count}} days" 40734 }, 40735 aboutXWeeks: { 40736 one: "about 1 week", 40737 other: "about {{count}} weeks" 40738 }, 40739 xWeeks: { 40740 one: "1 week", 40741 other: "{{count}} weeks" 40742 }, 40743 aboutXMonths: { 40744 one: "about 1 month", 40745 other: "about {{count}} months" 40746 }, 40747 xMonths: { 40748 one: "1 month", 40749 other: "{{count}} months" 40750 }, 40751 aboutXYears: { 40752 one: "about 1 year", 40753 other: "about {{count}} years" 40754 }, 40755 xYears: { 40756 one: "1 year", 40757 other: "{{count}} years" 40758 }, 40759 overXYears: { 40760 one: "over 1 year", 40761 other: "over {{count}} years" 40762 }, 40763 almostXYears: { 40764 one: "almost 1 year", 40765 other: "almost {{count}} years" 40766 } 40767 }; 40768 var formatDistance = (token2, count, options2) => { 40769 let result; 40770 const tokenValue = formatDistanceLocale[token2]; 40771 if (typeof tokenValue === "string") { 40772 result = tokenValue; 40773 } else if (count === 1) { 40774 result = tokenValue.one; 40775 } else { 40776 result = tokenValue.other.replace("{{count}}", count.toString()); 40777 } 40778 if (options2?.addSuffix) { 40779 if (options2.comparison && options2.comparison > 0) { 40780 return "in " + result; 40781 } else { 40782 return result + " ago"; 40783 } 40784 } 40785 return result; 40786 }; 40787 40788 // node_modules/date-fns/locale/_lib/buildFormatLongFn.mjs 40789 function buildFormatLongFn(args) { 40790 return (options2 = {}) => { 40791 const width = options2.width ? String(options2.width) : args.defaultWidth; 40792 const format3 = args.formats[width] || args.formats[args.defaultWidth]; 40793 return format3; 40794 }; 40795 } 40796 40797 // node_modules/date-fns/locale/en-US/_lib/formatLong.mjs 40798 var dateFormats = { 40799 full: "EEEE, MMMM do, y", 40800 long: "MMMM do, y", 40801 medium: "MMM d, y", 40802 short: "MM/dd/yyyy" 40803 }; 40804 var timeFormats = { 40805 full: "h:mm:ss a zzzz", 40806 long: "h:mm:ss a z", 40807 medium: "h:mm:ss a", 40808 short: "h:mm a" 40809 }; 40810 var dateTimeFormats = { 40811 full: "{{date}} 'at' {{time}}", 40812 long: "{{date}} 'at' {{time}}", 40813 medium: "{{date}}, {{time}}", 40814 short: "{{date}}, {{time}}" 40815 }; 40816 var formatLong = { 40817 date: buildFormatLongFn({ 40818 formats: dateFormats, 40819 defaultWidth: "full" 40820 }), 40821 time: buildFormatLongFn({ 40822 formats: timeFormats, 40823 defaultWidth: "full" 40824 }), 40825 dateTime: buildFormatLongFn({ 40826 formats: dateTimeFormats, 40827 defaultWidth: "full" 40828 }) 40829 }; 40830 40831 // node_modules/date-fns/locale/en-US/_lib/formatRelative.mjs 40832 var formatRelativeLocale = { 40833 lastWeek: "'last' eeee 'at' p", 40834 yesterday: "'yesterday at' p", 40835 today: "'today at' p", 40836 tomorrow: "'tomorrow at' p", 40837 nextWeek: "eeee 'at' p", 40838 other: "P" 40839 }; 40840 var formatRelative = (token2, _date, _baseDate, _options) => formatRelativeLocale[token2]; 40841 40842 // node_modules/date-fns/locale/_lib/buildLocalizeFn.mjs 40843 function buildLocalizeFn(args) { 40844 return (value, options2) => { 40845 const context = options2?.context ? String(options2.context) : "standalone"; 40846 let valuesArray; 40847 if (context === "formatting" && args.formattingValues) { 40848 const defaultWidth = args.defaultFormattingWidth || args.defaultWidth; 40849 const width = options2?.width ? String(options2.width) : defaultWidth; 40850 valuesArray = args.formattingValues[width] || args.formattingValues[defaultWidth]; 40851 } else { 40852 const defaultWidth = args.defaultWidth; 40853 const width = options2?.width ? String(options2.width) : args.defaultWidth; 40854 valuesArray = args.values[width] || args.values[defaultWidth]; 40855 } 40856 const index2 = args.argumentCallback ? args.argumentCallback(value) : value; 40857 return valuesArray[index2]; 40858 }; 40859 } 40860 40861 // node_modules/date-fns/locale/en-US/_lib/localize.mjs 40862 var eraValues = { 40863 narrow: ["B", "A"], 40864 abbreviated: ["BC", "AD"], 40865 wide: ["Before Christ", "Anno Domini"] 40866 }; 40867 var quarterValues = { 40868 narrow: ["1", "2", "3", "4"], 40869 abbreviated: ["Q1", "Q2", "Q3", "Q4"], 40870 wide: ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"] 40871 }; 40872 var monthValues = { 40873 narrow: ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"], 40874 abbreviated: [ 40875 "Jan", 40876 "Feb", 40877 "Mar", 40878 "Apr", 40879 "May", 40880 "Jun", 40881 "Jul", 40882 "Aug", 40883 "Sep", 40884 "Oct", 40885 "Nov", 40886 "Dec" 40887 ], 40888 wide: [ 40889 "January", 40890 "February", 40891 "March", 40892 "April", 40893 "May", 40894 "June", 40895 "July", 40896 "August", 40897 "September", 40898 "October", 40899 "November", 40900 "December" 40901 ] 40902 }; 40903 var dayValues = { 40904 narrow: ["S", "M", "T", "W", "T", "F", "S"], 40905 short: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], 40906 abbreviated: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], 40907 wide: [ 40908 "Sunday", 40909 "Monday", 40910 "Tuesday", 40911 "Wednesday", 40912 "Thursday", 40913 "Friday", 40914 "Saturday" 40915 ] 40916 }; 40917 var dayPeriodValues = { 40918 narrow: { 40919 am: "a", 40920 pm: "p", 40921 midnight: "mi", 40922 noon: "n", 40923 morning: "morning", 40924 afternoon: "afternoon", 40925 evening: "evening", 40926 night: "night" 40927 }, 40928 abbreviated: { 40929 am: "AM", 40930 pm: "PM", 40931 midnight: "midnight", 40932 noon: "noon", 40933 morning: "morning", 40934 afternoon: "afternoon", 40935 evening: "evening", 40936 night: "night" 40937 }, 40938 wide: { 40939 am: "a.m.", 40940 pm: "p.m.", 40941 midnight: "midnight", 40942 noon: "noon", 40943 morning: "morning", 40944 afternoon: "afternoon", 40945 evening: "evening", 40946 night: "night" 40947 } 40948 }; 40949 var formattingDayPeriodValues = { 40950 narrow: { 40951 am: "a", 40952 pm: "p", 40953 midnight: "mi", 40954 noon: "n", 40955 morning: "in the morning", 40956 afternoon: "in the afternoon", 40957 evening: "in the evening", 40958 night: "at night" 40959 }, 40960 abbreviated: { 40961 am: "AM", 40962 pm: "PM", 40963 midnight: "midnight", 40964 noon: "noon", 40965 morning: "in the morning", 40966 afternoon: "in the afternoon", 40967 evening: "in the evening", 40968 night: "at night" 40969 }, 40970 wide: { 40971 am: "a.m.", 40972 pm: "p.m.", 40973 midnight: "midnight", 40974 noon: "noon", 40975 morning: "in the morning", 40976 afternoon: "in the afternoon", 40977 evening: "in the evening", 40978 night: "at night" 40979 } 40980 }; 40981 var ordinalNumber = (dirtyNumber, _options) => { 40982 const number2 = Number(dirtyNumber); 40983 const rem100 = number2 % 100; 40984 if (rem100 > 20 || rem100 < 10) { 40985 switch (rem100 % 10) { 40986 case 1: 40987 return number2 + "st"; 40988 case 2: 40989 return number2 + "nd"; 40990 case 3: 40991 return number2 + "rd"; 40992 } 40993 } 40994 return number2 + "th"; 40995 }; 40996 var localize = { 40997 ordinalNumber, 40998 era: buildLocalizeFn({ 40999 values: eraValues, 41000 defaultWidth: "wide" 41001 }), 41002 quarter: buildLocalizeFn({ 41003 values: quarterValues, 41004 defaultWidth: "wide", 41005 argumentCallback: (quarter) => quarter - 1 41006 }), 41007 month: buildLocalizeFn({ 41008 values: monthValues, 41009 defaultWidth: "wide" 41010 }), 41011 day: buildLocalizeFn({ 41012 values: dayValues, 41013 defaultWidth: "wide" 41014 }), 41015 dayPeriod: buildLocalizeFn({ 41016 values: dayPeriodValues, 41017 defaultWidth: "wide", 41018 formattingValues: formattingDayPeriodValues, 41019 defaultFormattingWidth: "wide" 41020 }) 41021 }; 41022 41023 // node_modules/date-fns/locale/_lib/buildMatchFn.mjs 41024 function buildMatchFn(args) { 41025 return (string, options2 = {}) => { 41026 const width = options2.width; 41027 const matchPattern = width && args.matchPatterns[width] || args.matchPatterns[args.defaultMatchWidth]; 41028 const matchResult = string.match(matchPattern); 41029 if (!matchResult) { 41030 return null; 41031 } 41032 const matchedString = matchResult[0]; 41033 const parsePatterns = width && args.parsePatterns[width] || args.parsePatterns[args.defaultParseWidth]; 41034 const key = Array.isArray(parsePatterns) ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString)) : ( 41035 // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange you to fix the type 41036 findKey(parsePatterns, (pattern) => pattern.test(matchedString)) 41037 ); 41038 let value; 41039 value = args.valueCallback ? args.valueCallback(key) : key; 41040 value = options2.valueCallback ? ( 41041 // eslint-disable-next-line @typescript-eslint/no-explicit-any -- I challange you to fix the type 41042 options2.valueCallback(value) 41043 ) : value; 41044 const rest = string.slice(matchedString.length); 41045 return { value, rest }; 41046 }; 41047 } 41048 function findKey(object, predicate) { 41049 for (const key in object) { 41050 if (Object.prototype.hasOwnProperty.call(object, key) && predicate(object[key])) { 41051 return key; 41052 } 41053 } 41054 return void 0; 41055 } 41056 function findIndex(array, predicate) { 41057 for (let key = 0; key < array.length; key++) { 41058 if (predicate(array[key])) { 41059 return key; 41060 } 41061 } 41062 return void 0; 41063 } 41064 41065 // node_modules/date-fns/locale/_lib/buildMatchPatternFn.mjs 41066 function buildMatchPatternFn(args) { 41067 return (string, options2 = {}) => { 41068 const matchResult = string.match(args.matchPattern); 41069 if (!matchResult) return null; 41070 const matchedString = matchResult[0]; 41071 const parseResult = string.match(args.parsePattern); 41072 if (!parseResult) return null; 41073 let value = args.valueCallback ? args.valueCallback(parseResult[0]) : parseResult[0]; 41074 value = options2.valueCallback ? options2.valueCallback(value) : value; 41075 const rest = string.slice(matchedString.length); 41076 return { value, rest }; 41077 }; 41078 } 41079 41080 // node_modules/date-fns/locale/en-US/_lib/match.mjs 41081 var matchOrdinalNumberPattern = /^(\d+)(th|st|nd|rd)?/i; 41082 var parseOrdinalNumberPattern = /\d+/i; 41083 var matchEraPatterns = { 41084 narrow: /^(b|a)/i, 41085 abbreviated: /^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i, 41086 wide: /^(before christ|before common era|anno domini|common era)/i 41087 }; 41088 var parseEraPatterns = { 41089 any: [/^b/i, /^(a|c)/i] 41090 }; 41091 var matchQuarterPatterns = { 41092 narrow: /^[1234]/i, 41093 abbreviated: /^q[1234]/i, 41094 wide: /^[1234](th|st|nd|rd)? quarter/i 41095 }; 41096 var parseQuarterPatterns = { 41097 any: [/1/i, /2/i, /3/i, /4/i] 41098 }; 41099 var matchMonthPatterns = { 41100 narrow: /^[jfmasond]/i, 41101 abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i, 41102 wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i 41103 }; 41104 var parseMonthPatterns = { 41105 narrow: [ 41106 /^j/i, 41107 /^f/i, 41108 /^m/i, 41109 /^a/i, 41110 /^m/i, 41111 /^j/i, 41112 /^j/i, 41113 /^a/i, 41114 /^s/i, 41115 /^o/i, 41116 /^n/i, 41117 /^d/i 41118 ], 41119 any: [ 41120 /^ja/i, 41121 /^f/i, 41122 /^mar/i, 41123 /^ap/i, 41124 /^may/i, 41125 /^jun/i, 41126 /^jul/i, 41127 /^au/i, 41128 /^s/i, 41129 /^o/i, 41130 /^n/i, 41131 /^d/i 41132 ] 41133 }; 41134 var matchDayPatterns = { 41135 narrow: /^[smtwf]/i, 41136 short: /^(su|mo|tu|we|th|fr|sa)/i, 41137 abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i, 41138 wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i 41139 }; 41140 var parseDayPatterns = { 41141 narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i], 41142 any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i] 41143 }; 41144 var matchDayPeriodPatterns = { 41145 narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i, 41146 any: /^([ap]\.?\s?m\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i 41147 }; 41148 var parseDayPeriodPatterns = { 41149 any: { 41150 am: /^a/i, 41151 pm: /^p/i, 41152 midnight: /^mi/i, 41153 noon: /^no/i, 41154 morning: /morning/i, 41155 afternoon: /afternoon/i, 41156 evening: /evening/i, 41157 night: /night/i 41158 } 41159 }; 41160 var match2 = { 41161 ordinalNumber: buildMatchPatternFn({ 41162 matchPattern: matchOrdinalNumberPattern, 41163 parsePattern: parseOrdinalNumberPattern, 41164 valueCallback: (value) => parseInt(value, 10) 41165 }), 41166 era: buildMatchFn({ 41167 matchPatterns: matchEraPatterns, 41168 defaultMatchWidth: "wide", 41169 parsePatterns: parseEraPatterns, 41170 defaultParseWidth: "any" 41171 }), 41172 quarter: buildMatchFn({ 41173 matchPatterns: matchQuarterPatterns, 41174 defaultMatchWidth: "wide", 41175 parsePatterns: parseQuarterPatterns, 41176 defaultParseWidth: "any", 41177 valueCallback: (index2) => index2 + 1 41178 }), 41179 month: buildMatchFn({ 41180 matchPatterns: matchMonthPatterns, 41181 defaultMatchWidth: "wide", 41182 parsePatterns: parseMonthPatterns, 41183 defaultParseWidth: "any" 41184 }), 41185 day: buildMatchFn({ 41186 matchPatterns: matchDayPatterns, 41187 defaultMatchWidth: "wide", 41188 parsePatterns: parseDayPatterns, 41189 defaultParseWidth: "any" 41190 }), 41191 dayPeriod: buildMatchFn({ 41192 matchPatterns: matchDayPeriodPatterns, 41193 defaultMatchWidth: "any", 41194 parsePatterns: parseDayPeriodPatterns, 41195 defaultParseWidth: "any" 41196 }) 41197 }; 41198 41199 // node_modules/date-fns/locale/en-US.mjs 41200 var enUS = { 41201 code: "en-US", 41202 formatDistance, 41203 formatLong, 41204 formatRelative, 41205 localize, 41206 match: match2, 41207 options: { 41208 weekStartsOn: 0, 41209 firstWeekContainsDate: 1 41210 } 41211 }; 41212 41213 // node_modules/date-fns/getDayOfYear.mjs 41214 function getDayOfYear(date) { 41215 const _date = toDate(date); 41216 const diff = differenceInCalendarDays(_date, startOfYear(_date)); 41217 const dayOfYear = diff + 1; 41218 return dayOfYear; 41219 } 41220 41221 // node_modules/date-fns/getISOWeek.mjs 41222 function getISOWeek(date) { 41223 const _date = toDate(date); 41224 const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date); 41225 return Math.round(diff / millisecondsInWeek) + 1; 41226 } 41227 41228 // node_modules/date-fns/getWeekYear.mjs 41229 function getWeekYear(date, options2) { 41230 const _date = toDate(date); 41231 const year = _date.getFullYear(); 41232 const defaultOptions4 = getDefaultOptions(); 41233 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 41234 const firstWeekOfNextYear = constructFrom(date, 0); 41235 firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate); 41236 firstWeekOfNextYear.setHours(0, 0, 0, 0); 41237 const startOfNextYear = startOfWeek(firstWeekOfNextYear, options2); 41238 const firstWeekOfThisYear = constructFrom(date, 0); 41239 firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate); 41240 firstWeekOfThisYear.setHours(0, 0, 0, 0); 41241 const startOfThisYear = startOfWeek(firstWeekOfThisYear, options2); 41242 if (_date.getTime() >= startOfNextYear.getTime()) { 41243 return year + 1; 41244 } else if (_date.getTime() >= startOfThisYear.getTime()) { 41245 return year; 41246 } else { 41247 return year - 1; 41248 } 41249 } 41250 41251 // node_modules/date-fns/startOfWeekYear.mjs 41252 function startOfWeekYear(date, options2) { 41253 const defaultOptions4 = getDefaultOptions(); 41254 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 41255 const year = getWeekYear(date, options2); 41256 const firstWeek = constructFrom(date, 0); 41257 firstWeek.setFullYear(year, 0, firstWeekContainsDate); 41258 firstWeek.setHours(0, 0, 0, 0); 41259 const _date = startOfWeek(firstWeek, options2); 41260 return _date; 41261 } 41262 41263 // node_modules/date-fns/getWeek.mjs 41264 function getWeek(date, options2) { 41265 const _date = toDate(date); 41266 const diff = +startOfWeek(_date, options2) - +startOfWeekYear(_date, options2); 41267 return Math.round(diff / millisecondsInWeek) + 1; 41268 } 41269 41270 // node_modules/date-fns/_lib/addLeadingZeros.mjs 41271 function addLeadingZeros(number2, targetLength) { 41272 const sign = number2 < 0 ? "-" : ""; 41273 const output = Math.abs(number2).toString().padStart(targetLength, "0"); 41274 return sign + output; 41275 } 41276 41277 // node_modules/date-fns/_lib/format/lightFormatters.mjs 41278 var lightFormatters = { 41279 // Year 41280 y(date, token2) { 41281 const signedYear = date.getFullYear(); 41282 const year = signedYear > 0 ? signedYear : 1 - signedYear; 41283 return addLeadingZeros(token2 === "yy" ? year % 100 : year, token2.length); 41284 }, 41285 // Month 41286 M(date, token2) { 41287 const month = date.getMonth(); 41288 return token2 === "M" ? String(month + 1) : addLeadingZeros(month + 1, 2); 41289 }, 41290 // Day of the month 41291 d(date, token2) { 41292 return addLeadingZeros(date.getDate(), token2.length); 41293 }, 41294 // AM or PM 41295 a(date, token2) { 41296 const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? "pm" : "am"; 41297 switch (token2) { 41298 case "a": 41299 case "aa": 41300 return dayPeriodEnumValue.toUpperCase(); 41301 case "aaa": 41302 return dayPeriodEnumValue; 41303 case "aaaaa": 41304 return dayPeriodEnumValue[0]; 41305 case "aaaa": 41306 default: 41307 return dayPeriodEnumValue === "am" ? "a.m." : "p.m."; 41308 } 41309 }, 41310 // Hour [1-12] 41311 h(date, token2) { 41312 return addLeadingZeros(date.getHours() % 12 || 12, token2.length); 41313 }, 41314 // Hour [0-23] 41315 H(date, token2) { 41316 return addLeadingZeros(date.getHours(), token2.length); 41317 }, 41318 // Minute 41319 m(date, token2) { 41320 return addLeadingZeros(date.getMinutes(), token2.length); 41321 }, 41322 // Second 41323 s(date, token2) { 41324 return addLeadingZeros(date.getSeconds(), token2.length); 41325 }, 41326 // Fraction of second 41327 S(date, token2) { 41328 const numberOfDigits = token2.length; 41329 const milliseconds = date.getMilliseconds(); 41330 const fractionalSeconds = Math.trunc( 41331 milliseconds * Math.pow(10, numberOfDigits - 3) 41332 ); 41333 return addLeadingZeros(fractionalSeconds, token2.length); 41334 } 41335 }; 41336 41337 // node_modules/date-fns/_lib/format/formatters.mjs 41338 var dayPeriodEnum = { 41339 am: "am", 41340 pm: "pm", 41341 midnight: "midnight", 41342 noon: "noon", 41343 morning: "morning", 41344 afternoon: "afternoon", 41345 evening: "evening", 41346 night: "night" 41347 }; 41348 var formatters = { 41349 // Era 41350 G: function(date, token2, localize3) { 41351 const era = date.getFullYear() > 0 ? 1 : 0; 41352 switch (token2) { 41353 // AD, BC 41354 case "G": 41355 case "GG": 41356 case "GGG": 41357 return localize3.era(era, { width: "abbreviated" }); 41358 // A, B 41359 case "GGGGG": 41360 return localize3.era(era, { width: "narrow" }); 41361 // Anno Domini, Before Christ 41362 case "GGGG": 41363 default: 41364 return localize3.era(era, { width: "wide" }); 41365 } 41366 }, 41367 // Year 41368 y: function(date, token2, localize3) { 41369 if (token2 === "yo") { 41370 const signedYear = date.getFullYear(); 41371 const year = signedYear > 0 ? signedYear : 1 - signedYear; 41372 return localize3.ordinalNumber(year, { unit: "year" }); 41373 } 41374 return lightFormatters.y(date, token2); 41375 }, 41376 // Local week-numbering year 41377 Y: function(date, token2, localize3, options2) { 41378 const signedWeekYear = getWeekYear(date, options2); 41379 const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear; 41380 if (token2 === "YY") { 41381 const twoDigitYear = weekYear % 100; 41382 return addLeadingZeros(twoDigitYear, 2); 41383 } 41384 if (token2 === "Yo") { 41385 return localize3.ordinalNumber(weekYear, { unit: "year" }); 41386 } 41387 return addLeadingZeros(weekYear, token2.length); 41388 }, 41389 // ISO week-numbering year 41390 R: function(date, token2) { 41391 const isoWeekYear = getISOWeekYear(date); 41392 return addLeadingZeros(isoWeekYear, token2.length); 41393 }, 41394 // Extended year. This is a single number designating the year of this calendar system. 41395 // The main difference between `y` and `u` localizers are B.C. years: 41396 // | Year | `y` | `u` | 41397 // |------|-----|-----| 41398 // | AC 1 | 1 | 1 | 41399 // | BC 1 | 1 | 0 | 41400 // | BC 2 | 2 | -1 | 41401 // Also `yy` always returns the last two digits of a year, 41402 // while `uu` pads single digit years to 2 characters and returns other years unchanged. 41403 u: function(date, token2) { 41404 const year = date.getFullYear(); 41405 return addLeadingZeros(year, token2.length); 41406 }, 41407 // Quarter 41408 Q: function(date, token2, localize3) { 41409 const quarter = Math.ceil((date.getMonth() + 1) / 3); 41410 switch (token2) { 41411 // 1, 2, 3, 4 41412 case "Q": 41413 return String(quarter); 41414 // 01, 02, 03, 04 41415 case "QQ": 41416 return addLeadingZeros(quarter, 2); 41417 // 1st, 2nd, 3rd, 4th 41418 case "Qo": 41419 return localize3.ordinalNumber(quarter, { unit: "quarter" }); 41420 // Q1, Q2, Q3, Q4 41421 case "QQQ": 41422 return localize3.quarter(quarter, { 41423 width: "abbreviated", 41424 context: "formatting" 41425 }); 41426 // 1, 2, 3, 4 (narrow quarter; could be not numerical) 41427 case "QQQQQ": 41428 return localize3.quarter(quarter, { 41429 width: "narrow", 41430 context: "formatting" 41431 }); 41432 // 1st quarter, 2nd quarter, ... 41433 case "QQQQ": 41434 default: 41435 return localize3.quarter(quarter, { 41436 width: "wide", 41437 context: "formatting" 41438 }); 41439 } 41440 }, 41441 // Stand-alone quarter 41442 q: function(date, token2, localize3) { 41443 const quarter = Math.ceil((date.getMonth() + 1) / 3); 41444 switch (token2) { 41445 // 1, 2, 3, 4 41446 case "q": 41447 return String(quarter); 41448 // 01, 02, 03, 04 41449 case "qq": 41450 return addLeadingZeros(quarter, 2); 41451 // 1st, 2nd, 3rd, 4th 41452 case "qo": 41453 return localize3.ordinalNumber(quarter, { unit: "quarter" }); 41454 // Q1, Q2, Q3, Q4 41455 case "qqq": 41456 return localize3.quarter(quarter, { 41457 width: "abbreviated", 41458 context: "standalone" 41459 }); 41460 // 1, 2, 3, 4 (narrow quarter; could be not numerical) 41461 case "qqqqq": 41462 return localize3.quarter(quarter, { 41463 width: "narrow", 41464 context: "standalone" 41465 }); 41466 // 1st quarter, 2nd quarter, ... 41467 case "qqqq": 41468 default: 41469 return localize3.quarter(quarter, { 41470 width: "wide", 41471 context: "standalone" 41472 }); 41473 } 41474 }, 41475 // Month 41476 M: function(date, token2, localize3) { 41477 const month = date.getMonth(); 41478 switch (token2) { 41479 case "M": 41480 case "MM": 41481 return lightFormatters.M(date, token2); 41482 // 1st, 2nd, ..., 12th 41483 case "Mo": 41484 return localize3.ordinalNumber(month + 1, { unit: "month" }); 41485 // Jan, Feb, ..., Dec 41486 case "MMM": 41487 return localize3.month(month, { 41488 width: "abbreviated", 41489 context: "formatting" 41490 }); 41491 // J, F, ..., D 41492 case "MMMMM": 41493 return localize3.month(month, { 41494 width: "narrow", 41495 context: "formatting" 41496 }); 41497 // January, February, ..., December 41498 case "MMMM": 41499 default: 41500 return localize3.month(month, { width: "wide", context: "formatting" }); 41501 } 41502 }, 41503 // Stand-alone month 41504 L: function(date, token2, localize3) { 41505 const month = date.getMonth(); 41506 switch (token2) { 41507 // 1, 2, ..., 12 41508 case "L": 41509 return String(month + 1); 41510 // 01, 02, ..., 12 41511 case "LL": 41512 return addLeadingZeros(month + 1, 2); 41513 // 1st, 2nd, ..., 12th 41514 case "Lo": 41515 return localize3.ordinalNumber(month + 1, { unit: "month" }); 41516 // Jan, Feb, ..., Dec 41517 case "LLL": 41518 return localize3.month(month, { 41519 width: "abbreviated", 41520 context: "standalone" 41521 }); 41522 // J, F, ..., D 41523 case "LLLLL": 41524 return localize3.month(month, { 41525 width: "narrow", 41526 context: "standalone" 41527 }); 41528 // January, February, ..., December 41529 case "LLLL": 41530 default: 41531 return localize3.month(month, { width: "wide", context: "standalone" }); 41532 } 41533 }, 41534 // Local week of year 41535 w: function(date, token2, localize3, options2) { 41536 const week = getWeek(date, options2); 41537 if (token2 === "wo") { 41538 return localize3.ordinalNumber(week, { unit: "week" }); 41539 } 41540 return addLeadingZeros(week, token2.length); 41541 }, 41542 // ISO week of year 41543 I: function(date, token2, localize3) { 41544 const isoWeek = getISOWeek(date); 41545 if (token2 === "Io") { 41546 return localize3.ordinalNumber(isoWeek, { unit: "week" }); 41547 } 41548 return addLeadingZeros(isoWeek, token2.length); 41549 }, 41550 // Day of the month 41551 d: function(date, token2, localize3) { 41552 if (token2 === "do") { 41553 return localize3.ordinalNumber(date.getDate(), { unit: "date" }); 41554 } 41555 return lightFormatters.d(date, token2); 41556 }, 41557 // Day of year 41558 D: function(date, token2, localize3) { 41559 const dayOfYear = getDayOfYear(date); 41560 if (token2 === "Do") { 41561 return localize3.ordinalNumber(dayOfYear, { unit: "dayOfYear" }); 41562 } 41563 return addLeadingZeros(dayOfYear, token2.length); 41564 }, 41565 // Day of week 41566 E: function(date, token2, localize3) { 41567 const dayOfWeek = date.getDay(); 41568 switch (token2) { 41569 // Tue 41570 case "E": 41571 case "EE": 41572 case "EEE": 41573 return localize3.day(dayOfWeek, { 41574 width: "abbreviated", 41575 context: "formatting" 41576 }); 41577 // T 41578 case "EEEEE": 41579 return localize3.day(dayOfWeek, { 41580 width: "narrow", 41581 context: "formatting" 41582 }); 41583 // Tu 41584 case "EEEEEE": 41585 return localize3.day(dayOfWeek, { 41586 width: "short", 41587 context: "formatting" 41588 }); 41589 // Tuesday 41590 case "EEEE": 41591 default: 41592 return localize3.day(dayOfWeek, { 41593 width: "wide", 41594 context: "formatting" 41595 }); 41596 } 41597 }, 41598 // Local day of week 41599 e: function(date, token2, localize3, options2) { 41600 const dayOfWeek = date.getDay(); 41601 const localDayOfWeek = (dayOfWeek - options2.weekStartsOn + 8) % 7 || 7; 41602 switch (token2) { 41603 // Numerical value (Nth day of week with current locale or weekStartsOn) 41604 case "e": 41605 return String(localDayOfWeek); 41606 // Padded numerical value 41607 case "ee": 41608 return addLeadingZeros(localDayOfWeek, 2); 41609 // 1st, 2nd, ..., 7th 41610 case "eo": 41611 return localize3.ordinalNumber(localDayOfWeek, { unit: "day" }); 41612 case "eee": 41613 return localize3.day(dayOfWeek, { 41614 width: "abbreviated", 41615 context: "formatting" 41616 }); 41617 // T 41618 case "eeeee": 41619 return localize3.day(dayOfWeek, { 41620 width: "narrow", 41621 context: "formatting" 41622 }); 41623 // Tu 41624 case "eeeeee": 41625 return localize3.day(dayOfWeek, { 41626 width: "short", 41627 context: "formatting" 41628 }); 41629 // Tuesday 41630 case "eeee": 41631 default: 41632 return localize3.day(dayOfWeek, { 41633 width: "wide", 41634 context: "formatting" 41635 }); 41636 } 41637 }, 41638 // Stand-alone local day of week 41639 c: function(date, token2, localize3, options2) { 41640 const dayOfWeek = date.getDay(); 41641 const localDayOfWeek = (dayOfWeek - options2.weekStartsOn + 8) % 7 || 7; 41642 switch (token2) { 41643 // Numerical value (same as in `e`) 41644 case "c": 41645 return String(localDayOfWeek); 41646 // Padded numerical value 41647 case "cc": 41648 return addLeadingZeros(localDayOfWeek, token2.length); 41649 // 1st, 2nd, ..., 7th 41650 case "co": 41651 return localize3.ordinalNumber(localDayOfWeek, { unit: "day" }); 41652 case "ccc": 41653 return localize3.day(dayOfWeek, { 41654 width: "abbreviated", 41655 context: "standalone" 41656 }); 41657 // T 41658 case "ccccc": 41659 return localize3.day(dayOfWeek, { 41660 width: "narrow", 41661 context: "standalone" 41662 }); 41663 // Tu 41664 case "cccccc": 41665 return localize3.day(dayOfWeek, { 41666 width: "short", 41667 context: "standalone" 41668 }); 41669 // Tuesday 41670 case "cccc": 41671 default: 41672 return localize3.day(dayOfWeek, { 41673 width: "wide", 41674 context: "standalone" 41675 }); 41676 } 41677 }, 41678 // ISO day of week 41679 i: function(date, token2, localize3) { 41680 const dayOfWeek = date.getDay(); 41681 const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek; 41682 switch (token2) { 41683 // 2 41684 case "i": 41685 return String(isoDayOfWeek); 41686 // 02 41687 case "ii": 41688 return addLeadingZeros(isoDayOfWeek, token2.length); 41689 // 2nd 41690 case "io": 41691 return localize3.ordinalNumber(isoDayOfWeek, { unit: "day" }); 41692 // Tue 41693 case "iii": 41694 return localize3.day(dayOfWeek, { 41695 width: "abbreviated", 41696 context: "formatting" 41697 }); 41698 // T 41699 case "iiiii": 41700 return localize3.day(dayOfWeek, { 41701 width: "narrow", 41702 context: "formatting" 41703 }); 41704 // Tu 41705 case "iiiiii": 41706 return localize3.day(dayOfWeek, { 41707 width: "short", 41708 context: "formatting" 41709 }); 41710 // Tuesday 41711 case "iiii": 41712 default: 41713 return localize3.day(dayOfWeek, { 41714 width: "wide", 41715 context: "formatting" 41716 }); 41717 } 41718 }, 41719 // AM or PM 41720 a: function(date, token2, localize3) { 41721 const hours = date.getHours(); 41722 const dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am"; 41723 switch (token2) { 41724 case "a": 41725 case "aa": 41726 return localize3.dayPeriod(dayPeriodEnumValue, { 41727 width: "abbreviated", 41728 context: "formatting" 41729 }); 41730 case "aaa": 41731 return localize3.dayPeriod(dayPeriodEnumValue, { 41732 width: "abbreviated", 41733 context: "formatting" 41734 }).toLowerCase(); 41735 case "aaaaa": 41736 return localize3.dayPeriod(dayPeriodEnumValue, { 41737 width: "narrow", 41738 context: "formatting" 41739 }); 41740 case "aaaa": 41741 default: 41742 return localize3.dayPeriod(dayPeriodEnumValue, { 41743 width: "wide", 41744 context: "formatting" 41745 }); 41746 } 41747 }, 41748 // AM, PM, midnight, noon 41749 b: function(date, token2, localize3) { 41750 const hours = date.getHours(); 41751 let dayPeriodEnumValue; 41752 if (hours === 12) { 41753 dayPeriodEnumValue = dayPeriodEnum.noon; 41754 } else if (hours === 0) { 41755 dayPeriodEnumValue = dayPeriodEnum.midnight; 41756 } else { 41757 dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am"; 41758 } 41759 switch (token2) { 41760 case "b": 41761 case "bb": 41762 return localize3.dayPeriod(dayPeriodEnumValue, { 41763 width: "abbreviated", 41764 context: "formatting" 41765 }); 41766 case "bbb": 41767 return localize3.dayPeriod(dayPeriodEnumValue, { 41768 width: "abbreviated", 41769 context: "formatting" 41770 }).toLowerCase(); 41771 case "bbbbb": 41772 return localize3.dayPeriod(dayPeriodEnumValue, { 41773 width: "narrow", 41774 context: "formatting" 41775 }); 41776 case "bbbb": 41777 default: 41778 return localize3.dayPeriod(dayPeriodEnumValue, { 41779 width: "wide", 41780 context: "formatting" 41781 }); 41782 } 41783 }, 41784 // in the morning, in the afternoon, in the evening, at night 41785 B: function(date, token2, localize3) { 41786 const hours = date.getHours(); 41787 let dayPeriodEnumValue; 41788 if (hours >= 17) { 41789 dayPeriodEnumValue = dayPeriodEnum.evening; 41790 } else if (hours >= 12) { 41791 dayPeriodEnumValue = dayPeriodEnum.afternoon; 41792 } else if (hours >= 4) { 41793 dayPeriodEnumValue = dayPeriodEnum.morning; 41794 } else { 41795 dayPeriodEnumValue = dayPeriodEnum.night; 41796 } 41797 switch (token2) { 41798 case "B": 41799 case "BB": 41800 case "BBB": 41801 return localize3.dayPeriod(dayPeriodEnumValue, { 41802 width: "abbreviated", 41803 context: "formatting" 41804 }); 41805 case "BBBBB": 41806 return localize3.dayPeriod(dayPeriodEnumValue, { 41807 width: "narrow", 41808 context: "formatting" 41809 }); 41810 case "BBBB": 41811 default: 41812 return localize3.dayPeriod(dayPeriodEnumValue, { 41813 width: "wide", 41814 context: "formatting" 41815 }); 41816 } 41817 }, 41818 // Hour [1-12] 41819 h: function(date, token2, localize3) { 41820 if (token2 === "ho") { 41821 let hours = date.getHours() % 12; 41822 if (hours === 0) hours = 12; 41823 return localize3.ordinalNumber(hours, { unit: "hour" }); 41824 } 41825 return lightFormatters.h(date, token2); 41826 }, 41827 // Hour [0-23] 41828 H: function(date, token2, localize3) { 41829 if (token2 === "Ho") { 41830 return localize3.ordinalNumber(date.getHours(), { unit: "hour" }); 41831 } 41832 return lightFormatters.H(date, token2); 41833 }, 41834 // Hour [0-11] 41835 K: function(date, token2, localize3) { 41836 const hours = date.getHours() % 12; 41837 if (token2 === "Ko") { 41838 return localize3.ordinalNumber(hours, { unit: "hour" }); 41839 } 41840 return addLeadingZeros(hours, token2.length); 41841 }, 41842 // Hour [1-24] 41843 k: function(date, token2, localize3) { 41844 let hours = date.getHours(); 41845 if (hours === 0) hours = 24; 41846 if (token2 === "ko") { 41847 return localize3.ordinalNumber(hours, { unit: "hour" }); 41848 } 41849 return addLeadingZeros(hours, token2.length); 41850 }, 41851 // Minute 41852 m: function(date, token2, localize3) { 41853 if (token2 === "mo") { 41854 return localize3.ordinalNumber(date.getMinutes(), { unit: "minute" }); 41855 } 41856 return lightFormatters.m(date, token2); 41857 }, 41858 // Second 41859 s: function(date, token2, localize3) { 41860 if (token2 === "so") { 41861 return localize3.ordinalNumber(date.getSeconds(), { unit: "second" }); 41862 } 41863 return lightFormatters.s(date, token2); 41864 }, 41865 // Fraction of second 41866 S: function(date, token2) { 41867 return lightFormatters.S(date, token2); 41868 }, 41869 // Timezone (ISO-8601. If offset is 0, output is always `'Z'`) 41870 X: function(date, token2, _localize) { 41871 const timezoneOffset = date.getTimezoneOffset(); 41872 if (timezoneOffset === 0) { 41873 return "Z"; 41874 } 41875 switch (token2) { 41876 // Hours and optional minutes 41877 case "X": 41878 return formatTimezoneWithOptionalMinutes(timezoneOffset); 41879 // Hours, minutes and optional seconds without `:` delimiter 41880 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 41881 // so this token always has the same output as `XX` 41882 case "XXXX": 41883 case "XX": 41884 return formatTimezone(timezoneOffset); 41885 // Hours, minutes and optional seconds with `:` delimiter 41886 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 41887 // so this token always has the same output as `XXX` 41888 case "XXXXX": 41889 case "XXX": 41890 // Hours and minutes with `:` delimiter 41891 default: 41892 return formatTimezone(timezoneOffset, ":"); 41893 } 41894 }, 41895 // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent) 41896 x: function(date, token2, _localize) { 41897 const timezoneOffset = date.getTimezoneOffset(); 41898 switch (token2) { 41899 // Hours and optional minutes 41900 case "x": 41901 return formatTimezoneWithOptionalMinutes(timezoneOffset); 41902 // Hours, minutes and optional seconds without `:` delimiter 41903 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 41904 // so this token always has the same output as `xx` 41905 case "xxxx": 41906 case "xx": 41907 return formatTimezone(timezoneOffset); 41908 // Hours, minutes and optional seconds with `:` delimiter 41909 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 41910 // so this token always has the same output as `xxx` 41911 case "xxxxx": 41912 case "xxx": 41913 // Hours and minutes with `:` delimiter 41914 default: 41915 return formatTimezone(timezoneOffset, ":"); 41916 } 41917 }, 41918 // Timezone (GMT) 41919 O: function(date, token2, _localize) { 41920 const timezoneOffset = date.getTimezoneOffset(); 41921 switch (token2) { 41922 // Short 41923 case "O": 41924 case "OO": 41925 case "OOO": 41926 return "GMT" + formatTimezoneShort(timezoneOffset, ":"); 41927 // Long 41928 case "OOOO": 41929 default: 41930 return "GMT" + formatTimezone(timezoneOffset, ":"); 41931 } 41932 }, 41933 // Timezone (specific non-location) 41934 z: function(date, token2, _localize) { 41935 const timezoneOffset = date.getTimezoneOffset(); 41936 switch (token2) { 41937 // Short 41938 case "z": 41939 case "zz": 41940 case "zzz": 41941 return "GMT" + formatTimezoneShort(timezoneOffset, ":"); 41942 // Long 41943 case "zzzz": 41944 default: 41945 return "GMT" + formatTimezone(timezoneOffset, ":"); 41946 } 41947 }, 41948 // Seconds timestamp 41949 t: function(date, token2, _localize) { 41950 const timestamp = Math.trunc(date.getTime() / 1e3); 41951 return addLeadingZeros(timestamp, token2.length); 41952 }, 41953 // Milliseconds timestamp 41954 T: function(date, token2, _localize) { 41955 const timestamp = date.getTime(); 41956 return addLeadingZeros(timestamp, token2.length); 41957 } 41958 }; 41959 function formatTimezoneShort(offset3, delimiter2 = "") { 41960 const sign = offset3 > 0 ? "-" : "+"; 41961 const absOffset = Math.abs(offset3); 41962 const hours = Math.trunc(absOffset / 60); 41963 const minutes = absOffset % 60; 41964 if (minutes === 0) { 41965 return sign + String(hours); 41966 } 41967 return sign + String(hours) + delimiter2 + addLeadingZeros(minutes, 2); 41968 } 41969 function formatTimezoneWithOptionalMinutes(offset3, delimiter2) { 41970 if (offset3 % 60 === 0) { 41971 const sign = offset3 > 0 ? "-" : "+"; 41972 return sign + addLeadingZeros(Math.abs(offset3) / 60, 2); 41973 } 41974 return formatTimezone(offset3, delimiter2); 41975 } 41976 function formatTimezone(offset3, delimiter2 = "") { 41977 const sign = offset3 > 0 ? "-" : "+"; 41978 const absOffset = Math.abs(offset3); 41979 const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2); 41980 const minutes = addLeadingZeros(absOffset % 60, 2); 41981 return sign + hours + delimiter2 + minutes; 41982 } 41983 41984 // node_modules/date-fns/_lib/format/longFormatters.mjs 41985 var dateLongFormatter = (pattern, formatLong3) => { 41986 switch (pattern) { 41987 case "P": 41988 return formatLong3.date({ width: "short" }); 41989 case "PP": 41990 return formatLong3.date({ width: "medium" }); 41991 case "PPP": 41992 return formatLong3.date({ width: "long" }); 41993 case "PPPP": 41994 default: 41995 return formatLong3.date({ width: "full" }); 41996 } 41997 }; 41998 var timeLongFormatter = (pattern, formatLong3) => { 41999 switch (pattern) { 42000 case "p": 42001 return formatLong3.time({ width: "short" }); 42002 case "pp": 42003 return formatLong3.time({ width: "medium" }); 42004 case "ppp": 42005 return formatLong3.time({ width: "long" }); 42006 case "pppp": 42007 default: 42008 return formatLong3.time({ width: "full" }); 42009 } 42010 }; 42011 var dateTimeLongFormatter = (pattern, formatLong3) => { 42012 const matchResult = pattern.match(/(P+)(p+)?/) || []; 42013 const datePattern = matchResult[1]; 42014 const timePattern = matchResult[2]; 42015 if (!timePattern) { 42016 return dateLongFormatter(pattern, formatLong3); 42017 } 42018 let dateTimeFormat; 42019 switch (datePattern) { 42020 case "P": 42021 dateTimeFormat = formatLong3.dateTime({ width: "short" }); 42022 break; 42023 case "PP": 42024 dateTimeFormat = formatLong3.dateTime({ width: "medium" }); 42025 break; 42026 case "PPP": 42027 dateTimeFormat = formatLong3.dateTime({ width: "long" }); 42028 break; 42029 case "PPPP": 42030 default: 42031 dateTimeFormat = formatLong3.dateTime({ width: "full" }); 42032 break; 42033 } 42034 return dateTimeFormat.replace("{{date}}", dateLongFormatter(datePattern, formatLong3)).replace("{{time}}", timeLongFormatter(timePattern, formatLong3)); 42035 }; 42036 var longFormatters = { 42037 p: timeLongFormatter, 42038 P: dateTimeLongFormatter 42039 }; 42040 42041 // node_modules/date-fns/_lib/protectedTokens.mjs 42042 var dayOfYearTokenRE = /^D+$/; 42043 var weekYearTokenRE = /^Y+$/; 42044 var throwTokens = ["D", "DD", "YY", "YYYY"]; 42045 function isProtectedDayOfYearToken(token2) { 42046 return dayOfYearTokenRE.test(token2); 42047 } 42048 function isProtectedWeekYearToken(token2) { 42049 return weekYearTokenRE.test(token2); 42050 } 42051 function warnOrThrowProtectedError(token2, format3, input) { 42052 const _message = message(token2, format3, input); 42053 console.warn(_message); 42054 if (throwTokens.includes(token2)) throw new RangeError(_message); 42055 } 42056 function message(token2, format3, input) { 42057 const subject = token2[0] === "Y" ? "years" : "days of the month"; 42058 return `Use \`$token2.toLowerCase()}\` instead of \`$token2}\` (in \`$format3}\`) for formatting $subject} to the input \`$input}\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`; 42059 } 42060 42061 // node_modules/date-fns/format.mjs 42062 var formattingTokensRegExp = /[yYQqMLwIdDecihHKkms]o|(\w)\1*|''|'(''|[^'])+('|$)|./g; 42063 var longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g; 42064 var escapedStringRegExp = /^'([^]*?)'?$/; 42065 var doubleQuoteRegExp = /''/g; 42066 var unescapedLatinCharacterRegExp = /[a-zA-Z]/; 42067 function format(date, formatStr, options2) { 42068 const defaultOptions4 = getDefaultOptions(); 42069 const locale = options2?.locale ?? defaultOptions4.locale ?? enUS; 42070 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 42071 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 42072 const originalDate = toDate(date); 42073 if (!isValid(originalDate)) { 42074 throw new RangeError("Invalid time value"); 42075 } 42076 let parts = formatStr.match(longFormattingTokensRegExp).map((substring) => { 42077 const firstCharacter = substring[0]; 42078 if (firstCharacter === "p" || firstCharacter === "P") { 42079 const longFormatter = longFormatters[firstCharacter]; 42080 return longFormatter(substring, locale.formatLong); 42081 } 42082 return substring; 42083 }).join("").match(formattingTokensRegExp).map((substring) => { 42084 if (substring === "''") { 42085 return { isToken: false, value: "'" }; 42086 } 42087 const firstCharacter = substring[0]; 42088 if (firstCharacter === "'") { 42089 return { isToken: false, value: cleanEscapedString(substring) }; 42090 } 42091 if (formatters[firstCharacter]) { 42092 return { isToken: true, value: substring }; 42093 } 42094 if (firstCharacter.match(unescapedLatinCharacterRegExp)) { 42095 throw new RangeError( 42096 "Format string contains an unescaped latin alphabet character `" + firstCharacter + "`" 42097 ); 42098 } 42099 return { isToken: false, value: substring }; 42100 }); 42101 if (locale.localize.preprocessor) { 42102 parts = locale.localize.preprocessor(originalDate, parts); 42103 } 42104 const formatterOptions = { 42105 firstWeekContainsDate, 42106 weekStartsOn, 42107 locale 42108 }; 42109 return parts.map((part) => { 42110 if (!part.isToken) return part.value; 42111 const token2 = part.value; 42112 if (!options2?.useAdditionalWeekYearTokens && isProtectedWeekYearToken(token2) || !options2?.useAdditionalDayOfYearTokens && isProtectedDayOfYearToken(token2)) { 42113 warnOrThrowProtectedError(token2, formatStr, String(date)); 42114 } 42115 const formatter = formatters[token2[0]]; 42116 return formatter(originalDate, token2, locale.localize, formatterOptions); 42117 }).join(""); 42118 } 42119 function cleanEscapedString(input) { 42120 const matched = input.match(escapedStringRegExp); 42121 if (!matched) { 42122 return input; 42123 } 42124 return matched[1].replace(doubleQuoteRegExp, "'"); 42125 } 42126 42127 // node_modules/date-fns/getDaysInMonth.mjs 42128 function getDaysInMonth(date) { 42129 const _date = toDate(date); 42130 const year = _date.getFullYear(); 42131 const monthIndex = _date.getMonth(); 42132 const lastDayOfMonth = constructFrom(date, 0); 42133 lastDayOfMonth.setFullYear(year, monthIndex + 1, 0); 42134 lastDayOfMonth.setHours(0, 0, 0, 0); 42135 return lastDayOfMonth.getDate(); 42136 } 42137 42138 // node_modules/date-fns/isAfter.mjs 42139 function isAfter(date, dateToCompare) { 42140 const _date = toDate(date); 42141 const _dateToCompare = toDate(dateToCompare); 42142 return _date.getTime() > _dateToCompare.getTime(); 42143 } 42144 42145 // node_modules/date-fns/isBefore.mjs 42146 function isBefore(date, dateToCompare) { 42147 const _date = toDate(date); 42148 const _dateToCompare = toDate(dateToCompare); 42149 return +_date < +_dateToCompare; 42150 } 42151 42152 // node_modules/date-fns/isEqual.mjs 42153 function isEqual(leftDate, rightDate) { 42154 const _dateLeft = toDate(leftDate); 42155 const _dateRight = toDate(rightDate); 42156 return +_dateLeft === +_dateRight; 42157 } 42158 42159 // node_modules/date-fns/isSameMonth.mjs 42160 function isSameMonth(dateLeft, dateRight) { 42161 const _dateLeft = toDate(dateLeft); 42162 const _dateRight = toDate(dateRight); 42163 return _dateLeft.getFullYear() === _dateRight.getFullYear() && _dateLeft.getMonth() === _dateRight.getMonth(); 42164 } 42165 42166 // node_modules/date-fns/setMonth.mjs 42167 function setMonth(date, month) { 42168 const _date = toDate(date); 42169 const year = _date.getFullYear(); 42170 const day = _date.getDate(); 42171 const dateWithDesiredMonth = constructFrom(date, 0); 42172 dateWithDesiredMonth.setFullYear(year, month, 15); 42173 dateWithDesiredMonth.setHours(0, 0, 0, 0); 42174 const daysInMonth = getDaysInMonth(dateWithDesiredMonth); 42175 _date.setMonth(month, Math.min(day, daysInMonth)); 42176 return _date; 42177 } 42178 42179 // node_modules/date-fns/set.mjs 42180 function set(date, values) { 42181 let _date = toDate(date); 42182 if (isNaN(+_date)) { 42183 return constructFrom(date, NaN); 42184 } 42185 if (values.year != null) { 42186 _date.setFullYear(values.year); 42187 } 42188 if (values.month != null) { 42189 _date = setMonth(_date, values.month); 42190 } 42191 if (values.date != null) { 42192 _date.setDate(values.date); 42193 } 42194 if (values.hours != null) { 42195 _date.setHours(values.hours); 42196 } 42197 if (values.minutes != null) { 42198 _date.setMinutes(values.minutes); 42199 } 42200 if (values.seconds != null) { 42201 _date.setSeconds(values.seconds); 42202 } 42203 if (values.milliseconds != null) { 42204 _date.setMilliseconds(values.milliseconds); 42205 } 42206 return _date; 42207 } 42208 42209 // node_modules/date-fns/setYear.mjs 42210 function setYear(date, year) { 42211 const _date = toDate(date); 42212 if (isNaN(+_date)) { 42213 return constructFrom(date, NaN); 42214 } 42215 _date.setFullYear(year); 42216 return _date; 42217 } 42218 42219 // node_modules/date-fns/startOfToday.mjs 42220 function startOfToday() { 42221 return startOfDay(Date.now()); 42222 } 42223 42224 // node_modules/date-fns/subMonths.mjs 42225 function subMonths(date, amount) { 42226 return addMonths(date, -amount); 42227 } 42228 42229 // node_modules/date-fns/subWeeks.mjs 42230 function subWeeks(date, amount) { 42231 return addWeeks(date, -amount); 42232 } 42233 42234 // node_modules/date-fns/subYears.mjs 42235 function subYears(date, amount) { 42236 return addYears(date, -amount); 42237 } 42238 42239 // packages/components/build-module/date-time/date/index.js 42240 var import_i18n42 = __toESM(require_i18n()); 42241 var import_date2 = __toESM(require_date()); 42242 var import_element128 = __toESM(require_element()); 42243 42244 // packages/components/build-module/date-time/date/use-lilius/index.js 42245 var import_element127 = __toESM(require_element()); 42246 var Day = /* @__PURE__ */ (function(Day22) { 42247 Day22[Day22["SUNDAY"] = 0] = "SUNDAY"; 42248 Day22[Day22["MONDAY"] = 1] = "MONDAY"; 42249 Day22[Day22["TUESDAY"] = 2] = "TUESDAY"; 42250 Day22[Day22["WEDNESDAY"] = 3] = "WEDNESDAY"; 42251 Day22[Day22["THURSDAY"] = 4] = "THURSDAY"; 42252 Day22[Day22["FRIDAY"] = 5] = "FRIDAY"; 42253 Day22[Day22["SATURDAY"] = 6] = "SATURDAY"; 42254 return Day22; 42255 })({}); 42256 var inRange = (date, min3, max3) => (isEqual(date, min3) || isAfter(date, min3)) && (isEqual(date, max3) || isBefore(date, max3)); 42257 var clearTime2 = (date) => set(date, { 42258 hours: 0, 42259 minutes: 0, 42260 seconds: 0, 42261 milliseconds: 0 42262 }); 42263 var useLilius = ({ 42264 weekStartsOn = Day.SUNDAY, 42265 viewing: initialViewing = /* @__PURE__ */ new Date(), 42266 selected: initialSelected = [], 42267 numberOfMonths = 1 42268 } = {}) => { 42269 const [viewing, setViewing] = (0, import_element127.useState)(initialViewing); 42270 const viewToday = (0, import_element127.useCallback)(() => setViewing(startOfToday()), [setViewing]); 42271 const viewMonth = (0, import_element127.useCallback)((month) => setViewing((v3) => setMonth(v3, month)), []); 42272 const viewPreviousMonth = (0, import_element127.useCallback)(() => setViewing((v3) => subMonths(v3, 1)), []); 42273 const viewNextMonth = (0, import_element127.useCallback)(() => setViewing((v3) => addMonths(v3, 1)), []); 42274 const viewYear = (0, import_element127.useCallback)((year) => setViewing((v3) => setYear(v3, year)), []); 42275 const viewPreviousYear = (0, import_element127.useCallback)(() => setViewing((v3) => subYears(v3, 1)), []); 42276 const viewNextYear = (0, import_element127.useCallback)(() => setViewing((v3) => addYears(v3, 1)), []); 42277 const [selected, setSelected] = (0, import_element127.useState)(initialSelected.map(clearTime2)); 42278 const clearSelected = () => setSelected([]); 42279 const isSelected2 = (0, import_element127.useCallback)((date) => selected.findIndex((s3) => isEqual(s3, date)) > -1, [selected]); 42280 const select = (0, import_element127.useCallback)((date, replaceExisting) => { 42281 if (replaceExisting) { 42282 setSelected(Array.isArray(date) ? date : [date]); 42283 } else { 42284 setSelected((selectedItems) => selectedItems.concat(Array.isArray(date) ? date : [date])); 42285 } 42286 }, []); 42287 const deselect = (0, import_element127.useCallback)((date) => setSelected((selectedItems) => Array.isArray(date) ? selectedItems.filter((s3) => !date.map((d3) => d3.getTime()).includes(s3.getTime())) : selectedItems.filter((s3) => !isEqual(s3, date))), []); 42288 const toggle = (0, import_element127.useCallback)((date, replaceExisting) => isSelected2(date) ? deselect(date) : select(date, replaceExisting), [deselect, isSelected2, select]); 42289 const selectRange = (0, import_element127.useCallback)((start, end, replaceExisting) => { 42290 if (replaceExisting) { 42291 setSelected(eachDayOfInterval({ 42292 start, 42293 end 42294 })); 42295 } else { 42296 setSelected((selectedItems) => selectedItems.concat(eachDayOfInterval({ 42297 start, 42298 end 42299 }))); 42300 } 42301 }, []); 42302 const deselectRange = (0, import_element127.useCallback)((start, end) => { 42303 setSelected((selectedItems) => selectedItems.filter((s3) => !eachDayOfInterval({ 42304 start, 42305 end 42306 }).map((d3) => d3.getTime()).includes(s3.getTime()))); 42307 }, []); 42308 const calendar = (0, import_element127.useMemo)(() => eachMonthOfInterval({ 42309 start: startOfMonth(viewing), 42310 end: endOfMonth(addMonths(viewing, numberOfMonths - 1)) 42311 }).map((month) => eachWeekOfInterval({ 42312 start: startOfMonth(month), 42313 end: endOfMonth(month) 42314 }, { 42315 weekStartsOn 42316 }).map((week) => eachDayOfInterval({ 42317 start: startOfWeek(week, { 42318 weekStartsOn 42319 }), 42320 end: endOfWeek(week, { 42321 weekStartsOn 42322 }) 42323 }))), [viewing, weekStartsOn, numberOfMonths]); 42324 return { 42325 clearTime: clearTime2, 42326 inRange, 42327 viewing, 42328 setViewing, 42329 viewToday, 42330 viewMonth, 42331 viewPreviousMonth, 42332 viewNextMonth, 42333 viewYear, 42334 viewPreviousYear, 42335 viewNextYear, 42336 selected, 42337 setSelected, 42338 clearSelected, 42339 isSelected: isSelected2, 42340 select, 42341 deselect, 42342 toggle, 42343 selectRange, 42344 deselectRange, 42345 calendar 42346 }; 42347 }; 42348 42349 // packages/components/build-module/date-time/date/styles.js 42350 function _EMOTION_STRINGIFIED_CSS_ERROR__28() { 42351 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 42352 } 42353 var Wrapper3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42354 target: "e105ri6r7" 42355 } : { 42356 target: "e105ri6r7", 42357 label: "Wrapper" 42358 })(boxSizingReset, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjaUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBib3hTaXppbmdSZXNldCwgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBIU3RhY2sgfSBmcm9tICcuLi8uLi9oLXN0YWNrJztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi8uLi9oZWFkaW5nJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYXZpZ2F0b3IgPSBzdHlsZWQoIEhTdGFjayApYFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgVmlld1ByZXZpb3VzTW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogMSAvIDI7XG5gO1xuXG5leHBvcnQgY29uc3QgVmlld05leHRNb250aEJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdGdyaWQtY29sdW1uOiA3IC8gODtcbmA7XG5cbmV4cG9ydCBjb25zdCBOYXZpZ2F0b3JIZWFkaW5nID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGZvbnQtd2VpZ2h0OiAkeyBDT05GSUcuZm9udFdlaWdodCB9O1xuXHRncmlkLWNvbHVtbjogMiAvIDc7XG5cblx0c3Ryb25nIHtcblx0XHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRIZWFkaW5nIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDYWxlbmRhciA9IHN0eWxlZC5kaXZgXG5cdGNvbHVtbi1nYXA6ICR7IHNwYWNlKCAyICkgfTtcblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAwLjVmciByZXBlYXQoIDUsIDFmciApIDAuNWZyO1xuXHRqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG5cdHJvdy1nYXA6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEYXlPZldlZWsgPSBzdHlsZWQuZGl2YFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDcwMCBdIH07XG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGxpbmUtaGVpZ2h0OiAkeyBDT05GSUcuZm9udExpbmVIZWlnaHRCYXNlIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5QnV0dG9uID0gc3R5bGVkKCBCdXR0b24sIHtcblx0c2hvdWxkRm9yd2FyZFByb3A6ICggcHJvcDogc3RyaW5nICkgPT5cblx0XHQhIFsgJ2NvbHVtbicsICdpc1NlbGVjdGVkJywgJ2lzVG9kYXknLCAnaGFzRXZlbnRzJyBdLmluY2x1ZGVzKCBwcm9wICksXG59ICk8IHtcblx0Y29sdW1uOiBudW1iZXI7XG5cdGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG5cdGlzVG9kYXk6IGJvb2xlYW47XG5cdGhhc0V2ZW50czogYm9vbGVhbjtcbn0gPmBcblx0Z3JpZC1jb2x1bW46ICR7ICggcHJvcHMgKSA9PiBwcm9wcy5jb2x1bW4gfTtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5kaXNhYmxlZCAmJlxuXHRcdGBcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRgIH1cblxuXHQmJiYge1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNSb3VuZCB9O1xuXHRcdGhlaWdodDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdHdpZHRoOiAkeyBzcGFjZSggNyApIH07XG5cdFx0Zm9udC13ZWlnaHQ6IDQwMDtcblxuXHRcdCR7ICggcHJvcHMgKSA9PlxuXHRcdFx0cHJvcHMuaXNTZWxlY3RlZCAmJlxuXHRcdFx0YFxuXHRcdFx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cblx0XHRcdFx0Jixcblx0XHRcdFx0Jjpob3Zlcjpub3QoOmRpc2FibGVkLCBbYXJpYS1kaXNhYmxlZD10cnVlXSkge1xuXHRcdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblx0XHRcdFx0fVxuXG5cdFx0XHRcdCY6Zm9jdXM6bm90KDpkaXNhYmxlZCksXG5cdFx0XHRcdCY6Zm9jdXM6bm90KDpkaXNhYmxlZCkge1xuXHRcdFx0XHRcdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCBjdXJyZW50Q29sb3I7XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQvKiBIaWdobGlnaHQgdGhlIHNlbGVjdGVkIGRheSBmb3IgaGlnaC1jb250cmFzdCBtb2RlICovXG5cdFx0XHRcdCY6OmFmdGVyIHtcblx0XHRcdFx0XHRjb250ZW50OiAnJztcblx0XHRcdFx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0XHRcdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0XHRcdFx0aW5zZXQ6IDA7XG5cdFx0XHRcdFx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0XHRcdFx0XHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRcdFx0fVxuXHRcdFx0YCB9XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdCEgcHJvcHMuaXNTZWxlY3RlZCAmJlxuXHRcdFx0cHJvcHMuaXNUb2RheSAmJlxuXHRcdFx0YFxuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDIwMCBdIH07XG5cdFx0XHRgIH1cblx0fVxuXG5cdCR7ICggcHJvcHMgKSA9PlxuXHRcdHByb3BzLmhhc0V2ZW50cyAmJlxuXHRcdGBcblx0XHQ6OmJlZm9yZSB7XG5cdFx0XHRib3JkZXI6IDJweCBzb2xpZCAke1xuXHRcdFx0XHRwcm9wcy5pc1NlbGVjdGVkXG5cdFx0XHRcdFx0PyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWRcblx0XHRcdFx0XHQ6IENPTE9SUy50aGVtZS5hY2NlbnRcblx0XHRcdH07XG5cdFx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRcdGNvbnRlbnQ6IFwiIFwiO1xuXHRcdFx0bGVmdDogNTAlO1xuXHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0dHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgOXB4KTtcblx0XHR9XG5cdFx0YCB9XG5gO1xuIl19 */")); 42359 var Navigator = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default9, false ? { 42360 target: "e105ri6r6" 42361 } : { 42362 target: "e105ri6r6", 42363 label: "Navigator" 42364 })("column-gap:", space(2), ";display:grid;grid-template-columns:0.5fr repeat( 5, 1fr ) 0.5fr;justify-items:center;margin-bottom:", space(4), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQnlDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */")); 42365 var ViewPreviousMonthButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 42366 target: "e105ri6r5" 42367 } : { 42368 target: "e105ri6r5", 42369 label: "ViewPreviousMonthButton" 42370 })(false ? { 42371 name: "sarfoe", 42372 styles: "grid-column:1/2" 42373 } : { 42374 name: "sarfoe", 42375 styles: "grid-column:1/2", 42376 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQnVEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */", 42377 toString: _EMOTION_STRINGIFIED_CSS_ERROR__28 42378 }); 42379 var ViewNextMonthButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 42380 target: "e105ri6r4" 42381 } : { 42382 target: "e105ri6r4", 42383 label: "ViewNextMonthButton" 42384 })(false ? { 42385 name: "1v98r3z", 42386 styles: "grid-column:7/8" 42387 } : { 42388 name: "1v98r3z", 42389 styles: "grid-column:7/8", 42390 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Qm1EIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */", 42391 toString: _EMOTION_STRINGIFIED_CSS_ERROR__28 42392 }); 42393 var NavigatorHeading = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default19, false ? { 42394 target: "e105ri6r3" 42395 } : { 42396 target: "e105ri6r3", 42397 label: "NavigatorHeading" 42398 })("font-size:", config_values_default.fontSize, ";font-weight:", config_values_default.fontWeight, ";grid-column:2/7;strong{font-weight:", config_values_default.fontWeightHeading, ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ2lEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */")); 42399 var Calendar = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42400 target: "e105ri6r2" 42401 } : { 42402 target: "e105ri6r2", 42403 label: "Calendar" 42404 })("column-gap:", space(2), ";display:grid;grid-template-columns:0.5fr repeat( 5, 1fr ) 0.5fr;justify-items:center;row-gap:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q2tDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */")); 42405 var DayOfWeek = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42406 target: "e105ri6r1" 42407 } : { 42408 target: "e105ri6r1", 42409 label: "DayOfWeek" 42410 })("color:", COLORS.theme.gray[700], ";font-size:", config_values_default.fontSize, ";line-height:", config_values_default.fontLineHeightBase, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRG1DIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJ1dHRvbiBmcm9tICcuLi8uLi9idXR0b24nO1xuaW1wb3J0IHsgYm94U2l6aW5nUmVzZXQsIENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9yID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0Y29sdW1uLWdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXHRkaXNwbGF5OiBncmlkO1xuXHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDAuNWZyIHJlcGVhdCggNSwgMWZyICkgMC41ZnI7XG5cdGp1c3RpZnktaXRlbXM6IGNlbnRlcjtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdQcmV2aW91c01vbnRoQnV0dG9uID0gc3R5bGVkKCBCdXR0b24gKWBcblx0Z3JpZC1jb2x1bW46IDEgLyAyO1xuYDtcblxuZXhwb3J0IGNvbnN0IFZpZXdOZXh0TW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogNyAvIDg7XG5gO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdG9ySGVhZGluZyA9IHN0eWxlZCggSGVhZGluZyApYFxuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHQgfTtcblx0Z3JpZC1jb2x1bW46IDIgLyA3O1xuXG5cdHN0cm9uZyB7XG5cdFx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0SGVhZGluZyB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2FsZW5kYXIgPSBzdHlsZWQuZGl2YFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRyb3ctZ2FwOiAkeyBzcGFjZSggMiApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5T2ZXZWVrID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogJHsgQ09ORklHLmZvbnRMaW5lSGVpZ2h0QmFzZSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IERheUJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uLCB7XG5cdHNob3VsZEZvcndhcmRQcm9wOiAoIHByb3A6IHN0cmluZyApID0+XG5cdFx0ISBbICdjb2x1bW4nLCAnaXNTZWxlY3RlZCcsICdpc1RvZGF5JywgJ2hhc0V2ZW50cycgXS5pbmNsdWRlcyggcHJvcCApLFxufSApPCB7XG5cdGNvbHVtbjogbnVtYmVyO1xuXHRpc1NlbGVjdGVkOiBib29sZWFuO1xuXHRpc1RvZGF5OiBib29sZWFuO1xuXHRoYXNFdmVudHM6IGJvb2xlYW47XG59ID5gXG5cdGdyaWQtY29sdW1uOiAkeyAoIHByb3BzICkgPT4gcHJvcHMuY29sdW1uIH07XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cblx0JHsgKCBwcm9wcyApID0+XG5cdFx0cHJvcHMuZGlzYWJsZWQgJiZcblx0XHRgXG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0YCB9XG5cblx0JiYmIHtcblx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRoZWlnaHQ6ICR7IHNwYWNlKCA3ICkgfTtcblx0XHR3aWR0aDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdGZvbnQtd2VpZ2h0OiA0MDA7XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdGBcblx0XHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdFx0XHRcdCYsXG5cdFx0XHRcdCY6aG92ZXI6bm90KDpkaXNhYmxlZCwgW2FyaWEtZGlzYWJsZWQ9dHJ1ZV0pIHtcblx0XHRcdFx0XHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkIH07XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpLFxuXHRcdFx0XHQmOmZvY3VzOm5vdCg6ZGlzYWJsZWQpIHtcblx0XHRcdFx0XHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gc29saWQgY3VycmVudENvbG9yO1xuXHRcdFx0XHR9XG5cblx0XHRcdFx0LyogSGlnaGxpZ2h0IHRoZSBzZWxlY3RlZCBkYXkgZm9yIGhpZ2gtY29udHJhc3QgbW9kZSAqL1xuXHRcdFx0XHQmOjphZnRlciB7XG5cdFx0XHRcdFx0Y29udGVudDogJyc7XG5cdFx0XHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0XHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdFx0XHRcdGluc2V0OiAwO1xuXHRcdFx0XHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0XHRcdFx0Ym9yZGVyOiAxcHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdFx0XHRcdH1cblx0XHRcdGAgfVxuXG5cdFx0JHsgKCBwcm9wcyApID0+XG5cdFx0XHQhIHByb3BzLmlzU2VsZWN0ZWQgJiZcblx0XHRcdHByb3BzLmlzVG9kYXkgJiZcblx0XHRcdGBcblx0XHRcdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5ncmF5WyAyMDAgXSB9O1xuXHRcdFx0YCB9XG5cdH1cblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5oYXNFdmVudHMgJiZcblx0XHRgXG5cdFx0OjpiZWZvcmUge1xuXHRcdFx0Ym9yZGVyOiAycHggc29saWQgJHtcblx0XHRcdFx0cHJvcHMuaXNTZWxlY3RlZFxuXHRcdFx0XHRcdD8gQ09MT1JTLnRoZW1lLmFjY2VudEludmVydGVkXG5cdFx0XHRcdFx0OiBDT0xPUlMudGhlbWUuYWNjZW50XG5cdFx0XHR9O1xuXHRcdFx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1JvdW5kIH07XG5cdFx0XHRjb250ZW50OiBcIiBcIjtcblx0XHRcdGxlZnQ6IDUwJTtcblx0XHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRcdHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDlweCk7XG5cdFx0fVxuXHRcdGAgfVxuYDtcbiJdfQ== */")); 42411 var DayButton = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 42412 shouldForwardProp: (prop) => !["column", "isSelected", "isToday", "hasEvents"].includes(prop), 42413 target: "e105ri6r0" 42414 } : { 42415 shouldForwardProp: (prop) => !["column", "isSelected", "isToday", "hasEvents"].includes(prop), 42416 target: "e105ri6r0", 42417 label: "DayButton" 42418 })("grid-column:", (props) => props.column, ";position:relative;justify-content:center;", (props) => props.disabled && ` 42419 pointer-events: none; 42420 `, " &&&{border-radius:", config_values_default.radiusRound, ";height:", space(7), ";width:", space(7), ";font-weight:400;", (props) => props.isSelected && ` 42421 background: $COLORS.theme.accent}; 42422 42423 &, 42424 &:hover:not(:disabled, [aria-disabled=true]) { 42425 color: $COLORS.theme.accentInverted}; 42426 } 42427 42428 &:focus:not(:disabled), 42429 &:focus:not(:disabled) { 42430 border: $config_values_default.borderWidthFocus} solid currentColor; 42431 } 42432 42433 /* Highlight the selected day for high-contrast mode */ 42434 &::after { 42435 content: ''; 42436 position: absolute; 42437 pointer-events: none; 42438 inset: 0; 42439 border-radius: inherit; 42440 border: 1px solid transparent; 42441 } 42442 `, " ", (props) => !props.isSelected && props.isToday && ` 42443 background: $COLORS.theme.gray[200]}; 42444 `, ";}", (props) => props.hasEvents && ` 42445 ::before { 42446 border: 2px solid $props.isSelected ? COLORS.theme.accentInverted : COLORS.theme.accent}; 42447 border-radius: $config_values_default.radiusRound}; 42448 content: " "; 42449 left: 50%; 42450 position: absolute; 42451 transform: translate(-50%, 9px); 42452 } 42453 `, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRUciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBib3hTaXppbmdSZXNldCwgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBIU3RhY2sgfSBmcm9tICcuLi8uLi9oLXN0YWNrJztcbmltcG9ydCB7IEhlYWRpbmcgfSBmcm9tICcuLi8uLi9oZWFkaW5nJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdCR7IGJveFNpemluZ1Jlc2V0IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBOYXZpZ2F0b3IgPSBzdHlsZWQoIEhTdGFjayApYFxuXHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggMiApIH07XG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMC41ZnIgcmVwZWF0KCA1LCAxZnIgKSAwLjVmcjtcblx0anVzdGlmeS1pdGVtczogY2VudGVyO1xuXHRtYXJnaW4tYm90dG9tOiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgVmlld1ByZXZpb3VzTW9udGhCdXR0b24gPSBzdHlsZWQoIEJ1dHRvbiApYFxuXHRncmlkLWNvbHVtbjogMSAvIDI7XG5gO1xuXG5leHBvcnQgY29uc3QgVmlld05leHRNb250aEJ1dHRvbiA9IHN0eWxlZCggQnV0dG9uIClgXG5cdGdyaWQtY29sdW1uOiA3IC8gODtcbmA7XG5cbmV4cG9ydCBjb25zdCBOYXZpZ2F0b3JIZWFkaW5nID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGZvbnQtd2VpZ2h0OiAkeyBDT05GSUcuZm9udFdlaWdodCB9O1xuXHRncmlkLWNvbHVtbjogMiAvIDc7XG5cblx0c3Ryb25nIHtcblx0XHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRIZWFkaW5nIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDYWxlbmRhciA9IHN0eWxlZC5kaXZgXG5cdGNvbHVtbi1nYXA6ICR7IHNwYWNlKCAyICkgfTtcblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAwLjVmciByZXBlYXQoIDUsIDFmciApIDAuNWZyO1xuXHRqdXN0aWZ5LWl0ZW1zOiBjZW50ZXI7XG5cdHJvdy1nYXA6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEYXlPZldlZWsgPSBzdHlsZWQuZGl2YFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDcwMCBdIH07XG5cdGZvbnQtc2l6ZTogJHsgQ09ORklHLmZvbnRTaXplIH07XG5cdGxpbmUtaGVpZ2h0OiAkeyBDT05GSUcuZm9udExpbmVIZWlnaHRCYXNlIH07XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5QnV0dG9uID0gc3R5bGVkKCBCdXR0b24sIHtcblx0c2hvdWxkRm9yd2FyZFByb3A6ICggcHJvcDogc3RyaW5nICkgPT5cblx0XHQhIFsgJ2NvbHVtbicsICdpc1NlbGVjdGVkJywgJ2lzVG9kYXknLCAnaGFzRXZlbnRzJyBdLmluY2x1ZGVzKCBwcm9wICksXG59ICk8IHtcblx0Y29sdW1uOiBudW1iZXI7XG5cdGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG5cdGlzVG9kYXk6IGJvb2xlYW47XG5cdGhhc0V2ZW50czogYm9vbGVhbjtcbn0gPmBcblx0Z3JpZC1jb2x1bW46ICR7ICggcHJvcHMgKSA9PiBwcm9wcy5jb2x1bW4gfTtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblxuXHQkeyAoIHByb3BzICkgPT5cblx0XHRwcm9wcy5kaXNhYmxlZCAmJlxuXHRcdGBcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHRgIH1cblxuXHQmJiYge1xuXHRcdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNSb3VuZCB9O1xuXHRcdGhlaWdodDogJHsgc3BhY2UoIDcgKSB9O1xuXHRcdHdpZHRoOiAkeyBzcGFjZSggNyApIH07XG5cdFx0Zm9udC13ZWlnaHQ6IDQwMDtcblxuXHRcdCR7ICggcHJvcHMgKSA9PlxuXHRcdFx0cHJvcHMuaXNTZWxlY3RlZCAmJlxuXHRcdFx0YFxuXHRcdFx0XHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cblx0XHRcdFx0Jixcblx0XHRcdFx0Jjpob3Zlcjpub3QoOmRpc2FibGVkLCBbYXJpYS1kaXNhYmxlZD10cnVlXSkge1xuXHRcdFx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblx0XHRcdFx0fVxuXG5cdFx0XHRcdCY6Zm9jdXM6bm90KDpkaXNhYmxlZCksXG5cdFx0XHRcdCY6Zm9jdXM6bm90KDpkaXNhYmxlZCkge1xuXHRcdFx0XHRcdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSBzb2xpZCBjdXJyZW50Q29sb3I7XG5cdFx0XHRcdH1cblxuXHRcdFx0XHQvKiBIaWdobGlnaHQgdGhlIHNlbGVjdGVkIGRheSBmb3IgaGlnaC1jb250cmFzdCBtb2RlICovXG5cdFx0XHRcdCY6OmFmdGVyIHtcblx0XHRcdFx0XHRjb250ZW50OiAnJztcblx0XHRcdFx0XHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdFx0XHRcdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0XHRcdFx0aW5zZXQ6IDA7XG5cdFx0XHRcdFx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0XHRcdFx0XHRib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0XHRcdFx0fVxuXHRcdFx0YCB9XG5cblx0XHQkeyAoIHByb3BzICkgPT5cblx0XHRcdCEgcHJvcHMuaXNTZWxlY3RlZCAmJlxuXHRcdFx0cHJvcHMuaXNUb2RheSAmJlxuXHRcdFx0YFxuXHRcdFx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmdyYXlbIDIwMCBdIH07XG5cdFx0XHRgIH1cblx0fVxuXG5cdCR7ICggcHJvcHMgKSA9PlxuXHRcdHByb3BzLmhhc0V2ZW50cyAmJlxuXHRcdGBcblx0XHQ6OmJlZm9yZSB7XG5cdFx0XHRib3JkZXI6IDJweCBzb2xpZCAke1xuXHRcdFx0XHRwcm9wcy5pc1NlbGVjdGVkXG5cdFx0XHRcdFx0PyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWRcblx0XHRcdFx0XHQ6IENPTE9SUy50aGVtZS5hY2NlbnRcblx0XHRcdH07XG5cdFx0XHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0XHRcdGNvbnRlbnQ6IFwiIFwiO1xuXHRcdFx0bGVmdDogNTAlO1xuXHRcdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdFx0dHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgOXB4KTtcblx0XHR9XG5cdFx0YCB9XG5gO1xuIl19 */")); 42454 42455 // node_modules/@date-fns/utc/date/mini.js 42456 var UTCDateMini = class extends Date { 42457 constructor() { 42458 super(); 42459 this.setTime(arguments.length === 0 ? ( 42460 // Enables Sinon's fake timers that override the constructor 42461 Date.now() 42462 ) : arguments.length === 1 ? typeof arguments[0] === "string" ? +new Date(arguments[0]) : arguments[0] : Date.UTC(...arguments)); 42463 } 42464 getTimezoneOffset() { 42465 return 0; 42466 } 42467 }; 42468 var re = /^(get|set)(?!UTC)/; 42469 Object.getOwnPropertyNames(Date.prototype).forEach((method) => { 42470 if (re.test(method)) { 42471 const utcMethod = Date.prototype[method.replace(re, "$1UTC")]; 42472 if (utcMethod) UTCDateMini.prototype[method] = utcMethod; 42473 } 42474 }); 42475 42476 // node_modules/@date-fns/utc/date/index.js 42477 var weekdayFormat = new Intl.DateTimeFormat("en-US", { 42478 weekday: "short", 42479 timeZone: "UTC" 42480 }); 42481 var dateFormat = new Intl.DateTimeFormat("en-US", { 42482 month: "short", 42483 day: "numeric", 42484 timeZone: "UTC" 42485 }); 42486 var timeFormat = new Intl.DateTimeFormat("en-GB", { 42487 hour12: false, 42488 hour: "numeric", 42489 minute: "numeric", 42490 second: "numeric", 42491 timeZone: "UTC" 42492 }); 42493 42494 // packages/components/build-module/date-time/utils.js 42495 function inputToDate(input) { 42496 if (typeof input === "string") { 42497 const hasTimezone = /Z|[+-]\d{2}(:?\d{2})?$/.test(input); 42498 return hasTimezone ? new Date(input) : new UTCDateMini(input + "Z"); 42499 } 42500 return toDate(input); 42501 } 42502 function from12hTo24h(hours, isPm) { 42503 return isPm ? (hours % 12 + 12) % 24 : hours % 12; 42504 } 42505 function from24hTo12h(hours) { 42506 return hours % 12 || 12; 42507 } 42508 function buildPadInputStateReducer(pad) { 42509 return (state, action) => { 42510 const nextState = { 42511 ...state 42512 }; 42513 if (action.type === COMMIT || action.type === PRESS_UP || action.type === PRESS_DOWN) { 42514 if (nextState.value !== void 0) { 42515 nextState.value = nextState.value.toString().padStart(pad, "0"); 42516 } 42517 } 42518 return nextState; 42519 }; 42520 } 42521 function validateInputElementTarget(event) { 42522 var _ownerDocument$defaul; 42523 const HTMLInputElementInstance = (_ownerDocument$defaul = event.target?.ownerDocument.defaultView?.HTMLInputElement) !== null && _ownerDocument$defaul !== void 0 ? _ownerDocument$defaul : HTMLInputElement; 42524 if (!(event.target instanceof HTMLInputElementInstance)) { 42525 return false; 42526 } 42527 return event.target.validity.valid; 42528 } 42529 42530 // packages/components/build-module/date-time/constants.js 42531 var TIMEZONELESS_FORMAT = "yyyy-MM-dd'T'HH:mm:ss"; 42532 42533 // packages/components/build-module/date-time/date/index.js 42534 var import_jsx_runtime194 = __toESM(require_jsx_runtime()); 42535 function DatePicker({ 42536 currentDate, 42537 onChange, 42538 events = [], 42539 isInvalidDate, 42540 onMonthPreviewed, 42541 startOfWeek: weekStartsOn = 0 42542 }) { 42543 const date = currentDate ? inputToDate(currentDate) : /* @__PURE__ */ new Date(); 42544 const { 42545 calendar, 42546 viewing, 42547 setSelected, 42548 setViewing, 42549 isSelected: isSelected2, 42550 viewPreviousMonth, 42551 viewNextMonth 42552 } = useLilius({ 42553 selected: [startOfDay(date)], 42554 viewing: startOfDay(date), 42555 weekStartsOn 42556 }); 42557 const [focusable, setFocusable] = (0, import_element128.useState)(startOfDay(date)); 42558 const [isFocusWithinCalendar, setIsFocusWithinCalendar] = (0, import_element128.useState)(false); 42559 const [prevCurrentDate, setPrevCurrentDate] = (0, import_element128.useState)(currentDate); 42560 if (currentDate !== prevCurrentDate) { 42561 setPrevCurrentDate(currentDate); 42562 setSelected([startOfDay(date)]); 42563 setViewing(startOfDay(date)); 42564 setFocusable(startOfDay(date)); 42565 } 42566 return /* @__PURE__ */ (0, import_jsx_runtime194.jsxs)(Wrapper3, { 42567 className: "components-datetime__date", 42568 role: "application", 42569 "aria-label": (0, import_i18n42.__)("Calendar"), 42570 children: [/* @__PURE__ */ (0, import_jsx_runtime194.jsxs)(Navigator, { 42571 children: [/* @__PURE__ */ (0, import_jsx_runtime194.jsx)(ViewPreviousMonthButton, { 42572 icon: (0, import_i18n42.isRTL)() ? arrow_right_default : arrow_left_default, 42573 variant: "tertiary", 42574 "aria-label": (0, import_i18n42.__)("View previous month"), 42575 onClick: () => { 42576 viewPreviousMonth(); 42577 setFocusable(subMonths(focusable, 1)); 42578 onMonthPreviewed?.(format(subMonths(viewing, 1), TIMEZONELESS_FORMAT)); 42579 }, 42580 size: "compact" 42581 }), /* @__PURE__ */ (0, import_jsx_runtime194.jsxs)(NavigatorHeading, { 42582 level: 3, 42583 children: [/* @__PURE__ */ (0, import_jsx_runtime194.jsx)("strong", { 42584 children: (0, import_date2.gmdateI18n)("F", viewing) 42585 }), " ", (0, import_date2.gmdateI18n)("Y", viewing)] 42586 }), /* @__PURE__ */ (0, import_jsx_runtime194.jsx)(ViewNextMonthButton, { 42587 icon: (0, import_i18n42.isRTL)() ? arrow_left_default : arrow_right_default, 42588 variant: "tertiary", 42589 "aria-label": (0, import_i18n42.__)("View next month"), 42590 onClick: () => { 42591 viewNextMonth(); 42592 setFocusable(addMonths(focusable, 1)); 42593 onMonthPreviewed?.(format(addMonths(viewing, 1), TIMEZONELESS_FORMAT)); 42594 }, 42595 size: "compact" 42596 })] 42597 }), /* @__PURE__ */ (0, import_jsx_runtime194.jsxs)(Calendar, { 42598 onFocus: () => setIsFocusWithinCalendar(true), 42599 onBlur: () => setIsFocusWithinCalendar(false), 42600 children: [calendar[0][0].map((day) => /* @__PURE__ */ (0, import_jsx_runtime194.jsx)(DayOfWeek, { 42601 children: (0, import_date2.gmdateI18n)("D", day) 42602 }, day.toString())), calendar[0].map((week) => week.map((day, index2) => { 42603 if (!isSameMonth(day, viewing)) { 42604 return null; 42605 } 42606 return /* @__PURE__ */ (0, import_jsx_runtime194.jsx)(Day2, { 42607 day, 42608 column: index2 + 1, 42609 isSelected: isSelected2(day), 42610 isFocusable: isEqual(day, focusable), 42611 isFocusAllowed: isFocusWithinCalendar, 42612 isToday: isSameDay(day, /* @__PURE__ */ new Date()), 42613 isInvalid: isInvalidDate ? isInvalidDate(day) : false, 42614 numEvents: events.filter((event) => isSameDay(event.date, day)).length, 42615 onClick: () => { 42616 setSelected([day]); 42617 setFocusable(day); 42618 onChange?.(format( 42619 // Don't change the selected date's time fields. 42620 new Date(day.getFullYear(), day.getMonth(), day.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()), 42621 TIMEZONELESS_FORMAT 42622 )); 42623 }, 42624 onKeyDown: (event) => { 42625 let nextFocusable; 42626 if (event.key === "ArrowLeft") { 42627 nextFocusable = addDays(day, (0, import_i18n42.isRTL)() ? 1 : -1); 42628 } 42629 if (event.key === "ArrowRight") { 42630 nextFocusable = addDays(day, (0, import_i18n42.isRTL)() ? -1 : 1); 42631 } 42632 if (event.key === "ArrowUp") { 42633 nextFocusable = subWeeks(day, 1); 42634 } 42635 if (event.key === "ArrowDown") { 42636 nextFocusable = addWeeks(day, 1); 42637 } 42638 if (event.key === "PageUp") { 42639 nextFocusable = subMonths(day, 1); 42640 } 42641 if (event.key === "PageDown") { 42642 nextFocusable = addMonths(day, 1); 42643 } 42644 if (event.key === "Home") { 42645 nextFocusable = startOfWeek(day); 42646 } 42647 if (event.key === "End") { 42648 nextFocusable = startOfDay(endOfWeek(day)); 42649 } 42650 if (nextFocusable) { 42651 event.preventDefault(); 42652 setFocusable(nextFocusable); 42653 if (!isSameMonth(nextFocusable, viewing)) { 42654 setViewing(nextFocusable); 42655 onMonthPreviewed?.(format(nextFocusable, TIMEZONELESS_FORMAT)); 42656 } 42657 } 42658 } 42659 }, day.toString()); 42660 }))] 42661 })] 42662 }); 42663 } 42664 function Day2({ 42665 day, 42666 column: column2, 42667 isSelected: isSelected2, 42668 isFocusable: isFocusable2, 42669 isFocusAllowed, 42670 isToday, 42671 isInvalid, 42672 numEvents, 42673 onClick, 42674 onKeyDown 42675 }) { 42676 const ref = (0, import_element128.useRef)(); 42677 (0, import_element128.useEffect)(() => { 42678 if (ref.current && isFocusable2 && isFocusAllowed) { 42679 ref.current.focus(); 42680 } 42681 }, [isFocusable2]); 42682 return /* @__PURE__ */ (0, import_jsx_runtime194.jsx)(DayButton, { 42683 __next40pxDefaultSize: true, 42684 ref, 42685 className: "components-datetime__date__day", 42686 disabled: isInvalid, 42687 tabIndex: isFocusable2 ? 0 : -1, 42688 "aria-label": getDayLabel(day, isSelected2, numEvents), 42689 column: column2, 42690 isSelected: isSelected2, 42691 isToday, 42692 hasEvents: numEvents > 0, 42693 onClick, 42694 onKeyDown, 42695 children: (0, import_date2.gmdateI18n)("j", day) 42696 }); 42697 } 42698 function getDayLabel(date, isSelected2, numEvents) { 42699 const { 42700 formats 42701 } = (0, import_date2.getSettings)(); 42702 const localizedDate = (0, import_date2.gmdateI18n)(formats.date, date); 42703 if (isSelected2 && numEvents > 0) { 42704 return (0, import_i18n42.sprintf)( 42705 // translators: 1: The calendar date. 2: Number of events on the calendar date. 42706 (0, import_i18n42._n)("%1$s. Selected. There is %2$d event", "%1$s. Selected. There are %2$d events", numEvents), 42707 localizedDate, 42708 numEvents 42709 ); 42710 } else if (isSelected2) { 42711 return (0, import_i18n42.sprintf)( 42712 // translators: 1: The calendar date. 42713 (0, import_i18n42.__)("%1$s. Selected"), 42714 localizedDate 42715 ); 42716 } else if (numEvents > 0) { 42717 return (0, import_i18n42.sprintf)( 42718 // translators: 1: The calendar date. 2: Number of events on the calendar date. 42719 (0, import_i18n42._n)("%1$s. There is %2$d event", "%1$s. There are %2$d events", numEvents), 42720 localizedDate, 42721 numEvents 42722 ); 42723 } 42724 return localizedDate; 42725 } 42726 var date_default = DatePicker; 42727 42728 // packages/components/build-module/date-time/time/index.js 42729 var import_element130 = __toESM(require_element()); 42730 var import_i18n45 = __toESM(require_i18n()); 42731 42732 // packages/components/build-module/date-time/time/timezone.js 42733 var import_i18n43 = __toESM(require_i18n()); 42734 var import_date3 = __toESM(require_date()); 42735 42736 // packages/components/build-module/date-time/time/styles.js 42737 function _EMOTION_STRINGIFIED_CSS_ERROR__29() { 42738 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 42739 } 42740 var Wrapper4 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42741 target: "evcr2319" 42742 } : { 42743 target: "evcr2319", 42744 label: "Wrapper" 42745 })("box-sizing:border-box;font-size:", config_values_default.fontSize, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQmlDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42746 var Fieldset = /* @__PURE__ */ emotion_styled_base_browser_esm_default("fieldset", false ? { 42747 target: "evcr2318" 42748 } : { 42749 target: "evcr2318", 42750 label: "Fieldset" 42751 })("border:0;margin:0 0 ", space(2 * 2), " 0;padding:0;&:last-child{margin-bottom:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQnVDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42752 var TimeWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42753 target: "evcr2317" 42754 } : { 42755 target: "evcr2317", 42756 label: "TimeWrapper" 42757 })(false ? { 42758 name: "pd0mhc", 42759 styles: "direction:ltr;display:flex" 42760 } : { 42761 name: "pd0mhc", 42762 styles: "direction:ltr;display:flex", 42763 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ3FDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */", 42764 toString: _EMOTION_STRINGIFIED_CSS_ERROR__29 42765 }); 42766 var baseInput = /* @__PURE__ */ css("&&& ", Input, "{padding-left:", space(2), ";padding-right:", space(2), ";text-align:center;}" + (false ? "" : ";label:baseInput;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ3FCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */"); 42767 var HoursInput = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 42768 target: "evcr2316" 42769 } : { 42770 target: "evcr2316", 42771 label: "HoursInput" 42772 })(baseInput, " width:", space(9), ";&&& ", Input, "{padding-right:0;}&&& ", BackdropUI, "{border-right:0;border-top-right-radius:0;border-bottom-right-radius:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q2lEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42773 var TimeSeparator = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 42774 target: "evcr2315" 42775 } : { 42776 target: "evcr2315", 42777 label: "TimeSeparator" 42778 })("border-top:", config_values_default.borderWidth, " solid ", COLORS.gray[700], ";border-bottom:", config_values_default.borderWidth, " solid ", COLORS.gray[700], ";font-size:", config_values_default.fontSize, ";line-height:calc(\n ", config_values_default.controlHeight, " - ", config_values_default.borderWidth, " * 2\n );display:inline-block;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RHdDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42779 var MinutesInput = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 42780 target: "evcr2314" 42781 } : { 42782 target: "evcr2314", 42783 label: "MinutesInput" 42784 })(baseInput, " width:", space(9), ";&&& ", Input, "{padding-left:0;}&&& ", BackdropUI, "{border-left:0;border-top-left-radius:0;border-bottom-left-radius:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RW1EIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42785 var MonthSelectWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42786 target: "evcr2313" 42787 } : { 42788 target: "evcr2313", 42789 label: "MonthSelectWrapper" 42790 })(false ? { 42791 name: "1ff36h2", 42792 styles: "flex-grow:1" 42793 } : { 42794 name: "1ff36h2", 42795 styles: "flex-grow:1", 42796 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5RjRDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */", 42797 toString: _EMOTION_STRINGIFIED_CSS_ERROR__29 42798 }); 42799 var DayInput = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 42800 target: "evcr2312" 42801 } : { 42802 target: "evcr2312", 42803 label: "DayInput" 42804 })(baseInput, " width:", space(9), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RitDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42805 var YearInput = /* @__PURE__ */ emotion_styled_base_browser_esm_default(number_control_default, false ? { 42806 target: "evcr2311" 42807 } : { 42808 target: "evcr2311", 42809 label: "YearInput" 42810 })(baseInput, " width:", space(14), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtR2dEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */")); 42811 var TimeZone = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 42812 target: "evcr2310" 42813 } : { 42814 target: "evcr2310", 42815 label: "TimeZone" 42816 })(false ? { 42817 name: "ebu3jh", 42818 styles: "text-decoration:underline dotted" 42819 } : { 42820 name: "ebu3jh", 42821 styles: "text-decoration:underline dotted", 42822 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5R2tDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uLy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7XG5cdElucHV0LFxuXHRCYWNrZHJvcFVJLFxufSBmcm9tICcuLi8uLi9pbnB1dC1jb250cm9sL3N0eWxlcy9pbnB1dC1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgTnVtYmVyQ29udHJvbCBmcm9tICcuLi8uLi9udW1iZXItY29udHJvbCc7XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0Zm9udC1zaXplOiAkeyBDT05GSUcuZm9udFNpemUgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBGaWVsZHNldCA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDAgMCAkeyBzcGFjZSggMiAqIDIgKSB9IDA7XG5cdHBhZGRpbmc6IDA7XG5cblx0JjpsYXN0LWNoaWxkIHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVGltZVdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRkaXJlY3Rpb246IGx0cjtcblx0ZGlzcGxheTogZmxleDtcbmA7XG5cbmNvbnN0IGJhc2VJbnB1dCA9IGNzc2Bcblx0JiYmICR7IElucHV0IH0ge1xuXHRcdHBhZGRpbmctbGVmdDogJHsgc3BhY2UoIDIgKSB9O1xuXHRcdHBhZGRpbmctcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcblx0XHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBIb3Vyc0lucHV0ID0gc3R5bGVkKCBOdW1iZXJDb250cm9sIClgXG5cdCR7IGJhc2VJbnB1dCB9XG5cblx0d2lkdGg6ICR7IHNwYWNlKCA5ICkgfTtcblxuXHQmJiYgJHsgSW5wdXQgfSB7XG5cdFx0cGFkZGluZy1yaWdodDogMDtcblx0fVxuXG5cdCYmJiAkeyBCYWNrZHJvcFVJIH0ge1xuXHRcdGJvcmRlci1yaWdodDogMDtcblx0XHRib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcblx0XHRib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVTZXBhcmF0b3IgPSBzdHlsZWQuc3BhbmBcblx0Ym9yZGVyLXRvcDogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdGJvcmRlci1ib3R0b206ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRmb250LXNpemU6ICR7IENPTkZJRy5mb250U2l6ZSB9O1xuXHRsaW5lLWhlaWdodDogY2FsYyhcblx0XHQkeyBDT05GSUcuY29udHJvbEhlaWdodCB9IC0gJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gKiAyXG5cdCk7XG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmA7XG5cbmV4cG9ydCBjb25zdCBNaW51dGVzSW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuXG5cdCYmJiAkeyBJbnB1dCB9IHtcblx0XHRwYWRkaW5nLWxlZnQ6IDA7XG5cdH1cblxuXHQmJiYgJHsgQmFja2Ryb3BVSSB9IHtcblx0XHRib3JkZXItbGVmdDogMDtcblx0XHRib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuXHRcdGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG5cdH1cbmA7XG5cbi8vIElkZWFsbHkgd2Ugd291bGRuJ3QgbmVlZCBhIHdyYXBwZXIsIGJ1dCBjYW4ndCBvdGhlcndpc2UgdGFyZ2V0IHRoZVxuLy8gPEJhc2VDb250cm9sPiBpbiA8U2VsZWN0Q29udHJvbD5cbmV4cG9ydCBjb25zdCBNb250aFNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRmbGV4LWdyb3c6IDE7XG5gO1xuXG5leHBvcnQgY29uc3QgRGF5SW5wdXQgPSBzdHlsZWQoIE51bWJlckNvbnRyb2wgKWBcblx0JHsgYmFzZUlucHV0IH1cblxuXHR3aWR0aDogJHsgc3BhY2UoIDkgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFllYXJJbnB1dCA9IHN0eWxlZCggTnVtYmVyQ29udHJvbCApYFxuXHQkeyBiYXNlSW5wdXQgfVxuXG5cdHdpZHRoOiAkeyBzcGFjZSggMTQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFRpbWVab25lID0gc3R5bGVkLmRpdmBcblx0dGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmUgZG90dGVkO1xuYDtcbiJdfQ== */", 42823 toString: _EMOTION_STRINGIFIED_CSS_ERROR__29 42824 }); 42825 42826 // packages/components/build-module/date-time/time/timezone.js 42827 var import_jsx_runtime195 = __toESM(require_jsx_runtime()); 42828 var TimeZone2 = () => { 42829 const { 42830 timezone 42831 } = (0, import_date3.getSettings)(); 42832 const userTimezoneOffset = -1 * ((/* @__PURE__ */ new Date()).getTimezoneOffset() / 60); 42833 if (Number(timezone.offset) === userTimezoneOffset) { 42834 return null; 42835 } 42836 const offsetSymbol = Number(timezone.offset) >= 0 ? "+" : ""; 42837 const zoneAbbr = "" !== timezone.abbr && isNaN(Number(timezone.abbr)) ? timezone.abbr : `UTC$offsetSymbol}$timezone.offsetFormatted}`; 42838 const prettyTimezoneString = timezone.string.replace("_", " "); 42839 const timezoneDetail = "UTC" === timezone.string ? (0, import_i18n43.__)("Coordinated Universal Time") : `($zoneAbbr}) $prettyTimezoneString}`; 42840 const hasNoAdditionalTimezoneDetail = prettyTimezoneString.trim().length === 0; 42841 return hasNoAdditionalTimezoneDetail ? /* @__PURE__ */ (0, import_jsx_runtime195.jsx)(TimeZone, { 42842 className: "components-datetime__timezone", 42843 children: zoneAbbr 42844 }) : /* @__PURE__ */ (0, import_jsx_runtime195.jsx)(tooltip_default, { 42845 placement: "top", 42846 text: timezoneDetail, 42847 children: /* @__PURE__ */ (0, import_jsx_runtime195.jsx)(TimeZone, { 42848 className: "components-datetime__timezone", 42849 children: zoneAbbr 42850 }) 42851 }); 42852 }; 42853 var timezone_default = TimeZone2; 42854 42855 // packages/components/build-module/date-time/time/time-input/index.js 42856 var import_i18n44 = __toESM(require_i18n()); 42857 var import_element129 = __toESM(require_element()); 42858 var import_jsx_runtime196 = __toESM(require_jsx_runtime()); 42859 function TimeInput({ 42860 value: valueProp, 42861 defaultValue: defaultValue2, 42862 is12Hour, 42863 label, 42864 minutesProps, 42865 onChange 42866 }) { 42867 const [value = { 42868 hours: (/* @__PURE__ */ new Date()).getHours(), 42869 minutes: (/* @__PURE__ */ new Date()).getMinutes() 42870 }, setValue] = useControlledValue({ 42871 value: valueProp, 42872 onChange, 42873 defaultValue: defaultValue2 42874 }); 42875 const dayPeriod = parseDayPeriod(value.hours); 42876 const hours12Format = from24hTo12h(value.hours); 42877 const buildNumberControlChangeCallback = (method) => { 42878 return (_value, { 42879 event 42880 }) => { 42881 if (!validateInputElementTarget(event)) { 42882 return; 42883 } 42884 const numberValue = Number(_value); 42885 setValue({ 42886 ...value, 42887 [method]: method === "hours" && is12Hour ? from12hTo24h(numberValue, dayPeriod === "PM") : numberValue 42888 }); 42889 }; 42890 }; 42891 const buildAmPmChangeCallback = (_value) => { 42892 return () => { 42893 if (dayPeriod === _value) { 42894 return; 42895 } 42896 setValue({ 42897 ...value, 42898 hours: from12hTo24h(hours12Format, _value === "PM") 42899 }); 42900 }; 42901 }; 42902 function parseDayPeriod(_hours) { 42903 return _hours < 12 ? "AM" : "PM"; 42904 } 42905 const Wrapper7 = label ? Fieldset : import_element129.Fragment; 42906 return /* @__PURE__ */ (0, import_jsx_runtime196.jsxs)(Wrapper7, { 42907 children: [label && /* @__PURE__ */ (0, import_jsx_runtime196.jsx)(base_control_default.VisualLabel, { 42908 as: "legend", 42909 children: label 42910 }), /* @__PURE__ */ (0, import_jsx_runtime196.jsxs)(component_default9, { 42911 alignment: "left", 42912 expanded: false, 42913 children: [/* @__PURE__ */ (0, import_jsx_runtime196.jsxs)(TimeWrapper, { 42914 className: "components-datetime__time-field components-datetime__time-field-time", 42915 children: [/* @__PURE__ */ (0, import_jsx_runtime196.jsx)(HoursInput, { 42916 className: "components-datetime__time-field-hours-input", 42917 label: (0, import_i18n44.__)("Hours"), 42918 hideLabelFromVision: true, 42919 __next40pxDefaultSize: true, 42920 value: String(is12Hour ? hours12Format : value.hours).padStart(2, "0"), 42921 step: 1, 42922 min: is12Hour ? 1 : 0, 42923 max: is12Hour ? 12 : 23, 42924 required: true, 42925 spinControls: "none", 42926 isPressEnterToChange: true, 42927 isDragEnabled: false, 42928 isShiftStepEnabled: false, 42929 onChange: buildNumberControlChangeCallback("hours"), 42930 __unstableStateReducer: buildPadInputStateReducer(2) 42931 }), /* @__PURE__ */ (0, import_jsx_runtime196.jsx)(TimeSeparator, { 42932 className: "components-datetime__time-separator", 42933 "aria-hidden": "true", 42934 children: ":" 42935 }), /* @__PURE__ */ (0, import_jsx_runtime196.jsx)(MinutesInput, { 42936 className: clsx_default( 42937 "components-datetime__time-field-minutes-input", 42938 // Unused, for backwards compatibility. 42939 minutesProps?.className 42940 ), 42941 label: (0, import_i18n44.__)("Minutes"), 42942 hideLabelFromVision: true, 42943 __next40pxDefaultSize: true, 42944 value: String(value.minutes).padStart(2, "0"), 42945 step: 1, 42946 min: 0, 42947 max: 59, 42948 required: true, 42949 spinControls: "none", 42950 isPressEnterToChange: true, 42951 isDragEnabled: false, 42952 isShiftStepEnabled: false, 42953 onChange: (...args) => { 42954 buildNumberControlChangeCallback("minutes")(...args); 42955 minutesProps?.onChange?.(...args); 42956 }, 42957 __unstableStateReducer: buildPadInputStateReducer(2), 42958 ...minutesProps 42959 })] 42960 }), is12Hour && /* @__PURE__ */ (0, import_jsx_runtime196.jsxs)(component_default12, { 42961 __next40pxDefaultSize: true, 42962 isBlock: true, 42963 label: (0, import_i18n44.__)("Select AM or PM"), 42964 hideLabelFromVision: true, 42965 value: dayPeriod, 42966 onChange: (newValue) => { 42967 buildAmPmChangeCallback(newValue)(); 42968 }, 42969 children: [/* @__PURE__ */ (0, import_jsx_runtime196.jsx)(component_default14, { 42970 value: "AM", 42971 label: (0, import_i18n44.__)("AM") 42972 }), /* @__PURE__ */ (0, import_jsx_runtime196.jsx)(component_default14, { 42973 value: "PM", 42974 label: (0, import_i18n44.__)("PM") 42975 })] 42976 })] 42977 })] 42978 }); 42979 } 42980 42981 // packages/components/build-module/date-time/time/index.js 42982 var import_jsx_runtime197 = __toESM(require_jsx_runtime()); 42983 var VALID_DATE_ORDERS = ["dmy", "mdy", "ymd"]; 42984 function TimePicker({ 42985 is12Hour, 42986 currentTime, 42987 onChange, 42988 dateOrder: dateOrderProp, 42989 hideLabelFromVision = false 42990 }) { 42991 const [date, setDate] = (0, import_element130.useState)(() => ( 42992 // Truncate the date at the minutes, see: #15495. 42993 currentTime ? startOfMinute(inputToDate(currentTime)) : /* @__PURE__ */ new Date() 42994 )); 42995 (0, import_element130.useEffect)(() => { 42996 setDate(currentTime ? startOfMinute(inputToDate(currentTime)) : /* @__PURE__ */ new Date()); 42997 }, [currentTime]); 42998 const monthOptions = [{ 42999 value: "01", 43000 label: (0, import_i18n45.__)("January") 43001 }, { 43002 value: "02", 43003 label: (0, import_i18n45.__)("February") 43004 }, { 43005 value: "03", 43006 label: (0, import_i18n45.__)("March") 43007 }, { 43008 value: "04", 43009 label: (0, import_i18n45.__)("April") 43010 }, { 43011 value: "05", 43012 label: (0, import_i18n45.__)("May") 43013 }, { 43014 value: "06", 43015 label: (0, import_i18n45.__)("June") 43016 }, { 43017 value: "07", 43018 label: (0, import_i18n45.__)("July") 43019 }, { 43020 value: "08", 43021 label: (0, import_i18n45.__)("August") 43022 }, { 43023 value: "09", 43024 label: (0, import_i18n45.__)("September") 43025 }, { 43026 value: "10", 43027 label: (0, import_i18n45.__)("October") 43028 }, { 43029 value: "11", 43030 label: (0, import_i18n45.__)("November") 43031 }, { 43032 value: "12", 43033 label: (0, import_i18n45.__)("December") 43034 }]; 43035 const { 43036 day, 43037 month, 43038 year, 43039 minutes, 43040 hours 43041 } = (0, import_element130.useMemo)(() => ({ 43042 day: format(date, "dd"), 43043 month: format(date, "MM"), 43044 year: format(date, "yyyy"), 43045 minutes: format(date, "mm"), 43046 hours: format(date, "HH"), 43047 am: format(date, "a") 43048 }), [date]); 43049 const buildNumberControlChangeCallback = (method) => { 43050 const callback = (value, { 43051 event 43052 }) => { 43053 if (!validateInputElementTarget(event)) { 43054 return; 43055 } 43056 const numberValue = Number(value); 43057 const newDate = set(date, { 43058 [method]: numberValue 43059 }); 43060 setDate(newDate); 43061 onChange?.(format(newDate, TIMEZONELESS_FORMAT)); 43062 }; 43063 return callback; 43064 }; 43065 const onTimeInputChangeCallback = ({ 43066 hours: newHours, 43067 minutes: newMinutes 43068 }) => { 43069 const newDate = set(date, { 43070 hours: newHours, 43071 minutes: newMinutes 43072 }); 43073 setDate(newDate); 43074 onChange?.(format(newDate, TIMEZONELESS_FORMAT)); 43075 }; 43076 const dayField = /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(DayInput, { 43077 className: "components-datetime__time-field components-datetime__time-field-day", 43078 label: (0, import_i18n45.__)("Day"), 43079 hideLabelFromVision: true, 43080 __next40pxDefaultSize: true, 43081 value: day, 43082 step: 1, 43083 min: 1, 43084 max: 31, 43085 required: true, 43086 spinControls: "none", 43087 isPressEnterToChange: true, 43088 isDragEnabled: false, 43089 isShiftStepEnabled: false, 43090 onChange: buildNumberControlChangeCallback("date") 43091 }, "day"); 43092 const monthField = /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(MonthSelectWrapper, { 43093 children: /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(select_control_default, { 43094 className: "components-datetime__time-field components-datetime__time-field-month", 43095 label: (0, import_i18n45.__)("Month"), 43096 hideLabelFromVision: true, 43097 __next40pxDefaultSize: true, 43098 value: month, 43099 options: monthOptions, 43100 onChange: (value) => { 43101 const newDate = setMonth(date, Number(value) - 1); 43102 setDate(newDate); 43103 onChange?.(format(newDate, TIMEZONELESS_FORMAT)); 43104 } 43105 }) 43106 }, "month"); 43107 const yearField = /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(YearInput, { 43108 className: "components-datetime__time-field components-datetime__time-field-year", 43109 label: (0, import_i18n45.__)("Year"), 43110 hideLabelFromVision: true, 43111 __next40pxDefaultSize: true, 43112 value: year, 43113 step: 1, 43114 min: 1, 43115 max: 9999, 43116 required: true, 43117 spinControls: "none", 43118 isPressEnterToChange: true, 43119 isDragEnabled: false, 43120 isShiftStepEnabled: false, 43121 onChange: buildNumberControlChangeCallback("year"), 43122 __unstableStateReducer: buildPadInputStateReducer(4) 43123 }, "year"); 43124 const defaultDateOrder = is12Hour ? "mdy" : "dmy"; 43125 const dateOrder = dateOrderProp && VALID_DATE_ORDERS.includes(dateOrderProp) ? dateOrderProp : defaultDateOrder; 43126 const fields = dateOrder.split("").map((field) => { 43127 switch (field) { 43128 case "d": 43129 return dayField; 43130 case "m": 43131 return monthField; 43132 case "y": 43133 return yearField; 43134 default: 43135 return null; 43136 } 43137 }); 43138 return /* @__PURE__ */ (0, import_jsx_runtime197.jsxs)(Wrapper4, { 43139 className: "components-datetime__time", 43140 children: [/* @__PURE__ */ (0, import_jsx_runtime197.jsxs)(Fieldset, { 43141 children: [hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(component_default2, { 43142 as: "legend", 43143 children: (0, import_i18n45.__)("Time") 43144 }) : /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(base_control_default.VisualLabel, { 43145 as: "legend", 43146 className: "components-datetime__time-legend", 43147 children: (0, import_i18n45.__)("Time") 43148 }), /* @__PURE__ */ (0, import_jsx_runtime197.jsxs)(component_default9, { 43149 className: "components-datetime__time-wrapper", 43150 children: [/* @__PURE__ */ (0, import_jsx_runtime197.jsx)(TimeInput, { 43151 value: { 43152 hours: Number(hours), 43153 minutes: Number(minutes) 43154 }, 43155 is12Hour, 43156 onChange: onTimeInputChangeCallback 43157 }), /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(component_default6, {}), /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(timezone_default, {})] 43158 })] 43159 }), /* @__PURE__ */ (0, import_jsx_runtime197.jsxs)(Fieldset, { 43160 children: [hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(component_default2, { 43161 as: "legend", 43162 children: (0, import_i18n45.__)("Date") 43163 }) : /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(base_control_default.VisualLabel, { 43164 as: "legend", 43165 className: "components-datetime__time-legend", 43166 children: (0, import_i18n45.__)("Date") 43167 }), /* @__PURE__ */ (0, import_jsx_runtime197.jsx)(component_default9, { 43168 className: "components-datetime__time-wrapper", 43169 children: fields 43170 })] 43171 })] 43172 }); 43173 } 43174 TimePicker.TimeInput = TimeInput; 43175 Object.assign(TimePicker.TimeInput, { 43176 displayName: "TimePicker.TimeInput" 43177 }); 43178 var time_default = TimePicker; 43179 43180 // packages/components/build-module/date-time/date-time/index.js 43181 var import_element131 = __toESM(require_element()); 43182 43183 // packages/components/build-module/date-time/date-time/styles.js 43184 function _EMOTION_STRINGIFIED_CSS_ERROR__30() { 43185 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 43186 } 43187 var Wrapper5 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default18, false ? { 43188 target: "e1p5onf00" 43189 } : { 43190 target: "e1p5onf00", 43191 label: "Wrapper" 43192 })(false ? { 43193 name: "1khn195", 43194 styles: "box-sizing:border-box" 43195 } : { 43196 name: "1khn195", 43197 styles: "box-sizing:border-box", 43198 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVdUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBWU3RhY2sgfSBmcm9tICcuLi8uLi92LXN0YWNrJztcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQoIFZTdGFjayApYFxuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuYDtcbiJdfQ== */", 43199 toString: _EMOTION_STRINGIFIED_CSS_ERROR__30 43200 }); 43201 43202 // packages/components/build-module/date-time/date-time/index.js 43203 var import_jsx_runtime198 = __toESM(require_jsx_runtime()); 43204 var noop12 = () => { 43205 }; 43206 function UnforwardedDateTimePicker({ 43207 currentDate, 43208 is12Hour, 43209 dateOrder, 43210 isInvalidDate, 43211 onMonthPreviewed = noop12, 43212 onChange, 43213 events, 43214 startOfWeek: startOfWeek3 43215 }, ref) { 43216 return /* @__PURE__ */ (0, import_jsx_runtime198.jsx)(Wrapper5, { 43217 ref, 43218 className: "components-datetime", 43219 spacing: 4, 43220 children: /* @__PURE__ */ (0, import_jsx_runtime198.jsxs)(import_jsx_runtime198.Fragment, { 43221 children: [/* @__PURE__ */ (0, import_jsx_runtime198.jsx)(time_default, { 43222 currentTime: currentDate, 43223 onChange, 43224 is12Hour, 43225 dateOrder 43226 }), /* @__PURE__ */ (0, import_jsx_runtime198.jsx)(date_default, { 43227 currentDate, 43228 onChange, 43229 isInvalidDate, 43230 events, 43231 onMonthPreviewed, 43232 startOfWeek: startOfWeek3 43233 })] 43234 }) 43235 }); 43236 } 43237 var DateTimePicker = (0, import_element131.forwardRef)(UnforwardedDateTimePicker); 43238 var date_time_default = DateTimePicker; 43239 43240 // packages/components/build-module/date-time/index.js 43241 var date_time_default2 = date_time_default; 43242 43243 // packages/components/build-module/disabled/index.js 43244 var import_element132 = __toESM(require_element()); 43245 43246 // packages/components/build-module/disabled/styles/disabled-styles.js 43247 function _EMOTION_STRINGIFIED_CSS_ERROR__31() { 43248 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 43249 } 43250 var disabledStyles3 = false ? { 43251 name: "u2jump", 43252 styles: "position:relative;pointer-events:none;&::after{content:'';position:absolute;top:0;right:0;bottom:0;left:0;}*{pointer-events:none;}" 43253 } : { 43254 name: "iqemdn-disabledStyles", 43255 styles: "position:relative;pointer-events:none;&::after{content:'';position:absolute;top:0;right:0;bottom:0;left:0;}*{pointer-events:none;};label:disabledStyles;", 43256 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImRpc2FibGVkLXN0eWxlcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS2lDIiwiZmlsZSI6ImRpc2FibGVkLXN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBkaXNhYmxlZFN0eWxlcyA9IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblxuXHQmOjphZnRlciB7XG5cdFx0Y29udGVudDogJyc7XG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHRvcDogMDtcblx0XHRyaWdodDogMDtcblx0XHRib3R0b206IDA7XG5cdFx0bGVmdDogMDtcblx0fVxuXG5cdC8vIEFsc28gbWFrZSBuZXN0ZWQgYmxvY2tzIHVuc2VsZWN0YWJsZS5cblx0KiB7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdH1cbmA7XG4iXX0= */", 43257 toString: _EMOTION_STRINGIFIED_CSS_ERROR__31 43258 }; 43259 43260 // packages/components/build-module/disabled/index.js 43261 var import_jsx_runtime199 = __toESM(require_jsx_runtime()); 43262 var Context = (0, import_element132.createContext)(false); 43263 Context.displayName = "DisabledContext"; 43264 var { 43265 Consumer, 43266 Provider: Provider2 43267 } = Context; 43268 function Disabled({ 43269 className: className2, 43270 children, 43271 isDisabled = true, 43272 ...props 43273 }) { 43274 const cx3 = useCx(); 43275 return /* @__PURE__ */ (0, import_jsx_runtime199.jsx)(Provider2, { 43276 value: isDisabled, 43277 children: /* @__PURE__ */ (0, import_jsx_runtime199.jsx)("div", { 43278 // @ts-ignore Reason: inert is a recent HTML attribute 43279 inert: isDisabled ? "true" : void 0, 43280 className: isDisabled ? cx3(disabledStyles3, className2, "components-disabled") : void 0, 43281 ...props, 43282 children 43283 }) 43284 }); 43285 } 43286 Disabled.Context = Context; 43287 Disabled.Consumer = Consumer; 43288 var disabled_default = Disabled; 43289 43290 // packages/components/build-module/disclosure/index.js 43291 var import_element133 = __toESM(require_element()); 43292 var import_jsx_runtime200 = __toESM(require_jsx_runtime()); 43293 var UnforwardedDisclosureContent = ({ 43294 visible, 43295 children, 43296 ...props 43297 }, ref) => { 43298 const disclosure = useDisclosureStore({ 43299 open: visible 43300 }); 43301 return /* @__PURE__ */ (0, import_jsx_runtime200.jsx)(DisclosureContent, { 43302 store: disclosure, 43303 ref, 43304 ...props, 43305 children 43306 }); 43307 }; 43308 var DisclosureContent22 = (0, import_element133.forwardRef)(UnforwardedDisclosureContent); 43309 43310 // packages/components/build-module/draggable/index.js 43311 var import_compose54 = __toESM(require_compose()); 43312 var import_element134 = __toESM(require_element()); 43313 var import_jsx_runtime201 = __toESM(require_jsx_runtime()); 43314 var dragImageClass = "components-draggable__invisible-drag-image"; 43315 var cloneWrapperClass = "components-draggable__clone"; 43316 var clonePadding = 0; 43317 var bodyClass = "is-dragging-components-draggable"; 43318 function Draggable({ 43319 children, 43320 onDragStart, 43321 onDragOver, 43322 onDragEnd, 43323 appendToOwnerDocument = false, 43324 cloneClassname, 43325 elementId, 43326 transferData, 43327 __experimentalTransferDataType: transferDataType = "text", 43328 __experimentalDragComponent: dragComponent 43329 }) { 43330 const dragComponentRef = (0, import_element134.useRef)(null); 43331 const cleanupRef = (0, import_element134.useRef)(() => { 43332 }); 43333 function end(event) { 43334 event.preventDefault(); 43335 cleanupRef.current(); 43336 if (onDragEnd) { 43337 onDragEnd(event); 43338 } 43339 } 43340 function start(event) { 43341 const { 43342 ownerDocument 43343 } = event.target; 43344 event.dataTransfer.setData(transferDataType, JSON.stringify(transferData)); 43345 const cloneWrapper = ownerDocument.createElement("div"); 43346 cloneWrapper.style.top = "0"; 43347 cloneWrapper.style.left = "0"; 43348 const dragImage = ownerDocument.createElement("div"); 43349 if ("function" === typeof event.dataTransfer.setDragImage) { 43350 dragImage.classList.add(dragImageClass); 43351 ownerDocument.body.appendChild(dragImage); 43352 event.dataTransfer.setDragImage(dragImage, 0, 0); 43353 } 43354 cloneWrapper.classList.add(cloneWrapperClass); 43355 if (cloneClassname) { 43356 cloneWrapper.classList.add(cloneClassname); 43357 } 43358 let x2 = 0; 43359 let y3 = 0; 43360 if (dragComponentRef.current) { 43361 x2 = event.clientX; 43362 y3 = event.clientY; 43363 cloneWrapper.style.transform = `translate( $x2}px, $y3}px )`; 43364 const clonedDragComponent = ownerDocument.createElement("div"); 43365 clonedDragComponent.innerHTML = dragComponentRef.current.innerHTML; 43366 cloneWrapper.appendChild(clonedDragComponent); 43367 ownerDocument.body.appendChild(cloneWrapper); 43368 } else { 43369 const element = ownerDocument.getElementById(elementId); 43370 const elementRect = element.getBoundingClientRect(); 43371 const elementWrapper = element.parentNode; 43372 const elementTopOffset = elementRect.top; 43373 const elementLeftOffset = elementRect.left; 43374 cloneWrapper.style.width = `$elementRect.width + clonePadding * 2}px`; 43375 const clone = element.cloneNode(true); 43376 clone.id = `clone-$elementId}`; 43377 x2 = elementLeftOffset - clonePadding; 43378 y3 = elementTopOffset - clonePadding; 43379 cloneWrapper.style.transform = `translate( $x2}px, $y3}px )`; 43380 Array.from(clone.querySelectorAll("iframe")).forEach((child) => child.parentNode?.removeChild(child)); 43381 cloneWrapper.appendChild(clone); 43382 if (appendToOwnerDocument) { 43383 ownerDocument.body.appendChild(cloneWrapper); 43384 } else { 43385 elementWrapper?.appendChild(cloneWrapper); 43386 } 43387 } 43388 let cursorLeft = event.clientX; 43389 let cursorTop = event.clientY; 43390 function over(e3) { 43391 if (cursorLeft === e3.clientX && cursorTop === e3.clientY) { 43392 return; 43393 } 43394 const nextX = x2 + e3.clientX - cursorLeft; 43395 const nextY = y3 + e3.clientY - cursorTop; 43396 cloneWrapper.style.transform = `translate( $nextX}px, $nextY}px )`; 43397 cursorLeft = e3.clientX; 43398 cursorTop = e3.clientY; 43399 x2 = nextX; 43400 y3 = nextY; 43401 if (onDragOver) { 43402 onDragOver(e3); 43403 } 43404 } 43405 const throttledDragOver = (0, import_compose54.throttle)(over, 16); 43406 ownerDocument.addEventListener("dragover", throttledDragOver); 43407 ownerDocument.body.classList.add(bodyClass); 43408 if (onDragStart) { 43409 onDragStart(event); 43410 } 43411 cleanupRef.current = () => { 43412 if (cloneWrapper && cloneWrapper.parentNode) { 43413 cloneWrapper.parentNode.removeChild(cloneWrapper); 43414 } 43415 if (dragImage && dragImage.parentNode) { 43416 dragImage.parentNode.removeChild(dragImage); 43417 } 43418 ownerDocument.body.classList.remove(bodyClass); 43419 ownerDocument.removeEventListener("dragover", throttledDragOver); 43420 }; 43421 } 43422 (0, import_element134.useEffect)(() => () => { 43423 cleanupRef.current(); 43424 }, []); 43425 return /* @__PURE__ */ (0, import_jsx_runtime201.jsxs)(import_jsx_runtime201.Fragment, { 43426 children: [children({ 43427 onDraggableStart: start, 43428 onDraggableEnd: end 43429 }), dragComponent && /* @__PURE__ */ (0, import_jsx_runtime201.jsx)("div", { 43430 className: "components-draggable-drag-component-root", 43431 style: { 43432 display: "none" 43433 }, 43434 ref: dragComponentRef, 43435 children: dragComponent 43436 })] 43437 }); 43438 } 43439 var draggable_default = Draggable; 43440 43441 // packages/components/build-module/drop-zone/index.js 43442 var import_i18n46 = __toESM(require_i18n()); 43443 var import_element135 = __toESM(require_element()); 43444 var import_dom31 = __toESM(require_dom()); 43445 var import_compose55 = __toESM(require_compose()); 43446 var import_jsx_runtime202 = __toESM(require_jsx_runtime()); 43447 function DropZoneComponent({ 43448 className: className2, 43449 icon = upload_default, 43450 label, 43451 onFilesDrop, 43452 onHTMLDrop, 43453 onDrop, 43454 isEligible = () => true, 43455 ...restProps 43456 }) { 43457 const [isDraggingOverDocument, setIsDraggingOverDocument] = (0, import_element135.useState)(); 43458 const [isDraggingOverElement, setIsDraggingOverElement] = (0, import_element135.useState)(); 43459 const [isActive, setIsActive] = (0, import_element135.useState)(); 43460 const ref = (0, import_compose55.__experimentalUseDropZone)({ 43461 onDrop(event) { 43462 if (!event.dataTransfer) { 43463 return; 43464 } 43465 const files = (0, import_dom31.getFilesFromDataTransfer)(event.dataTransfer); 43466 const html = event.dataTransfer.getData("text/html"); 43467 if (html && onHTMLDrop) { 43468 onHTMLDrop(html); 43469 } else if (files.length && onFilesDrop) { 43470 onFilesDrop(files); 43471 } else if (onDrop) { 43472 onDrop(event); 43473 } 43474 }, 43475 onDragStart(event) { 43476 setIsDraggingOverDocument(true); 43477 if (!event.dataTransfer) { 43478 return; 43479 } 43480 if (event.dataTransfer.types.includes("text/html")) { 43481 setIsActive(!!onHTMLDrop); 43482 } else if ( 43483 // Check for the types because sometimes the files themselves 43484 // are only available on drop. 43485 event.dataTransfer.types.includes("Files") || (0, import_dom31.getFilesFromDataTransfer)(event.dataTransfer).length > 0 43486 ) { 43487 setIsActive(!!onFilesDrop); 43488 } else { 43489 setIsActive(!!onDrop && isEligible(event.dataTransfer)); 43490 } 43491 }, 43492 onDragEnd() { 43493 setIsDraggingOverElement(false); 43494 setIsDraggingOverDocument(false); 43495 setIsActive(void 0); 43496 }, 43497 onDragEnter() { 43498 setIsDraggingOverElement(true); 43499 }, 43500 onDragLeave() { 43501 setIsDraggingOverElement(false); 43502 } 43503 }); 43504 const classes = clsx_default("components-drop-zone", className2, { 43505 "is-active": isActive, 43506 "is-dragging-over-document": isDraggingOverDocument, 43507 "is-dragging-over-element": isDraggingOverElement 43508 }); 43509 return /* @__PURE__ */ (0, import_jsx_runtime202.jsx)("div", { 43510 ...restProps, 43511 ref, 43512 className: classes, 43513 children: /* @__PURE__ */ (0, import_jsx_runtime202.jsx)("div", { 43514 className: "components-drop-zone__content", 43515 children: /* @__PURE__ */ (0, import_jsx_runtime202.jsxs)("div", { 43516 className: "components-drop-zone__content-inner", 43517 children: [/* @__PURE__ */ (0, import_jsx_runtime202.jsx)(icon_default2, { 43518 icon, 43519 className: "components-drop-zone__content-icon" 43520 }), /* @__PURE__ */ (0, import_jsx_runtime202.jsx)("span", { 43521 className: "components-drop-zone__content-text", 43522 children: label ? label : (0, import_i18n46.__)("Drop files to upload") 43523 })] 43524 }) 43525 }) 43526 }); 43527 } 43528 var drop_zone_default = DropZoneComponent; 43529 43530 // packages/components/build-module/drop-zone/provider.js 43531 var import_deprecated15 = __toESM(require_deprecated()); 43532 function DropZoneProvider({ 43533 children 43534 }) { 43535 (0, import_deprecated15.default)("wp.components.DropZoneProvider", { 43536 since: "5.8", 43537 hint: "wp.component.DropZone no longer needs a provider. wp.components.DropZoneProvider is safe to remove from your code." 43538 }); 43539 return children; 43540 } 43541 43542 // packages/components/build-module/duotone-picker/duotone-picker.js 43543 var import_es62 = __toESM(require_es6()); 43544 var import_element137 = __toESM(require_element()); 43545 var import_i18n48 = __toESM(require_i18n()); 43546 43547 // packages/components/build-module/duotone-picker/color-list-picker/index.js 43548 var import_element136 = __toESM(require_element()); 43549 var import_i18n47 = __toESM(require_i18n()); 43550 var import_compose56 = __toESM(require_compose()); 43551 var import_jsx_runtime203 = __toESM(require_jsx_runtime()); 43552 function ColorOption({ 43553 label, 43554 value, 43555 colors, 43556 disableCustomColors, 43557 enableAlpha, 43558 onChange 43559 }) { 43560 const [isOpen, setIsOpen] = (0, import_element136.useState)(false); 43561 const idRoot = (0, import_compose56.useInstanceId)(ColorOption, "color-list-picker-option"); 43562 const labelId = `$idRoot}__label`; 43563 const contentId = `$idRoot}__content`; 43564 return /* @__PURE__ */ (0, import_jsx_runtime203.jsxs)(import_jsx_runtime203.Fragment, { 43565 children: [/* @__PURE__ */ (0, import_jsx_runtime203.jsx)(button_default, { 43566 __next40pxDefaultSize: true, 43567 className: "components-color-list-picker__swatch-button", 43568 id: labelId, 43569 onClick: () => setIsOpen((prev2) => !prev2), 43570 "aria-expanded": isOpen, 43571 "aria-controls": contentId, 43572 icon: value ? /* @__PURE__ */ (0, import_jsx_runtime203.jsx)(color_indicator_default, { 43573 colorValue: value, 43574 className: "components-color-list-picker__swatch-color" 43575 }) : /* @__PURE__ */ (0, import_jsx_runtime203.jsx)(icon_default3, { 43576 icon: swatch_default 43577 }), 43578 text: label 43579 }), /* @__PURE__ */ (0, import_jsx_runtime203.jsx)("div", { 43580 role: "group", 43581 id: contentId, 43582 "aria-labelledby": labelId, 43583 "aria-hidden": !isOpen, 43584 children: isOpen && /* @__PURE__ */ (0, import_jsx_runtime203.jsx)(color_palette_default, { 43585 "aria-label": (0, import_i18n47.__)("Color options"), 43586 className: "components-color-list-picker__color-picker", 43587 colors, 43588 value, 43589 clearable: false, 43590 onChange, 43591 disableCustomColors, 43592 enableAlpha 43593 }) 43594 })] 43595 }); 43596 } 43597 function ColorListPicker({ 43598 colors, 43599 labels, 43600 value = [], 43601 disableCustomColors, 43602 enableAlpha, 43603 onChange 43604 }) { 43605 return /* @__PURE__ */ (0, import_jsx_runtime203.jsx)("div", { 43606 className: "components-color-list-picker", 43607 children: labels.map((label, index2) => /* @__PURE__ */ (0, import_jsx_runtime203.jsx)(ColorOption, { 43608 label, 43609 value: value[index2], 43610 colors, 43611 disableCustomColors, 43612 enableAlpha, 43613 onChange: (newColor) => { 43614 const newColors = value.slice(); 43615 newColors[index2] = newColor; 43616 onChange(newColors); 43617 } 43618 }, index2)) 43619 }); 43620 } 43621 var color_list_picker_default = ColorListPicker; 43622 43623 // packages/components/build-module/duotone-picker/utils.js 43624 k([names_default]); 43625 function getDefaultColors(palette) { 43626 if (!palette || palette.length < 2) { 43627 return ["#000", "#fff"]; 43628 } 43629 return palette.map(({ 43630 color: color2 43631 }) => ({ 43632 color: color2, 43633 brightness: w(color2).brightness() 43634 })).reduce(([min3, max3], current) => { 43635 return [current.brightness <= min3.brightness ? current : min3, current.brightness >= max3.brightness ? current : max3]; 43636 }, [{ 43637 brightness: 1, 43638 color: "" 43639 }, { 43640 brightness: 0, 43641 color: "" 43642 }]).map(({ 43643 color: color2 43644 }) => color2); 43645 } 43646 function getGradientFromCSSColors(colors = [], angle = "90deg") { 43647 const l3 = 100 / colors.length; 43648 const stops = colors.map((c3, i3) => `$c3} $i3 * l3}%, $c3} ${(i3 + 1) * l3}%`).join(", "); 43649 return `linear-gradient( $angle}, $stops} )`; 43650 } 43651 function getColorStopsFromColors(colors) { 43652 return colors.map((color2, i3) => ({ 43653 position: i3 * 100 / (colors.length - 1), 43654 color: color2 43655 })); 43656 } 43657 function getColorsFromColorStops(colorStops = []) { 43658 return colorStops.map(({ 43659 color: color2 43660 }) => color2); 43661 } 43662 43663 // packages/components/build-module/duotone-picker/custom-duotone-bar.js 43664 var import_jsx_runtime204 = __toESM(require_jsx_runtime()); 43665 var PLACEHOLDER_VALUES = ["#333", "#CCC"]; 43666 function CustomDuotoneBar({ 43667 value, 43668 onChange 43669 }) { 43670 const hasGradient = !!value; 43671 const values = hasGradient ? value : PLACEHOLDER_VALUES; 43672 const background2 = getGradientFromCSSColors(values); 43673 const controlPoints = getColorStopsFromColors(values); 43674 return /* @__PURE__ */ (0, import_jsx_runtime204.jsx)(CustomGradientBar, { 43675 disableInserter: true, 43676 background: background2, 43677 hasGradient, 43678 value: controlPoints, 43679 onChange: (newColorStops) => { 43680 const newValue = getColorsFromColorStops(newColorStops); 43681 onChange(newValue); 43682 } 43683 }); 43684 } 43685 43686 // packages/components/build-module/duotone-picker/duotone-picker.js 43687 var import_jsx_runtime205 = __toESM(require_jsx_runtime()); 43688 function DuotonePicker({ 43689 asButtons, 43690 loop, 43691 clearable = true, 43692 unsetable = true, 43693 colorPalette, 43694 duotonePalette, 43695 disableCustomColors, 43696 disableCustomDuotone, 43697 value, 43698 onChange, 43699 "aria-label": ariaLabel, 43700 "aria-labelledby": ariaLabelledby, 43701 ...otherProps 43702 }) { 43703 const [defaultDark, defaultLight] = (0, import_element137.useMemo)(() => getDefaultColors(colorPalette), [colorPalette]); 43704 const isUnset = value === "unset"; 43705 const unsetOptionLabel = (0, import_i18n48.__)("Unset"); 43706 const unsetOption = /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(circular_option_picker_default2.Option, { 43707 value: "unset", 43708 isSelected: isUnset, 43709 tooltipText: unsetOptionLabel, 43710 "aria-label": unsetOptionLabel, 43711 className: "components-duotone-picker__color-indicator", 43712 onClick: () => { 43713 onChange(isUnset ? void 0 : "unset"); 43714 } 43715 }, "unset"); 43716 const duotoneOptions = duotonePalette.map(({ 43717 colors, 43718 slug, 43719 name 43720 }) => { 43721 const style2 = { 43722 background: getGradientFromCSSColors(colors, "135deg"), 43723 color: "transparent" 43724 }; 43725 const tooltipText = name !== null && name !== void 0 ? name : (0, import_i18n48.sprintf)( 43726 // translators: %s: duotone code e.g: "dark-grayscale" or "7f7f7f-ffffff". 43727 (0, import_i18n48.__)("Duotone code: %s"), 43728 slug 43729 ); 43730 const label = name ? (0, import_i18n48.sprintf)( 43731 // translators: %s: The name of the option e.g: "Dark grayscale". 43732 (0, import_i18n48.__)("Duotone: %s"), 43733 name 43734 ) : tooltipText; 43735 const isSelected2 = (0, import_es62.default)(colors, value); 43736 return /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(circular_option_picker_default2.Option, { 43737 value: colors, 43738 isSelected: isSelected2, 43739 "aria-label": label, 43740 tooltipText, 43741 style: style2, 43742 onClick: () => { 43743 onChange(isSelected2 ? void 0 : colors); 43744 } 43745 }, slug); 43746 }); 43747 const { 43748 metaProps, 43749 labelProps 43750 } = getComputeCircularOptionPickerCommonProps(asButtons, loop, ariaLabel, ariaLabelledby); 43751 const options2 = unsetable ? [unsetOption, ...duotoneOptions] : duotoneOptions; 43752 return /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(circular_option_picker_default2, { 43753 ...otherProps, 43754 ...metaProps, 43755 ...labelProps, 43756 options: options2, 43757 actions: !!clearable && /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(circular_option_picker_default2.ButtonAction, { 43758 onClick: () => onChange(void 0), 43759 accessibleWhenDisabled: true, 43760 disabled: !value, 43761 children: (0, import_i18n48.__)("Clear") 43762 }), 43763 children: /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(component_default6, { 43764 paddingTop: options2.length === 0 ? 0 : 4, 43765 children: /* @__PURE__ */ (0, import_jsx_runtime205.jsxs)(component_default18, { 43766 spacing: 3, 43767 children: [!disableCustomColors && !disableCustomDuotone && /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(CustomDuotoneBar, { 43768 value: isUnset ? void 0 : value, 43769 onChange 43770 }), !disableCustomDuotone && /* @__PURE__ */ (0, import_jsx_runtime205.jsx)(color_list_picker_default, { 43771 labels: [(0, import_i18n48.__)("Shadows"), (0, import_i18n48.__)("Highlights")], 43772 colors: colorPalette, 43773 value: isUnset ? void 0 : value, 43774 disableCustomColors, 43775 enableAlpha: true, 43776 onChange: (newColors) => { 43777 if (!newColors[0]) { 43778 newColors[0] = defaultDark; 43779 } 43780 if (!newColors[1]) { 43781 newColors[1] = defaultLight; 43782 } 43783 const newValue = newColors.length >= 2 ? newColors : void 0; 43784 onChange(newValue); 43785 } 43786 })] 43787 }) 43788 }) 43789 }); 43790 } 43791 var duotone_picker_default = DuotonePicker; 43792 43793 // packages/components/build-module/duotone-picker/duotone-swatch.js 43794 var import_jsx_runtime206 = __toESM(require_jsx_runtime()); 43795 function DuotoneSwatch({ 43796 values 43797 }) { 43798 return values ? /* @__PURE__ */ (0, import_jsx_runtime206.jsx)(color_indicator_default, { 43799 colorValue: getGradientFromCSSColors(values, "135deg") 43800 }) : /* @__PURE__ */ (0, import_jsx_runtime206.jsx)(icon_default3, { 43801 icon: swatch_default 43802 }); 43803 } 43804 var duotone_swatch_default = DuotoneSwatch; 43805 43806 // packages/components/build-module/external-link/index.js 43807 var import_i18n49 = __toESM(require_i18n()); 43808 var import_element138 = __toESM(require_element()); 43809 var import_jsx_runtime207 = __toESM(require_jsx_runtime()); 43810 function UnforwardedExternalLink(props, ref) { 43811 const { 43812 href, 43813 children, 43814 className: className2, 43815 rel = "", 43816 ...additionalProps 43817 } = props; 43818 const optimizedRel = [...new Set([...rel.split(" "), "external", "noreferrer", "noopener"].filter(Boolean))].join(" "); 43819 const classes = clsx_default("components-external-link", className2); 43820 const isInternalAnchor = !!href?.startsWith("#"); 43821 const onClickHandler = (event) => { 43822 if (isInternalAnchor) { 43823 event.preventDefault(); 43824 } 43825 if (props.onClick) { 43826 props.onClick(event); 43827 } 43828 }; 43829 return ( 43830 /* eslint-disable react/jsx-no-target-blank */ 43831 /* @__PURE__ */ (0, import_jsx_runtime207.jsxs)("a", { 43832 ...additionalProps, 43833 className: classes, 43834 href, 43835 onClick: onClickHandler, 43836 target: "_blank", 43837 rel: optimizedRel, 43838 ref, 43839 children: [/* @__PURE__ */ (0, import_jsx_runtime207.jsx)("span", { 43840 className: "components-external-link__contents", 43841 children 43842 }), /* @__PURE__ */ (0, import_jsx_runtime207.jsx)("span", { 43843 className: "components-external-link__icon", 43844 "aria-label": ( 43845 /* translators: accessibility text */ 43846 (0, import_i18n49.__)("(opens in a new tab)") 43847 ), 43848 children: (0, import_i18n49.isRTL)() ? "\u2196" : "\u2197" 43849 })] 43850 }) 43851 ); 43852 } 43853 var ExternalLink = (0, import_element138.forwardRef)(UnforwardedExternalLink); 43854 var external_link_default = ExternalLink; 43855 43856 // packages/components/build-module/focal-point-picker/index.js 43857 var import_i18n51 = __toESM(require_i18n()); 43858 var import_element139 = __toESM(require_element()); 43859 var import_compose57 = __toESM(require_compose()); 43860 43861 // packages/components/build-module/focal-point-picker/controls.js 43862 var import_i18n50 = __toESM(require_i18n()); 43863 43864 // packages/components/build-module/focal-point-picker/utils.js 43865 var INITIAL_BOUNDS = { 43866 width: 200, 43867 height: 170 43868 }; 43869 var VIDEO_EXTENSIONS = ["avi", "mpg", "mpeg", "mov", "mp4", "m4v", "ogg", "ogv", "webm", "wmv"]; 43870 function getExtension(filename = "") { 43871 const parts = filename.split("."); 43872 return parts[parts.length - 1]; 43873 } 43874 function isVideoType(filename = "") { 43875 if (!filename) { 43876 return false; 43877 } 43878 return filename.startsWith("data:video/") || VIDEO_EXTENSIONS.includes(getExtension(filename)); 43879 } 43880 function fractionToPercentage(fraction) { 43881 return Math.round(fraction * 100); 43882 } 43883 43884 // packages/components/build-module/focal-point-picker/styles/focal-point-picker-style.js 43885 function _EMOTION_STRINGIFIED_CSS_ERROR__32() { 43886 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 43887 } 43888 var Container2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default, false ? { 43889 target: "eeew7dm9" 43890 } : { 43891 target: "eeew7dm9", 43892 label: "Container" 43893 })("border:0;padding:0;margin:0;font-family:", font("default.fontFamily"), ";font-size:", font("default.fontSize"), ";", boxSizingReset, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQnVDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */")); 43894 var MediaWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 43895 target: "eeew7dm8" 43896 } : { 43897 target: "eeew7dm8", 43898 label: "MediaWrapper" 43899 })(false ? { 43900 name: "jqnsxy", 43901 styles: "background-color:transparent;display:flex;text-align:center;width:100%" 43902 } : { 43903 name: "jqnsxy", 43904 styles: "background-color:transparent;display:flex;text-align:center;width:100%", 43905 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QnNDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */", 43906 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 43907 }); 43908 var MediaContainer = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 43909 target: "eeew7dm7" 43910 } : { 43911 target: "eeew7dm7", 43912 label: "MediaContainer" 43913 })("align-items:center;border-radius:", config_values_default.radiusSmall, ";cursor:pointer;display:inline-flex;justify-content:center;margin:auto;position:relative;height:100%;&:after{border-radius:inherit;bottom:0;box-shadow:inset 0 0 0 1px rgba( 0, 0, 0, 0.1 );content:'';left:0;pointer-events:none;position:absolute;right:0;top:0;}img,video{border-radius:inherit;box-sizing:border-box;display:block;height:auto;margin:0;max-height:100%;max-width:100%;pointer-events:none;user-select:none;width:100%;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ3dDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */")); 43914 var MediaPlaceholder = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 43915 target: "eeew7dm6" 43916 } : { 43917 target: "eeew7dm6", 43918 label: "MediaPlaceholder" 43919 })("background:", COLORS.gray[100], ";border-radius:inherit;box-sizing:border-box;height:", INITIAL_BOUNDS.height, "px;max-width:280px;min-width:", INITIAL_BOUNDS.width, "px;width:100%;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRTBDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */")); 43920 var StyledUnitControl2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(unit_control_default, false ? { 43921 target: "eeew7dm5" 43922 } : { 43923 target: "eeew7dm5", 43924 label: "StyledUnitControl" 43925 })(false ? { 43926 name: "1d3w5wq", 43927 styles: "width:100%" 43928 } : { 43929 name: "1d3w5wq", 43930 styles: "width:100%", 43931 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRXNEIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */", 43932 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 43933 }); 43934 var _ref8 = false ? { 43935 name: "1mn7kwb", 43936 styles: "padding-bottom:1em" 43937 } : { 43938 name: "ho4pgl-extraHelpTextMargin", 43939 styles: "padding-bottom:1em;label:extraHelpTextMargin;", 43940 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Rk8iLCJmaWxlIjoiZm9jYWwtcG9pbnQtcGlja2VyLXN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vLi4vZmxleCc7XG5pbXBvcnQgVW5pdENvbnRyb2wgZnJvbSAnLi4vLi4vdW5pdC1jb250cm9sJztcbmltcG9ydCB7IFZpZXcgfSBmcm9tICcuLi8uLi92aWV3JztcbmltcG9ydCB7IENPTE9SUywgQ09ORklHLCBib3hTaXppbmdSZXNldCwgZm9udCB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB0eXBlIHsgRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBJTklUSUFMX0JPVU5EUyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IENvbnRhaW5lciA9IHN0eWxlZCggVmlldyApYFxuXHRib3JkZXI6IDA7XG5cdHBhZGRpbmc6IDA7XG5cdG1hcmdpbjogMDtcblx0Zm9udC1mYW1pbHk6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRGYW1pbHknICkgfTtcblx0Zm9udC1zaXplOiAkeyBmb250KCAnZGVmYXVsdC5mb250U2l6ZScgKSB9O1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVkaWFXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cdGRpc3BsYXk6IGZsZXg7XG5cdHRleHQtYWxpZ246IGNlbnRlcjtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgTWVkaWFDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y3Vyc29yOiBwb2ludGVyO1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdG1hcmdpbjogYXV0bztcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRoZWlnaHQ6IDEwMCU7XG5cblx0JjphZnRlciB7XG5cdFx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0XHRib3R0b206IDA7XG5cdFx0Ym94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHJnYmEoIDAsIDAsIDAsIDAuMSApO1xuXHRcdGNvbnRlbnQ6ICcnO1xuXHRcdGxlZnQ6IDA7XG5cdFx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdFx0cG9zaXRpb246IGFic29sdXRlO1xuXHRcdHJpZ2h0OiAwO1xuXHRcdHRvcDogMDtcblx0fVxuXG5cdGltZyxcblx0dmlkZW8ge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRoZWlnaHQ6IGF1dG87XG5cdFx0bWFyZ2luOiAwO1xuXHRcdG1heC1oZWlnaHQ6IDEwMCU7XG5cdFx0bWF4LXdpZHRoOiAxMDAlO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHVzZXItc2VsZWN0OiBub25lO1xuXHRcdHdpZHRoOiAxMDAlO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVkaWFQbGFjZWhvbGRlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQ6ICR7IENPTE9SUy5ncmF5WyAxMDAgXSB9O1xuXHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRoZWlnaHQ6ICR7IElOSVRJQUxfQk9VTkRTLmhlaWdodCB9cHg7XG5cdG1heC13aWR0aDogMjgwcHg7XG5cdG1pbi13aWR0aDogJHsgSU5JVElBTF9CT1VORFMud2lkdGggfXB4O1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRVbml0Q29udHJvbCA9IHN0eWxlZCggVW5pdENvbnRyb2wgKWBcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5jb25zdCBleHRyYUhlbHBUZXh0TWFyZ2luID0gKCB7XG5cdGhhc0hlbHBUZXh0ID0gZmFsc2UsXG59OiBGb2NhbFBvaW50UGlja2VyQ29udHJvbHNQcm9wcyApID0+IHtcblx0cmV0dXJuIGhhc0hlbHBUZXh0XG5cdFx0PyBjc3NgXG5cdFx0XHRcdHBhZGRpbmctYm90dG9tOiAxZW07XG5cdFx0ICBgXG5cdFx0OiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgY29uc3QgQ29udHJvbFdyYXBwZXIgPSBzdHlsZWQoIEZsZXggKWBcblx0bWF4LXdpZHRoOiAzMjBweDtcblx0cGFkZGluZy10b3A6IDFlbTtcblxuXHQkeyBleHRyYUhlbHBUZXh0TWFyZ2luIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBHcmlkVmlldyA9IHN0eWxlZC5kaXZgXG5cdGxlZnQ6IDUwJTtcblx0b3ZlcmZsb3c6IGhpZGRlbjtcblx0cG9pbnRlci1ldmVudHM6IG5vbmU7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiA1MCU7XG5cdHRyYW5zZm9ybTogdHJhbnNsYXRlM2QoIC01MCUsIC01MCUsIDAgKTtcblx0ei1pbmRleDogMTtcblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOiBvcGFjaXR5IDEwMG1zIGxpbmVhcjtcblx0fVxuXG5cdG9wYWNpdHk6ICR7ICggeyBzaG93T3ZlcmxheSB9OiB7IHNob3dPdmVybGF5PzogYm9vbGVhbiB9ICkgPT5cblx0XHRzaG93T3ZlcmxheSA/IDEgOiAwIH07XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmUgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiByZ2JhKCAyNTUsIDI1NSwgMjU1LCAwLjQgKTtcblx0YmFja2Ryb3AtZmlsdGVyOiBibHVyKCAxNnB4ICkgc2F0dXJhdGUoIDE4MCUgKTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZVooIDAgKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBHcmlkTGluZVggPSBzdHlsZWQoIEdyaWRMaW5lIClgXG5cdGhlaWdodDogMXB4O1xuXHRsZWZ0OiAxcHg7XG5cdHJpZ2h0OiAxcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVZID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHR3aWR0aDogMXB4O1xuXHR0b3A6IDFweDtcblx0Ym90dG9tOiAxcHg7XG5gO1xuIl19 */", 43941 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 43942 }; 43943 var extraHelpTextMargin = ({ 43944 hasHelpText = false 43945 }) => { 43946 return hasHelpText ? _ref8 : void 0; 43947 }; 43948 var ControlWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default3, false ? { 43949 target: "eeew7dm4" 43950 } : { 43951 target: "eeew7dm4", 43952 label: "ControlWrapper" 43953 })("max-width:320px;padding-top:1em;", extraHelpTextMargin, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RjRDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */")); 43954 var GridView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 43955 target: "eeew7dm3" 43956 } : { 43957 target: "eeew7dm3", 43958 label: "GridView" 43959 })("left:50%;overflow:hidden;pointer-events:none;position:absolute;top:50%;transform:translate3d( -50%, -50%, 0 );z-index:1;@media not ( prefers-reduced-motion ){transition:opacity 100ms linear;}opacity:", ({ 43960 showOverlay 43961 }) => showOverlay ? 1 : 0, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvR2tDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */")); 43962 var GridLine = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 43963 target: "eeew7dm2" 43964 } : { 43965 target: "eeew7dm2", 43966 label: "GridLine" 43967 })(false ? { 43968 name: "1yzbo24", 43969 styles: "background:rgba( 255, 255, 255, 0.4 );backdrop-filter:blur( 16px ) saturate( 180% );position:absolute;transform:translateZ( 0 )" 43970 } : { 43971 name: "1yzbo24", 43972 styles: "background:rgba( 255, 255, 255, 0.4 );backdrop-filter:blur( 16px ) saturate( 180% );position:absolute;transform:translateZ( 0 )", 43973 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSGtDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */", 43974 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 43975 }); 43976 var GridLineX = /* @__PURE__ */ emotion_styled_base_browser_esm_default(GridLine, false ? { 43977 target: "eeew7dm1" 43978 } : { 43979 target: "eeew7dm1", 43980 label: "GridLineX" 43981 })(false ? { 43982 name: "1sw8ur", 43983 styles: "height:1px;left:1px;right:1px" 43984 } : { 43985 name: "1sw8ur", 43986 styles: "height:1px;left:1px;right:1px", 43987 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0SDJDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */", 43988 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 43989 }); 43990 var GridLineY = /* @__PURE__ */ emotion_styled_base_browser_esm_default(GridLine, false ? { 43991 target: "eeew7dm0" 43992 } : { 43993 target: "eeew7dm0", 43994 label: "GridLineY" 43995 })(false ? { 43996 name: "188vg4t", 43997 styles: "width:1px;top:1px;bottom:1px" 43998 } : { 43999 name: "188vg4t", 44000 styles: "width:1px;top:1px;bottom:1px", 44001 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrSTJDIiwiZmlsZSI6ImZvY2FsLXBvaW50LXBpY2tlci1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uLy4uL2ZsZXgnO1xuaW1wb3J0IFVuaXRDb250cm9sIGZyb20gJy4uLy4uL3VuaXQtY29udHJvbCc7XG5pbXBvcnQgeyBWaWV3IH0gZnJvbSAnLi4vLi4vdmlldyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgYm94U2l6aW5nUmVzZXQsIGZvbnQgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgdHlwZSB7IEZvY2FsUG9pbnRQaWNrZXJDb250cm9sc1Byb3BzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgSU5JVElBTF9CT1VORFMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDb250YWluZXIgPSBzdHlsZWQoIFZpZXcgKWBcblx0Ym9yZGVyOiAwO1xuXHRwYWRkaW5nOiAwO1xuXHRtYXJnaW46IDA7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHR0ZXh0LWFsaWduOiBjZW50ZXI7XG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGN1cnNvcjogcG9pbnRlcjtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRtYXJnaW46IGF1dG87XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0aGVpZ2h0OiAxMDAlO1xuXG5cdCY6YWZ0ZXIge1xuXHRcdGJvcmRlci1yYWRpdXM6IGluaGVyaXQ7XG5cdFx0Ym90dG9tOiAwO1xuXHRcdGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0XHRjb250ZW50OiAnJztcblx0XHRsZWZ0OiAwO1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRcdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0XHRyaWdodDogMDtcblx0XHR0b3A6IDA7XG5cdH1cblxuXHRpbWcsXG5cdHZpZGVvIHtcblx0XHRib3JkZXItcmFkaXVzOiBpbmhlcml0O1xuXHRcdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0aGVpZ2h0OiBhdXRvO1xuXHRcdG1hcmdpbjogMDtcblx0XHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0XHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0XHR1c2VyLXNlbGVjdDogbm9uZTtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IE1lZGlhUGxhY2Vob2xkZXIgPSBzdHlsZWQuZGl2YFxuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMuZ3JheVsgMTAwIF0gfTtcblx0Ym9yZGVyLXJhZGl1czogaW5oZXJpdDtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0aGVpZ2h0OiAkeyBJTklUSUFMX0JPVU5EUy5oZWlnaHQgfXB4O1xuXHRtYXgtd2lkdGg6IDI4MHB4O1xuXHRtaW4td2lkdGg6ICR7IElOSVRJQUxfQk9VTkRTLndpZHRoIH1weDtcblx0d2lkdGg6IDEwMCU7XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkVW5pdENvbnRyb2wgPSBzdHlsZWQoIFVuaXRDb250cm9sIClgXG5cdHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3QgZXh0cmFIZWxwVGV4dE1hcmdpbiA9ICgge1xuXHRoYXNIZWxwVGV4dCA9IGZhbHNlLFxufTogRm9jYWxQb2ludFBpY2tlckNvbnRyb2xzUHJvcHMgKSA9PiB7XG5cdHJldHVybiBoYXNIZWxwVGV4dFxuXHRcdD8gY3NzYFxuXHRcdFx0XHRwYWRkaW5nLWJvdHRvbTogMWVtO1xuXHRcdCAgYFxuXHRcdDogdW5kZWZpbmVkO1xufTtcblxuZXhwb3J0IGNvbnN0IENvbnRyb2xXcmFwcGVyID0gc3R5bGVkKCBGbGV4IClgXG5cdG1heC13aWR0aDogMzIwcHg7XG5cdHBhZGRpbmctdG9wOiAxZW07XG5cblx0JHsgZXh0cmFIZWxwVGV4dE1hcmdpbiB9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZFZpZXcgPSBzdHlsZWQuZGl2YFxuXHRsZWZ0OiA1MCU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogNTAlO1xuXHR0cmFuc2Zvcm06IHRyYW5zbGF0ZTNkKCAtNTAlLCAtNTAlLCAwICk7XG5cdHotaW5kZXg6IDE7XG5cblx0QG1lZGlhIG5vdCAoIHByZWZlcnMtcmVkdWNlZC1tb3Rpb24gKSB7XG5cdFx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHRvcGFjaXR5OiAkeyAoIHsgc2hvd092ZXJsYXkgfTogeyBzaG93T3ZlcmxheT86IGJvb2xlYW4gfSApID0+XG5cdFx0c2hvd092ZXJsYXkgPyAxIDogMCB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJhY2tkcm9wLWZpbHRlcjogYmx1ciggMTZweCApIHNhdHVyYXRlKCAxODAlICk7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dHJhbnNmb3JtOiB0cmFuc2xhdGVaKCAwICk7XG5gO1xuXG5leHBvcnQgY29uc3QgR3JpZExpbmVYID0gc3R5bGVkKCBHcmlkTGluZSApYFxuXHRoZWlnaHQ6IDFweDtcblx0bGVmdDogMXB4O1xuXHRyaWdodDogMXB4O1xuYDtcblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lWSA9IHN0eWxlZCggR3JpZExpbmUgKWBcblx0d2lkdGg6IDFweDtcblx0dG9wOiAxcHg7XG5cdGJvdHRvbTogMXB4O1xuYDtcbiJdfQ== */", 44002 toString: _EMOTION_STRINGIFIED_CSS_ERROR__32 44003 }); 44004 44005 // packages/components/build-module/focal-point-picker/controls.js 44006 var import_jsx_runtime208 = __toESM(require_jsx_runtime()); 44007 var TEXTCONTROL_MIN = 0; 44008 var TEXTCONTROL_MAX = 100; 44009 var noop13 = () => { 44010 }; 44011 function FocalPointPickerControls({ 44012 hasHelpText, 44013 onChange = noop13, 44014 point = { 44015 x: 0.5, 44016 y: 0.5 44017 } 44018 }) { 44019 const valueX = fractionToPercentage(point.x); 44020 const valueY = fractionToPercentage(point.y); 44021 const handleChange = (value, axis) => { 44022 if (value === void 0) { 44023 return; 44024 } 44025 const num = parseInt(value, 10); 44026 if (!isNaN(num)) { 44027 onChange({ 44028 ...point, 44029 [axis]: num / 100 44030 }); 44031 } 44032 }; 44033 return /* @__PURE__ */ (0, import_jsx_runtime208.jsxs)(ControlWrapper, { 44034 className: "focal-point-picker__controls", 44035 hasHelpText, 44036 gap: 4, 44037 children: [/* @__PURE__ */ (0, import_jsx_runtime208.jsx)(FocalPointUnitControl, { 44038 label: (0, import_i18n50.__)("Left"), 44039 "aria-label": (0, import_i18n50.__)("Focal point left position"), 44040 value: [valueX, "%"].join(""), 44041 onChange: (next2) => handleChange(next2, "x"), 44042 dragDirection: "e" 44043 }), /* @__PURE__ */ (0, import_jsx_runtime208.jsx)(FocalPointUnitControl, { 44044 label: (0, import_i18n50.__)("Top"), 44045 "aria-label": (0, import_i18n50.__)("Focal point top position"), 44046 value: [valueY, "%"].join(""), 44047 onChange: (next2) => handleChange(next2, "y"), 44048 dragDirection: "s" 44049 })] 44050 }); 44051 } 44052 function FocalPointUnitControl(props) { 44053 return /* @__PURE__ */ (0, import_jsx_runtime208.jsx)(StyledUnitControl2, { 44054 __next40pxDefaultSize: true, 44055 className: "focal-point-picker__controls-position-unit-control", 44056 labelPosition: "top", 44057 max: TEXTCONTROL_MAX, 44058 min: TEXTCONTROL_MIN, 44059 units: [{ 44060 value: "%", 44061 label: "%" 44062 }], 44063 ...props 44064 }); 44065 } 44066 44067 // packages/components/build-module/focal-point-picker/styles/focal-point-style.js 44068 var PointerCircle = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 44069 target: "e19snlhg0" 44070 } : { 44071 target: "e19snlhg0", 44072 label: "PointerCircle" 44073 })("background-color:transparent;cursor:grab;height:40px;margin:-20px 0 0 -20px;position:absolute;user-select:none;width:40px;will-change:transform;z-index:10000;background:rgba( 255, 255, 255, 0.4 );border:1px solid rgba( 255, 255, 255, 0.4 );border-radius:", config_values_default.radiusRound, ";backdrop-filter:blur( 16px ) saturate( 180% );box-shadow:rgb( 0 0 0 / 10% ) 0px 0px 8px;@media not ( prefers-reduced-motion ){transition:transform 100ms linear;}", ({ 44074 isDragging: isDragging2 44075 }) => isDragging2 && ` 44076 box-shadow: rgb( 0 0 0 / 12% ) 0px 0px 10px; 44077 transform: scale( 1.1 ); 44078 cursor: grabbing; 44079 `, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvY2FsLXBvaW50LXN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVV1QyIsImZpbGUiOiJmb2NhbC1wb2ludC1zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3QgUG9pbnRlckNpcmNsZSA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuXHRjdXJzb3I6IGdyYWI7XG5cdGhlaWdodDogNDBweDtcblx0bWFyZ2luOiAtMjBweCAwIDAgLTIwcHg7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dXNlci1zZWxlY3Q6IG5vbmU7XG5cdHdpZHRoOiA0MHB4O1xuXHR3aWxsLWNoYW5nZTogdHJhbnNmb3JtO1xuXHR6LWluZGV4OiAxMDAwMDtcblx0YmFja2dyb3VuZDogcmdiYSggMjU1LCAyNTUsIDI1NSwgMC40ICk7XG5cdGJvcmRlcjogMXB4IHNvbGlkIHJnYmEoIDI1NSwgMjU1LCAyNTUsIDAuNCApO1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzUm91bmQgfTtcblx0YmFja2Ryb3AtZmlsdGVyOiBibHVyKCAxNnB4ICkgc2F0dXJhdGUoIDE4MCUgKTtcblx0Ym94LXNoYWRvdzogcmdiKCAwIDAgMCAvIDEwJSApIDBweCAwcHggOHB4O1xuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdHRyYW5zaXRpb246IHRyYW5zZm9ybSAxMDBtcyBsaW5lYXI7XG5cdH1cblxuXHQkeyAoIHsgaXNEcmFnZ2luZyB9OiB7IGlzRHJhZ2dpbmc6IGJvb2xlYW4gfSApID0+XG5cdFx0aXNEcmFnZ2luZyAmJlxuXHRcdGBcblx0XHRcdGJveC1zaGFkb3c6IHJnYiggMCAwIDAgLyAxMiUgKSAwcHggMHB4IDEwcHg7XG5cdFx0XHR0cmFuc2Zvcm06IHNjYWxlKCAxLjEgKTtcblx0XHRcdGN1cnNvcjogZ3JhYmJpbmc7XG5cdFx0XHRgIH1cbmA7XG4iXX0= */")); 44080 44081 // packages/components/build-module/focal-point-picker/focal-point.js 44082 var import_jsx_runtime209 = __toESM(require_jsx_runtime()); 44083 function FocalPoint({ 44084 left = "50%", 44085 top = "50%", 44086 ...props 44087 }) { 44088 const style2 = { 44089 left, 44090 top 44091 }; 44092 return /* @__PURE__ */ (0, import_jsx_runtime209.jsx)(PointerCircle, { 44093 ...props, 44094 className: "components-focal-point-picker__icon_container", 44095 style: style2 44096 }); 44097 } 44098 44099 // packages/components/build-module/focal-point-picker/grid.js 44100 var import_jsx_runtime210 = __toESM(require_jsx_runtime()); 44101 function FocalPointPickerGrid({ 44102 bounds, 44103 ...props 44104 }) { 44105 return /* @__PURE__ */ (0, import_jsx_runtime210.jsxs)(GridView, { 44106 ...props, 44107 className: "components-focal-point-picker__grid", 44108 style: { 44109 width: bounds.width, 44110 height: bounds.height 44111 }, 44112 children: [/* @__PURE__ */ (0, import_jsx_runtime210.jsx)(GridLineX, { 44113 style: { 44114 top: "33%" 44115 } 44116 }), /* @__PURE__ */ (0, import_jsx_runtime210.jsx)(GridLineX, { 44117 style: { 44118 top: "66%" 44119 } 44120 }), /* @__PURE__ */ (0, import_jsx_runtime210.jsx)(GridLineY, { 44121 style: { 44122 left: "33%" 44123 } 44124 }), /* @__PURE__ */ (0, import_jsx_runtime210.jsx)(GridLineY, { 44125 style: { 44126 left: "66%" 44127 } 44128 })] 44129 }); 44130 } 44131 44132 // packages/components/build-module/focal-point-picker/media.js 44133 var import_jsx_runtime211 = __toESM(require_jsx_runtime()); 44134 function Media2({ 44135 alt, 44136 autoPlay, 44137 src, 44138 onLoad, 44139 mediaRef, 44140 // Exposing muted prop for test rendering purposes 44141 // https://github.com/testing-library/react-testing-library/issues/470 44142 muted: muted2 = true, 44143 ...props 44144 }) { 44145 if (!src) { 44146 return /* @__PURE__ */ (0, import_jsx_runtime211.jsx)(MediaPlaceholder, { 44147 className: "components-focal-point-picker__media components-focal-point-picker__media--placeholder", 44148 ref: mediaRef, 44149 ...props 44150 }); 44151 } 44152 const isVideo = isVideoType(src); 44153 return isVideo ? /* @__PURE__ */ (0, import_jsx_runtime211.jsx)("video", { 44154 ...props, 44155 autoPlay, 44156 className: "components-focal-point-picker__media components-focal-point-picker__media--video", 44157 loop: true, 44158 muted: muted2, 44159 onLoadedData: onLoad, 44160 ref: mediaRef, 44161 src 44162 }) : /* @__PURE__ */ (0, import_jsx_runtime211.jsx)("img", { 44163 ...props, 44164 alt, 44165 className: "components-focal-point-picker__media components-focal-point-picker__media--image", 44166 onLoad, 44167 ref: mediaRef, 44168 src 44169 }); 44170 } 44171 44172 // packages/components/build-module/focal-point-picker/index.js 44173 var import_jsx_runtime212 = __toESM(require_jsx_runtime()); 44174 var GRID_OVERLAY_TIMEOUT = 600; 44175 function FocalPointPicker({ 44176 // Prevent passing to internal component. 44177 __nextHasNoMarginBottom: _, 44178 autoPlay = true, 44179 className: className2, 44180 help, 44181 hideLabelFromVision, 44182 label, 44183 onChange, 44184 onDrag, 44185 onDragEnd, 44186 onDragStart, 44187 resolvePoint, 44188 url, 44189 value: valueProp = { 44190 x: 0.5, 44191 y: 0.5 44192 }, 44193 ...restProps 44194 }) { 44195 const [point, setPoint] = (0, import_element139.useState)(valueProp); 44196 const [showGridOverlay, setShowGridOverlay] = (0, import_element139.useState)(false); 44197 const { 44198 startDrag, 44199 endDrag, 44200 isDragging: isDragging2 44201 } = (0, import_compose57.__experimentalUseDragging)({ 44202 onDragStart: (event) => { 44203 dragAreaRef.current?.focus(); 44204 const value = getValueWithinDragArea(event); 44205 if (!value) { 44206 return; 44207 } 44208 onDragStart?.(value, event); 44209 setPoint(value); 44210 }, 44211 onDragMove: (event) => { 44212 event.preventDefault(); 44213 const value = getValueWithinDragArea(event); 44214 if (!value) { 44215 return; 44216 } 44217 onDrag?.(value, event); 44218 setPoint(value); 44219 }, 44220 onDragEnd: () => { 44221 onDragEnd?.(); 44222 onChange?.(point); 44223 } 44224 }); 44225 const { 44226 x: x2, 44227 y: y3 44228 } = isDragging2 ? point : valueProp; 44229 const dragAreaRef = (0, import_element139.useRef)(null); 44230 const [bounds, setBounds] = (0, import_element139.useState)(INITIAL_BOUNDS); 44231 const refUpdateBounds = (0, import_element139.useRef)(() => { 44232 if (!dragAreaRef.current) { 44233 return; 44234 } 44235 const { 44236 clientWidth: width, 44237 clientHeight: height 44238 } = dragAreaRef.current; 44239 setBounds(width > 0 && height > 0 ? { 44240 width, 44241 height 44242 } : { 44243 ...INITIAL_BOUNDS 44244 }); 44245 }); 44246 (0, import_element139.useEffect)(() => { 44247 const updateBounds = refUpdateBounds.current; 44248 if (!dragAreaRef.current) { 44249 return; 44250 } 44251 const { 44252 defaultView 44253 } = dragAreaRef.current.ownerDocument; 44254 defaultView?.addEventListener("resize", updateBounds); 44255 return () => defaultView?.removeEventListener("resize", updateBounds); 44256 }, []); 44257 (0, import_compose57.useIsomorphicLayoutEffect)(() => void refUpdateBounds.current(), []); 44258 const getValueWithinDragArea = ({ 44259 clientX, 44260 clientY, 44261 shiftKey 44262 }) => { 44263 if (!dragAreaRef.current) { 44264 return; 44265 } 44266 const { 44267 top, 44268 left 44269 } = dragAreaRef.current.getBoundingClientRect(); 44270 let nextX = (clientX - left) / bounds.width; 44271 let nextY = (clientY - top) / bounds.height; 44272 if (shiftKey) { 44273 nextX = Math.round(nextX / 0.1) * 0.1; 44274 nextY = Math.round(nextY / 0.1) * 0.1; 44275 } 44276 return getFinalValue({ 44277 x: nextX, 44278 y: nextY 44279 }); 44280 }; 44281 const getFinalValue = (value) => { 44282 var _resolvePoint; 44283 const resolvedValue = (_resolvePoint = resolvePoint?.(value)) !== null && _resolvePoint !== void 0 ? _resolvePoint : value; 44284 resolvedValue.x = Math.max(0, Math.min(resolvedValue.x, 1)); 44285 resolvedValue.y = Math.max(0, Math.min(resolvedValue.y, 1)); 44286 const roundToTwoDecimalPlaces = (n3) => Math.round(n3 * 100) / 100; 44287 return { 44288 x: roundToTwoDecimalPlaces(resolvedValue.x), 44289 y: roundToTwoDecimalPlaces(resolvedValue.y) 44290 }; 44291 }; 44292 const arrowKeyStep = (event) => { 44293 const { 44294 code, 44295 shiftKey 44296 } = event; 44297 if (!["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight"].includes(code)) { 44298 return; 44299 } 44300 event.preventDefault(); 44301 const value = { 44302 x: x2, 44303 y: y3 44304 }; 44305 const step = shiftKey ? 0.1 : 0.01; 44306 const delta = code === "ArrowUp" || code === "ArrowLeft" ? -1 * step : step; 44307 const axis = code === "ArrowUp" || code === "ArrowDown" ? "y" : "x"; 44308 value[axis] = value[axis] + delta; 44309 onChange?.(getFinalValue(value)); 44310 }; 44311 const focalPointPosition = { 44312 left: x2 !== void 0 ? x2 * bounds.width : 0.5 * bounds.width, 44313 top: y3 !== void 0 ? y3 * bounds.height : 0.5 * bounds.height 44314 }; 44315 const classes = clsx_default("components-focal-point-picker-control", className2); 44316 const Label4 = hideLabelFromVision ? component_default2 : StyledLabel; 44317 use_update_effect_default(() => { 44318 setShowGridOverlay(true); 44319 const timeout = window.setTimeout(() => { 44320 setShowGridOverlay(false); 44321 }, GRID_OVERLAY_TIMEOUT); 44322 return () => window.clearTimeout(timeout); 44323 }, [x2, y3]); 44324 return /* @__PURE__ */ (0, import_jsx_runtime212.jsxs)(Container2, { 44325 ...restProps, 44326 as: "fieldset", 44327 className: classes, 44328 children: [!!label && /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(Label4, { 44329 as: "legend", 44330 children: label 44331 }), /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(MediaWrapper, { 44332 className: "components-focal-point-picker-wrapper", 44333 children: /* @__PURE__ */ (0, import_jsx_runtime212.jsxs)(MediaContainer, { 44334 className: "components-focal-point-picker", 44335 onKeyDown: arrowKeyStep, 44336 onMouseDown: startDrag, 44337 onBlur: () => { 44338 if (isDragging2) { 44339 endDrag(); 44340 } 44341 }, 44342 ref: dragAreaRef, 44343 role: "button", 44344 tabIndex: -1, 44345 children: [/* @__PURE__ */ (0, import_jsx_runtime212.jsx)(FocalPointPickerGrid, { 44346 bounds, 44347 showOverlay: showGridOverlay 44348 }), /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(Media2, { 44349 alt: (0, import_i18n51.__)("Media preview"), 44350 autoPlay, 44351 onLoad: refUpdateBounds.current, 44352 src: url 44353 }), /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(FocalPoint, { 44354 ...focalPointPosition, 44355 isDragging: isDragging2 44356 })] 44357 }) 44358 }), /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(FocalPointPickerControls, { 44359 hasHelpText: !!help, 44360 point: { 44361 x: x2, 44362 y: y3 44363 }, 44364 onChange: (value) => { 44365 onChange?.(getFinalValue(value)); 44366 } 44367 }), !!help && /* @__PURE__ */ (0, import_jsx_runtime212.jsx)(StyledHelp, { 44368 children: help 44369 })] 44370 }); 44371 } 44372 var focal_point_picker_default = FocalPointPicker; 44373 44374 // packages/components/build-module/focusable-iframe/index.js 44375 var import_compose58 = __toESM(require_compose()); 44376 var import_deprecated16 = __toESM(require_deprecated()); 44377 var import_jsx_runtime213 = __toESM(require_jsx_runtime()); 44378 function FocusableIframe({ 44379 iframeRef, 44380 ...props 44381 }) { 44382 const ref = (0, import_compose58.useMergeRefs)([iframeRef, (0, import_compose58.useFocusableIframe)()]); 44383 (0, import_deprecated16.default)("wp.components.FocusableIframe", { 44384 since: "5.9", 44385 alternative: "wp.compose.useFocusableIframe" 44386 }); 44387 return /* @__PURE__ */ (0, import_jsx_runtime213.jsx)("iframe", { 44388 ref, 44389 ...props 44390 }); 44391 } 44392 44393 // packages/components/build-module/font-size-picker/index.js 44394 var import_i18n55 = __toESM(require_i18n()); 44395 var import_element141 = __toESM(require_element()); 44396 var import_compose59 = __toESM(require_compose()); 44397 44398 // packages/components/build-module/font-size-picker/styles.js 44399 function _EMOTION_STRINGIFIED_CSS_ERROR__33() { 44400 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 44401 } 44402 var Container3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("fieldset", false ? { 44403 target: "e8tqeku4" 44404 } : { 44405 target: "e8tqeku4", 44406 label: "Container" 44407 })(false ? { 44408 name: "k2q51s", 44409 styles: "border:0;margin:0;padding:0;display:contents" 44410 } : { 44411 name: "k2q51s", 44412 styles: "border:0;margin:0;padding:0;display:contents", 44413 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjd0MiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgQmFzZUNvbnRyb2wgZnJvbSAnLi4vYmFzZS1jb250cm9sJztcbmltcG9ydCBCdXR0b24gZnJvbSAnLi4vYnV0dG9uJztcbmltcG9ydCBDdXN0b21TZWxlY3RDb250cm9sIGZyb20gJy4uL2N1c3RvbS1zZWxlY3QtY29udHJvbCc7XG5pbXBvcnQgeyBIU3RhY2sgfSBmcm9tICcuLi9oLXN0YWNrJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmZpZWxkc2V0YFxuXHRib3JkZXI6IDA7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogMDtcblx0ZGlzcGxheTogY29udGVudHM7XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyID0gc3R5bGVkKCBIU3RhY2sgKWBcblx0aGVpZ2h0OiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyVG9nZ2xlID0gc3R5bGVkKCBCdXR0b24gKWBcblx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIC0xICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJMYWJlbCA9IHN0eWxlZCggQmFzZUNvbnRyb2wuVmlzdWFsTGFiZWwgKWBcblx0ZGlzcGxheTogZmxleDtcblx0Z2FwOiAkeyBzcGFjZSggMSApIH07XG5cdGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcblx0bWFyZ2luLWJvdHRvbTogMDtcbmA7XG5cbi8vIEN1c3RvbSBzdHlsZWQgY29tcG9uZW50IHRvIGZvcmNlIGxpbmUgYnJlYWsgYmV0d2VlbiBuYW1lIGFuZCBoaW50IHdoaWxlIGtlZXBpbmcgY2hlY2ttYXJrIG9uIHRoZSByaWdodFxuZXhwb3J0IGNvbnN0IFN0eWxlZEN1c3RvbVNlbGVjdENvbnRyb2wgPSBzdHlsZWQoIEN1c3RvbVNlbGVjdENvbnRyb2wgKWBcblx0LmNvbXBvbmVudHMtY3VzdG9tLXNlbGVjdC1jb250cm9sX19pdGVtXG5cdFx0LmNvbXBvbmVudHMtY3VzdG9tLXNlbGVjdC1jb250cm9sX19pdGVtLWhpbnQge1xuXHRcdHdpZHRoOiAxMDAlO1xuXHR9XG5gO1xuIl19 */", 44414 toString: _EMOTION_STRINGIFIED_CSS_ERROR__33 44415 }); 44416 var Header2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default9, false ? { 44417 target: "e8tqeku3" 44418 } : { 44419 target: "e8tqeku3", 44420 label: "Header" 44421 })("height:", space(4), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnNDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJhc2VDb250cm9sIGZyb20gJy4uL2Jhc2UtY29udHJvbCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uL2J1dHRvbic7XG5pbXBvcnQgQ3VzdG9tU2VsZWN0Q29udHJvbCBmcm9tICcuLi9jdXN0b20tc2VsZWN0LWNvbnRyb2wnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDA7XG5cdHBhZGRpbmc6IDA7XG5cdGRpc3BsYXk6IGNvbnRlbnRzO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlclRvZ2dsZSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyTGFiZWwgPSBzdHlsZWQoIEJhc2VDb250cm9sLlZpc3VhbExhYmVsIClgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGdhcDogJHsgc3BhY2UoIDEgKSB9O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG4vLyBDdXN0b20gc3R5bGVkIGNvbXBvbmVudCB0byBmb3JjZSBsaW5lIGJyZWFrIGJldHdlZW4gbmFtZSBhbmQgaGludCB3aGlsZSBrZWVwaW5nIGNoZWNrbWFyayBvbiB0aGUgcmlnaHRcbmV4cG9ydCBjb25zdCBTdHlsZWRDdXN0b21TZWxlY3RDb250cm9sID0gc3R5bGVkKCBDdXN0b21TZWxlY3RDb250cm9sIClgXG5cdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbVxuXHRcdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbS1oaW50IHtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcbiJdfQ== */")); 44422 var HeaderToggle = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 44423 target: "e8tqeku2" 44424 } : { 44425 target: "e8tqeku2", 44426 label: "HeaderToggle" 44427 })("margin-top:", space(-1), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QjRDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJhc2VDb250cm9sIGZyb20gJy4uL2Jhc2UtY29udHJvbCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uL2J1dHRvbic7XG5pbXBvcnQgQ3VzdG9tU2VsZWN0Q29udHJvbCBmcm9tICcuLi9jdXN0b20tc2VsZWN0LWNvbnRyb2wnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDA7XG5cdHBhZGRpbmc6IDA7XG5cdGRpc3BsYXk6IGNvbnRlbnRzO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlclRvZ2dsZSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyTGFiZWwgPSBzdHlsZWQoIEJhc2VDb250cm9sLlZpc3VhbExhYmVsIClgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGdhcDogJHsgc3BhY2UoIDEgKSB9O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG4vLyBDdXN0b20gc3R5bGVkIGNvbXBvbmVudCB0byBmb3JjZSBsaW5lIGJyZWFrIGJldHdlZW4gbmFtZSBhbmQgaGludCB3aGlsZSBrZWVwaW5nIGNoZWNrbWFyayBvbiB0aGUgcmlnaHRcbmV4cG9ydCBjb25zdCBTdHlsZWRDdXN0b21TZWxlY3RDb250cm9sID0gc3R5bGVkKCBDdXN0b21TZWxlY3RDb250cm9sIClgXG5cdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbVxuXHRcdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbS1oaW50IHtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcbiJdfQ== */")); 44428 var HeaderLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default(base_control_default.VisualLabel, false ? { 44429 target: "e8tqeku1" 44430 } : { 44431 target: "e8tqeku1", 44432 label: "HeaderLabel" 44433 })("display:flex;gap:", space(1), ";justify-content:flex-start;margin-bottom:0;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QjREIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJhc2VDb250cm9sIGZyb20gJy4uL2Jhc2UtY29udHJvbCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uL2J1dHRvbic7XG5pbXBvcnQgQ3VzdG9tU2VsZWN0Q29udHJvbCBmcm9tICcuLi9jdXN0b20tc2VsZWN0LWNvbnRyb2wnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDA7XG5cdHBhZGRpbmc6IDA7XG5cdGRpc3BsYXk6IGNvbnRlbnRzO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlclRvZ2dsZSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyTGFiZWwgPSBzdHlsZWQoIEJhc2VDb250cm9sLlZpc3VhbExhYmVsIClgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGdhcDogJHsgc3BhY2UoIDEgKSB9O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG4vLyBDdXN0b20gc3R5bGVkIGNvbXBvbmVudCB0byBmb3JjZSBsaW5lIGJyZWFrIGJldHdlZW4gbmFtZSBhbmQgaGludCB3aGlsZSBrZWVwaW5nIGNoZWNrbWFyayBvbiB0aGUgcmlnaHRcbmV4cG9ydCBjb25zdCBTdHlsZWRDdXN0b21TZWxlY3RDb250cm9sID0gc3R5bGVkKCBDdXN0b21TZWxlY3RDb250cm9sIClgXG5cdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbVxuXHRcdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbS1oaW50IHtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcbiJdfQ== */")); 44434 var StyledCustomSelectControl = /* @__PURE__ */ emotion_styled_base_browser_esm_default(custom_select_control_default, false ? { 44435 target: "e8tqeku0" 44436 } : { 44437 target: "e8tqeku0", 44438 label: "StyledCustomSelectControl" 44439 })(false ? { 44440 name: "anvx77", 44441 styles: ".components-custom-select-control__item .components-custom-select-control__item-hint{width:100%;}" 44442 } : { 44443 name: "anvx77", 44444 styles: ".components-custom-select-control__item .components-custom-select-control__item-hint{width:100%;}", 44445 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ3NFIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IEJhc2VDb250cm9sIGZyb20gJy4uL2Jhc2UtY29udHJvbCc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uL2J1dHRvbic7XG5pbXBvcnQgQ3VzdG9tU2VsZWN0Q29udHJvbCBmcm9tICcuLi9jdXN0b20tc2VsZWN0LWNvbnRyb2wnO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnLi4vaC1zdGFjayc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcblxuZXhwb3J0IGNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5maWVsZHNldGBcblx0Ym9yZGVyOiAwO1xuXHRtYXJnaW46IDA7XG5cdHBhZGRpbmc6IDA7XG5cdGRpc3BsYXk6IGNvbnRlbnRzO1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlciA9IHN0eWxlZCggSFN0YWNrIClgXG5cdGhlaWdodDogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IEhlYWRlclRvZ2dsZSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgSGVhZGVyTGFiZWwgPSBzdHlsZWQoIEJhc2VDb250cm9sLlZpc3VhbExhYmVsIClgXG5cdGRpc3BsYXk6IGZsZXg7XG5cdGdhcDogJHsgc3BhY2UoIDEgKSB9O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG4vLyBDdXN0b20gc3R5bGVkIGNvbXBvbmVudCB0byBmb3JjZSBsaW5lIGJyZWFrIGJldHdlZW4gbmFtZSBhbmQgaGludCB3aGlsZSBrZWVwaW5nIGNoZWNrbWFyayBvbiB0aGUgcmlnaHRcbmV4cG9ydCBjb25zdCBTdHlsZWRDdXN0b21TZWxlY3RDb250cm9sID0gc3R5bGVkKCBDdXN0b21TZWxlY3RDb250cm9sIClgXG5cdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbVxuXHRcdC5jb21wb25lbnRzLWN1c3RvbS1zZWxlY3QtY29udHJvbF9faXRlbS1oaW50IHtcblx0XHR3aWR0aDogMTAwJTtcblx0fVxuYDtcbiJdfQ== */", 44446 toString: _EMOTION_STRINGIFIED_CSS_ERROR__33 44447 }); 44448 44449 // packages/components/build-module/font-size-picker/font-size-picker-select.js 44450 var import_i18n52 = __toESM(require_i18n()); 44451 var import_element140 = __toESM(require_element()); 44452 44453 // packages/components/build-module/font-size-picker/utils.js 44454 function isSimpleCssValue(value) { 44455 const sizeRegex = /^[\d\.]+(px|em|rem|vw|vh|%|svw|lvw|dvw|svh|lvh|dvh|vi|svi|lvi|dvi|vb|svb|lvb|dvb|vmin|svmin|lvmin|dvmin|vmax|svmax|lvmax|dvmax)?$/i; 44456 return sizeRegex.test(String(value)); 44457 } 44458 function generateFontSizeHint(fontSize) { 44459 if (fontSize.hint) { 44460 return fontSize.hint; 44461 } 44462 if (isSimpleCssValue(fontSize.size)) { 44463 return String(fontSize.size); 44464 } 44465 return void 0; 44466 } 44467 44468 // packages/components/build-module/font-size-picker/font-size-picker-select.js 44469 var import_jsx_runtime214 = __toESM(require_jsx_runtime()); 44470 var DEFAULT_OPTION = { 44471 key: "default", 44472 name: (0, import_i18n52.__)("Default"), 44473 value: void 0 44474 }; 44475 var FontSizePickerSelect = (props) => { 44476 const { 44477 __next40pxDefaultSize, 44478 fontSizes, 44479 value, 44480 size: size3, 44481 valueMode = "literal", 44482 onChange 44483 } = props; 44484 const options2 = [DEFAULT_OPTION, ...fontSizes.map((fontSize) => { 44485 const hint = generateFontSizeHint(fontSize); 44486 return { 44487 key: fontSize.slug, 44488 name: fontSize.name || fontSize.slug, 44489 value: fontSize.size, 44490 hint 44491 }; 44492 })]; 44493 const selectedOption = (0, import_element140.useMemo)(() => { 44494 var _options$find; 44495 if (value === void 0) { 44496 return DEFAULT_OPTION; 44497 } 44498 if (valueMode === "slug") { 44499 const optionBySlug = options2.find((option) => option.key === value); 44500 if (optionBySlug) { 44501 return optionBySlug; 44502 } 44503 } 44504 return (_options$find = options2.find((option) => option.value === value)) !== null && _options$find !== void 0 ? _options$find : DEFAULT_OPTION; 44505 }, [value, valueMode, options2]); 44506 return /* @__PURE__ */ (0, import_jsx_runtime214.jsx)(StyledCustomSelectControl, { 44507 __next40pxDefaultSize, 44508 __shouldNotWarnDeprecated36pxSize: true, 44509 className: "components-font-size-picker__select", 44510 label: (0, import_i18n52.__)("Font size"), 44511 hideLabelFromVision: true, 44512 describedBy: (0, import_i18n52.sprintf)( 44513 // translators: %s: Currently selected font size. 44514 (0, import_i18n52.__)("Currently selected font size: %s"), 44515 selectedOption.name 44516 ), 44517 options: options2, 44518 value: selectedOption, 44519 showSelectedHint: true, 44520 onChange: ({ 44521 selectedItem 44522 }) => { 44523 const matchingFontSize = selectedItem.key === "default" ? void 0 : fontSizes.find((fontSize) => fontSize.slug === selectedItem.key); 44524 onChange(selectedItem.value, matchingFontSize); 44525 }, 44526 size: size3 44527 }); 44528 }; 44529 var font_size_picker_select_default = FontSizePickerSelect; 44530 44531 // packages/components/build-module/font-size-picker/font-size-picker-toggle-group.js 44532 var import_i18n54 = __toESM(require_i18n()); 44533 44534 // packages/components/build-module/font-size-picker/constants.js 44535 var import_i18n53 = __toESM(require_i18n()); 44536 var T_SHIRT_ABBREVIATIONS = [ 44537 /* translators: S stands for 'small' and is a size label. */ 44538 (0, import_i18n53.__)("S"), 44539 /* translators: M stands for 'medium' and is a size label. */ 44540 (0, import_i18n53.__)("M"), 44541 /* translators: L stands for 'large' and is a size label. */ 44542 (0, import_i18n53.__)("L"), 44543 /* translators: XL stands for 'extra large' and is a size label. */ 44544 (0, import_i18n53.__)("XL"), 44545 /* translators: XXL stands for 'extra extra large' and is a size label. */ 44546 (0, import_i18n53.__)("XXL") 44547 ]; 44548 var T_SHIRT_NAMES = [(0, import_i18n53.__)("Small"), (0, import_i18n53.__)("Medium"), (0, import_i18n53.__)("Large"), (0, import_i18n53.__)("Extra Large"), (0, import_i18n53.__)("Extra Extra Large")]; 44549 44550 // packages/components/build-module/font-size-picker/font-size-picker-toggle-group.js 44551 var import_jsx_runtime215 = __toESM(require_jsx_runtime()); 44552 var FontSizePickerToggleGroup = (props) => { 44553 const { 44554 fontSizes, 44555 value, 44556 valueMode = "literal", 44557 __next40pxDefaultSize, 44558 size: size3, 44559 onChange 44560 } = props; 44561 const currentValue = (() => { 44562 if (!value) { 44563 return void 0; 44564 } 44565 if (valueMode === "slug") { 44566 return String(value); 44567 } 44568 const matchingFontSizes = fontSizes.filter((fontSize) => fontSize.size === value); 44569 if (matchingFontSizes.length > 1) { 44570 return void 0; 44571 } 44572 const fontSizeBySize = fontSizes.find((fontSize) => fontSize.size === value); 44573 return fontSizeBySize?.slug; 44574 })(); 44575 return /* @__PURE__ */ (0, import_jsx_runtime215.jsx)(component_default12, { 44576 __next40pxDefaultSize, 44577 __shouldNotWarnDeprecated36pxSize: true, 44578 label: (0, import_i18n54.__)("Font size"), 44579 hideLabelFromVision: true, 44580 value: currentValue, 44581 onChange: (newSlug) => { 44582 if (newSlug === void 0) { 44583 onChange(void 0); 44584 } else { 44585 const selectedFontSize = fontSizes.find((fontSize) => fontSize.slug === String(newSlug)); 44586 if (selectedFontSize) { 44587 onChange(selectedFontSize.size, selectedFontSize); 44588 } 44589 } 44590 }, 44591 isBlock: true, 44592 size: size3, 44593 children: fontSizes.map((fontSize, index2) => /* @__PURE__ */ (0, import_jsx_runtime215.jsx)(component_default14, { 44594 value: fontSize.slug, 44595 label: T_SHIRT_ABBREVIATIONS[index2], 44596 "aria-label": fontSize.name || T_SHIRT_NAMES[index2], 44597 showTooltip: true 44598 }, fontSize.slug)) 44599 }); 44600 }; 44601 var font_size_picker_toggle_group_default = FontSizePickerToggleGroup; 44602 44603 // packages/components/build-module/font-size-picker/index.js 44604 var import_jsx_runtime216 = __toESM(require_jsx_runtime()); 44605 var DEFAULT_UNITS = ["px", "em", "rem", "vw", "vh"]; 44606 var MAX_TOGGLE_GROUP_SIZES = 5; 44607 var UnforwardedFontSizePicker = (props, ref) => { 44608 const { 44609 __next40pxDefaultSize = false, 44610 fallbackFontSize, 44611 fontSizes = [], 44612 disableCustomFontSizes = false, 44613 onChange, 44614 size: size3 = "default", 44615 units: unitsProp = DEFAULT_UNITS, 44616 value, 44617 valueMode = "literal", 44618 withSlider = false, 44619 withReset = true 44620 } = props; 44621 const labelId = (0, import_compose59.useInstanceId)(UnforwardedFontSizePicker, "font-size-picker-label"); 44622 const units = useCustomUnits({ 44623 availableUnits: unitsProp 44624 }); 44625 const selectedFontSize = (() => { 44626 if (!value) { 44627 return void 0; 44628 } 44629 if (valueMode === "slug") { 44630 return fontSizes.find((fontSize) => fontSize.slug === value); 44631 } 44632 return fontSizes.find((fontSize) => fontSize.size === value); 44633 })(); 44634 const isCustomValue2 = !!value && !selectedFontSize; 44635 const [userRequestedCustom, setUserRequestedCustom] = (0, import_element141.useState)(isCustomValue2); 44636 const resolvedValueForControls = valueMode === "slug" ? selectedFontSize?.size : value; 44637 let currentPickerType; 44638 if (!disableCustomFontSizes && userRequestedCustom) { 44639 currentPickerType = "custom"; 44640 } else { 44641 currentPickerType = fontSizes.length > MAX_TOGGLE_GROUP_SIZES ? "select" : "togglegroup"; 44642 } 44643 if (fontSizes.length === 0 && disableCustomFontSizes) { 44644 return null; 44645 } 44646 const hasUnits2 = typeof resolvedValueForControls === "string" || typeof fontSizes[0]?.size === "string"; 44647 const [valueQuantity, valueUnit] = parseQuantityAndUnitFromRawValue(resolvedValueForControls, units); 44648 const isValueUnitRelative = !!valueUnit && ["em", "rem", "vw", "vh"].includes(valueUnit); 44649 const isDisabled = value === void 0; 44650 maybeWarnDeprecated36pxSize({ 44651 componentName: "FontSizePicker", 44652 __next40pxDefaultSize, 44653 size: size3 44654 }); 44655 return /* @__PURE__ */ (0, import_jsx_runtime216.jsxs)(Container3, { 44656 ref, 44657 className: "components-font-size-picker", 44658 "aria-labelledby": labelId, 44659 children: [/* @__PURE__ */ (0, import_jsx_runtime216.jsx)(component_default6, { 44660 children: /* @__PURE__ */ (0, import_jsx_runtime216.jsxs)(Header2, { 44661 className: "components-font-size-picker__header", 44662 children: [/* @__PURE__ */ (0, import_jsx_runtime216.jsx)(HeaderLabel, { 44663 id: labelId, 44664 children: (0, import_i18n55.__)("Font size") 44665 }), !disableCustomFontSizes && /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(HeaderToggle, { 44666 label: currentPickerType === "custom" ? (0, import_i18n55.__)("Use size preset") : (0, import_i18n55.__)("Set custom size"), 44667 icon: settings_default, 44668 onClick: () => setUserRequestedCustom(!userRequestedCustom), 44669 isPressed: currentPickerType === "custom", 44670 size: "small" 44671 })] 44672 }) 44673 }), /* @__PURE__ */ (0, import_jsx_runtime216.jsxs)("div", { 44674 children: [currentPickerType === "select" && /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(font_size_picker_select_default, { 44675 __next40pxDefaultSize, 44676 fontSizes, 44677 value, 44678 valueMode, 44679 disableCustomFontSizes, 44680 size: size3, 44681 onChange: (newValue, selectedItem) => { 44682 if (newValue === void 0) { 44683 onChange?.(void 0, selectedItem); 44684 } else { 44685 onChange?.(hasUnits2 ? newValue : Number(newValue), selectedItem); 44686 } 44687 }, 44688 onSelectCustom: () => setUserRequestedCustom(true) 44689 }), currentPickerType === "togglegroup" && /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(font_size_picker_toggle_group_default, { 44690 fontSizes, 44691 value, 44692 valueMode, 44693 __next40pxDefaultSize, 44694 size: size3, 44695 onChange: (newValue, selectedItem) => { 44696 if (newValue === void 0) { 44697 onChange?.(void 0, selectedItem); 44698 } else { 44699 onChange?.(hasUnits2 ? newValue : Number(newValue), selectedItem); 44700 } 44701 } 44702 }), currentPickerType === "custom" && /* @__PURE__ */ (0, import_jsx_runtime216.jsxs)(component_default3, { 44703 className: "components-font-size-picker__custom-size-control", 44704 children: [/* @__PURE__ */ (0, import_jsx_runtime216.jsx)(component_default4, { 44705 isBlock: true, 44706 children: /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(unit_control_default, { 44707 __next40pxDefaultSize, 44708 __shouldNotWarnDeprecated36pxSize: true, 44709 label: (0, import_i18n55.__)("Font size"), 44710 labelPosition: "top", 44711 hideLabelFromVision: true, 44712 value: hasUnits2 ? `$valueQuantity !== null && valueQuantity !== void 0 ? valueQuantity : ""}$valueUnit !== null && valueUnit !== void 0 ? valueUnit : ""}` : resolvedValueForControls, 44713 onChange: (newValue) => { 44714 setUserRequestedCustom(true); 44715 if (newValue === void 0 || newValue === "") { 44716 onChange?.(void 0); 44717 } else { 44718 onChange?.(hasUnits2 ? newValue : parseInt(newValue, 10)); 44719 } 44720 }, 44721 size: size3, 44722 units: hasUnits2 ? units : [], 44723 min: 0 44724 }) 44725 }), withSlider && /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(component_default4, { 44726 isBlock: true, 44727 children: /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(component_default6, { 44728 marginX: 2, 44729 marginBottom: 0, 44730 children: /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(range_control_default, { 44731 __next40pxDefaultSize, 44732 __shouldNotWarnDeprecated36pxSize: true, 44733 className: "components-font-size-picker__custom-input", 44734 label: (0, import_i18n55.__)("Font size"), 44735 hideLabelFromVision: true, 44736 value: valueQuantity, 44737 initialPosition: fallbackFontSize, 44738 withInputField: false, 44739 onChange: (newValue) => { 44740 setUserRequestedCustom(true); 44741 if (newValue === void 0) { 44742 onChange?.(void 0); 44743 } else if (hasUnits2) { 44744 onChange?.(newValue + (valueUnit !== null && valueUnit !== void 0 ? valueUnit : "px")); 44745 } else { 44746 onChange?.(newValue); 44747 } 44748 }, 44749 min: 0, 44750 max: isValueUnitRelative ? 10 : 100, 44751 step: isValueUnitRelative ? 0.1 : 1 44752 }) 44753 }) 44754 }), withReset && /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(component_default4, { 44755 children: /* @__PURE__ */ (0, import_jsx_runtime216.jsx)(Button3, { 44756 disabled: isDisabled, 44757 accessibleWhenDisabled: true, 44758 onClick: () => { 44759 onChange?.(void 0); 44760 }, 44761 variant: "secondary", 44762 __next40pxDefaultSize: true, 44763 size: size3 === "__unstable-large" || props.__next40pxDefaultSize ? "default" : "small", 44764 children: (0, import_i18n55.__)("Reset") 44765 }) 44766 })] 44767 })] 44768 })] 44769 }); 44770 }; 44771 var FontSizePicker = (0, import_element141.forwardRef)(UnforwardedFontSizePicker); 44772 var font_size_picker_default = FontSizePicker; 44773 44774 // packages/components/build-module/form-file-upload/index.js 44775 var import_element142 = __toESM(require_element()); 44776 var import_jsx_runtime217 = __toESM(require_jsx_runtime()); 44777 function FormFileUpload({ 44778 accept, 44779 children, 44780 multiple = false, 44781 onChange, 44782 onClick, 44783 render, 44784 ...props 44785 }) { 44786 const ref = (0, import_element142.useRef)(null); 44787 const openFileDialog = () => { 44788 ref.current?.click(); 44789 }; 44790 if (!render) { 44791 maybeWarnDeprecated36pxSize({ 44792 componentName: "FormFileUpload", 44793 __next40pxDefaultSize: props.__next40pxDefaultSize, 44794 // @ts-expect-error - We don't "officially" support all Button props but this likely happens. 44795 size: props.size 44796 }); 44797 } 44798 const ui = render ? render({ 44799 openFileDialog 44800 }) : /* @__PURE__ */ (0, import_jsx_runtime217.jsx)(button_default, { 44801 onClick: openFileDialog, 44802 ...props, 44803 children 44804 }); 44805 const compatAccept = accept?.includes("audio/*") ? `${accept}, audio/mp3, audio/x-m4a, audio/x-m4b, audio/x-m4p, audio/x-wav, audio/webm` : accept; 44806 return /* @__PURE__ */ (0, import_jsx_runtime217.jsxs)("div", { 44807 className: "components-form-file-upload", 44808 children: [ui, /* @__PURE__ */ (0, import_jsx_runtime217.jsx)("input", { 44809 type: "file", 44810 ref, 44811 multiple, 44812 style: { 44813 display: "none" 44814 }, 44815 accept: compatAccept, 44816 onChange, 44817 onClick, 44818 "data-testid": "form-file-upload-input" 44819 })] 44820 }); 44821 } 44822 var form_file_upload_default = FormFileUpload; 44823 44824 // packages/components/build-module/form-toggle/index.js 44825 var import_element143 = __toESM(require_element()); 44826 var import_jsx_runtime218 = __toESM(require_jsx_runtime()); 44827 var noop14 = () => { 44828 }; 44829 function UnforwardedFormToggle(props, ref) { 44830 const { 44831 className: className2, 44832 checked, 44833 id: id3, 44834 disabled, 44835 onChange = noop14, 44836 onClick, 44837 ...additionalProps 44838 } = props; 44839 const wrapperClasses = clsx_default("components-form-toggle", className2, { 44840 "is-checked": checked, 44841 "is-disabled": disabled 44842 }); 44843 return /* @__PURE__ */ (0, import_jsx_runtime218.jsxs)("span", { 44844 className: wrapperClasses, 44845 children: [/* @__PURE__ */ (0, import_jsx_runtime218.jsx)("input", { 44846 className: "components-form-toggle__input", 44847 id: id3, 44848 type: "checkbox", 44849 checked, 44850 onChange, 44851 disabled, 44852 onClick: (event) => { 44853 event.currentTarget.focus(); 44854 onClick?.(event); 44855 }, 44856 ...additionalProps, 44857 ref 44858 }), /* @__PURE__ */ (0, import_jsx_runtime218.jsx)("span", { 44859 className: "components-form-toggle__track" 44860 }), /* @__PURE__ */ (0, import_jsx_runtime218.jsx)("span", { 44861 className: "components-form-toggle__thumb" 44862 })] 44863 }); 44864 } 44865 var FormToggle = (0, import_element143.forwardRef)(UnforwardedFormToggle); 44866 var form_toggle_default = FormToggle; 44867 44868 // packages/components/build-module/form-token-field/index.js 44869 var import_element144 = __toESM(require_element()); 44870 var import_i18n57 = __toESM(require_i18n()); 44871 var import_compose61 = __toESM(require_compose()); 44872 var import_a11y6 = __toESM(require_a11y()); 44873 var import_is_shallow_equal2 = __toESM(require_is_shallow_equal()); 44874 44875 // packages/components/build-module/form-token-field/token.js 44876 var import_compose60 = __toESM(require_compose()); 44877 var import_i18n56 = __toESM(require_i18n()); 44878 var import_jsx_runtime219 = __toESM(require_jsx_runtime()); 44879 var noop15 = () => { 44880 }; 44881 function Token({ 44882 value, 44883 status, 44884 title, 44885 displayTransform, 44886 isBorderless = false, 44887 disabled = false, 44888 onClickRemove = noop15, 44889 onMouseEnter, 44890 onMouseLeave, 44891 messages, 44892 termPosition, 44893 termsCount 44894 }) { 44895 const instanceId = (0, import_compose60.useInstanceId)(Token); 44896 const tokenClasses = clsx_default("components-form-token-field__token", { 44897 "is-error": "error" === status, 44898 "is-success": "success" === status, 44899 "is-validating": "validating" === status, 44900 "is-borderless": isBorderless, 44901 "is-disabled": disabled 44902 }); 44903 const onClick = () => onClickRemove({ 44904 value 44905 }); 44906 const transformedValue = displayTransform(value); 44907 const termPositionAndCount = (0, import_i18n56.sprintf)( 44908 /* translators: 1: term name, 2: term position in a set of terms, 3: total term set count. */ 44909 (0, import_i18n56.__)("%1$s (%2$d of %3$d)"), 44910 transformedValue, 44911 termPosition, 44912 termsCount 44913 ); 44914 return /* @__PURE__ */ (0, import_jsx_runtime219.jsxs)("span", { 44915 className: tokenClasses, 44916 onMouseEnter, 44917 onMouseLeave, 44918 title, 44919 children: [/* @__PURE__ */ (0, import_jsx_runtime219.jsxs)("span", { 44920 className: "components-form-token-field__token-text", 44921 id: `components-form-token-field__token-text-$instanceId}`, 44922 children: [/* @__PURE__ */ (0, import_jsx_runtime219.jsx)(component_default2, { 44923 as: "span", 44924 children: termPositionAndCount 44925 }), /* @__PURE__ */ (0, import_jsx_runtime219.jsx)("span", { 44926 "aria-hidden": "true", 44927 children: transformedValue 44928 })] 44929 }), /* @__PURE__ */ (0, import_jsx_runtime219.jsx)(button_default, { 44930 className: "components-form-token-field__remove-token", 44931 size: "small", 44932 icon: close_small_default, 44933 onClick: !disabled ? onClick : void 0, 44934 disabled, 44935 label: messages.remove, 44936 "aria-describedby": `components-form-token-field__token-text-$instanceId}` 44937 })] 44938 }); 44939 } 44940 44941 // packages/components/build-module/form-token-field/styles.js 44942 var deprecatedPaddings = ({ 44943 __next40pxDefaultSize, 44944 hasTokens 44945 }) => !__next40pxDefaultSize && /* @__PURE__ */ css("padding-top:", space(hasTokens ? 1 : 0.5), ";padding-bottom:", space(hasTokens ? 1 : 0.5), ";" + (false ? "" : ";label:deprecatedPaddings;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QkkiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBGbGV4IH0gZnJvbSAnLi4vZmxleCc7XG5pbXBvcnQgeyBzcGFjZSB9IGZyb20gJy4uL3V0aWxzL3NwYWNlJztcbmltcG9ydCB7IGJveFNpemluZ1Jlc2V0IH0gZnJvbSAnLi4vdXRpbHMnO1xuXG50eXBlIFRva2Vuc0FuZElucHV0V3JhcHBlclByb3BzID0ge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemU6IGJvb2xlYW47XG5cdGhhc1Rva2VuczogYm9vbGVhbjtcbn07XG5cbmNvbnN0IGRlcHJlY2F0ZWRQYWRkaW5ncyA9ICgge1xuXHRfX25leHQ0MHB4RGVmYXVsdFNpemUsXG5cdGhhc1Rva2Vucyxcbn06IFRva2Vuc0FuZElucHV0V3JhcHBlclByb3BzICkgPT5cblx0ISBfX25leHQ0MHB4RGVmYXVsdFNpemUgJiZcblx0Y3NzYFxuXHRcdHBhZGRpbmctdG9wOiAkeyBzcGFjZSggaGFzVG9rZW5zID8gMSA6IDAuNSApIH07XG5cdFx0cGFkZGluZy1ib3R0b206ICR7IHNwYWNlKCBoYXNUb2tlbnMgPyAxIDogMC41ICkgfTtcblx0YDtcblxuZXhwb3J0IGNvbnN0IFRva2Vuc0FuZElucHV0V3JhcHBlckZsZXggPSBzdHlsZWQoIEZsZXggKWBcblx0cGFkZGluZzogN3B4O1xuXHQkeyBib3hTaXppbmdSZXNldCB9XG5cblx0JHsgZGVwcmVjYXRlZFBhZGRpbmdzIH1cbmA7XG4iXX0= */"); 44946 var TokensAndInputWrapperFlex = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default3, false ? { 44947 target: "ehq8nmi0" 44948 } : { 44949 target: "ehq8nmi0", 44950 label: "TokensAndInputWrapperFlex" 44951 })("padding:7px;", boxSizingReset, " ", deprecatedPaddings, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QnVEIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgRmxleCB9IGZyb20gJy4uL2ZsZXgnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5pbXBvcnQgeyBib3hTaXppbmdSZXNldCB9IGZyb20gJy4uL3V0aWxzJztcblxudHlwZSBUb2tlbnNBbmRJbnB1dFdyYXBwZXJQcm9wcyA9IHtcblx0X19uZXh0NDBweERlZmF1bHRTaXplOiBib29sZWFuO1xuXHRoYXNUb2tlbnM6IGJvb2xlYW47XG59O1xuXG5jb25zdCBkZXByZWNhdGVkUGFkZGluZ3MgPSAoIHtcblx0X19uZXh0NDBweERlZmF1bHRTaXplLFxuXHRoYXNUb2tlbnMsXG59OiBUb2tlbnNBbmRJbnB1dFdyYXBwZXJQcm9wcyApID0+XG5cdCEgX19uZXh0NDBweERlZmF1bHRTaXplICYmXG5cdGNzc2Bcblx0XHRwYWRkaW5nLXRvcDogJHsgc3BhY2UoIGhhc1Rva2VucyA/IDEgOiAwLjUgKSB9O1xuXHRcdHBhZGRpbmctYm90dG9tOiAkeyBzcGFjZSggaGFzVG9rZW5zID8gMSA6IDAuNSApIH07XG5cdGA7XG5cbmV4cG9ydCBjb25zdCBUb2tlbnNBbmRJbnB1dFdyYXBwZXJGbGV4ID0gc3R5bGVkKCBGbGV4IClgXG5cdHBhZGRpbmc6IDdweDtcblx0JHsgYm94U2l6aW5nUmVzZXQgfVxuXG5cdCR7IGRlcHJlY2F0ZWRQYWRkaW5ncyB9XG5gO1xuIl19 */")); 44952 44953 // packages/components/build-module/form-token-field/index.js 44954 var import_jsx_runtime220 = __toESM(require_jsx_runtime()); 44955 var identity3 = (value) => value; 44956 function FormTokenField(props) { 44957 const { 44958 autoCapitalize, 44959 autoComplete, 44960 maxLength, 44961 placeholder, 44962 label = (0, import_i18n57.__)("Add item"), 44963 className: className2, 44964 suggestions = [], 44965 maxSuggestions = 100, 44966 value = [], 44967 displayTransform = identity3, 44968 saveTransform = (token2) => token2.trim(), 44969 onChange = () => { 44970 }, 44971 onInputChange = () => { 44972 }, 44973 onFocus = void 0, 44974 isBorderless = false, 44975 disabled = false, 44976 tokenizeOnSpace = false, 44977 messages = { 44978 added: (0, import_i18n57.__)("Item added."), 44979 removed: (0, import_i18n57.__)("Item removed."), 44980 remove: (0, import_i18n57.__)("Remove item"), 44981 __experimentalInvalid: (0, import_i18n57.__)("Invalid item") 44982 }, 44983 __experimentalRenderItem, 44984 __experimentalExpandOnFocus = false, 44985 __experimentalValidateInput = () => true, 44986 __experimentalShowHowTo = true, 44987 __next40pxDefaultSize = false, 44988 __experimentalAutoSelectFirstMatch = false, 44989 tokenizeOnBlur = false 44990 } = useDeprecated36pxDefaultSizeProp(props); 44991 maybeWarnDeprecated36pxSize({ 44992 componentName: "FormTokenField", 44993 size: void 0, 44994 __next40pxDefaultSize 44995 }); 44996 const instanceId = (0, import_compose61.useInstanceId)(FormTokenField); 44997 const [incompleteTokenValue, setIncompleteTokenValue] = (0, import_element144.useState)(""); 44998 const [inputOffsetFromEnd, setInputOffsetFromEnd] = (0, import_element144.useState)(0); 44999 const [isActive, setIsActive] = (0, import_element144.useState)(false); 45000 const [isExpanded, setIsExpanded] = (0, import_element144.useState)(false); 45001 const [selectedSuggestionIndex, setSelectedSuggestionIndex] = (0, import_element144.useState)(-1); 45002 const [selectedSuggestionScroll, setSelectedSuggestionScroll] = (0, import_element144.useState)(false); 45003 const prevSuggestions = (0, import_compose61.usePrevious)(suggestions); 45004 const prevValue = (0, import_compose61.usePrevious)(value); 45005 const input = (0, import_element144.useRef)(null); 45006 const tokensAndInput = (0, import_element144.useRef)(null); 45007 const debouncedSpeak = (0, import_compose61.useDebounce)(import_a11y6.speak, 500); 45008 (0, import_element144.useEffect)(() => { 45009 if (isActive && !hasFocus2()) { 45010 focus4(); 45011 } 45012 }, [isActive]); 45013 (0, import_element144.useEffect)(() => { 45014 const suggestionsDidUpdate = !(0, import_is_shallow_equal2.default)(suggestions, prevSuggestions || []); 45015 if (suggestionsDidUpdate || value !== prevValue) { 45016 updateSuggestions(suggestionsDidUpdate); 45017 } 45018 }, [suggestions, prevSuggestions, value, prevValue]); 45019 (0, import_element144.useEffect)(() => { 45020 updateSuggestions(); 45021 }, [incompleteTokenValue]); 45022 (0, import_element144.useEffect)(() => { 45023 updateSuggestions(); 45024 }, [__experimentalAutoSelectFirstMatch]); 45025 if (disabled && isActive) { 45026 setIsActive(false); 45027 setIncompleteTokenValue(""); 45028 } 45029 function focus4() { 45030 input.current?.focus(); 45031 } 45032 function hasFocus2() { 45033 return input.current === input.current?.ownerDocument.activeElement; 45034 } 45035 function onFocusHandler(event) { 45036 if (hasFocus2() || event.target === tokensAndInput.current) { 45037 setIsActive(true); 45038 setIsExpanded(__experimentalExpandOnFocus || isExpanded); 45039 } else { 45040 setIsActive(false); 45041 } 45042 if ("function" === typeof onFocus) { 45043 onFocus(event); 45044 } 45045 } 45046 function onBlur(event) { 45047 if (inputHasValidValue() && __experimentalValidateInput(incompleteTokenValue)) { 45048 setIsActive(false); 45049 if (tokenizeOnBlur && inputHasValidValue()) { 45050 addNewToken(incompleteTokenValue); 45051 } 45052 } else { 45053 setIncompleteTokenValue(""); 45054 setInputOffsetFromEnd(0); 45055 setIsActive(false); 45056 if (__experimentalExpandOnFocus) { 45057 const hasFocusWithin2 = event.relatedTarget === tokensAndInput.current; 45058 setIsExpanded(hasFocusWithin2); 45059 } else { 45060 setIsExpanded(false); 45061 } 45062 setSelectedSuggestionIndex(-1); 45063 setSelectedSuggestionScroll(false); 45064 } 45065 } 45066 function onKeyDown(event) { 45067 let preventDefault = false; 45068 if (event.defaultPrevented) { 45069 return; 45070 } 45071 switch (event.key) { 45072 case "Backspace": 45073 preventDefault = handleDeleteKey(deleteTokenBeforeInput); 45074 break; 45075 case "Enter": 45076 preventDefault = addCurrentToken(); 45077 break; 45078 case "ArrowLeft": 45079 preventDefault = handleLeftArrowKey(); 45080 break; 45081 case "ArrowUp": 45082 preventDefault = handleUpArrowKey(); 45083 break; 45084 case "ArrowRight": 45085 preventDefault = handleRightArrowKey(); 45086 break; 45087 case "ArrowDown": 45088 preventDefault = handleDownArrowKey(); 45089 break; 45090 case "Delete": 45091 preventDefault = handleDeleteKey(deleteTokenAfterInput); 45092 break; 45093 case "Space": 45094 if (tokenizeOnSpace) { 45095 preventDefault = addCurrentToken(); 45096 } 45097 break; 45098 case "Escape": 45099 preventDefault = handleEscapeKey(event); 45100 break; 45101 case "Tab": 45102 preventDefault = handleTabKey(event); 45103 break; 45104 default: 45105 break; 45106 } 45107 if (preventDefault) { 45108 event.preventDefault(); 45109 } 45110 } 45111 function onKeyPress(event) { 45112 let preventDefault = false; 45113 switch (event.key) { 45114 case ",": 45115 preventDefault = handleCommaKey(); 45116 break; 45117 default: 45118 break; 45119 } 45120 if (preventDefault) { 45121 event.preventDefault(); 45122 } 45123 } 45124 function onContainerTouched(event) { 45125 if (event.target === tokensAndInput.current && isActive) { 45126 event.preventDefault(); 45127 } 45128 } 45129 function onTokenClickRemove(event) { 45130 deleteToken(event.value); 45131 focus4(); 45132 } 45133 function onSuggestionHovered(suggestion) { 45134 const index2 = getMatchingSuggestions().indexOf(suggestion); 45135 if (index2 >= 0) { 45136 setSelectedSuggestionIndex(index2); 45137 setSelectedSuggestionScroll(false); 45138 } 45139 } 45140 function onSuggestionSelected(suggestion) { 45141 addNewToken(suggestion); 45142 } 45143 function onInputChangeHandler(event) { 45144 const text = event.value; 45145 const separator = tokenizeOnSpace ? /[ ,\t]+/ : /[,\t]+/; 45146 const items = text.split(separator); 45147 const tokenValue = items[items.length - 1] || ""; 45148 if (items.length > 1) { 45149 addNewTokens(items.slice(0, -1)); 45150 } 45151 setIncompleteTokenValue(tokenValue); 45152 onInputChange(tokenValue); 45153 } 45154 function handleDeleteKey(_deleteToken) { 45155 let preventDefault = false; 45156 if (hasFocus2() && isInputEmpty()) { 45157 _deleteToken(); 45158 preventDefault = true; 45159 } 45160 return preventDefault; 45161 } 45162 function handleLeftArrowKey() { 45163 let preventDefault = false; 45164 if (isInputEmpty()) { 45165 moveInputBeforePreviousToken(); 45166 preventDefault = true; 45167 } 45168 return preventDefault; 45169 } 45170 function handleRightArrowKey() { 45171 let preventDefault = false; 45172 if (isInputEmpty()) { 45173 moveInputAfterNextToken(); 45174 preventDefault = true; 45175 } 45176 return preventDefault; 45177 } 45178 function handleUpArrowKey() { 45179 setSelectedSuggestionIndex((index2) => { 45180 return (index2 === 0 ? getMatchingSuggestions(incompleteTokenValue, suggestions, value, maxSuggestions, saveTransform).length : index2) - 1; 45181 }); 45182 setSelectedSuggestionScroll(true); 45183 return true; 45184 } 45185 function handleDownArrowKey() { 45186 setSelectedSuggestionIndex((index2) => { 45187 return (index2 + 1) % getMatchingSuggestions(incompleteTokenValue, suggestions, value, maxSuggestions, saveTransform).length; 45188 }); 45189 setSelectedSuggestionScroll(true); 45190 return true; 45191 } 45192 function collapseSuggestionsList(event) { 45193 if (event.target instanceof HTMLInputElement) { 45194 setIncompleteTokenValue(event.target.value); 45195 setIsExpanded(false); 45196 setSelectedSuggestionIndex(-1); 45197 setSelectedSuggestionScroll(false); 45198 } 45199 } 45200 function handleEscapeKey(event) { 45201 collapseSuggestionsList(event); 45202 return true; 45203 } 45204 function handleTabKey(event) { 45205 collapseSuggestionsList(event); 45206 return false; 45207 } 45208 function handleCommaKey() { 45209 if (inputHasValidValue()) { 45210 addNewToken(incompleteTokenValue); 45211 } 45212 return true; 45213 } 45214 function moveInputToIndex(index2) { 45215 setInputOffsetFromEnd(value.length - Math.max(index2, -1) - 1); 45216 } 45217 function moveInputBeforePreviousToken() { 45218 setInputOffsetFromEnd((prevInputOffsetFromEnd) => { 45219 return Math.min(prevInputOffsetFromEnd + 1, value.length); 45220 }); 45221 } 45222 function moveInputAfterNextToken() { 45223 setInputOffsetFromEnd((prevInputOffsetFromEnd) => { 45224 return Math.max(prevInputOffsetFromEnd - 1, 0); 45225 }); 45226 } 45227 function deleteTokenBeforeInput() { 45228 const index2 = getIndexOfInput() - 1; 45229 if (index2 > -1) { 45230 deleteToken(value[index2]); 45231 } 45232 } 45233 function deleteTokenAfterInput() { 45234 const index2 = getIndexOfInput(); 45235 if (index2 < value.length) { 45236 deleteToken(value[index2]); 45237 moveInputToIndex(index2); 45238 } 45239 } 45240 function addCurrentToken() { 45241 let preventDefault = false; 45242 const selectedSuggestion = getSelectedSuggestion(); 45243 if (selectedSuggestion) { 45244 addNewToken(selectedSuggestion); 45245 preventDefault = true; 45246 } else if (inputHasValidValue()) { 45247 addNewToken(incompleteTokenValue); 45248 preventDefault = true; 45249 } 45250 return preventDefault; 45251 } 45252 function addNewTokens(tokens) { 45253 const tokensToAdd = [...new Set(tokens.map(saveTransform).filter(Boolean).filter((token2) => !valueContainsToken(token2)))]; 45254 if (tokensToAdd.length > 0) { 45255 const newValue = [...value]; 45256 newValue.splice(getIndexOfInput(), 0, ...tokensToAdd); 45257 onChange(newValue); 45258 } 45259 } 45260 function addNewToken(token2) { 45261 if (!__experimentalValidateInput(token2)) { 45262 (0, import_a11y6.speak)(messages.__experimentalInvalid, "assertive"); 45263 return; 45264 } 45265 addNewTokens([token2]); 45266 (0, import_a11y6.speak)(messages.added, "assertive"); 45267 setIncompleteTokenValue(""); 45268 setSelectedSuggestionIndex(-1); 45269 setSelectedSuggestionScroll(false); 45270 setIsExpanded(!__experimentalExpandOnFocus); 45271 if (isActive && !tokenizeOnBlur) { 45272 focus4(); 45273 } 45274 } 45275 function deleteToken(token2) { 45276 const newTokens = value.filter((item2) => { 45277 return getTokenValue(item2) !== getTokenValue(token2); 45278 }); 45279 onChange(newTokens); 45280 (0, import_a11y6.speak)(messages.removed, "assertive"); 45281 } 45282 function getTokenValue(token2) { 45283 if ("object" === typeof token2) { 45284 return token2.value; 45285 } 45286 return token2; 45287 } 45288 function getMatchingSuggestions(searchValue = incompleteTokenValue, _suggestions = suggestions, _value = value, _maxSuggestions = maxSuggestions, _saveTransform = saveTransform) { 45289 let match5 = _saveTransform(searchValue); 45290 const startsWithMatch = []; 45291 const containsMatch = []; 45292 const normalizedValue = _value.map((item2) => { 45293 if (typeof item2 === "string") { 45294 return item2; 45295 } 45296 return item2.value; 45297 }); 45298 if (match5.length === 0) { 45299 _suggestions = _suggestions.filter((suggestion) => !normalizedValue.includes(suggestion)); 45300 } else { 45301 match5 = match5.normalize("NFKC").toLocaleLowerCase(); 45302 _suggestions.forEach((suggestion) => { 45303 const index2 = suggestion.normalize("NFKC").toLocaleLowerCase().indexOf(match5); 45304 if (normalizedValue.indexOf(suggestion) === -1) { 45305 if (index2 === 0) { 45306 startsWithMatch.push(suggestion); 45307 } else if (index2 > 0) { 45308 containsMatch.push(suggestion); 45309 } 45310 } 45311 }); 45312 _suggestions = startsWithMatch.concat(containsMatch); 45313 } 45314 return _suggestions.slice(0, _maxSuggestions); 45315 } 45316 function getSelectedSuggestion() { 45317 if (selectedSuggestionIndex !== -1) { 45318 return getMatchingSuggestions()[selectedSuggestionIndex]; 45319 } 45320 return void 0; 45321 } 45322 function valueContainsToken(token2) { 45323 return value.some((item2) => { 45324 return getTokenValue(token2) === getTokenValue(item2); 45325 }); 45326 } 45327 function getIndexOfInput() { 45328 return value.length - inputOffsetFromEnd; 45329 } 45330 function isInputEmpty() { 45331 return incompleteTokenValue.length === 0; 45332 } 45333 function inputHasValidValue() { 45334 return saveTransform(incompleteTokenValue).length > 0; 45335 } 45336 function updateSuggestions(resetSelectedSuggestion = true) { 45337 const inputHasMinimumChars = incompleteTokenValue.trim().length > 1; 45338 const matchingSuggestions2 = getMatchingSuggestions(incompleteTokenValue); 45339 const hasMatchingSuggestions = matchingSuggestions2.length > 0; 45340 const shouldExpandIfFocuses = hasFocus2() && __experimentalExpandOnFocus; 45341 setIsExpanded(shouldExpandIfFocuses || inputHasMinimumChars && hasMatchingSuggestions); 45342 if (resetSelectedSuggestion) { 45343 if (__experimentalAutoSelectFirstMatch && inputHasMinimumChars && hasMatchingSuggestions) { 45344 setSelectedSuggestionIndex(0); 45345 setSelectedSuggestionScroll(true); 45346 } else { 45347 setSelectedSuggestionIndex(-1); 45348 setSelectedSuggestionScroll(false); 45349 } 45350 } 45351 if (inputHasMinimumChars) { 45352 const message3 = hasMatchingSuggestions ? (0, import_i18n57.sprintf)( 45353 /* translators: %d: number of results. */ 45354 (0, import_i18n57._n)("%d result found, use up and down arrow keys to navigate.", "%d results found, use up and down arrow keys to navigate.", matchingSuggestions2.length), 45355 matchingSuggestions2.length 45356 ) : (0, import_i18n57.__)("No results."); 45357 debouncedSpeak(message3, "assertive"); 45358 } 45359 } 45360 function renderTokensAndInput() { 45361 const components = value.map(renderToken); 45362 components.splice(getIndexOfInput(), 0, renderInput()); 45363 return components; 45364 } 45365 function renderToken(token2, index2, tokens) { 45366 const _value = getTokenValue(token2); 45367 const status = typeof token2 !== "string" ? token2.status : void 0; 45368 const termPosition = index2 + 1; 45369 const termsCount = tokens.length; 45370 return /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(component_default4, { 45371 children: /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(Token, { 45372 value: _value, 45373 status, 45374 title: typeof token2 !== "string" ? token2.title : void 0, 45375 displayTransform, 45376 onClickRemove: onTokenClickRemove, 45377 isBorderless: typeof token2 !== "string" && token2.isBorderless || isBorderless, 45378 onMouseEnter: typeof token2 !== "string" ? token2.onMouseEnter : void 0, 45379 onMouseLeave: typeof token2 !== "string" ? token2.onMouseLeave : void 0, 45380 disabled: "error" !== status && disabled, 45381 messages, 45382 termsCount, 45383 termPosition 45384 }) 45385 }, "token-" + _value); 45386 } 45387 function renderInput() { 45388 const inputProps = { 45389 instanceId, 45390 autoCapitalize, 45391 autoComplete, 45392 placeholder: value.length === 0 ? placeholder : "", 45393 disabled, 45394 value: incompleteTokenValue, 45395 onBlur, 45396 isExpanded, 45397 selectedSuggestionIndex 45398 }; 45399 return /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(token_input_default, { 45400 ...inputProps, 45401 onChange: !(maxLength && value.length >= maxLength) ? onInputChangeHandler : void 0, 45402 ref: input 45403 }, "input"); 45404 } 45405 const classes = clsx_default(className2, "components-form-token-field__input-container", { 45406 "is-active": isActive, 45407 "is-disabled": disabled 45408 }); 45409 let tokenFieldProps = { 45410 className: "components-form-token-field", 45411 tabIndex: -1 45412 }; 45413 const matchingSuggestions = getMatchingSuggestions(); 45414 if (!disabled) { 45415 tokenFieldProps = Object.assign({}, tokenFieldProps, { 45416 onKeyDown: withIgnoreIMEEvents(onKeyDown), 45417 onKeyPress, 45418 onFocus: onFocusHandler 45419 }); 45420 } 45421 return /* @__PURE__ */ (0, import_jsx_runtime220.jsxs)("div", { 45422 ...tokenFieldProps, 45423 children: [label && /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(StyledLabel, { 45424 htmlFor: `components-form-token-input-$instanceId}`, 45425 className: "components-form-token-field__label", 45426 children: label 45427 }), /* @__PURE__ */ (0, import_jsx_runtime220.jsxs)("div", { 45428 ref: tokensAndInput, 45429 className: classes, 45430 tabIndex: -1, 45431 onMouseDown: onContainerTouched, 45432 onTouchStart: onContainerTouched, 45433 children: [/* @__PURE__ */ (0, import_jsx_runtime220.jsx)(TokensAndInputWrapperFlex, { 45434 justify: "flex-start", 45435 align: "center", 45436 gap: 1, 45437 wrap: true, 45438 __next40pxDefaultSize, 45439 hasTokens: !!value.length, 45440 children: renderTokensAndInput() 45441 }), isExpanded && /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(suggestions_list_default, { 45442 instanceId, 45443 match: saveTransform(incompleteTokenValue), 45444 displayTransform, 45445 suggestions: matchingSuggestions, 45446 selectedIndex: selectedSuggestionIndex, 45447 scrollIntoView: selectedSuggestionScroll, 45448 onHover: onSuggestionHovered, 45449 onSelect: onSuggestionSelected, 45450 __experimentalRenderItem 45451 })] 45452 }), __experimentalShowHowTo && /* @__PURE__ */ (0, import_jsx_runtime220.jsx)(StyledHelp, { 45453 id: `components-form-token-suggestions-howto-$instanceId}`, 45454 className: "components-form-token-field__help", 45455 children: tokenizeOnSpace ? (0, import_i18n57.__)("Separate with commas, spaces, or the Enter key.") : (0, import_i18n57.__)("Separate with commas or the Enter key.") 45456 })] 45457 }); 45458 } 45459 var form_token_field_default = FormTokenField; 45460 45461 // packages/components/build-module/guide/index.js 45462 var import_element145 = __toESM(require_element()); 45463 var import_deprecated17 = __toESM(require_deprecated()); 45464 var import_i18n59 = __toESM(require_i18n()); 45465 45466 // packages/components/build-module/guide/page-control.js 45467 var import_i18n58 = __toESM(require_i18n()); 45468 45469 // packages/components/build-module/guide/icons.js 45470 var import_primitives33 = __toESM(require_primitives()); 45471 var import_jsx_runtime221 = __toESM(require_jsx_runtime()); 45472 var PageControlIcon = () => /* @__PURE__ */ (0, import_jsx_runtime221.jsx)(import_primitives33.SVG, { 45473 width: "8", 45474 height: "8", 45475 fill: "none", 45476 xmlns: "http://www.w3.org/2000/svg", 45477 children: /* @__PURE__ */ (0, import_jsx_runtime221.jsx)(import_primitives33.Circle, { 45478 cx: "4", 45479 cy: "4", 45480 r: "4" 45481 }) 45482 }); 45483 45484 // packages/components/build-module/guide/page-control.js 45485 var import_jsx_runtime222 = __toESM(require_jsx_runtime()); 45486 function PageControl({ 45487 currentPage, 45488 numberOfPages, 45489 setCurrentPage 45490 }) { 45491 return /* @__PURE__ */ (0, import_jsx_runtime222.jsx)("ul", { 45492 className: "components-guide__page-control", 45493 "aria-label": (0, import_i18n58.__)("Guide controls"), 45494 children: Array.from({ 45495 length: numberOfPages 45496 }).map((_, page) => /* @__PURE__ */ (0, import_jsx_runtime222.jsx)("li", { 45497 // Set aria-current="step" on the active page, see https://www.w3.org/TR/wai-aria-1.1/#aria-current 45498 "aria-current": page === currentPage ? "step" : void 0, 45499 children: /* @__PURE__ */ (0, import_jsx_runtime222.jsx)(button_default, { 45500 size: "small", 45501 icon: /* @__PURE__ */ (0, import_jsx_runtime222.jsx)(PageControlIcon, {}), 45502 "aria-label": (0, import_i18n58.sprintf)( 45503 /* translators: 1: current page number 2: total number of pages */ 45504 (0, import_i18n58.__)("Page %1$d of %2$d"), 45505 page + 1, 45506 numberOfPages 45507 ), 45508 onClick: () => setCurrentPage(page) 45509 }, page) 45510 }, page)) 45511 }); 45512 } 45513 45514 // packages/components/build-module/guide/index.js 45515 var import_jsx_runtime223 = __toESM(require_jsx_runtime()); 45516 function Guide({ 45517 children, 45518 className: className2, 45519 contentLabel, 45520 finishButtonText = (0, import_i18n59.__)("Finish"), 45521 nextButtonText = (0, import_i18n59.__)("Next"), 45522 previousButtonText = (0, import_i18n59.__)("Previous"), 45523 onFinish, 45524 pages = [] 45525 }) { 45526 const ref = (0, import_element145.useRef)(null); 45527 const [currentPage, setCurrentPage] = (0, import_element145.useState)(0); 45528 (0, import_element145.useEffect)(() => { 45529 const frame2 = ref.current?.querySelector(".components-guide"); 45530 if (frame2 instanceof HTMLElement) { 45531 frame2.focus(); 45532 } 45533 }, [currentPage]); 45534 (0, import_element145.useEffect)(() => { 45535 if (import_element145.Children.count(children)) { 45536 (0, import_deprecated17.default)("Passing children to <Guide>", { 45537 since: "5.5", 45538 alternative: "the `pages` prop" 45539 }); 45540 } 45541 }, [children]); 45542 if (import_element145.Children.count(children)) { 45543 var _Children$map; 45544 pages = (_Children$map = import_element145.Children.map(children, (child) => ({ 45545 content: child 45546 }))) !== null && _Children$map !== void 0 ? _Children$map : []; 45547 } 45548 const canGoBack = currentPage > 0; 45549 const canGoForward = currentPage < pages.length - 1; 45550 const goBack = () => { 45551 if (canGoBack) { 45552 setCurrentPage(currentPage - 1); 45553 } 45554 }; 45555 const goForward = () => { 45556 if (canGoForward) { 45557 setCurrentPage(currentPage + 1); 45558 } 45559 }; 45560 if (pages.length === 0) { 45561 return null; 45562 } 45563 return /* @__PURE__ */ (0, import_jsx_runtime223.jsx)(modal_default, { 45564 className: clsx_default("components-guide", className2), 45565 contentLabel, 45566 isDismissible: pages.length > 1, 45567 onRequestClose: onFinish, 45568 onKeyDown: (event) => { 45569 if (event.code === "ArrowLeft") { 45570 goBack(); 45571 event.preventDefault(); 45572 } else if (event.code === "ArrowRight") { 45573 goForward(); 45574 event.preventDefault(); 45575 } 45576 }, 45577 ref, 45578 children: /* @__PURE__ */ (0, import_jsx_runtime223.jsxs)("div", { 45579 className: "components-guide__container", 45580 children: [/* @__PURE__ */ (0, import_jsx_runtime223.jsxs)("div", { 45581 className: "components-guide__page", 45582 children: [pages[currentPage].image, pages.length > 1 && /* @__PURE__ */ (0, import_jsx_runtime223.jsx)(PageControl, { 45583 currentPage, 45584 numberOfPages: pages.length, 45585 setCurrentPage 45586 }), pages[currentPage].content] 45587 }), /* @__PURE__ */ (0, import_jsx_runtime223.jsxs)("div", { 45588 className: "components-guide__footer", 45589 children: [canGoBack && /* @__PURE__ */ (0, import_jsx_runtime223.jsx)(button_default, { 45590 className: "components-guide__back-button", 45591 variant: "tertiary", 45592 onClick: goBack, 45593 __next40pxDefaultSize: true, 45594 children: previousButtonText 45595 }), canGoForward && /* @__PURE__ */ (0, import_jsx_runtime223.jsx)(button_default, { 45596 className: "components-guide__forward-button", 45597 variant: "primary", 45598 onClick: goForward, 45599 __next40pxDefaultSize: true, 45600 children: nextButtonText 45601 }), !canGoForward && /* @__PURE__ */ (0, import_jsx_runtime223.jsx)(button_default, { 45602 className: "components-guide__finish-button", 45603 variant: "primary", 45604 onClick: onFinish, 45605 __next40pxDefaultSize: true, 45606 children: finishButtonText 45607 })] 45608 })] 45609 }) 45610 }); 45611 } 45612 var guide_default = Guide; 45613 45614 // packages/components/build-module/guide/page.js 45615 var import_element146 = __toESM(require_element()); 45616 var import_deprecated18 = __toESM(require_deprecated()); 45617 var import_jsx_runtime224 = __toESM(require_jsx_runtime()); 45618 function GuidePage(props) { 45619 (0, import_element146.useEffect)(() => { 45620 (0, import_deprecated18.default)("<GuidePage>", { 45621 since: "5.5", 45622 alternative: "the `pages` prop in <Guide>" 45623 }); 45624 }, []); 45625 return /* @__PURE__ */ (0, import_jsx_runtime224.jsx)("div", { 45626 ...props 45627 }); 45628 } 45629 45630 // packages/components/build-module/button/deprecated.js 45631 var import_deprecated19 = __toESM(require_deprecated()); 45632 var import_element147 = __toESM(require_element()); 45633 var import_jsx_runtime225 = __toESM(require_jsx_runtime()); 45634 function UnforwardedIconButton({ 45635 label, 45636 labelPosition, 45637 size: size3, 45638 tooltip, 45639 ...props 45640 }, ref) { 45641 (0, import_deprecated19.default)("wp.components.IconButton", { 45642 since: "5.4", 45643 alternative: "wp.components.Button", 45644 version: "6.2" 45645 }); 45646 return /* @__PURE__ */ (0, import_jsx_runtime225.jsx)(button_default, { 45647 ...props, 45648 ref, 45649 tooltipPosition: labelPosition, 45650 iconSize: size3, 45651 showTooltip: tooltip !== void 0 ? !!tooltip : void 0, 45652 label: tooltip || label 45653 }); 45654 } 45655 var deprecated_default = (0, import_element147.forwardRef)(UnforwardedIconButton); 45656 45657 // packages/components/build-module/keyboard-shortcuts/index.js 45658 var import_element148 = __toESM(require_element()); 45659 var import_compose62 = __toESM(require_compose()); 45660 var import_jsx_runtime226 = __toESM(require_jsx_runtime()); 45661 function KeyboardShortcut({ 45662 target, 45663 callback, 45664 shortcut, 45665 bindGlobal, 45666 eventName 45667 }) { 45668 (0, import_compose62.useKeyboardShortcut)(shortcut, callback, { 45669 bindGlobal, 45670 target, 45671 eventName 45672 }); 45673 return null; 45674 } 45675 function KeyboardShortcuts({ 45676 children, 45677 shortcuts, 45678 bindGlobal, 45679 eventName 45680 }) { 45681 const target = (0, import_element148.useRef)(null); 45682 const element = Object.entries(shortcuts !== null && shortcuts !== void 0 ? shortcuts : {}).map(([shortcut, callback]) => /* @__PURE__ */ (0, import_jsx_runtime226.jsx)(KeyboardShortcut, { 45683 shortcut, 45684 callback, 45685 bindGlobal, 45686 eventName, 45687 target 45688 }, shortcut)); 45689 if (!import_element148.Children.count(children)) { 45690 return /* @__PURE__ */ (0, import_jsx_runtime226.jsx)(import_jsx_runtime226.Fragment, { 45691 children: element 45692 }); 45693 } 45694 return /* @__PURE__ */ (0, import_jsx_runtime226.jsxs)("div", { 45695 ref: target, 45696 children: [element, children] 45697 }); 45698 } 45699 var keyboard_shortcuts_default = KeyboardShortcuts; 45700 45701 // packages/components/build-module/menu-group/index.js 45702 var import_element149 = __toESM(require_element()); 45703 var import_compose63 = __toESM(require_compose()); 45704 var import_jsx_runtime227 = __toESM(require_jsx_runtime()); 45705 function MenuGroup3(props) { 45706 const { 45707 children, 45708 className: className2 = "", 45709 label, 45710 hideSeparator 45711 } = props; 45712 const instanceId = (0, import_compose63.useInstanceId)(MenuGroup3); 45713 if (!import_element149.Children.count(children)) { 45714 return null; 45715 } 45716 const labelId = `components-menu-group-label-$instanceId}`; 45717 const classNames = clsx_default(className2, "components-menu-group", { 45718 "has-hidden-separator": hideSeparator 45719 }); 45720 return /* @__PURE__ */ (0, import_jsx_runtime227.jsxs)("div", { 45721 className: classNames, 45722 children: [label && /* @__PURE__ */ (0, import_jsx_runtime227.jsx)("div", { 45723 className: "components-menu-group__label", 45724 id: labelId, 45725 "aria-hidden": "true", 45726 children: label 45727 }), /* @__PURE__ */ (0, import_jsx_runtime227.jsx)("div", { 45728 role: "group", 45729 "aria-labelledby": label ? labelId : void 0, 45730 children 45731 })] 45732 }); 45733 } 45734 var menu_group_default = MenuGroup3; 45735 45736 // packages/components/build-module/menu-item/index.js 45737 var import_element150 = __toESM(require_element()); 45738 var import_jsx_runtime228 = __toESM(require_jsx_runtime()); 45739 function UnforwardedMenuItem(props, ref) { 45740 let { 45741 children, 45742 info, 45743 className: className2, 45744 icon, 45745 iconPosition = "right", 45746 shortcut, 45747 isSelected: isSelected2, 45748 role = "menuitem", 45749 suffix, 45750 ...buttonProps 45751 } = props; 45752 className2 = clsx_default("components-menu-item__button", className2); 45753 if (info) { 45754 children = /* @__PURE__ */ (0, import_jsx_runtime228.jsxs)("span", { 45755 className: "components-menu-item__info-wrapper", 45756 children: [/* @__PURE__ */ (0, import_jsx_runtime228.jsx)("span", { 45757 className: "components-menu-item__item", 45758 children 45759 }), /* @__PURE__ */ (0, import_jsx_runtime228.jsx)("span", { 45760 className: "components-menu-item__info", 45761 children: info 45762 })] 45763 }); 45764 } 45765 if (icon && typeof icon !== "string") { 45766 icon = (0, import_element150.cloneElement)(icon, { 45767 className: clsx_default("components-menu-items__item-icon", { 45768 "has-icon-right": iconPosition === "right" 45769 }) 45770 }); 45771 } 45772 return /* @__PURE__ */ (0, import_jsx_runtime228.jsxs)(button_default, { 45773 size: "compact", 45774 ref, 45775 "aria-checked": role === "menuitemcheckbox" || role === "menuitemradio" ? isSelected2 : void 0, 45776 role, 45777 icon: iconPosition === "left" ? icon : void 0, 45778 className: className2, 45779 accessibleWhenDisabled: true, 45780 ...buttonProps, 45781 children: [/* @__PURE__ */ (0, import_jsx_runtime228.jsx)("span", { 45782 className: "components-menu-item__item", 45783 children 45784 }), !suffix && /* @__PURE__ */ (0, import_jsx_runtime228.jsx)(shortcut_default, { 45785 className: "components-menu-item__shortcut", 45786 shortcut 45787 }), !suffix && icon && iconPosition === "right" && /* @__PURE__ */ (0, import_jsx_runtime228.jsx)(icon_default3, { 45788 icon 45789 }), suffix] 45790 }); 45791 } 45792 var MenuItem3 = (0, import_element150.forwardRef)(UnforwardedMenuItem); 45793 var menu_item_default = MenuItem3; 45794 45795 // packages/components/build-module/menu-items-choice/index.js 45796 var import_jsx_runtime229 = __toESM(require_jsx_runtime()); 45797 var noop16 = () => { 45798 }; 45799 function MenuItemsChoice({ 45800 choices = [], 45801 onHover = noop16, 45802 onSelect, 45803 value 45804 }) { 45805 return /* @__PURE__ */ (0, import_jsx_runtime229.jsx)(import_jsx_runtime229.Fragment, { 45806 children: choices.map((item2) => { 45807 const isSelected2 = value === item2.value; 45808 return /* @__PURE__ */ (0, import_jsx_runtime229.jsx)(menu_item_default, { 45809 role: "menuitemradio", 45810 disabled: item2.disabled, 45811 icon: isSelected2 ? check_default : null, 45812 info: item2.info, 45813 isSelected: isSelected2, 45814 shortcut: item2.shortcut, 45815 className: "components-menu-items-choice", 45816 onClick: () => { 45817 if (!isSelected2) { 45818 onSelect(item2.value); 45819 } 45820 }, 45821 onMouseEnter: () => onHover(item2.value), 45822 onMouseLeave: () => onHover(null), 45823 "aria-label": item2["aria-label"], 45824 children: item2.label 45825 }, item2.value); 45826 }) 45827 }); 45828 } 45829 var menu_items_choice_default = MenuItemsChoice; 45830 45831 // packages/components/build-module/navigation/index.js 45832 var import_deprecated20 = __toESM(require_deprecated()); 45833 var import_element154 = __toESM(require_element()); 45834 var import_i18n61 = __toESM(require_i18n()); 45835 45836 // packages/components/build-module/navigation/constants.js 45837 var ROOT_MENU = "root"; 45838 var SEARCH_FOCUS_DELAY = 100; 45839 45840 // packages/components/build-module/navigation/context.js 45841 var import_element151 = __toESM(require_element()); 45842 var noop17 = () => { 45843 }; 45844 var defaultIsEmpty = () => false; 45845 var defaultGetter = () => void 0; 45846 var NavigationContext = (0, import_element151.createContext)({ 45847 activeItem: void 0, 45848 activeMenu: ROOT_MENU, 45849 setActiveMenu: noop17, 45850 navigationTree: { 45851 items: {}, 45852 getItem: defaultGetter, 45853 addItem: noop17, 45854 removeItem: noop17, 45855 menus: {}, 45856 getMenu: defaultGetter, 45857 addMenu: noop17, 45858 removeMenu: noop17, 45859 childMenu: {}, 45860 traverseMenu: noop17, 45861 isMenuEmpty: defaultIsEmpty 45862 } 45863 }); 45864 NavigationContext.displayName = "NavigationContext"; 45865 var useNavigationContext = () => (0, import_element151.useContext)(NavigationContext); 45866 45867 // packages/components/build-module/navigation/styles/navigation-styles.js 45868 var import_i18n60 = __toESM(require_i18n()); 45869 function _EMOTION_STRINGIFIED_CSS_ERROR__34() { 45870 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 45871 } 45872 var NavigationUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 45873 target: "eeiismy11" 45874 } : { 45875 target: "eeiismy11", 45876 label: "NavigationUI" 45877 })("width:100%;box-sizing:border-box;padding:0 ", space(4), ";overflow:hidden;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQnNDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45878 var MenuUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 45879 target: "eeiismy10" 45880 } : { 45881 target: "eeiismy10", 45882 label: "MenuUI" 45883 })("margin-top:", space(6), ";margin-bottom:", space(6), ";display:flex;flex-direction:column;ul{padding:0;margin:0;list-style:none;}.components-navigation__back-button{margin-bottom:", space(6), ";}.components-navigation__group+.components-navigation__group{margin-top:", space(6), ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmdDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45884 var MenuBackButtonUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default(button_default, false ? { 45885 target: "eeiismy9" 45886 } : { 45887 target: "eeiismy9", 45888 label: "MenuBackButtonUI" 45889 })(false ? { 45890 name: "26l0q2", 45891 styles: "&.is-tertiary{color:inherit;opacity:0.7;&:hover:not( :disabled ){opacity:1;box-shadow:none;color:inherit;}&:active:not( :disabled ){background:transparent;opacity:1;color:inherit;}}" 45892 } : { 45893 name: "26l0q2", 45894 styles: "&.is-tertiary{color:inherit;opacity:0.7;&:hover:not( :disabled ){opacity:1;box-shadow:none;color:inherit;}&:active:not( :disabled ){background:transparent;opacity:1;color:inherit;}}", 45895 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q2dEIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */", 45896 toString: _EMOTION_STRINGIFIED_CSS_ERROR__34 45897 }); 45898 var MenuTitleUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 45899 target: "eeiismy8" 45900 } : { 45901 target: "eeiismy8", 45902 label: "MenuTitleUI" 45903 })(false ? { 45904 name: "1aubja5", 45905 styles: "overflow:hidden;width:100%" 45906 } : { 45907 name: "1aubja5", 45908 styles: "overflow:hidden;width:100%", 45909 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRXFDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */", 45910 toString: _EMOTION_STRINGIFIED_CSS_ERROR__34 45911 }); 45912 var MenuTitleSearchControlWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 45913 target: "eeiismy7" 45914 } : { 45915 target: "eeiismy7", 45916 label: "MenuTitleSearchControlWrapper" 45917 })(false ? { 45918 name: "rgorny", 45919 styles: "margin:11px 0;padding:1px" 45920 } : { 45921 name: "rgorny", 45922 styles: "margin:11px 0;padding:1px", 45923 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRXVEIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */", 45924 toString: _EMOTION_STRINGIFIED_CSS_ERROR__34 45925 }); 45926 var MenuTitleActionsUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 45927 target: "eeiismy6" 45928 } : { 45929 target: "eeiismy6", 45930 label: "MenuTitleActionsUI" 45931 })("height:", space(6), ";.components-button.is-small{color:inherit;opacity:0.7;margin-right:", space(1), ";padding:0;&:active:not( :disabled ){background:none;opacity:1;color:inherit;}&:hover:not( :disabled ){box-shadow:none;opacity:1;color:inherit;}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyRTZDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45932 var GroupTitleUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default19, false ? { 45933 target: "eeiismy5" 45934 } : { 45935 target: "eeiismy5", 45936 label: "GroupTitleUI" 45937 })("min-height:", space(12), ";align-items:center;color:inherit;display:flex;justify-content:space-between;margin-bottom:", space(2), ";padding:", () => (0, import_i18n60.isRTL)() ? `$space(1)} $space(4)} $space(1)} $space(2)}` : `$space(1)} $space(2)} $space(1)} $space(4)}`, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRzZDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45938 var ItemBaseUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("li", false ? { 45939 target: "eeiismy4" 45940 } : { 45941 target: "eeiismy4", 45942 label: "ItemBaseUI" 45943 })("border-radius:", config_values_default.radiusSmall, ";color:inherit;margin-bottom:0;>button,>a.components-button,>a{width:100%;color:inherit;opacity:0.7;padding:", space(2), " ", space(4), ";", rtl({ 45944 textAlign: "left" 45945 }, { 45946 textAlign: "right" 45947 }), " &:hover,&:focus:not( [aria-disabled='true'] ):active,&:active:not( [aria-disabled='true'] ):active{color:inherit;opacity:1;}}&.is-active{background-color:", COLORS.theme.accent, ";color:", COLORS.theme.accentInverted, ";>button,.components-button:hover,>a{color:", COLORS.theme.accentInverted, ";opacity:1;}}>svg path{color:", COLORS.gray[600], ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSG1DIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45948 var ItemUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 45949 target: "eeiismy3" 45950 } : { 45951 target: "eeiismy3", 45952 label: "ItemUI" 45953 })("display:flex;align-items:center;height:auto;min-height:40px;margin:0;padding:", space(1.5), " ", space(4), ";font-weight:400;line-height:20px;width:100%;color:inherit;opacity:0.7;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1SmdDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45954 var ItemIconUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 45955 target: "eeiismy2" 45956 } : { 45957 target: "eeiismy2", 45958 label: "ItemIconUI" 45959 })("display:flex;margin-right:", space(2), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxS3FDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45960 var ItemBadgeUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 45961 target: "eeiismy1" 45962 } : { 45963 target: "eeiismy1", 45964 label: "ItemBadgeUI" 45965 })("margin-left:", () => (0, import_i18n60.isRTL)() ? "0" : space(2), ";margin-right:", () => (0, import_i18n60.isRTL)() ? space(2) : "0", ";display:inline-flex;padding:", space(1), " ", space(3), ";border-radius:", config_values_default.radiusSmall, ";@keyframes fade-in{from{opacity:0;}to{opacity:1;}}@media not ( prefers-reduced-motion ){animation:fade-in 250ms ease-out;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwS3NDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45966 var ItemTitleUI = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default8, false ? { 45967 target: "eeiismy0" 45968 } : { 45969 target: "eeiismy0", 45970 label: "ItemTitleUI" 45971 })(() => (0, import_i18n60.isRTL)() ? "margin-left: auto;" : "margin-right: auto;", " font-size:14px;line-height:20px;color:inherit;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5hdmlnYXRpb24tc3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErTHlDIiwiZmlsZSI6Im5hdmlnYXRpb24tc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBXb3JkUHJlc3MgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGlzUlRMIH0gZnJvbSAnQHdvcmRwcmVzcy9pMThuJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgQnV0dG9uIGZyb20gJy4uLy4uL2J1dHRvbic7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBIZWFkaW5nIH0gZnJvbSAnLi4vLi4vaGVhZGluZyc7XG5pbXBvcnQgeyBydGwsIENPTkZJRyB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3BhY2UnO1xuXG5leHBvcnQgY29uc3QgTmF2aWdhdGlvblVJID0gc3R5bGVkLmRpdmBcblx0d2lkdGg6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdHBhZGRpbmc6IDAgJHsgc3BhY2UoIDQgKSB9O1xuXHRvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IE1lbnVVSSA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCA2ICkgfTtcblx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuXHR1bCB7XG5cdFx0cGFkZGluZzogMDtcblx0XHRtYXJnaW46IDA7XG5cdFx0bGlzdC1zdHlsZTogbm9uZTtcblx0fVxuXHQuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19iYWNrLWJ1dHRvbiB7XG5cdFx0bWFyZ2luLWJvdHRvbTogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5cblx0LmNvbXBvbmVudHMtbmF2aWdhdGlvbl9fZ3JvdXAgKyAuY29tcG9uZW50cy1uYXZpZ2F0aW9uX19ncm91cCB7XG5cdFx0bWFyZ2luLXRvcDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudUJhY2tCdXR0b25VSSA9IHN0eWxlZCggQnV0dG9uIClgXG5cdCYuaXMtdGVydGlhcnkge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblxuXHRcdCY6aG92ZXI6bm90KCA6ZGlzYWJsZWQgKSB7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Ym94LXNoYWRvdzogbm9uZTtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdH1cblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlVUkgPSBzdHlsZWQuZGl2YFxuXHRvdmVyZmxvdzogaGlkZGVuO1xuXHR3aWR0aDogMTAwJTtcbmA7XG5cbmV4cG9ydCBjb25zdCBNZW51VGl0bGVTZWFyY2hDb250cm9sV3JhcHBlciA9IHN0eWxlZC5kaXZgXG5cdG1hcmdpbjogMTFweCAwOyAvLyBub24taWRlYWwgaGFyZGNvZGluZyB0byBtYWludGFpbiBzYW1lIGhlaWdodCBhcyBIZWFkaW5nLCBjb3VsZCBiZSBpbXByb3ZlZFxuXHRwYWRkaW5nOiAxcHg7IC8vIHNvIHRoZSBmb2N1cyBib3JkZXIgZG9lc24ndCBnZXQgY3V0IG9mZiBieSB0aGUgb3ZlcmZsb3cgaGlkZGVuIG9uIE1lbnVUaXRsZVVJXG5gO1xuXG5leHBvcnQgY29uc3QgTWVudVRpdGxlQWN0aW9uc1VJID0gc3R5bGVkLnNwYW5gXG5cdGhlaWdodDogJHsgc3BhY2UoIDYgKSB9OyAvLyAyNHB4LCBzYW1lIGhlaWdodCBhcyB0aGUgYnV0dG9ucyBpbnNpZGVcblxuXHQuY29tcG9uZW50cy1idXR0b24uaXMtc21hbGwge1xuXHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdG9wYWNpdHk6IDAuNztcblx0XHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAxICkgfTsgLy8gQXZvaWQgaGlkaW5nIHRoZSBmb2N1cyBvdXRsaW5lXG5cdFx0cGFkZGluZzogMDtcblxuXHRcdCY6YWN0aXZlOm5vdCggOmRpc2FibGVkICkge1xuXHRcdFx0YmFja2dyb3VuZDogbm9uZTtcblx0XHRcdG9wYWNpdHk6IDE7XG5cdFx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHR9XG5cdFx0Jjpob3Zlcjpub3QoIDpkaXNhYmxlZCApIHtcblx0XHRcdGJveC1zaGFkb3c6IG5vbmU7XG5cdFx0XHRvcGFjaXR5OiAxO1xuXHRcdFx0Y29sb3I6IGluaGVyaXQ7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgR3JvdXBUaXRsZVVJID0gc3R5bGVkKCBIZWFkaW5nIClgXG5cdG1pbi1oZWlnaHQ6ICR7IHNwYWNlKCAxMiApIH07XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRkaXNwbGF5OiBmbGV4O1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAyICkgfTtcblx0cGFkZGluZzogJHsgKCkgPT5cblx0XHRpc1JUTCgpXG5cdFx0XHQ/IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDQgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZSggMiApIH1gXG5cdFx0XHQ6IGAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCAxICkgfSAkeyBzcGFjZShcblx0XHRcdFx0XHQ0XG5cdFx0XHQgICkgfWAgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFzZVVJID0gc3R5bGVkLmxpYFxuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblx0Y29sb3I6IGluaGVyaXQ7XG5cdG1hcmdpbi1ib3R0b206IDA7XG5cblx0PiBidXR0b24sXG5cdD4gYS5jb21wb25lbnRzLWJ1dHRvbixcblx0PiBhIHtcblx0XHR3aWR0aDogMTAwJTtcblx0XHRjb2xvcjogaW5oZXJpdDtcblx0XHRvcGFjaXR5OiAwLjc7XG5cdFx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9ICR7IHNwYWNlKCA0ICkgfTsgLyogOHB4IDE2cHggKi9cblx0XHQkeyBydGwoIHsgdGV4dEFsaWduOiAnbGVmdCcgfSwgeyB0ZXh0QWxpZ246ICdyaWdodCcgfSApIH1cblxuXHRcdCY6aG92ZXIsXG5cdFx0Jjpmb2N1czpub3QoIFthcmlhLWRpc2FibGVkPSd0cnVlJ10gKTphY3RpdmUsXG5cdFx0JjphY3RpdmU6bm90KCBbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddICk6YWN0aXZlIHtcblx0XHRcdGNvbG9yOiBpbmhlcml0O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQmLmlzLWFjdGl2ZSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdD4gYnV0dG9uLFxuXHRcdC5jb21wb25lbnRzLWJ1dHRvbjpob3Zlcixcblx0XHQ+IGEge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5hY2NlbnRJbnZlcnRlZCB9O1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHQ+IHN2ZyBwYXRoIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDYwMCBdIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVUkgPSBzdHlsZWQuZGl2YFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRoZWlnaHQ6IGF1dG87XG5cdG1pbi1oZWlnaHQ6IDQwcHg7XG5cdG1hcmdpbjogMDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDEuNSApIH0gJHsgc3BhY2UoIDQgKSB9O1xuXHRmb250LXdlaWdodDogNDAwO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0d2lkdGg6IDEwMCU7XG5cdGNvbG9yOiBpbmhlcml0O1xuXHRvcGFjaXR5OiAwLjc7XG5gO1xuXG5leHBvcnQgY29uc3QgSXRlbUljb25VSSA9IHN0eWxlZC5zcGFuYFxuXHRkaXNwbGF5OiBmbGV4O1xuXHRtYXJnaW4tcmlnaHQ6ICR7IHNwYWNlKCAyICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtQmFkZ2VVSSA9IHN0eWxlZC5zcGFuYFxuXHRtYXJnaW4tbGVmdDogJHsgKCkgPT4gKCBpc1JUTCgpID8gJzAnIDogc3BhY2UoIDIgKSApIH07XG5cdG1hcmdpbi1yaWdodDogJHsgKCkgPT4gKCBpc1JUTCgpID8gc3BhY2UoIDIgKSA6ICcwJyApIH07XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggMSApIH0gJHsgc3BhY2UoIDMgKSB9O1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzU21hbGwgfTtcblxuXHRAa2V5ZnJhbWVzIGZhZGUtaW4ge1xuXHRcdGZyb20ge1xuXHRcdFx0b3BhY2l0eTogMDtcblx0XHR9XG5cdFx0dG8ge1xuXHRcdFx0b3BhY2l0eTogMTtcblx0XHR9XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHRhbmltYXRpb246IGZhZGUtaW4gMjUwbXMgZWFzZS1vdXQ7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtVGl0bGVVSSA9IHN0eWxlZCggVGV4dCApYFxuXHQkeyAoKSA9PiAoIGlzUlRMKCkgPyAnbWFyZ2luLWxlZnQ6IGF1dG87JyA6ICdtYXJnaW4tcmlnaHQ6IGF1dG87JyApIH1cblx0Zm9udC1zaXplOiAxNHB4O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6IGluaGVyaXQ7XG5gO1xuIl19 */")); 45972 45973 // packages/components/build-module/navigation/use-create-navigation-tree.js 45974 var import_element153 = __toESM(require_element()); 45975 45976 // packages/components/build-module/navigation/use-navigation-tree-nodes.js 45977 var import_element152 = __toESM(require_element()); 45978 function useNavigationTreeNodes() { 45979 const [nodes, setNodes] = (0, import_element152.useState)({}); 45980 const getNode = (key) => nodes[key]; 45981 const addNode = (key, value) => { 45982 const { 45983 children, 45984 ...newNode 45985 } = value; 45986 return setNodes((original) => ({ 45987 ...original, 45988 [key]: newNode 45989 })); 45990 }; 45991 const removeNode = (key) => { 45992 return setNodes((original) => { 45993 const { 45994 [key]: removedNode, 45995 ...remainingNodes 45996 } = original; 45997 return remainingNodes; 45998 }); 45999 }; 46000 return { 46001 nodes, 46002 getNode, 46003 addNode, 46004 removeNode 46005 }; 46006 } 46007 46008 // packages/components/build-module/navigation/use-create-navigation-tree.js 46009 var useCreateNavigationTree = () => { 46010 const { 46011 nodes: items, 46012 getNode: getItem, 46013 addNode: addItem, 46014 removeNode: removeItem2 46015 } = useNavigationTreeNodes(); 46016 const { 46017 nodes: menus, 46018 getNode: getMenu, 46019 addNode: addMenu, 46020 removeNode: removeMenu 46021 } = useNavigationTreeNodes(); 46022 const [childMenu, setChildMenu] = (0, import_element153.useState)({}); 46023 const getChildMenu = (menu2) => childMenu[menu2] || []; 46024 const traverseMenu = (startMenu, callback) => { 46025 const visited = []; 46026 let queue = [startMenu]; 46027 let current; 46028 while (queue.length > 0) { 46029 current = getMenu(queue.shift()); 46030 if (!current || visited.includes(current.menu)) { 46031 continue; 46032 } 46033 visited.push(current.menu); 46034 queue = [...queue, ...getChildMenu(current.menu)]; 46035 if (callback(current) === false) { 46036 break; 46037 } 46038 } 46039 }; 46040 const isMenuEmpty = (menuToCheck) => { 46041 let isEmpty2 = true; 46042 traverseMenu(menuToCheck, (current) => { 46043 if (!current.isEmpty) { 46044 isEmpty2 = false; 46045 return false; 46046 } 46047 return void 0; 46048 }); 46049 return isEmpty2; 46050 }; 46051 return { 46052 items, 46053 getItem, 46054 addItem, 46055 removeItem: removeItem2, 46056 menus, 46057 getMenu, 46058 addMenu: (key, value) => { 46059 setChildMenu((state) => { 46060 const newState = { 46061 ...state 46062 }; 46063 if (!value.parentMenu) { 46064 return newState; 46065 } 46066 if (!newState[value.parentMenu]) { 46067 newState[value.parentMenu] = []; 46068 } 46069 newState[value.parentMenu].push(key); 46070 return newState; 46071 }); 46072 addMenu(key, value); 46073 }, 46074 removeMenu, 46075 childMenu, 46076 traverseMenu, 46077 isMenuEmpty 46078 }; 46079 }; 46080 46081 // packages/components/build-module/navigation/index.js 46082 var import_jsx_runtime230 = __toESM(require_jsx_runtime()); 46083 var noop18 = () => { 46084 }; 46085 function Navigation({ 46086 activeItem, 46087 activeMenu = ROOT_MENU, 46088 children, 46089 className: className2, 46090 onActivateMenu = noop18 46091 }) { 46092 const [menu2, setMenu] = (0, import_element154.useState)(activeMenu); 46093 const [slideOrigin, setSlideOrigin] = (0, import_element154.useState)(); 46094 const navigationTree = useCreateNavigationTree(); 46095 const defaultSlideOrigin = (0, import_i18n61.isRTL)() ? "right" : "left"; 46096 (0, import_deprecated20.default)("wp.components.Navigation (and all subcomponents)", { 46097 since: "6.8", 46098 version: "7.1", 46099 alternative: "wp.components.Navigator" 46100 }); 46101 const setActiveMenu = (menuId, slideInOrigin = defaultSlideOrigin) => { 46102 if (!navigationTree.getMenu(menuId)) { 46103 return; 46104 } 46105 setSlideOrigin(slideInOrigin); 46106 setMenu(menuId); 46107 onActivateMenu(menuId); 46108 }; 46109 const isMountedRef = (0, import_element154.useRef)(false); 46110 (0, import_element154.useEffect)(() => { 46111 if (!isMountedRef.current) { 46112 isMountedRef.current = true; 46113 } 46114 }, []); 46115 (0, import_element154.useEffect)(() => { 46116 if (activeMenu !== menu2) { 46117 setActiveMenu(activeMenu); 46118 } 46119 }, [activeMenu]); 46120 const context = { 46121 activeItem, 46122 activeMenu: menu2, 46123 setActiveMenu, 46124 navigationTree 46125 }; 46126 const classes = clsx_default("components-navigation", className2); 46127 const animateClassName = getAnimateClassName({ 46128 type: "slide-in", 46129 origin: slideOrigin 46130 }); 46131 return /* @__PURE__ */ (0, import_jsx_runtime230.jsx)(NavigationUI, { 46132 className: classes, 46133 children: /* @__PURE__ */ (0, import_jsx_runtime230.jsx)("div", { 46134 className: animateClassName ? clsx_default({ 46135 [animateClassName]: isMountedRef.current && slideOrigin 46136 }) : void 0, 46137 children: /* @__PURE__ */ (0, import_jsx_runtime230.jsx)(NavigationContext.Provider, { 46138 value: context, 46139 children 46140 }) 46141 }, menu2) 46142 }); 46143 } 46144 var navigation_default = Navigation; 46145 46146 // packages/components/build-module/navigation/back-button/index.js 46147 var import_element155 = __toESM(require_element()); 46148 var import_i18n62 = __toESM(require_i18n()); 46149 var import_jsx_runtime231 = __toESM(require_jsx_runtime()); 46150 function UnforwardedNavigationBackButton({ 46151 backButtonLabel, 46152 className: className2, 46153 href, 46154 onClick, 46155 parentMenu 46156 }, ref) { 46157 const { 46158 setActiveMenu, 46159 navigationTree 46160 } = useNavigationContext(); 46161 const classes = clsx_default("components-navigation__back-button", className2); 46162 const parentMenuTitle = parentMenu !== void 0 ? navigationTree.getMenu(parentMenu)?.title : void 0; 46163 const handleOnClick = (event) => { 46164 if (typeof onClick === "function") { 46165 onClick(event); 46166 } 46167 const animationDirection = (0, import_i18n62.isRTL)() ? "left" : "right"; 46168 if (parentMenu && !event.defaultPrevented) { 46169 setActiveMenu(parentMenu, animationDirection); 46170 } 46171 }; 46172 const icon = (0, import_i18n62.isRTL)() ? chevron_right_default : chevron_left_default; 46173 return /* @__PURE__ */ (0, import_jsx_runtime231.jsxs)(MenuBackButtonUI, { 46174 __next40pxDefaultSize: true, 46175 className: classes, 46176 href, 46177 variant: "tertiary", 46178 ref, 46179 onClick: handleOnClick, 46180 children: [/* @__PURE__ */ (0, import_jsx_runtime231.jsx)(icon_default2, { 46181 icon 46182 }), backButtonLabel || parentMenuTitle || (0, import_i18n62.__)("Back")] 46183 }); 46184 } 46185 var NavigationBackButton = (0, import_element155.forwardRef)(UnforwardedNavigationBackButton); 46186 var back_button_default = NavigationBackButton; 46187 46188 // packages/components/build-module/navigation/group/index.js 46189 var import_element157 = __toESM(require_element()); 46190 46191 // packages/components/build-module/navigation/group/context.js 46192 var import_element156 = __toESM(require_element()); 46193 var NavigationGroupContext = (0, import_element156.createContext)({ 46194 group: void 0 46195 }); 46196 NavigationGroupContext.displayName = "NavigationGroupContext"; 46197 var useNavigationGroupContext = () => (0, import_element156.useContext)(NavigationGroupContext); 46198 46199 // packages/components/build-module/navigation/group/index.js 46200 var import_jsx_runtime232 = __toESM(require_jsx_runtime()); 46201 var uniqueId = 0; 46202 function NavigationGroup({ 46203 children, 46204 className: className2, 46205 title 46206 }) { 46207 const [groupId] = (0, import_element157.useState)(`group-${++uniqueId}`); 46208 const { 46209 navigationTree: { 46210 items 46211 } 46212 } = useNavigationContext(); 46213 const context = { 46214 group: groupId 46215 }; 46216 if (!Object.values(items).some((item2) => item2.group === groupId && item2._isVisible)) { 46217 return /* @__PURE__ */ (0, import_jsx_runtime232.jsx)(NavigationGroupContext.Provider, { 46218 value: context, 46219 children 46220 }); 46221 } 46222 const groupTitleId = `components-navigation__group-title-$groupId}`; 46223 const classes = clsx_default("components-navigation__group", className2); 46224 return /* @__PURE__ */ (0, import_jsx_runtime232.jsx)(NavigationGroupContext.Provider, { 46225 value: context, 46226 children: /* @__PURE__ */ (0, import_jsx_runtime232.jsxs)("li", { 46227 className: classes, 46228 children: [title && /* @__PURE__ */ (0, import_jsx_runtime232.jsx)(GroupTitleUI, { 46229 className: "components-navigation__group-title", 46230 id: groupTitleId, 46231 level: 3, 46232 children: title 46233 }), /* @__PURE__ */ (0, import_jsx_runtime232.jsx)("ul", { 46234 "aria-labelledby": groupTitleId, 46235 role: "group", 46236 children 46237 })] 46238 }) 46239 }); 46240 } 46241 var group_default = NavigationGroup; 46242 46243 // packages/components/build-module/navigation/item/index.js 46244 var import_i18n63 = __toESM(require_i18n()); 46245 46246 // packages/components/build-module/navigation/item/base-content.js 46247 var import_jsx_runtime233 = __toESM(require_jsx_runtime()); 46248 function NavigationItemBaseContent(props) { 46249 const { 46250 badge, 46251 title 46252 } = props; 46253 return /* @__PURE__ */ (0, import_jsx_runtime233.jsxs)(import_jsx_runtime233.Fragment, { 46254 children: [title && /* @__PURE__ */ (0, import_jsx_runtime233.jsx)(ItemTitleUI, { 46255 className: "components-navigation__item-title", 46256 as: "span", 46257 children: title 46258 }), badge && /* @__PURE__ */ (0, import_jsx_runtime233.jsx)(ItemBadgeUI, { 46259 className: "components-navigation__item-badge", 46260 children: badge 46261 })] 46262 }); 46263 } 46264 46265 // packages/components/build-module/navigation/item/base.js 46266 var import_element160 = __toESM(require_element()); 46267 46268 // packages/components/build-module/navigation/item/use-navigation-tree-item.js 46269 var import_element159 = __toESM(require_element()); 46270 46271 // packages/components/build-module/navigation/menu/context.js 46272 var import_element158 = __toESM(require_element()); 46273 var NavigationMenuContext = (0, import_element158.createContext)({ 46274 menu: void 0, 46275 search: "" 46276 }); 46277 NavigationMenuContext.displayName = "NavigationMenuContext"; 46278 var useNavigationMenuContext = () => (0, import_element158.useContext)(NavigationMenuContext); 46279 46280 // packages/components/build-module/navigation/utils.js 46281 var import_remove_accents4 = __toESM(require_remove_accents()); 46282 var normalizeInput = (input) => (0, import_remove_accents4.default)(input).replace(/^\//, "").toLowerCase(); 46283 var normalizedSearch = (title, search) => -1 !== normalizeInput(title).indexOf(normalizeInput(search)); 46284 46285 // packages/components/build-module/navigation/item/use-navigation-tree-item.js 46286 var useNavigationTreeItem = (itemId, props) => { 46287 const { 46288 activeMenu, 46289 navigationTree: { 46290 addItem, 46291 removeItem: removeItem2 46292 } 46293 } = useNavigationContext(); 46294 const { 46295 group 46296 } = useNavigationGroupContext(); 46297 const { 46298 menu: menu2, 46299 search 46300 } = useNavigationMenuContext(); 46301 (0, import_element159.useEffect)(() => { 46302 const isMenuActive = activeMenu === menu2; 46303 const isItemVisible = !search || props.title !== void 0 && normalizedSearch(props.title, search); 46304 addItem(itemId, { 46305 ...props, 46306 group, 46307 menu: menu2, 46308 _isVisible: isMenuActive && isItemVisible 46309 }); 46310 return () => { 46311 removeItem2(itemId); 46312 }; 46313 }, [activeMenu, search]); 46314 }; 46315 46316 // packages/components/build-module/navigation/item/base.js 46317 var import_jsx_runtime234 = __toESM(require_jsx_runtime()); 46318 var uniqueId2 = 0; 46319 function NavigationItemBase(props) { 46320 const { 46321 children, 46322 className: className2, 46323 title, 46324 href, 46325 ...restProps 46326 } = props; 46327 const [itemId] = (0, import_element160.useState)(`item-${++uniqueId2}`); 46328 useNavigationTreeItem(itemId, props); 46329 const { 46330 navigationTree 46331 } = useNavigationContext(); 46332 if (!navigationTree.getItem(itemId)?._isVisible) { 46333 return null; 46334 } 46335 const classes = clsx_default("components-navigation__item", className2); 46336 return /* @__PURE__ */ (0, import_jsx_runtime234.jsx)(ItemBaseUI, { 46337 className: classes, 46338 ...restProps, 46339 children 46340 }); 46341 } 46342 46343 // packages/components/build-module/navigation/item/index.js 46344 var import_jsx_runtime235 = __toESM(require_jsx_runtime()); 46345 var noop19 = () => { 46346 }; 46347 function NavigationItem(props) { 46348 const { 46349 badge, 46350 children, 46351 className: className2, 46352 href, 46353 item: item2, 46354 navigateToMenu, 46355 onClick = noop19, 46356 title, 46357 icon, 46358 hideIfTargetMenuEmpty, 46359 isText, 46360 ...restProps 46361 } = props; 46362 const { 46363 activeItem, 46364 setActiveMenu, 46365 navigationTree: { 46366 isMenuEmpty 46367 } 46368 } = useNavigationContext(); 46369 if (hideIfTargetMenuEmpty && navigateToMenu && isMenuEmpty(navigateToMenu)) { 46370 return null; 46371 } 46372 const isActive = item2 && activeItem === item2; 46373 const classes = clsx_default(className2, { 46374 "is-active": isActive 46375 }); 46376 const onItemClick = (event) => { 46377 if (navigateToMenu) { 46378 setActiveMenu(navigateToMenu); 46379 } 46380 onClick(event); 46381 }; 46382 const navigationIcon = (0, import_i18n63.isRTL)() ? chevron_left_default : chevron_right_default; 46383 const baseProps = children ? props : { 46384 ...props, 46385 onClick: void 0 46386 }; 46387 const itemProps = isText ? restProps : { 46388 as: button_default, 46389 __next40pxDefaultSize: "as" in restProps ? restProps.as === void 0 : true, 46390 href, 46391 onClick: onItemClick, 46392 "aria-current": isActive ? "page" : void 0, 46393 ...restProps 46394 }; 46395 return /* @__PURE__ */ (0, import_jsx_runtime235.jsx)(NavigationItemBase, { 46396 ...baseProps, 46397 className: classes, 46398 children: children || /* @__PURE__ */ (0, import_jsx_runtime235.jsxs)(ItemUI, { 46399 ...itemProps, 46400 children: [icon && /* @__PURE__ */ (0, import_jsx_runtime235.jsx)(ItemIconUI, { 46401 children: /* @__PURE__ */ (0, import_jsx_runtime235.jsx)(icon_default2, { 46402 icon 46403 }) 46404 }), /* @__PURE__ */ (0, import_jsx_runtime235.jsx)(NavigationItemBaseContent, { 46405 title, 46406 badge 46407 }), navigateToMenu && /* @__PURE__ */ (0, import_jsx_runtime235.jsx)(icon_default2, { 46408 icon: navigationIcon 46409 })] 46410 }) 46411 }); 46412 } 46413 var item_default2 = NavigationItem; 46414 46415 // packages/components/build-module/navigation/menu/index.js 46416 var import_element165 = __toESM(require_element()); 46417 46418 // packages/components/build-module/navigation/menu/use-navigation-tree-menu.js 46419 var import_element161 = __toESM(require_element()); 46420 var useNavigationTreeMenu = (props) => { 46421 const { 46422 navigationTree: { 46423 addMenu, 46424 removeMenu 46425 } 46426 } = useNavigationContext(); 46427 const key = props.menu || ROOT_MENU; 46428 (0, import_element161.useEffect)(() => { 46429 addMenu(key, { 46430 ...props, 46431 menu: key 46432 }); 46433 return () => { 46434 removeMenu(key); 46435 }; 46436 }, []); 46437 }; 46438 46439 // packages/components/build-module/navigation/menu/menu-title.js 46440 var import_element164 = __toESM(require_element()); 46441 var import_i18n66 = __toESM(require_i18n()); 46442 46443 // packages/components/build-module/navigation/menu/menu-title-search.js 46444 var import_element163 = __toESM(require_element()); 46445 var import_i18n65 = __toESM(require_i18n()); 46446 46447 // packages/components/build-module/higher-order/with-spoken-messages/index.js 46448 var import_compose64 = __toESM(require_compose()); 46449 var import_a11y7 = __toESM(require_a11y()); 46450 var import_jsx_runtime236 = __toESM(require_jsx_runtime()); 46451 var with_spoken_messages_default = (0, import_compose64.createHigherOrderComponent)((Component9) => (props) => /* @__PURE__ */ (0, import_jsx_runtime236.jsx)(Component9, { 46452 ...props, 46453 speak: import_a11y7.speak, 46454 debouncedSpeak: (0, import_compose64.useDebounce)(import_a11y7.speak, 500) 46455 }), "withSpokenMessages"); 46456 46457 // packages/components/build-module/search-control/index.js 46458 var import_compose65 = __toESM(require_compose()); 46459 var import_i18n64 = __toESM(require_i18n()); 46460 var import_element162 = __toESM(require_element()); 46461 var import_deprecated21 = __toESM(require_deprecated()); 46462 46463 // packages/components/build-module/search-control/styles.js 46464 function _EMOTION_STRINGIFIED_CSS_ERROR__35() { 46465 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 46466 } 46467 var StyledInputControl = /* @__PURE__ */ emotion_styled_base_browser_esm_default(input_control_default, false ? { 46468 target: "effl84m1" 46469 } : { 46470 target: "effl84m1", 46471 label: "StyledInputControl" 46472 })(false ? { 46473 name: "37btb2", 46474 styles: "input[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{-webkit-appearance:none;}}" 46475 } : { 46476 name: "37btb2", 46477 styles: "input[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{-webkit-appearance:none;}}", 46478 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXd0QiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgSW5wdXRDb250cm9sIGZyb20gJy4uL2lucHV0LWNvbnRyb2wnO1xuaW1wb3J0IEljb24gZnJvbSAnLi4vaWNvbic7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dENvbnRyb2wgPSBzdHlsZWQoIElucHV0Q29udHJvbCApYFxuXHRpbnB1dFt0eXBlPSdzZWFyY2gnXSB7XG5cdFx0Jjo6LXdlYmtpdC1zZWFyY2gtZGVjb3JhdGlvbixcblx0XHQmOjotd2Via2l0LXNlYXJjaC1jYW5jZWwtYnV0dG9uLFxuXHRcdCY6Oi13ZWJraXQtc2VhcmNoLXJlc3VsdHMtYnV0dG9uLFxuXHRcdCY6Oi13ZWJraXQtc2VhcmNoLXJlc3VsdHMtZGVjb3JhdGlvbiB7XG5cdFx0XHQtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmU7XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSWNvbiA9IHN0eWxlZCggSWNvbiApYFxuXHQmOmRpciggbHRyICkge1xuXHRcdHRyYW5zZm9ybTogc2NhbGVYKCAtMSApO1xuXHR9XG5gO1xuIl19 */", 46479 toString: _EMOTION_STRINGIFIED_CSS_ERROR__35 46480 }); 46481 var StyledIcon = /* @__PURE__ */ emotion_styled_base_browser_esm_default(icon_default3, false ? { 46482 target: "effl84m0" 46483 } : { 46484 target: "effl84m0", 46485 label: "StyledIcon" 46486 })(false ? { 46487 name: "1i54h4p", 46488 styles: "&:dir( ltr ){transform:scaleX( -1 );}" 46489 } : { 46490 name: "1i54h4p", 46491 styles: "&:dir( ltr ){transform:scaleX( -1 );}", 46492 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQndDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IElucHV0Q29udHJvbCBmcm9tICcuLi9pbnB1dC1jb250cm9sJztcbmltcG9ydCBJY29uIGZyb20gJy4uL2ljb24nO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkSW5wdXRDb250cm9sID0gc3R5bGVkKCBJbnB1dENvbnRyb2wgKWBcblx0aW5wdXRbdHlwZT0nc2VhcmNoJ10ge1xuXHRcdCY6Oi13ZWJraXQtc2VhcmNoLWRlY29yYXRpb24sXG5cdFx0Jjo6LXdlYmtpdC1zZWFyY2gtY2FuY2VsLWJ1dHRvbixcblx0XHQmOjotd2Via2l0LXNlYXJjaC1yZXN1bHRzLWJ1dHRvbixcblx0XHQmOjotd2Via2l0LXNlYXJjaC1yZXN1bHRzLWRlY29yYXRpb24ge1xuXHRcdFx0LXdlYmtpdC1hcHBlYXJhbmNlOiBub25lO1xuXHRcdH1cblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEljb24gPSBzdHlsZWQoIEljb24gKWBcblx0JjpkaXIoIGx0ciApIHtcblx0XHR0cmFuc2Zvcm06IHNjYWxlWCggLTEgKTtcblx0fVxuYDtcbiJdfQ== */", 46493 toString: _EMOTION_STRINGIFIED_CSS_ERROR__35 46494 }); 46495 46496 // packages/components/build-module/search-control/index.js 46497 var import_jsx_runtime237 = __toESM(require_jsx_runtime()); 46498 function SuffixItem({ 46499 searchRef, 46500 value, 46501 onChange, 46502 onClose 46503 }) { 46504 if (!onClose && !value) { 46505 return null; 46506 } 46507 if (onClose) { 46508 (0, import_deprecated21.default)("`onClose` prop in wp.components.SearchControl", { 46509 since: "6.8" 46510 }); 46511 } 46512 const onReset = () => { 46513 onChange(""); 46514 searchRef.current?.focus(); 46515 }; 46516 return /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(InputControlSuffixWrapper, { 46517 variant: "control", 46518 children: /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(button_default, { 46519 size: "small", 46520 icon: close_small_default, 46521 label: onClose ? (0, import_i18n64.__)("Close search") : (0, import_i18n64.__)("Reset search"), 46522 onClick: onClose !== null && onClose !== void 0 ? onClose : onReset 46523 }) 46524 }); 46525 } 46526 function UnforwardedSearchControl({ 46527 __nextHasNoMarginBottom: _, 46528 // Prevent passing to internal component 46529 className: className2, 46530 onChange, 46531 value, 46532 label = (0, import_i18n64.__)("Search"), 46533 placeholder = (0, import_i18n64.__)("Search"), 46534 hideLabelFromVision = true, 46535 onClose, 46536 size: size3 = "default", 46537 ...restProps 46538 }, forwardedRef) { 46539 const { 46540 disabled, 46541 ...filteredRestProps 46542 } = restProps; 46543 const searchRef = (0, import_element162.useRef)(null); 46544 const instanceId = (0, import_compose65.useInstanceId)(SearchControl, "components-search-control"); 46545 return /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(StyledInputControl, { 46546 __next40pxDefaultSize: true, 46547 id: instanceId, 46548 hideLabelFromVision, 46549 label, 46550 ref: (0, import_compose65.useMergeRefs)([searchRef, forwardedRef]), 46551 type: "search", 46552 size: size3, 46553 className: clsx_default("components-search-control", className2), 46554 onChange: (nextValue) => onChange(nextValue !== null && nextValue !== void 0 ? nextValue : ""), 46555 autoComplete: "off", 46556 placeholder, 46557 value: value !== null && value !== void 0 ? value : "", 46558 prefix: /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(InputControlPrefixWrapper, { 46559 variant: "icon", 46560 children: /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(StyledIcon, { 46561 icon: search_default, 46562 fill: "currentColor" 46563 }) 46564 }), 46565 suffix: /* @__PURE__ */ (0, import_jsx_runtime237.jsx)(SuffixItem, { 46566 searchRef, 46567 value, 46568 onChange, 46569 onClose 46570 }), 46571 ...filteredRestProps 46572 }); 46573 } 46574 var SearchControl = (0, import_element162.forwardRef)(UnforwardedSearchControl); 46575 var search_control_default = SearchControl; 46576 46577 // packages/components/build-module/navigation/menu/menu-title-search.js 46578 var import_jsx_runtime238 = __toESM(require_jsx_runtime()); 46579 function MenuTitleSearch({ 46580 debouncedSpeak, 46581 onCloseSearch, 46582 onSearch, 46583 search, 46584 title 46585 }) { 46586 const { 46587 navigationTree: { 46588 items 46589 } 46590 } = useNavigationContext(); 46591 const { 46592 menu: menu2 46593 } = useNavigationMenuContext(); 46594 const inputRef = (0, import_element163.useRef)(null); 46595 (0, import_element163.useEffect)(() => { 46596 const delayedFocus = setTimeout(() => { 46597 inputRef.current?.focus(); 46598 }, SEARCH_FOCUS_DELAY); 46599 return () => { 46600 clearTimeout(delayedFocus); 46601 }; 46602 }, []); 46603 (0, import_element163.useEffect)(() => { 46604 if (!search) { 46605 return; 46606 } 46607 const count = Object.values(items).filter((item2) => item2._isVisible).length; 46608 const resultsFoundMessage = (0, import_i18n65.sprintf)( 46609 /* translators: %d: number of results. */ 46610 (0, import_i18n65._n)("%d result found.", "%d results found.", count), 46611 count 46612 ); 46613 debouncedSpeak(resultsFoundMessage); 46614 }, [items, search]); 46615 const onClose = () => { 46616 onSearch?.(""); 46617 onCloseSearch(); 46618 }; 46619 const onKeyDown = (event) => { 46620 if (event.code === "Escape" && !event.defaultPrevented) { 46621 event.preventDefault(); 46622 onClose(); 46623 } 46624 }; 46625 const inputId = `components-navigation__menu-title-search-$menu2}`; 46626 const placeholder = (0, import_i18n65.sprintf)( 46627 /* translators: placeholder for menu search box. %s: menu title */ 46628 (0, import_i18n65.__)("Search %s"), 46629 title?.toLowerCase() || "" 46630 ).trim(); 46631 return /* @__PURE__ */ (0, import_jsx_runtime238.jsx)(MenuTitleSearchControlWrapper, { 46632 children: /* @__PURE__ */ (0, import_jsx_runtime238.jsx)(search_control_default, { 46633 className: "components-navigation__menu-search-input", 46634 id: inputId, 46635 onChange: (value) => onSearch?.(value), 46636 onKeyDown, 46637 placeholder, 46638 onClose, 46639 ref: inputRef, 46640 value: search 46641 }) 46642 }); 46643 } 46644 var menu_title_search_default = with_spoken_messages_default(MenuTitleSearch); 46645 46646 // packages/components/build-module/navigation/menu/menu-title.js 46647 var import_jsx_runtime239 = __toESM(require_jsx_runtime()); 46648 function NavigationMenuTitle({ 46649 hasSearch, 46650 onSearch, 46651 search, 46652 title, 46653 titleAction 46654 }) { 46655 const [isSearching, setIsSearching] = (0, import_element164.useState)(false); 46656 const { 46657 menu: menu2 46658 } = useNavigationMenuContext(); 46659 const searchButtonRef = (0, import_element164.useRef)(null); 46660 if (!title) { 46661 return null; 46662 } 46663 const onCloseSearch = () => { 46664 setIsSearching(false); 46665 setTimeout(() => { 46666 searchButtonRef.current?.focus(); 46667 }, SEARCH_FOCUS_DELAY); 46668 }; 46669 const menuTitleId = `components-navigation__menu-title-$menu2}`; 46670 const searchButtonLabel = (0, import_i18n66.sprintf)((0, import_i18n66.__)("Search in %s"), title); 46671 return /* @__PURE__ */ (0, import_jsx_runtime239.jsxs)(MenuTitleUI, { 46672 className: "components-navigation__menu-title", 46673 children: [!isSearching && /* @__PURE__ */ (0, import_jsx_runtime239.jsxs)(GroupTitleUI, { 46674 as: "h2", 46675 className: "components-navigation__menu-title-heading", 46676 level: 3, 46677 children: [/* @__PURE__ */ (0, import_jsx_runtime239.jsx)("span", { 46678 id: menuTitleId, 46679 children: title 46680 }), (hasSearch || titleAction) && /* @__PURE__ */ (0, import_jsx_runtime239.jsxs)(MenuTitleActionsUI, { 46681 children: [titleAction, hasSearch && /* @__PURE__ */ (0, import_jsx_runtime239.jsx)(button_default, { 46682 size: "small", 46683 variant: "tertiary", 46684 label: searchButtonLabel, 46685 onClick: () => setIsSearching(true), 46686 ref: searchButtonRef, 46687 children: /* @__PURE__ */ (0, import_jsx_runtime239.jsx)(icon_default2, { 46688 icon: search_default 46689 }) 46690 })] 46691 })] 46692 }), isSearching && /* @__PURE__ */ (0, import_jsx_runtime239.jsx)("div", { 46693 className: getAnimateClassName({ 46694 type: "slide-in", 46695 origin: "left" 46696 }), 46697 children: /* @__PURE__ */ (0, import_jsx_runtime239.jsx)(menu_title_search_default, { 46698 onCloseSearch, 46699 onSearch, 46700 search, 46701 title 46702 }) 46703 })] 46704 }); 46705 } 46706 46707 // packages/components/build-module/navigation/menu/search-no-results-found.js 46708 var import_i18n67 = __toESM(require_i18n()); 46709 var import_jsx_runtime240 = __toESM(require_jsx_runtime()); 46710 function NavigationSearchNoResultsFound({ 46711 search 46712 }) { 46713 const { 46714 navigationTree: { 46715 items 46716 } 46717 } = useNavigationContext(); 46718 const resultsCount = Object.values(items).filter((item2) => item2._isVisible).length; 46719 if (!search || !!resultsCount) { 46720 return null; 46721 } 46722 return /* @__PURE__ */ (0, import_jsx_runtime240.jsx)(ItemBaseUI, { 46723 children: /* @__PURE__ */ (0, import_jsx_runtime240.jsxs)(ItemUI, { 46724 children: [(0, import_i18n67.__)("No results found."), " "] 46725 }) 46726 }); 46727 } 46728 46729 // packages/components/build-module/navigation/menu/index.js 46730 var import_jsx_runtime241 = __toESM(require_jsx_runtime()); 46731 function NavigationMenu(props) { 46732 const { 46733 backButtonLabel, 46734 children, 46735 className: className2, 46736 hasSearch, 46737 menu: menu2 = ROOT_MENU, 46738 onBackButtonClick, 46739 onSearch: setControlledSearch, 46740 parentMenu, 46741 search: controlledSearch, 46742 isSearchDebouncing, 46743 title, 46744 titleAction 46745 } = props; 46746 const [uncontrolledSearch, setUncontrolledSearch] = (0, import_element165.useState)(""); 46747 useNavigationTreeMenu(props); 46748 const { 46749 activeMenu 46750 } = useNavigationContext(); 46751 const context = { 46752 menu: menu2, 46753 search: uncontrolledSearch 46754 }; 46755 if (activeMenu !== menu2) { 46756 return /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(NavigationMenuContext.Provider, { 46757 value: context, 46758 children 46759 }); 46760 } 46761 const isControlledSearch = !!setControlledSearch; 46762 const search = isControlledSearch ? controlledSearch : uncontrolledSearch; 46763 const onSearch = isControlledSearch ? setControlledSearch : setUncontrolledSearch; 46764 const menuTitleId = `components-navigation__menu-title-$menu2}`; 46765 const classes = clsx_default("components-navigation__menu", className2); 46766 return /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(NavigationMenuContext.Provider, { 46767 value: context, 46768 children: /* @__PURE__ */ (0, import_jsx_runtime241.jsxs)(MenuUI, { 46769 className: classes, 46770 children: [(parentMenu || onBackButtonClick) && /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(back_button_default, { 46771 backButtonLabel, 46772 parentMenu, 46773 onClick: onBackButtonClick 46774 }), title && /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(NavigationMenuTitle, { 46775 hasSearch, 46776 onSearch, 46777 search, 46778 title, 46779 titleAction 46780 }), /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(menu_default2, { 46781 children: /* @__PURE__ */ (0, import_jsx_runtime241.jsxs)("ul", { 46782 "aria-labelledby": menuTitleId, 46783 children: [children, search && !isSearchDebouncing && /* @__PURE__ */ (0, import_jsx_runtime241.jsx)(NavigationSearchNoResultsFound, { 46784 search 46785 })] 46786 }) 46787 })] 46788 }) 46789 }); 46790 } 46791 var menu_default3 = NavigationMenu; 46792 46793 // packages/components/build-module/navigator/navigator/component.js 46794 var import_element167 = __toESM(require_element()); 46795 var import_is_shallow_equal3 = __toESM(require_is_shallow_equal()); 46796 var import_warning7 = __toESM(require_warning()); 46797 46798 // packages/components/node_modules/path-to-regexp/dist.es2015/index.js 46799 function lexer(str) { 46800 var tokens = []; 46801 var i3 = 0; 46802 while (i3 < str.length) { 46803 var char2 = str[i3]; 46804 if (char2 === "*" || char2 === "+" || char2 === "?") { 46805 tokens.push({ type: "MODIFIER", index: i3, value: str[i3++] }); 46806 continue; 46807 } 46808 if (char2 === "\\") { 46809 tokens.push({ type: "ESCAPED_CHAR", index: i3++, value: str[i3++] }); 46810 continue; 46811 } 46812 if (char2 === "{") { 46813 tokens.push({ type: "OPEN", index: i3, value: str[i3++] }); 46814 continue; 46815 } 46816 if (char2 === "}") { 46817 tokens.push({ type: "CLOSE", index: i3, value: str[i3++] }); 46818 continue; 46819 } 46820 if (char2 === ":") { 46821 var name = ""; 46822 var j2 = i3 + 1; 46823 while (j2 < str.length) { 46824 var code = str.charCodeAt(j2); 46825 if ( 46826 // `0-9` 46827 code >= 48 && code <= 57 || // `A-Z` 46828 code >= 65 && code <= 90 || // `a-z` 46829 code >= 97 && code <= 122 || // `_` 46830 code === 95 46831 ) { 46832 name += str[j2++]; 46833 continue; 46834 } 46835 break; 46836 } 46837 if (!name) 46838 throw new TypeError("Missing parameter name at ".concat(i3)); 46839 tokens.push({ type: "NAME", index: i3, value: name }); 46840 i3 = j2; 46841 continue; 46842 } 46843 if (char2 === "(") { 46844 var count = 1; 46845 var pattern = ""; 46846 var j2 = i3 + 1; 46847 if (str[j2] === "?") { 46848 throw new TypeError('Pattern cannot start with "?" at '.concat(j2)); 46849 } 46850 while (j2 < str.length) { 46851 if (str[j2] === "\\") { 46852 pattern += str[j2++] + str[j2++]; 46853 continue; 46854 } 46855 if (str[j2] === ")") { 46856 count--; 46857 if (count === 0) { 46858 j2++; 46859 break; 46860 } 46861 } else if (str[j2] === "(") { 46862 count++; 46863 if (str[j2 + 1] !== "?") { 46864 throw new TypeError("Capturing groups are not allowed at ".concat(j2)); 46865 } 46866 } 46867 pattern += str[j2++]; 46868 } 46869 if (count) 46870 throw new TypeError("Unbalanced pattern at ".concat(i3)); 46871 if (!pattern) 46872 throw new TypeError("Missing pattern at ".concat(i3)); 46873 tokens.push({ type: "PATTERN", index: i3, value: pattern }); 46874 i3 = j2; 46875 continue; 46876 } 46877 tokens.push({ type: "CHAR", index: i3, value: str[i3++] }); 46878 } 46879 tokens.push({ type: "END", index: i3, value: "" }); 46880 return tokens; 46881 } 46882 function parse3(str, options2) { 46883 if (options2 === void 0) { 46884 options2 = {}; 46885 } 46886 var tokens = lexer(str); 46887 var _a = options2.prefixes, prefixes = _a === void 0 ? "./" : _a, _b = options2.delimiter, delimiter2 = _b === void 0 ? "/#?" : _b; 46888 var result = []; 46889 var key = 0; 46890 var i3 = 0; 46891 var path = ""; 46892 var tryConsume = function(type) { 46893 if (i3 < tokens.length && tokens[i3].type === type) 46894 return tokens[i3++].value; 46895 }; 46896 var mustConsume = function(type) { 46897 var value2 = tryConsume(type); 46898 if (value2 !== void 0) 46899 return value2; 46900 var _a2 = tokens[i3], nextType = _a2.type, index2 = _a2.index; 46901 throw new TypeError("Unexpected ".concat(nextType, " at ").concat(index2, ", expected ").concat(type)); 46902 }; 46903 var consumeText = function() { 46904 var result2 = ""; 46905 var value2; 46906 while (value2 = tryConsume("CHAR") || tryConsume("ESCAPED_CHAR")) { 46907 result2 += value2; 46908 } 46909 return result2; 46910 }; 46911 var isSafe = function(value2) { 46912 for (var _i = 0, delimiter_1 = delimiter2; _i < delimiter_1.length; _i++) { 46913 var char3 = delimiter_1[_i]; 46914 if (value2.indexOf(char3) > -1) 46915 return true; 46916 } 46917 return false; 46918 }; 46919 var safePattern = function(prefix3) { 46920 var prev2 = result[result.length - 1]; 46921 var prevText = prefix3 || (prev2 && typeof prev2 === "string" ? prev2 : ""); 46922 if (prev2 && !prevText) { 46923 throw new TypeError('Must have text between two parameters, missing text after "'.concat(prev2.name, '"')); 46924 } 46925 if (!prevText || isSafe(prevText)) 46926 return "[^".concat(escapeString(delimiter2), "]+?"); 46927 return "(?:(?!".concat(escapeString(prevText), ")[^").concat(escapeString(delimiter2), "])+?"); 46928 }; 46929 while (i3 < tokens.length) { 46930 var char2 = tryConsume("CHAR"); 46931 var name = tryConsume("NAME"); 46932 var pattern = tryConsume("PATTERN"); 46933 if (name || pattern) { 46934 var prefix2 = char2 || ""; 46935 if (prefixes.indexOf(prefix2) === -1) { 46936 path += prefix2; 46937 prefix2 = ""; 46938 } 46939 if (path) { 46940 result.push(path); 46941 path = ""; 46942 } 46943 result.push({ 46944 name: name || key++, 46945 prefix: prefix2, 46946 suffix: "", 46947 pattern: pattern || safePattern(prefix2), 46948 modifier: tryConsume("MODIFIER") || "" 46949 }); 46950 continue; 46951 } 46952 var value = char2 || tryConsume("ESCAPED_CHAR"); 46953 if (value) { 46954 path += value; 46955 continue; 46956 } 46957 if (path) { 46958 result.push(path); 46959 path = ""; 46960 } 46961 var open = tryConsume("OPEN"); 46962 if (open) { 46963 var prefix2 = consumeText(); 46964 var name_1 = tryConsume("NAME") || ""; 46965 var pattern_1 = tryConsume("PATTERN") || ""; 46966 var suffix = consumeText(); 46967 mustConsume("CLOSE"); 46968 result.push({ 46969 name: name_1 || (pattern_1 ? key++ : ""), 46970 pattern: name_1 && !pattern_1 ? safePattern(prefix2) : pattern_1, 46971 prefix: prefix2, 46972 suffix, 46973 modifier: tryConsume("MODIFIER") || "" 46974 }); 46975 continue; 46976 } 46977 mustConsume("END"); 46978 } 46979 return result; 46980 } 46981 function match3(str, options2) { 46982 var keys = []; 46983 var re3 = pathToRegexp(str, keys, options2); 46984 return regexpToFunction(re3, keys, options2); 46985 } 46986 function regexpToFunction(re3, keys, options2) { 46987 if (options2 === void 0) { 46988 options2 = {}; 46989 } 46990 var _a = options2.decode, decode = _a === void 0 ? function(x2) { 46991 return x2; 46992 } : _a; 46993 return function(pathname) { 46994 var m3 = re3.exec(pathname); 46995 if (!m3) 46996 return false; 46997 var path = m3[0], index2 = m3.index; 46998 var params = /* @__PURE__ */ Object.create(null); 46999 var _loop_1 = function(i4) { 47000 if (m3[i4] === void 0) 47001 return "continue"; 47002 var key = keys[i4 - 1]; 47003 if (key.modifier === "*" || key.modifier === "+") { 47004 params[key.name] = m3[i4].split(key.prefix + key.suffix).map(function(value) { 47005 return decode(value, key); 47006 }); 47007 } else { 47008 params[key.name] = decode(m3[i4], key); 47009 } 47010 }; 47011 for (var i3 = 1; i3 < m3.length; i3++) { 47012 _loop_1(i3); 47013 } 47014 return { path, index: index2, params }; 47015 }; 47016 } 47017 function escapeString(str) { 47018 return str.replace(/([.+*?=^!:${}()[\]|/\\])/g, "\\$1"); 47019 } 47020 function flags(options2) { 47021 return options2 && options2.sensitive ? "" : "i"; 47022 } 47023 function regexpToRegexp(path, keys) { 47024 if (!keys) 47025 return path; 47026 var groupsRegex = /\((?:\?<(.*?)>)?(?!\?)/g; 47027 var index2 = 0; 47028 var execResult = groupsRegex.exec(path.source); 47029 while (execResult) { 47030 keys.push({ 47031 // Use parenthesized substring match if available, index otherwise 47032 name: execResult[1] || index2++, 47033 prefix: "", 47034 suffix: "", 47035 modifier: "", 47036 pattern: "" 47037 }); 47038 execResult = groupsRegex.exec(path.source); 47039 } 47040 return path; 47041 } 47042 function arrayToRegexp(paths, keys, options2) { 47043 var parts = paths.map(function(path) { 47044 return pathToRegexp(path, keys, options2).source; 47045 }); 47046 return new RegExp("(?:".concat(parts.join("|"), ")"), flags(options2)); 47047 } 47048 function stringToRegexp(path, keys, options2) { 47049 return tokensToRegexp(parse3(path, options2), keys, options2); 47050 } 47051 function tokensToRegexp(tokens, keys, options2) { 47052 if (options2 === void 0) { 47053 options2 = {}; 47054 } 47055 var _a = options2.strict, strict = _a === void 0 ? false : _a, _b = options2.start, start = _b === void 0 ? true : _b, _c = options2.end, end = _c === void 0 ? true : _c, _d = options2.encode, encode = _d === void 0 ? function(x2) { 47056 return x2; 47057 } : _d, _e2 = options2.delimiter, delimiter2 = _e2 === void 0 ? "/#?" : _e2, _f = options2.endsWith, endsWith2 = _f === void 0 ? "" : _f; 47058 var endsWithRe = "[".concat(escapeString(endsWith2), "]|$"); 47059 var delimiterRe = "[".concat(escapeString(delimiter2), "]"); 47060 var route = start ? "^" : ""; 47061 for (var _i = 0, tokens_1 = tokens; _i < tokens_1.length; _i++) { 47062 var token2 = tokens_1[_i]; 47063 if (typeof token2 === "string") { 47064 route += escapeString(encode(token2)); 47065 } else { 47066 var prefix2 = escapeString(encode(token2.prefix)); 47067 var suffix = escapeString(encode(token2.suffix)); 47068 if (token2.pattern) { 47069 if (keys) 47070 keys.push(token2); 47071 if (prefix2 || suffix) { 47072 if (token2.modifier === "+" || token2.modifier === "*") { 47073 var mod = token2.modifier === "*" ? "?" : ""; 47074 route += "(?:".concat(prefix2, "((?:").concat(token2.pattern, ")(?:").concat(suffix).concat(prefix2, "(?:").concat(token2.pattern, "))*)").concat(suffix, ")").concat(mod); 47075 } else { 47076 route += "(?:".concat(prefix2, "(").concat(token2.pattern, ")").concat(suffix, ")").concat(token2.modifier); 47077 } 47078 } else { 47079 if (token2.modifier === "+" || token2.modifier === "*") { 47080 throw new TypeError('Can not repeat "'.concat(token2.name, '" without a prefix and suffix')); 47081 } 47082 route += "(".concat(token2.pattern, ")").concat(token2.modifier); 47083 } 47084 } else { 47085 route += "(?:".concat(prefix2).concat(suffix, ")").concat(token2.modifier); 47086 } 47087 } 47088 } 47089 if (end) { 47090 if (!strict) 47091 route += "".concat(delimiterRe, "?"); 47092 route += !options2.endsWith ? "$" : "(?=".concat(endsWithRe, ")"); 47093 } else { 47094 var endToken = tokens[tokens.length - 1]; 47095 var isEndDelimited = typeof endToken === "string" ? delimiterRe.indexOf(endToken[endToken.length - 1]) > -1 : endToken === void 0; 47096 if (!strict) { 47097 route += "(?:".concat(delimiterRe, "(?=").concat(endsWithRe, "))?"); 47098 } 47099 if (!isEndDelimited) { 47100 route += "(?=".concat(delimiterRe, "|").concat(endsWithRe, ")"); 47101 } 47102 } 47103 return new RegExp(route, flags(options2)); 47104 } 47105 function pathToRegexp(path, keys, options2) { 47106 if (path instanceof RegExp) 47107 return regexpToRegexp(path, keys); 47108 if (Array.isArray(path)) 47109 return arrayToRegexp(path, keys, options2); 47110 return stringToRegexp(path, keys, options2); 47111 } 47112 47113 // packages/components/build-module/navigator/utils/router.js 47114 function matchPath(path, pattern) { 47115 const matchingFunction = match3(pattern, { 47116 decode: decodeURIComponent 47117 }); 47118 return matchingFunction(path); 47119 } 47120 function patternMatch(path, screens) { 47121 for (const screen of screens) { 47122 const matched = matchPath(path, screen.path); 47123 if (matched) { 47124 return { 47125 params: matched.params, 47126 id: screen.id 47127 }; 47128 } 47129 } 47130 return void 0; 47131 } 47132 function findParent(path, screens) { 47133 if (!path.startsWith("/")) { 47134 return void 0; 47135 } 47136 const pathParts = path.split("/"); 47137 let parentPath; 47138 while (pathParts.length > 1 && parentPath === void 0) { 47139 pathParts.pop(); 47140 const potentialParentPath = pathParts.join("/") === "" ? "/" : pathParts.join("/"); 47141 if (screens.find((screen) => { 47142 return matchPath(potentialParentPath, screen.path) !== false; 47143 })) { 47144 parentPath = potentialParentPath; 47145 } 47146 } 47147 return parentPath; 47148 } 47149 47150 // packages/components/build-module/navigator/context.js 47151 var import_element166 = __toESM(require_element()); 47152 var initialContextValue2 = { 47153 location: {}, 47154 goTo: () => { 47155 }, 47156 goBack: () => { 47157 }, 47158 goToParent: () => { 47159 }, 47160 addScreen: () => { 47161 }, 47162 removeScreen: () => { 47163 }, 47164 params: {} 47165 }; 47166 var NavigatorContext = (0, import_element166.createContext)(initialContextValue2); 47167 NavigatorContext.displayName = "NavigatorContext"; 47168 47169 // packages/components/build-module/navigator/styles.js 47170 function _EMOTION_STRINGIFIED_CSS_ERROR__36() { 47171 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 47172 } 47173 var navigatorWrapper = false ? { 47174 name: "1br0vvk", 47175 styles: "position:relative;overflow-x:clip;contain:layout;display:grid;grid-template-columns:1fr;grid-template-rows:1fr;align-items:start" 47176 } : { 47177 name: "il0xvu-navigatorWrapper", 47178 styles: "position:relative;overflow-x:clip;contain:layout;display:grid;grid-template-columns:1fr;grid-template-rows:1fr;align-items:start;label:navigatorWrapper;", 47179 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLbUMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JXcmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdC8qIFByZXZlbnRzIGhvcml6b250YWwgb3ZlcmZsb3cgd2hpbGUgYW5pbWF0aW5nIHNjcmVlbiB0cmFuc2l0aW9ucyAqL1xuXHRvdmVyZmxvdy14OiBjbGlwO1xuXHQvKlxuXHQgKiBNYXJrIHRoaXMgRE9NIHN1YnRyZWUgYXMgaXNvbGF0ZWQgd2hlbiBpdCBjb21lcyB0byBsYXlvdXQgY2FsY3VsYXRpb25zLFxuXHQgKiBwcm92aWRpbmcgcGVyZm9ybWFuY2UgYmVuZWZpdHMuXG5cdCAqL1xuXHRjb250YWluOiBsYXlvdXQ7XG5cblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnI7XG5cdGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuXHRhbGlnbi1pdGVtczogc3RhcnQ7XG5gO1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdG9wYWNpdHk6IDAsXG5cdH0sXG59ICk7XG5cbmNvbnN0IGZhZGVPdXQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9MZWZ0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtODBweCknLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tTGVmdCA9IGtleWZyYW1lcygge1xuXHRmcm9tOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9SaWdodCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoODBweCknLFxuXHR9LFxufSApO1xuXG5jb25zdCBGQURFID0ge1xuXHREVVJBVElPTjogNzAsXG5cdEVBU0lORzogJ2xpbmVhcicsXG5cdERFTEFZOiB7XG5cdFx0SU46IDcwLFxuXHRcdE9VVDogNDAsXG5cdH0sXG59O1xuY29uc3QgU0xJREUgPSB7XG5cdERVUkFUSU9OOiAzMDAsXG5cdEVBU0lORzogJ2N1YmljLWJlemllcigwLjMzLCAwLCAwLCAxKScsXG59O1xuXG5leHBvcnQgY29uc3QgVE9UQUxfQU5JTUFUSU9OX0RVUkFUSU9OID0ge1xuXHRJTjogTWF0aC5tYXgoIEZBREUuRFVSQVRJT04gKyBGQURFLkRFTEFZLklOLCBTTElERS5EVVJBVElPTiApLFxuXHRPVVQ6IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5PVVQsIFNMSURFLkRVUkFUSU9OICksXG59O1xuXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0VORF9OQU1FUyA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IHNsaWRlRnJvbVJpZ2h0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvTGVmdC5uYW1lLFxuXHR9LFxuXHRzdGFydDoge1xuXHRcdGluOiBzbGlkZUZyb21MZWZ0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvUmlnaHQubmFtZSxcblx0fSxcbn07XG5cbmNvbnN0IEFOSU1BVElPTiA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbVJpZ2h0IH1cblx0XHRgLFxuXHRcdG91dDogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5PVVQgfW1zIGJvdGggJHsgZmFkZU91dCB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZVRvTGVmdCB9XG5cdFx0YCxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5JTiB9bXMgYm90aCAkeyBmYWRlSW4gfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVGcm9tTGVmdCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb1JpZ2h0IH1cblx0XHRgLFxuXHR9LFxufSBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW5BbmltYXRpb24gPSBjc3NgXG5cdHotaW5kZXg6IDE7XG5cblx0JltkYXRhLWFuaW1hdGlvbi10eXBlPSdvdXQnXSB7XG5cdFx0ei1pbmRleDogMDtcblx0fVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCY6bm90KCBbZGF0YS1za2lwLWFuaW1hdGlvbl0gKSB7XG5cdFx0XHQkeyAoIFsgJ3N0YXJ0JywgJ2VuZCcgXSBhcyBjb25zdCApLm1hcCggKCBkaXJlY3Rpb24gKSA9PlxuXHRcdFx0XHQoIFsgJ2luJywgJ291dCcgXSBhcyBjb25zdCApLm1hcChcblx0XHRcdFx0XHQoIHR5cGUgKSA9PiBjc3NgXG5cdFx0XHRcdFx0XHQmW2RhdGEtYW5pbWF0aW9uLWRpcmVjdGlvbj0nJHsgZGlyZWN0aW9uIH0nXVtkYXRhLWFuaW1hdGlvbi10eXBlPSckeyB0eXBlIH0nXSB7XG5cdFx0XHRcdFx0XHRcdGFuaW1hdGlvbjogJHsgQU5JTUFUSU9OWyBkaXJlY3Rpb24gXVsgdHlwZSBdIH07XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0YFxuXHRcdFx0XHQpXG5cdFx0XHQpIH1cblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW4gPSBjc3NgXG5cdC8qIEVuc3VyZXMgaG9yaXpvbnRhbCBvdmVyZmxvdyBpcyB2aXN1YWxseSBhY2Nlc3NpYmxlICovXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdC8qIEluIGNhc2UgdGhlIHJvb3QgaGFzIGEgaGVpZ2h0LCBpdCBzaG91bGQgbm90IGJlIGV4Y2VlZGVkICovXG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdGdyaWQtcm93OiAxIC8gLTE7XG5gO1xuIl19 */", 47180 toString: _EMOTION_STRINGIFIED_CSS_ERROR__36 47181 }; 47182 var fadeIn = keyframes2({ 47183 from: { 47184 opacity: 0 47185 } 47186 }); 47187 var fadeOut = keyframes2({ 47188 to: { 47189 opacity: 0 47190 } 47191 }); 47192 var slideFromRight = keyframes2({ 47193 from: { 47194 transform: "translateX(100px)" 47195 } 47196 }); 47197 var slideToLeft = keyframes2({ 47198 to: { 47199 transform: "translateX(-80px)" 47200 } 47201 }); 47202 var slideFromLeft = keyframes2({ 47203 from: { 47204 transform: "translateX(-100px)" 47205 } 47206 }); 47207 var slideToRight = keyframes2({ 47208 to: { 47209 transform: "translateX(80px)" 47210 } 47211 }); 47212 var FADE = { 47213 DURATION: 70, 47214 EASING: "linear", 47215 DELAY: { 47216 IN: 70, 47217 OUT: 40 47218 } 47219 }; 47220 var SLIDE = { 47221 DURATION: 300, 47222 EASING: "cubic-bezier(0.33, 0, 0, 1)" 47223 }; 47224 var TOTAL_ANIMATION_DURATION = { 47225 IN: Math.max(FADE.DURATION + FADE.DELAY.IN, SLIDE.DURATION), 47226 OUT: Math.max(FADE.DURATION + FADE.DELAY.OUT, SLIDE.DURATION) 47227 }; 47228 var ANIMATION_END_NAMES = { 47229 end: { 47230 in: slideFromRight.name, 47231 out: slideToLeft.name 47232 }, 47233 start: { 47234 in: slideFromLeft.name, 47235 out: slideToRight.name 47236 } 47237 }; 47238 var ANIMATION = { 47239 end: { 47240 in: /* @__PURE__ */ css(FADE.DURATION, "ms ", FADE.EASING, " ", FADE.DELAY.IN, "ms both ", fadeIn, ",", SLIDE.DURATION, "ms ", SLIDE.EASING, " both ", slideFromRight, ";" + (false ? "" : ";label:in;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RlMiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JXcmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdC8qIFByZXZlbnRzIGhvcml6b250YWwgb3ZlcmZsb3cgd2hpbGUgYW5pbWF0aW5nIHNjcmVlbiB0cmFuc2l0aW9ucyAqL1xuXHRvdmVyZmxvdy14OiBjbGlwO1xuXHQvKlxuXHQgKiBNYXJrIHRoaXMgRE9NIHN1YnRyZWUgYXMgaXNvbGF0ZWQgd2hlbiBpdCBjb21lcyB0byBsYXlvdXQgY2FsY3VsYXRpb25zLFxuXHQgKiBwcm92aWRpbmcgcGVyZm9ybWFuY2UgYmVuZWZpdHMuXG5cdCAqL1xuXHRjb250YWluOiBsYXlvdXQ7XG5cblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnI7XG5cdGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuXHRhbGlnbi1pdGVtczogc3RhcnQ7XG5gO1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdG9wYWNpdHk6IDAsXG5cdH0sXG59ICk7XG5cbmNvbnN0IGZhZGVPdXQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9MZWZ0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtODBweCknLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tTGVmdCA9IGtleWZyYW1lcygge1xuXHRmcm9tOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9SaWdodCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoODBweCknLFxuXHR9LFxufSApO1xuXG5jb25zdCBGQURFID0ge1xuXHREVVJBVElPTjogNzAsXG5cdEVBU0lORzogJ2xpbmVhcicsXG5cdERFTEFZOiB7XG5cdFx0SU46IDcwLFxuXHRcdE9VVDogNDAsXG5cdH0sXG59O1xuY29uc3QgU0xJREUgPSB7XG5cdERVUkFUSU9OOiAzMDAsXG5cdEVBU0lORzogJ2N1YmljLWJlemllcigwLjMzLCAwLCAwLCAxKScsXG59O1xuXG5leHBvcnQgY29uc3QgVE9UQUxfQU5JTUFUSU9OX0RVUkFUSU9OID0ge1xuXHRJTjogTWF0aC5tYXgoIEZBREUuRFVSQVRJT04gKyBGQURFLkRFTEFZLklOLCBTTElERS5EVVJBVElPTiApLFxuXHRPVVQ6IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5PVVQsIFNMSURFLkRVUkFUSU9OICksXG59O1xuXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0VORF9OQU1FUyA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IHNsaWRlRnJvbVJpZ2h0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvTGVmdC5uYW1lLFxuXHR9LFxuXHRzdGFydDoge1xuXHRcdGluOiBzbGlkZUZyb21MZWZ0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvUmlnaHQubmFtZSxcblx0fSxcbn07XG5cbmNvbnN0IEFOSU1BVElPTiA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbVJpZ2h0IH1cblx0XHRgLFxuXHRcdG91dDogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5PVVQgfW1zIGJvdGggJHsgZmFkZU91dCB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZVRvTGVmdCB9XG5cdFx0YCxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5JTiB9bXMgYm90aCAkeyBmYWRlSW4gfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVGcm9tTGVmdCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb1JpZ2h0IH1cblx0XHRgLFxuXHR9LFxufSBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW5BbmltYXRpb24gPSBjc3NgXG5cdHotaW5kZXg6IDE7XG5cblx0JltkYXRhLWFuaW1hdGlvbi10eXBlPSdvdXQnXSB7XG5cdFx0ei1pbmRleDogMDtcblx0fVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCY6bm90KCBbZGF0YS1za2lwLWFuaW1hdGlvbl0gKSB7XG5cdFx0XHQkeyAoIFsgJ3N0YXJ0JywgJ2VuZCcgXSBhcyBjb25zdCApLm1hcCggKCBkaXJlY3Rpb24gKSA9PlxuXHRcdFx0XHQoIFsgJ2luJywgJ291dCcgXSBhcyBjb25zdCApLm1hcChcblx0XHRcdFx0XHQoIHR5cGUgKSA9PiBjc3NgXG5cdFx0XHRcdFx0XHQmW2RhdGEtYW5pbWF0aW9uLWRpcmVjdGlvbj0nJHsgZGlyZWN0aW9uIH0nXVtkYXRhLWFuaW1hdGlvbi10eXBlPSckeyB0eXBlIH0nXSB7XG5cdFx0XHRcdFx0XHRcdGFuaW1hdGlvbjogJHsgQU5JTUFUSU9OWyBkaXJlY3Rpb24gXVsgdHlwZSBdIH07XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0YFxuXHRcdFx0XHQpXG5cdFx0XHQpIH1cblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW4gPSBjc3NgXG5cdC8qIEVuc3VyZXMgaG9yaXpvbnRhbCBvdmVyZmxvdyBpcyB2aXN1YWxseSBhY2Nlc3NpYmxlICovXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdC8qIEluIGNhc2UgdGhlIHJvb3QgaGFzIGEgaGVpZ2h0LCBpdCBzaG91bGQgbm90IGJlIGV4Y2VlZGVkICovXG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdGdyaWQtcm93OiAxIC8gLTE7XG5gO1xuIl19 */"), 47241 out: /* @__PURE__ */ css(FADE.DURATION, "ms ", FADE.EASING, " ", FADE.DELAY.OUT, "ms both ", fadeOut, ",", SLIDE.DURATION, "ms ", SLIDE.EASING, " both ", slideToLeft, ";" + (false ? "" : ";label:out;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RlUiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JXcmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdC8qIFByZXZlbnRzIGhvcml6b250YWwgb3ZlcmZsb3cgd2hpbGUgYW5pbWF0aW5nIHNjcmVlbiB0cmFuc2l0aW9ucyAqL1xuXHRvdmVyZmxvdy14OiBjbGlwO1xuXHQvKlxuXHQgKiBNYXJrIHRoaXMgRE9NIHN1YnRyZWUgYXMgaXNvbGF0ZWQgd2hlbiBpdCBjb21lcyB0byBsYXlvdXQgY2FsY3VsYXRpb25zLFxuXHQgKiBwcm92aWRpbmcgcGVyZm9ybWFuY2UgYmVuZWZpdHMuXG5cdCAqL1xuXHRjb250YWluOiBsYXlvdXQ7XG5cblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnI7XG5cdGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuXHRhbGlnbi1pdGVtczogc3RhcnQ7XG5gO1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdG9wYWNpdHk6IDAsXG5cdH0sXG59ICk7XG5cbmNvbnN0IGZhZGVPdXQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9MZWZ0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtODBweCknLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tTGVmdCA9IGtleWZyYW1lcygge1xuXHRmcm9tOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9SaWdodCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoODBweCknLFxuXHR9LFxufSApO1xuXG5jb25zdCBGQURFID0ge1xuXHREVVJBVElPTjogNzAsXG5cdEVBU0lORzogJ2xpbmVhcicsXG5cdERFTEFZOiB7XG5cdFx0SU46IDcwLFxuXHRcdE9VVDogNDAsXG5cdH0sXG59O1xuY29uc3QgU0xJREUgPSB7XG5cdERVUkFUSU9OOiAzMDAsXG5cdEVBU0lORzogJ2N1YmljLWJlemllcigwLjMzLCAwLCAwLCAxKScsXG59O1xuXG5leHBvcnQgY29uc3QgVE9UQUxfQU5JTUFUSU9OX0RVUkFUSU9OID0ge1xuXHRJTjogTWF0aC5tYXgoIEZBREUuRFVSQVRJT04gKyBGQURFLkRFTEFZLklOLCBTTElERS5EVVJBVElPTiApLFxuXHRPVVQ6IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5PVVQsIFNMSURFLkRVUkFUSU9OICksXG59O1xuXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0VORF9OQU1FUyA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IHNsaWRlRnJvbVJpZ2h0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvTGVmdC5uYW1lLFxuXHR9LFxuXHRzdGFydDoge1xuXHRcdGluOiBzbGlkZUZyb21MZWZ0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvUmlnaHQubmFtZSxcblx0fSxcbn07XG5cbmNvbnN0IEFOSU1BVElPTiA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbVJpZ2h0IH1cblx0XHRgLFxuXHRcdG91dDogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5PVVQgfW1zIGJvdGggJHsgZmFkZU91dCB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZVRvTGVmdCB9XG5cdFx0YCxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5JTiB9bXMgYm90aCAkeyBmYWRlSW4gfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVGcm9tTGVmdCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb1JpZ2h0IH1cblx0XHRgLFxuXHR9LFxufSBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW5BbmltYXRpb24gPSBjc3NgXG5cdHotaW5kZXg6IDE7XG5cblx0JltkYXRhLWFuaW1hdGlvbi10eXBlPSdvdXQnXSB7XG5cdFx0ei1pbmRleDogMDtcblx0fVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCY6bm90KCBbZGF0YS1za2lwLWFuaW1hdGlvbl0gKSB7XG5cdFx0XHQkeyAoIFsgJ3N0YXJ0JywgJ2VuZCcgXSBhcyBjb25zdCApLm1hcCggKCBkaXJlY3Rpb24gKSA9PlxuXHRcdFx0XHQoIFsgJ2luJywgJ291dCcgXSBhcyBjb25zdCApLm1hcChcblx0XHRcdFx0XHQoIHR5cGUgKSA9PiBjc3NgXG5cdFx0XHRcdFx0XHQmW2RhdGEtYW5pbWF0aW9uLWRpcmVjdGlvbj0nJHsgZGlyZWN0aW9uIH0nXVtkYXRhLWFuaW1hdGlvbi10eXBlPSckeyB0eXBlIH0nXSB7XG5cdFx0XHRcdFx0XHRcdGFuaW1hdGlvbjogJHsgQU5JTUFUSU9OWyBkaXJlY3Rpb24gXVsgdHlwZSBdIH07XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0YFxuXHRcdFx0XHQpXG5cdFx0XHQpIH1cblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW4gPSBjc3NgXG5cdC8qIEVuc3VyZXMgaG9yaXpvbnRhbCBvdmVyZmxvdyBpcyB2aXN1YWxseSBhY2Nlc3NpYmxlICovXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdC8qIEluIGNhc2UgdGhlIHJvb3QgaGFzIGEgaGVpZ2h0LCBpdCBzaG91bGQgbm90IGJlIGV4Y2VlZGVkICovXG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdGdyaWQtcm93OiAxIC8gLTE7XG5gO1xuIl19 */") 47242 }, 47243 start: { 47244 in: /* @__PURE__ */ css(FADE.DURATION, "ms ", FADE.EASING, " ", FADE.DELAY.IN, "ms both ", fadeIn, ",", SLIDE.DURATION, "ms ", SLIDE.EASING, " both ", slideFromLeft, ";" + (false ? "" : ";label:in;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrR1MiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JXcmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdC8qIFByZXZlbnRzIGhvcml6b250YWwgb3ZlcmZsb3cgd2hpbGUgYW5pbWF0aW5nIHNjcmVlbiB0cmFuc2l0aW9ucyAqL1xuXHRvdmVyZmxvdy14OiBjbGlwO1xuXHQvKlxuXHQgKiBNYXJrIHRoaXMgRE9NIHN1YnRyZWUgYXMgaXNvbGF0ZWQgd2hlbiBpdCBjb21lcyB0byBsYXlvdXQgY2FsY3VsYXRpb25zLFxuXHQgKiBwcm92aWRpbmcgcGVyZm9ybWFuY2UgYmVuZWZpdHMuXG5cdCAqL1xuXHRjb250YWluOiBsYXlvdXQ7XG5cblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnI7XG5cdGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuXHRhbGlnbi1pdGVtczogc3RhcnQ7XG5gO1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdG9wYWNpdHk6IDAsXG5cdH0sXG59ICk7XG5cbmNvbnN0IGZhZGVPdXQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9MZWZ0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtODBweCknLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tTGVmdCA9IGtleWZyYW1lcygge1xuXHRmcm9tOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9SaWdodCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoODBweCknLFxuXHR9LFxufSApO1xuXG5jb25zdCBGQURFID0ge1xuXHREVVJBVElPTjogNzAsXG5cdEVBU0lORzogJ2xpbmVhcicsXG5cdERFTEFZOiB7XG5cdFx0SU46IDcwLFxuXHRcdE9VVDogNDAsXG5cdH0sXG59O1xuY29uc3QgU0xJREUgPSB7XG5cdERVUkFUSU9OOiAzMDAsXG5cdEVBU0lORzogJ2N1YmljLWJlemllcigwLjMzLCAwLCAwLCAxKScsXG59O1xuXG5leHBvcnQgY29uc3QgVE9UQUxfQU5JTUFUSU9OX0RVUkFUSU9OID0ge1xuXHRJTjogTWF0aC5tYXgoIEZBREUuRFVSQVRJT04gKyBGQURFLkRFTEFZLklOLCBTTElERS5EVVJBVElPTiApLFxuXHRPVVQ6IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5PVVQsIFNMSURFLkRVUkFUSU9OICksXG59O1xuXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0VORF9OQU1FUyA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IHNsaWRlRnJvbVJpZ2h0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvTGVmdC5uYW1lLFxuXHR9LFxuXHRzdGFydDoge1xuXHRcdGluOiBzbGlkZUZyb21MZWZ0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvUmlnaHQubmFtZSxcblx0fSxcbn07XG5cbmNvbnN0IEFOSU1BVElPTiA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbVJpZ2h0IH1cblx0XHRgLFxuXHRcdG91dDogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5PVVQgfW1zIGJvdGggJHsgZmFkZU91dCB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZVRvTGVmdCB9XG5cdFx0YCxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5JTiB9bXMgYm90aCAkeyBmYWRlSW4gfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVGcm9tTGVmdCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb1JpZ2h0IH1cblx0XHRgLFxuXHR9LFxufSBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW5BbmltYXRpb24gPSBjc3NgXG5cdHotaW5kZXg6IDE7XG5cblx0JltkYXRhLWFuaW1hdGlvbi10eXBlPSdvdXQnXSB7XG5cdFx0ei1pbmRleDogMDtcblx0fVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCY6bm90KCBbZGF0YS1za2lwLWFuaW1hdGlvbl0gKSB7XG5cdFx0XHQkeyAoIFsgJ3N0YXJ0JywgJ2VuZCcgXSBhcyBjb25zdCApLm1hcCggKCBkaXJlY3Rpb24gKSA9PlxuXHRcdFx0XHQoIFsgJ2luJywgJ291dCcgXSBhcyBjb25zdCApLm1hcChcblx0XHRcdFx0XHQoIHR5cGUgKSA9PiBjc3NgXG5cdFx0XHRcdFx0XHQmW2RhdGEtYW5pbWF0aW9uLWRpcmVjdGlvbj0nJHsgZGlyZWN0aW9uIH0nXVtkYXRhLWFuaW1hdGlvbi10eXBlPSckeyB0eXBlIH0nXSB7XG5cdFx0XHRcdFx0XHRcdGFuaW1hdGlvbjogJHsgQU5JTUFUSU9OWyBkaXJlY3Rpb24gXVsgdHlwZSBdIH07XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0YFxuXHRcdFx0XHQpXG5cdFx0XHQpIH1cblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW4gPSBjc3NgXG5cdC8qIEVuc3VyZXMgaG9yaXpvbnRhbCBvdmVyZmxvdyBpcyB2aXN1YWxseSBhY2Nlc3NpYmxlICovXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdC8qIEluIGNhc2UgdGhlIHJvb3QgaGFzIGEgaGVpZ2h0LCBpdCBzaG91bGQgbm90IGJlIGV4Y2VlZGVkICovXG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdGdyaWQtcm93OiAxIC8gLTE7XG5gO1xuIl19 */"), 47245 out: /* @__PURE__ */ css(FADE.DURATION, "ms ", FADE.EASING, " ", FADE.DELAY.OUT, "ms both ", fadeOut, ",", SLIDE.DURATION, "ms ", SLIDE.EASING, " both ", slideToRight, ";" + (false ? "" : ";label:out;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR1UiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JXcmFwcGVyID0gY3NzYFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdC8qIFByZXZlbnRzIGhvcml6b250YWwgb3ZlcmZsb3cgd2hpbGUgYW5pbWF0aW5nIHNjcmVlbiB0cmFuc2l0aW9ucyAqL1xuXHRvdmVyZmxvdy14OiBjbGlwO1xuXHQvKlxuXHQgKiBNYXJrIHRoaXMgRE9NIHN1YnRyZWUgYXMgaXNvbGF0ZWQgd2hlbiBpdCBjb21lcyB0byBsYXlvdXQgY2FsY3VsYXRpb25zLFxuXHQgKiBwcm92aWRpbmcgcGVyZm9ybWFuY2UgYmVuZWZpdHMuXG5cdCAqL1xuXHRjb250YWluOiBsYXlvdXQ7XG5cblx0ZGlzcGxheTogZ3JpZDtcblx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnI7XG5cdGdyaWQtdGVtcGxhdGUtcm93czogMWZyO1xuXHRhbGlnbi1pdGVtczogc3RhcnQ7XG5gO1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdG9wYWNpdHk6IDAsXG5cdH0sXG59ICk7XG5cbmNvbnN0IGZhZGVPdXQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9MZWZ0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtODBweCknLFxuXHR9LFxufSApO1xuXG5leHBvcnQgY29uc3Qgc2xpZGVGcm9tTGVmdCA9IGtleWZyYW1lcygge1xuXHRmcm9tOiB7XG5cdFx0dHJhbnNmb3JtOiAndHJhbnNsYXRlWCgtMTAwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlVG9SaWdodCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoODBweCknLFxuXHR9LFxufSApO1xuXG5jb25zdCBGQURFID0ge1xuXHREVVJBVElPTjogNzAsXG5cdEVBU0lORzogJ2xpbmVhcicsXG5cdERFTEFZOiB7XG5cdFx0SU46IDcwLFxuXHRcdE9VVDogNDAsXG5cdH0sXG59O1xuY29uc3QgU0xJREUgPSB7XG5cdERVUkFUSU9OOiAzMDAsXG5cdEVBU0lORzogJ2N1YmljLWJlemllcigwLjMzLCAwLCAwLCAxKScsXG59O1xuXG5leHBvcnQgY29uc3QgVE9UQUxfQU5JTUFUSU9OX0RVUkFUSU9OID0ge1xuXHRJTjogTWF0aC5tYXgoIEZBREUuRFVSQVRJT04gKyBGQURFLkRFTEFZLklOLCBTTElERS5EVVJBVElPTiApLFxuXHRPVVQ6IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5PVVQsIFNMSURFLkRVUkFUSU9OICksXG59O1xuXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0VORF9OQU1FUyA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IHNsaWRlRnJvbVJpZ2h0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvTGVmdC5uYW1lLFxuXHR9LFxuXHRzdGFydDoge1xuXHRcdGluOiBzbGlkZUZyb21MZWZ0Lm5hbWUsXG5cdFx0b3V0OiBzbGlkZVRvUmlnaHQubmFtZSxcblx0fSxcbn07XG5cbmNvbnN0IEFOSU1BVElPTiA9IHtcblx0ZW5kOiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbVJpZ2h0IH1cblx0XHRgLFxuXHRcdG91dDogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5PVVQgfW1zIGJvdGggJHsgZmFkZU91dCB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZVRvTGVmdCB9XG5cdFx0YCxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogY3NzYFxuXHRcdFx0JHsgRkFERS5EVVJBVElPTiB9bXMgJHsgRkFERS5FQVNJTkcgfSAkeyBGQURFLkRFTEFZXG5cdFx0XHRcdC5JTiB9bXMgYm90aCAkeyBmYWRlSW4gfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVGcm9tTGVmdCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb1JpZ2h0IH1cblx0XHRgLFxuXHR9LFxufSBhcyBjb25zdDtcbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW5BbmltYXRpb24gPSBjc3NgXG5cdHotaW5kZXg6IDE7XG5cblx0JltkYXRhLWFuaW1hdGlvbi10eXBlPSdvdXQnXSB7XG5cdFx0ei1pbmRleDogMDtcblx0fVxuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdCY6bm90KCBbZGF0YS1za2lwLWFuaW1hdGlvbl0gKSB7XG5cdFx0XHQkeyAoIFsgJ3N0YXJ0JywgJ2VuZCcgXSBhcyBjb25zdCApLm1hcCggKCBkaXJlY3Rpb24gKSA9PlxuXHRcdFx0XHQoIFsgJ2luJywgJ291dCcgXSBhcyBjb25zdCApLm1hcChcblx0XHRcdFx0XHQoIHR5cGUgKSA9PiBjc3NgXG5cdFx0XHRcdFx0XHQmW2RhdGEtYW5pbWF0aW9uLWRpcmVjdGlvbj0nJHsgZGlyZWN0aW9uIH0nXVtkYXRhLWFuaW1hdGlvbi10eXBlPSckeyB0eXBlIH0nXSB7XG5cdFx0XHRcdFx0XHRcdGFuaW1hdGlvbjogJHsgQU5JTUFUSU9OWyBkaXJlY3Rpb24gXVsgdHlwZSBdIH07XG5cdFx0XHRcdFx0XHR9XG5cdFx0XHRcdFx0YFxuXHRcdFx0XHQpXG5cdFx0XHQpIH1cblx0XHR9XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBuYXZpZ2F0b3JTY3JlZW4gPSBjc3NgXG5cdC8qIEVuc3VyZXMgaG9yaXpvbnRhbCBvdmVyZmxvdyBpcyB2aXN1YWxseSBhY2Nlc3NpYmxlICovXG5cdG92ZXJmbG93LXg6IGF1dG87XG5cdC8qIEluIGNhc2UgdGhlIHJvb3QgaGFzIGEgaGVpZ2h0LCBpdCBzaG91bGQgbm90IGJlIGV4Y2VlZGVkICovXG5cdG1heC1oZWlnaHQ6IDEwMCU7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdGdyaWQtcm93OiAxIC8gLTE7XG5gO1xuIl19 */") 47246 } 47247 }; 47248 var navigatorScreenAnimation = /* @__PURE__ */ css("z-index:1;&[data-animation-type='out']{z-index:0;}@media not ( prefers-reduced-motion ){&:not( [data-skip-animation] ){", ["start", "end"].map((direction) => ["in", "out"].map((type) => /* @__PURE__ */ css("&[data-animation-direction='", direction, "'][data-animation-type='", type, "']{animation:", ANIMATION[direction][type], ";}" + (false ? "" : ";label:navigatorScreenAnimation;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1SG9CIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yV3JhcHBlciA9IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHQvKiBQcmV2ZW50cyBob3Jpem9udGFsIG92ZXJmbG93IHdoaWxlIGFuaW1hdGluZyBzY3JlZW4gdHJhbnNpdGlvbnMgKi9cblx0b3ZlcmZsb3cteDogY2xpcDtcblx0Lypcblx0ICogTWFyayB0aGlzIERPTSBzdWJ0cmVlIGFzIGlzb2xhdGVkIHdoZW4gaXQgY29tZXMgdG8gbGF5b3V0IGNhbGN1bGF0aW9ucyxcblx0ICogcHJvdmlkaW5nIHBlcmZvcm1hbmNlIGJlbmVmaXRzLlxuXHQgKi9cblx0Y29udGFpbjogbGF5b3V0O1xuXG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMWZyO1xuXHRncmlkLXRlbXBsYXRlLXJvd3M6IDFmcjtcblx0YWxpZ24taXRlbXM6IHN0YXJ0O1xuYDtcblxuY29uc3QgZmFkZUluID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5jb25zdCBmYWRlT3V0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0b3BhY2l0eTogMCxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbVJpZ2h0ID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvTGVmdCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTgwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbUxlZnQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDgwcHgpJyxcblx0fSxcbn0gKTtcblxuY29uc3QgRkFERSA9IHtcblx0RFVSQVRJT046IDcwLFxuXHRFQVNJTkc6ICdsaW5lYXInLFxuXHRERUxBWToge1xuXHRcdElOOiA3MCxcblx0XHRPVVQ6IDQwLFxuXHR9LFxufTtcbmNvbnN0IFNMSURFID0ge1xuXHREVVJBVElPTjogMzAwLFxuXHRFQVNJTkc6ICdjdWJpYy1iZXppZXIoMC4zMywgMCwgMCwgMSknLFxufTtcblxuZXhwb3J0IGNvbnN0IFRPVEFMX0FOSU1BVElPTl9EVVJBVElPTiA9IHtcblx0SU46IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5JTiwgU0xJREUuRFVSQVRJT04gKSxcblx0T1VUOiBNYXRoLm1heCggRkFERS5EVVJBVElPTiArIEZBREUuREVMQVkuT1VULCBTTElERS5EVVJBVElPTiApLFxufTtcblxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9FTkRfTkFNRVMgPSB7XG5cdGVuZDoge1xuXHRcdGluOiBzbGlkZUZyb21SaWdodC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb0xlZnQubmFtZSxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogc2xpZGVGcm9tTGVmdC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb1JpZ2h0Lm5hbWUsXG5cdH0sXG59O1xuXG5jb25zdCBBTklNQVRJT04gPSB7XG5cdGVuZDoge1xuXHRcdGluOiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0LklOIH1tcyBib3RoICR7IGZhZGVJbiB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZUZyb21SaWdodCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb0xlZnQgfVxuXHRcdGAsXG5cdH0sXG5cdHN0YXJ0OiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbUxlZnQgfVxuXHRcdGAsXG5cdFx0b3V0OiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0Lk9VVCB9bXMgYm90aCAkeyBmYWRlT3V0IH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlVG9SaWdodCB9XG5cdFx0YCxcblx0fSxcbn0gYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuQW5pbWF0aW9uID0gY3NzYFxuXHR6LWluZGV4OiAxO1xuXG5cdCZbZGF0YS1hbmltYXRpb24tdHlwZT0nb3V0J10ge1xuXHRcdHotaW5kZXg6IDA7XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHQmOm5vdCggW2RhdGEtc2tpcC1hbmltYXRpb25dICkge1xuXHRcdFx0JHsgKCBbICdzdGFydCcsICdlbmQnIF0gYXMgY29uc3QgKS5tYXAoICggZGlyZWN0aW9uICkgPT5cblx0XHRcdFx0KCBbICdpbicsICdvdXQnIF0gYXMgY29uc3QgKS5tYXAoXG5cdFx0XHRcdFx0KCB0eXBlICkgPT4gY3NzYFxuXHRcdFx0XHRcdFx0JltkYXRhLWFuaW1hdGlvbi1kaXJlY3Rpb249JyR7IGRpcmVjdGlvbiB9J11bZGF0YS1hbmltYXRpb24tdHlwZT0nJHsgdHlwZSB9J10ge1xuXHRcdFx0XHRcdFx0XHRhbmltYXRpb246ICR7IEFOSU1BVElPTlsgZGlyZWN0aW9uIF1bIHR5cGUgXSB9O1xuXHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdGBcblx0XHRcdFx0KVxuXHRcdFx0KSB9XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuID0gY3NzYFxuXHQvKiBFbnN1cmVzIGhvcml6b250YWwgb3ZlcmZsb3cgaXMgdmlzdWFsbHkgYWNjZXNzaWJsZSAqL1xuXHRvdmVyZmxvdy14OiBhdXRvO1xuXHQvKiBJbiBjYXNlIHRoZSByb290IGhhcyBhIGhlaWdodCwgaXQgc2hvdWxkIG5vdCBiZSBleGNlZWRlZCAqL1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRncmlkLXJvdzogMSAvIC0xO1xuYDtcbiJdfQ== */"))), ";}}" + (false ? "" : ";label:navigatorScreenAnimation;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RzJDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yV3JhcHBlciA9IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHQvKiBQcmV2ZW50cyBob3Jpem9udGFsIG92ZXJmbG93IHdoaWxlIGFuaW1hdGluZyBzY3JlZW4gdHJhbnNpdGlvbnMgKi9cblx0b3ZlcmZsb3cteDogY2xpcDtcblx0Lypcblx0ICogTWFyayB0aGlzIERPTSBzdWJ0cmVlIGFzIGlzb2xhdGVkIHdoZW4gaXQgY29tZXMgdG8gbGF5b3V0IGNhbGN1bGF0aW9ucyxcblx0ICogcHJvdmlkaW5nIHBlcmZvcm1hbmNlIGJlbmVmaXRzLlxuXHQgKi9cblx0Y29udGFpbjogbGF5b3V0O1xuXG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMWZyO1xuXHRncmlkLXRlbXBsYXRlLXJvd3M6IDFmcjtcblx0YWxpZ24taXRlbXM6IHN0YXJ0O1xuYDtcblxuY29uc3QgZmFkZUluID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5jb25zdCBmYWRlT3V0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0b3BhY2l0eTogMCxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbVJpZ2h0ID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvTGVmdCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTgwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbUxlZnQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDgwcHgpJyxcblx0fSxcbn0gKTtcblxuY29uc3QgRkFERSA9IHtcblx0RFVSQVRJT046IDcwLFxuXHRFQVNJTkc6ICdsaW5lYXInLFxuXHRERUxBWToge1xuXHRcdElOOiA3MCxcblx0XHRPVVQ6IDQwLFxuXHR9LFxufTtcbmNvbnN0IFNMSURFID0ge1xuXHREVVJBVElPTjogMzAwLFxuXHRFQVNJTkc6ICdjdWJpYy1iZXppZXIoMC4zMywgMCwgMCwgMSknLFxufTtcblxuZXhwb3J0IGNvbnN0IFRPVEFMX0FOSU1BVElPTl9EVVJBVElPTiA9IHtcblx0SU46IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5JTiwgU0xJREUuRFVSQVRJT04gKSxcblx0T1VUOiBNYXRoLm1heCggRkFERS5EVVJBVElPTiArIEZBREUuREVMQVkuT1VULCBTTElERS5EVVJBVElPTiApLFxufTtcblxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9FTkRfTkFNRVMgPSB7XG5cdGVuZDoge1xuXHRcdGluOiBzbGlkZUZyb21SaWdodC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb0xlZnQubmFtZSxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogc2xpZGVGcm9tTGVmdC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb1JpZ2h0Lm5hbWUsXG5cdH0sXG59O1xuXG5jb25zdCBBTklNQVRJT04gPSB7XG5cdGVuZDoge1xuXHRcdGluOiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0LklOIH1tcyBib3RoICR7IGZhZGVJbiB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZUZyb21SaWdodCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb0xlZnQgfVxuXHRcdGAsXG5cdH0sXG5cdHN0YXJ0OiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbUxlZnQgfVxuXHRcdGAsXG5cdFx0b3V0OiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0Lk9VVCB9bXMgYm90aCAkeyBmYWRlT3V0IH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlVG9SaWdodCB9XG5cdFx0YCxcblx0fSxcbn0gYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuQW5pbWF0aW9uID0gY3NzYFxuXHR6LWluZGV4OiAxO1xuXG5cdCZbZGF0YS1hbmltYXRpb24tdHlwZT0nb3V0J10ge1xuXHRcdHotaW5kZXg6IDA7XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHQmOm5vdCggW2RhdGEtc2tpcC1hbmltYXRpb25dICkge1xuXHRcdFx0JHsgKCBbICdzdGFydCcsICdlbmQnIF0gYXMgY29uc3QgKS5tYXAoICggZGlyZWN0aW9uICkgPT5cblx0XHRcdFx0KCBbICdpbicsICdvdXQnIF0gYXMgY29uc3QgKS5tYXAoXG5cdFx0XHRcdFx0KCB0eXBlICkgPT4gY3NzYFxuXHRcdFx0XHRcdFx0JltkYXRhLWFuaW1hdGlvbi1kaXJlY3Rpb249JyR7IGRpcmVjdGlvbiB9J11bZGF0YS1hbmltYXRpb24tdHlwZT0nJHsgdHlwZSB9J10ge1xuXHRcdFx0XHRcdFx0XHRhbmltYXRpb246ICR7IEFOSU1BVElPTlsgZGlyZWN0aW9uIF1bIHR5cGUgXSB9O1xuXHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdGBcblx0XHRcdFx0KVxuXHRcdFx0KSB9XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuID0gY3NzYFxuXHQvKiBFbnN1cmVzIGhvcml6b250YWwgb3ZlcmZsb3cgaXMgdmlzdWFsbHkgYWNjZXNzaWJsZSAqL1xuXHRvdmVyZmxvdy14OiBhdXRvO1xuXHQvKiBJbiBjYXNlIHRoZSByb290IGhhcyBhIGhlaWdodCwgaXQgc2hvdWxkIG5vdCBiZSBleGNlZWRlZCAqL1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRncmlkLXJvdzogMSAvIC0xO1xuYDtcbiJdfQ== */"); 47249 var navigatorScreen = false ? { 47250 name: "14di7zd", 47251 styles: "overflow-x:auto;max-height:100%;box-sizing:border-box;position:relative;grid-column:1/-1;grid-row:1/-1" 47252 } : { 47253 name: "x0o5tf-navigatorScreen", 47254 styles: "overflow-x:auto;max-height:100%;box-sizing:border-box;position:relative;grid-column:1/-1;grid-row:1/-1;label:navigatorScreen;", 47255 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrSWtDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yV3JhcHBlciA9IGNzc2Bcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHQvKiBQcmV2ZW50cyBob3Jpem9udGFsIG92ZXJmbG93IHdoaWxlIGFuaW1hdGluZyBzY3JlZW4gdHJhbnNpdGlvbnMgKi9cblx0b3ZlcmZsb3cteDogY2xpcDtcblx0Lypcblx0ICogTWFyayB0aGlzIERPTSBzdWJ0cmVlIGFzIGlzb2xhdGVkIHdoZW4gaXQgY29tZXMgdG8gbGF5b3V0IGNhbGN1bGF0aW9ucyxcblx0ICogcHJvdmlkaW5nIHBlcmZvcm1hbmNlIGJlbmVmaXRzLlxuXHQgKi9cblx0Y29udGFpbjogbGF5b3V0O1xuXG5cdGRpc3BsYXk6IGdyaWQ7XG5cdGdyaWQtdGVtcGxhdGUtY29sdW1uczogMWZyO1xuXHRncmlkLXRlbXBsYXRlLXJvd3M6IDFmcjtcblx0YWxpZ24taXRlbXM6IHN0YXJ0O1xuYDtcblxuY29uc3QgZmFkZUluID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHRvcGFjaXR5OiAwLFxuXHR9LFxufSApO1xuXG5jb25zdCBmYWRlT3V0ID0ga2V5ZnJhbWVzKCB7XG5cdHRvOiB7XG5cdFx0b3BhY2l0eTogMCxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbVJpZ2h0ID0ga2V5ZnJhbWVzKCB7XG5cdGZyb206IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvTGVmdCA9IGtleWZyYW1lcygge1xuXHR0bzoge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTgwcHgpJyxcblx0fSxcbn0gKTtcblxuZXhwb3J0IGNvbnN0IHNsaWRlRnJvbUxlZnQgPSBrZXlmcmFtZXMoIHtcblx0ZnJvbToge1xuXHRcdHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoLTEwMHB4KScsXG5cdH0sXG59ICk7XG5cbmV4cG9ydCBjb25zdCBzbGlkZVRvUmlnaHQgPSBrZXlmcmFtZXMoIHtcblx0dG86IHtcblx0XHR0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDgwcHgpJyxcblx0fSxcbn0gKTtcblxuY29uc3QgRkFERSA9IHtcblx0RFVSQVRJT046IDcwLFxuXHRFQVNJTkc6ICdsaW5lYXInLFxuXHRERUxBWToge1xuXHRcdElOOiA3MCxcblx0XHRPVVQ6IDQwLFxuXHR9LFxufTtcbmNvbnN0IFNMSURFID0ge1xuXHREVVJBVElPTjogMzAwLFxuXHRFQVNJTkc6ICdjdWJpYy1iZXppZXIoMC4zMywgMCwgMCwgMSknLFxufTtcblxuZXhwb3J0IGNvbnN0IFRPVEFMX0FOSU1BVElPTl9EVVJBVElPTiA9IHtcblx0SU46IE1hdGgubWF4KCBGQURFLkRVUkFUSU9OICsgRkFERS5ERUxBWS5JTiwgU0xJREUuRFVSQVRJT04gKSxcblx0T1VUOiBNYXRoLm1heCggRkFERS5EVVJBVElPTiArIEZBREUuREVMQVkuT1VULCBTTElERS5EVVJBVElPTiApLFxufTtcblxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9FTkRfTkFNRVMgPSB7XG5cdGVuZDoge1xuXHRcdGluOiBzbGlkZUZyb21SaWdodC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb0xlZnQubmFtZSxcblx0fSxcblx0c3RhcnQ6IHtcblx0XHRpbjogc2xpZGVGcm9tTGVmdC5uYW1lLFxuXHRcdG91dDogc2xpZGVUb1JpZ2h0Lm5hbWUsXG5cdH0sXG59O1xuXG5jb25zdCBBTklNQVRJT04gPSB7XG5cdGVuZDoge1xuXHRcdGluOiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0LklOIH1tcyBib3RoICR7IGZhZGVJbiB9LCAkeyBTTElERS5EVVJBVElPTiB9bXMgJHsgU0xJREUuRUFTSU5HIH0gYm90aCAkeyBzbGlkZUZyb21SaWdodCB9XG5cdFx0YCxcblx0XHRvdXQ6IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuT1VUIH1tcyBib3RoICR7IGZhZGVPdXQgfSwgJHsgU0xJREUuRFVSQVRJT04gfW1zICR7IFNMSURFLkVBU0lORyB9IGJvdGggJHsgc2xpZGVUb0xlZnQgfVxuXHRcdGAsXG5cdH0sXG5cdHN0YXJ0OiB7XG5cdFx0aW46IGNzc2Bcblx0XHRcdCR7IEZBREUuRFVSQVRJT04gfW1zICR7IEZBREUuRUFTSU5HIH0gJHsgRkFERS5ERUxBWVxuXHRcdFx0XHQuSU4gfW1zIGJvdGggJHsgZmFkZUluIH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlRnJvbUxlZnQgfVxuXHRcdGAsXG5cdFx0b3V0OiBjc3NgXG5cdFx0XHQkeyBGQURFLkRVUkFUSU9OIH1tcyAkeyBGQURFLkVBU0lORyB9ICR7IEZBREUuREVMQVlcblx0XHRcdFx0Lk9VVCB9bXMgYm90aCAkeyBmYWRlT3V0IH0sICR7IFNMSURFLkRVUkFUSU9OIH1tcyAkeyBTTElERS5FQVNJTkcgfSBib3RoICR7IHNsaWRlVG9SaWdodCB9XG5cdFx0YCxcblx0fSxcbn0gYXMgY29uc3Q7XG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuQW5pbWF0aW9uID0gY3NzYFxuXHR6LWluZGV4OiAxO1xuXG5cdCZbZGF0YS1hbmltYXRpb24tdHlwZT0nb3V0J10ge1xuXHRcdHotaW5kZXg6IDA7XG5cdH1cblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHQmOm5vdCggW2RhdGEtc2tpcC1hbmltYXRpb25dICkge1xuXHRcdFx0JHsgKCBbICdzdGFydCcsICdlbmQnIF0gYXMgY29uc3QgKS5tYXAoICggZGlyZWN0aW9uICkgPT5cblx0XHRcdFx0KCBbICdpbicsICdvdXQnIF0gYXMgY29uc3QgKS5tYXAoXG5cdFx0XHRcdFx0KCB0eXBlICkgPT4gY3NzYFxuXHRcdFx0XHRcdFx0JltkYXRhLWFuaW1hdGlvbi1kaXJlY3Rpb249JyR7IGRpcmVjdGlvbiB9J11bZGF0YS1hbmltYXRpb24tdHlwZT0nJHsgdHlwZSB9J10ge1xuXHRcdFx0XHRcdFx0XHRhbmltYXRpb246ICR7IEFOSU1BVElPTlsgZGlyZWN0aW9uIF1bIHR5cGUgXSB9O1xuXHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdGBcblx0XHRcdFx0KVxuXHRcdFx0KSB9XG5cdFx0fVxuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgbmF2aWdhdG9yU2NyZWVuID0gY3NzYFxuXHQvKiBFbnN1cmVzIGhvcml6b250YWwgb3ZlcmZsb3cgaXMgdmlzdWFsbHkgYWNjZXNzaWJsZSAqL1xuXHRvdmVyZmxvdy14OiBhdXRvO1xuXHQvKiBJbiBjYXNlIHRoZSByb290IGhhcyBhIGhlaWdodCwgaXQgc2hvdWxkIG5vdCBiZSBleGNlZWRlZCAqL1xuXHRtYXgtaGVpZ2h0OiAxMDAlO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRncmlkLXJvdzogMSAvIC0xO1xuYDtcbiJdfQ== */", 47256 toString: _EMOTION_STRINGIFIED_CSS_ERROR__36 47257 }; 47258 47259 // packages/components/build-module/navigator/navigator/component.js 47260 var import_deprecated22 = __toESM(require_deprecated()); 47261 var import_jsx_runtime242 = __toESM(require_jsx_runtime()); 47262 function addScreen({ 47263 screens 47264 }, screen) { 47265 if (screens.some((s3) => s3.path === screen.path)) { 47266 true ? (0, import_warning7.default)(`Navigator: a screen with path $screen.path} already exists. 47267 The screen with id $screen.id} will not be added.`) : void 0; 47268 return screens; 47269 } 47270 return [...screens, screen]; 47271 } 47272 function removeScreen({ 47273 screens 47274 }, screen) { 47275 return screens.filter((s3) => s3.id !== screen.id); 47276 } 47277 function goTo(state, path, options2 = {}) { 47278 var _focusSelectorsCopy2; 47279 const { 47280 focusSelectors 47281 } = state; 47282 const currentLocation = { 47283 ...state.currentLocation 47284 }; 47285 const { 47286 // Default assignments 47287 isBack = false, 47288 skipFocus = false, 47289 // Extract to avoid forwarding 47290 replace: replace3, 47291 focusTargetSelector, 47292 // Rest 47293 ...restOptions 47294 } = options2; 47295 if (currentLocation.path === path) { 47296 return { 47297 currentLocation, 47298 focusSelectors 47299 }; 47300 } 47301 let focusSelectorsCopy; 47302 function getFocusSelectorsCopy() { 47303 var _focusSelectorsCopy; 47304 focusSelectorsCopy = (_focusSelectorsCopy = focusSelectorsCopy) !== null && _focusSelectorsCopy !== void 0 ? _focusSelectorsCopy : new Map(state.focusSelectors); 47305 return focusSelectorsCopy; 47306 } 47307 if (focusTargetSelector && currentLocation.path) { 47308 getFocusSelectorsCopy().set(currentLocation.path, focusTargetSelector); 47309 } 47310 let currentFocusSelector; 47311 if (focusSelectors.get(path)) { 47312 if (isBack) { 47313 currentFocusSelector = focusSelectors.get(path); 47314 } 47315 getFocusSelectorsCopy().delete(path); 47316 } 47317 return { 47318 currentLocation: { 47319 ...restOptions, 47320 isInitial: false, 47321 path, 47322 isBack, 47323 hasRestoredFocus: false, 47324 focusTargetSelector: currentFocusSelector, 47325 skipFocus 47326 }, 47327 focusSelectors: (_focusSelectorsCopy2 = focusSelectorsCopy) !== null && _focusSelectorsCopy2 !== void 0 ? _focusSelectorsCopy2 : focusSelectors 47328 }; 47329 } 47330 function goToParent(state, options2 = {}) { 47331 const { 47332 screens, 47333 focusSelectors 47334 } = state; 47335 const currentLocation = { 47336 ...state.currentLocation 47337 }; 47338 const currentPath = currentLocation.path; 47339 if (currentPath === void 0) { 47340 return { 47341 currentLocation, 47342 focusSelectors 47343 }; 47344 } 47345 const parentPath = findParent(currentPath, screens); 47346 if (parentPath === void 0) { 47347 return { 47348 currentLocation, 47349 focusSelectors 47350 }; 47351 } 47352 return goTo(state, parentPath, { 47353 ...options2, 47354 isBack: true 47355 }); 47356 } 47357 function routerReducer(state, action) { 47358 let { 47359 screens, 47360 currentLocation, 47361 matchedPath, 47362 focusSelectors, 47363 ...restState 47364 } = state; 47365 switch (action.type) { 47366 case "add": 47367 screens = addScreen(state, action.screen); 47368 break; 47369 case "remove": 47370 screens = removeScreen(state, action.screen); 47371 break; 47372 case "goto": 47373 ({ 47374 currentLocation, 47375 focusSelectors 47376 } = goTo(state, action.path, action.options)); 47377 break; 47378 case "gotoparent": 47379 ({ 47380 currentLocation, 47381 focusSelectors 47382 } = goToParent(state, action.options)); 47383 break; 47384 } 47385 if (screens === state.screens && currentLocation === state.currentLocation) { 47386 return state; 47387 } 47388 const currentPath = currentLocation.path; 47389 matchedPath = currentPath !== void 0 ? patternMatch(currentPath, screens) : void 0; 47390 if (matchedPath && state.matchedPath && matchedPath.id === state.matchedPath.id && (0, import_is_shallow_equal3.default)(matchedPath.params, state.matchedPath.params)) { 47391 matchedPath = state.matchedPath; 47392 } 47393 return { 47394 ...restState, 47395 screens, 47396 currentLocation, 47397 matchedPath, 47398 focusSelectors 47399 }; 47400 } 47401 function UnconnectedNavigator(props, forwardedRef) { 47402 const { 47403 initialPath: initialPathProp, 47404 children, 47405 className: className2, 47406 ...otherProps 47407 } = useContextSystem(props, "Navigator"); 47408 const [routerState, dispatch] = (0, import_element167.useReducer)(routerReducer, initialPathProp, (path) => ({ 47409 screens: [], 47410 currentLocation: { 47411 path, 47412 isInitial: true 47413 }, 47414 matchedPath: void 0, 47415 focusSelectors: /* @__PURE__ */ new Map(), 47416 initialPath: initialPathProp 47417 })); 47418 const methods = (0, import_element167.useMemo)(() => ({ 47419 // Note: calling goBack calls `goToParent` internally, as it was established 47420 // that `goBack` should behave like `goToParent`, and `goToParent` should 47421 // be marked as deprecated. 47422 goBack: (options2) => dispatch({ 47423 type: "gotoparent", 47424 options: options2 47425 }), 47426 goTo: (path, options2) => dispatch({ 47427 type: "goto", 47428 path, 47429 options: options2 47430 }), 47431 goToParent: (options2) => { 47432 (0, import_deprecated22.default)(`wp.components.useNavigator().goToParent`, { 47433 since: "6.7", 47434 alternative: "wp.components.useNavigator().goBack" 47435 }); 47436 dispatch({ 47437 type: "gotoparent", 47438 options: options2 47439 }); 47440 }, 47441 addScreen: (screen) => dispatch({ 47442 type: "add", 47443 screen 47444 }), 47445 removeScreen: (screen) => dispatch({ 47446 type: "remove", 47447 screen 47448 }) 47449 }), []); 47450 const { 47451 currentLocation, 47452 matchedPath 47453 } = routerState; 47454 const navigatorContextValue = (0, import_element167.useMemo)(() => { 47455 var _matchedPath$params; 47456 return { 47457 location: currentLocation, 47458 params: (_matchedPath$params = matchedPath?.params) !== null && _matchedPath$params !== void 0 ? _matchedPath$params : {}, 47459 match: matchedPath?.id, 47460 ...methods 47461 }; 47462 }, [currentLocation, matchedPath, methods]); 47463 const cx3 = useCx(); 47464 const classes = (0, import_element167.useMemo)(() => cx3(navigatorWrapper, className2), [className2, cx3]); 47465 return /* @__PURE__ */ (0, import_jsx_runtime242.jsx)(component_default, { 47466 ref: forwardedRef, 47467 className: classes, 47468 ...otherProps, 47469 children: /* @__PURE__ */ (0, import_jsx_runtime242.jsx)(NavigatorContext.Provider, { 47470 value: navigatorContextValue, 47471 children 47472 }) 47473 }); 47474 } 47475 var Navigator2 = contextConnect(UnconnectedNavigator, "Navigator"); 47476 47477 // packages/components/build-module/navigator/navigator-screen/component.js 47478 var import_dom32 = __toESM(require_dom()); 47479 var import_element169 = __toESM(require_element()); 47480 var import_compose67 = __toESM(require_compose()); 47481 var import_escape_html = __toESM(require_escape_html()); 47482 var import_warning8 = __toESM(require_warning()); 47483 47484 // packages/components/build-module/navigator/navigator-screen/use-screen-animate-presence.js 47485 var import_element168 = __toESM(require_element()); 47486 var import_compose66 = __toESM(require_compose()); 47487 var import_i18n68 = __toESM(require_i18n()); 47488 var ANIMATION_TIMEOUT_MARGIN = 1.2; 47489 var isEnterAnimation = (animationDirection, animationStatus, animationName) => animationStatus === "ANIMATING_IN" && animationName === ANIMATION_END_NAMES[animationDirection].in; 47490 var isExitAnimation = (animationDirection, animationStatus, animationName) => animationStatus === "ANIMATING_OUT" && animationName === ANIMATION_END_NAMES[animationDirection].out; 47491 function useScreenAnimatePresence({ 47492 isMatch, 47493 skipAnimation, 47494 isBack, 47495 onAnimationEnd 47496 }) { 47497 const isRTL23 = (0, import_i18n68.isRTL)(); 47498 const prefersReducedMotion2 = (0, import_compose66.useReducedMotion)(); 47499 const [animationStatus, setAnimationStatus] = (0, import_element168.useState)("INITIAL"); 47500 const becameSelected = animationStatus !== "ANIMATING_IN" && animationStatus !== "IN" && isMatch; 47501 const becameUnselected = animationStatus !== "ANIMATING_OUT" && animationStatus !== "OUT" && !isMatch; 47502 (0, import_element168.useLayoutEffect)(() => { 47503 if (becameSelected) { 47504 setAnimationStatus(skipAnimation || prefersReducedMotion2 ? "IN" : "ANIMATING_IN"); 47505 } else if (becameUnselected) { 47506 setAnimationStatus(skipAnimation || prefersReducedMotion2 ? "OUT" : "ANIMATING_OUT"); 47507 } 47508 }, [becameSelected, becameUnselected, skipAnimation, prefersReducedMotion2]); 47509 const animationDirection = isRTL23 && isBack || !isRTL23 && !isBack ? "end" : "start"; 47510 const isAnimatingIn = animationStatus === "ANIMATING_IN"; 47511 const isAnimatingOut = animationStatus === "ANIMATING_OUT"; 47512 let animationType; 47513 if (isAnimatingIn) { 47514 animationType = "in"; 47515 } else if (isAnimatingOut) { 47516 animationType = "out"; 47517 } 47518 const onScreenAnimationEnd = (0, import_element168.useCallback)((e3) => { 47519 onAnimationEnd?.(e3); 47520 if (isExitAnimation(animationDirection, animationStatus, e3.animationName)) { 47521 setAnimationStatus("OUT"); 47522 } else if (isEnterAnimation(animationDirection, animationStatus, e3.animationName)) { 47523 setAnimationStatus("IN"); 47524 } 47525 }, [onAnimationEnd, animationStatus, animationDirection]); 47526 (0, import_element168.useEffect)(() => { 47527 let animationTimeout; 47528 if (isAnimatingOut) { 47529 animationTimeout = window.setTimeout(() => { 47530 setAnimationStatus("OUT"); 47531 animationTimeout = void 0; 47532 }, TOTAL_ANIMATION_DURATION.OUT * ANIMATION_TIMEOUT_MARGIN); 47533 } else if (isAnimatingIn) { 47534 animationTimeout = window.setTimeout(() => { 47535 setAnimationStatus("IN"); 47536 animationTimeout = void 0; 47537 }, TOTAL_ANIMATION_DURATION.IN * ANIMATION_TIMEOUT_MARGIN); 47538 } 47539 return () => { 47540 if (animationTimeout) { 47541 window.clearTimeout(animationTimeout); 47542 animationTimeout = void 0; 47543 } 47544 }; 47545 }, [isAnimatingOut, isAnimatingIn]); 47546 return { 47547 animationStyles: navigatorScreenAnimation, 47548 // Render the screen's contents in the DOM not only when the screen is 47549 // selected, but also while it is animating out. 47550 shouldRenderScreen: isMatch || animationStatus === "IN" || animationStatus === "ANIMATING_OUT", 47551 screenProps: { 47552 onAnimationEnd: onScreenAnimationEnd, 47553 "data-animation-direction": animationDirection, 47554 "data-animation-type": animationType, 47555 "data-skip-animation": skipAnimation || void 0 47556 } 47557 }; 47558 } 47559 47560 // packages/components/build-module/navigator/navigator-screen/component.js 47561 var import_jsx_runtime243 = __toESM(require_jsx_runtime()); 47562 function UnconnectedNavigatorScreen(props, forwardedRef) { 47563 if (!/^\//.test(props.path)) { 47564 true ? (0, import_warning8.default)("wp.components.Navigator.Screen: the `path` should follow a URL-like scheme; it should start with and be separated by the `/` character.") : void 0; 47565 } 47566 const screenId = (0, import_element169.useId)(); 47567 const { 47568 children, 47569 className: className2, 47570 path, 47571 onAnimationEnd: onAnimationEndProp, 47572 ...otherProps 47573 } = useContextSystem(props, "Navigator.Screen"); 47574 const { 47575 location, 47576 match: match5, 47577 addScreen: addScreen2, 47578 removeScreen: removeScreen2 47579 } = (0, import_element169.useContext)(NavigatorContext); 47580 const { 47581 isInitial, 47582 isBack, 47583 focusTargetSelector, 47584 skipFocus 47585 } = location; 47586 const isMatch = match5 === screenId; 47587 const wrapperRef = (0, import_element169.useRef)(null); 47588 const skipAnimationAndFocusRestoration = !!isInitial && !isBack; 47589 (0, import_element169.useEffect)(() => { 47590 const screen = { 47591 id: screenId, 47592 path: (0, import_escape_html.escapeAttribute)(path) 47593 }; 47594 addScreen2(screen); 47595 return () => removeScreen2(screen); 47596 }, [screenId, path, addScreen2, removeScreen2]); 47597 const { 47598 animationStyles, 47599 shouldRenderScreen, 47600 screenProps 47601 } = useScreenAnimatePresence({ 47602 isMatch, 47603 isBack, 47604 onAnimationEnd: onAnimationEndProp, 47605 skipAnimation: skipAnimationAndFocusRestoration 47606 }); 47607 const cx3 = useCx(); 47608 const classes = (0, import_element169.useMemo)(() => cx3(navigatorScreen, animationStyles, className2), [className2, cx3, animationStyles]); 47609 const locationRef = (0, import_element169.useRef)(location); 47610 (0, import_element169.useEffect)(() => { 47611 locationRef.current = location; 47612 }, [location]); 47613 (0, import_element169.useEffect)(() => { 47614 const wrapperEl = wrapperRef.current; 47615 if (skipAnimationAndFocusRestoration || !isMatch || !wrapperEl || locationRef.current.hasRestoredFocus || skipFocus) { 47616 return; 47617 } 47618 const activeElement = wrapperEl.ownerDocument.activeElement; 47619 if (wrapperEl.contains(activeElement)) { 47620 return; 47621 } 47622 let elementToFocus = null; 47623 if (isBack && focusTargetSelector) { 47624 elementToFocus = wrapperEl.querySelector(focusTargetSelector); 47625 } 47626 if (!elementToFocus) { 47627 const [firstTabbable] = import_dom32.focus.tabbable.find(wrapperEl); 47628 elementToFocus = firstTabbable !== null && firstTabbable !== void 0 ? firstTabbable : wrapperEl; 47629 } 47630 locationRef.current.hasRestoredFocus = true; 47631 elementToFocus.focus(); 47632 }, [skipAnimationAndFocusRestoration, isMatch, isBack, focusTargetSelector, skipFocus]); 47633 const mergedWrapperRef = (0, import_compose67.useMergeRefs)([forwardedRef, wrapperRef]); 47634 return shouldRenderScreen ? /* @__PURE__ */ (0, import_jsx_runtime243.jsx)(component_default, { 47635 ref: mergedWrapperRef, 47636 className: classes, 47637 ...screenProps, 47638 ...otherProps, 47639 children 47640 }) : null; 47641 } 47642 var NavigatorScreen = contextConnect(UnconnectedNavigatorScreen, "Navigator.Screen"); 47643 47644 // packages/components/build-module/navigator/navigator-button/hook.js 47645 var import_element171 = __toESM(require_element()); 47646 var import_escape_html2 = __toESM(require_escape_html()); 47647 47648 // packages/components/build-module/navigator/use-navigator.js 47649 var import_element170 = __toESM(require_element()); 47650 function useNavigator() { 47651 const { 47652 location, 47653 params, 47654 goTo: goTo2, 47655 goBack, 47656 goToParent: goToParent2 47657 } = (0, import_element170.useContext)(NavigatorContext); 47658 return { 47659 location, 47660 goTo: goTo2, 47661 goBack, 47662 goToParent: goToParent2, 47663 params 47664 }; 47665 } 47666 47667 // packages/components/build-module/navigator/navigator-button/hook.js 47668 var cssSelectorForAttribute = (attrName, attrValue) => `[$attrName}="$attrValue}"]`; 47669 function useNavigatorButton(props) { 47670 const { 47671 path, 47672 onClick, 47673 as = button_default, 47674 attributeName = "id", 47675 ...otherProps 47676 } = useContextSystem(props, "Navigator.Button"); 47677 const escapedPath = (0, import_escape_html2.escapeAttribute)(path); 47678 const { 47679 goTo: goTo2 47680 } = useNavigator(); 47681 const handleClick = (0, import_element171.useCallback)((e3) => { 47682 e3.preventDefault(); 47683 goTo2(escapedPath, { 47684 focusTargetSelector: cssSelectorForAttribute(attributeName, escapedPath) 47685 }); 47686 onClick?.(e3); 47687 }, [goTo2, onClick, attributeName, escapedPath]); 47688 return { 47689 as, 47690 onClick: handleClick, 47691 ...otherProps, 47692 [attributeName]: escapedPath 47693 }; 47694 } 47695 47696 // packages/components/build-module/navigator/navigator-button/component.js 47697 var import_jsx_runtime244 = __toESM(require_jsx_runtime()); 47698 function UnconnectedNavigatorButton(props, forwardedRef) { 47699 const navigatorButtonProps = useNavigatorButton(props); 47700 return /* @__PURE__ */ (0, import_jsx_runtime244.jsx)(component_default, { 47701 ref: forwardedRef, 47702 ...navigatorButtonProps 47703 }); 47704 } 47705 var NavigatorButton = contextConnect(UnconnectedNavigatorButton, "Navigator.Button"); 47706 47707 // packages/components/build-module/navigator/navigator-back-button/hook.js 47708 var import_element172 = __toESM(require_element()); 47709 function useNavigatorBackButton(props) { 47710 const { 47711 onClick, 47712 as = button_default, 47713 ...otherProps 47714 } = useContextSystem(props, "Navigator.BackButton"); 47715 const { 47716 goBack 47717 } = useNavigator(); 47718 const handleClick = (0, import_element172.useCallback)((e3) => { 47719 e3.preventDefault(); 47720 goBack(); 47721 onClick?.(e3); 47722 }, [goBack, onClick]); 47723 return { 47724 as, 47725 onClick: handleClick, 47726 ...otherProps 47727 }; 47728 } 47729 47730 // packages/components/build-module/navigator/navigator-back-button/component.js 47731 var import_jsx_runtime245 = __toESM(require_jsx_runtime()); 47732 function UnconnectedNavigatorBackButton(props, forwardedRef) { 47733 const navigatorBackButtonProps = useNavigatorBackButton(props); 47734 return /* @__PURE__ */ (0, import_jsx_runtime245.jsx)(component_default, { 47735 ref: forwardedRef, 47736 ...navigatorBackButtonProps 47737 }); 47738 } 47739 var NavigatorBackButton = contextConnect(UnconnectedNavigatorBackButton, "Navigator.BackButton"); 47740 47741 // packages/components/build-module/navigator/navigator-to-parent-button/component.js 47742 var import_deprecated23 = __toESM(require_deprecated()); 47743 var import_jsx_runtime246 = __toESM(require_jsx_runtime()); 47744 function UnconnectedNavigatorToParentButton(props, forwardedRef) { 47745 (0, import_deprecated23.default)("wp.components.NavigatorToParentButton", { 47746 since: "6.7", 47747 alternative: "wp.components.Navigator.BackButton" 47748 }); 47749 return /* @__PURE__ */ (0, import_jsx_runtime246.jsx)(NavigatorBackButton, { 47750 ref: forwardedRef, 47751 ...props 47752 }); 47753 } 47754 var NavigatorToParentButton = contextConnect(UnconnectedNavigatorToParentButton, "Navigator.ToParentButton"); 47755 47756 // packages/components/build-module/navigator/legacy.js 47757 var NavigatorProvider = Object.assign(Navigator2, { 47758 displayName: "NavigatorProvider" 47759 }); 47760 var NavigatorScreen2 = Object.assign(NavigatorScreen, { 47761 displayName: "NavigatorScreen" 47762 }); 47763 var NavigatorButton2 = Object.assign(NavigatorButton, { 47764 displayName: "NavigatorButton" 47765 }); 47766 var NavigatorBackButton2 = Object.assign(NavigatorBackButton, { 47767 displayName: "NavigatorBackButton" 47768 }); 47769 var NavigatorToParentButton2 = Object.assign(NavigatorToParentButton, { 47770 displayName: "NavigatorToParentButton" 47771 }); 47772 47773 // packages/components/build-module/navigator/index.js 47774 var Navigator3 = Object.assign(Navigator2, { 47775 /** 47776 * The `Navigator.Screen` component represents a single view/screen/panel and 47777 * should be used in combination with the `Navigator`, the `Navigator.Button` 47778 * and the `Navigator.BackButton` components. 47779 * 47780 * @example 47781 * ```jsx 47782 * import { Navigator } from '@wordpress/components'; 47783 * 47784 * const MyNavigation = () => ( 47785 * <Navigator initialPath="/"> 47786 * <Navigator.Screen path="/"> 47787 * <p>This is the home screen.</p> 47788 * <Navigator.Button path="/child"> 47789 * Navigate to child screen. 47790 * </Navigator.Button> 47791 * </Navigator.Screen> 47792 * 47793 * <Navigator.Screen path="/child"> 47794 * <p>This is the child screen.</p> 47795 * <Navigator.BackButton> 47796 * Go back 47797 * </Navigator.BackButton> 47798 * </Navigator.Screen> 47799 * </Navigator> 47800 * ); 47801 * ``` 47802 */ 47803 Screen: Object.assign(NavigatorScreen, { 47804 displayName: "Navigator.Screen" 47805 }), 47806 /** 47807 * The `Navigator.Button` component can be used to navigate to a screen and 47808 * should be used in combination with the `Navigator`, the `Navigator.Screen` 47809 * and the `Navigator.BackButton` components. 47810 * 47811 * @example 47812 * ```jsx 47813 * import { Navigator } from '@wordpress/components'; 47814 * 47815 * const MyNavigation = () => ( 47816 * <Navigator initialPath="/"> 47817 * <Navigator.Screen path="/"> 47818 * <p>This is the home screen.</p> 47819 * <Navigator.Button path="/child"> 47820 * Navigate to child screen. 47821 * </Navigator.Button> 47822 * </Navigator.Screen> 47823 * 47824 * <Navigator.Screen path="/child"> 47825 * <p>This is the child screen.</p> 47826 * <Navigator.BackButton> 47827 * Go back 47828 * </Navigator.BackButton> 47829 * </Navigator.Screen> 47830 * </Navigator> 47831 * ); 47832 * ``` 47833 */ 47834 Button: Object.assign(NavigatorButton, { 47835 displayName: "Navigator.Button" 47836 }), 47837 /** 47838 * The `Navigator.BackButton` component can be used to navigate to a screen and 47839 * should be used in combination with the `Navigator`, the `Navigator.Screen` 47840 * and the `Navigator.Button` components. 47841 * 47842 * @example 47843 * ```jsx 47844 * import { Navigator } from '@wordpress/components'; 47845 * 47846 * const MyNavigation = () => ( 47847 * <Navigator initialPath="/"> 47848 * <Navigator.Screen path="/"> 47849 * <p>This is the home screen.</p> 47850 * <Navigator.Button path="/child"> 47851 * Navigate to child screen. 47852 * </Navigator.Button> 47853 * </Navigator.Screen> 47854 * 47855 * <Navigator.Screen path="/child"> 47856 * <p>This is the child screen.</p> 47857 * <Navigator.BackButton> 47858 * Go back 47859 * </Navigator.BackButton> 47860 * </Navigator.Screen> 47861 * </Navigator> 47862 * ); 47863 * ``` 47864 */ 47865 BackButton: Object.assign(NavigatorBackButton, { 47866 displayName: "Navigator.BackButton" 47867 }) 47868 }); 47869 47870 // packages/components/build-module/notice/index.js 47871 var import_i18n69 = __toESM(require_i18n()); 47872 var import_element173 = __toESM(require_element()); 47873 var import_a11y8 = __toESM(require_a11y()); 47874 var import_jsx_runtime247 = __toESM(require_jsx_runtime()); 47875 var noop20 = () => { 47876 }; 47877 function useSpokenMessage(message3, politeness) { 47878 const spokenMessage = typeof message3 === "string" ? message3 : (0, import_element173.renderToString)(message3); 47879 (0, import_element173.useEffect)(() => { 47880 if (spokenMessage) { 47881 (0, import_a11y8.speak)(spokenMessage, politeness); 47882 } 47883 }, [spokenMessage, politeness]); 47884 } 47885 function getDefaultPoliteness(status) { 47886 switch (status) { 47887 case "success": 47888 case "warning": 47889 case "info": 47890 return "polite"; 47891 // The default will also catch the 'error' status. 47892 default: 47893 return "assertive"; 47894 } 47895 } 47896 function getStatusLabel(status) { 47897 switch (status) { 47898 case "warning": 47899 return (0, import_i18n69.__)("Warning notice"); 47900 case "info": 47901 return (0, import_i18n69.__)("Information notice"); 47902 case "error": 47903 return (0, import_i18n69.__)("Error notice"); 47904 // The default will also catch the 'success' status. 47905 default: 47906 return (0, import_i18n69.__)("Notice"); 47907 } 47908 } 47909 function Notice({ 47910 className: className2, 47911 status = "info", 47912 children, 47913 spokenMessage = children, 47914 onRemove = noop20, 47915 isDismissible = true, 47916 actions = [], 47917 politeness = getDefaultPoliteness(status), 47918 __unstableHTML, 47919 // onDismiss is a callback executed when the notice is dismissed. 47920 // It is distinct from onRemove, which _looks_ like a callback but is 47921 // actually the function to call to remove the notice from the UI. 47922 onDismiss = noop20 47923 }) { 47924 useSpokenMessage(spokenMessage, politeness); 47925 const classes = clsx_default(className2, "components-notice", "is-" + status, { 47926 "is-dismissible": isDismissible 47927 }); 47928 if (__unstableHTML && typeof children === "string") { 47929 children = /* @__PURE__ */ (0, import_jsx_runtime247.jsx)(import_element173.RawHTML, { 47930 children 47931 }); 47932 } 47933 const onDismissNotice = () => { 47934 onDismiss(); 47935 onRemove(); 47936 }; 47937 return /* @__PURE__ */ (0, import_jsx_runtime247.jsxs)("div", { 47938 className: classes, 47939 children: [/* @__PURE__ */ (0, import_jsx_runtime247.jsx)(component_default2, { 47940 children: getStatusLabel(status) 47941 }), /* @__PURE__ */ (0, import_jsx_runtime247.jsxs)("div", { 47942 className: "components-notice__content", 47943 children: [children, actions.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime247.jsx)("div", { 47944 className: "components-notice__actions", 47945 children: actions.map(({ 47946 className: buttonCustomClasses, 47947 label, 47948 isPrimary, 47949 variant, 47950 noDefaultClasses = false, 47951 onClick, 47952 url 47953 }, index2) => { 47954 let computedVariant = variant; 47955 if (variant !== "primary" && !noDefaultClasses) { 47956 computedVariant = !url ? "secondary" : "link"; 47957 } 47958 if (typeof computedVariant === "undefined" && isPrimary) { 47959 computedVariant = "primary"; 47960 } 47961 return /* @__PURE__ */ (0, import_jsx_runtime247.jsx)(button_default, { 47962 __next40pxDefaultSize: true, 47963 href: url, 47964 variant: computedVariant, 47965 onClick: url ? void 0 : onClick, 47966 className: clsx_default("components-notice__action", buttonCustomClasses), 47967 children: label 47968 }, index2); 47969 }) 47970 })] 47971 }), isDismissible && /* @__PURE__ */ (0, import_jsx_runtime247.jsx)(button_default, { 47972 size: "small", 47973 className: "components-notice__dismiss", 47974 icon: close_default, 47975 label: (0, import_i18n69.__)("Close"), 47976 onClick: onDismissNotice 47977 })] 47978 }); 47979 } 47980 var notice_default = Notice; 47981 47982 // packages/components/build-module/notice/list.js 47983 var import_react126 = __toESM(require_react()); 47984 var import_jsx_runtime248 = __toESM(require_jsx_runtime()); 47985 var noop21 = () => { 47986 }; 47987 function NoticeList({ 47988 notices, 47989 onRemove = noop21, 47990 className: className2, 47991 children 47992 }) { 47993 const removeNotice = (id3) => () => onRemove(id3); 47994 className2 = clsx_default("components-notice-list", className2); 47995 return /* @__PURE__ */ (0, import_jsx_runtime248.jsxs)("div", { 47996 className: className2, 47997 children: [children, [...notices].reverse().map((notice) => { 47998 const { 47999 content, 48000 ...restNotice 48001 } = notice; 48002 return /* @__PURE__ */ (0, import_react126.createElement)(notice_default, { 48003 ...restNotice, 48004 key: notice.id, 48005 onRemove: removeNotice(notice.id) 48006 }, notice.content); 48007 })] 48008 }); 48009 } 48010 var list_default = NoticeList; 48011 48012 // packages/components/build-module/panel/index.js 48013 var import_element174 = __toESM(require_element()); 48014 48015 // packages/components/build-module/panel/header.js 48016 var import_jsx_runtime249 = __toESM(require_jsx_runtime()); 48017 function PanelHeader({ 48018 label, 48019 children 48020 }) { 48021 return /* @__PURE__ */ (0, import_jsx_runtime249.jsxs)("div", { 48022 className: "components-panel__header", 48023 children: [label && /* @__PURE__ */ (0, import_jsx_runtime249.jsx)("h2", { 48024 children: label 48025 }), children] 48026 }); 48027 } 48028 var header_default = PanelHeader; 48029 48030 // packages/components/build-module/panel/index.js 48031 var import_jsx_runtime250 = __toESM(require_jsx_runtime()); 48032 function UnforwardedPanel({ 48033 header, 48034 className: className2, 48035 children 48036 }, ref) { 48037 const classNames = clsx_default(className2, "components-panel"); 48038 return /* @__PURE__ */ (0, import_jsx_runtime250.jsxs)("div", { 48039 className: classNames, 48040 ref, 48041 children: [header && /* @__PURE__ */ (0, import_jsx_runtime250.jsx)(header_default, { 48042 label: header 48043 }), children] 48044 }); 48045 } 48046 var Panel = (0, import_element174.forwardRef)(UnforwardedPanel); 48047 var panel_default = Panel; 48048 48049 // packages/components/build-module/panel/body.js 48050 var import_compose68 = __toESM(require_compose()); 48051 var import_element175 = __toESM(require_element()); 48052 var import_jsx_runtime251 = __toESM(require_jsx_runtime()); 48053 var noop22 = () => { 48054 }; 48055 function UnforwardedPanelBody(props, ref) { 48056 const { 48057 buttonProps = {}, 48058 children, 48059 className: className2, 48060 icon, 48061 initialOpen, 48062 onToggle = noop22, 48063 opened, 48064 title, 48065 scrollAfterOpen = true 48066 } = props; 48067 const [isOpened, setIsOpened] = use_controlled_state_default(opened, { 48068 initial: initialOpen === void 0 ? true : initialOpen, 48069 fallback: false 48070 }); 48071 const nodeRef = (0, import_element175.useRef)(null); 48072 const scrollBehavior = (0, import_compose68.useReducedMotion)() ? "auto" : "smooth"; 48073 const handleOnToggle = (event) => { 48074 event.preventDefault(); 48075 const next2 = !isOpened; 48076 setIsOpened(next2); 48077 onToggle(next2); 48078 }; 48079 const scrollAfterOpenRef = (0, import_element175.useRef)(); 48080 scrollAfterOpenRef.current = scrollAfterOpen; 48081 use_update_effect_default(() => { 48082 if (isOpened && scrollAfterOpenRef.current && nodeRef.current?.scrollIntoView) { 48083 nodeRef.current.scrollIntoView({ 48084 inline: "nearest", 48085 block: "nearest", 48086 behavior: scrollBehavior 48087 }); 48088 } 48089 }, [isOpened, scrollBehavior]); 48090 const classes = clsx_default("components-panel__body", className2, { 48091 "is-opened": isOpened 48092 }); 48093 return /* @__PURE__ */ (0, import_jsx_runtime251.jsxs)("div", { 48094 className: classes, 48095 ref: (0, import_compose68.useMergeRefs)([nodeRef, ref]), 48096 children: [/* @__PURE__ */ (0, import_jsx_runtime251.jsx)(PanelBodyTitle, { 48097 icon, 48098 isOpened: Boolean(isOpened), 48099 onClick: handleOnToggle, 48100 title, 48101 ...buttonProps 48102 }), typeof children === "function" ? children({ 48103 opened: Boolean(isOpened) 48104 }) : isOpened && children] 48105 }); 48106 } 48107 var PanelBodyTitle = (0, import_element175.forwardRef)(({ 48108 isOpened, 48109 icon, 48110 title, 48111 ...props 48112 }, ref) => { 48113 if (!title) { 48114 return null; 48115 } 48116 return /* @__PURE__ */ (0, import_jsx_runtime251.jsx)("h2", { 48117 className: "components-panel__body-title", 48118 children: /* @__PURE__ */ (0, import_jsx_runtime251.jsxs)(button_default, { 48119 __next40pxDefaultSize: true, 48120 className: "components-panel__body-toggle", 48121 "aria-expanded": isOpened, 48122 ref, 48123 ...props, 48124 children: [/* @__PURE__ */ (0, import_jsx_runtime251.jsx)("span", { 48125 "aria-hidden": "true", 48126 children: /* @__PURE__ */ (0, import_jsx_runtime251.jsx)(icon_default3, { 48127 className: "components-panel__arrow", 48128 icon: isOpened ? chevron_up_default : chevron_down_default 48129 }) 48130 }), title, icon && /* @__PURE__ */ (0, import_jsx_runtime251.jsx)(icon_default3, { 48131 icon, 48132 className: "components-panel__icon", 48133 size: 20 48134 })] 48135 }) 48136 }); 48137 }); 48138 var PanelBody = (0, import_element175.forwardRef)(UnforwardedPanelBody); 48139 var body_default = PanelBody; 48140 48141 // packages/components/build-module/panel/row.js 48142 var import_element176 = __toESM(require_element()); 48143 var import_jsx_runtime252 = __toESM(require_jsx_runtime()); 48144 function UnforwardedPanelRow({ 48145 className: className2, 48146 children 48147 }, ref) { 48148 return /* @__PURE__ */ (0, import_jsx_runtime252.jsx)("div", { 48149 className: clsx_default("components-panel__row", className2), 48150 ref, 48151 children 48152 }); 48153 } 48154 var PanelRow = (0, import_element176.forwardRef)(UnforwardedPanelRow); 48155 var row_default = PanelRow; 48156 48157 // packages/components/build-module/placeholder/index.js 48158 var import_compose69 = __toESM(require_compose()); 48159 var import_primitives34 = __toESM(require_primitives()); 48160 var import_element177 = __toESM(require_element()); 48161 var import_a11y9 = __toESM(require_a11y()); 48162 var import_jsx_runtime253 = __toESM(require_jsx_runtime()); 48163 var PlaceholderIllustration = /* @__PURE__ */ (0, import_jsx_runtime253.jsx)(import_primitives34.SVG, { 48164 className: "components-placeholder__illustration", 48165 fill: "none", 48166 xmlns: "http://www.w3.org/2000/svg", 48167 viewBox: "0 0 60 60", 48168 preserveAspectRatio: "none", 48169 children: /* @__PURE__ */ (0, import_jsx_runtime253.jsx)(import_primitives34.Path, { 48170 vectorEffect: "non-scaling-stroke", 48171 d: "M60 60 0 0" 48172 }) 48173 }); 48174 function Placeholder(props) { 48175 const { 48176 icon, 48177 children, 48178 label, 48179 instructions, 48180 className: className2, 48181 notices, 48182 preview, 48183 isColumnLayout, 48184 withIllustration, 48185 ...additionalProps 48186 } = props; 48187 const [resizeListener, { 48188 width 48189 }] = (0, import_compose69.useResizeObserver)(); 48190 let modifierClassNames; 48191 if (typeof width === "number") { 48192 modifierClassNames = { 48193 "is-large": width >= 480, 48194 "is-medium": width >= 160 && width < 480, 48195 "is-small": width < 160 48196 }; 48197 } 48198 const classes = clsx_default("components-placeholder", className2, modifierClassNames, withIllustration ? "has-illustration" : null); 48199 const fieldsetClasses = clsx_default("components-placeholder__fieldset", { 48200 "is-column-layout": isColumnLayout 48201 }); 48202 (0, import_element177.useEffect)(() => { 48203 if (instructions) { 48204 (0, import_a11y9.speak)(instructions); 48205 } 48206 }, [instructions]); 48207 return /* @__PURE__ */ (0, import_jsx_runtime253.jsxs)("div", { 48208 ...additionalProps, 48209 className: classes, 48210 children: [withIllustration ? PlaceholderIllustration : null, resizeListener, notices, preview && /* @__PURE__ */ (0, import_jsx_runtime253.jsx)("div", { 48211 className: "components-placeholder__preview", 48212 children: preview 48213 }), /* @__PURE__ */ (0, import_jsx_runtime253.jsxs)("div", { 48214 className: "components-placeholder__label", 48215 children: [/* @__PURE__ */ (0, import_jsx_runtime253.jsx)(icon_default3, { 48216 icon 48217 }), label] 48218 }), !!instructions && /* @__PURE__ */ (0, import_jsx_runtime253.jsx)("div", { 48219 className: "components-placeholder__instructions", 48220 children: instructions 48221 }), /* @__PURE__ */ (0, import_jsx_runtime253.jsx)("div", { 48222 className: fieldsetClasses, 48223 children 48224 })] 48225 }); 48226 } 48227 var placeholder_default = Placeholder; 48228 48229 // packages/components/build-module/progress-bar/index.js 48230 var import_i18n71 = __toESM(require_i18n()); 48231 var import_element178 = __toESM(require_element()); 48232 48233 // packages/components/build-module/progress-bar/styles.js 48234 var import_i18n70 = __toESM(require_i18n()); 48235 function _EMOTION_STRINGIFIED_CSS_ERROR__37() { 48236 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 48237 } 48238 function animateProgressBar(isRtl = false) { 48239 const animationDirection = isRtl ? "right" : "left"; 48240 return keyframes2({ 48241 "0%": { 48242 [animationDirection]: "-50%" 48243 }, 48244 "100%": { 48245 [animationDirection]: "100%" 48246 } 48247 }); 48248 } 48249 var INDETERMINATE_TRACK_WIDTH = 50; 48250 var Track2 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 48251 target: "e15u147w2" 48252 } : { 48253 target: "e15u147w2", 48254 label: "Track" 48255 })("position:relative;overflow:hidden;height:", config_values_default.borderWidthFocus, ";background-color:color-mix(\n in srgb,\n ", COLORS.theme.foreground, ",\n transparent 90%\n );border-radius:", config_values_default.radiusFull, ";outline:2px solid transparent;outline-offset:2px;:where( & ){width:160px;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQytCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgaXNSVEwgfSBmcm9tICdAd29yZHByZXNzL2kxOG4nO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuZnVuY3Rpb24gYW5pbWF0ZVByb2dyZXNzQmFyKCBpc1J0bCA9IGZhbHNlICkge1xuXHRjb25zdCBhbmltYXRpb25EaXJlY3Rpb24gPSBpc1J0bCA/ICdyaWdodCcgOiAnbGVmdCc7XG5cblx0cmV0dXJuIGtleWZyYW1lcygge1xuXHRcdCcwJSc6IHtcblx0XHRcdFsgYW5pbWF0aW9uRGlyZWN0aW9uIF06ICctNTAlJyxcblx0XHR9LFxuXHRcdCcxMDAlJzoge1xuXHRcdFx0WyBhbmltYXRpb25EaXJlY3Rpb24gXTogJzEwMCUnLFxuXHRcdH0sXG5cdH0gKTtcbn1cblxuLy8gV2lkdGggb2YgdGhlIGluZGljYXRvciBmb3IgdGhlIGluZGV0ZXJtaW5hdGUgcHJvZ3Jlc3MgYmFyXG5leHBvcnQgY29uc3QgSU5ERVRFUk1JTkFURV9UUkFDS19XSURUSCA9IDUwO1xuXG5leHBvcnQgY29uc3QgVHJhY2sgPSBzdHlsZWQuZGl2YFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdGhlaWdodDogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfTtcblx0LyogVGV4dCBjb2xvciBhdCAxMCUgb3BhY2l0eSAqL1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiBjb2xvci1taXgoXG5cdFx0aW4gc3JnYixcblx0XHQkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9LFxuXHRcdHRyYW5zcGFyZW50IDkwJVxuXHQpO1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzRnVsbCB9O1xuXG5cdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdG91dGxpbmUtb2Zmc2V0OiAycHg7XG5cblx0OndoZXJlKCAmICkge1xuXHRcdHdpZHRoOiAxNjBweDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IEluZGljYXRvciA9IHN0eWxlZC5kaXY8IHtcblx0aXNJbmRldGVybWluYXRlOiBib29sZWFuO1xufSA+YFxuXHRkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiAwO1xuXHRoZWlnaHQ6IDEwMCU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdC8qIFRleHQgY29sb3IgYXQgOTAlIG9wYWNpdHkgKi9cblx0YmFja2dyb3VuZC1jb2xvcjogY29sb3ItbWl4KFxuXHRcdGluIHNyZ2IsXG5cdFx0JHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfSxcblx0XHR0cmFuc3BhcmVudCAxMCVcblx0KTtcblxuXHQvLyBXaW5kb3dzIGhpZ2ggY29udHJhc3QgbW9kZS5cblx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRvdXRsaW5lLW9mZnNldDogLTJweDtcblxuXHQkeyAoIHsgaXNJbmRldGVybWluYXRlIH0gKSA9PlxuXHRcdGlzSW5kZXRlcm1pbmF0ZVxuXHRcdFx0PyBjc3MoIHtcblx0XHRcdFx0XHRhbmltYXRpb25EdXJhdGlvbjogJzEuNXMnLFxuXHRcdFx0XHRcdGFuaW1hdGlvblRpbWluZ0Z1bmN0aW9uOiAnZWFzZS1pbi1vdXQnLFxuXHRcdFx0XHRcdGFuaW1hdGlvbkl0ZXJhdGlvbkNvdW50OiAnaW5maW5pdGUnLFxuXHRcdFx0XHRcdGFuaW1hdGlvbk5hbWU6IGFuaW1hdGVQcm9ncmVzc0JhciggaXNSVEwoKSApLFxuXHRcdFx0XHRcdHdpZHRoOiBgJHsgSU5ERVRFUk1JTkFURV9UUkFDS19XSURUSCB9JWAsXG5cdFx0XHQgIH0gKVxuXHRcdFx0OiBjc3MoIHtcblx0XHRcdFx0XHR3aWR0aDogJ3ZhcigtLWluZGljYXRvci13aWR0aCknLFxuXHRcdFx0XHRcdHRyYW5zaXRpb246ICd3aWR0aCAwLjRzIGVhc2UtaW4tb3V0Jyxcblx0XHRcdCAgfSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzYFxuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogMDtcblx0bGVmdDogMDtcblx0b3BhY2l0eTogMDtcblx0d2lkdGg6IDEwMCU7XG5cdGhlaWdodDogMTAwJTtcbmA7XG4iXX0= */")); 48256 var _ref9 = false ? { 48257 name: "152sa26", 48258 styles: "width:var(--indicator-width);transition:width 0.4s ease-in-out" 48259 } : { 48260 name: "1ox6xu8-Indicator", 48261 styles: "width:var(--indicator-width);transition:width 0.4s ease-in-out;label:Indicator;", 48262 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRksiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBpc1JUTCB9IGZyb20gJ0B3b3JkcHJlc3MvaTE4bic7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5mdW5jdGlvbiBhbmltYXRlUHJvZ3Jlc3NCYXIoIGlzUnRsID0gZmFsc2UgKSB7XG5cdGNvbnN0IGFuaW1hdGlvbkRpcmVjdGlvbiA9IGlzUnRsID8gJ3JpZ2h0JyA6ICdsZWZ0JztcblxuXHRyZXR1cm4ga2V5ZnJhbWVzKCB7XG5cdFx0JzAlJzoge1xuXHRcdFx0WyBhbmltYXRpb25EaXJlY3Rpb24gXTogJy01MCUnLFxuXHRcdH0sXG5cdFx0JzEwMCUnOiB7XG5cdFx0XHRbIGFuaW1hdGlvbkRpcmVjdGlvbiBdOiAnMTAwJScsXG5cdFx0fSxcblx0fSApO1xufVxuXG4vLyBXaWR0aCBvZiB0aGUgaW5kaWNhdG9yIGZvciB0aGUgaW5kZXRlcm1pbmF0ZSBwcm9ncmVzcyBiYXJcbmV4cG9ydCBjb25zdCBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIID0gNTA7XG5cbmV4cG9ydCBjb25zdCBUcmFjayA9IHN0eWxlZC5kaXZgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0b3ZlcmZsb3c6IGhpZGRlbjtcblx0aGVpZ2h0OiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9O1xuXHQvKiBUZXh0IGNvbG9yIGF0IDEwJSBvcGFjaXR5ICovXG5cdGJhY2tncm91bmQtY29sb3I6IGNvbG9yLW1peChcblx0XHRpbiBzcmdiLFxuXHRcdCR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH0sXG5cdFx0dHJhbnNwYXJlbnQgOTAlXG5cdCk7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cblx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0b3V0bGluZS1vZmZzZXQ6IDJweDtcblxuXHQ6d2hlcmUoICYgKSB7XG5cdFx0d2lkdGg6IDE2MHB4O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yID0gc3R5bGVkLmRpdjwge1xuXHRpc0luZGV0ZXJtaW5hdGU6IGJvb2xlYW47XG59ID5gXG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHR0b3A6IDA7XG5cdGhlaWdodDogMTAwJTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0LyogVGV4dCBjb2xvciBhdCA5MCUgb3BhY2l0eSAqL1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiBjb2xvci1taXgoXG5cdFx0aW4gc3JnYixcblx0XHQkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9LFxuXHRcdHRyYW5zcGFyZW50IDEwJVxuXHQpO1xuXG5cdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdG91dGxpbmUtb2Zmc2V0OiAtMnB4O1xuXG5cdCR7ICggeyBpc0luZGV0ZXJtaW5hdGUgfSApID0+XG5cdFx0aXNJbmRldGVybWluYXRlXG5cdFx0XHQ/IGNzcygge1xuXHRcdFx0XHRcdGFuaW1hdGlvbkR1cmF0aW9uOiAnMS41cycsXG5cdFx0XHRcdFx0YW5pbWF0aW9uVGltaW5nRnVuY3Rpb246ICdlYXNlLWluLW91dCcsXG5cdFx0XHRcdFx0YW5pbWF0aW9uSXRlcmF0aW9uQ291bnQ6ICdpbmZpbml0ZScsXG5cdFx0XHRcdFx0YW5pbWF0aW9uTmFtZTogYW5pbWF0ZVByb2dyZXNzQmFyKCBpc1JUTCgpICksXG5cdFx0XHRcdFx0d2lkdGg6IGAkeyBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIIH0lYCxcblx0XHRcdCAgfSApXG5cdFx0XHQ6IGNzcygge1xuXHRcdFx0XHRcdHdpZHRoOiAndmFyKC0taW5kaWNhdG9yLXdpZHRoKScsXG5cdFx0XHRcdFx0dHJhbnNpdGlvbjogJ3dpZHRoIDAuNHMgZWFzZS1pbi1vdXQnLFxuXHRcdFx0ICB9ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQcm9ncmVzc0VsZW1lbnQgPSBzdHlsZWQucHJvZ3Jlc3NgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiAwO1xuXHRsZWZ0OiAwO1xuXHRvcGFjaXR5OiAwO1xuXHR3aWR0aDogMTAwJTtcblx0aGVpZ2h0OiAxMDAlO1xuYDtcbiJdfQ== */", 48263 toString: _EMOTION_STRINGIFIED_CSS_ERROR__37 48264 }; 48265 var Indicator = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 48266 target: "e15u147w1" 48267 } : { 48268 target: "e15u147w1", 48269 label: "Indicator" 48270 })("display:inline-block;position:absolute;top:0;height:100%;border-radius:", config_values_default.radiusFull, ";background-color:color-mix(\n in srgb,\n ", COLORS.theme.foreground, ",\n transparent 10%\n );outline:2px solid transparent;outline-offset:-2px;", ({ 48271 isIndeterminate 48272 }) => isIndeterminate ? /* @__PURE__ */ css({ 48273 animationDuration: "1.5s", 48274 animationTimingFunction: "ease-in-out", 48275 animationIterationCount: "infinite", 48276 animationName: animateProgressBar((0, import_i18n70.isRTL)()), 48277 width: `$INDETERMINATE_TRACK_WIDTH}%` 48278 }, false ? "" : ";label:Indicator;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRUsiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBpc1JUTCB9IGZyb20gJ0B3b3JkcHJlc3MvaTE4bic7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5mdW5jdGlvbiBhbmltYXRlUHJvZ3Jlc3NCYXIoIGlzUnRsID0gZmFsc2UgKSB7XG5cdGNvbnN0IGFuaW1hdGlvbkRpcmVjdGlvbiA9IGlzUnRsID8gJ3JpZ2h0JyA6ICdsZWZ0JztcblxuXHRyZXR1cm4ga2V5ZnJhbWVzKCB7XG5cdFx0JzAlJzoge1xuXHRcdFx0WyBhbmltYXRpb25EaXJlY3Rpb24gXTogJy01MCUnLFxuXHRcdH0sXG5cdFx0JzEwMCUnOiB7XG5cdFx0XHRbIGFuaW1hdGlvbkRpcmVjdGlvbiBdOiAnMTAwJScsXG5cdFx0fSxcblx0fSApO1xufVxuXG4vLyBXaWR0aCBvZiB0aGUgaW5kaWNhdG9yIGZvciB0aGUgaW5kZXRlcm1pbmF0ZSBwcm9ncmVzcyBiYXJcbmV4cG9ydCBjb25zdCBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIID0gNTA7XG5cbmV4cG9ydCBjb25zdCBUcmFjayA9IHN0eWxlZC5kaXZgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0b3ZlcmZsb3c6IGhpZGRlbjtcblx0aGVpZ2h0OiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9O1xuXHQvKiBUZXh0IGNvbG9yIGF0IDEwJSBvcGFjaXR5ICovXG5cdGJhY2tncm91bmQtY29sb3I6IGNvbG9yLW1peChcblx0XHRpbiBzcmdiLFxuXHRcdCR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH0sXG5cdFx0dHJhbnNwYXJlbnQgOTAlXG5cdCk7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cblx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0b3V0bGluZS1vZmZzZXQ6IDJweDtcblxuXHQ6d2hlcmUoICYgKSB7XG5cdFx0d2lkdGg6IDE2MHB4O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yID0gc3R5bGVkLmRpdjwge1xuXHRpc0luZGV0ZXJtaW5hdGU6IGJvb2xlYW47XG59ID5gXG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHR0b3A6IDA7XG5cdGhlaWdodDogMTAwJTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0LyogVGV4dCBjb2xvciBhdCA5MCUgb3BhY2l0eSAqL1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiBjb2xvci1taXgoXG5cdFx0aW4gc3JnYixcblx0XHQkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9LFxuXHRcdHRyYW5zcGFyZW50IDEwJVxuXHQpO1xuXG5cdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdG91dGxpbmUtb2Zmc2V0OiAtMnB4O1xuXG5cdCR7ICggeyBpc0luZGV0ZXJtaW5hdGUgfSApID0+XG5cdFx0aXNJbmRldGVybWluYXRlXG5cdFx0XHQ/IGNzcygge1xuXHRcdFx0XHRcdGFuaW1hdGlvbkR1cmF0aW9uOiAnMS41cycsXG5cdFx0XHRcdFx0YW5pbWF0aW9uVGltaW5nRnVuY3Rpb246ICdlYXNlLWluLW91dCcsXG5cdFx0XHRcdFx0YW5pbWF0aW9uSXRlcmF0aW9uQ291bnQ6ICdpbmZpbml0ZScsXG5cdFx0XHRcdFx0YW5pbWF0aW9uTmFtZTogYW5pbWF0ZVByb2dyZXNzQmFyKCBpc1JUTCgpICksXG5cdFx0XHRcdFx0d2lkdGg6IGAkeyBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIIH0lYCxcblx0XHRcdCAgfSApXG5cdFx0XHQ6IGNzcygge1xuXHRcdFx0XHRcdHdpZHRoOiAndmFyKC0taW5kaWNhdG9yLXdpZHRoKScsXG5cdFx0XHRcdFx0dHJhbnNpdGlvbjogJ3dpZHRoIDAuNHMgZWFzZS1pbi1vdXQnLFxuXHRcdFx0ICB9ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQcm9ncmVzc0VsZW1lbnQgPSBzdHlsZWQucHJvZ3Jlc3NgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiAwO1xuXHRsZWZ0OiAwO1xuXHRvcGFjaXR5OiAwO1xuXHR3aWR0aDogMTAwJTtcblx0aGVpZ2h0OiAxMDAlO1xuYDtcbiJdfQ== */") : _ref9, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1REciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogV29yZFByZXNzIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBpc1JUTCB9IGZyb20gJ0B3b3JkcHJlc3MvaTE4bic7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IENPTE9SUywgQ09ORklHIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5mdW5jdGlvbiBhbmltYXRlUHJvZ3Jlc3NCYXIoIGlzUnRsID0gZmFsc2UgKSB7XG5cdGNvbnN0IGFuaW1hdGlvbkRpcmVjdGlvbiA9IGlzUnRsID8gJ3JpZ2h0JyA6ICdsZWZ0JztcblxuXHRyZXR1cm4ga2V5ZnJhbWVzKCB7XG5cdFx0JzAlJzoge1xuXHRcdFx0WyBhbmltYXRpb25EaXJlY3Rpb24gXTogJy01MCUnLFxuXHRcdH0sXG5cdFx0JzEwMCUnOiB7XG5cdFx0XHRbIGFuaW1hdGlvbkRpcmVjdGlvbiBdOiAnMTAwJScsXG5cdFx0fSxcblx0fSApO1xufVxuXG4vLyBXaWR0aCBvZiB0aGUgaW5kaWNhdG9yIGZvciB0aGUgaW5kZXRlcm1pbmF0ZSBwcm9ncmVzcyBiYXJcbmV4cG9ydCBjb25zdCBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIID0gNTA7XG5cbmV4cG9ydCBjb25zdCBUcmFjayA9IHN0eWxlZC5kaXZgXG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0b3ZlcmZsb3c6IGhpZGRlbjtcblx0aGVpZ2h0OiAkeyBDT05GSUcuYm9yZGVyV2lkdGhGb2N1cyB9O1xuXHQvKiBUZXh0IGNvbG9yIGF0IDEwJSBvcGFjaXR5ICovXG5cdGJhY2tncm91bmQtY29sb3I6IGNvbG9yLW1peChcblx0XHRpbiBzcmdiLFxuXHRcdCR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH0sXG5cdFx0dHJhbnNwYXJlbnQgOTAlXG5cdCk7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cblx0Ly8gV2luZG93cyBoaWdoIGNvbnRyYXN0IG1vZGUuXG5cdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcblx0b3V0bGluZS1vZmZzZXQ6IDJweDtcblxuXHQ6d2hlcmUoICYgKSB7XG5cdFx0d2lkdGg6IDE2MHB4O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgSW5kaWNhdG9yID0gc3R5bGVkLmRpdjwge1xuXHRpc0luZGV0ZXJtaW5hdGU6IGJvb2xlYW47XG59ID5gXG5cdGRpc3BsYXk6IGlubGluZS1ibG9jaztcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHR0b3A6IDA7XG5cdGhlaWdodDogMTAwJTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c0Z1bGwgfTtcblx0LyogVGV4dCBjb2xvciBhdCA5MCUgb3BhY2l0eSAqL1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiBjb2xvci1taXgoXG5cdFx0aW4gc3JnYixcblx0XHQkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9LFxuXHRcdHRyYW5zcGFyZW50IDEwJVxuXHQpO1xuXG5cdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdG91dGxpbmUtb2Zmc2V0OiAtMnB4O1xuXG5cdCR7ICggeyBpc0luZGV0ZXJtaW5hdGUgfSApID0+XG5cdFx0aXNJbmRldGVybWluYXRlXG5cdFx0XHQ/IGNzcygge1xuXHRcdFx0XHRcdGFuaW1hdGlvbkR1cmF0aW9uOiAnMS41cycsXG5cdFx0XHRcdFx0YW5pbWF0aW9uVGltaW5nRnVuY3Rpb246ICdlYXNlLWluLW91dCcsXG5cdFx0XHRcdFx0YW5pbWF0aW9uSXRlcmF0aW9uQ291bnQ6ICdpbmZpbml0ZScsXG5cdFx0XHRcdFx0YW5pbWF0aW9uTmFtZTogYW5pbWF0ZVByb2dyZXNzQmFyKCBpc1JUTCgpICksXG5cdFx0XHRcdFx0d2lkdGg6IGAkeyBJTkRFVEVSTUlOQVRFX1RSQUNLX1dJRFRIIH0lYCxcblx0XHRcdCAgfSApXG5cdFx0XHQ6IGNzcygge1xuXHRcdFx0XHRcdHdpZHRoOiAndmFyKC0taW5kaWNhdG9yLXdpZHRoKScsXG5cdFx0XHRcdFx0dHJhbnNpdGlvbjogJ3dpZHRoIDAuNHMgZWFzZS1pbi1vdXQnLFxuXHRcdFx0ICB9ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBQcm9ncmVzc0VsZW1lbnQgPSBzdHlsZWQucHJvZ3Jlc3NgXG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiAwO1xuXHRsZWZ0OiAwO1xuXHRvcGFjaXR5OiAwO1xuXHR3aWR0aDogMTAwJTtcblx0aGVpZ2h0OiAxMDAlO1xuYDtcbiJdfQ== */")); 48279 var ProgressElement = /* @__PURE__ */ emotion_styled_base_browser_esm_default("progress", false ? { 48280 target: "e15u147w0" 48281 } : { 48282 target: "e15u147w0", 48283 label: "ProgressElement" 48284 })(false ? { 48285 name: "11fb690", 48286 styles: "position:absolute;top:0;left:0;opacity:0;width:100%;height:100%" 48287 } : { 48288 name: "11fb690", 48289 styles: "position:absolute;top:0;left:0;opacity:0;width:100%;height:100%", 48290 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RjhDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIFdvcmRQcmVzcyBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgaXNSVEwgfSBmcm9tICdAd29yZHByZXNzL2kxOG4nO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uL3V0aWxzJztcblxuZnVuY3Rpb24gYW5pbWF0ZVByb2dyZXNzQmFyKCBpc1J0bCA9IGZhbHNlICkge1xuXHRjb25zdCBhbmltYXRpb25EaXJlY3Rpb24gPSBpc1J0bCA/ICdyaWdodCcgOiAnbGVmdCc7XG5cblx0cmV0dXJuIGtleWZyYW1lcygge1xuXHRcdCcwJSc6IHtcblx0XHRcdFsgYW5pbWF0aW9uRGlyZWN0aW9uIF06ICctNTAlJyxcblx0XHR9LFxuXHRcdCcxMDAlJzoge1xuXHRcdFx0WyBhbmltYXRpb25EaXJlY3Rpb24gXTogJzEwMCUnLFxuXHRcdH0sXG5cdH0gKTtcbn1cblxuLy8gV2lkdGggb2YgdGhlIGluZGljYXRvciBmb3IgdGhlIGluZGV0ZXJtaW5hdGUgcHJvZ3Jlc3MgYmFyXG5leHBvcnQgY29uc3QgSU5ERVRFUk1JTkFURV9UUkFDS19XSURUSCA9IDUwO1xuXG5leHBvcnQgY29uc3QgVHJhY2sgPSBzdHlsZWQuZGl2YFxuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdG92ZXJmbG93OiBoaWRkZW47XG5cdGhlaWdodDogJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfTtcblx0LyogVGV4dCBjb2xvciBhdCAxMCUgb3BhY2l0eSAqL1xuXHRiYWNrZ3JvdW5kLWNvbG9yOiBjb2xvci1taXgoXG5cdFx0aW4gc3JnYixcblx0XHQkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZCB9LFxuXHRcdHRyYW5zcGFyZW50IDkwJVxuXHQpO1xuXHRib3JkZXItcmFkaXVzOiAkeyBDT05GSUcucmFkaXVzRnVsbCB9O1xuXG5cdC8vIFdpbmRvd3MgaGlnaCBjb250cmFzdCBtb2RlLlxuXHRvdXRsaW5lOiAycHggc29saWQgdHJhbnNwYXJlbnQ7XG5cdG91dGxpbmUtb2Zmc2V0OiAycHg7XG5cblx0OndoZXJlKCAmICkge1xuXHRcdHdpZHRoOiAxNjBweDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IEluZGljYXRvciA9IHN0eWxlZC5kaXY8IHtcblx0aXNJbmRldGVybWluYXRlOiBib29sZWFuO1xufSA+YFxuXHRkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG5cdHBvc2l0aW9uOiBhYnNvbHV0ZTtcblx0dG9wOiAwO1xuXHRoZWlnaHQ6IDEwMCU7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNGdWxsIH07XG5cdC8qIFRleHQgY29sb3IgYXQgOTAlIG9wYWNpdHkgKi9cblx0YmFja2dyb3VuZC1jb2xvcjogY29sb3ItbWl4KFxuXHRcdGluIHNyZ2IsXG5cdFx0JHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfSxcblx0XHR0cmFuc3BhcmVudCAxMCVcblx0KTtcblxuXHQvLyBXaW5kb3dzIGhpZ2ggY29udHJhc3QgbW9kZS5cblx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuXHRvdXRsaW5lLW9mZnNldDogLTJweDtcblxuXHQkeyAoIHsgaXNJbmRldGVybWluYXRlIH0gKSA9PlxuXHRcdGlzSW5kZXRlcm1pbmF0ZVxuXHRcdFx0PyBjc3MoIHtcblx0XHRcdFx0XHRhbmltYXRpb25EdXJhdGlvbjogJzEuNXMnLFxuXHRcdFx0XHRcdGFuaW1hdGlvblRpbWluZ0Z1bmN0aW9uOiAnZWFzZS1pbi1vdXQnLFxuXHRcdFx0XHRcdGFuaW1hdGlvbkl0ZXJhdGlvbkNvdW50OiAnaW5maW5pdGUnLFxuXHRcdFx0XHRcdGFuaW1hdGlvbk5hbWU6IGFuaW1hdGVQcm9ncmVzc0JhciggaXNSVEwoKSApLFxuXHRcdFx0XHRcdHdpZHRoOiBgJHsgSU5ERVRFUk1JTkFURV9UUkFDS19XSURUSCB9JWAsXG5cdFx0XHQgIH0gKVxuXHRcdFx0OiBjc3MoIHtcblx0XHRcdFx0XHR3aWR0aDogJ3ZhcigtLWluZGljYXRvci13aWR0aCknLFxuXHRcdFx0XHRcdHRyYW5zaXRpb246ICd3aWR0aCAwLjRzIGVhc2UtaW4tb3V0Jyxcblx0XHRcdCAgfSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgUHJvZ3Jlc3NFbGVtZW50ID0gc3R5bGVkLnByb2dyZXNzYFxuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHRvcDogMDtcblx0bGVmdDogMDtcblx0b3BhY2l0eTogMDtcblx0d2lkdGg6IDEwMCU7XG5cdGhlaWdodDogMTAwJTtcbmA7XG4iXX0= */", 48291 toString: _EMOTION_STRINGIFIED_CSS_ERROR__37 48292 }); 48293 48294 // packages/components/build-module/progress-bar/index.js 48295 var import_jsx_runtime254 = __toESM(require_jsx_runtime()); 48296 function UnforwardedProgressBar(props, ref) { 48297 const { 48298 className: className2, 48299 value, 48300 ...progressProps 48301 } = props; 48302 const isIndeterminate = !Number.isFinite(value); 48303 return /* @__PURE__ */ (0, import_jsx_runtime254.jsxs)(Track2, { 48304 className: className2, 48305 children: [/* @__PURE__ */ (0, import_jsx_runtime254.jsx)(Indicator, { 48306 style: { 48307 "--indicator-width": !isIndeterminate ? `$value}%` : void 0 48308 }, 48309 isIndeterminate 48310 }), /* @__PURE__ */ (0, import_jsx_runtime254.jsx)(ProgressElement, { 48311 max: 100, 48312 value, 48313 "aria-label": (0, import_i18n71.__)("Loading \u2026"), 48314 ref, 48315 ...progressProps 48316 })] 48317 }); 48318 } 48319 var ProgressBar = (0, import_element178.forwardRef)(UnforwardedProgressBar); 48320 var progress_bar_default = ProgressBar; 48321 48322 // packages/components/build-module/query-controls/index.js 48323 var import_i18n72 = __toESM(require_i18n()); 48324 48325 // packages/components/build-module/query-controls/terms.js 48326 var ensureParentsAreDefined = (terms) => { 48327 return terms.every((term) => term.parent !== null); 48328 }; 48329 function buildTermsTree(flatTerms) { 48330 const flatTermsWithParentAndChildren = flatTerms.map((term) => ({ 48331 children: [], 48332 parent: null, 48333 ...term, 48334 id: String(term.id) 48335 })); 48336 if (!ensureParentsAreDefined(flatTermsWithParentAndChildren)) { 48337 return flatTermsWithParentAndChildren; 48338 } 48339 const termsByParent = flatTermsWithParentAndChildren.reduce((acc, term) => { 48340 const { 48341 parent 48342 } = term; 48343 if (!acc[parent]) { 48344 acc[parent] = []; 48345 } 48346 acc[parent].push(term); 48347 return acc; 48348 }, {}); 48349 const fillWithChildren = (terms) => { 48350 return terms.map((term) => { 48351 const children = termsByParent[term.id]; 48352 return { 48353 ...term, 48354 children: children && children.length ? fillWithChildren(children) : [] 48355 }; 48356 }); 48357 }; 48358 return fillWithChildren(termsByParent["0"] || []); 48359 } 48360 48361 // packages/components/build-module/tree-select/index.js 48362 var import_element179 = __toESM(require_element()); 48363 var import_html_entities = __toESM(require_html_entities()); 48364 var import_jsx_runtime255 = __toESM(require_jsx_runtime()); 48365 function getSelectOptions(tree, level = 0) { 48366 return tree.flatMap((treeNode) => [{ 48367 value: treeNode.id, 48368 label: "\xA0".repeat(level * 3) + (0, import_html_entities.decodeEntities)(treeNode.name) 48369 }, ...getSelectOptions(treeNode.children || [], level + 1)]); 48370 } 48371 function TreeSelect(props) { 48372 const { 48373 __nextHasNoMarginBottom: _, 48374 // Prevent passing to internal component 48375 label, 48376 noOptionLabel, 48377 onChange, 48378 selectedId, 48379 tree = [], 48380 ...restProps 48381 } = useDeprecated36pxDefaultSizeProp(props); 48382 const options2 = (0, import_element179.useMemo)(() => { 48383 return [noOptionLabel && { 48384 value: "", 48385 label: noOptionLabel 48386 }, ...getSelectOptions(tree)].filter((option) => !!option); 48387 }, [noOptionLabel, tree]); 48388 maybeWarnDeprecated36pxSize({ 48389 componentName: "TreeSelect", 48390 size: restProps.size, 48391 __next40pxDefaultSize: restProps.__next40pxDefaultSize 48392 }); 48393 return /* @__PURE__ */ (0, import_jsx_runtime255.jsx)(SelectControl, { 48394 __shouldNotWarnDeprecated36pxSize: true, 48395 label, 48396 options: options2, 48397 onChange, 48398 value: selectedId, 48399 ...restProps 48400 }); 48401 } 48402 var tree_select_default = TreeSelect; 48403 48404 // packages/components/build-module/query-controls/author-select.js 48405 var import_jsx_runtime256 = __toESM(require_jsx_runtime()); 48406 function AuthorSelect({ 48407 __next40pxDefaultSize, 48408 label, 48409 noOptionLabel, 48410 authorList, 48411 selectedAuthorId, 48412 onChange: onChangeProp 48413 }) { 48414 if (!authorList) { 48415 return null; 48416 } 48417 const termsTree = buildTermsTree(authorList); 48418 return /* @__PURE__ */ (0, import_jsx_runtime256.jsx)(tree_select_default, { 48419 label, 48420 noOptionLabel, 48421 onChange: onChangeProp, 48422 tree: termsTree, 48423 selectedId: selectedAuthorId !== void 0 ? String(selectedAuthorId) : void 0, 48424 __next40pxDefaultSize 48425 }); 48426 } 48427 48428 // packages/components/build-module/query-controls/category-select.js 48429 var import_element180 = __toESM(require_element()); 48430 var import_jsx_runtime257 = __toESM(require_jsx_runtime()); 48431 function CategorySelect({ 48432 __next40pxDefaultSize, 48433 label, 48434 noOptionLabel, 48435 categoriesList, 48436 selectedCategoryId, 48437 onChange: onChangeProp, 48438 ...props 48439 }) { 48440 const termsTree = (0, import_element180.useMemo)(() => { 48441 return buildTermsTree(categoriesList); 48442 }, [categoriesList]); 48443 return /* @__PURE__ */ (0, import_jsx_runtime257.jsx)(tree_select_default, { 48444 label, 48445 noOptionLabel, 48446 onChange: onChangeProp, 48447 tree: termsTree, 48448 selectedId: selectedCategoryId !== void 0 ? String(selectedCategoryId) : void 0, 48449 ...props, 48450 __next40pxDefaultSize 48451 }); 48452 } 48453 48454 // packages/components/build-module/query-controls/index.js 48455 var import_jsx_runtime258 = __toESM(require_jsx_runtime()); 48456 var DEFAULT_MIN_ITEMS = 1; 48457 var DEFAULT_MAX_ITEMS = 100; 48458 var MAX_CATEGORIES_SUGGESTIONS = 20; 48459 function isSingleCategorySelection(props) { 48460 return "categoriesList" in props; 48461 } 48462 function isMultipleCategorySelection(props) { 48463 return "categorySuggestions" in props; 48464 } 48465 var defaultOrderByOptions = [{ 48466 label: (0, import_i18n72.__)("Newest to oldest"), 48467 value: "date/desc" 48468 }, { 48469 label: (0, import_i18n72.__)("Oldest to newest"), 48470 value: "date/asc" 48471 }, { 48472 /* translators: Label for ordering posts by title in ascending order. */ 48473 label: (0, import_i18n72.__)("A \u2192 Z"), 48474 value: "title/asc" 48475 }, { 48476 /* translators: Label for ordering posts by title in descending order. */ 48477 label: (0, import_i18n72.__)("Z \u2192 A"), 48478 value: "title/desc" 48479 }]; 48480 function QueryControls({ 48481 authorList, 48482 selectedAuthorId, 48483 numberOfItems, 48484 order, 48485 orderBy, 48486 orderByOptions = defaultOrderByOptions, 48487 maxItems = DEFAULT_MAX_ITEMS, 48488 minItems = DEFAULT_MIN_ITEMS, 48489 onAuthorChange, 48490 onNumberOfItemsChange, 48491 onOrderChange, 48492 onOrderByChange, 48493 // Props for single OR multiple category selection are not destructured here, 48494 // but instead are destructured inline where necessary. 48495 ...props 48496 }) { 48497 return /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(component_default18, { 48498 spacing: "4", 48499 className: "components-query-controls", 48500 children: [onOrderChange && onOrderByChange && /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(select_control_default, { 48501 __next40pxDefaultSize: true, 48502 label: (0, import_i18n72.__)("Order by"), 48503 value: orderBy === void 0 || order === void 0 ? void 0 : `$orderBy}/$order}`, 48504 options: orderByOptions, 48505 onChange: (value) => { 48506 if (typeof value !== "string") { 48507 return; 48508 } 48509 const [newOrderBy, newOrder] = value.split("/"); 48510 if (newOrder !== order) { 48511 onOrderChange(newOrder); 48512 } 48513 if (newOrderBy !== orderBy) { 48514 onOrderByChange(newOrderBy); 48515 } 48516 } 48517 }, "query-controls-order-select"), isSingleCategorySelection(props) && props.categoriesList && props.onCategoryChange && /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(CategorySelect, { 48518 __next40pxDefaultSize: true, 48519 categoriesList: props.categoriesList, 48520 label: (0, import_i18n72.__)("Category"), 48521 noOptionLabel: (0, import_i18n72._x)("All", "categories"), 48522 selectedCategoryId: props.selectedCategoryId, 48523 onChange: props.onCategoryChange 48524 }, "query-controls-category-select"), isMultipleCategorySelection(props) && props.categorySuggestions && props.onCategoryChange && /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(form_token_field_default, { 48525 __next40pxDefaultSize: true, 48526 label: (0, import_i18n72.__)("Categories"), 48527 value: props.selectedCategories && props.selectedCategories.map((item2) => ({ 48528 id: item2.id, 48529 // Keeping the fallback to `item.value` for legacy reasons, 48530 // even if items of `selectedCategories` should not have a 48531 // `value` property. 48532 // @ts-expect-error 48533 value: item2.name || item2.value 48534 })), 48535 suggestions: Object.keys(props.categorySuggestions), 48536 onChange: props.onCategoryChange, 48537 maxSuggestions: MAX_CATEGORIES_SUGGESTIONS 48538 }, "query-controls-categories-select"), onAuthorChange && /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(AuthorSelect, { 48539 __next40pxDefaultSize: true, 48540 authorList, 48541 label: (0, import_i18n72.__)("Author"), 48542 noOptionLabel: (0, import_i18n72._x)("All", "authors"), 48543 selectedAuthorId, 48544 onChange: onAuthorChange 48545 }, "query-controls-author-select"), onNumberOfItemsChange && /* @__PURE__ */ (0, import_jsx_runtime258.jsx)(range_control_default, { 48546 __next40pxDefaultSize: true, 48547 label: (0, import_i18n72.__)("Number of items"), 48548 value: numberOfItems, 48549 onChange: onNumberOfItemsChange, 48550 min: minItems, 48551 max: maxItems, 48552 required: true 48553 }, "query-controls-range-control")] 48554 }); 48555 } 48556 var query_controls_default = QueryControls; 48557 48558 // packages/components/build-module/radio-group/radio.js 48559 var import_element182 = __toESM(require_element()); 48560 48561 // packages/components/build-module/radio-group/context.js 48562 var import_element181 = __toESM(require_element()); 48563 var RadioGroupContext = (0, import_element181.createContext)({ 48564 store: void 0, 48565 disabled: void 0 48566 }); 48567 RadioGroupContext.displayName = "RadioGroupContext"; 48568 48569 // packages/components/build-module/radio-group/radio.js 48570 var import_jsx_runtime259 = __toESM(require_jsx_runtime()); 48571 function UnforwardedRadio({ 48572 value, 48573 children, 48574 ...props 48575 }, ref) { 48576 const { 48577 store, 48578 disabled 48579 } = (0, import_element182.useContext)(RadioGroupContext); 48580 const selectedValue = useStoreState(store, "value"); 48581 const isChecked = selectedValue !== void 0 && selectedValue === value; 48582 maybeWarnDeprecated36pxSize({ 48583 componentName: "Radio", 48584 size: void 0, 48585 __next40pxDefaultSize: props.__next40pxDefaultSize 48586 }); 48587 return /* @__PURE__ */ (0, import_jsx_runtime259.jsx)(Radio, { 48588 disabled, 48589 store, 48590 ref, 48591 value, 48592 render: /* @__PURE__ */ (0, import_jsx_runtime259.jsx)(button_default, { 48593 variant: isChecked ? "primary" : "secondary", 48594 ...props 48595 }), 48596 children: children || value 48597 }); 48598 } 48599 var Radio22 = (0, import_element182.forwardRef)(UnforwardedRadio); 48600 var radio_default = Radio22; 48601 48602 // packages/components/build-module/radio-group/index.js 48603 var import_deprecated24 = __toESM(require_deprecated()); 48604 var import_element183 = __toESM(require_element()); 48605 var import_i18n73 = __toESM(require_i18n()); 48606 var import_jsx_runtime260 = __toESM(require_jsx_runtime()); 48607 function UnforwardedRadioGroup({ 48608 label, 48609 checked, 48610 defaultChecked, 48611 disabled, 48612 onChange, 48613 children, 48614 ...props 48615 }, ref) { 48616 const radioStore = useRadioStore({ 48617 value: checked, 48618 defaultValue: defaultChecked, 48619 setValue: (newValue) => { 48620 onChange?.(newValue !== null && newValue !== void 0 ? newValue : void 0); 48621 }, 48622 rtl: (0, import_i18n73.isRTL)() 48623 }); 48624 const contextValue = (0, import_element183.useMemo)(() => ({ 48625 store: radioStore, 48626 disabled 48627 }), [radioStore, disabled]); 48628 (0, import_deprecated24.default)("wp.components.__experimentalRadioGroup", { 48629 alternative: "wp.components.RadioControl or wp.components.__experimentalToggleGroupControl", 48630 since: "6.8" 48631 }); 48632 return /* @__PURE__ */ (0, import_jsx_runtime260.jsx)(RadioGroupContext.Provider, { 48633 value: contextValue, 48634 children: /* @__PURE__ */ (0, import_jsx_runtime260.jsx)(RadioGroup, { 48635 store: radioStore, 48636 render: /* @__PURE__ */ (0, import_jsx_runtime260.jsx)(button_group_default, { 48637 __shouldNotWarnDeprecated: true, 48638 children 48639 }), 48640 "aria-label": label, 48641 ref, 48642 ...props 48643 }) 48644 }); 48645 } 48646 var RadioGroup22 = (0, import_element183.forwardRef)(UnforwardedRadioGroup); 48647 var radio_group_default = RadioGroup22; 48648 48649 // packages/components/build-module/radio-control/index.js 48650 var import_compose70 = __toESM(require_compose()); 48651 var import_jsx_runtime261 = __toESM(require_jsx_runtime()); 48652 function generateOptionDescriptionId(radioGroupId, index2) { 48653 return `$radioGroupId}-$index2}-option-description`; 48654 } 48655 function generateOptionId(radioGroupId, index2) { 48656 return `$radioGroupId}-$index2}`; 48657 } 48658 function generateHelpId(radioGroupId) { 48659 return `$radioGroupId}__help`; 48660 } 48661 function RadioControl(props) { 48662 const { 48663 label, 48664 className: className2, 48665 selected, 48666 help, 48667 onChange, 48668 onClick, 48669 hideLabelFromVision, 48670 options: options2 = [], 48671 id: preferredId, 48672 ...additionalProps 48673 } = props; 48674 const id3 = (0, import_compose70.useInstanceId)(RadioControl, "inspector-radio-control", preferredId); 48675 const onChangeValue = (event) => onChange(event.target.value); 48676 if (!options2?.length) { 48677 return null; 48678 } 48679 return /* @__PURE__ */ (0, import_jsx_runtime261.jsxs)("fieldset", { 48680 id: id3, 48681 className: clsx_default(className2, "components-radio-control"), 48682 "aria-describedby": !!help ? generateHelpId(id3) : void 0, 48683 children: [hideLabelFromVision ? /* @__PURE__ */ (0, import_jsx_runtime261.jsx)(component_default2, { 48684 as: "legend", 48685 children: label 48686 }) : /* @__PURE__ */ (0, import_jsx_runtime261.jsx)(base_control_default.VisualLabel, { 48687 as: "legend", 48688 children: label 48689 }), /* @__PURE__ */ (0, import_jsx_runtime261.jsx)(component_default18, { 48690 spacing: 3, 48691 className: clsx_default("components-radio-control__group-wrapper", { 48692 "has-help": !!help 48693 }), 48694 children: options2.map((option, index2) => /* @__PURE__ */ (0, import_jsx_runtime261.jsxs)("div", { 48695 className: "components-radio-control__option", 48696 children: [/* @__PURE__ */ (0, import_jsx_runtime261.jsx)("input", { 48697 id: generateOptionId(id3, index2), 48698 className: "components-radio-control__input", 48699 type: "radio", 48700 name: id3, 48701 value: option.value, 48702 onChange: onChangeValue, 48703 checked: option.value === selected, 48704 "aria-describedby": !!option.description ? generateOptionDescriptionId(id3, index2) : void 0, 48705 onClick: (event) => { 48706 event.currentTarget.focus(); 48707 onClick?.(event); 48708 }, 48709 ...additionalProps 48710 }), /* @__PURE__ */ (0, import_jsx_runtime261.jsx)("label", { 48711 className: "components-radio-control__label", 48712 htmlFor: generateOptionId(id3, index2), 48713 children: option.label 48714 }), !!option.description ? /* @__PURE__ */ (0, import_jsx_runtime261.jsx)(StyledHelp, { 48715 id: generateOptionDescriptionId(id3, index2), 48716 className: "components-radio-control__option-description", 48717 children: option.description 48718 }) : null] 48719 }, generateOptionId(id3, index2))) 48720 }), !!help && /* @__PURE__ */ (0, import_jsx_runtime261.jsx)(StyledHelp, { 48721 id: generateHelpId(id3), 48722 className: "components-base-control__help", 48723 children: help 48724 })] 48725 }); 48726 } 48727 var radio_control_default = RadioControl; 48728 48729 // packages/components/build-module/resizable-box/index.js 48730 var import_element187 = __toESM(require_element()); 48731 48732 // node_modules/re-resizable/lib/index.js 48733 var React9 = __toESM(require_react()); 48734 48735 // node_modules/re-resizable/lib/resizer.js 48736 var React8 = __toESM(require_react()); 48737 var __extends = /* @__PURE__ */ (function() { 48738 var extendStatics = function(d3, b3) { 48739 extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d4, b4) { 48740 d4.__proto__ = b4; 48741 } || function(d4, b4) { 48742 for (var p3 in b4) if (b4.hasOwnProperty(p3)) d4[p3] = b4[p3]; 48743 }; 48744 return extendStatics(d3, b3); 48745 }; 48746 return function(d3, b3) { 48747 extendStatics(d3, b3); 48748 function __67() { 48749 this.constructor = d3; 48750 } 48751 d3.prototype = b3 === null ? Object.create(b3) : (__67.prototype = b3.prototype, new __67()); 48752 }; 48753 })(); 48754 var __assign2 = function() { 48755 __assign2 = Object.assign || function(t4) { 48756 for (var s3, i3 = 1, n3 = arguments.length; i3 < n3; i3++) { 48757 s3 = arguments[i3]; 48758 for (var p3 in s3) if (Object.prototype.hasOwnProperty.call(s3, p3)) 48759 t4[p3] = s3[p3]; 48760 } 48761 return t4; 48762 }; 48763 return __assign2.apply(this, arguments); 48764 }; 48765 var styles2 = { 48766 top: { 48767 width: "100%", 48768 height: "10px", 48769 top: "-5px", 48770 left: "0px", 48771 cursor: "row-resize" 48772 }, 48773 right: { 48774 width: "10px", 48775 height: "100%", 48776 top: "0px", 48777 right: "-5px", 48778 cursor: "col-resize" 48779 }, 48780 bottom: { 48781 width: "100%", 48782 height: "10px", 48783 bottom: "-5px", 48784 left: "0px", 48785 cursor: "row-resize" 48786 }, 48787 left: { 48788 width: "10px", 48789 height: "100%", 48790 top: "0px", 48791 left: "-5px", 48792 cursor: "col-resize" 48793 }, 48794 topRight: { 48795 width: "20px", 48796 height: "20px", 48797 position: "absolute", 48798 right: "-10px", 48799 top: "-10px", 48800 cursor: "ne-resize" 48801 }, 48802 bottomRight: { 48803 width: "20px", 48804 height: "20px", 48805 position: "absolute", 48806 right: "-10px", 48807 bottom: "-10px", 48808 cursor: "se-resize" 48809 }, 48810 bottomLeft: { 48811 width: "20px", 48812 height: "20px", 48813 position: "absolute", 48814 left: "-10px", 48815 bottom: "-10px", 48816 cursor: "sw-resize" 48817 }, 48818 topLeft: { 48819 width: "20px", 48820 height: "20px", 48821 position: "absolute", 48822 left: "-10px", 48823 top: "-10px", 48824 cursor: "nw-resize" 48825 } 48826 }; 48827 var Resizer = ( 48828 /** @class */ 48829 (function(_super) { 48830 __extends(Resizer2, _super); 48831 function Resizer2() { 48832 var _this = _super !== null && _super.apply(this, arguments) || this; 48833 _this.onMouseDown = function(e3) { 48834 _this.props.onResizeStart(e3, _this.props.direction); 48835 }; 48836 _this.onTouchStart = function(e3) { 48837 _this.props.onResizeStart(e3, _this.props.direction); 48838 }; 48839 return _this; 48840 } 48841 Resizer2.prototype.render = function() { 48842 return React8.createElement("div", { className: this.props.className || "", style: __assign2(__assign2({ position: "absolute", userSelect: "none" }, styles2[this.props.direction]), this.props.replaceStyles || {}), onMouseDown: this.onMouseDown, onTouchStart: this.onTouchStart }, this.props.children); 48843 }; 48844 return Resizer2; 48845 })(React8.PureComponent) 48846 ); 48847 48848 // node_modules/re-resizable/lib/index.js 48849 var import_fast_memoize = __toESM(require_src()); 48850 var __extends2 = /* @__PURE__ */ (function() { 48851 var extendStatics = function(d3, b3) { 48852 extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d4, b4) { 48853 d4.__proto__ = b4; 48854 } || function(d4, b4) { 48855 for (var p3 in b4) if (b4.hasOwnProperty(p3)) d4[p3] = b4[p3]; 48856 }; 48857 return extendStatics(d3, b3); 48858 }; 48859 return function(d3, b3) { 48860 extendStatics(d3, b3); 48861 function __67() { 48862 this.constructor = d3; 48863 } 48864 d3.prototype = b3 === null ? Object.create(b3) : (__67.prototype = b3.prototype, new __67()); 48865 }; 48866 })(); 48867 var __assign3 = function() { 48868 __assign3 = Object.assign || function(t4) { 48869 for (var s3, i3 = 1, n3 = arguments.length; i3 < n3; i3++) { 48870 s3 = arguments[i3]; 48871 for (var p3 in s3) if (Object.prototype.hasOwnProperty.call(s3, p3)) 48872 t4[p3] = s3[p3]; 48873 } 48874 return t4; 48875 }; 48876 return __assign3.apply(this, arguments); 48877 }; 48878 var DEFAULT_SIZE = { 48879 width: "auto", 48880 height: "auto" 48881 }; 48882 var clamp5 = (0, import_fast_memoize.default)(function(n3, min3, max3) { 48883 return Math.max(Math.min(n3, max3), min3); 48884 }); 48885 var snap = (0, import_fast_memoize.default)(function(n3, size3) { 48886 return Math.round(n3 / size3) * size3; 48887 }); 48888 var hasDirection = (0, import_fast_memoize.default)(function(dir, target) { 48889 return new RegExp(dir, "i").test(target); 48890 }); 48891 var isTouchEvent = function(event) { 48892 return Boolean(event.touches && event.touches.length); 48893 }; 48894 var isMouseEvent = function(event) { 48895 return Boolean((event.clientX || event.clientX === 0) && (event.clientY || event.clientY === 0)); 48896 }; 48897 var findClosestSnap = (0, import_fast_memoize.default)(function(n3, snapArray, snapGap) { 48898 if (snapGap === void 0) { 48899 snapGap = 0; 48900 } 48901 var closestGapIndex = snapArray.reduce(function(prev2, curr, index2) { 48902 return Math.abs(curr - n3) < Math.abs(snapArray[prev2] - n3) ? index2 : prev2; 48903 }, 0); 48904 var gap = Math.abs(snapArray[closestGapIndex] - n3); 48905 return snapGap === 0 || gap < snapGap ? snapArray[closestGapIndex] : n3; 48906 }); 48907 var endsWith = (0, import_fast_memoize.default)(function(str, searchStr) { 48908 return str.substr(str.length - searchStr.length, searchStr.length) === searchStr; 48909 }); 48910 var getStringSize = (0, import_fast_memoize.default)(function(n3) { 48911 n3 = n3.toString(); 48912 if (n3 === "auto") { 48913 return n3; 48914 } 48915 if (endsWith(n3, "px")) { 48916 return n3; 48917 } 48918 if (endsWith(n3, "%")) { 48919 return n3; 48920 } 48921 if (endsWith(n3, "vh")) { 48922 return n3; 48923 } 48924 if (endsWith(n3, "vw")) { 48925 return n3; 48926 } 48927 if (endsWith(n3, "vmax")) { 48928 return n3; 48929 } 48930 if (endsWith(n3, "vmin")) { 48931 return n3; 48932 } 48933 return n3 + "px"; 48934 }); 48935 var getPixelSize = function(size3, parentSize, innerWidth, innerHeight) { 48936 if (size3 && typeof size3 === "string") { 48937 if (endsWith(size3, "px")) { 48938 return Number(size3.replace("px", "")); 48939 } 48940 if (endsWith(size3, "%")) { 48941 var ratio = Number(size3.replace("%", "")) / 100; 48942 return parentSize * ratio; 48943 } 48944 if (endsWith(size3, "vw")) { 48945 var ratio = Number(size3.replace("vw", "")) / 100; 48946 return innerWidth * ratio; 48947 } 48948 if (endsWith(size3, "vh")) { 48949 var ratio = Number(size3.replace("vh", "")) / 100; 48950 return innerHeight * ratio; 48951 } 48952 } 48953 return size3; 48954 }; 48955 var calculateNewMax = (0, import_fast_memoize.default)(function(parentSize, innerWidth, innerHeight, maxWidth, maxHeight, minWidth, minHeight) { 48956 maxWidth = getPixelSize(maxWidth, parentSize.width, innerWidth, innerHeight); 48957 maxHeight = getPixelSize(maxHeight, parentSize.height, innerWidth, innerHeight); 48958 minWidth = getPixelSize(minWidth, parentSize.width, innerWidth, innerHeight); 48959 minHeight = getPixelSize(minHeight, parentSize.height, innerWidth, innerHeight); 48960 return { 48961 maxWidth: typeof maxWidth === "undefined" ? void 0 : Number(maxWidth), 48962 maxHeight: typeof maxHeight === "undefined" ? void 0 : Number(maxHeight), 48963 minWidth: typeof minWidth === "undefined" ? void 0 : Number(minWidth), 48964 minHeight: typeof minHeight === "undefined" ? void 0 : Number(minHeight) 48965 }; 48966 }); 48967 var definedProps = [ 48968 "as", 48969 "style", 48970 "className", 48971 "grid", 48972 "snap", 48973 "bounds", 48974 "boundsByDirection", 48975 "size", 48976 "defaultSize", 48977 "minWidth", 48978 "minHeight", 48979 "maxWidth", 48980 "maxHeight", 48981 "lockAspectRatio", 48982 "lockAspectRatioExtraWidth", 48983 "lockAspectRatioExtraHeight", 48984 "enable", 48985 "handleStyles", 48986 "handleClasses", 48987 "handleWrapperStyle", 48988 "handleWrapperClass", 48989 "children", 48990 "onResizeStart", 48991 "onResize", 48992 "onResizeStop", 48993 "handleComponent", 48994 "scale", 48995 "resizeRatio", 48996 "snapGap" 48997 ]; 48998 var baseClassName = "__resizable_base__"; 48999 var Resizable = ( 49000 /** @class */ 49001 (function(_super) { 49002 __extends2(Resizable2, _super); 49003 function Resizable2(props) { 49004 var _this = _super.call(this, props) || this; 49005 _this.ratio = 1; 49006 _this.resizable = null; 49007 _this.parentLeft = 0; 49008 _this.parentTop = 0; 49009 _this.resizableLeft = 0; 49010 _this.resizableRight = 0; 49011 _this.resizableTop = 0; 49012 _this.resizableBottom = 0; 49013 _this.targetLeft = 0; 49014 _this.targetTop = 0; 49015 _this.appendBase = function() { 49016 if (!_this.resizable || !_this.window) { 49017 return null; 49018 } 49019 var parent = _this.parentNode; 49020 if (!parent) { 49021 return null; 49022 } 49023 var element = _this.window.document.createElement("div"); 49024 element.style.width = "100%"; 49025 element.style.height = "100%"; 49026 element.style.position = "absolute"; 49027 element.style.transform = "scale(0, 0)"; 49028 element.style.left = "0"; 49029 element.style.flex = "0"; 49030 if (element.classList) { 49031 element.classList.add(baseClassName); 49032 } else { 49033 element.className += baseClassName; 49034 } 49035 parent.appendChild(element); 49036 return element; 49037 }; 49038 _this.removeBase = function(base) { 49039 var parent = _this.parentNode; 49040 if (!parent) { 49041 return; 49042 } 49043 parent.removeChild(base); 49044 }; 49045 _this.ref = function(c3) { 49046 if (c3) { 49047 _this.resizable = c3; 49048 } 49049 }; 49050 _this.state = { 49051 isResizing: false, 49052 width: typeof (_this.propsSize && _this.propsSize.width) === "undefined" ? "auto" : _this.propsSize && _this.propsSize.width, 49053 height: typeof (_this.propsSize && _this.propsSize.height) === "undefined" ? "auto" : _this.propsSize && _this.propsSize.height, 49054 direction: "right", 49055 original: { 49056 x: 0, 49057 y: 0, 49058 width: 0, 49059 height: 0 49060 }, 49061 backgroundStyle: { 49062 height: "100%", 49063 width: "100%", 49064 backgroundColor: "rgba(0,0,0,0)", 49065 cursor: "auto", 49066 opacity: 0, 49067 position: "fixed", 49068 zIndex: 9999, 49069 top: "0", 49070 left: "0", 49071 bottom: "0", 49072 right: "0" 49073 }, 49074 flexBasis: void 0 49075 }; 49076 _this.onResizeStart = _this.onResizeStart.bind(_this); 49077 _this.onMouseMove = _this.onMouseMove.bind(_this); 49078 _this.onMouseUp = _this.onMouseUp.bind(_this); 49079 return _this; 49080 } 49081 Object.defineProperty(Resizable2.prototype, "parentNode", { 49082 get: function() { 49083 if (!this.resizable) { 49084 return null; 49085 } 49086 return this.resizable.parentNode; 49087 }, 49088 enumerable: false, 49089 configurable: true 49090 }); 49091 Object.defineProperty(Resizable2.prototype, "window", { 49092 get: function() { 49093 if (!this.resizable) { 49094 return null; 49095 } 49096 if (!this.resizable.ownerDocument) { 49097 return null; 49098 } 49099 return this.resizable.ownerDocument.defaultView; 49100 }, 49101 enumerable: false, 49102 configurable: true 49103 }); 49104 Object.defineProperty(Resizable2.prototype, "propsSize", { 49105 get: function() { 49106 return this.props.size || this.props.defaultSize || DEFAULT_SIZE; 49107 }, 49108 enumerable: false, 49109 configurable: true 49110 }); 49111 Object.defineProperty(Resizable2.prototype, "size", { 49112 get: function() { 49113 var width = 0; 49114 var height = 0; 49115 if (this.resizable && this.window) { 49116 var orgWidth = this.resizable.offsetWidth; 49117 var orgHeight = this.resizable.offsetHeight; 49118 var orgPosition = this.resizable.style.position; 49119 if (orgPosition !== "relative") { 49120 this.resizable.style.position = "relative"; 49121 } 49122 width = this.resizable.style.width !== "auto" ? this.resizable.offsetWidth : orgWidth; 49123 height = this.resizable.style.height !== "auto" ? this.resizable.offsetHeight : orgHeight; 49124 this.resizable.style.position = orgPosition; 49125 } 49126 return { width, height }; 49127 }, 49128 enumerable: false, 49129 configurable: true 49130 }); 49131 Object.defineProperty(Resizable2.prototype, "sizeStyle", { 49132 get: function() { 49133 var _this = this; 49134 var size3 = this.props.size; 49135 var getSize = function(key) { 49136 if (typeof _this.state[key] === "undefined" || _this.state[key] === "auto") { 49137 return "auto"; 49138 } 49139 if (_this.propsSize && _this.propsSize[key] && endsWith(_this.propsSize[key].toString(), "%")) { 49140 if (endsWith(_this.state[key].toString(), "%")) { 49141 return _this.state[key].toString(); 49142 } 49143 var parentSize = _this.getParentSize(); 49144 var value = Number(_this.state[key].toString().replace("px", "")); 49145 var percent2 = value / parentSize[key] * 100; 49146 return percent2 + "%"; 49147 } 49148 return getStringSize(_this.state[key]); 49149 }; 49150 var width = size3 && typeof size3.width !== "undefined" && !this.state.isResizing ? getStringSize(size3.width) : getSize("width"); 49151 var height = size3 && typeof size3.height !== "undefined" && !this.state.isResizing ? getStringSize(size3.height) : getSize("height"); 49152 return { width, height }; 49153 }, 49154 enumerable: false, 49155 configurable: true 49156 }); 49157 Resizable2.prototype.getParentSize = function() { 49158 if (!this.parentNode) { 49159 if (!this.window) { 49160 return { width: 0, height: 0 }; 49161 } 49162 return { width: this.window.innerWidth, height: this.window.innerHeight }; 49163 } 49164 var base = this.appendBase(); 49165 if (!base) { 49166 return { width: 0, height: 0 }; 49167 } 49168 var wrapChanged = false; 49169 var wrap = this.parentNode.style.flexWrap; 49170 if (wrap !== "wrap") { 49171 wrapChanged = true; 49172 this.parentNode.style.flexWrap = "wrap"; 49173 } 49174 base.style.position = "relative"; 49175 base.style.minWidth = "100%"; 49176 var size3 = { 49177 width: base.offsetWidth, 49178 height: base.offsetHeight 49179 }; 49180 if (wrapChanged) { 49181 this.parentNode.style.flexWrap = wrap; 49182 } 49183 this.removeBase(base); 49184 return size3; 49185 }; 49186 Resizable2.prototype.bindEvents = function() { 49187 if (this.window) { 49188 this.window.addEventListener("mouseup", this.onMouseUp); 49189 this.window.addEventListener("mousemove", this.onMouseMove); 49190 this.window.addEventListener("mouseleave", this.onMouseUp); 49191 this.window.addEventListener("touchmove", this.onMouseMove, { 49192 capture: true, 49193 passive: false 49194 }); 49195 this.window.addEventListener("touchend", this.onMouseUp); 49196 } 49197 }; 49198 Resizable2.prototype.unbindEvents = function() { 49199 if (this.window) { 49200 this.window.removeEventListener("mouseup", this.onMouseUp); 49201 this.window.removeEventListener("mousemove", this.onMouseMove); 49202 this.window.removeEventListener("mouseleave", this.onMouseUp); 49203 this.window.removeEventListener("touchmove", this.onMouseMove, true); 49204 this.window.removeEventListener("touchend", this.onMouseUp); 49205 } 49206 }; 49207 Resizable2.prototype.componentDidMount = function() { 49208 if (!this.resizable || !this.window) { 49209 return; 49210 } 49211 var computedStyle = this.window.getComputedStyle(this.resizable); 49212 this.setState({ 49213 width: this.state.width || this.size.width, 49214 height: this.state.height || this.size.height, 49215 flexBasis: computedStyle.flexBasis !== "auto" ? computedStyle.flexBasis : void 0 49216 }); 49217 }; 49218 Resizable2.prototype.componentWillUnmount = function() { 49219 if (this.window) { 49220 this.unbindEvents(); 49221 } 49222 }; 49223 Resizable2.prototype.createSizeForCssProperty = function(newSize, kind) { 49224 var propsSize = this.propsSize && this.propsSize[kind]; 49225 return this.state[kind] === "auto" && this.state.original[kind] === newSize && (typeof propsSize === "undefined" || propsSize === "auto") ? "auto" : newSize; 49226 }; 49227 Resizable2.prototype.calculateNewMaxFromBoundary = function(maxWidth, maxHeight) { 49228 var boundsByDirection = this.props.boundsByDirection; 49229 var direction = this.state.direction; 49230 var widthByDirection = boundsByDirection && hasDirection("left", direction); 49231 var heightByDirection = boundsByDirection && hasDirection("top", direction); 49232 var boundWidth; 49233 var boundHeight; 49234 if (this.props.bounds === "parent") { 49235 var parent_1 = this.parentNode; 49236 if (parent_1) { 49237 boundWidth = widthByDirection ? this.resizableRight - this.parentLeft : parent_1.offsetWidth + (this.parentLeft - this.resizableLeft); 49238 boundHeight = heightByDirection ? this.resizableBottom - this.parentTop : parent_1.offsetHeight + (this.parentTop - this.resizableTop); 49239 } 49240 } else if (this.props.bounds === "window") { 49241 if (this.window) { 49242 boundWidth = widthByDirection ? this.resizableRight : this.window.innerWidth - this.resizableLeft; 49243 boundHeight = heightByDirection ? this.resizableBottom : this.window.innerHeight - this.resizableTop; 49244 } 49245 } else if (this.props.bounds) { 49246 boundWidth = widthByDirection ? this.resizableRight - this.targetLeft : this.props.bounds.offsetWidth + (this.targetLeft - this.resizableLeft); 49247 boundHeight = heightByDirection ? this.resizableBottom - this.targetTop : this.props.bounds.offsetHeight + (this.targetTop - this.resizableTop); 49248 } 49249 if (boundWidth && Number.isFinite(boundWidth)) { 49250 maxWidth = maxWidth && maxWidth < boundWidth ? maxWidth : boundWidth; 49251 } 49252 if (boundHeight && Number.isFinite(boundHeight)) { 49253 maxHeight = maxHeight && maxHeight < boundHeight ? maxHeight : boundHeight; 49254 } 49255 return { maxWidth, maxHeight }; 49256 }; 49257 Resizable2.prototype.calculateNewSizeFromDirection = function(clientX, clientY) { 49258 var scale2 = this.props.scale || 1; 49259 var resizeRatio = this.props.resizeRatio || 1; 49260 var _a = this.state, direction = _a.direction, original = _a.original; 49261 var _b = this.props, lockAspectRatio = _b.lockAspectRatio, lockAspectRatioExtraHeight = _b.lockAspectRatioExtraHeight, lockAspectRatioExtraWidth = _b.lockAspectRatioExtraWidth; 49262 var newWidth = original.width; 49263 var newHeight = original.height; 49264 var extraHeight = lockAspectRatioExtraHeight || 0; 49265 var extraWidth = lockAspectRatioExtraWidth || 0; 49266 if (hasDirection("right", direction)) { 49267 newWidth = original.width + (clientX - original.x) * resizeRatio / scale2; 49268 if (lockAspectRatio) { 49269 newHeight = (newWidth - extraWidth) / this.ratio + extraHeight; 49270 } 49271 } 49272 if (hasDirection("left", direction)) { 49273 newWidth = original.width - (clientX - original.x) * resizeRatio / scale2; 49274 if (lockAspectRatio) { 49275 newHeight = (newWidth - extraWidth) / this.ratio + extraHeight; 49276 } 49277 } 49278 if (hasDirection("bottom", direction)) { 49279 newHeight = original.height + (clientY - original.y) * resizeRatio / scale2; 49280 if (lockAspectRatio) { 49281 newWidth = (newHeight - extraHeight) * this.ratio + extraWidth; 49282 } 49283 } 49284 if (hasDirection("top", direction)) { 49285 newHeight = original.height - (clientY - original.y) * resizeRatio / scale2; 49286 if (lockAspectRatio) { 49287 newWidth = (newHeight - extraHeight) * this.ratio + extraWidth; 49288 } 49289 } 49290 return { newWidth, newHeight }; 49291 }; 49292 Resizable2.prototype.calculateNewSizeFromAspectRatio = function(newWidth, newHeight, max3, min3) { 49293 var _a = this.props, lockAspectRatio = _a.lockAspectRatio, lockAspectRatioExtraHeight = _a.lockAspectRatioExtraHeight, lockAspectRatioExtraWidth = _a.lockAspectRatioExtraWidth; 49294 var computedMinWidth = typeof min3.width === "undefined" ? 10 : min3.width; 49295 var computedMaxWidth = typeof max3.width === "undefined" || max3.width < 0 ? newWidth : max3.width; 49296 var computedMinHeight = typeof min3.height === "undefined" ? 10 : min3.height; 49297 var computedMaxHeight = typeof max3.height === "undefined" || max3.height < 0 ? newHeight : max3.height; 49298 var extraHeight = lockAspectRatioExtraHeight || 0; 49299 var extraWidth = lockAspectRatioExtraWidth || 0; 49300 if (lockAspectRatio) { 49301 var extraMinWidth = (computedMinHeight - extraHeight) * this.ratio + extraWidth; 49302 var extraMaxWidth = (computedMaxHeight - extraHeight) * this.ratio + extraWidth; 49303 var extraMinHeight = (computedMinWidth - extraWidth) / this.ratio + extraHeight; 49304 var extraMaxHeight = (computedMaxWidth - extraWidth) / this.ratio + extraHeight; 49305 var lockedMinWidth = Math.max(computedMinWidth, extraMinWidth); 49306 var lockedMaxWidth = Math.min(computedMaxWidth, extraMaxWidth); 49307 var lockedMinHeight = Math.max(computedMinHeight, extraMinHeight); 49308 var lockedMaxHeight = Math.min(computedMaxHeight, extraMaxHeight); 49309 newWidth = clamp5(newWidth, lockedMinWidth, lockedMaxWidth); 49310 newHeight = clamp5(newHeight, lockedMinHeight, lockedMaxHeight); 49311 } else { 49312 newWidth = clamp5(newWidth, computedMinWidth, computedMaxWidth); 49313 newHeight = clamp5(newHeight, computedMinHeight, computedMaxHeight); 49314 } 49315 return { newWidth, newHeight }; 49316 }; 49317 Resizable2.prototype.setBoundingClientRect = function() { 49318 if (this.props.bounds === "parent") { 49319 var parent_2 = this.parentNode; 49320 if (parent_2) { 49321 var parentRect = parent_2.getBoundingClientRect(); 49322 this.parentLeft = parentRect.left; 49323 this.parentTop = parentRect.top; 49324 } 49325 } 49326 if (this.props.bounds && typeof this.props.bounds !== "string") { 49327 var targetRect = this.props.bounds.getBoundingClientRect(); 49328 this.targetLeft = targetRect.left; 49329 this.targetTop = targetRect.top; 49330 } 49331 if (this.resizable) { 49332 var _a = this.resizable.getBoundingClientRect(), left = _a.left, top_1 = _a.top, right = _a.right, bottom = _a.bottom; 49333 this.resizableLeft = left; 49334 this.resizableRight = right; 49335 this.resizableTop = top_1; 49336 this.resizableBottom = bottom; 49337 } 49338 }; 49339 Resizable2.prototype.onResizeStart = function(event, direction) { 49340 if (!this.resizable || !this.window) { 49341 return; 49342 } 49343 var clientX = 0; 49344 var clientY = 0; 49345 if (event.nativeEvent && isMouseEvent(event.nativeEvent)) { 49346 clientX = event.nativeEvent.clientX; 49347 clientY = event.nativeEvent.clientY; 49348 if (event.nativeEvent.which === 3) { 49349 return; 49350 } 49351 } else if (event.nativeEvent && isTouchEvent(event.nativeEvent)) { 49352 clientX = event.nativeEvent.touches[0].clientX; 49353 clientY = event.nativeEvent.touches[0].clientY; 49354 } 49355 if (this.props.onResizeStart) { 49356 if (this.resizable) { 49357 var startResize = this.props.onResizeStart(event, direction, this.resizable); 49358 if (startResize === false) { 49359 return; 49360 } 49361 } 49362 } 49363 if (this.props.size) { 49364 if (typeof this.props.size.height !== "undefined" && this.props.size.height !== this.state.height) { 49365 this.setState({ height: this.props.size.height }); 49366 } 49367 if (typeof this.props.size.width !== "undefined" && this.props.size.width !== this.state.width) { 49368 this.setState({ width: this.props.size.width }); 49369 } 49370 } 49371 this.ratio = typeof this.props.lockAspectRatio === "number" ? this.props.lockAspectRatio : this.size.width / this.size.height; 49372 var flexBasis; 49373 var computedStyle = this.window.getComputedStyle(this.resizable); 49374 if (computedStyle.flexBasis !== "auto") { 49375 var parent_3 = this.parentNode; 49376 if (parent_3) { 49377 var dir = this.window.getComputedStyle(parent_3).flexDirection; 49378 this.flexDir = dir.startsWith("row") ? "row" : "column"; 49379 flexBasis = computedStyle.flexBasis; 49380 } 49381 } 49382 this.setBoundingClientRect(); 49383 this.bindEvents(); 49384 var state = { 49385 original: { 49386 x: clientX, 49387 y: clientY, 49388 width: this.size.width, 49389 height: this.size.height 49390 }, 49391 isResizing: true, 49392 backgroundStyle: __assign3(__assign3({}, this.state.backgroundStyle), { cursor: this.window.getComputedStyle(event.target).cursor || "auto" }), 49393 direction, 49394 flexBasis 49395 }; 49396 this.setState(state); 49397 }; 49398 Resizable2.prototype.onMouseMove = function(event) { 49399 if (!this.state.isResizing || !this.resizable || !this.window) { 49400 return; 49401 } 49402 if (this.window.TouchEvent && isTouchEvent(event)) { 49403 try { 49404 event.preventDefault(); 49405 event.stopPropagation(); 49406 } catch (e3) { 49407 } 49408 } 49409 var _a = this.props, maxWidth = _a.maxWidth, maxHeight = _a.maxHeight, minWidth = _a.minWidth, minHeight = _a.minHeight; 49410 var clientX = isTouchEvent(event) ? event.touches[0].clientX : event.clientX; 49411 var clientY = isTouchEvent(event) ? event.touches[0].clientY : event.clientY; 49412 var _b = this.state, direction = _b.direction, original = _b.original, width = _b.width, height = _b.height; 49413 var parentSize = this.getParentSize(); 49414 var max3 = calculateNewMax(parentSize, this.window.innerWidth, this.window.innerHeight, maxWidth, maxHeight, minWidth, minHeight); 49415 maxWidth = max3.maxWidth; 49416 maxHeight = max3.maxHeight; 49417 minWidth = max3.minWidth; 49418 minHeight = max3.minHeight; 49419 var _c = this.calculateNewSizeFromDirection(clientX, clientY), newHeight = _c.newHeight, newWidth = _c.newWidth; 49420 var boundaryMax = this.calculateNewMaxFromBoundary(maxWidth, maxHeight); 49421 var newSize = this.calculateNewSizeFromAspectRatio(newWidth, newHeight, { width: boundaryMax.maxWidth, height: boundaryMax.maxHeight }, { width: minWidth, height: minHeight }); 49422 newWidth = newSize.newWidth; 49423 newHeight = newSize.newHeight; 49424 if (this.props.grid) { 49425 var newGridWidth = snap(newWidth, this.props.grid[0]); 49426 var newGridHeight = snap(newHeight, this.props.grid[1]); 49427 var gap = this.props.snapGap || 0; 49428 newWidth = gap === 0 || Math.abs(newGridWidth - newWidth) <= gap ? newGridWidth : newWidth; 49429 newHeight = gap === 0 || Math.abs(newGridHeight - newHeight) <= gap ? newGridHeight : newHeight; 49430 } 49431 if (this.props.snap && this.props.snap.x) { 49432 newWidth = findClosestSnap(newWidth, this.props.snap.x, this.props.snapGap); 49433 } 49434 if (this.props.snap && this.props.snap.y) { 49435 newHeight = findClosestSnap(newHeight, this.props.snap.y, this.props.snapGap); 49436 } 49437 var delta = { 49438 width: newWidth - original.width, 49439 height: newHeight - original.height 49440 }; 49441 if (width && typeof width === "string") { 49442 if (endsWith(width, "%")) { 49443 var percent2 = newWidth / parentSize.width * 100; 49444 newWidth = percent2 + "%"; 49445 } else if (endsWith(width, "vw")) { 49446 var vw2 = newWidth / this.window.innerWidth * 100; 49447 newWidth = vw2 + "vw"; 49448 } else if (endsWith(width, "vh")) { 49449 var vh2 = newWidth / this.window.innerHeight * 100; 49450 newWidth = vh2 + "vh"; 49451 } 49452 } 49453 if (height && typeof height === "string") { 49454 if (endsWith(height, "%")) { 49455 var percent2 = newHeight / parentSize.height * 100; 49456 newHeight = percent2 + "%"; 49457 } else if (endsWith(height, "vw")) { 49458 var vw2 = newHeight / this.window.innerWidth * 100; 49459 newHeight = vw2 + "vw"; 49460 } else if (endsWith(height, "vh")) { 49461 var vh2 = newHeight / this.window.innerHeight * 100; 49462 newHeight = vh2 + "vh"; 49463 } 49464 } 49465 var newState = { 49466 width: this.createSizeForCssProperty(newWidth, "width"), 49467 height: this.createSizeForCssProperty(newHeight, "height") 49468 }; 49469 if (this.flexDir === "row") { 49470 newState.flexBasis = newState.width; 49471 } else if (this.flexDir === "column") { 49472 newState.flexBasis = newState.height; 49473 } 49474 this.setState(newState); 49475 if (this.props.onResize) { 49476 this.props.onResize(event, direction, this.resizable, delta); 49477 } 49478 }; 49479 Resizable2.prototype.onMouseUp = function(event) { 49480 var _a = this.state, isResizing = _a.isResizing, direction = _a.direction, original = _a.original; 49481 if (!isResizing || !this.resizable) { 49482 return; 49483 } 49484 var delta = { 49485 width: this.size.width - original.width, 49486 height: this.size.height - original.height 49487 }; 49488 if (this.props.onResizeStop) { 49489 this.props.onResizeStop(event, direction, this.resizable, delta); 49490 } 49491 if (this.props.size) { 49492 this.setState(this.props.size); 49493 } 49494 this.unbindEvents(); 49495 this.setState({ 49496 isResizing: false, 49497 backgroundStyle: __assign3(__assign3({}, this.state.backgroundStyle), { cursor: "auto" }) 49498 }); 49499 }; 49500 Resizable2.prototype.updateSize = function(size3) { 49501 this.setState({ width: size3.width, height: size3.height }); 49502 }; 49503 Resizable2.prototype.renderResizer = function() { 49504 var _this = this; 49505 var _a = this.props, enable = _a.enable, handleStyles = _a.handleStyles, handleClasses = _a.handleClasses, handleWrapperStyle = _a.handleWrapperStyle, handleWrapperClass = _a.handleWrapperClass, handleComponent = _a.handleComponent; 49506 if (!enable) { 49507 return null; 49508 } 49509 var resizers = Object.keys(enable).map(function(dir) { 49510 if (enable[dir] !== false) { 49511 return React9.createElement(Resizer, { key: dir, direction: dir, onResizeStart: _this.onResizeStart, replaceStyles: handleStyles && handleStyles[dir], className: handleClasses && handleClasses[dir] }, handleComponent && handleComponent[dir] ? handleComponent[dir] : null); 49512 } 49513 return null; 49514 }); 49515 return React9.createElement("div", { className: handleWrapperClass, style: handleWrapperStyle }, resizers); 49516 }; 49517 Resizable2.prototype.render = function() { 49518 var _this = this; 49519 var extendsProps = Object.keys(this.props).reduce(function(acc, key) { 49520 if (definedProps.indexOf(key) !== -1) { 49521 return acc; 49522 } 49523 acc[key] = _this.props[key]; 49524 return acc; 49525 }, {}); 49526 var style2 = __assign3(__assign3(__assign3({ position: "relative", userSelect: this.state.isResizing ? "none" : "auto" }, this.props.style), this.sizeStyle), { maxWidth: this.props.maxWidth, maxHeight: this.props.maxHeight, minWidth: this.props.minWidth, minHeight: this.props.minHeight, boxSizing: "border-box", flexShrink: 0 }); 49527 if (this.state.flexBasis) { 49528 style2.flexBasis = this.state.flexBasis; 49529 } 49530 var Wrapper7 = this.props.as || "div"; 49531 return React9.createElement( 49532 Wrapper7, 49533 __assign3({ ref: this.ref, style: style2, className: this.props.className }, extendsProps), 49534 this.state.isResizing && React9.createElement("div", { style: this.state.backgroundStyle }), 49535 this.props.children, 49536 this.renderResizer() 49537 ); 49538 }; 49539 Resizable2.defaultProps = { 49540 as: "div", 49541 onResizeStart: function() { 49542 }, 49543 onResize: function() { 49544 }, 49545 onResizeStop: function() { 49546 }, 49547 enable: { 49548 top: true, 49549 right: true, 49550 bottom: true, 49551 left: true, 49552 topRight: true, 49553 bottomRight: true, 49554 bottomLeft: true, 49555 topLeft: true 49556 }, 49557 style: {}, 49558 grid: [1, 1], 49559 lockAspectRatio: false, 49560 lockAspectRatioExtraWidth: 0, 49561 lockAspectRatioExtraHeight: 0, 49562 scale: 1, 49563 resizeRatio: 1, 49564 snapGap: 0 49565 }; 49566 return Resizable2; 49567 })(React9.PureComponent) 49568 ); 49569 49570 // packages/components/build-module/resizable-box/resize-tooltip/index.js 49571 var import_element186 = __toESM(require_element()); 49572 49573 // packages/components/build-module/resizable-box/resize-tooltip/label.js 49574 var import_element185 = __toESM(require_element()); 49575 var import_i18n74 = __toESM(require_i18n()); 49576 49577 // packages/components/build-module/resizable-box/resize-tooltip/utils.js 49578 var import_element184 = __toESM(require_element()); 49579 var import_compose71 = __toESM(require_compose()); 49580 var noop23 = () => { 49581 }; 49582 var POSITIONS = { 49583 bottom: "bottom", 49584 corner: "corner" 49585 }; 49586 function useResizeLabel({ 49587 axis, 49588 fadeTimeout = 180, 49589 onResize = noop23, 49590 position: position2 = POSITIONS.bottom, 49591 showPx = false 49592 }) { 49593 const [resizeListener, sizes] = (0, import_compose71.useResizeObserver)(); 49594 const isAxisControlled = !!axis; 49595 const [moveX, setMoveX] = (0, import_element184.useState)(false); 49596 const [moveY, setMoveY] = (0, import_element184.useState)(false); 49597 const { 49598 width, 49599 height 49600 } = sizes; 49601 const heightRef = (0, import_element184.useRef)(height); 49602 const widthRef = (0, import_element184.useRef)(width); 49603 const moveTimeoutRef = (0, import_element184.useRef)(); 49604 const debounceUnsetMoveXY = (0, import_element184.useCallback)(() => { 49605 const unsetMoveXY = () => { 49606 if (isAxisControlled) { 49607 return; 49608 } 49609 setMoveX(false); 49610 setMoveY(false); 49611 }; 49612 if (moveTimeoutRef.current) { 49613 window.clearTimeout(moveTimeoutRef.current); 49614 } 49615 moveTimeoutRef.current = window.setTimeout(unsetMoveXY, fadeTimeout); 49616 }, [fadeTimeout, isAxisControlled]); 49617 (0, import_element184.useEffect)(() => { 49618 const isRendered = width !== null || height !== null; 49619 if (!isRendered) { 49620 return; 49621 } 49622 const didWidthChange = width !== widthRef.current; 49623 const didHeightChange = height !== heightRef.current; 49624 if (!didWidthChange && !didHeightChange) { 49625 return; 49626 } 49627 if (width && !widthRef.current && height && !heightRef.current) { 49628 widthRef.current = width; 49629 heightRef.current = height; 49630 return; 49631 } 49632 if (didWidthChange) { 49633 setMoveX(true); 49634 widthRef.current = width; 49635 } 49636 if (didHeightChange) { 49637 setMoveY(true); 49638 heightRef.current = height; 49639 } 49640 onResize({ 49641 width, 49642 height 49643 }); 49644 debounceUnsetMoveXY(); 49645 }, [width, height, onResize, debounceUnsetMoveXY]); 49646 const label = getSizeLabel({ 49647 axis, 49648 height, 49649 moveX, 49650 moveY, 49651 position: position2, 49652 showPx, 49653 width 49654 }); 49655 return { 49656 label, 49657 resizeListener 49658 }; 49659 } 49660 function getSizeLabel({ 49661 axis, 49662 height, 49663 moveX = false, 49664 moveY = false, 49665 position: position2 = POSITIONS.bottom, 49666 showPx = false, 49667 width 49668 }) { 49669 if (!moveX && !moveY) { 49670 return void 0; 49671 } 49672 if (position2 === POSITIONS.corner) { 49673 return `$width} x $height}`; 49674 } 49675 const labelUnit = showPx ? " px" : ""; 49676 if (axis) { 49677 if (axis === "x" && moveX) { 49678 return `$width}$labelUnit}`; 49679 } 49680 if (axis === "y" && moveY) { 49681 return `$height}$labelUnit}`; 49682 } 49683 } 49684 if (moveX && moveY) { 49685 return `$width} x $height}`; 49686 } 49687 if (moveX) { 49688 return `$width}$labelUnit}`; 49689 } 49690 if (moveY) { 49691 return `$height}$labelUnit}`; 49692 } 49693 return void 0; 49694 } 49695 49696 // packages/components/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js 49697 function _EMOTION_STRINGIFIED_CSS_ERROR__38() { 49698 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 49699 } 49700 var Root4 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 49701 target: "e1wq7y4k3" 49702 } : { 49703 target: "e1wq7y4k3", 49704 label: "Root" 49705 })(false ? { 49706 name: "1cd7zoc", 49707 styles: "bottom:0;box-sizing:border-box;left:0;pointer-events:none;position:absolute;right:0;top:0" 49708 } : { 49709 name: "1cd7zoc", 49710 styles: "bottom:0;box-sizing:border-box;left:0;pointer-events:none;position:absolute;right:0;top:0", 49711 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXOEIiLCJmaWxlIjoicmVzaXplLXRvb2x0aXAuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vLi4vdGV4dCc7XG5pbXBvcnQgeyBmb250LCBDT0xPUlMsIENPTkZJRyB9IGZyb20gJy4uLy4uLy4uL3V0aWxzJztcblxuZXhwb3J0IGNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuXHRib3R0b206IDA7XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGxlZnQ6IDA7XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHRwb3NpdGlvbjogYWJzb2x1dGU7XG5cdHJpZ2h0OiAwO1xuXHR0b3A6IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHRpcFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdG9wYWNpdHk6IDA7XG5cdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHR0cmFuc2l0aW9uOiBvcGFjaXR5IDEyMG1zIGxpbmVhcjtcbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sdGlwID0gc3R5bGVkLmRpdmBcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGZvbnQtc2l6ZTogMTJweDtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblx0cGFkZGluZzogNHB4IDhweDtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuYDtcblxuLy8gVE9ETzogUmVzb2x2ZSBuZWVkIHRvIHVzZSAmJiYgdG8gaW5jcmVhc2Ugc3BlY2lmaWNpdHlcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9Xb3JkUHJlc3MvZ3V0ZW5iZXJnL2lzc3Vlcy8xODQ4M1xuXG5leHBvcnQgY29uc3QgTGFiZWxUZXh0ID0gc3R5bGVkKCBUZXh0IClgXG5cdCYmJiB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblx0XHRkaXNwbGF5OiBibG9jaztcblx0XHRmb250LXNpemU6IDEzcHg7XG5cdFx0bGluZS1oZWlnaHQ6IDEuNDtcblx0XHR3aGl0ZS1zcGFjZTogbm93cmFwO1xuXHR9XG5gO1xuIl19 */", 49712 toString: _EMOTION_STRINGIFIED_CSS_ERROR__38 49713 }); 49714 var TooltipWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 49715 target: "e1wq7y4k2" 49716 } : { 49717 target: "e1wq7y4k2", 49718 label: "TooltipWrapper" 49719 })(false ? { 49720 name: "ajymcs", 49721 styles: "align-items:center;box-sizing:border-box;display:inline-flex;justify-content:center;opacity:0;pointer-events:none;transition:opacity 120ms linear" 49722 } : { 49723 name: "ajymcs", 49724 styles: "align-items:center;box-sizing:border-box;display:inline-flex;justify-content:center;opacity:0;pointer-events:none;transition:opacity 120ms linear", 49725 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQndDIiwiZmlsZSI6InJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uLy4uL3RleHQnO1xuaW1wb3J0IHsgZm9udCwgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLmRpdmBcblx0Ym90dG9tOiAwO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRsZWZ0OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRyaWdodDogMDtcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2x0aXBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRvcGFjaXR5OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMjBtcyBsaW5lYXI7XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRmb250LXNpemU6IDEycHg7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdHBhZGRpbmc6IDRweCA4cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZCggVGV4dCApYFxuXHQmJiYge1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0fVxuYDtcbiJdfQ== */", 49726 toString: _EMOTION_STRINGIFIED_CSS_ERROR__38 49727 }); 49728 var Tooltip4 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 49729 target: "e1wq7y4k1" 49730 } : { 49731 target: "e1wq7y4k1", 49732 label: "Tooltip" 49733 })("background:", COLORS.theme.foreground, ";border-radius:", config_values_default.radiusSmall, ";box-sizing:border-box;font-family:", font("default.fontFamily"), ";font-size:12px;color:", COLORS.theme.foregroundInverted, ";padding:4px 8px;position:relative;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmlDIiwiZmlsZSI6InJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uLy4uL3RleHQnO1xuaW1wb3J0IHsgZm9udCwgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLmRpdmBcblx0Ym90dG9tOiAwO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRsZWZ0OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRyaWdodDogMDtcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2x0aXBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRvcGFjaXR5OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMjBtcyBsaW5lYXI7XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRmb250LXNpemU6IDEycHg7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdHBhZGRpbmc6IDRweCA4cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZCggVGV4dCApYFxuXHQmJiYge1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0fVxuYDtcbiJdfQ== */")); 49734 var LabelText = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default8, false ? { 49735 target: "e1wq7y4k0" 49736 } : { 49737 target: "e1wq7y4k0", 49738 label: "LabelText" 49739 })("&&&{color:", COLORS.theme.foregroundInverted, ";display:block;font-size:13px;line-height:1.4;white-space:nowrap;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q3VDIiwiZmlsZSI6InJlc2l6ZS10b29sdGlwLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uLy4uLy4uL3RleHQnO1xuaW1wb3J0IHsgZm9udCwgQ09MT1JTLCBDT05GSUcgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBSb290ID0gc3R5bGVkLmRpdmBcblx0Ym90dG9tOiAwO1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRsZWZ0OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0cG9zaXRpb246IGFic29sdXRlO1xuXHRyaWdodDogMDtcblx0dG9wOiAwO1xuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2x0aXBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0Ym94LXNpemluZzogYm9yZGVyLWJveDtcblx0ZGlzcGxheTogaW5saW5lLWZsZXg7XG5cdGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXHRvcGFjaXR5OiAwO1xuXHRwb2ludGVyLWV2ZW50czogbm9uZTtcblx0dHJhbnNpdGlvbjogb3BhY2l0eSAxMjBtcyBsaW5lYXI7XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHRpcCA9IHN0eWxlZC5kaXZgXG5cdGJhY2tncm91bmQ6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRib3gtc2l6aW5nOiBib3JkZXItYm94O1xuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRmb250LXNpemU6IDEycHg7XG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdHBhZGRpbmc6IDRweCA4cHg7XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcbmA7XG5cbi8vIFRPRE86IFJlc29sdmUgbmVlZCB0byB1c2UgJiYmIHRvIGluY3JlYXNlIHNwZWNpZmljaXR5XG4vLyBodHRwczovL2dpdGh1Yi5jb20vV29yZFByZXNzL2d1dGVuYmVyZy9pc3N1ZXMvMTg0ODNcblxuZXhwb3J0IGNvbnN0IExhYmVsVGV4dCA9IHN0eWxlZCggVGV4dCApYFxuXHQmJiYge1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuZm9yZWdyb3VuZEludmVydGVkIH07XG5cdFx0ZGlzcGxheTogYmxvY2s7XG5cdFx0Zm9udC1zaXplOiAxM3B4O1xuXHRcdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdFx0d2hpdGUtc3BhY2U6IG5vd3JhcDtcblx0fVxuYDtcbiJdfQ== */")); 49740 49741 // packages/components/build-module/resizable-box/resize-tooltip/label.js 49742 var import_jsx_runtime262 = __toESM(require_jsx_runtime()); 49743 var CORNER_OFFSET = 4; 49744 var CURSOR_OFFSET_TOP = CORNER_OFFSET * 2.5; 49745 function Label3({ 49746 label, 49747 position: position2 = POSITIONS.corner, 49748 zIndex = 1e3, 49749 ...props 49750 }, ref) { 49751 const showLabel = !!label; 49752 const isBottom = position2 === POSITIONS.bottom; 49753 const isCorner = position2 === POSITIONS.corner; 49754 if (!showLabel) { 49755 return null; 49756 } 49757 let style2 = { 49758 opacity: showLabel ? 1 : void 0, 49759 zIndex 49760 }; 49761 let labelStyle = {}; 49762 if (isBottom) { 49763 style2 = { 49764 ...style2, 49765 position: "absolute", 49766 bottom: CURSOR_OFFSET_TOP * -1, 49767 left: "50%", 49768 transform: "translate(-50%, 0)" 49769 }; 49770 labelStyle = { 49771 transform: `translate(0, 100%)` 49772 }; 49773 } 49774 if (isCorner) { 49775 style2 = { 49776 ...style2, 49777 position: "absolute", 49778 top: CORNER_OFFSET, 49779 right: (0, import_i18n74.isRTL)() ? void 0 : CORNER_OFFSET, 49780 left: (0, import_i18n74.isRTL)() ? CORNER_OFFSET : void 0 49781 }; 49782 } 49783 return /* @__PURE__ */ (0, import_jsx_runtime262.jsx)(TooltipWrapper, { 49784 "aria-hidden": "true", 49785 className: "components-resizable-tooltip__tooltip-wrapper", 49786 ref, 49787 style: style2, 49788 ...props, 49789 children: /* @__PURE__ */ (0, import_jsx_runtime262.jsx)(Tooltip4, { 49790 className: "components-resizable-tooltip__tooltip", 49791 style: labelStyle, 49792 children: /* @__PURE__ */ (0, import_jsx_runtime262.jsx)(LabelText, { 49793 as: "span", 49794 children: label 49795 }) 49796 }) 49797 }); 49798 } 49799 var ForwardedComponent3 = (0, import_element185.forwardRef)(Label3); 49800 var label_default = ForwardedComponent3; 49801 49802 // packages/components/build-module/resizable-box/resize-tooltip/index.js 49803 var import_jsx_runtime263 = __toESM(require_jsx_runtime()); 49804 var noop24 = () => { 49805 }; 49806 function ResizeTooltip({ 49807 axis, 49808 className: className2, 49809 fadeTimeout = 180, 49810 isVisible: isVisible2 = true, 49811 labelRef, 49812 onResize = noop24, 49813 position: position2 = POSITIONS.bottom, 49814 showPx = true, 49815 zIndex = 1e3, 49816 ...props 49817 }, ref) { 49818 const { 49819 label, 49820 resizeListener 49821 } = useResizeLabel({ 49822 axis, 49823 fadeTimeout, 49824 onResize, 49825 showPx, 49826 position: position2 49827 }); 49828 if (!isVisible2) { 49829 return null; 49830 } 49831 const classes = clsx_default("components-resize-tooltip", className2); 49832 return /* @__PURE__ */ (0, import_jsx_runtime263.jsxs)(Root4, { 49833 "aria-hidden": "true", 49834 className: classes, 49835 ref, 49836 ...props, 49837 children: [resizeListener, /* @__PURE__ */ (0, import_jsx_runtime263.jsx)(label_default, { 49838 "aria-hidden": props["aria-hidden"], 49839 label, 49840 position: position2, 49841 ref: labelRef, 49842 zIndex 49843 })] 49844 }); 49845 } 49846 var ForwardedComponent4 = (0, import_element186.forwardRef)(ResizeTooltip); 49847 var resize_tooltip_default = ForwardedComponent4; 49848 49849 // packages/components/build-module/resizable-box/index.js 49850 var import_jsx_runtime264 = __toESM(require_jsx_runtime()); 49851 var HANDLE_CLASS_NAME = "components-resizable-box__handle"; 49852 var SIDE_HANDLE_CLASS_NAME = "components-resizable-box__side-handle"; 49853 var CORNER_HANDLE_CLASS_NAME = "components-resizable-box__corner-handle"; 49854 var HANDLE_CLASSES = { 49855 top: clsx_default(HANDLE_CLASS_NAME, SIDE_HANDLE_CLASS_NAME, "components-resizable-box__handle-top"), 49856 right: clsx_default(HANDLE_CLASS_NAME, SIDE_HANDLE_CLASS_NAME, "components-resizable-box__handle-right"), 49857 bottom: clsx_default(HANDLE_CLASS_NAME, SIDE_HANDLE_CLASS_NAME, "components-resizable-box__handle-bottom"), 49858 left: clsx_default(HANDLE_CLASS_NAME, SIDE_HANDLE_CLASS_NAME, "components-resizable-box__handle-left"), 49859 topLeft: clsx_default(HANDLE_CLASS_NAME, CORNER_HANDLE_CLASS_NAME, "components-resizable-box__handle-top", "components-resizable-box__handle-left"), 49860 topRight: clsx_default(HANDLE_CLASS_NAME, CORNER_HANDLE_CLASS_NAME, "components-resizable-box__handle-top", "components-resizable-box__handle-right"), 49861 bottomRight: clsx_default(HANDLE_CLASS_NAME, CORNER_HANDLE_CLASS_NAME, "components-resizable-box__handle-bottom", "components-resizable-box__handle-right"), 49862 bottomLeft: clsx_default(HANDLE_CLASS_NAME, CORNER_HANDLE_CLASS_NAME, "components-resizable-box__handle-bottom", "components-resizable-box__handle-left") 49863 }; 49864 var HANDLE_STYLES_OVERRIDES = { 49865 width: void 0, 49866 height: void 0, 49867 top: void 0, 49868 right: void 0, 49869 bottom: void 0, 49870 left: void 0 49871 }; 49872 var HANDLE_STYLES = { 49873 top: HANDLE_STYLES_OVERRIDES, 49874 right: HANDLE_STYLES_OVERRIDES, 49875 bottom: HANDLE_STYLES_OVERRIDES, 49876 left: HANDLE_STYLES_OVERRIDES, 49877 topLeft: HANDLE_STYLES_OVERRIDES, 49878 topRight: HANDLE_STYLES_OVERRIDES, 49879 bottomRight: HANDLE_STYLES_OVERRIDES, 49880 bottomLeft: HANDLE_STYLES_OVERRIDES 49881 }; 49882 function UnforwardedResizableBox({ 49883 className: className2, 49884 children, 49885 showHandle = true, 49886 __experimentalShowTooltip: showTooltip = false, 49887 __experimentalTooltipProps: tooltipProps = {}, 49888 ...props 49889 }, ref) { 49890 return /* @__PURE__ */ (0, import_jsx_runtime264.jsxs)(Resizable, { 49891 className: clsx_default("components-resizable-box__container", showHandle && "has-show-handle", className2), 49892 handleComponent: Object.fromEntries(Object.keys(HANDLE_CLASSES).map((key) => [key, /* @__PURE__ */ (0, import_jsx_runtime264.jsx)("div", { 49893 tabIndex: -1 49894 }, key)])), 49895 handleClasses: HANDLE_CLASSES, 49896 handleStyles: HANDLE_STYLES, 49897 ref, 49898 ...props, 49899 children: [children, showTooltip && /* @__PURE__ */ (0, import_jsx_runtime264.jsx)(resize_tooltip_default, { 49900 ...tooltipProps 49901 })] 49902 }); 49903 } 49904 var ResizableBox = (0, import_element187.forwardRef)(UnforwardedResizableBox); 49905 var resizable_box_default = ResizableBox; 49906 49907 // packages/components/build-module/responsive-wrapper/index.js 49908 var import_element188 = __toESM(require_element()); 49909 var import_jsx_runtime265 = __toESM(require_jsx_runtime()); 49910 function ResponsiveWrapper({ 49911 naturalWidth, 49912 naturalHeight, 49913 children, 49914 isInline = false 49915 }) { 49916 if (import_element188.Children.count(children) !== 1) { 49917 return null; 49918 } 49919 const TagName59 = isInline ? "span" : "div"; 49920 let aspectRatio2; 49921 if (naturalWidth && naturalHeight) { 49922 aspectRatio2 = `$naturalWidth} / $naturalHeight}`; 49923 } 49924 return /* @__PURE__ */ (0, import_jsx_runtime265.jsx)(TagName59, { 49925 className: "components-responsive-wrapper", 49926 children: /* @__PURE__ */ (0, import_jsx_runtime265.jsx)("div", { 49927 children: (0, import_element188.cloneElement)(children, { 49928 className: clsx_default("components-responsive-wrapper__content", children.props.className), 49929 style: { 49930 ...children.props.style, 49931 aspectRatio: aspectRatio2 49932 } 49933 }) 49934 }) 49935 }); 49936 } 49937 var responsive_wrapper_default = ResponsiveWrapper; 49938 49939 // packages/components/build-module/sandbox/index.js 49940 var import_element189 = __toESM(require_element()); 49941 var import_compose72 = __toESM(require_compose()); 49942 var import_jsx_runtime266 = __toESM(require_jsx_runtime()); 49943 var observeAndResizeJS = function() { 49944 const { 49945 MutationObserver: MutationObserver2 49946 } = window; 49947 if (!MutationObserver2 || !document.body || !window.parent) { 49948 return; 49949 } 49950 function sendResize() { 49951 const clientBoundingRect = document.body.getBoundingClientRect(); 49952 window.parent.postMessage({ 49953 action: "resize", 49954 width: clientBoundingRect.width, 49955 height: clientBoundingRect.height 49956 }, "*"); 49957 } 49958 const observer = new MutationObserver2(sendResize); 49959 observer.observe(document.body, { 49960 attributes: true, 49961 attributeOldValue: false, 49962 characterData: true, 49963 characterDataOldValue: false, 49964 childList: true, 49965 subtree: true 49966 }); 49967 window.addEventListener("load", sendResize, true); 49968 function removeViewportStyles(ruleOrNode) { 49969 if (ruleOrNode.style) { 49970 ["width", "height", "minHeight", "maxHeight"].forEach(function(style2) { 49971 if (/^\\d+(vw|vh|svw|lvw|dvw|svh|lvh|dvh|vi|svi|lvi|dvi|vb|svb|lvb|dvb|vmin|svmin|lvmin|dvmin|vmax|svmax|lvmax|dvmax)$/.test(ruleOrNode.style[style2])) { 49972 ruleOrNode.style[style2] = ""; 49973 } 49974 }); 49975 } 49976 } 49977 Array.prototype.forEach.call(document.querySelectorAll("[style]"), removeViewportStyles); 49978 Array.prototype.forEach.call(document.styleSheets, function(stylesheet) { 49979 Array.prototype.forEach.call(stylesheet.cssRules || stylesheet.rules, removeViewportStyles); 49980 }); 49981 document.body.style.position = "absolute"; 49982 document.body.style.width = "100%"; 49983 document.body.setAttribute("data-resizable-iframe-connected", ""); 49984 sendResize(); 49985 window.addEventListener("resize", sendResize, true); 49986 }; 49987 var style = ` 49988 body { 49989 margin: 0; 49990 } 49991 html, 49992 body, 49993 body > div { 49994 width: 100%; 49995 } 49996 html.wp-has-aspect-ratio, 49997 body.wp-has-aspect-ratio, 49998 body.wp-has-aspect-ratio > div, 49999 body.wp-has-aspect-ratio > div iframe { 50000 width: 100%; 50001 height: 100%; 50002 overflow: hidden; /* If it has an aspect ratio, it shouldn't scroll. */ 50003 } 50004 body > div > * { 50005 margin-top: 0 !important; /* Has to have !important to override inline styles. */ 50006 margin-bottom: 0 !important; 50007 } 50008 `; 50009 function SandBox({ 50010 html = "", 50011 title = "", 50012 type, 50013 styles: styles3 = [], 50014 scripts = [], 50015 onFocus, 50016 tabIndex 50017 }) { 50018 const ref = (0, import_element189.useRef)(); 50019 const [width, setWidth] = (0, import_element189.useState)(0); 50020 const [height, setHeight] = (0, import_element189.useState)(0); 50021 function isFrameAccessible() { 50022 try { 50023 return !!ref.current?.contentDocument?.body; 50024 } catch (e3) { 50025 return false; 50026 } 50027 } 50028 function trySandBox(forceRerender = false) { 50029 if (!isFrameAccessible()) { 50030 return; 50031 } 50032 const { 50033 contentDocument, 50034 ownerDocument 50035 } = ref.current; 50036 if (!forceRerender && null !== contentDocument?.body.getAttribute("data-resizable-iframe-connected")) { 50037 return; 50038 } 50039 const htmlDoc = /* @__PURE__ */ (0, import_jsx_runtime266.jsxs)("html", { 50040 lang: ownerDocument.documentElement.lang, 50041 className: type, 50042 children: [/* @__PURE__ */ (0, import_jsx_runtime266.jsxs)("head", { 50043 children: [/* @__PURE__ */ (0, import_jsx_runtime266.jsx)("title", { 50044 children: title 50045 }), /* @__PURE__ */ (0, import_jsx_runtime266.jsx)("style", { 50046 dangerouslySetInnerHTML: { 50047 __html: style 50048 } 50049 }), styles3.map((rules, i3) => /* @__PURE__ */ (0, import_jsx_runtime266.jsx)("style", { 50050 dangerouslySetInnerHTML: { 50051 __html: rules 50052 } 50053 }, i3))] 50054 }), /* @__PURE__ */ (0, import_jsx_runtime266.jsxs)("body", { 50055 "data-resizable-iframe-connected": "data-resizable-iframe-connected", 50056 className: type, 50057 children: [/* @__PURE__ */ (0, import_jsx_runtime266.jsx)("div", { 50058 dangerouslySetInnerHTML: { 50059 __html: html 50060 } 50061 }), /* @__PURE__ */ (0, import_jsx_runtime266.jsx)("script", { 50062 type: "text/javascript", 50063 dangerouslySetInnerHTML: { 50064 __html: `($observeAndResizeJS.toString()})();` 50065 } 50066 }), scripts.map((src) => /* @__PURE__ */ (0, import_jsx_runtime266.jsx)("script", { 50067 src 50068 }, src))] 50069 })] 50070 }); 50071 contentDocument.open(); 50072 contentDocument.write("<!DOCTYPE html>" + (0, import_element189.renderToString)(htmlDoc)); 50073 contentDocument.close(); 50074 } 50075 (0, import_element189.useEffect)(() => { 50076 trySandBox(); 50077 function tryNoForceSandBox() { 50078 trySandBox(false); 50079 } 50080 function checkMessageForResize(event) { 50081 const iframe2 = ref.current; 50082 if (!iframe2 || iframe2.contentWindow !== event.source) { 50083 return; 50084 } 50085 let data = event.data || {}; 50086 if ("string" === typeof data) { 50087 try { 50088 data = JSON.parse(data); 50089 } catch (e3) { 50090 } 50091 } 50092 if ("resize" !== data.action) { 50093 return; 50094 } 50095 setWidth(data.width); 50096 setHeight(data.height); 50097 } 50098 const iframe = ref.current; 50099 const defaultView = iframe?.ownerDocument?.defaultView; 50100 iframe?.addEventListener("load", tryNoForceSandBox, false); 50101 defaultView?.addEventListener("message", checkMessageForResize); 50102 return () => { 50103 iframe?.removeEventListener("load", tryNoForceSandBox, false); 50104 defaultView?.removeEventListener("message", checkMessageForResize); 50105 }; 50106 }, []); 50107 (0, import_element189.useEffect)(() => { 50108 trySandBox(); 50109 }, [title, styles3, scripts]); 50110 (0, import_element189.useEffect)(() => { 50111 trySandBox(true); 50112 }, [html, type]); 50113 return /* @__PURE__ */ (0, import_jsx_runtime266.jsx)("iframe", { 50114 ref: (0, import_compose72.useMergeRefs)([ref, (0, import_compose72.useFocusableIframe)()]), 50115 title, 50116 tabIndex, 50117 className: "components-sandbox", 50118 sandbox: "allow-scripts allow-same-origin allow-presentation", 50119 onFocus, 50120 width: Math.ceil(width), 50121 height: Math.ceil(height) 50122 }); 50123 } 50124 var sandbox_default = SandBox; 50125 50126 // packages/components/build-module/snackbar/index.js 50127 var import_a11y10 = __toESM(require_a11y()); 50128 var import_element190 = __toESM(require_element()); 50129 var import_i18n75 = __toESM(require_i18n()); 50130 var import_warning9 = __toESM(require_warning()); 50131 var import_jsx_runtime267 = __toESM(require_jsx_runtime()); 50132 var NOTICE_TIMEOUT = 6e3; 50133 function useSpokenMessage2(message3, politeness) { 50134 const spokenMessage = typeof message3 === "string" ? message3 : (0, import_element190.renderToString)(message3); 50135 (0, import_element190.useEffect)(() => { 50136 if (spokenMessage) { 50137 (0, import_a11y10.speak)(spokenMessage, politeness); 50138 } 50139 }, [spokenMessage, politeness]); 50140 } 50141 function UnforwardedSnackbar({ 50142 className: className2, 50143 children, 50144 spokenMessage = children, 50145 politeness = "polite", 50146 actions = [], 50147 onRemove, 50148 icon = null, 50149 explicitDismiss = false, 50150 // onDismiss is a callback executed when the snackbar is dismissed. 50151 // It is distinct from onRemove, which _looks_ like a callback but is 50152 // actually the function to call to remove the snackbar from the UI. 50153 onDismiss, 50154 listRef 50155 }, ref) { 50156 function dismissMe(event) { 50157 if (event && event.preventDefault) { 50158 event.preventDefault(); 50159 } 50160 listRef?.current?.focus(); 50161 onDismiss?.(); 50162 onRemove?.(); 50163 } 50164 function onActionClick(event, onClick) { 50165 event.stopPropagation(); 50166 onRemove?.(); 50167 if (onClick) { 50168 onClick(event); 50169 } 50170 } 50171 useSpokenMessage2(spokenMessage, politeness); 50172 const callbacksRef = (0, import_element190.useRef)({ 50173 onDismiss, 50174 onRemove 50175 }); 50176 (0, import_element190.useLayoutEffect)(() => { 50177 callbacksRef.current = { 50178 onDismiss, 50179 onRemove 50180 }; 50181 }); 50182 (0, import_element190.useEffect)(() => { 50183 const timeoutHandle = setTimeout(() => { 50184 if (!explicitDismiss) { 50185 callbacksRef.current.onDismiss?.(); 50186 callbacksRef.current.onRemove?.(); 50187 } 50188 }, NOTICE_TIMEOUT); 50189 return () => clearTimeout(timeoutHandle); 50190 }, [explicitDismiss]); 50191 const classes = clsx_default(className2, "components-snackbar", { 50192 "components-snackbar-explicit-dismiss": !!explicitDismiss 50193 }); 50194 if (actions && actions.length > 1) { 50195 true ? (0, import_warning9.default)("Snackbar can only have one action. Use Notice if your message requires many actions.") : void 0; 50196 actions = [actions[0]]; 50197 } 50198 const snackbarContentClassnames = clsx_default("components-snackbar__content", { 50199 "components-snackbar__content-with-icon": !!icon 50200 }); 50201 return /* @__PURE__ */ (0, import_jsx_runtime267.jsx)("div", { 50202 ref, 50203 className: classes, 50204 onClick: !explicitDismiss ? dismissMe : void 0, 50205 tabIndex: 0, 50206 role: !explicitDismiss ? "button" : void 0, 50207 onKeyPress: !explicitDismiss ? dismissMe : void 0, 50208 "aria-label": !explicitDismiss ? (0, import_i18n75.__)("Dismiss this notice") : void 0, 50209 "data-testid": "snackbar", 50210 children: /* @__PURE__ */ (0, import_jsx_runtime267.jsxs)("div", { 50211 className: snackbarContentClassnames, 50212 children: [icon && /* @__PURE__ */ (0, import_jsx_runtime267.jsx)("div", { 50213 className: "components-snackbar__icon", 50214 children: icon 50215 }), children, actions.map(({ 50216 label, 50217 onClick, 50218 url, 50219 openInNewTab = false 50220 }, index2) => url !== void 0 && openInNewTab ? /* @__PURE__ */ (0, import_jsx_runtime267.jsx)(external_link_default, { 50221 href: url, 50222 onClick: (event) => onActionClick(event, onClick), 50223 className: "components-snackbar__action", 50224 children: label 50225 }, index2) : /* @__PURE__ */ (0, import_jsx_runtime267.jsx)(button_default, { 50226 __next40pxDefaultSize: true, 50227 href: url, 50228 variant: "link", 50229 onClick: (event) => onActionClick(event, onClick), 50230 className: "components-snackbar__action", 50231 children: label 50232 }, index2)), explicitDismiss && /* @__PURE__ */ (0, import_jsx_runtime267.jsx)("span", { 50233 role: "button", 50234 "aria-label": (0, import_i18n75.__)("Dismiss this notice"), 50235 tabIndex: 0, 50236 className: "components-snackbar__dismiss-button", 50237 onClick: dismissMe, 50238 onKeyPress: dismissMe, 50239 children: "\u2715" 50240 })] 50241 }) 50242 }); 50243 } 50244 var Snackbar = (0, import_element190.forwardRef)(UnforwardedSnackbar); 50245 var snackbar_default = Snackbar; 50246 50247 // packages/components/build-module/snackbar/list.js 50248 var import_compose73 = __toESM(require_compose()); 50249 var import_element191 = __toESM(require_element()); 50250 var import_jsx_runtime268 = __toESM(require_jsx_runtime()); 50251 var SNACKBAR_VARIANTS = { 50252 init: { 50253 height: 0, 50254 opacity: 0 50255 }, 50256 open: { 50257 height: "auto", 50258 opacity: 1, 50259 transition: { 50260 height: { 50261 type: "tween", 50262 duration: 0.3, 50263 ease: [0, 0, 0.2, 1] 50264 }, 50265 opacity: { 50266 type: "tween", 50267 duration: 0.25, 50268 delay: 0.05, 50269 ease: [0, 0, 0.2, 1] 50270 } 50271 } 50272 }, 50273 exit: { 50274 opacity: 0, 50275 transition: { 50276 type: "tween", 50277 duration: 0.1, 50278 ease: [0, 0, 0.2, 1] 50279 } 50280 } 50281 }; 50282 function SnackbarList({ 50283 notices, 50284 className: className2, 50285 children, 50286 onRemove 50287 }) { 50288 const listRef = (0, import_element191.useRef)(null); 50289 const isReducedMotion = (0, import_compose73.useReducedMotion)(); 50290 className2 = clsx_default("components-snackbar-list", className2); 50291 const removeNotice = (notice) => () => onRemove?.(notice.id); 50292 return /* @__PURE__ */ (0, import_jsx_runtime268.jsxs)("div", { 50293 className: className2, 50294 tabIndex: -1, 50295 ref: listRef, 50296 "data-testid": "snackbar-list", 50297 children: [children, /* @__PURE__ */ (0, import_jsx_runtime268.jsx)(AnimatePresence, { 50298 children: notices.map((notice) => { 50299 const { 50300 content, 50301 ...restNotice 50302 } = notice; 50303 return /* @__PURE__ */ (0, import_jsx_runtime268.jsx)(motion.div, { 50304 layout: !isReducedMotion, 50305 initial: "init", 50306 animate: "open", 50307 exit: "exit", 50308 variants: isReducedMotion ? void 0 : SNACKBAR_VARIANTS, 50309 children: /* @__PURE__ */ (0, import_jsx_runtime268.jsx)("div", { 50310 className: "components-snackbar-list__notice-container", 50311 children: /* @__PURE__ */ (0, import_jsx_runtime268.jsx)(snackbar_default, { 50312 ...restNotice, 50313 onRemove: removeNotice(notice), 50314 listRef, 50315 children: notice.content 50316 }) 50317 }) 50318 }, notice.id); 50319 }) 50320 })] 50321 }); 50322 } 50323 var list_default2 = SnackbarList; 50324 50325 // packages/components/build-module/tab-panel/index.js 50326 var import_element192 = __toESM(require_element()); 50327 var import_compose74 = __toESM(require_compose()); 50328 var import_i18n76 = __toESM(require_i18n()); 50329 var import_jsx_runtime269 = __toESM(require_jsx_runtime()); 50330 var extractTabName = (id3) => { 50331 if (typeof id3 === "undefined" || id3 === null) { 50332 return; 50333 } 50334 return id3.match(/^tab-panel-[0-9]*-(.*)/)?.[1]; 50335 }; 50336 var UnforwardedTabPanel = ({ 50337 className: className2, 50338 children, 50339 tabs, 50340 selectOnMove = true, 50341 initialTabName, 50342 orientation = "horizontal", 50343 activeClass = "is-active", 50344 onSelect 50345 }, ref) => { 50346 const instanceId = (0, import_compose74.useInstanceId)(TabPanel22, "tab-panel"); 50347 const prependInstanceId = (0, import_element192.useCallback)((tabName) => { 50348 if (typeof tabName === "undefined") { 50349 return; 50350 } 50351 return `$instanceId}-$tabName}`; 50352 }, [instanceId]); 50353 const tabStore = useTabStore({ 50354 setSelectedId: (newTabValue) => { 50355 if (typeof newTabValue === "undefined" || newTabValue === null) { 50356 return; 50357 } 50358 const newTab = tabs.find((t4) => prependInstanceId(t4.name) === newTabValue); 50359 if (newTab?.disabled || newTab === selectedTab) { 50360 return; 50361 } 50362 const simplifiedTabName = extractTabName(newTabValue); 50363 if (typeof simplifiedTabName === "undefined") { 50364 return; 50365 } 50366 onSelect?.(simplifiedTabName); 50367 }, 50368 orientation, 50369 selectOnMove, 50370 defaultSelectedId: prependInstanceId(initialTabName), 50371 rtl: (0, import_i18n76.isRTL)() 50372 }); 50373 const selectedTabName = extractTabName(useStoreState(tabStore, "selectedId")); 50374 const setTabStoreSelectedId = (0, import_element192.useCallback)((tabName) => { 50375 tabStore.setState("selectedId", prependInstanceId(tabName)); 50376 }, [prependInstanceId, tabStore]); 50377 const selectedTab = tabs.find(({ 50378 name 50379 }) => name === selectedTabName); 50380 const previousSelectedTabName = (0, import_compose74.usePrevious)(selectedTabName); 50381 (0, import_element192.useEffect)(() => { 50382 if (previousSelectedTabName !== selectedTabName && selectedTabName === initialTabName && !!selectedTabName) { 50383 onSelect?.(selectedTabName); 50384 } 50385 }, [selectedTabName, initialTabName, onSelect, previousSelectedTabName]); 50386 (0, import_element192.useLayoutEffect)(() => { 50387 if (selectedTab) { 50388 return; 50389 } 50390 const initialTab = tabs.find((tab) => tab.name === initialTabName); 50391 if (initialTabName && !initialTab) { 50392 return; 50393 } 50394 if (initialTab && !initialTab.disabled) { 50395 setTabStoreSelectedId(initialTab.name); 50396 } else { 50397 const firstEnabledTab = tabs.find((tab) => !tab.disabled); 50398 if (firstEnabledTab) { 50399 setTabStoreSelectedId(firstEnabledTab.name); 50400 } 50401 } 50402 }, [tabs, selectedTab, initialTabName, instanceId, setTabStoreSelectedId]); 50403 (0, import_element192.useEffect)(() => { 50404 if (!selectedTab?.disabled) { 50405 return; 50406 } 50407 const firstEnabledTab = tabs.find((tab) => !tab.disabled); 50408 if (firstEnabledTab) { 50409 setTabStoreSelectedId(firstEnabledTab.name); 50410 } 50411 }, [tabs, selectedTab?.disabled, setTabStoreSelectedId, instanceId]); 50412 return /* @__PURE__ */ (0, import_jsx_runtime269.jsxs)("div", { 50413 className: className2, 50414 ref, 50415 children: [/* @__PURE__ */ (0, import_jsx_runtime269.jsx)(TabList, { 50416 store: tabStore, 50417 className: "components-tab-panel__tabs", 50418 children: tabs.map((tab) => { 50419 return /* @__PURE__ */ (0, import_jsx_runtime269.jsx)(Tab, { 50420 id: prependInstanceId(tab.name), 50421 className: clsx_default("components-tab-panel__tabs-item", tab.className, { 50422 [activeClass]: tab.name === selectedTabName 50423 }), 50424 disabled: tab.disabled, 50425 "aria-controls": `$prependInstanceId(tab.name)}-view`, 50426 render: /* @__PURE__ */ (0, import_jsx_runtime269.jsx)(button_default, { 50427 __next40pxDefaultSize: true, 50428 icon: tab.icon, 50429 label: tab.icon && tab.title, 50430 showTooltip: !!tab.icon 50431 }), 50432 children: !tab.icon && tab.title 50433 }, tab.name); 50434 }) 50435 }), selectedTab && /* @__PURE__ */ (0, import_jsx_runtime269.jsx)(TabPanel, { 50436 id: `$prependInstanceId(selectedTab.name)}-view`, 50437 store: tabStore, 50438 tabId: prependInstanceId(selectedTab.name), 50439 className: "components-tab-panel__tab-content", 50440 children: children(selectedTab) 50441 })] 50442 }); 50443 }; 50444 var TabPanel22 = (0, import_element192.forwardRef)(UnforwardedTabPanel); 50445 var tab_panel_default = TabPanel22; 50446 50447 // packages/components/build-module/text-control/index.js 50448 var import_compose75 = __toESM(require_compose()); 50449 var import_element193 = __toESM(require_element()); 50450 var import_jsx_runtime270 = __toESM(require_jsx_runtime()); 50451 function UnforwardedTextControl(props, ref) { 50452 const { 50453 // Prevent passing this to `input`. 50454 __nextHasNoMarginBottom: _, 50455 __next40pxDefaultSize = false, 50456 label, 50457 hideLabelFromVision, 50458 value, 50459 help, 50460 id: idProp, 50461 className: className2, 50462 onChange, 50463 type = "text", 50464 ...additionalProps 50465 } = props; 50466 const id3 = (0, import_compose75.useInstanceId)(TextControl, "inspector-text-control", idProp); 50467 const onChangeValue = (event) => onChange(event.target.value); 50468 maybeWarnDeprecated36pxSize({ 50469 componentName: "TextControl", 50470 size: void 0, 50471 __next40pxDefaultSize 50472 }); 50473 return /* @__PURE__ */ (0, import_jsx_runtime270.jsx)(base_control_default, { 50474 label, 50475 hideLabelFromVision, 50476 id: id3, 50477 help, 50478 className: className2, 50479 children: /* @__PURE__ */ (0, import_jsx_runtime270.jsx)("input", { 50480 className: clsx_default("components-text-control__input", { 50481 "is-next-40px-default-size": __next40pxDefaultSize 50482 }), 50483 type, 50484 id: id3, 50485 value, 50486 onChange: onChangeValue, 50487 "aria-describedby": !!help ? id3 + "__help" : void 0, 50488 ref, 50489 ...additionalProps 50490 }) 50491 }); 50492 } 50493 var TextControl = (0, import_element193.forwardRef)(UnforwardedTextControl); 50494 var text_control_default = TextControl; 50495 50496 // packages/components/build-module/textarea-control/index.js 50497 var import_compose76 = __toESM(require_compose()); 50498 var import_element194 = __toESM(require_element()); 50499 50500 // packages/components/build-module/textarea-control/styles/textarea-control-styles.js 50501 var inputStyleNeutral = /* @__PURE__ */ css("box-shadow:0 0 0 transparent;border-radius:", config_values_default.radiusSmall, ";border:", config_values_default.borderWidth, " solid ", COLORS.ui.border, ";@media not ( prefers-reduced-motion ){transition:box-shadow 0.1s linear;}" + (false ? "" : ";label:inputStyleNeutral;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRleHRhcmVhLWNvbnRyb2wtc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWM2QiIsImZpbGUiOiJ0ZXh0YXJlYS1jb250cm9sLXN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgZm9udCB9IGZyb20gJy4uLy4uL3V0aWxzL2ZvbnQnO1xuaW1wb3J0IHsgQ09MT1JTIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29sb3JzLXZhbHVlcyc7XG5pbXBvcnQgeyBDT05GSUcgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyBicmVha3BvaW50IH0gZnJvbSAnLi4vLi4vdXRpbHMvYnJlYWtwb2ludCc7XG5cbmNvbnN0IGlucHV0U3R5bGVOZXV0cmFsID0gY3NzYFxuXHRib3gtc2hhZG93OiAwIDAgMCB0cmFuc3BhcmVudDtcblx0Ym9yZGVyLXJhZGl1czogJHsgQ09ORklHLnJhZGl1c1NtYWxsIH07XG5cdGJvcmRlcjogJHsgQ09ORklHLmJvcmRlcldpZHRoIH0gc29saWQgJHsgQ09MT1JTLnVpLmJvcmRlciB9O1xuXG5cdEBtZWRpYSBub3QgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdHRyYW5zaXRpb246IGJveC1zaGFkb3cgMC4xcyBsaW5lYXI7XG5cdH1cbmA7XG5cbmNvbnN0IGlucHV0U3R5bGVGb2N1cyA9IGNzc2Bcblx0Ym9yZGVyLWNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cdGJveC1zaGFkb3c6IDAgMCAwXG5cdFx0Y2FsYyggJHsgQ09ORklHLmJvcmRlcldpZHRoRm9jdXMgfSAtICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IClcblx0XHQkeyBDT0xPUlMudGhlbWUuYWNjZW50IH07XG5cblx0Ly8gV2luZG93cyBIaWdoIENvbnRyYXN0IG1vZGUgd2lsbCBzaG93IHRoaXMgb3V0bGluZSwgYnV0IG5vdCB0aGUgYm94LXNoYWRvdy5cblx0b3V0bGluZTogMnB4IHNvbGlkIHRyYW5zcGFyZW50O1xuYDtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZFRleHRhcmVhID0gc3R5bGVkLnRleHRhcmVhYFxuXHR3aWR0aDogMTAwJTtcblx0ZGlzcGxheTogYmxvY2s7XG5cdGZvbnQtZmFtaWx5OiAkeyBmb250KCAnZGVmYXVsdC5mb250RmFtaWx5JyApIH07XG5cdGxpbmUtaGVpZ2h0OiAyMHB4O1xuXHRiYWNrZ3JvdW5kOiAkeyBDT0xPUlMudGhlbWUuYmFja2dyb3VuZCB9O1xuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmZvcmVncm91bmQgfTtcblx0cmVzaXplOiB2ZXJ0aWNhbDtcblxuXHQvLyBWZXJ0aWNhbCBwYWRkaW5nIGlzIHRvIG1hdGNoIHRoZSBzdGFuZGFyZCA0MHB4IGNvbnRyb2wgaGVpZ2h0IHdoZW4gcm93cz0xLFxuXHQvLyBpbiBjb25qdW5jdGlvbiB3aXRoIHRoZSAyMHB4IGxpbmUtaGVpZ2h0LlxuXHQvLyBcIlN0YW5kYXJkXCIgbWV0cmljcyBhcmUgMTBweCAxMnB4LCBidXQgc3VidHJhY3RzIDFweCBlYWNoIHRvIGFjY291bnQgZm9yIHRoZSBib3JkZXIgd2lkdGguXG5cdHBhZGRpbmc6IDlweCAxMXB4O1xuXG5cdC8vIE1hdGNoaW5nIHRoZSAyMHB4IGxpbmUtaGVpZ2h0ICsgdGhlIDlweCB0b3AgYW5kIGJvdHRvbSBwYWRkaW5nLlxuXHRtaW4taGVpZ2h0OiAzOHB4O1xuXG5cdCR7IGlucHV0U3R5bGVOZXV0cmFsIH07XG5cblx0LyogRm9udHMgc21hbGxlciB0aGFuIDE2cHggY2F1c2VzIG1vYmlsZSBzYWZhcmkgdG8gem9vbS4gKi9cblx0Zm9udC1zaXplOiAkeyBmb250KCAnbW9iaWxlVGV4dE1pbkZvbnRTaXplJyApIH07XG5cblx0JHsgYnJlYWtwb2ludCggJ3NtYWxsJyApIH0ge1xuXHRcdGZvbnQtc2l6ZTogJHsgZm9udCggJ2RlZmF1bHQuZm9udFNpemUnICkgfTtcblx0fVxuXG5cdCY6Zm9jdXMge1xuXHRcdCR7IGlucHV0U3R5bGVGb2N1cyB9XG5cdH1cblxuXHQvLyBVc2Ugb3BhY2l0eSB0byB3b3JrIGluIHZhcmlvdXMgZWRpdG9yIHN0eWxlcy5cblx0Jjo6LXdlYmtpdC1pbnB1dC1wbGFjZWhvbGRlciB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy51aS5kYXJrR3JheVBsYWNlaG9sZGVyIH07XG5cdH1cblxuXHQmOjotbW96LXBsYWNlaG9sZGVyIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLmRhcmtHcmF5UGxhY2Vob2xkZXIgfTtcblx0fVxuXG5cdCY6LW1zLWlucHV0LXBsYWNlaG9sZGVyIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLmRhcmtHcmF5UGxhY2Vob2xkZXIgfTtcblx0fVxuXG5cdC5pcy1kYXJrLXRoZW1lICYge1xuXHRcdCY6Oi13ZWJraXQtaW5wdXQtcGxhY2Vob2xkZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy51aS5saWdodEdyYXlQbGFjZWhvbGRlciB9O1xuXHRcdH1cblxuXHRcdCY6Oi1tb3otcGxhY2Vob2xkZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy51aS5saWdodEdyYXlQbGFjZWhvbGRlciB9O1xuXHRcdH1cblxuXHRcdCY6LW1zLWlucHV0LXBsYWNlaG9sZGVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudWkubGlnaHRHcmF5UGxhY2Vob2xkZXIgfTtcblx0XHR9XG5cdH1cbmA7XG4iXX0= */"); 50502 var inputStyleFocus = /* @__PURE__ */ css("border-color:", COLORS.theme.accent, ";box-shadow:0 0 0 calc( ", config_values_default.borderWidthFocus, " - ", config_values_default.borderWidth, " ) ", COLORS.theme.accent, ";outline:2px solid transparent;" + (false ? "" : ";label:inputStyleFocus;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRleHRhcmVhLWNvbnRyb2wtc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdCMkIiLCJmaWxlIjoidGV4dGFyZWEtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGZvbnQgfSBmcm9tICcuLi8uLi91dGlscy9mb250JztcbmltcG9ydCB7IENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzL2NvbG9ycy12YWx1ZXMnO1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgYnJlYWtwb2ludCB9IGZyb20gJy4uLy4uL3V0aWxzL2JyZWFrcG9pbnQnO1xuXG5jb25zdCBpbnB1dFN0eWxlTmV1dHJhbCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOiBib3gtc2hhZG93IDAuMXMgbGluZWFyO1xuXHR9XG5gO1xuXG5jb25zdCBpbnB1dFN0eWxlRm9jdXMgPSBjc3NgXG5cdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRib3gtc2hhZG93OiAwIDAgMFxuXHRcdGNhbGMoICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gLSAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSApXG5cdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdC8vIFdpbmRvd3MgSGlnaCBDb250cmFzdCBtb2RlIHdpbGwgc2hvdyB0aGlzIG91dGxpbmUsIGJ1dCBub3QgdGhlIGJveC1zaGFkb3cuXG5cdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRUZXh0YXJlYSA9IHN0eWxlZC50ZXh0YXJlYWBcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmJhY2tncm91bmQgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdHJlc2l6ZTogdmVydGljYWw7XG5cblx0Ly8gVmVydGljYWwgcGFkZGluZyBpcyB0byBtYXRjaCB0aGUgc3RhbmRhcmQgNDBweCBjb250cm9sIGhlaWdodCB3aGVuIHJvd3M9MSxcblx0Ly8gaW4gY29uanVuY3Rpb24gd2l0aCB0aGUgMjBweCBsaW5lLWhlaWdodC5cblx0Ly8gXCJTdGFuZGFyZFwiIG1ldHJpY3MgYXJlIDEwcHggMTJweCwgYnV0IHN1YnRyYWN0cyAxcHggZWFjaCB0byBhY2NvdW50IGZvciB0aGUgYm9yZGVyIHdpZHRoLlxuXHRwYWRkaW5nOiA5cHggMTFweDtcblxuXHQvLyBNYXRjaGluZyB0aGUgMjBweCBsaW5lLWhlaWdodCArIHRoZSA5cHggdG9wIGFuZCBib3R0b20gcGFkZGluZy5cblx0bWluLWhlaWdodDogMzhweDtcblxuXHQkeyBpbnB1dFN0eWxlTmV1dHJhbCB9O1xuXG5cdC8qIEZvbnRzIHNtYWxsZXIgdGhhbiAxNnB4IGNhdXNlcyBtb2JpbGUgc2FmYXJpIHRvIHpvb20uICovXG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ21vYmlsZVRleHRNaW5Gb250U2l6ZScgKSB9O1xuXG5cdCR7IGJyZWFrcG9pbnQoICdzbWFsbCcgKSB9IHtcblx0XHRmb250LXNpemU6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRTaXplJyApIH07XG5cdH1cblxuXHQmOmZvY3VzIHtcblx0XHQkeyBpbnB1dFN0eWxlRm9jdXMgfVxuXHR9XG5cblx0Ly8gVXNlIG9wYWNpdHkgdG8gd29yayBpbiB2YXJpb3VzIGVkaXRvciBzdHlsZXMuXG5cdCY6Oi13ZWJraXQtaW5wdXQtcGxhY2Vob2xkZXIge1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkuZGFya0dyYXlQbGFjZWhvbGRlciB9O1xuXHR9XG5cblx0Jjo6LW1vei1wbGFjZWhvbGRlciB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy51aS5kYXJrR3JheVBsYWNlaG9sZGVyIH07XG5cdH1cblxuXHQmOi1tcy1pbnB1dC1wbGFjZWhvbGRlciB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy51aS5kYXJrR3JheVBsYWNlaG9sZGVyIH07XG5cdH1cblxuXHQuaXMtZGFyay10aGVtZSAmIHtcblx0XHQmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudWkubGlnaHRHcmF5UGxhY2Vob2xkZXIgfTtcblx0XHR9XG5cblx0XHQmOjotbW96LXBsYWNlaG9sZGVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudWkubGlnaHRHcmF5UGxhY2Vob2xkZXIgfTtcblx0XHR9XG5cblx0XHQmOi1tcy1pbnB1dC1wbGFjZWhvbGRlciB7XG5cdFx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLmxpZ2h0R3JheVBsYWNlaG9sZGVyIH07XG5cdFx0fVxuXHR9XG5gO1xuIl19 */"); 50503 var StyledTextarea = /* @__PURE__ */ emotion_styled_base_browser_esm_default("textarea", false ? { 50504 target: "e1w5nnrk0" 50505 } : { 50506 target: "e1w5nnrk0", 50507 label: "StyledTextarea" 50508 })("width:100%;display:block;font-family:", font("default.fontFamily"), ";line-height:20px;background:", COLORS.theme.background, ";color:", COLORS.theme.foreground, ";resize:vertical;padding:9px 11px;min-height:38px;", inputStyleNeutral, ";font-size:", font("mobileTextMinFontSize"), ";", breakpoint("small"), "{font-size:", font("default.fontSize"), ";}&:focus{", inputStyleFocus, ";}&::-webkit-input-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}&::-moz-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}&:-ms-input-placeholder{color:", COLORS.ui.darkGrayPlaceholder, ";}.is-dark-theme &{&::-webkit-input-placeholder{color:", COLORS.ui.lightGrayPlaceholder, ";}&::-moz-placeholder{color:", COLORS.ui.lightGrayPlaceholder, ";}&:-ms-input-placeholder{color:", COLORS.ui.lightGrayPlaceholder, ";}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRleHRhcmVhLWNvbnRyb2wtc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDNkMiLCJmaWxlIjoidGV4dGFyZWEtY29udHJvbC1zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbi8qKlxuICogSW50ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGZvbnQgfSBmcm9tICcuLi8uLi91dGlscy9mb250JztcbmltcG9ydCB7IENPTE9SUyB9IGZyb20gJy4uLy4uL3V0aWxzL2NvbG9ycy12YWx1ZXMnO1xuaW1wb3J0IHsgQ09ORklHIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgYnJlYWtwb2ludCB9IGZyb20gJy4uLy4uL3V0aWxzL2JyZWFrcG9pbnQnO1xuXG5jb25zdCBpbnB1dFN0eWxlTmV1dHJhbCA9IGNzc2Bcblx0Ym94LXNoYWRvdzogMCAwIDAgdHJhbnNwYXJlbnQ7XG5cdGJvcmRlci1yYWRpdXM6ICR7IENPTkZJRy5yYWRpdXNTbWFsbCB9O1xuXHRib3JkZXI6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy51aS5ib3JkZXIgfTtcblxuXHRAbWVkaWEgbm90ICggcHJlZmVycy1yZWR1Y2VkLW1vdGlvbiApIHtcblx0XHR0cmFuc2l0aW9uOiBib3gtc2hhZG93IDAuMXMgbGluZWFyO1xuXHR9XG5gO1xuXG5jb25zdCBpbnB1dFN0eWxlRm9jdXMgPSBjc3NgXG5cdGJvcmRlci1jb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXHRib3gtc2hhZG93OiAwIDAgMFxuXHRcdGNhbGMoICR7IENPTkZJRy5ib3JkZXJXaWR0aEZvY3VzIH0gLSAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSApXG5cdFx0JHsgQ09MT1JTLnRoZW1lLmFjY2VudCB9O1xuXG5cdC8vIFdpbmRvd3MgSGlnaCBDb250cmFzdCBtb2RlIHdpbGwgc2hvdyB0aGlzIG91dGxpbmUsIGJ1dCBub3QgdGhlIGJveC1zaGFkb3cuXG5cdG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRUZXh0YXJlYSA9IHN0eWxlZC50ZXh0YXJlYWBcblx0d2lkdGg6IDEwMCU7XG5cdGRpc3BsYXk6IGJsb2NrO1xuXHRmb250LWZhbWlseTogJHsgZm9udCggJ2RlZmF1bHQuZm9udEZhbWlseScgKSB9O1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0YmFja2dyb3VuZDogJHsgQ09MT1JTLnRoZW1lLmJhY2tncm91bmQgfTtcblx0Y29sb3I6ICR7IENPTE9SUy50aGVtZS5mb3JlZ3JvdW5kIH07XG5cdHJlc2l6ZTogdmVydGljYWw7XG5cblx0Ly8gVmVydGljYWwgcGFkZGluZyBpcyB0byBtYXRjaCB0aGUgc3RhbmRhcmQgNDBweCBjb250cm9sIGhlaWdodCB3aGVuIHJvd3M9MSxcblx0Ly8gaW4gY29uanVuY3Rpb24gd2l0aCB0aGUgMjBweCBsaW5lLWhlaWdodC5cblx0Ly8gXCJTdGFuZGFyZFwiIG1ldHJpY3MgYXJlIDEwcHggMTJweCwgYnV0IHN1YnRyYWN0cyAxcHggZWFjaCB0byBhY2NvdW50IGZvciB0aGUgYm9yZGVyIHdpZHRoLlxuXHRwYWRkaW5nOiA5cHggMTFweDtcblxuXHQvLyBNYXRjaGluZyB0aGUgMjBweCBsaW5lLWhlaWdodCArIHRoZSA5cHggdG9wIGFuZCBib3R0b20gcGFkZGluZy5cblx0bWluLWhlaWdodDogMzhweDtcblxuXHQkeyBpbnB1dFN0eWxlTmV1dHJhbCB9O1xuXG5cdC8qIEZvbnRzIHNtYWxsZXIgdGhhbiAxNnB4IGNhdXNlcyBtb2JpbGUgc2FmYXJpIHRvIHpvb20uICovXG5cdGZvbnQtc2l6ZTogJHsgZm9udCggJ21vYmlsZVRleHRNaW5Gb250U2l6ZScgKSB9O1xuXG5cdCR7IGJyZWFrcG9pbnQoICdzbWFsbCcgKSB9IHtcblx0XHRmb250LXNpemU6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRTaXplJyApIH07XG5cdH1cblxuXHQmOmZvY3VzIHtcblx0XHQkeyBpbnB1dFN0eWxlRm9jdXMgfVxuXHR9XG5cblx0Ly8gVXNlIG9wYWNpdHkgdG8gd29yayBpbiB2YXJpb3VzIGVkaXRvciBzdHlsZXMuXG5cdCY6Oi13ZWJraXQtaW5wdXQtcGxhY2Vob2xkZXIge1xuXHRcdGNvbG9yOiAkeyBDT0xPUlMudWkuZGFya0dyYXlQbGFjZWhvbGRlciB9O1xuXHR9XG5cblx0Jjo6LW1vei1wbGFjZWhvbGRlciB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy51aS5kYXJrR3JheVBsYWNlaG9sZGVyIH07XG5cdH1cblxuXHQmOi1tcy1pbnB1dC1wbGFjZWhvbGRlciB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy51aS5kYXJrR3JheVBsYWNlaG9sZGVyIH07XG5cdH1cblxuXHQuaXMtZGFyay10aGVtZSAmIHtcblx0XHQmOjotd2Via2l0LWlucHV0LXBsYWNlaG9sZGVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudWkubGlnaHRHcmF5UGxhY2Vob2xkZXIgfTtcblx0XHR9XG5cblx0XHQmOjotbW96LXBsYWNlaG9sZGVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMudWkubGlnaHRHcmF5UGxhY2Vob2xkZXIgfTtcblx0XHR9XG5cblx0XHQmOi1tcy1pbnB1dC1wbGFjZWhvbGRlciB7XG5cdFx0XHRjb2xvcjogJHsgQ09MT1JTLnVpLmxpZ2h0R3JheVBsYWNlaG9sZGVyIH07XG5cdFx0fVxuXHR9XG5gO1xuIl19 */")); 50509 50510 // packages/components/build-module/textarea-control/index.js 50511 var import_jsx_runtime271 = __toESM(require_jsx_runtime()); 50512 function UnforwardedTextareaControl(props, ref) { 50513 const { 50514 // Prevent passing this to `textarea`. 50515 __nextHasNoMarginBottom: _, 50516 label, 50517 hideLabelFromVision, 50518 value, 50519 help, 50520 onChange, 50521 rows = 4, 50522 className: className2, 50523 ...additionalProps 50524 } = props; 50525 const instanceId = (0, import_compose76.useInstanceId)(TextareaControl); 50526 const id3 = `inspector-textarea-control-$instanceId}`; 50527 const onChangeValue = (event) => onChange(event.target.value); 50528 const classes = clsx_default("components-textarea-control", className2); 50529 return /* @__PURE__ */ (0, import_jsx_runtime271.jsx)(base_control_default, { 50530 label, 50531 hideLabelFromVision, 50532 id: id3, 50533 help, 50534 className: classes, 50535 children: /* @__PURE__ */ (0, import_jsx_runtime271.jsx)(StyledTextarea, { 50536 className: "components-textarea-control__input", 50537 id: id3, 50538 rows, 50539 onChange: onChangeValue, 50540 "aria-describedby": !!help ? id3 + "__help" : void 0, 50541 value, 50542 ref, 50543 ...additionalProps 50544 }) 50545 }); 50546 } 50547 var TextareaControl = (0, import_element194.forwardRef)(UnforwardedTextareaControl); 50548 var textarea_control_default = TextareaControl; 50549 50550 // packages/components/build-module/text-highlight/index.js 50551 var import_element195 = __toESM(require_element()); 50552 var import_jsx_runtime272 = __toESM(require_jsx_runtime()); 50553 var TextHighlight = (props) => { 50554 const { 50555 text = "", 50556 highlight = "" 50557 } = props; 50558 const trimmedHighlightText = highlight.trim(); 50559 if (!trimmedHighlightText) { 50560 return /* @__PURE__ */ (0, import_jsx_runtime272.jsx)(import_jsx_runtime272.Fragment, { 50561 children: text 50562 }); 50563 } 50564 const regex = new RegExp(`($escapeRegExp(trimmedHighlightText)})`, "gi"); 50565 return (0, import_element195.createInterpolateElement)(text.replace(regex, "<mark>$&</mark>"), { 50566 mark: /* @__PURE__ */ (0, import_jsx_runtime272.jsx)("mark", {}) 50567 }); 50568 }; 50569 var text_highlight_default = TextHighlight; 50570 50571 // packages/components/build-module/tip/index.js 50572 var import_jsx_runtime273 = __toESM(require_jsx_runtime()); 50573 function Tip(props) { 50574 const { 50575 children 50576 } = props; 50577 return /* @__PURE__ */ (0, import_jsx_runtime273.jsxs)("div", { 50578 className: "components-tip", 50579 children: [/* @__PURE__ */ (0, import_jsx_runtime273.jsx)(icon_default2, { 50580 icon: tip_default 50581 }), /* @__PURE__ */ (0, import_jsx_runtime273.jsx)("p", { 50582 children 50583 })] 50584 }); 50585 } 50586 var tip_default2 = Tip; 50587 50588 // packages/components/build-module/toggle-control/index.js 50589 var import_element196 = __toESM(require_element()); 50590 var import_compose77 = __toESM(require_compose()); 50591 var import_jsx_runtime274 = __toESM(require_jsx_runtime()); 50592 function UnforwardedToggleControl({ 50593 label, 50594 checked, 50595 help, 50596 className: className2, 50597 onChange, 50598 disabled 50599 }, ref) { 50600 function onChangeToggle(event) { 50601 onChange(event.target.checked); 50602 } 50603 const instanceId = (0, import_compose77.useInstanceId)(ToggleControl); 50604 const id3 = `inspector-toggle-control-$instanceId}`; 50605 let describedBy, helpLabel; 50606 if (help) { 50607 if (typeof help === "function") { 50608 if (checked !== void 0) { 50609 helpLabel = help(checked); 50610 } 50611 } else { 50612 helpLabel = help; 50613 } 50614 if (helpLabel) { 50615 describedBy = id3 + "__help"; 50616 } 50617 } 50618 return /* @__PURE__ */ (0, import_jsx_runtime274.jsx)(base_control_default, { 50619 id: id3, 50620 help: helpLabel && /* @__PURE__ */ (0, import_jsx_runtime274.jsx)("span", { 50621 className: "components-toggle-control__help", 50622 children: helpLabel 50623 }), 50624 className: clsx_default("components-toggle-control", className2), 50625 children: /* @__PURE__ */ (0, import_jsx_runtime274.jsxs)(component_default9, { 50626 justify: "flex-start", 50627 spacing: 2, 50628 children: [/* @__PURE__ */ (0, import_jsx_runtime274.jsx)(form_toggle_default, { 50629 id: id3, 50630 checked, 50631 onChange: onChangeToggle, 50632 "aria-describedby": describedBy, 50633 disabled, 50634 ref 50635 }), /* @__PURE__ */ (0, import_jsx_runtime274.jsx)(component_default5, { 50636 as: "label", 50637 htmlFor: id3, 50638 className: clsx_default("components-toggle-control__label", { 50639 "is-disabled": disabled 50640 }), 50641 children: label 50642 })] 50643 }) 50644 }); 50645 } 50646 var ToggleControl = (0, import_element196.forwardRef)(UnforwardedToggleControl); 50647 var toggle_control_default = ToggleControl; 50648 50649 // packages/components/build-module/toolbar/toolbar/index.js 50650 var import_element203 = __toESM(require_element()); 50651 var import_deprecated25 = __toESM(require_deprecated()); 50652 50653 // packages/components/build-module/toolbar/toolbar-group/index.js 50654 var import_element201 = __toESM(require_element()); 50655 50656 // packages/components/build-module/toolbar/toolbar-button/index.js 50657 var import_element199 = __toESM(require_element()); 50658 50659 // packages/components/build-module/toolbar/toolbar-item/index.js 50660 var import_element198 = __toESM(require_element()); 50661 var import_warning10 = __toESM(require_warning()); 50662 50663 // packages/components/build-module/toolbar/toolbar-context/index.js 50664 var import_element197 = __toESM(require_element()); 50665 var ToolbarContext = (0, import_element197.createContext)(void 0); 50666 ToolbarContext.displayName = "ToolbarContext"; 50667 var toolbar_context_default = ToolbarContext; 50668 50669 // packages/components/build-module/toolbar/toolbar-item/index.js 50670 var import_jsx_runtime275 = __toESM(require_jsx_runtime()); 50671 function UnforwardedToolbarItem({ 50672 children, 50673 as: Component9, 50674 ...props 50675 }, ref) { 50676 const accessibleToolbarStore = (0, import_element198.useContext)(toolbar_context_default); 50677 const isRenderProp = typeof children === "function"; 50678 if (!isRenderProp && !Component9) { 50679 true ? (0, import_warning10.default)("`ToolbarItem` is a generic headless component. You must pass either a `children` prop as a function or an `as` prop as a component. See https://developer.wordpress.org/block-editor/components/toolbar-item/") : void 0; 50680 return null; 50681 } 50682 const allProps = { 50683 ...props, 50684 ref, 50685 "data-toolbar-item": true 50686 }; 50687 if (!accessibleToolbarStore) { 50688 if (Component9) { 50689 return /* @__PURE__ */ (0, import_jsx_runtime275.jsx)(Component9, { 50690 ...allProps, 50691 children 50692 }); 50693 } 50694 if (!isRenderProp) { 50695 return null; 50696 } 50697 return children(allProps); 50698 } 50699 const render = isRenderProp ? children : Component9 && /* @__PURE__ */ (0, import_jsx_runtime275.jsx)(Component9, { 50700 children 50701 }); 50702 return /* @__PURE__ */ (0, import_jsx_runtime275.jsx)(ToolbarItem, { 50703 accessibleWhenDisabled: true, 50704 ...allProps, 50705 store: accessibleToolbarStore, 50706 render 50707 }); 50708 } 50709 var ToolbarItem22 = (0, import_element198.forwardRef)(UnforwardedToolbarItem); 50710 var toolbar_item_default = ToolbarItem22; 50711 50712 // packages/components/build-module/toolbar/toolbar-button/toolbar-button-container.js 50713 var import_jsx_runtime276 = __toESM(require_jsx_runtime()); 50714 var ToolbarButtonContainer = ({ 50715 children, 50716 className: className2 50717 }) => /* @__PURE__ */ (0, import_jsx_runtime276.jsx)("div", { 50718 className: className2, 50719 children 50720 }); 50721 var toolbar_button_container_default = ToolbarButtonContainer; 50722 50723 // packages/components/build-module/toolbar/toolbar-button/index.js 50724 var import_jsx_runtime277 = __toESM(require_jsx_runtime()); 50725 function useDeprecatedProps6({ 50726 isDisabled, 50727 ...otherProps 50728 }) { 50729 return { 50730 disabled: isDisabled, 50731 ...otherProps 50732 }; 50733 } 50734 function UnforwardedToolbarButton(props, ref) { 50735 const { 50736 children, 50737 className: className2, 50738 containerClassName, 50739 extraProps, 50740 isActive, 50741 title, 50742 ...restProps 50743 } = useDeprecatedProps6(props); 50744 const accessibleToolbarState = (0, import_element199.useContext)(toolbar_context_default); 50745 if (!accessibleToolbarState) { 50746 return /* @__PURE__ */ (0, import_jsx_runtime277.jsx)(toolbar_button_container_default, { 50747 className: containerClassName, 50748 children: /* @__PURE__ */ (0, import_jsx_runtime277.jsx)(button_default, { 50749 ref, 50750 icon: restProps.icon, 50751 size: "compact", 50752 label: title, 50753 shortcut: restProps.shortcut, 50754 "data-subscript": restProps.subscript, 50755 onClick: (event) => { 50756 event.stopPropagation(); 50757 if (restProps.onClick) { 50758 restProps.onClick(event); 50759 } 50760 }, 50761 className: clsx_default("components-toolbar__control", className2), 50762 isPressed: isActive, 50763 accessibleWhenDisabled: true, 50764 "data-toolbar-item": true, 50765 ...extraProps, 50766 ...restProps, 50767 children 50768 }) 50769 }); 50770 } 50771 return /* @__PURE__ */ (0, import_jsx_runtime277.jsx)(toolbar_item_default, { 50772 className: clsx_default("components-toolbar-button", className2), 50773 ...extraProps, 50774 ...restProps, 50775 ref, 50776 children: (toolbarItemProps) => /* @__PURE__ */ (0, import_jsx_runtime277.jsx)(button_default, { 50777 size: "compact", 50778 label: title, 50779 isPressed: isActive, 50780 ...toolbarItemProps, 50781 children 50782 }) 50783 }); 50784 } 50785 var ToolbarButton = (0, import_element199.forwardRef)(UnforwardedToolbarButton); 50786 var toolbar_button_default = ToolbarButton; 50787 50788 // packages/components/build-module/toolbar/toolbar-group/toolbar-group-container.js 50789 var import_jsx_runtime278 = __toESM(require_jsx_runtime()); 50790 var ToolbarGroupContainer = ({ 50791 className: className2, 50792 children, 50793 ...props 50794 }) => /* @__PURE__ */ (0, import_jsx_runtime278.jsx)("div", { 50795 className: className2, 50796 ...props, 50797 children 50798 }); 50799 var toolbar_group_container_default = ToolbarGroupContainer; 50800 50801 // packages/components/build-module/toolbar/toolbar-group/toolbar-group-collapsed.js 50802 var import_element200 = __toESM(require_element()); 50803 var import_jsx_runtime279 = __toESM(require_jsx_runtime()); 50804 function ToolbarGroupCollapsed({ 50805 controls = [], 50806 toggleProps, 50807 ...props 50808 }) { 50809 const accessibleToolbarState = (0, import_element200.useContext)(toolbar_context_default); 50810 const renderDropdownMenu = (internalToggleProps) => /* @__PURE__ */ (0, import_jsx_runtime279.jsx)(dropdown_menu_default, { 50811 controls, 50812 toggleProps: { 50813 ...internalToggleProps, 50814 "data-toolbar-item": true 50815 }, 50816 ...props 50817 }); 50818 if (accessibleToolbarState) { 50819 return /* @__PURE__ */ (0, import_jsx_runtime279.jsx)(toolbar_item_default, { 50820 ...toggleProps, 50821 children: renderDropdownMenu 50822 }); 50823 } 50824 return renderDropdownMenu(toggleProps); 50825 } 50826 var toolbar_group_collapsed_default = ToolbarGroupCollapsed; 50827 50828 // packages/components/build-module/toolbar/toolbar-group/index.js 50829 var import_jsx_runtime280 = __toESM(require_jsx_runtime()); 50830 function isNestedArray(arr) { 50831 return Array.isArray(arr) && Array.isArray(arr[0]); 50832 } 50833 function ToolbarGroup({ 50834 controls = [], 50835 children, 50836 className: className2, 50837 isCollapsed: isCollapsed2, 50838 title, 50839 ...props 50840 }) { 50841 const accessibleToolbarState = (0, import_element201.useContext)(toolbar_context_default); 50842 if ((!controls || !controls.length) && !children) { 50843 return null; 50844 } 50845 const finalClassName = clsx_default( 50846 // Unfortunately, there's legacy code referencing to `.components-toolbar` 50847 // So we can't get rid of it 50848 accessibleToolbarState ? "components-toolbar-group" : "components-toolbar", 50849 className2 50850 ); 50851 let controlSets; 50852 if (isNestedArray(controls)) { 50853 controlSets = controls; 50854 } else { 50855 controlSets = [controls]; 50856 } 50857 if (isCollapsed2) { 50858 return /* @__PURE__ */ (0, import_jsx_runtime280.jsx)(toolbar_group_collapsed_default, { 50859 label: title, 50860 controls: controlSets, 50861 className: finalClassName, 50862 children, 50863 ...props 50864 }); 50865 } 50866 return /* @__PURE__ */ (0, import_jsx_runtime280.jsxs)(toolbar_group_container_default, { 50867 className: finalClassName, 50868 ...props, 50869 children: [controlSets?.flatMap((controlSet, indexOfSet) => controlSet.map((control, indexOfControl) => /* @__PURE__ */ (0, import_jsx_runtime280.jsx)(toolbar_button_default, { 50870 containerClassName: indexOfSet > 0 && indexOfControl === 0 ? "has-left-divider" : void 0, 50871 ...control 50872 }, [indexOfSet, indexOfControl].join()))), children] 50873 }); 50874 } 50875 var toolbar_group_default = ToolbarGroup; 50876 50877 // packages/components/build-module/toolbar/toolbar/toolbar-container.js 50878 var import_element202 = __toESM(require_element()); 50879 var import_i18n77 = __toESM(require_i18n()); 50880 var import_jsx_runtime281 = __toESM(require_jsx_runtime()); 50881 function UnforwardedToolbarContainer({ 50882 label, 50883 ...props 50884 }, ref) { 50885 const toolbarStore = useToolbarStore({ 50886 focusLoop: true, 50887 rtl: (0, import_i18n77.isRTL)() 50888 }); 50889 return ( 50890 // This will provide state for `ToolbarButton`'s 50891 /* @__PURE__ */ (0, import_jsx_runtime281.jsx)(toolbar_context_default.Provider, { 50892 value: toolbarStore, 50893 children: /* @__PURE__ */ (0, import_jsx_runtime281.jsx)(Toolbar, { 50894 ref, 50895 "aria-label": label, 50896 store: toolbarStore, 50897 ...props 50898 }) 50899 }) 50900 ); 50901 } 50902 var ToolbarContainer2 = (0, import_element202.forwardRef)(UnforwardedToolbarContainer); 50903 var toolbar_container_default = ToolbarContainer2; 50904 50905 // packages/components/build-module/toolbar/toolbar/index.js 50906 var import_jsx_runtime282 = __toESM(require_jsx_runtime()); 50907 function UnforwardedToolbar({ 50908 className: className2, 50909 label, 50910 variant, 50911 ...props 50912 }, ref) { 50913 const isVariantDefined = variant !== void 0; 50914 const contextSystemValue = (0, import_element203.useMemo)(() => { 50915 if (isVariantDefined) { 50916 return {}; 50917 } 50918 return { 50919 DropdownMenu: { 50920 variant: "toolbar" 50921 }, 50922 Dropdown: { 50923 variant: "toolbar" 50924 }, 50925 Menu: { 50926 variant: "toolbar" 50927 } 50928 }; 50929 }, [isVariantDefined]); 50930 if (!label) { 50931 (0, import_deprecated25.default)("Using Toolbar without label prop", { 50932 since: "5.6", 50933 alternative: "ToolbarGroup component", 50934 link: "https://developer.wordpress.org/block-editor/components/toolbar/" 50935 }); 50936 const { 50937 title: _title, 50938 ...restProps 50939 } = props; 50940 return /* @__PURE__ */ (0, import_jsx_runtime282.jsx)(toolbar_group_default, { 50941 isCollapsed: false, 50942 ...restProps, 50943 className: className2 50944 }); 50945 } 50946 const finalClassName = clsx_default("components-accessible-toolbar", className2, variant && `is-$variant}`); 50947 return /* @__PURE__ */ (0, import_jsx_runtime282.jsx)(ContextSystemProvider, { 50948 value: contextSystemValue, 50949 children: /* @__PURE__ */ (0, import_jsx_runtime282.jsx)(toolbar_container_default, { 50950 className: finalClassName, 50951 label, 50952 ref, 50953 ...props 50954 }) 50955 }); 50956 } 50957 var Toolbar3 = (0, import_element203.forwardRef)(UnforwardedToolbar); 50958 var toolbar_default = Toolbar3; 50959 50960 // packages/components/build-module/toolbar/toolbar-dropdown-menu/index.js 50961 var import_element204 = __toESM(require_element()); 50962 var import_jsx_runtime283 = __toESM(require_jsx_runtime()); 50963 function UnforwardedToolbarDropdownMenu(props, ref) { 50964 const accessibleToolbarState = (0, import_element204.useContext)(toolbar_context_default); 50965 if (!accessibleToolbarState) { 50966 return /* @__PURE__ */ (0, import_jsx_runtime283.jsx)(dropdown_menu_default, { 50967 ...props 50968 }); 50969 } 50970 return /* @__PURE__ */ (0, import_jsx_runtime283.jsx)(toolbar_item_default, { 50971 ref, 50972 ...props.toggleProps, 50973 children: (toolbarItemProps) => /* @__PURE__ */ (0, import_jsx_runtime283.jsx)(dropdown_menu_default, { 50974 ...props, 50975 popoverProps: { 50976 ...props.popoverProps 50977 }, 50978 toggleProps: toolbarItemProps 50979 }) 50980 }); 50981 } 50982 var ToolbarDropdownMenu = (0, import_element204.forwardRef)(UnforwardedToolbarDropdownMenu); 50983 var toolbar_dropdown_menu_default = ToolbarDropdownMenu; 50984 50985 // packages/components/build-module/tools-panel/tools-panel-header/component.js 50986 var import_a11y11 = __toESM(require_a11y()); 50987 var import_i18n78 = __toESM(require_i18n()); 50988 50989 // packages/components/build-module/tools-panel/tools-panel-header/hook.js 50990 var import_element206 = __toESM(require_element()); 50991 50992 // packages/components/build-module/tools-panel/styles.js 50993 function _EMOTION_STRINGIFIED_CSS_ERROR__39() { 50994 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 50995 } 50996 var toolsPanelGrid = { 50997 columns: (columns) => /* @__PURE__ */ css("grid-template-columns:", `repeat( $columns}, minmax(0, 1fr) )`, ";" + (false ? "" : ";label:columns;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQm9DIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"), 50998 spacing: /* @__PURE__ */ css("column-gap:", space(4), ";row-gap:", space(4), ";" + (false ? "" : ";label:spacing;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQmEiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQge1xuXHRTdHlsZWRGaWVsZCBhcyBCYXNlQ29udHJvbEZpZWxkLFxuXHRTdHlsZWRIZWxwIGFzIEJhc2VDb250cm9sSGVscCxcblx0V3JhcHBlciBhcyBCYXNlQ29udHJvbFdyYXBwZXIsXG59IGZyb20gJy4uL2Jhc2UtY29udHJvbC9zdHlsZXMvYmFzZS1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5cbmNvbnN0IHRvb2xzUGFuZWxHcmlkID0ge1xuXHRjb2x1bW5zOiAoIGNvbHVtbnM6IG51bWJlciApID0+IGNzc2Bcblx0XHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6ICR7IGByZXBlYXQoICR7IGNvbHVtbnMgfSwgbWlubWF4KDAsIDFmcikgKWAgfTtcblx0YCxcblx0c3BhY2luZzogY3NzYFxuXHRcdGNvbHVtbi1nYXA6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRyb3ctZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdGAsXG5cdGl0ZW06IHtcblx0XHRmdWxsV2lkdGg6IGNzc2Bcblx0XHRcdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdFx0YCxcblx0fSxcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsID0gKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdCR7IHRvb2xzUGFuZWxHcmlkLmNvbHVtbnMoIGNvbHVtbnMgKSB9XG5cdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXG5cdGJvcmRlci10b3A6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyAzMDAgXSB9O1xuXHRtYXJnaW4tdG9wOiAtMXB4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG4vKipcbiAqIEl0ZW1zIGluamVjdGVkIGludG8gYSBUb29sc1BhbmVsIHZpYSBhIHZpcnR1YWwgYnViYmxpbmcgc2xvdCB3aWxsIHJlcXVpcmVcbiAqIGFuIGlubmVyIGRvbSBlbGVtZW50IHRvIGJlIGluamVjdGVkLiBUaGUgZm9sbG93aW5nIHJ1bGUgYWxsb3dzIGZvciB0aGVcbiAqIENTUyBncmlkIGRpc3BsYXkgdG8gYmUgcmUtZXN0YWJsaXNoZWQuXG4gKi9cblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxXaXRoSW5uZXJXcmFwcGVyID0gKCBjb2x1bW5zOiBudW1iZXIgKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0PiBkaXY6bm90KCA6Zmlyc3Qtb2YtdHlwZSApIHtcblx0XHRcdGRpc3BsYXk6IGdyaWQ7XG5cdFx0XHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuc3BhY2luZyB9XG5cdFx0XHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxIaWRkZW5Jbm5lcldyYXBwZXIgPSBjc3NgXG5cdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0ZGlzcGxheTogbm9uZTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxIZWFkZXIgPSBjc3NgXG5cdCR7IHRvb2xzUGFuZWxHcmlkLml0ZW0uZnVsbFdpZHRoIH1cblx0Z2FwOiAkeyBzcGFjZSggMiApIH07XG5cblx0LyoqXG5cdCAqIFRoZSB0YXJnZXRpbmcgb2YgZHJvcGRvd24gbWVudSBjb21wb25lbnQgY2xhc3NlcyBoZXJlIGlzIGEgdGVtcG9yYXJ5XG5cdCAqIG1lYXN1cmUgb25seS5cblx0ICpcblx0ICogVGhlIGZvbGxvd2luZyBzdHlsZXMgc2hvdWxkIGJlIHJlcGxhY2VkIG9uY2UgdGhlIERyb3Bkb3duTWVudSBoYXMgYmVlblxuXHQgKiByZWZhY3RvcmVkIGFuZCBjYW4gYmUgdGFyZ2V0ZWQgdmlhIGNvbXBvbmVudCBpbnRlcnBvbGF0aW9uLlxuXHQgKi9cblx0LmNvbXBvbmVudHMtZHJvcGRvd24tbWVudSB7XG5cdFx0bWFyZ2luOiAkeyBzcGFjZSggLTEgKSB9IDA7XG5cdFx0bGluZS1oZWlnaHQ6IDA7XG5cdH1cblx0JiYmJiAuY29tcG9uZW50cy1kcm9wZG93bi1tZW51X190b2dnbGUge1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0bWluLXdpZHRoOiAkeyBzcGFjZSggNiApIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGluZyA9IGNzc2Bcblx0Zm9udC1zaXplOiBpbmhlcml0O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRNZWRpdW0gfTtcblx0bGluZS1oZWlnaHQ6IG5vcm1hbDtcblxuXHQvKiBSZXF1aXJlZCB0byBtZWV0IHNwZWNpZmljaXR5IHJlcXVpcmVtZW50cyB0byBlbnN1cmUgemVybyBtYXJnaW4gKi9cblx0JiYge1xuXHRcdG1hcmdpbjogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxJdGVtID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cblx0LyogQ2xlYXIgc3BhY2luZyBpbiBhbmQgYXJvdW5kIGNvbnRyb2xzIGFkZGVkIGFzIHBhbmVsIGl0ZW1zLiAqL1xuXHQvKiBSZW1vdmUgd2hlbiB0aGV5IGNhbiBiZSBhZGRyZXNzZWQgdmlhIGNvbnRleHQgc3lzdGVtLiAqL1xuXHQmID4gZGl2LFxuXHQmID4gZmllbGRzZXQge1xuXHRcdHBhZGRpbmctYm90dG9tOiAwO1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdFx0bWF4LXdpZHRoOiAxMDAlO1xuXHR9XG5cblx0LyogUmVtb3ZlIEJhc2VDb250cm9sIGNvbXBvbmVudHMgbWFyZ2lucyBhbmQgbGVhdmUgc3BhY2luZyB0byBncmlkIGxheW91dCAqL1xuXHQmJiAkeyBCYXNlQ29udHJvbFdyYXBwZXIgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblxuXHRcdC8qKlxuXHRcdCAqIFRvIG1haW50YWluIHByb3BlciBzcGFjaW5nIHdpdGhpbiBhIGJhc2UgY29udHJvbCwgdGhlIGZpZWxkJ3MgYm90dG9tXG5cdFx0ICogbWFyZ2luIHNob3VsZCBvbmx5IGJlIHJlbW92ZWQgd2hlbiB0aGVyZSBpcyBubyBoZWxwIHRleHQgaW5jbHVkZWQgYW5kXG5cdFx0ICogaXQgaXMgdGhlcmVmb3JlIHRoZSBsYXN0LWNoaWxkLlxuXHRcdCAqL1xuXHRcdCR7IEJhc2VDb250cm9sRmllbGQgfTpsYXN0LWNoaWxkIHtcblx0XHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdFx0fVxuXHR9XG5cblx0JHsgQmFzZUNvbnRyb2xIZWxwIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbVBsYWNlaG9sZGVyID0gY3NzYFxuXHRkaXNwbGF5OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IERyb3Bkb3duTWVudSA9IGNzc2Bcblx0bWluLXdpZHRoOiAyMDBweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBSZXNldExhYmVsID0gc3R5bGVkLnNwYW5gXG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50RGFya2VyMTAgfTtcblx0Zm9udC1zaXplOiAxMXB4O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRNZWRpdW0gfTtcblx0bGluZS1oZWlnaHQ6IDEuNDtcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6IHNwYWNlKCAzICkgfSApIH1cblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEZWZhdWx0Q29udHJvbHNJdGVtID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cblx0JiZbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdFx0b3BhY2l0eTogMTtcblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdH1cblxuXHRcdCR7IFJlc2V0TGFiZWwgfSB7XG5cdFx0XHRvcGFjaXR5OiAwLjM7XG5cdFx0fVxuXHR9XG5gO1xuIl19 */"), 50999 item: { 51000 fullWidth: false ? { 51001 name: "18iuzk9", 51002 styles: "grid-column:1/-1" 51003 } : { 51004 name: "1nz7xr6-fullWidth", 51005 styles: "grid-column:1/-1;label:fullWidth;", 51006 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQmdCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */", 51007 toString: _EMOTION_STRINGIFIED_CSS_ERROR__39 51008 } 51009 } 51010 }; 51011 var ToolsPanel = (columns) => /* @__PURE__ */ css(toolsPanelGrid.columns(columns), " ", toolsPanelGrid.spacing, " border-top:", config_values_default.borderWidth, " solid ", COLORS.gray[300], ";margin-top:-1px;padding:", space(4), ";" + (false ? "" : ";label:ToolsPanel;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ29EIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"); 51012 var ToolsPanelWithInnerWrapper = (columns) => { 51013 return /* @__PURE__ */ css(">div:not( :first-of-type ){display:grid;", toolsPanelGrid.columns(columns), " ", toolsPanelGrid.spacing, " ", toolsPanelGrid.item.fullWidth, ";}" + (false ? "" : ";label:ToolsPanelWithInnerWrapper;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRFciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQge1xuXHRTdHlsZWRGaWVsZCBhcyBCYXNlQ29udHJvbEZpZWxkLFxuXHRTdHlsZWRIZWxwIGFzIEJhc2VDb250cm9sSGVscCxcblx0V3JhcHBlciBhcyBCYXNlQ29udHJvbFdyYXBwZXIsXG59IGZyb20gJy4uL2Jhc2UtY29udHJvbC9zdHlsZXMvYmFzZS1jb250cm9sLXN0eWxlcyc7XG5pbXBvcnQgeyBDT0xPUlMsIENPTkZJRywgcnRsIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgc3BhY2UgfSBmcm9tICcuLi91dGlscy9zcGFjZSc7XG5cbmNvbnN0IHRvb2xzUGFuZWxHcmlkID0ge1xuXHRjb2x1bW5zOiAoIGNvbHVtbnM6IG51bWJlciApID0+IGNzc2Bcblx0XHRncmlkLXRlbXBsYXRlLWNvbHVtbnM6ICR7IGByZXBlYXQoICR7IGNvbHVtbnMgfSwgbWlubWF4KDAsIDFmcikgKWAgfTtcblx0YCxcblx0c3BhY2luZzogY3NzYFxuXHRcdGNvbHVtbi1nYXA6ICR7IHNwYWNlKCA0ICkgfTtcblx0XHRyb3ctZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdGAsXG5cdGl0ZW06IHtcblx0XHRmdWxsV2lkdGg6IGNzc2Bcblx0XHRcdGdyaWQtY29sdW1uOiAxIC8gLTE7XG5cdFx0YCxcblx0fSxcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsID0gKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdCR7IHRvb2xzUGFuZWxHcmlkLmNvbHVtbnMoIGNvbHVtbnMgKSB9XG5cdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXG5cdGJvcmRlci10b3A6ICR7IENPTkZJRy5ib3JkZXJXaWR0aCB9IHNvbGlkICR7IENPTE9SUy5ncmF5WyAzMDAgXSB9O1xuXHRtYXJnaW4tdG9wOiAtMXB4O1xuXHRwYWRkaW5nOiAkeyBzcGFjZSggNCApIH07XG5gO1xuXG4vKipcbiAqIEl0ZW1zIGluamVjdGVkIGludG8gYSBUb29sc1BhbmVsIHZpYSBhIHZpcnR1YWwgYnViYmxpbmcgc2xvdCB3aWxsIHJlcXVpcmVcbiAqIGFuIGlubmVyIGRvbSBlbGVtZW50IHRvIGJlIGluamVjdGVkLiBUaGUgZm9sbG93aW5nIHJ1bGUgYWxsb3dzIGZvciB0aGVcbiAqIENTUyBncmlkIGRpc3BsYXkgdG8gYmUgcmUtZXN0YWJsaXNoZWQuXG4gKi9cblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxXaXRoSW5uZXJXcmFwcGVyID0gKCBjb2x1bW5zOiBudW1iZXIgKSA9PiB7XG5cdHJldHVybiBjc3NgXG5cdFx0PiBkaXY6bm90KCA6Zmlyc3Qtb2YtdHlwZSApIHtcblx0XHRcdGRpc3BsYXk6IGdyaWQ7XG5cdFx0XHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuc3BhY2luZyB9XG5cdFx0XHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdFx0fVxuXHRgO1xufTtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxIaWRkZW5Jbm5lcldyYXBwZXIgPSBjc3NgXG5cdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0ZGlzcGxheTogbm9uZTtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxIZWFkZXIgPSBjc3NgXG5cdCR7IHRvb2xzUGFuZWxHcmlkLml0ZW0uZnVsbFdpZHRoIH1cblx0Z2FwOiAkeyBzcGFjZSggMiApIH07XG5cblx0LyoqXG5cdCAqIFRoZSB0YXJnZXRpbmcgb2YgZHJvcGRvd24gbWVudSBjb21wb25lbnQgY2xhc3NlcyBoZXJlIGlzIGEgdGVtcG9yYXJ5XG5cdCAqIG1lYXN1cmUgb25seS5cblx0ICpcblx0ICogVGhlIGZvbGxvd2luZyBzdHlsZXMgc2hvdWxkIGJlIHJlcGxhY2VkIG9uY2UgdGhlIERyb3Bkb3duTWVudSBoYXMgYmVlblxuXHQgKiByZWZhY3RvcmVkIGFuZCBjYW4gYmUgdGFyZ2V0ZWQgdmlhIGNvbXBvbmVudCBpbnRlcnBvbGF0aW9uLlxuXHQgKi9cblx0LmNvbXBvbmVudHMtZHJvcGRvd24tbWVudSB7XG5cdFx0bWFyZ2luOiAkeyBzcGFjZSggLTEgKSB9IDA7XG5cdFx0bGluZS1oZWlnaHQ6IDA7XG5cdH1cblx0JiYmJiAuY29tcG9uZW50cy1kcm9wZG93bi1tZW51X190b2dnbGUge1xuXHRcdHBhZGRpbmc6IDA7XG5cdFx0bWluLXdpZHRoOiAkeyBzcGFjZSggNiApIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGluZyA9IGNzc2Bcblx0Zm9udC1zaXplOiBpbmhlcml0O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRNZWRpdW0gfTtcblx0bGluZS1oZWlnaHQ6IG5vcm1hbDtcblxuXHQvKiBSZXF1aXJlZCB0byBtZWV0IHNwZWNpZmljaXR5IHJlcXVpcmVtZW50cyB0byBlbnN1cmUgemVybyBtYXJnaW4gKi9cblx0JiYge1xuXHRcdG1hcmdpbjogMDtcblx0fVxuYDtcblxuZXhwb3J0IGNvbnN0IFRvb2xzUGFuZWxJdGVtID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cblx0LyogQ2xlYXIgc3BhY2luZyBpbiBhbmQgYXJvdW5kIGNvbnRyb2xzIGFkZGVkIGFzIHBhbmVsIGl0ZW1zLiAqL1xuXHQvKiBSZW1vdmUgd2hlbiB0aGV5IGNhbiBiZSBhZGRyZXNzZWQgdmlhIGNvbnRleHQgc3lzdGVtLiAqL1xuXHQmID4gZGl2LFxuXHQmID4gZmllbGRzZXQge1xuXHRcdHBhZGRpbmctYm90dG9tOiAwO1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdFx0bWF4LXdpZHRoOiAxMDAlO1xuXHR9XG5cblx0LyogUmVtb3ZlIEJhc2VDb250cm9sIGNvbXBvbmVudHMgbWFyZ2lucyBhbmQgbGVhdmUgc3BhY2luZyB0byBncmlkIGxheW91dCAqL1xuXHQmJiAkeyBCYXNlQ29udHJvbFdyYXBwZXIgfSB7XG5cdFx0bWFyZ2luLWJvdHRvbTogMDtcblxuXHRcdC8qKlxuXHRcdCAqIFRvIG1haW50YWluIHByb3BlciBzcGFjaW5nIHdpdGhpbiBhIGJhc2UgY29udHJvbCwgdGhlIGZpZWxkJ3MgYm90dG9tXG5cdFx0ICogbWFyZ2luIHNob3VsZCBvbmx5IGJlIHJlbW92ZWQgd2hlbiB0aGVyZSBpcyBubyBoZWxwIHRleHQgaW5jbHVkZWQgYW5kXG5cdFx0ICogaXQgaXMgdGhlcmVmb3JlIHRoZSBsYXN0LWNoaWxkLlxuXHRcdCAqL1xuXHRcdCR7IEJhc2VDb250cm9sRmllbGQgfTpsYXN0LWNoaWxkIHtcblx0XHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdFx0fVxuXHR9XG5cblx0JHsgQmFzZUNvbnRyb2xIZWxwIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbVBsYWNlaG9sZGVyID0gY3NzYFxuXHRkaXNwbGF5OiBub25lO1xuYDtcblxuZXhwb3J0IGNvbnN0IERyb3Bkb3duTWVudSA9IGNzc2Bcblx0bWluLXdpZHRoOiAyMDBweDtcbmA7XG5cbmV4cG9ydCBjb25zdCBSZXNldExhYmVsID0gc3R5bGVkLnNwYW5gXG5cdGNvbG9yOiAkeyBDT0xPUlMudGhlbWUuYWNjZW50RGFya2VyMTAgfTtcblx0Zm9udC1zaXplOiAxMXB4O1xuXHRmb250LXdlaWdodDogJHsgQ09ORklHLmZvbnRXZWlnaHRNZWRpdW0gfTtcblx0bGluZS1oZWlnaHQ6IDEuNDtcblx0JHsgcnRsKCB7IG1hcmdpbkxlZnQ6IHNwYWNlKCAzICkgfSApIH1cblx0dGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEZWZhdWx0Q29udHJvbHNJdGVtID0gY3NzYFxuXHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDkwMCBdIH07XG5cblx0JiZbYXJpYS1kaXNhYmxlZD0ndHJ1ZSddIHtcblx0XHRjb2xvcjogJHsgQ09MT1JTLmdyYXlbIDcwMCBdIH07XG5cdFx0b3BhY2l0eTogMTtcblxuXHRcdCY6aG92ZXIge1xuXHRcdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdH1cblxuXHRcdCR7IFJlc2V0TGFiZWwgfSB7XG5cdFx0XHRvcGFjaXR5OiAwLjM7XG5cdFx0fVxuXHR9XG5gO1xuIl19 */"); 51014 }; 51015 var ToolsPanelHiddenInnerWrapper = false ? { 51016 name: "huufmu", 51017 styles: ">div:not( :first-of-type ){display:none;}" 51018 } : { 51019 name: "1vvi63i-ToolsPanelHiddenInnerWrapper", 51020 styles: ">div:not( :first-of-type ){display:none;};label:ToolsPanelHiddenInnerWrapper;", 51021 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRCtDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */", 51022 toString: _EMOTION_STRINGIFIED_CSS_ERROR__39 51023 }; 51024 var ToolsPanelHeader = /* @__PURE__ */ css(toolsPanelGrid.item.fullWidth, " gap:", space(2), ";.components-dropdown-menu{margin:", space(-1), " 0;line-height:0;}&&&& .components-dropdown-menu__toggle{padding:0;min-width:", space(6), ";}" + (false ? "" : ";label:ToolsPanelHeader;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRW1DIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"); 51025 var ToolsPanelHeading = /* @__PURE__ */ css("font-size:inherit;font-weight:", config_values_default.fontWeightMedium, ";line-height:normal;&&{margin:0;}" + (false ? "" : ";label:ToolsPanelHeading;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRm9DIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"); 51026 var ToolsPanelItem = /* @__PURE__ */ css(toolsPanelGrid.item.fullWidth, "&>div,&>fieldset{padding-bottom:0;margin-bottom:0;max-width:100%;}&& ", Wrapper, "{margin-bottom:0;", StyledField, ":last-child{margin-bottom:0;}}", StyledHelp, "{margin-bottom:0;}" + (false ? "" : ";label:ToolsPanelItem;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnR2lDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"); 51027 var ToolsPanelItemPlaceholder = false ? { 51028 name: "eivff4", 51029 styles: "display:none" 51030 } : { 51031 name: "16a3kc6-ToolsPanelItemPlaceholder", 51032 styles: "display:none;label:ToolsPanelItemPlaceholder;", 51033 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErSDRDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */", 51034 toString: _EMOTION_STRINGIFIED_CSS_ERROR__39 51035 }; 51036 var DropdownMenu2 = false ? { 51037 name: "16gsvie", 51038 styles: "min-width:200px" 51039 } : { 51040 name: "1lfy0sm-DropdownMenu", 51041 styles: "min-width:200px;label:DropdownMenu;", 51042 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtSStCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */", 51043 toString: _EMOTION_STRINGIFIED_CSS_ERROR__39 51044 }; 51045 var ResetLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 51046 target: "ews648u0" 51047 } : { 51048 target: "ews648u0", 51049 label: "ResetLabel" 51050 })("color:", COLORS.theme.accentDarker10, ";font-size:11px;font-weight:", config_values_default.fontWeightMedium, ";line-height:1.4;", rtl({ 51051 marginLeft: space(3) 51052 }), " text-transform:uppercase;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1SXFDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */")); 51053 var DefaultControlsItem = /* @__PURE__ */ css("color:", COLORS.gray[900], ";&&[aria-disabled='true']{color:", COLORS.gray[700], ";opacity:1;&:hover{color:", COLORS.gray[700], ";}", ResetLabel, "{opacity:0.3;}}" + (false ? "" : ";label:DefaultControlsItem;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnSnNDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHtcblx0U3R5bGVkRmllbGQgYXMgQmFzZUNvbnRyb2xGaWVsZCxcblx0U3R5bGVkSGVscCBhcyBCYXNlQ29udHJvbEhlbHAsXG5cdFdyYXBwZXIgYXMgQmFzZUNvbnRyb2xXcmFwcGVyLFxufSBmcm9tICcuLi9iYXNlLWNvbnRyb2wvc3R5bGVzL2Jhc2UtY29udHJvbC1zdHlsZXMnO1xuaW1wb3J0IHsgQ09MT1JTLCBDT05GSUcsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdXRpbHMvc3BhY2UnO1xuXG5jb25zdCB0b29sc1BhbmVsR3JpZCA9IHtcblx0Y29sdW1uczogKCBjb2x1bW5zOiBudW1iZXIgKSA9PiBjc3NgXG5cdFx0Z3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAkeyBgcmVwZWF0KCAkeyBjb2x1bW5zIH0sIG1pbm1heCgwLCAxZnIpIClgIH07XG5cdGAsXG5cdHNwYWNpbmc6IGNzc2Bcblx0XHRjb2x1bW4tZ2FwOiAkeyBzcGFjZSggNCApIH07XG5cdFx0cm93LWdhcDogJHsgc3BhY2UoIDQgKSB9O1xuXHRgLFxuXHRpdGVtOiB7XG5cdFx0ZnVsbFdpZHRoOiBjc3NgXG5cdFx0XHRncmlkLWNvbHVtbjogMSAvIC0xO1xuXHRcdGAsXG5cdH0sXG59O1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbCA9ICggY29sdW1uczogbnVtYmVyICkgPT4gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5jb2x1bW5zKCBjb2x1bW5zICkgfVxuXHQkeyB0b29sc1BhbmVsR3JpZC5zcGFjaW5nIH1cblxuXHRib3JkZXItdG9wOiAkeyBDT05GSUcuYm9yZGVyV2lkdGggfSBzb2xpZCAkeyBDT0xPUlMuZ3JheVsgMzAwIF0gfTtcblx0bWFyZ2luLXRvcDogLTFweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDQgKSB9O1xuYDtcblxuLyoqXG4gKiBJdGVtcyBpbmplY3RlZCBpbnRvIGEgVG9vbHNQYW5lbCB2aWEgYSB2aXJ0dWFsIGJ1YmJsaW5nIHNsb3Qgd2lsbCByZXF1aXJlXG4gKiBhbiBpbm5lciBkb20gZWxlbWVudCB0byBiZSBpbmplY3RlZC4gVGhlIGZvbGxvd2luZyBydWxlIGFsbG93cyBmb3IgdGhlXG4gKiBDU1MgZ3JpZCBkaXNwbGF5IHRvIGJlIHJlLWVzdGFibGlzaGVkLlxuICovXG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsV2l0aElubmVyV3JhcHBlciA9ICggY29sdW1uczogbnVtYmVyICkgPT4ge1xuXHRyZXR1cm4gY3NzYFxuXHRcdD4gZGl2Om5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0XHRkaXNwbGF5OiBncmlkO1xuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuY29sdW1ucyggY29sdW1ucyApIH1cblx0XHRcdCR7IHRvb2xzUGFuZWxHcmlkLnNwYWNpbmcgfVxuXHRcdFx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXHRcdH1cblx0YDtcbn07XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGlkZGVuSW5uZXJXcmFwcGVyID0gY3NzYFxuXHQ+IGRpdjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdGRpc3BsYXk6IG5vbmU7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSGVhZGVyID0gY3NzYFxuXHQkeyB0b29sc1BhbmVsR3JpZC5pdGVtLmZ1bGxXaWR0aCB9XG5cdGdhcDogJHsgc3BhY2UoIDIgKSB9O1xuXG5cdC8qKlxuXHQgKiBUaGUgdGFyZ2V0aW5nIG9mIGRyb3Bkb3duIG1lbnUgY29tcG9uZW50IGNsYXNzZXMgaGVyZSBpcyBhIHRlbXBvcmFyeVxuXHQgKiBtZWFzdXJlIG9ubHkuXG5cdCAqXG5cdCAqIFRoZSBmb2xsb3dpbmcgc3R5bGVzIHNob3VsZCBiZSByZXBsYWNlZCBvbmNlIHRoZSBEcm9wZG93bk1lbnUgaGFzIGJlZW5cblx0ICogcmVmYWN0b3JlZCBhbmQgY2FuIGJlIHRhcmdldGVkIHZpYSBjb21wb25lbnQgaW50ZXJwb2xhdGlvbi5cblx0ICovXG5cdC5jb21wb25lbnRzLWRyb3Bkb3duLW1lbnUge1xuXHRcdG1hcmdpbjogJHsgc3BhY2UoIC0xICkgfSAwO1xuXHRcdGxpbmUtaGVpZ2h0OiAwO1xuXHR9XG5cdCYmJiYgLmNvbXBvbmVudHMtZHJvcGRvd24tbWVudV9fdG9nZ2xlIHtcblx0XHRwYWRkaW5nOiAwO1xuXHRcdG1pbi13aWR0aDogJHsgc3BhY2UoIDYgKSB9O1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEhlYWRpbmcgPSBjc3NgXG5cdGZvbnQtc2l6ZTogaW5oZXJpdDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiBub3JtYWw7XG5cblx0LyogUmVxdWlyZWQgdG8gbWVldCBzcGVjaWZpY2l0eSByZXF1aXJlbWVudHMgdG8gZW5zdXJlIHplcm8gbWFyZ2luICovXG5cdCYmIHtcblx0XHRtYXJnaW46IDA7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUb29sc1BhbmVsSXRlbSA9IGNzc2Bcblx0JHsgdG9vbHNQYW5lbEdyaWQuaXRlbS5mdWxsV2lkdGggfVxuXG5cdC8qIENsZWFyIHNwYWNpbmcgaW4gYW5kIGFyb3VuZCBjb250cm9scyBhZGRlZCBhcyBwYW5lbCBpdGVtcy4gKi9cblx0LyogUmVtb3ZlIHdoZW4gdGhleSBjYW4gYmUgYWRkcmVzc2VkIHZpYSBjb250ZXh0IHN5c3RlbS4gKi9cblx0JiA+IGRpdixcblx0JiA+IGZpZWxkc2V0IHtcblx0XHRwYWRkaW5nLWJvdHRvbTogMDtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdG1heC13aWR0aDogMTAwJTtcblx0fVxuXG5cdC8qIFJlbW92ZSBCYXNlQ29udHJvbCBjb21wb25lbnRzIG1hcmdpbnMgYW5kIGxlYXZlIHNwYWNpbmcgdG8gZ3JpZCBsYXlvdXQgKi9cblx0JiYgJHsgQmFzZUNvbnRyb2xXcmFwcGVyIH0ge1xuXHRcdG1hcmdpbi1ib3R0b206IDA7XG5cblx0XHQvKipcblx0XHQgKiBUbyBtYWludGFpbiBwcm9wZXIgc3BhY2luZyB3aXRoaW4gYSBiYXNlIGNvbnRyb2wsIHRoZSBmaWVsZCdzIGJvdHRvbVxuXHRcdCAqIG1hcmdpbiBzaG91bGQgb25seSBiZSByZW1vdmVkIHdoZW4gdGhlcmUgaXMgbm8gaGVscCB0ZXh0IGluY2x1ZGVkIGFuZFxuXHRcdCAqIGl0IGlzIHRoZXJlZm9yZSB0aGUgbGFzdC1jaGlsZC5cblx0XHQgKi9cblx0XHQkeyBCYXNlQ29udHJvbEZpZWxkIH06bGFzdC1jaGlsZCB7XG5cdFx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHRcdH1cblx0fVxuXG5cdCR7IEJhc2VDb250cm9sSGVscCB9IHtcblx0XHRtYXJnaW4tYm90dG9tOiAwO1xuXHR9XG5gO1xuXG5leHBvcnQgY29uc3QgVG9vbHNQYW5lbEl0ZW1QbGFjZWhvbGRlciA9IGNzc2Bcblx0ZGlzcGxheTogbm9uZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnUgPSBjc3NgXG5cdG1pbi13aWR0aDogMjAwcHg7XG5gO1xuXG5leHBvcnQgY29uc3QgUmVzZXRMYWJlbCA9IHN0eWxlZC5zcGFuYFxuXHRjb2xvcjogJHsgQ09MT1JTLnRoZW1lLmFjY2VudERhcmtlcjEwIH07XG5cdGZvbnQtc2l6ZTogMTFweDtcblx0Zm9udC13ZWlnaHQ6ICR7IENPTkZJRy5mb250V2VpZ2h0TWVkaXVtIH07XG5cdGxpbmUtaGVpZ2h0OiAxLjQ7XG5cdCR7IHJ0bCggeyBtYXJnaW5MZWZ0OiBzcGFjZSggMyApIH0gKSB9XG5cdHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG5gO1xuXG5leHBvcnQgY29uc3QgRGVmYXVsdENvbnRyb2xzSXRlbSA9IGNzc2Bcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXG5cdCYmW2FyaWEtZGlzYWJsZWQ9J3RydWUnXSB7XG5cdFx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA3MDAgXSB9O1xuXHRcdG9wYWNpdHk6IDE7XG5cblx0XHQmOmhvdmVyIHtcblx0XHRcdGNvbG9yOiAkeyBDT0xPUlMuZ3JheVsgNzAwIF0gfTtcblx0XHR9XG5cblx0XHQkeyBSZXNldExhYmVsIH0ge1xuXHRcdFx0b3BhY2l0eTogMC4zO1xuXHRcdH1cblx0fVxuYDtcbiJdfQ== */"); 51054 51055 // packages/components/build-module/tools-panel/context.js 51056 var import_element205 = __toESM(require_element()); 51057 var noop25 = () => void 0; 51058 var ToolsPanelContext = (0, import_element205.createContext)({ 51059 menuItems: { 51060 default: {}, 51061 optional: {} 51062 }, 51063 hasMenuItems: false, 51064 isResetting: false, 51065 shouldRenderPlaceholderItems: false, 51066 registerPanelItem: noop25, 51067 deregisterPanelItem: noop25, 51068 flagItemCustomization: noop25, 51069 registerResetAllFilter: noop25, 51070 deregisterResetAllFilter: noop25, 51071 areAllOptionalControlsHidden: true 51072 }); 51073 ToolsPanelContext.displayName = "ToolsPanelContext"; 51074 var useToolsPanelContext = () => (0, import_element205.useContext)(ToolsPanelContext); 51075 51076 // packages/components/build-module/tools-panel/tools-panel-header/hook.js 51077 function useToolsPanelHeader(props) { 51078 const { 51079 className: className2, 51080 headingLevel = 2, 51081 ...otherProps 51082 } = useContextSystem(props, "ToolsPanelHeader"); 51083 const cx3 = useCx(); 51084 const classes = (0, import_element206.useMemo)(() => { 51085 return cx3(ToolsPanelHeader, className2); 51086 }, [className2, cx3]); 51087 const dropdownMenuClassName = (0, import_element206.useMemo)(() => { 51088 return cx3(DropdownMenu2); 51089 }, [cx3]); 51090 const headingClassName = (0, import_element206.useMemo)(() => { 51091 return cx3(ToolsPanelHeading); 51092 }, [cx3]); 51093 const defaultControlsItemClassName = (0, import_element206.useMemo)(() => { 51094 return cx3(DefaultControlsItem); 51095 }, [cx3]); 51096 const { 51097 menuItems, 51098 hasMenuItems, 51099 areAllOptionalControlsHidden 51100 } = useToolsPanelContext(); 51101 return { 51102 ...otherProps, 51103 areAllOptionalControlsHidden, 51104 defaultControlsItemClassName, 51105 dropdownMenuClassName, 51106 hasMenuItems, 51107 headingClassName, 51108 headingLevel, 51109 menuItems, 51110 className: classes 51111 }; 51112 } 51113 51114 // packages/components/build-module/tools-panel/tools-panel-header/component.js 51115 var import_jsx_runtime284 = __toESM(require_jsx_runtime()); 51116 var DefaultControlsGroup = ({ 51117 itemClassName, 51118 items, 51119 toggleItem 51120 }) => { 51121 if (!items.length) { 51122 return null; 51123 } 51124 const resetSuffix = /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(ResetLabel, { 51125 "aria-hidden": true, 51126 children: (0, import_i18n78.__)("Reset") 51127 }); 51128 return /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(import_jsx_runtime284.Fragment, { 51129 children: items.map(([label, hasValue]) => { 51130 if (hasValue) { 51131 return /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(menu_item_default, { 51132 className: itemClassName, 51133 role: "menuitem", 51134 label: (0, import_i18n78.sprintf)( 51135 // translators: %s: The name of the control being reset e.g. "Padding". 51136 (0, import_i18n78.__)("Reset %s"), 51137 label 51138 ), 51139 onClick: () => { 51140 toggleItem(label); 51141 (0, import_a11y11.speak)((0, import_i18n78.sprintf)( 51142 // translators: %s: The name of the control being reset e.g. "Padding". 51143 (0, import_i18n78.__)("%s reset to default"), 51144 label 51145 ), "assertive"); 51146 }, 51147 suffix: resetSuffix, 51148 children: label 51149 }, label); 51150 } 51151 return /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(menu_item_default, { 51152 icon: check_default, 51153 className: itemClassName, 51154 role: "menuitemcheckbox", 51155 isSelected: true, 51156 "aria-disabled": true, 51157 children: label 51158 }, label); 51159 }) 51160 }); 51161 }; 51162 var OptionalControlsGroup = ({ 51163 items, 51164 toggleItem 51165 }) => { 51166 if (!items.length) { 51167 return null; 51168 } 51169 return /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(import_jsx_runtime284.Fragment, { 51170 children: items.map(([label, isSelected2]) => { 51171 const itemLabel = isSelected2 ? (0, import_i18n78.sprintf)( 51172 // translators: %s: The name of the control being hidden and reset e.g. "Padding". 51173 (0, import_i18n78.__)("Hide and reset %s"), 51174 label 51175 ) : (0, import_i18n78.sprintf)( 51176 // translators: %s: The name of the control to display e.g. "Padding". 51177 (0, import_i18n78._x)("Show %s", "input control"), 51178 label 51179 ); 51180 return /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(menu_item_default, { 51181 icon: isSelected2 ? check_default : null, 51182 isSelected: isSelected2, 51183 label: itemLabel, 51184 onClick: () => { 51185 if (isSelected2) { 51186 (0, import_a11y11.speak)((0, import_i18n78.sprintf)( 51187 // translators: %s: The name of the control being reset e.g. "Padding". 51188 (0, import_i18n78.__)("%s hidden and reset to default"), 51189 label 51190 ), "assertive"); 51191 } else { 51192 (0, import_a11y11.speak)((0, import_i18n78.sprintf)( 51193 // translators: %s: The name of the control being reset e.g. "Padding". 51194 (0, import_i18n78.__)("%s is now visible"), 51195 label 51196 ), "assertive"); 51197 } 51198 toggleItem(label); 51199 }, 51200 role: "menuitemcheckbox", 51201 children: label 51202 }, label); 51203 }) 51204 }); 51205 }; 51206 var ToolsPanelHeader2 = (props, forwardedRef) => { 51207 const { 51208 areAllOptionalControlsHidden, 51209 defaultControlsItemClassName, 51210 dropdownMenuClassName, 51211 hasMenuItems, 51212 headingClassName, 51213 headingLevel = 2, 51214 label: labelText, 51215 menuItems, 51216 resetAll, 51217 toggleItem, 51218 dropdownMenuProps, 51219 ...headerProps 51220 } = useToolsPanelHeader(props); 51221 if (!labelText) { 51222 return null; 51223 } 51224 const defaultItems = Object.entries(menuItems?.default || {}); 51225 const optionalItems = Object.entries(menuItems?.optional || {}); 51226 const dropDownMenuIcon = areAllOptionalControlsHidden ? plus_default : more_vertical_default; 51227 const dropDownMenuLabelText = (0, import_i18n78.sprintf)( 51228 // translators: %s: The name of the tool e.g. "Color" or "Typography". 51229 (0, import_i18n78._x)("%s options", "Button label to reveal tool panel options"), 51230 labelText 51231 ); 51232 const dropdownMenuDescriptionText = areAllOptionalControlsHidden ? (0, import_i18n78.__)("All options are currently hidden") : void 0; 51233 const canResetAll = [...defaultItems, ...optionalItems].some(([, isSelected2]) => isSelected2); 51234 return /* @__PURE__ */ (0, import_jsx_runtime284.jsxs)(component_default9, { 51235 ...headerProps, 51236 ref: forwardedRef, 51237 children: [/* @__PURE__ */ (0, import_jsx_runtime284.jsx)(component_default19, { 51238 level: headingLevel, 51239 className: headingClassName, 51240 children: labelText 51241 }), hasMenuItems && /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(dropdown_menu_default, { 51242 ...dropdownMenuProps, 51243 icon: dropDownMenuIcon, 51244 label: dropDownMenuLabelText, 51245 menuProps: { 51246 className: dropdownMenuClassName 51247 }, 51248 toggleProps: { 51249 size: "small", 51250 description: dropdownMenuDescriptionText 51251 }, 51252 children: () => /* @__PURE__ */ (0, import_jsx_runtime284.jsxs)(import_jsx_runtime284.Fragment, { 51253 children: [/* @__PURE__ */ (0, import_jsx_runtime284.jsxs)(menu_group_default, { 51254 label: labelText, 51255 children: [/* @__PURE__ */ (0, import_jsx_runtime284.jsx)(DefaultControlsGroup, { 51256 items: defaultItems, 51257 toggleItem, 51258 itemClassName: defaultControlsItemClassName 51259 }), /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(OptionalControlsGroup, { 51260 items: optionalItems, 51261 toggleItem 51262 })] 51263 }), /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(menu_group_default, { 51264 children: /* @__PURE__ */ (0, import_jsx_runtime284.jsx)(menu_item_default, { 51265 "aria-disabled": !canResetAll, 51266 variant: "tertiary", 51267 onClick: () => { 51268 if (canResetAll) { 51269 resetAll(); 51270 (0, import_a11y11.speak)((0, import_i18n78.__)("All options reset"), "assertive"); 51271 } 51272 }, 51273 children: (0, import_i18n78.__)("Reset all") 51274 }) 51275 })] 51276 }) 51277 })] 51278 }); 51279 }; 51280 var ConnectedToolsPanelHeader = contextConnect(ToolsPanelHeader2, "ToolsPanelHeader"); 51281 var component_default38 = ConnectedToolsPanelHeader; 51282 51283 // packages/components/build-module/tools-panel/tools-panel/hook.js 51284 var import_element207 = __toESM(require_element()); 51285 var DEFAULT_COLUMNS = 2; 51286 function emptyMenuItems() { 51287 return { 51288 default: {}, 51289 optional: {} 51290 }; 51291 } 51292 function emptyState() { 51293 return { 51294 panelItems: [], 51295 menuItemOrder: [], 51296 menuItems: emptyMenuItems() 51297 }; 51298 } 51299 var generateMenuItems = ({ 51300 panelItems, 51301 shouldReset, 51302 currentMenuItems, 51303 menuItemOrder 51304 }) => { 51305 const newMenuItems = emptyMenuItems(); 51306 const menuItems = emptyMenuItems(); 51307 panelItems.forEach(({ 51308 hasValue, 51309 isShownByDefault, 51310 label 51311 }) => { 51312 const group = isShownByDefault ? "default" : "optional"; 51313 const existingItemValue = currentMenuItems?.[group]?.[label]; 51314 const value = existingItemValue ? existingItemValue : hasValue(); 51315 newMenuItems[group][label] = shouldReset ? false : value; 51316 }); 51317 menuItemOrder.forEach((key) => { 51318 if (newMenuItems.default.hasOwnProperty(key)) { 51319 menuItems.default[key] = newMenuItems.default[key]; 51320 } 51321 if (newMenuItems.optional.hasOwnProperty(key)) { 51322 menuItems.optional[key] = newMenuItems.optional[key]; 51323 } 51324 }); 51325 Object.keys(newMenuItems.default).forEach((key) => { 51326 if (!menuItems.default.hasOwnProperty(key)) { 51327 menuItems.default[key] = newMenuItems.default[key]; 51328 } 51329 }); 51330 Object.keys(newMenuItems.optional).forEach((key) => { 51331 if (!menuItems.optional.hasOwnProperty(key)) { 51332 menuItems.optional[key] = newMenuItems.optional[key]; 51333 } 51334 }); 51335 return menuItems; 51336 }; 51337 function panelItemsReducer(panelItems, action) { 51338 switch (action.type) { 51339 case "REGISTER_PANEL": { 51340 const newItems = [...panelItems]; 51341 const existingIndex = newItems.findIndex((oldItem) => oldItem.label === action.item.label); 51342 if (existingIndex !== -1) { 51343 newItems.splice(existingIndex, 1); 51344 } 51345 newItems.push(action.item); 51346 return newItems; 51347 } 51348 case "UNREGISTER_PANEL": { 51349 const index2 = panelItems.findIndex((item2) => item2.label === action.label); 51350 if (index2 !== -1) { 51351 const newItems = [...panelItems]; 51352 newItems.splice(index2, 1); 51353 return newItems; 51354 } 51355 return panelItems; 51356 } 51357 default: 51358 return panelItems; 51359 } 51360 } 51361 function menuItemOrderReducer(menuItemOrder, action) { 51362 switch (action.type) { 51363 case "REGISTER_PANEL": { 51364 if (menuItemOrder.includes(action.item.label)) { 51365 return menuItemOrder; 51366 } 51367 return [...menuItemOrder, action.item.label]; 51368 } 51369 default: 51370 return menuItemOrder; 51371 } 51372 } 51373 function menuItemsReducer(state, action) { 51374 switch (action.type) { 51375 case "REGISTER_PANEL": 51376 case "UNREGISTER_PANEL": 51377 return generateMenuItems({ 51378 currentMenuItems: state.menuItems, 51379 panelItems: state.panelItems, 51380 menuItemOrder: state.menuItemOrder, 51381 shouldReset: false 51382 }); 51383 case "RESET_ALL": 51384 return generateMenuItems({ 51385 panelItems: state.panelItems, 51386 menuItemOrder: state.menuItemOrder, 51387 shouldReset: true 51388 }); 51389 case "UPDATE_VALUE": { 51390 const oldValue = state.menuItems[action.group][action.label]; 51391 if (action.value === oldValue) { 51392 return state.menuItems; 51393 } 51394 return { 51395 ...state.menuItems, 51396 [action.group]: { 51397 ...state.menuItems[action.group], 51398 [action.label]: action.value 51399 } 51400 }; 51401 } 51402 case "TOGGLE_VALUE": { 51403 const currentItem = state.panelItems.find((item2) => item2.label === action.label); 51404 if (!currentItem) { 51405 return state.menuItems; 51406 } 51407 const menuGroup = currentItem.isShownByDefault ? "default" : "optional"; 51408 const newMenuItems = { 51409 ...state.menuItems, 51410 [menuGroup]: { 51411 ...state.menuItems[menuGroup], 51412 [action.label]: !state.menuItems[menuGroup][action.label] 51413 } 51414 }; 51415 return newMenuItems; 51416 } 51417 default: 51418 return state.menuItems; 51419 } 51420 } 51421 function panelReducer(state, action) { 51422 const panelItems = panelItemsReducer(state.panelItems, action); 51423 const menuItemOrder = menuItemOrderReducer(state.menuItemOrder, action); 51424 const menuItems = menuItemsReducer({ 51425 panelItems, 51426 menuItemOrder, 51427 menuItems: state.menuItems 51428 }, action); 51429 return { 51430 panelItems, 51431 menuItemOrder, 51432 menuItems 51433 }; 51434 } 51435 function resetAllFiltersReducer(filters, action) { 51436 switch (action.type) { 51437 case "REGISTER": 51438 return [...filters, action.filter]; 51439 case "UNREGISTER": 51440 return filters.filter((f3) => f3 !== action.filter); 51441 default: 51442 return filters; 51443 } 51444 } 51445 var isMenuItemTypeEmpty = (obj) => Object.keys(obj).length === 0; 51446 function useToolsPanel(props) { 51447 const { 51448 className: className2, 51449 headingLevel = 2, 51450 resetAll, 51451 panelId, 51452 hasInnerWrapper = false, 51453 shouldRenderPlaceholderItems = false, 51454 __experimentalFirstVisibleItemClass, 51455 __experimentalLastVisibleItemClass, 51456 ...otherProps 51457 } = useContextSystem(props, "ToolsPanel"); 51458 const isResettingRef = (0, import_element207.useRef)(false); 51459 const wasResetting = isResettingRef.current; 51460 (0, import_element207.useEffect)(() => { 51461 if (wasResetting) { 51462 isResettingRef.current = false; 51463 } 51464 }, [wasResetting]); 51465 const [{ 51466 panelItems, 51467 menuItems 51468 }, panelDispatch] = (0, import_element207.useReducer)(panelReducer, void 0, emptyState); 51469 const [resetAllFilters, dispatchResetAllFilters] = (0, import_element207.useReducer)(resetAllFiltersReducer, []); 51470 const registerPanelItem = (0, import_element207.useCallback)((item2) => { 51471 panelDispatch({ 51472 type: "REGISTER_PANEL", 51473 item: item2 51474 }); 51475 }, []); 51476 const deregisterPanelItem = (0, import_element207.useCallback)((label) => { 51477 panelDispatch({ 51478 type: "UNREGISTER_PANEL", 51479 label 51480 }); 51481 }, []); 51482 const registerResetAllFilter = (0, import_element207.useCallback)((filter2) => { 51483 dispatchResetAllFilters({ 51484 type: "REGISTER", 51485 filter: filter2 51486 }); 51487 }, []); 51488 const deregisterResetAllFilter = (0, import_element207.useCallback)((filter2) => { 51489 dispatchResetAllFilters({ 51490 type: "UNREGISTER", 51491 filter: filter2 51492 }); 51493 }, []); 51494 const flagItemCustomization = (0, import_element207.useCallback)((value, label, group = "default") => { 51495 panelDispatch({ 51496 type: "UPDATE_VALUE", 51497 group, 51498 label, 51499 value 51500 }); 51501 }, []); 51502 const areAllOptionalControlsHidden = (0, import_element207.useMemo)(() => { 51503 return isMenuItemTypeEmpty(menuItems.default) && !isMenuItemTypeEmpty(menuItems.optional) && Object.values(menuItems.optional).every((isSelected2) => !isSelected2); 51504 }, [menuItems]); 51505 const cx3 = useCx(); 51506 const classes = (0, import_element207.useMemo)(() => { 51507 const wrapperStyle = hasInnerWrapper && ToolsPanelWithInnerWrapper(DEFAULT_COLUMNS); 51508 const emptyStyle = areAllOptionalControlsHidden && ToolsPanelHiddenInnerWrapper; 51509 return cx3(ToolsPanel(DEFAULT_COLUMNS), wrapperStyle, emptyStyle, className2); 51510 }, [areAllOptionalControlsHidden, className2, cx3, hasInnerWrapper]); 51511 const toggleItem = (0, import_element207.useCallback)((label) => { 51512 panelDispatch({ 51513 type: "TOGGLE_VALUE", 51514 label 51515 }); 51516 }, []); 51517 const resetAllItems = (0, import_element207.useCallback)(() => { 51518 if (typeof resetAll === "function") { 51519 isResettingRef.current = true; 51520 resetAll(resetAllFilters); 51521 } 51522 panelDispatch({ 51523 type: "RESET_ALL" 51524 }); 51525 }, [resetAllFilters, resetAll]); 51526 const getFirstVisibleItemLabel = (items) => { 51527 const optionalItems = menuItems.optional || {}; 51528 const firstItem = items.find((item2) => item2.isShownByDefault || optionalItems[item2.label]); 51529 return firstItem?.label; 51530 }; 51531 const firstDisplayedItem = getFirstVisibleItemLabel(panelItems); 51532 const lastDisplayedItem = getFirstVisibleItemLabel([...panelItems].reverse()); 51533 const hasMenuItems = panelItems.length > 0; 51534 const panelContext = (0, import_element207.useMemo)(() => ({ 51535 areAllOptionalControlsHidden, 51536 deregisterPanelItem, 51537 deregisterResetAllFilter, 51538 firstDisplayedItem, 51539 flagItemCustomization, 51540 hasMenuItems, 51541 isResetting: isResettingRef.current, 51542 lastDisplayedItem, 51543 menuItems, 51544 panelId, 51545 registerPanelItem, 51546 registerResetAllFilter, 51547 shouldRenderPlaceholderItems, 51548 __experimentalFirstVisibleItemClass, 51549 __experimentalLastVisibleItemClass 51550 }), [areAllOptionalControlsHidden, deregisterPanelItem, deregisterResetAllFilter, firstDisplayedItem, flagItemCustomization, lastDisplayedItem, menuItems, panelId, hasMenuItems, registerResetAllFilter, registerPanelItem, shouldRenderPlaceholderItems, __experimentalFirstVisibleItemClass, __experimentalLastVisibleItemClass]); 51551 return { 51552 ...otherProps, 51553 headingLevel, 51554 panelContext, 51555 resetAllItems, 51556 toggleItem, 51557 className: classes 51558 }; 51559 } 51560 51561 // packages/components/build-module/tools-panel/tools-panel/component.js 51562 var import_jsx_runtime285 = __toESM(require_jsx_runtime()); 51563 var UnconnectedToolsPanel = (props, forwardedRef) => { 51564 const { 51565 children, 51566 label, 51567 panelContext, 51568 resetAllItems, 51569 toggleItem, 51570 headingLevel, 51571 dropdownMenuProps, 51572 ...toolsPanelProps 51573 } = useToolsPanel(props); 51574 return /* @__PURE__ */ (0, import_jsx_runtime285.jsx)(component_default22, { 51575 ...toolsPanelProps, 51576 columns: 2, 51577 ref: forwardedRef, 51578 children: /* @__PURE__ */ (0, import_jsx_runtime285.jsxs)(ToolsPanelContext.Provider, { 51579 value: panelContext, 51580 children: [/* @__PURE__ */ (0, import_jsx_runtime285.jsx)(component_default38, { 51581 label, 51582 resetAll: resetAllItems, 51583 toggleItem, 51584 headingLevel, 51585 dropdownMenuProps 51586 }), children] 51587 }) 51588 }); 51589 }; 51590 var ToolsPanel2 = contextConnect(UnconnectedToolsPanel, "ToolsPanel"); 51591 var component_default39 = ToolsPanel2; 51592 51593 // packages/components/build-module/tools-panel/tools-panel-item/hook.js 51594 var import_compose78 = __toESM(require_compose()); 51595 var import_element208 = __toESM(require_element()); 51596 var noop26 = () => { 51597 }; 51598 function useToolsPanelItem(props) { 51599 const { 51600 className: className2, 51601 hasValue, 51602 isShownByDefault = false, 51603 label, 51604 panelId, 51605 resetAllFilter = noop26, 51606 onDeselect, 51607 onSelect, 51608 ...otherProps 51609 } = useContextSystem(props, "ToolsPanelItem"); 51610 const { 51611 panelId: currentPanelId, 51612 menuItems, 51613 registerResetAllFilter, 51614 deregisterResetAllFilter, 51615 registerPanelItem, 51616 deregisterPanelItem, 51617 flagItemCustomization, 51618 isResetting, 51619 shouldRenderPlaceholderItems: shouldRenderPlaceholder, 51620 firstDisplayedItem, 51621 lastDisplayedItem, 51622 __experimentalFirstVisibleItemClass, 51623 __experimentalLastVisibleItemClass 51624 } = useToolsPanelContext(); 51625 const hasValueCallback = (0, import_element208.useCallback)(hasValue, [panelId]); 51626 const resetAllFilterCallback = (0, import_element208.useCallback)(resetAllFilter, [panelId]); 51627 const previousPanelId = (0, import_compose78.usePrevious)(currentPanelId); 51628 const hasMatchingPanel = currentPanelId === panelId || currentPanelId === null; 51629 (0, import_element208.useLayoutEffect)(() => { 51630 if (hasMatchingPanel && previousPanelId !== null) { 51631 registerPanelItem({ 51632 hasValue: hasValueCallback, 51633 isShownByDefault, 51634 label, 51635 panelId 51636 }); 51637 } 51638 return () => { 51639 if (previousPanelId === null && !!currentPanelId || currentPanelId === panelId) { 51640 deregisterPanelItem(label); 51641 } 51642 }; 51643 }, [currentPanelId, hasMatchingPanel, isShownByDefault, label, hasValueCallback, panelId, previousPanelId, registerPanelItem, deregisterPanelItem]); 51644 (0, import_element208.useEffect)(() => { 51645 if (hasMatchingPanel) { 51646 registerResetAllFilter(resetAllFilterCallback); 51647 } 51648 return () => { 51649 if (hasMatchingPanel) { 51650 deregisterResetAllFilter(resetAllFilterCallback); 51651 } 51652 }; 51653 }, [registerResetAllFilter, deregisterResetAllFilter, resetAllFilterCallback, hasMatchingPanel]); 51654 const menuGroup = isShownByDefault ? "default" : "optional"; 51655 const isMenuItemChecked = menuItems?.[menuGroup]?.[label]; 51656 const wasMenuItemChecked = (0, import_compose78.usePrevious)(isMenuItemChecked); 51657 const isRegistered = menuItems?.[menuGroup]?.[label] !== void 0; 51658 const isValueSet = hasValue(); 51659 (0, import_element208.useEffect)(() => { 51660 if (!isShownByDefault && !isValueSet) { 51661 return; 51662 } 51663 flagItemCustomization(isValueSet, label, menuGroup); 51664 }, [isValueSet, menuGroup, label, flagItemCustomization, isShownByDefault]); 51665 (0, import_element208.useEffect)(() => { 51666 if (!isRegistered || isResetting || !hasMatchingPanel) { 51667 return; 51668 } 51669 if (isMenuItemChecked && !isValueSet && !wasMenuItemChecked) { 51670 onSelect?.(); 51671 } 51672 if (!isMenuItemChecked && isValueSet && wasMenuItemChecked) { 51673 onDeselect?.(); 51674 } 51675 }, [hasMatchingPanel, isMenuItemChecked, isRegistered, isResetting, isValueSet, wasMenuItemChecked, onSelect, onDeselect]); 51676 const isShown = isShownByDefault ? menuItems?.[menuGroup]?.[label] !== void 0 : isMenuItemChecked; 51677 const cx3 = useCx(); 51678 const classes = (0, import_element208.useMemo)(() => { 51679 const shouldApplyPlaceholderStyles = shouldRenderPlaceholder && !isShown; 51680 const firstItemStyle = firstDisplayedItem === label && __experimentalFirstVisibleItemClass; 51681 const lastItemStyle = lastDisplayedItem === label && __experimentalLastVisibleItemClass; 51682 return cx3(ToolsPanelItem, shouldApplyPlaceholderStyles && ToolsPanelItemPlaceholder, !shouldApplyPlaceholderStyles && className2, firstItemStyle, lastItemStyle); 51683 }, [isShown, shouldRenderPlaceholder, className2, cx3, firstDisplayedItem, lastDisplayedItem, __experimentalFirstVisibleItemClass, __experimentalLastVisibleItemClass, label]); 51684 return { 51685 ...otherProps, 51686 isShown, 51687 shouldRenderPlaceholder, 51688 className: classes 51689 }; 51690 } 51691 51692 // packages/components/build-module/tools-panel/tools-panel-item/component.js 51693 var import_jsx_runtime286 = __toESM(require_jsx_runtime()); 51694 var UnconnectedToolsPanelItem = (props, forwardedRef) => { 51695 const { 51696 children, 51697 isShown, 51698 shouldRenderPlaceholder, 51699 ...toolsPanelItemProps 51700 } = useToolsPanelItem(props); 51701 if (!isShown) { 51702 return shouldRenderPlaceholder ? /* @__PURE__ */ (0, import_jsx_runtime286.jsx)(component_default, { 51703 ...toolsPanelItemProps, 51704 ref: forwardedRef 51705 }) : null; 51706 } 51707 return /* @__PURE__ */ (0, import_jsx_runtime286.jsx)(component_default, { 51708 ...toolsPanelItemProps, 51709 ref: forwardedRef, 51710 children 51711 }); 51712 }; 51713 var ToolsPanelItem2 = contextConnect(UnconnectedToolsPanelItem, "ToolsPanelItem"); 51714 var component_default40 = ToolsPanelItem2; 51715 51716 // packages/components/build-module/tree-grid/index.js 51717 var import_dom33 = __toESM(require_dom()); 51718 var import_element215 = __toESM(require_element()); 51719 var import_keycodes2 = __toESM(require_keycodes()); 51720 51721 // packages/components/build-module/tree-grid/roving-tab-index.js 51722 var import_element210 = __toESM(require_element()); 51723 51724 // packages/components/build-module/tree-grid/roving-tab-index-context.js 51725 var import_element209 = __toESM(require_element()); 51726 var RovingTabIndexContext = (0, import_element209.createContext)(void 0); 51727 RovingTabIndexContext.displayName = "RovingTabIndexContext"; 51728 var useRovingTabIndexContext = () => (0, import_element209.useContext)(RovingTabIndexContext); 51729 var RovingTabIndexProvider = RovingTabIndexContext.Provider; 51730 51731 // packages/components/build-module/tree-grid/roving-tab-index.js 51732 var import_jsx_runtime287 = __toESM(require_jsx_runtime()); 51733 function RovingTabIndex({ 51734 children 51735 }) { 51736 const [lastFocusedElement, setLastFocusedElement] = (0, import_element210.useState)(); 51737 const providerValue = (0, import_element210.useMemo)(() => ({ 51738 lastFocusedElement, 51739 setLastFocusedElement 51740 }), [lastFocusedElement]); 51741 return /* @__PURE__ */ (0, import_jsx_runtime287.jsx)(RovingTabIndexProvider, { 51742 value: providerValue, 51743 children 51744 }); 51745 } 51746 51747 // packages/components/build-module/tree-grid/index.js 51748 var import_jsx_runtime292 = __toESM(require_jsx_runtime()); 51749 51750 // packages/components/build-module/tree-grid/row.js 51751 var import_element211 = __toESM(require_element()); 51752 var import_jsx_runtime288 = __toESM(require_jsx_runtime()); 51753 function UnforwardedTreeGridRow({ 51754 children, 51755 level, 51756 positionInSet, 51757 setSize, 51758 isExpanded, 51759 ...props 51760 }, ref) { 51761 return /* @__PURE__ */ (0, import_jsx_runtime288.jsx)("tr", { 51762 ...props, 51763 ref, 51764 role: "row", 51765 "aria-level": level, 51766 "aria-posinset": positionInSet, 51767 "aria-setsize": setSize, 51768 "aria-expanded": isExpanded, 51769 children 51770 }); 51771 } 51772 var TreeGridRow = (0, import_element211.forwardRef)(UnforwardedTreeGridRow); 51773 var row_default2 = TreeGridRow; 51774 51775 // packages/components/build-module/tree-grid/cell.js 51776 var import_element214 = __toESM(require_element()); 51777 51778 // packages/components/build-module/tree-grid/item.js 51779 var import_element213 = __toESM(require_element()); 51780 51781 // packages/components/build-module/tree-grid/roving-tab-index-item.js 51782 var import_element212 = __toESM(require_element()); 51783 var import_jsx_runtime289 = __toESM(require_jsx_runtime()); 51784 var RovingTabIndexItem = (0, import_element212.forwardRef)(function UnforwardedRovingTabIndexItem({ 51785 children, 51786 as: Component9, 51787 ...props 51788 }, forwardedRef) { 51789 const localRef = (0, import_element212.useRef)(); 51790 const ref = forwardedRef || localRef; 51791 const { 51792 lastFocusedElement, 51793 setLastFocusedElement 51794 } = useRovingTabIndexContext(); 51795 let tabIndex; 51796 if (lastFocusedElement) { 51797 tabIndex = lastFocusedElement === // TODO: The original implementation simply used `ref.current` here, assuming 51798 // that a forwarded ref would always be an object, which is not necessarily true. 51799 // This workaround maintains the original runtime behavior in a type-safe way, 51800 // but should be revisited. 51801 ("current" in ref ? ref.current : void 0) ? 0 : -1; 51802 } 51803 const onFocus = (event) => setLastFocusedElement?.(event.target); 51804 const allProps = { 51805 ref, 51806 tabIndex, 51807 onFocus, 51808 ...props 51809 }; 51810 if (typeof children === "function") { 51811 return children(allProps); 51812 } 51813 if (!Component9) { 51814 return null; 51815 } 51816 return /* @__PURE__ */ (0, import_jsx_runtime289.jsx)(Component9, { 51817 ...allProps, 51818 children 51819 }); 51820 }); 51821 var roving_tab_index_item_default = RovingTabIndexItem; 51822 51823 // packages/components/build-module/tree-grid/item.js 51824 var import_jsx_runtime290 = __toESM(require_jsx_runtime()); 51825 function UnforwardedTreeGridItem({ 51826 children, 51827 ...props 51828 }, ref) { 51829 return /* @__PURE__ */ (0, import_jsx_runtime290.jsx)(roving_tab_index_item_default, { 51830 ref, 51831 ...props, 51832 children 51833 }); 51834 } 51835 var TreeGridItem = (0, import_element213.forwardRef)(UnforwardedTreeGridItem); 51836 var item_default3 = TreeGridItem; 51837 51838 // packages/components/build-module/tree-grid/cell.js 51839 var import_jsx_runtime291 = __toESM(require_jsx_runtime()); 51840 function UnforwardedTreeGridCell({ 51841 children, 51842 withoutGridItem = false, 51843 ...props 51844 }, ref) { 51845 return /* @__PURE__ */ (0, import_jsx_runtime291.jsx)("td", { 51846 ...props, 51847 role: "gridcell", 51848 children: withoutGridItem ? /* @__PURE__ */ (0, import_jsx_runtime291.jsx)(import_jsx_runtime291.Fragment, { 51849 children: typeof children === "function" ? children({ 51850 ...props, 51851 ref 51852 }) : children 51853 }) : /* @__PURE__ */ (0, import_jsx_runtime291.jsx)(item_default3, { 51854 ref, 51855 children 51856 }) 51857 }); 51858 } 51859 var TreeGridCell = (0, import_element214.forwardRef)(UnforwardedTreeGridCell); 51860 var cell_default = TreeGridCell; 51861 51862 // packages/components/build-module/tree-grid/index.js 51863 function getRowFocusables(rowElement) { 51864 const focusablesInRow = import_dom33.focus.focusable.find(rowElement, { 51865 sequential: true 51866 }); 51867 return focusablesInRow.filter((focusable) => { 51868 return focusable.closest('[role="row"]') === rowElement; 51869 }); 51870 } 51871 function UnforwardedTreeGrid({ 51872 children, 51873 onExpandRow = () => { 51874 }, 51875 onCollapseRow = () => { 51876 }, 51877 onFocusRow = () => { 51878 }, 51879 applicationAriaLabel, 51880 ...props 51881 }, ref) { 51882 const onKeyDown = (0, import_element215.useCallback)((event) => { 51883 const { 51884 keyCode, 51885 metaKey, 51886 ctrlKey, 51887 altKey 51888 } = event; 51889 const hasModifierKeyPressed = metaKey || ctrlKey || altKey; 51890 if (hasModifierKeyPressed || ![import_keycodes2.UP, import_keycodes2.DOWN, import_keycodes2.LEFT, import_keycodes2.RIGHT, import_keycodes2.HOME, import_keycodes2.END].includes(keyCode)) { 51891 return; 51892 } 51893 event.stopPropagation(); 51894 const { 51895 activeElement 51896 } = document; 51897 const { 51898 currentTarget: treeGridElement 51899 } = event; 51900 if (!activeElement || !treeGridElement.contains(activeElement)) { 51901 return; 51902 } 51903 const activeRow = activeElement.closest('[role="row"]'); 51904 if (!activeRow) { 51905 return; 51906 } 51907 const focusablesInRow = getRowFocusables(activeRow); 51908 const currentColumnIndex = focusablesInRow.indexOf(activeElement); 51909 const canExpandCollapse = 0 === currentColumnIndex; 51910 const cannotFocusNextColumn = canExpandCollapse && (activeRow.getAttribute("data-expanded") === "false" || activeRow.getAttribute("aria-expanded") === "false") && keyCode === import_keycodes2.RIGHT; 51911 if ([import_keycodes2.LEFT, import_keycodes2.RIGHT].includes(keyCode)) { 51912 let nextIndex; 51913 if (keyCode === import_keycodes2.LEFT) { 51914 nextIndex = Math.max(0, currentColumnIndex - 1); 51915 } else { 51916 nextIndex = Math.min(currentColumnIndex + 1, focusablesInRow.length - 1); 51917 } 51918 if (canExpandCollapse) { 51919 if (keyCode === import_keycodes2.LEFT) { 51920 var _activeRow$getAttribu; 51921 if (activeRow.getAttribute("data-expanded") === "true" || activeRow.getAttribute("aria-expanded") === "true") { 51922 onCollapseRow(activeRow); 51923 event.preventDefault(); 51924 return; 51925 } 51926 const level = Math.max(parseInt((_activeRow$getAttribu = activeRow?.getAttribute("aria-level")) !== null && _activeRow$getAttribu !== void 0 ? _activeRow$getAttribu : "1", 10) - 1, 1); 51927 const rows = Array.from(treeGridElement.querySelectorAll('[role="row"]')); 51928 let parentRow = activeRow; 51929 const currentRowIndex = rows.indexOf(activeRow); 51930 for (let i3 = currentRowIndex; i3 >= 0; i3--) { 51931 const ariaLevel = rows[i3].getAttribute("aria-level"); 51932 if (ariaLevel !== null && parseInt(ariaLevel, 10) === level) { 51933 parentRow = rows[i3]; 51934 break; 51935 } 51936 } 51937 getRowFocusables(parentRow)?.[0]?.focus(); 51938 } 51939 if (keyCode === import_keycodes2.RIGHT) { 51940 if (activeRow.getAttribute("data-expanded") === "false" || activeRow.getAttribute("aria-expanded") === "false") { 51941 onExpandRow(activeRow); 51942 event.preventDefault(); 51943 return; 51944 } 51945 const focusableItems = getRowFocusables(activeRow); 51946 if (focusableItems.length > 0) { 51947 focusableItems[nextIndex]?.focus(); 51948 } 51949 } 51950 event.preventDefault(); 51951 return; 51952 } 51953 if (cannotFocusNextColumn) { 51954 return; 51955 } 51956 focusablesInRow[nextIndex].focus(); 51957 event.preventDefault(); 51958 } else if ([import_keycodes2.UP, import_keycodes2.DOWN].includes(keyCode)) { 51959 const rows = Array.from(treeGridElement.querySelectorAll('[role="row"]')); 51960 const currentRowIndex = rows.indexOf(activeRow); 51961 let nextRowIndex; 51962 if (keyCode === import_keycodes2.UP) { 51963 nextRowIndex = Math.max(0, currentRowIndex - 1); 51964 } else { 51965 nextRowIndex = Math.min(currentRowIndex + 1, rows.length - 1); 51966 } 51967 if (nextRowIndex === currentRowIndex) { 51968 event.preventDefault(); 51969 return; 51970 } 51971 const focusablesInNextRow = getRowFocusables(rows[nextRowIndex]); 51972 if (!focusablesInNextRow || !focusablesInNextRow.length) { 51973 event.preventDefault(); 51974 return; 51975 } 51976 const nextIndex = Math.min(currentColumnIndex, focusablesInNextRow.length - 1); 51977 focusablesInNextRow[nextIndex].focus(); 51978 onFocusRow(event, activeRow, rows[nextRowIndex]); 51979 event.preventDefault(); 51980 } else if ([import_keycodes2.HOME, import_keycodes2.END].includes(keyCode)) { 51981 const rows = Array.from(treeGridElement.querySelectorAll('[role="row"]')); 51982 const currentRowIndex = rows.indexOf(activeRow); 51983 let nextRowIndex; 51984 if (keyCode === import_keycodes2.HOME) { 51985 nextRowIndex = 0; 51986 } else { 51987 nextRowIndex = rows.length - 1; 51988 } 51989 if (nextRowIndex === currentRowIndex) { 51990 event.preventDefault(); 51991 return; 51992 } 51993 const focusablesInNextRow = getRowFocusables(rows[nextRowIndex]); 51994 if (!focusablesInNextRow || !focusablesInNextRow.length) { 51995 event.preventDefault(); 51996 return; 51997 } 51998 const nextIndex = Math.min(currentColumnIndex, focusablesInNextRow.length - 1); 51999 focusablesInNextRow[nextIndex].focus(); 52000 onFocusRow(event, activeRow, rows[nextRowIndex]); 52001 event.preventDefault(); 52002 } 52003 }, [onExpandRow, onCollapseRow, onFocusRow]); 52004 return /* @__PURE__ */ (0, import_jsx_runtime292.jsx)(RovingTabIndex, { 52005 children: /* @__PURE__ */ (0, import_jsx_runtime292.jsx)("div", { 52006 role: "application", 52007 "aria-label": applicationAriaLabel, 52008 children: /* @__PURE__ */ (0, import_jsx_runtime292.jsx)("table", { 52009 ...props, 52010 role: "treegrid", 52011 onKeyDown, 52012 ref, 52013 children: /* @__PURE__ */ (0, import_jsx_runtime292.jsx)("tbody", { 52014 children 52015 }) 52016 }) 52017 }) 52018 }); 52019 } 52020 var TreeGrid = (0, import_element215.forwardRef)(UnforwardedTreeGrid); 52021 var tree_grid_default = TreeGrid; 52022 52023 // packages/components/build-module/isolated-event-container/index.js 52024 var import_element216 = __toESM(require_element()); 52025 var import_deprecated26 = __toESM(require_deprecated()); 52026 var import_jsx_runtime293 = __toESM(require_jsx_runtime()); 52027 function stopPropagation(event) { 52028 event.stopPropagation(); 52029 } 52030 var IsolatedEventContainer = (0, import_element216.forwardRef)((props, ref) => { 52031 (0, import_deprecated26.default)("wp.components.IsolatedEventContainer", { 52032 since: "5.7" 52033 }); 52034 return /* @__PURE__ */ (0, import_jsx_runtime293.jsx)("div", { 52035 ...props, 52036 ref, 52037 onMouseDown: stopPropagation 52038 }); 52039 }); 52040 var isolated_event_container_default = IsolatedEventContainer; 52041 52042 // packages/components/build-module/z-stack/component.js 52043 var import_element217 = __toESM(require_element()); 52044 52045 // packages/components/build-module/z-stack/styles.js 52046 function _EMOTION_STRINGIFIED_CSS_ERROR__40() { 52047 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 52048 } 52049 var ZStackChildView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52050 target: "ebn2ljm1" 52051 } : { 52052 target: "ebn2ljm1", 52053 label: "ZStackChildView" 52054 })("&:not( :first-of-type ){", ({ 52055 offsetAmount 52056 }) => /* @__PURE__ */ css({ 52057 marginInlineStart: offsetAmount 52058 }, false ? "" : ";label:ZStackChildView;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZRyIsImZpbGUiOiJzdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBaU3RhY2tDaGlsZFZpZXcgPSBzdHlsZWQuZGl2PCB7XG5cdG9mZnNldEFtb3VudDogbnVtYmVyO1xuXHR6SW5kZXg6IG51bWJlcjtcbn0gPmBcblx0Jjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdCR7ICggeyBvZmZzZXRBbW91bnQgfSApID0+XG5cdFx0XHRjc3MoIHtcblx0XHRcdFx0bWFyZ2luSW5saW5lU3RhcnQ6IG9mZnNldEFtb3VudCxcblx0XHRcdH0gKSB9O1xuXHR9XG5cblx0JHsgKCB7IHpJbmRleCB9ICkgPT4gY3NzKCB7IHpJbmRleCB9ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBaU3RhY2tWaWV3ID0gc3R5bGVkLmRpdjwge1xuXHRpc0xheWVyZWQ6IGJvb2xlYW47XG59ID5gXG5cdGRpc3BsYXk6IGlubGluZS1ncmlkO1xuXHRncmlkLWF1dG8tZmxvdzogY29sdW1uO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JiA+ICR7IFpTdGFja0NoaWxkVmlldyB9IHtcblx0XHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdFx0anVzdGlmeS1zZWxmOiBzdGFydDtcblxuXHRcdCR7ICggeyBpc0xheWVyZWQgfSApID0+XG5cdFx0XHRpc0xheWVyZWRcblx0XHRcdFx0PyAvLyBXaGVuIGBpc0xheWVyZWRgIGlzIHRydWUsIGFsbCBpdGVtcyBvdmVybGFwIGluIHRoZSBzYW1lIGdyaWQgY2VsbFxuXHRcdFx0XHQgIGNzcyggeyBncmlkUm93U3RhcnQ6IDEsIGdyaWRDb2x1bW5TdGFydDogMSB9IClcblx0XHRcdFx0OiB1bmRlZmluZWQgfTtcblx0fVxuYDtcbiJdfQ== */"), ";}", ({ 52059 zIndex 52060 }) => /* @__PURE__ */ css({ 52061 zIndex 52062 }, false ? "" : ";label:ZStackChildView;", false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnNCIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuZXhwb3J0IGNvbnN0IFpTdGFja0NoaWxkVmlldyA9IHN0eWxlZC5kaXY8IHtcblx0b2Zmc2V0QW1vdW50OiBudW1iZXI7XG5cdHpJbmRleDogbnVtYmVyO1xufSA+YFxuXHQmOm5vdCggOmZpcnN0LW9mLXR5cGUgKSB7XG5cdFx0JHsgKCB7IG9mZnNldEFtb3VudCB9ICkgPT5cblx0XHRcdGNzcygge1xuXHRcdFx0XHRtYXJnaW5JbmxpbmVTdGFydDogb2Zmc2V0QW1vdW50LFxuXHRcdFx0fSApIH07XG5cdH1cblxuXHQkeyAoIHsgekluZGV4IH0gKSA9PiBjc3MoIHsgekluZGV4IH0gKSB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IFpTdGFja1ZpZXcgPSBzdHlsZWQuZGl2PCB7XG5cdGlzTGF5ZXJlZDogYm9vbGVhbjtcbn0gPmBcblx0ZGlzcGxheTogaW5saW5lLWdyaWQ7XG5cdGdyaWQtYXV0by1mbG93OiBjb2x1bW47XG5cdHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuXHQmID4gJHsgWlN0YWNrQ2hpbGRWaWV3IH0ge1xuXHRcdHBvc2l0aW9uOiByZWxhdGl2ZTtcblx0XHRqdXN0aWZ5LXNlbGY6IHN0YXJ0O1xuXG5cdFx0JHsgKCB7IGlzTGF5ZXJlZCB9ICkgPT5cblx0XHRcdGlzTGF5ZXJlZFxuXHRcdFx0XHQ/IC8vIFdoZW4gYGlzTGF5ZXJlZGAgaXMgdHJ1ZSwgYWxsIGl0ZW1zIG92ZXJsYXAgaW4gdGhlIHNhbWUgZ3JpZCBjZWxsXG5cdFx0XHRcdCAgY3NzKCB7IGdyaWRSb3dTdGFydDogMSwgZ3JpZENvbHVtblN0YXJ0OiAxIH0gKVxuXHRcdFx0XHQ6IHVuZGVmaW5lZCB9O1xuXHR9XG5gO1xuIl19 */"), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTRyIsImZpbGUiOiJzdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4dGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBaU3RhY2tDaGlsZFZpZXcgPSBzdHlsZWQuZGl2PCB7XG5cdG9mZnNldEFtb3VudDogbnVtYmVyO1xuXHR6SW5kZXg6IG51bWJlcjtcbn0gPmBcblx0Jjpub3QoIDpmaXJzdC1vZi10eXBlICkge1xuXHRcdCR7ICggeyBvZmZzZXRBbW91bnQgfSApID0+XG5cdFx0XHRjc3MoIHtcblx0XHRcdFx0bWFyZ2luSW5saW5lU3RhcnQ6IG9mZnNldEFtb3VudCxcblx0XHRcdH0gKSB9O1xuXHR9XG5cblx0JHsgKCB7IHpJbmRleCB9ICkgPT4gY3NzKCB7IHpJbmRleCB9ICkgfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBaU3RhY2tWaWV3ID0gc3R5bGVkLmRpdjwge1xuXHRpc0xheWVyZWQ6IGJvb2xlYW47XG59ID5gXG5cdGRpc3BsYXk6IGlubGluZS1ncmlkO1xuXHRncmlkLWF1dG8tZmxvdzogY29sdW1uO1xuXHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cblx0JiA+ICR7IFpTdGFja0NoaWxkVmlldyB9IHtcblx0XHRwb3NpdGlvbjogcmVsYXRpdmU7XG5cdFx0anVzdGlmeS1zZWxmOiBzdGFydDtcblxuXHRcdCR7ICggeyBpc0xheWVyZWQgfSApID0+XG5cdFx0XHRpc0xheWVyZWRcblx0XHRcdFx0PyAvLyBXaGVuIGBpc0xheWVyZWRgIGlzIHRydWUsIGFsbCBpdGVtcyBvdmVybGFwIGluIHRoZSBzYW1lIGdyaWQgY2VsbFxuXHRcdFx0XHQgIGNzcyggeyBncmlkUm93U3RhcnQ6IDEsIGdyaWRDb2x1bW5TdGFydDogMSB9IClcblx0XHRcdFx0OiB1bmRlZmluZWQgfTtcblx0fVxuYDtcbiJdfQ== */")); 52063 var _ref10 = false ? { 52064 name: "rs0gp6", 52065 styles: "grid-row-start:1;grid-column-start:1" 52066 } : { 52067 name: "80o7c0-ZStackView", 52068 styles: "grid-row-start:1;grid-column-start:1;label:ZStackView;", 52069 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQ00iLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5leHBvcnQgY29uc3QgWlN0YWNrQ2hpbGRWaWV3ID0gc3R5bGVkLmRpdjwge1xuXHRvZmZzZXRBbW91bnQ6IG51bWJlcjtcblx0ekluZGV4OiBudW1iZXI7XG59ID5gXG5cdCY6bm90KCA6Zmlyc3Qtb2YtdHlwZSApIHtcblx0XHQkeyAoIHsgb2Zmc2V0QW1vdW50IH0gKSA9PlxuXHRcdFx0Y3NzKCB7XG5cdFx0XHRcdG1hcmdpbklubGluZVN0YXJ0OiBvZmZzZXRBbW91bnQsXG5cdFx0XHR9ICkgfTtcblx0fVxuXG5cdCR7ICggeyB6SW5kZXggfSApID0+IGNzcyggeyB6SW5kZXggfSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgWlN0YWNrVmlldyA9IHN0eWxlZC5kaXY8IHtcblx0aXNMYXllcmVkOiBib29sZWFuO1xufSA+YFxuXHRkaXNwbGF5OiBpbmxpbmUtZ3JpZDtcblx0Z3JpZC1hdXRvLWZsb3c6IGNvbHVtbjtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdCYgPiAkeyBaU3RhY2tDaGlsZFZpZXcgfSB7XG5cdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdGp1c3RpZnktc2VsZjogc3RhcnQ7XG5cblx0XHQkeyAoIHsgaXNMYXllcmVkIH0gKSA9PlxuXHRcdFx0aXNMYXllcmVkXG5cdFx0XHRcdD8gLy8gV2hlbiBgaXNMYXllcmVkYCBpcyB0cnVlLCBhbGwgaXRlbXMgb3ZlcmxhcCBpbiB0aGUgc2FtZSBncmlkIGNlbGxcblx0XHRcdFx0ICBjc3MoIHsgZ3JpZFJvd1N0YXJ0OiAxLCBncmlkQ29sdW1uU3RhcnQ6IDEgfSApXG5cdFx0XHRcdDogdW5kZWZpbmVkIH07XG5cdH1cbmA7XG4iXX0= */", 52070 toString: _EMOTION_STRINGIFIED_CSS_ERROR__40 52071 }; 52072 var ZStackView = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52073 target: "ebn2ljm0" 52074 } : { 52075 target: "ebn2ljm0", 52076 label: "ZStackView" 52077 })("display:inline-grid;grid-auto-flow:column;position:relative;&>", ZStackChildView, "{position:relative;justify-self:start;", ({ 52078 isLayered 52079 }) => isLayered ? ( 52080 // When `isLayered` is true, all items overlap in the same grid cell 52081 _ref10 52082 ) : void 0, ";}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQkciLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5leHBvcnQgY29uc3QgWlN0YWNrQ2hpbGRWaWV3ID0gc3R5bGVkLmRpdjwge1xuXHRvZmZzZXRBbW91bnQ6IG51bWJlcjtcblx0ekluZGV4OiBudW1iZXI7XG59ID5gXG5cdCY6bm90KCA6Zmlyc3Qtb2YtdHlwZSApIHtcblx0XHQkeyAoIHsgb2Zmc2V0QW1vdW50IH0gKSA9PlxuXHRcdFx0Y3NzKCB7XG5cdFx0XHRcdG1hcmdpbklubGluZVN0YXJ0OiBvZmZzZXRBbW91bnQsXG5cdFx0XHR9ICkgfTtcblx0fVxuXG5cdCR7ICggeyB6SW5kZXggfSApID0+IGNzcyggeyB6SW5kZXggfSApIH07XG5gO1xuXG5leHBvcnQgY29uc3QgWlN0YWNrVmlldyA9IHN0eWxlZC5kaXY8IHtcblx0aXNMYXllcmVkOiBib29sZWFuO1xufSA+YFxuXHRkaXNwbGF5OiBpbmxpbmUtZ3JpZDtcblx0Z3JpZC1hdXRvLWZsb3c6IGNvbHVtbjtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXG5cdCYgPiAkeyBaU3RhY2tDaGlsZFZpZXcgfSB7XG5cdFx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHRcdGp1c3RpZnktc2VsZjogc3RhcnQ7XG5cblx0XHQkeyAoIHsgaXNMYXllcmVkIH0gKSA9PlxuXHRcdFx0aXNMYXllcmVkXG5cdFx0XHRcdD8gLy8gV2hlbiBgaXNMYXllcmVkYCBpcyB0cnVlLCBhbGwgaXRlbXMgb3ZlcmxhcCBpbiB0aGUgc2FtZSBncmlkIGNlbGxcblx0XHRcdFx0ICBjc3MoIHsgZ3JpZFJvd1N0YXJ0OiAxLCBncmlkQ29sdW1uU3RhcnQ6IDEgfSApXG5cdFx0XHRcdDogdW5kZWZpbmVkIH07XG5cdH1cbmA7XG4iXX0= */")); 52083 52084 // packages/components/build-module/z-stack/component.js 52085 var import_jsx_runtime294 = __toESM(require_jsx_runtime()); 52086 function UnconnectedZStack(props, forwardedRef) { 52087 const { 52088 children, 52089 className: className2, 52090 isLayered = true, 52091 isReversed = false, 52092 offset: offset3 = 0, 52093 ...otherProps 52094 } = useContextSystem(props, "ZStack"); 52095 const validChildren = getValidChildren(children); 52096 const childrenLastIndex = validChildren.length - 1; 52097 const clonedChildren = validChildren.map((child, index2) => { 52098 const zIndex = isReversed ? childrenLastIndex - index2 : index2; 52099 const offsetAmount = isLayered ? offset3 * index2 : offset3; 52100 const key = (0, import_element217.isValidElement)(child) ? child.key : index2; 52101 return /* @__PURE__ */ (0, import_jsx_runtime294.jsx)(ZStackChildView, { 52102 offsetAmount, 52103 zIndex, 52104 children: child 52105 }, key); 52106 }); 52107 return /* @__PURE__ */ (0, import_jsx_runtime294.jsx)(ZStackView, { 52108 ...otherProps, 52109 className: className2, 52110 isLayered, 52111 ref: forwardedRef, 52112 children: clonedChildren 52113 }); 52114 } 52115 var ZStack = contextConnect(UnconnectedZStack, "ZStack"); 52116 var component_default41 = ZStack; 52117 52118 // packages/components/build-module/higher-order/navigate-regions/index.js 52119 var import_element218 = __toESM(require_element()); 52120 var import_compose79 = __toESM(require_compose()); 52121 var import_keycodes3 = __toESM(require_keycodes()); 52122 var import_jsx_runtime295 = __toESM(require_jsx_runtime()); 52123 var defaultShortcuts = { 52124 previous: [{ 52125 modifier: "ctrlShift", 52126 character: "`" 52127 }, { 52128 modifier: "ctrlShift", 52129 character: "~" 52130 }, { 52131 modifier: "access", 52132 character: "p" 52133 }], 52134 next: [{ 52135 modifier: "ctrl", 52136 character: "`" 52137 }, { 52138 modifier: "access", 52139 character: "n" 52140 }] 52141 }; 52142 function useNavigateRegions(shortcuts = defaultShortcuts) { 52143 const ref = (0, import_element218.useRef)(null); 52144 const [isFocusingRegions, setIsFocusingRegions] = (0, import_element218.useState)(false); 52145 function focusRegion(offset3) { 52146 var _ref$current$querySel; 52147 const regions = Array.from((_ref$current$querySel = ref.current?.querySelectorAll('[role="region"][tabindex="-1"]')) !== null && _ref$current$querySel !== void 0 ? _ref$current$querySel : []); 52148 if (!regions.length) { 52149 return; 52150 } 52151 let nextRegion = regions[0]; 52152 const wrappingRegion = ref.current?.ownerDocument?.activeElement?.closest('[role="region"][tabindex="-1"]'); 52153 const selectedIndex = wrappingRegion ? regions.indexOf(wrappingRegion) : -1; 52154 if (selectedIndex !== -1) { 52155 let nextIndex = selectedIndex + offset3; 52156 nextIndex = nextIndex === -1 ? regions.length - 1 : nextIndex; 52157 nextIndex = nextIndex === regions.length ? 0 : nextIndex; 52158 nextRegion = regions[nextIndex]; 52159 } 52160 nextRegion.focus(); 52161 setIsFocusingRegions(true); 52162 } 52163 const clickRef = (0, import_compose79.useRefEffect)((element) => { 52164 function onClick() { 52165 setIsFocusingRegions(false); 52166 } 52167 element.addEventListener("click", onClick); 52168 return () => { 52169 element.removeEventListener("click", onClick); 52170 }; 52171 }, [setIsFocusingRegions]); 52172 return { 52173 ref: (0, import_compose79.useMergeRefs)([ref, clickRef]), 52174 className: isFocusingRegions ? "is-focusing-regions" : "", 52175 onKeyDown(event) { 52176 if (shortcuts.previous.some(({ 52177 modifier, 52178 character: character2 52179 }) => { 52180 return import_keycodes3.isKeyboardEvent[modifier](event, character2); 52181 })) { 52182 focusRegion(-1); 52183 } else if (shortcuts.next.some(({ 52184 modifier, 52185 character: character2 52186 }) => { 52187 return import_keycodes3.isKeyboardEvent[modifier](event, character2); 52188 })) { 52189 focusRegion(1); 52190 } 52191 } 52192 }; 52193 } 52194 var navigate_regions_default = (0, import_compose79.createHigherOrderComponent)((Component9) => ({ 52195 shortcuts, 52196 ...props 52197 }) => /* @__PURE__ */ (0, import_jsx_runtime295.jsx)("div", { 52198 ...useNavigateRegions(shortcuts), 52199 children: /* @__PURE__ */ (0, import_jsx_runtime295.jsx)(Component9, { 52200 ...props 52201 }) 52202 }), "navigateRegions"); 52203 52204 // packages/components/build-module/higher-order/with-constrained-tabbing/index.js 52205 var import_compose80 = __toESM(require_compose()); 52206 var import_jsx_runtime296 = __toESM(require_jsx_runtime()); 52207 var withConstrainedTabbing = (0, import_compose80.createHigherOrderComponent)((WrappedComponent) => function ComponentWithConstrainedTabbing(props) { 52208 const ref = (0, import_compose80.useConstrainedTabbing)(); 52209 return /* @__PURE__ */ (0, import_jsx_runtime296.jsx)("div", { 52210 ref, 52211 tabIndex: -1, 52212 children: /* @__PURE__ */ (0, import_jsx_runtime296.jsx)(WrappedComponent, { 52213 ...props 52214 }) 52215 }); 52216 }, "withConstrainedTabbing"); 52217 var with_constrained_tabbing_default = withConstrainedTabbing; 52218 52219 // packages/components/build-module/higher-order/with-fallback-styles/index.js 52220 var import_es63 = __toESM(require_es6()); 52221 var import_element219 = __toESM(require_element()); 52222 var import_compose81 = __toESM(require_compose()); 52223 var import_jsx_runtime297 = __toESM(require_jsx_runtime()); 52224 var with_fallback_styles_default = (mapNodeToProps) => (0, import_compose81.createHigherOrderComponent)((WrappedComponent) => { 52225 return class extends import_element219.Component { 52226 constructor(props) { 52227 super(props); 52228 this.nodeRef = this.props.node; 52229 this.state = { 52230 fallbackStyles: void 0, 52231 grabStylesCompleted: false 52232 }; 52233 this.bindRef = this.bindRef.bind(this); 52234 } 52235 bindRef(node2) { 52236 if (!node2) { 52237 return; 52238 } 52239 this.nodeRef = node2; 52240 } 52241 componentDidMount() { 52242 this.grabFallbackStyles(); 52243 } 52244 componentDidUpdate() { 52245 this.grabFallbackStyles(); 52246 } 52247 grabFallbackStyles() { 52248 const { 52249 grabStylesCompleted, 52250 fallbackStyles 52251 } = this.state; 52252 if (this.nodeRef && !grabStylesCompleted) { 52253 const newFallbackStyles = mapNodeToProps(this.nodeRef, this.props); 52254 if (!(0, import_es63.default)(newFallbackStyles, fallbackStyles)) { 52255 this.setState({ 52256 fallbackStyles: newFallbackStyles, 52257 grabStylesCompleted: Object.values(newFallbackStyles).every(Boolean) 52258 }); 52259 } 52260 } 52261 } 52262 render() { 52263 const wrappedComponent = /* @__PURE__ */ (0, import_jsx_runtime297.jsx)(WrappedComponent, { 52264 ...this.props, 52265 ...this.state.fallbackStyles 52266 }); 52267 return this.props.node ? wrappedComponent : /* @__PURE__ */ (0, import_jsx_runtime297.jsxs)("div", { 52268 ref: this.bindRef, 52269 children: [" ", wrappedComponent, " "] 52270 }); 52271 } 52272 }; 52273 }, "withFallbackStyles"); 52274 52275 // packages/components/build-module/higher-order/with-filters/index.js 52276 var import_element220 = __toESM(require_element()); 52277 var import_hooks11 = __toESM(require_hooks()); 52278 var import_compose82 = __toESM(require_compose()); 52279 var import_jsx_runtime298 = __toESM(require_jsx_runtime()); 52280 var ANIMATION_FRAME_PERIOD = 16; 52281 function withFilters(hookName) { 52282 return (0, import_compose82.createHigherOrderComponent)((OriginalComponent) => { 52283 const namespace = "core/with-filters/" + hookName; 52284 let FilteredComponent; 52285 function ensureFilteredComponent() { 52286 if (FilteredComponent === void 0) { 52287 FilteredComponent = (0, import_hooks11.applyFilters)(hookName, OriginalComponent); 52288 } 52289 } 52290 class FilteredComponentRenderer extends import_element220.Component { 52291 constructor(props) { 52292 super(props); 52293 ensureFilteredComponent(); 52294 } 52295 componentDidMount() { 52296 FilteredComponentRenderer.instances.push(this); 52297 if (FilteredComponentRenderer.instances.length === 1) { 52298 (0, import_hooks11.addAction)("hookRemoved", namespace, onHooksUpdated); 52299 (0, import_hooks11.addAction)("hookAdded", namespace, onHooksUpdated); 52300 } 52301 } 52302 componentWillUnmount() { 52303 FilteredComponentRenderer.instances = FilteredComponentRenderer.instances.filter((instance) => instance !== this); 52304 if (FilteredComponentRenderer.instances.length === 0) { 52305 (0, import_hooks11.removeAction)("hookRemoved", namespace); 52306 (0, import_hooks11.removeAction)("hookAdded", namespace); 52307 } 52308 } 52309 render() { 52310 return /* @__PURE__ */ (0, import_jsx_runtime298.jsx)(FilteredComponent, { 52311 ...this.props 52312 }); 52313 } 52314 } 52315 FilteredComponentRenderer.instances = []; 52316 const throttledForceUpdate = (0, import_compose82.debounce)(() => { 52317 FilteredComponent = (0, import_hooks11.applyFilters)(hookName, OriginalComponent); 52318 FilteredComponentRenderer.instances.forEach((instance) => { 52319 instance.forceUpdate(); 52320 }); 52321 }, ANIMATION_FRAME_PERIOD); 52322 function onHooksUpdated(updatedHookName) { 52323 if (updatedHookName === hookName) { 52324 throttledForceUpdate(); 52325 } 52326 } 52327 return FilteredComponentRenderer; 52328 }, "withFilters"); 52329 } 52330 52331 // packages/components/build-module/higher-order/with-focus-return/index.js 52332 var import_element221 = __toESM(require_element()); 52333 var import_compose83 = __toESM(require_compose()); 52334 var import_deprecated27 = __toESM(require_deprecated()); 52335 var import_jsx_runtime299 = __toESM(require_jsx_runtime()); 52336 function isComponentLike(object) { 52337 return object instanceof import_element221.Component || typeof object === "function"; 52338 } 52339 var with_focus_return_default = (0, import_compose83.createHigherOrderComponent)( 52340 // @ts-expect-error TODO: Reconcile with intended `createHigherOrderComponent` types 52341 (options2) => { 52342 const HoC = ({ 52343 onFocusReturn 52344 } = {}) => (WrappedComponent) => { 52345 const WithFocusReturn = (props) => { 52346 const ref = (0, import_compose83.useFocusReturn)(onFocusReturn); 52347 return /* @__PURE__ */ (0, import_jsx_runtime299.jsx)("div", { 52348 ref, 52349 children: /* @__PURE__ */ (0, import_jsx_runtime299.jsx)(WrappedComponent, { 52350 ...props 52351 }) 52352 }); 52353 }; 52354 return WithFocusReturn; 52355 }; 52356 if (isComponentLike(options2)) { 52357 const WrappedComponent = options2; 52358 return HoC()(WrappedComponent); 52359 } 52360 return HoC(options2); 52361 }, 52362 "withFocusReturn" 52363 ); 52364 var Provider3 = ({ 52365 children 52366 }) => { 52367 (0, import_deprecated27.default)("wp.components.FocusReturnProvider component", { 52368 since: "5.7", 52369 hint: "This provider is not used anymore. You can just remove it from your codebase" 52370 }); 52371 return children; 52372 }; 52373 52374 // packages/components/build-module/higher-order/with-notices/index.js 52375 var import_element222 = __toESM(require_element()); 52376 var import_compose84 = __toESM(require_compose()); 52377 var import_jsx_runtime300 = __toESM(require_jsx_runtime()); 52378 var with_notices_default = (0, import_compose84.createHigherOrderComponent)((OriginalComponent) => { 52379 function Component9(props, ref) { 52380 const [noticeList, setNoticeList] = (0, import_element222.useState)([]); 52381 const noticeOperations = (0, import_element222.useMemo)(() => { 52382 const createNotice = (notice) => { 52383 const noticeToAdd = notice.id ? notice : { 52384 ...notice, 52385 id: v4_default() 52386 }; 52387 setNoticeList((current) => [...current, noticeToAdd]); 52388 }; 52389 return { 52390 createNotice, 52391 createErrorNotice: (msg) => { 52392 createNotice({ 52393 status: "error", 52394 content: msg 52395 }); 52396 }, 52397 removeNotice: (id3) => { 52398 setNoticeList((current) => current.filter((notice) => notice.id !== id3)); 52399 }, 52400 removeAllNotices: () => { 52401 setNoticeList([]); 52402 } 52403 }; 52404 }, []); 52405 const propsOut = { 52406 ...props, 52407 noticeList, 52408 noticeOperations, 52409 noticeUI: noticeList.length > 0 && /* @__PURE__ */ (0, import_jsx_runtime300.jsx)(list_default, { 52410 className: "components-with-notices-ui", 52411 notices: noticeList, 52412 onRemove: noticeOperations.removeNotice 52413 }) 52414 }; 52415 return isForwardRef ? /* @__PURE__ */ (0, import_jsx_runtime300.jsx)(OriginalComponent, { 52416 ...propsOut, 52417 ref 52418 }) : /* @__PURE__ */ (0, import_jsx_runtime300.jsx)(OriginalComponent, { 52419 ...propsOut 52420 }); 52421 } 52422 let isForwardRef; 52423 const { 52424 render 52425 } = OriginalComponent; 52426 if (typeof render === "function") { 52427 isForwardRef = true; 52428 return (0, import_element222.forwardRef)(Component9); 52429 } 52430 return Component9; 52431 }, "withNotices"); 52432 52433 // packages/components/build-module/menu/index.js 52434 var import_element235 = __toESM(require_element()); 52435 var import_i18n79 = __toESM(require_i18n()); 52436 52437 // packages/components/build-module/menu/context.js 52438 var import_element223 = __toESM(require_element()); 52439 var Context2 = (0, import_element223.createContext)(void 0); 52440 Context2.displayName = "MenuContext"; 52441 52442 // packages/components/build-module/menu/item.js 52443 var import_element224 = __toESM(require_element()); 52444 52445 // packages/components/build-module/menu/styles.js 52446 function _EMOTION_STRINGIFIED_CSS_ERROR__41() { 52447 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 52448 } 52449 var ANIMATION_PARAMS2 = { 52450 SCALE_AMOUNT_OUTER: 0.82, 52451 SCALE_AMOUNT_CONTENT: 0.9, 52452 DURATION: { 52453 IN: "400ms", 52454 OUT: "200ms" 52455 }, 52456 EASING: "cubic-bezier(0.33, 0, 0, 1)" 52457 }; 52458 var CONTENT_WRAPPER_PADDING = space(1); 52459 var ITEM_PADDING_BLOCK = space(1); 52460 var ITEM_PADDING_INLINE = space(3); 52461 var DEFAULT_BORDER_COLOR = COLORS.theme.gray[300]; 52462 var DIVIDER_COLOR = COLORS.theme.gray[200]; 52463 var LIGHTER_TEXT_COLOR = COLORS.theme.gray[700]; 52464 var LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[100]; 52465 var TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground; 52466 var DEFAULT_BOX_SHADOW = `0 0 0 $config_values_default.borderWidth} $DEFAULT_BORDER_COLOR}, $config_values_default.elevationMedium}`; 52467 var TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 $config_values_default.borderWidth} $TOOLBAR_VARIANT_BORDER_COLOR}`; 52468 var GRID_TEMPLATE_COLS = "minmax( 0, max-content ) 1fr"; 52469 var PopoverOuterWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52470 target: "e1wg7tti14" 52471 } : { 52472 target: "e1wg7tti14", 52473 label: "PopoverOuterWrapper" 52474 })("position:relative;background-color:", COLORS.ui.background, ";border-radius:", config_values_default.radiusMedium, ";", (props) => /* @__PURE__ */ css("box-shadow:", props.variant === "toolbar" ? TOOLBAR_VARIANT_BOX_SHADOW : DEFAULT_BOX_SHADOW, ";" + (false ? "" : ";label:PopoverOuterWrapper;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAmDoB","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */"), " overflow:hidden;@media not ( prefers-reduced-motion ){transition-property:transform,opacity;transition-timing-function:", ANIMATION_PARAMS2.EASING, ";transition-duration:", ANIMATION_PARAMS2.DURATION.IN, ";will-change:transform,opacity;opacity:0;&:has( [data-enter] ){opacity:1;}&:has( [data-leave] ){transition-duration:", ANIMATION_PARAMS2.DURATION.OUT, ";}&:has( [data-side='bottom'] ),&:has( [data-side='top'] ){transform:scaleY( ", ANIMATION_PARAMS2.SCALE_AMOUNT_OUTER, " );}&:has( [data-side='bottom'] ){transform-origin:top;}&:has( [data-side='top'] ){transform-origin:bottom;}&:has( [data-enter][data-side='bottom'] ),&:has( [data-enter][data-side='top'] ),&:has( [data-leave][data-side='bottom'] ),&:has( [data-leave][data-side='top'] ){transform:scaleY( 1 );}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA8CC","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52475 var PopoverInnerWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52476 target: "e1wg7tti13" 52477 } : { 52478 target: "e1wg7tti13", 52479 label: "PopoverInnerWrapper" 52480 })("position:relative;z-index:1000000;display:grid;grid-template-columns:", GRID_TEMPLATE_COLS, ";grid-template-rows:auto;box-sizing:border-box;min-width:160px;max-width:320px;max-height:var( --popover-available-height );padding:", CONTENT_WRAPPER_PADDING, ";overscroll-behavior:contain;overflow:auto;outline:2px solid transparent!important;@media not ( prefers-reduced-motion ){transition:inherit;transform-origin:inherit;&[data-side='bottom'],&[data-side='top']{transform:scaleY(\n calc(\n 1 / ", ANIMATION_PARAMS2.SCALE_AMOUNT_OUTER, " *\n ", ANIMATION_PARAMS2.SCALE_AMOUNT_CONTENT, "\n )\n );}&[data-enter][data-side='bottom'],&[data-enter][data-side='top'],&[data-leave][data-side='bottom'],&[data-leave][data-side='top']{transform:scaleY( 1 );}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAiG6C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52481 var baseItem = /* @__PURE__ */ css("all:unset;position:relative;min-height:", space(8), ";box-sizing:border-box;grid-column:1/-1;display:grid;grid-template-columns:", GRID_TEMPLATE_COLS, ";align-items:center;@supports ( grid-template-columns: subgrid ){grid-template-columns:subgrid;}font-size:", font("default.fontSize"), ";font-family:inherit;font-weight:normal;line-height:20px;color:", COLORS.theme.foreground, ";border-radius:", config_values_default.radiusSmall, ";padding-block:", ITEM_PADDING_BLOCK, ";padding-inline:", ITEM_PADDING_INLINE, ";scroll-margin:", CONTENT_WRAPPER_PADDING, ";user-select:none;outline:none;&[aria-disabled='true']{color:", COLORS.ui.textDisabled, ";cursor:not-allowed;}&[data-active-item]:not( [data-focus-visible] ):not(\n [aria-disabled='true']\n ){background-color:", COLORS.theme.accent, ";color:", COLORS.theme.accentInverted, ";}&[data-focus-visible]{box-shadow:0 0 0 1.5px ", COLORS.theme.accent, ";outline:2px solid transparent;}&:active,&[data-active]{}", PopoverInnerWrapper, ':not(:focus) &:not(:focus)[aria-expanded="true"]{background-color:', LIGHT_BACKGROUND_COLOR, ";color:", COLORS.theme.foreground, ";}svg{fill:currentColor;}" + (false ? "" : ";label:baseItem;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsJoB","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */"); 52482 var Item3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuItem, false ? { 52483 target: "e1wg7tti12" 52484 } : { 52485 target: "e1wg7tti12", 52486 label: "Item" 52487 })(baseItem, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAuO8C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52488 var CheckboxItem = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuItemCheckbox, false ? { 52489 target: "e1wg7tti11" 52490 } : { 52491 target: "e1wg7tti11", 52492 label: "CheckboxItem" 52493 })(baseItem, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA2O8D","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52494 var RadioItem = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuItemRadio, false ? { 52495 target: "e1wg7tti10" 52496 } : { 52497 target: "e1wg7tti10", 52498 label: "RadioItem" 52499 })(baseItem, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA+OwD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52500 var ItemPrefixWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 52501 target: "e1wg7tti9" 52502 } : { 52503 target: "e1wg7tti9", 52504 label: "ItemPrefixWrapper" 52505 })("grid-column:1;", CheckboxItem, ">&,", RadioItem, ">&{min-width:", space(6), ";}", CheckboxItem, ">&,", RadioItem, ">&,&:not( :empty ){margin-inline-end:", space(2), ";}display:flex;align-items:center;justify-content:center;color:", LIGHTER_TEXT_COLOR, ";[data-active-item]:not( [data-focus-visible] )>&,[aria-disabled='true']>&{color:inherit;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAmP4C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52506 var ItemContentWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52507 target: "e1wg7tti8" 52508 } : { 52509 target: "e1wg7tti8", 52510 label: "ItemContentWrapper" 52511 })("grid-column:2;display:flex;align-items:center;justify-content:space-between;gap:", space(3), ";pointer-events:none;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAwR4C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52512 var ItemChildrenWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 52513 target: "e1wg7tti7" 52514 } : { 52515 target: "e1wg7tti7", 52516 label: "ItemChildrenWrapper" 52517 })("flex:1;display:inline-flex;flex-direction:column;gap:", space(1), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAuS6C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52518 var ItemSuffixWrapper = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 52519 target: "e1wg7tti6" 52520 } : { 52521 target: "e1wg7tti6", 52522 label: "ItemSuffixWrapper" 52523 })("flex:0 1 fit-content;min-width:0;width:fit-content;display:flex;align-items:center;justify-content:center;gap:", space(3), ";color:", LIGHTER_TEXT_COLOR, ";[data-active-item]:not( [data-focus-visible] ) *:not(", PopoverInnerWrapper, ") &,[aria-disabled='true'] *:not(", PopoverInnerWrapper, ") &{color:inherit;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA+S4C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52524 var Group3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuGroup, false ? { 52525 target: "e1wg7tti5" 52526 } : { 52527 target: "e1wg7tti5", 52528 label: "Group" 52529 })(false ? { 52530 name: "49aokf", 52531 styles: "display:contents" 52532 } : { 52533 name: "49aokf", 52534 styles: "display:contents", 52535 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsUgD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */", 52536 toString: _EMOTION_STRINGIFIED_CSS_ERROR__41 52537 }); 52538 var GroupLabel3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuGroupLabel, false ? { 52539 target: "e1wg7tti4" 52540 } : { 52541 target: "e1wg7tti4", 52542 label: "GroupLabel" 52543 })("grid-column:1/-1;padding-block-start:", space(3), ";padding-block-end:", space(2), ";padding-inline:", ITEM_PADDING_INLINE, ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA2U0D","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52544 var Separator3 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(MenuSeparator, false ? { 52545 target: "e1wg7tti3" 52546 } : { 52547 target: "e1wg7tti3", 52548 label: "Separator" 52549 })("grid-column:1/-1;border:none;height:", config_values_default.borderWidth, ";background-color:", (props) => props.variant === "toolbar" ? TOOLBAR_VARIANT_BORDER_COLOR : DIVIDER_COLOR, ";margin-block:", space(2), ";margin-inline:", ITEM_PADDING_INLINE, ";outline:2px solid transparent;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsVC","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52550 var SubmenuChevronIcon = /* @__PURE__ */ emotion_styled_base_browser_esm_default(icon_default3, false ? { 52551 target: "e1wg7tti2" 52552 } : { 52553 target: "e1wg7tti2", 52554 label: "SubmenuChevronIcon" 52555 })("width:", space(1.5), ";", rtl({ 52556 transform: `scaleX(1)` 52557 }, { 52558 transform: `scaleX(-1)` 52559 }), ";" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAwWgD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52560 var ItemLabel = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default7, false ? { 52561 target: "e1wg7tti1" 52562 } : { 52563 target: "e1wg7tti1", 52564 label: "ItemLabel" 52565 })("font-size:", font("default.fontSize"), ";line-height:20px;color:inherit;" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAoX2C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52566 var ItemHelpText = /* @__PURE__ */ emotion_styled_base_browser_esm_default(component_default7, false ? { 52567 target: "e1wg7tti0" 52568 } : { 52569 target: "e1wg7tti0", 52570 label: "ItemHelpText" 52571 })("font-size:", font("helpText.fontSize"), ";line-height:16px;color:", LIGHTER_TEXT_COLOR, ";overflow-wrap:anywhere;[data-active-item]:not( [data-focus-visible] ) *:not( ", PopoverInnerWrapper, " ) &,[aria-disabled='true'] *:not( ", PopoverInnerWrapper, " ) &{color:inherit;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AA0X8C","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport * as Ariakit from '@ariakit/react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl, CONFIG } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\nimport { Truncate } from '../truncate';\nimport type { ContextProps } from './types';\n\nconst ANIMATION_PARAMS = {\n\tSCALE_AMOUNT_OUTER: 0.82,\n\tSCALE_AMOUNT_CONTENT: 0.9,\n\tDURATION: {\n\t\tIN: '400ms',\n\t\tOUT: '200ms',\n\t},\n\tEASING: 'cubic-bezier(0.33, 0, 0, 1)',\n};\n\nconst CONTENT_WRAPPER_PADDING = space( 1 );\nconst ITEM_PADDING_BLOCK = space( 1 );\nconst ITEM_PADDING_INLINE = space( 3 );\n\n// TODO:\n// - border color and divider color are different from COLORS.theme variables\n// - lighter text color is not defined in COLORS.theme, should it be?\n// - lighter background color is not defined in COLORS.theme, should it be?\nconst DEFAULT_BORDER_COLOR = COLORS.theme.gray[ 300 ];\nconst DIVIDER_COLOR = COLORS.theme.gray[ 200 ];\nconst LIGHTER_TEXT_COLOR = COLORS.theme.gray[ 700 ];\nconst LIGHT_BACKGROUND_COLOR = COLORS.theme.gray[ 100 ];\nconst TOOLBAR_VARIANT_BORDER_COLOR = COLORS.theme.foreground;\nconst DEFAULT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ DEFAULT_BORDER_COLOR }, ${ CONFIG.elevationMedium }`;\nconst TOOLBAR_VARIANT_BOX_SHADOW = `0 0 0 ${ CONFIG.borderWidth } ${ TOOLBAR_VARIANT_BORDER_COLOR }`;\n\nconst GRID_TEMPLATE_COLS = 'minmax( 0, max-content ) 1fr';\n\nexport const PopoverOuterWrapper = styled.div<\n\tPick< ContextProps, 'variant' >\n>`\n\tposition: relative;\n\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: ${ CONFIG.radiusMedium };\n\t${ ( props ) => css`\n\t\tbox-shadow: ${ props.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BOX_SHADOW\n\t\t\t: DEFAULT_BOX_SHADOW };\n\t` }\n\n\toverflow: hidden;\n\n\t/* Open/close animation (outer wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition-property: transform, opacity;\n\t\ttransition-timing-function: ${ ANIMATION_PARAMS.EASING };\n\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.IN };\n\t\twill-change: transform, opacity;\n\n\t\t/* Regardless of the side, fade in and out. */\n\t\topacity: 0;\n\t\t&:has( [data-enter] ) {\n\t\t\topacity: 1;\n\t\t}\n\n\t\t&:has( [data-leave] ) {\n\t\t\ttransition-duration: ${ ANIMATION_PARAMS.DURATION.OUT };\n\t\t}\n\n\t\t/* For menus opening on top and bottom side, animate the scale Y too. */\n\t\t&:has( [data-side='bottom'] ),\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform: scaleY( ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } );\n\t\t}\n\t\t&:has( [data-side='bottom'] ) {\n\t\t\ttransform-origin: top;\n\t\t}\n\t\t&:has( [data-side='top'] ) {\n\t\t\ttransform-origin: bottom;\n\t\t}\n\t\t&:has( [data-enter][data-side='bottom'] ),\n\t\t&:has( [data-enter][data-side='top'] ),\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&:has( [data-leave][data-side='bottom'] ),\n\t\t&:has( [data-leave][data-side='top'] ) {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nexport const PopoverInnerWrapper = styled.div`\n\tposition: relative;\n\t/* Same as popover component */\n\t/* TODO: is there a way to read the sass variable? */\n\tz-index: 1000000;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\tgrid-template-rows: auto;\n\n\tbox-sizing: border-box;\n\tmin-width: 160px;\n\tmax-width: 320px;\n\tmax-height: var( --popover-available-height );\n\n\tpadding: ${ CONTENT_WRAPPER_PADDING };\n\n\toverscroll-behavior: contain;\n\toverflow: auto;\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent !important;\n\n\t/* Open/close animation (inner content wrapper) */\n\t@media not ( prefers-reduced-motion ) {\n\t\ttransition: inherit;\n\t\ttransform-origin: inherit;\n\n\t\t/*\n\t\t * For menus opening on top and bottom side, animate the scale Y too.\n\t\t * The content scales at a different rate than the outer container:\n\t\t * - first, counter the outer scale factor by doing \"1 / scaleAmountOuter\"\n\t\t * - then, apply the content scale factor.\n\t\t */\n\t\t&[data-side='bottom'],\n\t\t&[data-side='top'] {\n\t\t\ttransform: scaleY(\n\t\t\t\tcalc(\n\t\t\t\t\t1 / ${ ANIMATION_PARAMS.SCALE_AMOUNT_OUTER } *\n\t\t\t\t\t\t${ ANIMATION_PARAMS.SCALE_AMOUNT_CONTENT }\n\t\t\t\t)\n\t\t\t);\n\t\t}\n\t\t&[data-enter][data-side='bottom'],\n\t\t&[data-enter][data-side='top'],\n\t\t/* Do not animate the scaleY when closing the menu */\n\t\t&[data-leave][data-side='bottom'],\n\t\t&[data-leave][data-side='top'] {\n\t\t\ttransform: scaleY( 1 );\n\t\t}\n\t}\n`;\n\nconst baseItem = css`\n\tall: unset;\n\n\tposition: relative;\n\tmin-height: ${ space( 8 ) };\n\tbox-sizing: border-box;\n\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tdisplay: grid;\n\tgrid-template-columns: ${ GRID_TEMPLATE_COLS };\n\talign-items: center;\n\n\t@supports ( grid-template-columns: subgrid ) {\n\t\t/*\n\t\t * Define a grid layout which inherits the same columns configuration\n\t\t * from the parent layout (ie. subgrid). This allows the menu\n\t\t * to synchronize the indentation of all its items.\n\t\t */\n\t\tgrid-template-columns: subgrid;\n\t}\n\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\n\tcolor: ${ COLORS.theme.foreground };\n\tborder-radius: ${ CONFIG.radiusSmall };\n\n\tpadding-block: ${ ITEM_PADDING_BLOCK };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n\n\t/*\n\t * Make sure that, when an item is scrolled into view (eg. while using the\n\t * keyboard to move focus), the whole item comes into view\n\t */\n\tscroll-margin: ${ CONTENT_WRAPPER_PADDING };\n\n\tuser-select: none;\n\toutline: none;\n\n\t&[aria-disabled='true'] {\n\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\tcursor: not-allowed;\n\t}\n\n\t/* Active item (including hover) */\n\t&[data-active-item]:not( [data-focus-visible] ):not(\n\t\t\t[aria-disabled='true']\n\t\t) {\n\t\tbackground-color: ${ COLORS.theme.accent };\n\t\tcolor: ${ COLORS.theme.accentInverted };\n\t}\n\n\t/* Keyboard focus (focus-visible) */\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 1.5px ${ COLORS.theme.accent };\n\n\t\t/* Only visible in Windows High Contrast mode */\n\t\toutline: 2px solid transparent;\n\t}\n\n\t/* Active (ie. pressed, mouse down) */\n\t&:active,\n\t&[data-active] {\n\t\t/* TODO: should there be a visual active state? */\n\t}\n\n\t/* When the item is the trigger of an open submenu */\n\t${ PopoverInnerWrapper }:not(:focus) &:not(:focus)[aria-expanded=\"true\"] {\n\t\tbackground-color: ${ LIGHT_BACKGROUND_COLOR };\n\t\tcolor: ${ COLORS.theme.foreground };\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n`;\n\nexport const Item = styled( Ariakit.MenuItem )`\n\t${ baseItem };\n`;\n\nexport const CheckboxItem = styled( Ariakit.MenuItemCheckbox )`\n\t${ baseItem };\n`;\n\nexport const RadioItem = styled( Ariakit.MenuItemRadio )`\n\t${ baseItem };\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t/* Always occupy the first column, even when auto-collapsing */\n\tgrid-column: 1;\n\n\t/*\n\t * Even when the item is not checked, occupy the same screen space to avoid\n\t * the space collapside when no items are checked.\n\t */\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > & {\n\t\t/* Same width as the check icons */\n\t\tmin-width: ${ space( 6 ) };\n\t}\n\n\t${ CheckboxItem } > &,\n\t${ RadioItem } > &,\n\t&:not( :empty ) {\n\t\tmargin-inline-end: ${ space( 2 ) };\n\t}\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t* When the parent menu item is active, except when it's a non-focused/hovered\n\t* submenu trigger (in that case, color should not be inherited)\n\t*/\n\t[data-active-item]:not( [data-focus-visible] ) > &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] > & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const ItemContentWrapper = styled.div`\n\t/*\n\t * Always occupy the second column, since the first column\n\t * is taken by the prefix wrapper (when displayed).\n\t */\n\tgrid-column: 2;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: space-between;\n\tgap: ${ space( 3 ) };\n\n\tpointer-events: none;\n`;\n\nexport const ItemChildrenWrapper = styled.div`\n\tflex: 1;\n\n\tdisplay: inline-flex;\n\tflex-direction: column;\n\tgap: ${ space( 1 ) };\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\tflex: 0 1 fit-content;\n\tmin-width: 0;\n\twidth: fit-content;\n\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tgap: ${ space( 3 ) };\n\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\n\t/*\n\t * When the parent menu item is active, except when it's a non-focused/hovered\n\t * submenu trigger (in that case, color should not be inherited)\n\t */\n\t[data-active-item]:not( [data-focus-visible] ) *:not(${ PopoverInnerWrapper }) &,\n\t/* When the parent menu item is disabled */\n\t[aria-disabled='true'] *:not(${ PopoverInnerWrapper }) & {\n\t\tcolor: inherit;\n\t}\n`;\n\nexport const Group = styled( Ariakit.MenuGroup )`\n\t/* Ignore this element when calculating the layout. Useful for subgrid */\n\tdisplay: contents;\n`;\n\nexport const GroupLabel = styled( Ariakit.MenuGroupLabel )`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tpadding-block-start: ${ space( 3 ) };\n\tpadding-block-end: ${ space( 2 ) };\n\tpadding-inline: ${ ITEM_PADDING_INLINE };\n`;\n\nexport const Separator = styled( Ariakit.MenuSeparator )<\n\tPick< ContextProps, 'variant' >\n>`\n\t/* Occupy the width of all grid columns (ie. full width) */\n\tgrid-column: 1 / -1;\n\n\tborder: none;\n\theight: ${ CONFIG.borderWidth };\n\tbackground-color: ${ ( props ) =>\n\t\tprops.variant === 'toolbar'\n\t\t\t? TOOLBAR_VARIANT_BORDER_COLOR\n\t\t\t: DIVIDER_COLOR };\n\t/* Align with menu items' content */\n\tmargin-block: ${ space( 2 ) };\n\tmargin-inline: ${ ITEM_PADDING_INLINE };\n\n\t/* Only visible in Windows High Contrast mode */\n\toutline: 2px solid transparent;\n`;\n\nexport const SubmenuChevronIcon = styled( Icon )`\n\twidth: ${ space( 1.5 ) };\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1)`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1)`,\n\t\t}\n\t) };\n`;\n\nexport const ItemLabel = styled( Truncate )`\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tline-height: 20px;\n\tcolor: inherit;\n`;\n\nexport const ItemHelpText = styled( Truncate )`\n\tfont-size: ${ font( 'helpText.fontSize' ) };\n\tline-height: 16px;\n\tcolor: ${ LIGHTER_TEXT_COLOR };\n\toverflow-wrap: anywhere;\n\n\t[data-active-item]:not( [data-focus-visible] )\n\t\t*:not( ${ PopoverInnerWrapper } )\n\t\t&,\n\t[aria-disabled='true'] *:not( ${ PopoverInnerWrapper } ) & {\n\t\tcolor: inherit;\n\t}\n`;\n"]} */")); 52572 52573 // packages/components/build-module/menu/item.js 52574 var import_jsx_runtime301 = __toESM(require_jsx_runtime()); 52575 var Item22 = (0, import_element224.forwardRef)(function Item32({ 52576 prefix: prefix2, 52577 suffix, 52578 children, 52579 disabled = false, 52580 hideOnClick = true, 52581 store, 52582 ...props 52583 }, ref) { 52584 const menuContext = (0, import_element224.useContext)(Context2); 52585 if (!menuContext?.store) { 52586 throw new Error("Menu.Item can only be rendered inside a Menu component"); 52587 } 52588 const computedStore = store !== null && store !== void 0 ? store : menuContext.store; 52589 return /* @__PURE__ */ (0, import_jsx_runtime301.jsxs)(Item3, { 52590 ref, 52591 ...props, 52592 accessibleWhenDisabled: true, 52593 disabled, 52594 hideOnClick, 52595 store: computedStore, 52596 children: [/* @__PURE__ */ (0, import_jsx_runtime301.jsx)(ItemPrefixWrapper, { 52597 children: prefix2 52598 }), /* @__PURE__ */ (0, import_jsx_runtime301.jsxs)(ItemContentWrapper, { 52599 children: [/* @__PURE__ */ (0, import_jsx_runtime301.jsx)(ItemChildrenWrapper, { 52600 children 52601 }), suffix && /* @__PURE__ */ (0, import_jsx_runtime301.jsx)(ItemSuffixWrapper, { 52602 children: suffix 52603 })] 52604 })] 52605 }); 52606 }); 52607 52608 // packages/components/build-module/menu/checkbox-item.js 52609 var import_element225 = __toESM(require_element()); 52610 var import_jsx_runtime302 = __toESM(require_jsx_runtime()); 52611 var CheckboxItem2 = (0, import_element225.forwardRef)(function CheckboxItem3({ 52612 suffix, 52613 children, 52614 disabled = false, 52615 hideOnClick = false, 52616 ...props 52617 }, ref) { 52618 const menuContext = (0, import_element225.useContext)(Context2); 52619 if (!menuContext?.store) { 52620 throw new Error("Menu.CheckboxItem can only be rendered inside a Menu component"); 52621 } 52622 return /* @__PURE__ */ (0, import_jsx_runtime302.jsxs)(CheckboxItem, { 52623 ref, 52624 ...props, 52625 accessibleWhenDisabled: true, 52626 disabled, 52627 hideOnClick, 52628 store: menuContext.store, 52629 children: [/* @__PURE__ */ (0, import_jsx_runtime302.jsx)(MenuItemCheck, { 52630 store: menuContext.store, 52631 render: /* @__PURE__ */ (0, import_jsx_runtime302.jsx)(ItemPrefixWrapper, {}), 52632 style: { 52633 width: "auto", 52634 height: "auto" 52635 }, 52636 children: /* @__PURE__ */ (0, import_jsx_runtime302.jsx)(icon_default2, { 52637 icon: check_default, 52638 size: 24 52639 }) 52640 }), /* @__PURE__ */ (0, import_jsx_runtime302.jsxs)(ItemContentWrapper, { 52641 children: [/* @__PURE__ */ (0, import_jsx_runtime302.jsx)(ItemChildrenWrapper, { 52642 children 52643 }), suffix && /* @__PURE__ */ (0, import_jsx_runtime302.jsx)(ItemSuffixWrapper, { 52644 children: suffix 52645 })] 52646 })] 52647 }); 52648 }); 52649 52650 // packages/components/build-module/menu/radio-item.js 52651 var import_element226 = __toESM(require_element()); 52652 var import_primitives35 = __toESM(require_primitives()); 52653 var import_jsx_runtime303 = __toESM(require_jsx_runtime()); 52654 var radioCheck = /* @__PURE__ */ (0, import_jsx_runtime303.jsx)(import_primitives35.SVG, { 52655 xmlns: "http://www.w3.org/2000/svg", 52656 viewBox: "0 0 24 24", 52657 children: /* @__PURE__ */ (0, import_jsx_runtime303.jsx)(import_primitives35.Circle, { 52658 cx: 12, 52659 cy: 12, 52660 r: 3 52661 }) 52662 }); 52663 var RadioItem2 = (0, import_element226.forwardRef)(function RadioItem3({ 52664 suffix, 52665 children, 52666 disabled = false, 52667 hideOnClick = false, 52668 ...props 52669 }, ref) { 52670 const menuContext = (0, import_element226.useContext)(Context2); 52671 if (!menuContext?.store) { 52672 throw new Error("Menu.RadioItem can only be rendered inside a Menu component"); 52673 } 52674 return /* @__PURE__ */ (0, import_jsx_runtime303.jsxs)(RadioItem, { 52675 ref, 52676 ...props, 52677 accessibleWhenDisabled: true, 52678 disabled, 52679 hideOnClick, 52680 store: menuContext.store, 52681 children: [/* @__PURE__ */ (0, import_jsx_runtime303.jsx)(MenuItemCheck, { 52682 store: menuContext.store, 52683 render: /* @__PURE__ */ (0, import_jsx_runtime303.jsx)(ItemPrefixWrapper, {}), 52684 style: { 52685 width: "auto", 52686 height: "auto" 52687 }, 52688 children: /* @__PURE__ */ (0, import_jsx_runtime303.jsx)(icon_default2, { 52689 icon: radioCheck, 52690 size: 24 52691 }) 52692 }), /* @__PURE__ */ (0, import_jsx_runtime303.jsxs)(ItemContentWrapper, { 52693 children: [/* @__PURE__ */ (0, import_jsx_runtime303.jsx)(ItemChildrenWrapper, { 52694 children 52695 }), suffix && /* @__PURE__ */ (0, import_jsx_runtime303.jsx)(ItemSuffixWrapper, { 52696 children: suffix 52697 })] 52698 })] 52699 }); 52700 }); 52701 52702 // packages/components/build-module/menu/group.js 52703 var import_element227 = __toESM(require_element()); 52704 var import_jsx_runtime304 = __toESM(require_jsx_runtime()); 52705 var Group22 = (0, import_element227.forwardRef)(function Group32(props, ref) { 52706 const menuContext = (0, import_element227.useContext)(Context2); 52707 if (!menuContext?.store) { 52708 throw new Error("Menu.Group can only be rendered inside a Menu component"); 52709 } 52710 return /* @__PURE__ */ (0, import_jsx_runtime304.jsx)(Group3, { 52711 ref, 52712 ...props, 52713 store: menuContext.store 52714 }); 52715 }); 52716 52717 // packages/components/build-module/menu/group-label.js 52718 var import_element228 = __toESM(require_element()); 52719 var import_jsx_runtime305 = __toESM(require_jsx_runtime()); 52720 var GroupLabel22 = (0, import_element228.forwardRef)(function Group4(props, ref) { 52721 const menuContext = (0, import_element228.useContext)(Context2); 52722 if (!menuContext?.store) { 52723 throw new Error("Menu.GroupLabel can only be rendered inside a Menu component"); 52724 } 52725 return /* @__PURE__ */ (0, import_jsx_runtime305.jsx)(GroupLabel3, { 52726 ref, 52727 render: ( 52728 // @ts-expect-error The `children` prop is passed 52729 /* @__PURE__ */ (0, import_jsx_runtime305.jsx)(component_default8, { 52730 upperCase: true, 52731 variant: "muted", 52732 size: "11px", 52733 weight: 500, 52734 lineHeight: "16px" 52735 }) 52736 ), 52737 ...props, 52738 store: menuContext.store 52739 }); 52740 }); 52741 52742 // packages/components/build-module/menu/separator.js 52743 var import_element229 = __toESM(require_element()); 52744 var import_jsx_runtime306 = __toESM(require_jsx_runtime()); 52745 var Separator22 = (0, import_element229.forwardRef)(function Separator32(props, ref) { 52746 const menuContext = (0, import_element229.useContext)(Context2); 52747 if (!menuContext?.store) { 52748 throw new Error("Menu.Separator can only be rendered inside a Menu component"); 52749 } 52750 return /* @__PURE__ */ (0, import_jsx_runtime306.jsx)(Separator3, { 52751 ref, 52752 ...props, 52753 store: menuContext.store, 52754 variant: menuContext.variant 52755 }); 52756 }); 52757 52758 // packages/components/build-module/menu/item-label.js 52759 var import_element230 = __toESM(require_element()); 52760 var import_jsx_runtime307 = __toESM(require_jsx_runtime()); 52761 var ItemLabel2 = (0, import_element230.forwardRef)(function ItemLabel3(props, ref) { 52762 const menuContext = (0, import_element230.useContext)(Context2); 52763 if (!menuContext?.store) { 52764 throw new Error("Menu.ItemLabel can only be rendered inside a Menu component"); 52765 } 52766 return /* @__PURE__ */ (0, import_jsx_runtime307.jsx)(ItemLabel, { 52767 numberOfLines: 1, 52768 ref, 52769 ...props 52770 }); 52771 }); 52772 52773 // packages/components/build-module/menu/item-help-text.js 52774 var import_element231 = __toESM(require_element()); 52775 var import_jsx_runtime308 = __toESM(require_jsx_runtime()); 52776 var ItemHelpText2 = (0, import_element231.forwardRef)(function ItemHelpText3(props, ref) { 52777 const menuContext = (0, import_element231.useContext)(Context2); 52778 if (!menuContext?.store) { 52779 throw new Error("Menu.ItemHelpText can only be rendered inside a Menu component"); 52780 } 52781 return /* @__PURE__ */ (0, import_jsx_runtime308.jsx)(ItemHelpText, { 52782 numberOfLines: 2, 52783 ref, 52784 ...props 52785 }); 52786 }); 52787 52788 // packages/components/build-module/menu/trigger-button.js 52789 var import_element232 = __toESM(require_element()); 52790 var import_jsx_runtime309 = __toESM(require_jsx_runtime()); 52791 var TriggerButton = (0, import_element232.forwardRef)(function TriggerButton2({ 52792 children, 52793 disabled = false, 52794 ...props 52795 }, ref) { 52796 const menuContext = (0, import_element232.useContext)(Context2); 52797 if (!menuContext?.store) { 52798 throw new Error("Menu.TriggerButton can only be rendered inside a Menu component"); 52799 } 52800 if (menuContext.store.parent) { 52801 throw new Error("Menu.TriggerButton should not be rendered inside a nested Menu component. Use Menu.SubmenuTriggerItem instead."); 52802 } 52803 return /* @__PURE__ */ (0, import_jsx_runtime309.jsx)(MenuButton, { 52804 ref, 52805 ...props, 52806 disabled, 52807 store: menuContext.store, 52808 children 52809 }); 52810 }); 52811 52812 // packages/components/build-module/menu/submenu-trigger-item.js 52813 var import_element233 = __toESM(require_element()); 52814 var import_jsx_runtime310 = __toESM(require_jsx_runtime()); 52815 var SubmenuTriggerItem = (0, import_element233.forwardRef)(function SubmenuTriggerItem2({ 52816 suffix, 52817 ...otherProps 52818 }, ref) { 52819 const menuContext = (0, import_element233.useContext)(Context2); 52820 if (!menuContext?.store.parent) { 52821 throw new Error("Menu.SubmenuTriggerItem can only be rendered inside a nested Menu component"); 52822 } 52823 return /* @__PURE__ */ (0, import_jsx_runtime310.jsx)(MenuButton, { 52824 ref, 52825 accessibleWhenDisabled: true, 52826 store: menuContext.store, 52827 render: /* @__PURE__ */ (0, import_jsx_runtime310.jsx)(Item22, { 52828 ...otherProps, 52829 // The menu item needs to register and be part of the parent menu. 52830 // Without specifying the store explicitly, the `Item` component 52831 // would otherwise read the store via context and pick up the one from 52832 // the sub-menu `Menu` component. 52833 store: menuContext.store.parent, 52834 suffix: /* @__PURE__ */ (0, import_jsx_runtime310.jsxs)(import_jsx_runtime310.Fragment, { 52835 children: [suffix, /* @__PURE__ */ (0, import_jsx_runtime310.jsx)(SubmenuChevronIcon, { 52836 "aria-hidden": "true", 52837 icon: chevron_right_small_default, 52838 size: 24, 52839 preserveAspectRatio: "xMidYMid slice" 52840 })] 52841 }) 52842 }) 52843 }); 52844 }); 52845 52846 // packages/components/build-module/menu/popover.js 52847 var import_element234 = __toESM(require_element()); 52848 var import_jsx_runtime311 = __toESM(require_jsx_runtime()); 52849 var Popover4 = (0, import_element234.forwardRef)(function Popover22({ 52850 gutter, 52851 children, 52852 shift: shift3, 52853 modal = true, 52854 ...otherProps 52855 }, ref) { 52856 const menuContext = (0, import_element234.useContext)(Context2); 52857 const appliedPlacementSide = useStoreState(menuContext?.store, "currentPlacement")?.split("-")[0]; 52858 const hideOnEscape = (0, import_element234.useCallback)((event) => { 52859 event.preventDefault(); 52860 return true; 52861 }, []); 52862 const computedDirection = useStoreState(menuContext?.store, "rtl") ? "rtl" : "ltr"; 52863 const wrapperProps = (0, import_element234.useMemo)(() => ({ 52864 dir: computedDirection, 52865 style: { 52866 direction: computedDirection 52867 } 52868 }), [computedDirection]); 52869 if (!menuContext?.store) { 52870 throw new Error("Menu.Popover can only be rendered inside a Menu component"); 52871 } 52872 return /* @__PURE__ */ (0, import_jsx_runtime311.jsx)(Menu, { 52873 ...otherProps, 52874 ref, 52875 modal, 52876 store: menuContext.store, 52877 gutter: gutter !== null && gutter !== void 0 ? gutter : menuContext.store.parent ? 0 : 8, 52878 shift: shift3 !== null && shift3 !== void 0 ? shift3 : menuContext.store.parent ? -4 : 0, 52879 hideOnHoverOutside: false, 52880 "data-side": appliedPlacementSide, 52881 wrapperProps, 52882 hideOnEscape, 52883 unmountOnHide: true, 52884 render: (renderProps) => ( 52885 // Two wrappers are needed for the entry animation, where the menu 52886 // container scales with a different factor than its contents. 52887 // The {...renderProps} are passed to the inner wrapper, so that the 52888 // menu element is the direct parent of the menu item elements. 52889 /* @__PURE__ */ (0, import_jsx_runtime311.jsx)(PopoverOuterWrapper, { 52890 variant: menuContext.variant, 52891 children: /* @__PURE__ */ (0, import_jsx_runtime311.jsx)(PopoverInnerWrapper, { 52892 ...renderProps 52893 }) 52894 }) 52895 ), 52896 children 52897 }); 52898 }); 52899 52900 // packages/components/build-module/menu/index.js 52901 var import_jsx_runtime312 = __toESM(require_jsx_runtime()); 52902 var UnconnectedMenu = (props) => { 52903 const { 52904 children, 52905 defaultOpen = false, 52906 open, 52907 onOpenChange, 52908 placement, 52909 // From internal components context 52910 variant 52911 } = useContextSystem(props, "Menu"); 52912 const parentContext = (0, import_element235.useContext)(Context2); 52913 const rtl2 = (0, import_i18n79.isRTL)(); 52914 let computedPlacement = placement !== null && placement !== void 0 ? placement : parentContext?.store ? "right-start" : "bottom-start"; 52915 if (rtl2) { 52916 if (/right/.test(computedPlacement)) { 52917 computedPlacement = computedPlacement.replace("right", "left"); 52918 } else if (/left/.test(computedPlacement)) { 52919 computedPlacement = computedPlacement.replace("left", "right"); 52920 } 52921 } 52922 const menuStore = useMenuStore({ 52923 parent: parentContext?.store, 52924 open, 52925 defaultOpen, 52926 placement: computedPlacement, 52927 focusLoop: true, 52928 setOpen(willBeOpen) { 52929 onOpenChange?.(willBeOpen); 52930 }, 52931 rtl: rtl2 52932 }); 52933 const contextValue = (0, import_element235.useMemo)(() => ({ 52934 store: menuStore, 52935 variant 52936 }), [menuStore, variant]); 52937 return /* @__PURE__ */ (0, import_jsx_runtime312.jsx)(Context2.Provider, { 52938 value: contextValue, 52939 children 52940 }); 52941 }; 52942 var Menu3 = Object.assign(contextConnectWithoutRef(UnconnectedMenu, "Menu"), { 52943 Context: Object.assign(Context2, { 52944 displayName: "Menu.Context" 52945 }), 52946 /** 52947 * Renders a menu item inside the `Menu.Popover` or `Menu.Group` components. 52948 * 52949 * It can optionally contain one instance of the `Menu.ItemLabel` component 52950 * and one instance of the `Menu.ItemHelpText` component. 52951 */ 52952 Item: Object.assign(Item22, { 52953 displayName: "Menu.Item" 52954 }), 52955 /** 52956 * Renders a radio menu item inside the `Menu.Popover` or `Menu.Group` 52957 * components. 52958 * 52959 * It can optionally contain one instance of the `Menu.ItemLabel` component 52960 * and one instance of the `Menu.ItemHelpText` component. 52961 */ 52962 RadioItem: Object.assign(RadioItem2, { 52963 displayName: "Menu.RadioItem" 52964 }), 52965 /** 52966 * Renders a checkbox menu item inside the `Menu.Popover` or `Menu.Group` 52967 * components. 52968 * 52969 * It can optionally contain one instance of the `Menu.ItemLabel` component 52970 * and one instance of the `Menu.ItemHelpText` component. 52971 */ 52972 CheckboxItem: Object.assign(CheckboxItem2, { 52973 displayName: "Menu.CheckboxItem" 52974 }), 52975 /** 52976 * Renders a group for menu items. 52977 * 52978 * It should contain one instance of `Menu.GroupLabel` and one or more 52979 * instances of `Menu.Item`, `Menu.RadioItem`, or `Menu.CheckboxItem`. 52980 */ 52981 Group: Object.assign(Group22, { 52982 displayName: "Menu.Group" 52983 }), 52984 /** 52985 * Renders a label in a menu group. 52986 * 52987 * This component should be wrapped with `Menu.Group` so the 52988 * `aria-labelledby` is correctly set on the group element. 52989 */ 52990 GroupLabel: Object.assign(GroupLabel22, { 52991 displayName: "Menu.GroupLabel" 52992 }), 52993 /** 52994 * Renders a divider between menu items or menu groups. 52995 */ 52996 Separator: Object.assign(Separator22, { 52997 displayName: "Menu.Separator" 52998 }), 52999 /** 53000 * Renders a menu item's label text. It should be wrapped with `Menu.Item`, 53001 * `Menu.RadioItem`, or `Menu.CheckboxItem`. 53002 */ 53003 ItemLabel: Object.assign(ItemLabel2, { 53004 displayName: "Menu.ItemLabel" 53005 }), 53006 /** 53007 * Renders a menu item's help text. It should be wrapped with `Menu.Item`, 53008 * `Menu.RadioItem`, or `Menu.CheckboxItem`. 53009 */ 53010 ItemHelpText: Object.assign(ItemHelpText2, { 53011 displayName: "Menu.ItemHelpText" 53012 }), 53013 /** 53014 * Renders a dropdown menu element that's controlled by a sibling 53015 * `Menu.TriggerButton` component. It renders a popover and automatically 53016 * focuses on items when the menu is shown. 53017 * 53018 * The only valid children of `Menu.Popover` are `Menu.Item`, 53019 * `Menu.RadioItem`, `Menu.CheckboxItem`, `Menu.Group`, `Menu.Separator`, 53020 * and `Menu` (for nested dropdown menus). 53021 */ 53022 Popover: Object.assign(Popover4, { 53023 displayName: "Menu.Popover" 53024 }), 53025 /** 53026 * Renders a menu button that toggles the visibility of a sibling 53027 * `Menu.Popover` component when clicked or when using arrow keys. 53028 */ 53029 TriggerButton: Object.assign(TriggerButton, { 53030 displayName: "Menu.TriggerButton" 53031 }), 53032 /** 53033 * Renders a menu item that toggles the visibility of a sibling 53034 * `Menu.Popover` component when clicked or when using arrow keys. 53035 * 53036 * This component is used to create a nested dropdown menu. 53037 */ 53038 SubmenuTriggerItem: Object.assign(SubmenuTriggerItem, { 53039 displayName: "Menu.SubmenuTriggerItem" 53040 }) 53041 }); 53042 53043 // packages/components/build-module/theme/index.js 53044 var import_element236 = __toESM(require_element()); 53045 53046 // packages/components/build-module/theme/styles.js 53047 function _EMOTION_STRINGIFIED_CSS_ERROR__42() { 53048 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 53049 } 53050 var colorVariables = ({ 53051 colors 53052 }) => { 53053 const shades = Object.entries(colors.gray || {}).map(([k2, v3]) => `--wp-components-color-gray-$k2}: $v3};`).join(""); 53054 return [/* @__PURE__ */ css("--wp-components-color-accent:", colors.accent, ";--wp-components-color-accent-darker-10:", colors.accentDarker10, ";--wp-components-color-accent-darker-20:", colors.accentDarker20, ";--wp-components-color-accent-inverted:", colors.accentInverted, ";--wp-components-color-background:", colors.background, ";--wp-components-color-foreground:", colors.foreground, ";--wp-components-color-foreground-inverted:", colors.foregroundInverted, ";", shades, ";" + (false ? "" : ";label:colorVariables;"), false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQksiLCJmaWxlIjoic3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgdHlwZSB7IFRoZW1lT3V0cHV0VmFsdWVzIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBjb2xvclZhcmlhYmxlcyA9ICggeyBjb2xvcnMgfTogVGhlbWVPdXRwdXRWYWx1ZXMgKSA9PiB7XG5cdGNvbnN0IHNoYWRlcyA9IE9iamVjdC5lbnRyaWVzKCBjb2xvcnMuZ3JheSB8fCB7fSApXG5cdFx0Lm1hcCggKCBbIGssIHYgXSApID0+IGAtLXdwLWNvbXBvbmVudHMtY29sb3ItZ3JheS0keyBrIH06ICR7IHYgfTtgIClcblx0XHQuam9pbiggJycgKTtcblxuXHRyZXR1cm4gW1xuXHRcdGNzc2Bcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1hY2NlbnQ6ICR7IGNvbG9ycy5hY2NlbnQgfTtcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1hY2NlbnQtZGFya2VyLTEwOiAkeyBjb2xvcnMuYWNjZW50RGFya2VyMTAgfTtcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1hY2NlbnQtZGFya2VyLTIwOiAkeyBjb2xvcnMuYWNjZW50RGFya2VyMjAgfTtcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1hY2NlbnQtaW52ZXJ0ZWQ6ICR7IGNvbG9ycy5hY2NlbnRJbnZlcnRlZCB9O1xuXG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItYmFja2dyb3VuZDogJHsgY29sb3JzLmJhY2tncm91bmQgfTtcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1mb3JlZ3JvdW5kOiAkeyBjb2xvcnMuZm9yZWdyb3VuZCB9O1xuXHRcdFx0LS13cC1jb21wb25lbnRzLWNvbG9yLWZvcmVncm91bmQtaW52ZXJ0ZWQ6ICR7IGNvbG9ycy5mb3JlZ3JvdW5kSW52ZXJ0ZWQgfTtcblxuXHRcdFx0JHsgc2hhZGVzIH1cblx0XHRgLFxuXHRdO1xufTtcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuXHRjb2xvcjogdmFyKCAtLXdwLWNvbXBvbmVudHMtY29sb3ItZm9yZWdyb3VuZCwgY3VycmVudENvbG9yICk7XG5gO1xuIl19 */")]; 53055 }; 53056 var Wrapper6 = /* @__PURE__ */ emotion_styled_base_browser_esm_default("div", false ? { 53057 target: "e1krjpvb0" 53058 } : { 53059 target: "e1krjpvb0", 53060 label: "Wrapper" 53061 })(false ? { 53062 name: "1a3idx0", 53063 styles: "color:var( --wp-components-color-foreground, currentColor )" 53064 } : { 53065 name: "1a3idx0", 53066 styles: "color:var( --wp-components-color-foreground, currentColor )", 53067 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQ2lDIiwiZmlsZSI6InN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRXh0ZXJuYWwgZGVwZW5kZW5jaWVzXG4gKi9cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLyoqXG4gKiBJbnRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHR5cGUgeyBUaGVtZU91dHB1dFZhbHVlcyB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgY29sb3JWYXJpYWJsZXMgPSAoIHsgY29sb3JzIH06IFRoZW1lT3V0cHV0VmFsdWVzICkgPT4ge1xuXHRjb25zdCBzaGFkZXMgPSBPYmplY3QuZW50cmllcyggY29sb3JzLmdyYXkgfHwge30gKVxuXHRcdC5tYXAoICggWyBrLCB2IF0gKSA9PiBgLS13cC1jb21wb25lbnRzLWNvbG9yLWdyYXktJHsgayB9OiAkeyB2IH07YCApXG5cdFx0LmpvaW4oICcnICk7XG5cblx0cmV0dXJuIFtcblx0XHRjc3NgXG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItYWNjZW50OiAkeyBjb2xvcnMuYWNjZW50IH07XG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItYWNjZW50LWRhcmtlci0xMDogJHsgY29sb3JzLmFjY2VudERhcmtlcjEwIH07XG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItYWNjZW50LWRhcmtlci0yMDogJHsgY29sb3JzLmFjY2VudERhcmtlcjIwIH07XG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItYWNjZW50LWludmVydGVkOiAkeyBjb2xvcnMuYWNjZW50SW52ZXJ0ZWQgfTtcblxuXHRcdFx0LS13cC1jb21wb25lbnRzLWNvbG9yLWJhY2tncm91bmQ6ICR7IGNvbG9ycy5iYWNrZ3JvdW5kIH07XG5cdFx0XHQtLXdwLWNvbXBvbmVudHMtY29sb3ItZm9yZWdyb3VuZDogJHsgY29sb3JzLmZvcmVncm91bmQgfTtcblx0XHRcdC0td3AtY29tcG9uZW50cy1jb2xvci1mb3JlZ3JvdW5kLWludmVydGVkOiAkeyBjb2xvcnMuZm9yZWdyb3VuZEludmVydGVkIH07XG5cblx0XHRcdCR7IHNoYWRlcyB9XG5cdFx0YCxcblx0XTtcbn07XG5cbmV4cG9ydCBjb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcblx0Y29sb3I6IHZhciggLS13cC1jb21wb25lbnRzLWNvbG9yLWZvcmVncm91bmQsIGN1cnJlbnRDb2xvciApO1xuYDtcbiJdfQ== */", 53068 toString: _EMOTION_STRINGIFIED_CSS_ERROR__42 53069 }); 53070 53071 // packages/components/build-module/theme/color-algorithms.js 53072 var import_warning11 = __toESM(require_warning()); 53073 k([names_default, a11y_default]); 53074 function generateThemeVariables(inputs) { 53075 validateInputs(inputs); 53076 const generatedColors = { 53077 ...generateAccentDependentColors(inputs.accent), 53078 ...generateBackgroundDependentColors(inputs.background) 53079 }; 53080 warnContrastIssues(checkContrasts(inputs, generatedColors)); 53081 return { 53082 colors: generatedColors 53083 }; 53084 } 53085 function validateInputs(inputs) { 53086 for (const [key, value] of Object.entries(inputs)) { 53087 if (typeof value !== "undefined" && !w(value).isValid()) { 53088 true ? (0, import_warning11.default)(`wp.components.Theme: "$value}" is not a valid color value for the '$key}' prop.`) : void 0; 53089 } 53090 } 53091 } 53092 function checkContrasts(inputs, outputs) { 53093 const background2 = inputs.background || COLORS.white; 53094 const accent = inputs.accent || "#3858e9"; 53095 const foreground = outputs.foreground || COLORS.gray[900]; 53096 const gray = outputs.gray || COLORS.gray; 53097 return { 53098 accent: w(background2).isReadable(accent) ? void 0 : `The background color ("$background2}") does not have sufficient contrast against the accent color ("$accent}").`, 53099 foreground: w(background2).isReadable(foreground) ? void 0 : `The background color provided ("$background2}") does not have sufficient contrast against the standard foreground colors.`, 53100 grays: w(background2).contrast(gray[600]) >= 3 && w(background2).contrast(gray[700]) >= 4.5 ? void 0 : `The background color provided ("$background2}") cannot generate a set of grayscale foreground colors with sufficient contrast. Try adjusting the color to be lighter or darker.` 53101 }; 53102 } 53103 function warnContrastIssues(issues) { 53104 for (const error of Object.values(issues)) { 53105 if (error) { 53106 true ? (0, import_warning11.default)("wp.components.Theme: " + error) : void 0; 53107 } 53108 } 53109 } 53110 function generateAccentDependentColors(accent) { 53111 if (!accent) { 53112 return {}; 53113 } 53114 return { 53115 accent, 53116 accentDarker10: w(accent).darken(0.1).toHex(), 53117 accentDarker20: w(accent).darken(0.2).toHex(), 53118 accentInverted: getForegroundForColor(accent) 53119 }; 53120 } 53121 function generateBackgroundDependentColors(background2) { 53122 if (!background2) { 53123 return {}; 53124 } 53125 const foreground = getForegroundForColor(background2); 53126 return { 53127 background: background2, 53128 foreground, 53129 foregroundInverted: getForegroundForColor(foreground), 53130 gray: generateShades(background2, foreground) 53131 }; 53132 } 53133 function getForegroundForColor(color2) { 53134 return w(color2).isDark() ? COLORS.white : COLORS.gray[900]; 53135 } 53136 function generateShades(background2, foreground) { 53137 const SHADES = { 53138 100: 0.06, 53139 200: 0.121, 53140 300: 0.132, 53141 400: 0.2, 53142 600: 0.42, 53143 700: 0.543, 53144 800: 0.821 53145 }; 53146 const limit = 0.884; 53147 const direction = w(background2).isDark() ? "lighten" : "darken"; 53148 const range = Math.abs(w(background2).toHsl().l - w(foreground).toHsl().l) / 100; 53149 const result = {}; 53150 Object.entries(SHADES).forEach(([key, value]) => { 53151 result[parseInt(key)] = w(background2)[direction](value / limit * range).toHex(); 53152 }); 53153 return result; 53154 } 53155 53156 // packages/components/build-module/theme/index.js 53157 var import_jsx_runtime313 = __toESM(require_jsx_runtime()); 53158 function Theme({ 53159 accent, 53160 background: background2, 53161 className: className2, 53162 ...props 53163 }) { 53164 const cx3 = useCx(); 53165 const classes = (0, import_element236.useMemo)(() => cx3(...colorVariables(generateThemeVariables({ 53166 accent, 53167 background: background2 53168 })), className2), [accent, background2, className2, cx3]); 53169 return /* @__PURE__ */ (0, import_jsx_runtime313.jsx)(Wrapper6, { 53170 className: classes, 53171 ...props 53172 }); 53173 } 53174 var theme_default = Theme; 53175 53176 // packages/components/build-module/tabs/index.js 53177 var import_compose87 = __toESM(require_compose()); 53178 var import_element242 = __toESM(require_element()); 53179 var import_i18n80 = __toESM(require_i18n()); 53180 53181 // packages/components/build-module/tabs/context.js 53182 var import_element237 = __toESM(require_element()); 53183 var TabsContext = (0, import_element237.createContext)(void 0); 53184 TabsContext.displayName = "TabsContext"; 53185 var useTabsContext = () => (0, import_element237.useContext)(TabsContext); 53186 53187 // packages/components/build-module/tabs/tab.js 53188 var import_element238 = __toESM(require_element()); 53189 var import_warning12 = __toESM(require_warning()); 53190 53191 // packages/components/build-module/tabs/styles.js 53192 function _EMOTION_STRINGIFIED_CSS_ERROR__43() { 53193 return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; 53194 } 53195 var StyledTabList = /* @__PURE__ */ emotion_styled_base_browser_esm_default(TabList, false ? { 53196 target: "enfox0g4" 53197 } : { 53198 target: "enfox0g4", 53199 label: "StyledTabList" 53200 })("display:flex;align-items:stretch;overflow-x:auto;&[aria-orientation='vertical']{flex-direction:column;}:where( [aria-orientation='horizontal'] ){width:fit-content;}--direction-factor:1;--direction-start:left;--direction-end:right;--selected-start:var( --selected-left, 0 );&:dir( rtl ){--direction-factor:-1;--direction-start:right;--direction-end:left;--selected-start:var( --selected-right, 0 );}@media not ( prefers-reduced-motion ){&[data-indicator-animated]::before{transition-property:transform,border-radius,border-block;transition-duration:0.2s;transition-timing-function:ease-out;}}position:relative;&::before{content:'';position:absolute;pointer-events:none;transform-origin:var( --direction-start ) top;outline:2px solid transparent;outline-offset:-1px;}--antialiasing-factor:100;&[aria-orientation='horizontal']{--fade-width:64px;--fade-gradient-base:transparent 0%,black var( --fade-width );--fade-gradient-composed:var( --fade-gradient-base ),black 60%,transparent 50%;&.is-overflowing-first{mask-image:linear-gradient(\n to var( --direction-end ),\n var( --fade-gradient-base )\n );}&.is-overflowing-last{mask-image:linear-gradient(\n to var( --direction-start ),\n var( --fade-gradient-base )\n );}&.is-overflowing-first.is-overflowing-last{mask-image:linear-gradient(\n to right,\n var( --fade-gradient-composed )\n ),linear-gradient( to left, var( --fade-gradient-composed ) );}&::before{bottom:0;height:0;width:calc( var( --antialiasing-factor ) * 1px );transform:translateX(\n calc(\n var( --selected-start ) * var( --direction-factor ) *\n 1px\n )\n ) scaleX(\n calc(\n var( --selected-width, 0 ) /\n var( --antialiasing-factor )\n )\n );border-bottom:var( --wp-admin-border-width-focus ) solid ", COLORS.theme.accent, ";}}&[aria-orientation='vertical']{&::before{border-radius:", config_values_default.radiusSmall, "/calc(\n ", config_values_default.radiusSmall, " /\n (\n var( --selected-height, 0 ) /\n var( --antialiasing-factor )\n )\n );top:0;left:0;width:100%;height:calc( var( --antialiasing-factor ) * 1px );transform:translateY( calc( var( --selected-top, 0 ) * 1px ) ) scaleY(\n calc(\n var( --selected-height, 0 ) /\n var( --antialiasing-factor )\n )\n );background-color:color-mix(\n in srgb,\n ", COLORS.theme.accent, ",\n transparent 96%\n );}&[data-select-on-move='true']:has(\n :is( :focus-visible, [data-focus-visible] )\n )::before{box-sizing:border-box;border:var( --wp-admin-border-width-focus ) solid ", COLORS.theme.accent, ";border-block-width:calc(\n var( --wp-admin-border-width-focus, 1px ) /\n (\n var( --selected-height, 0 ) /\n var( --antialiasing-factor )\n )\n );}}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAasD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport * as Ariakit from '@ariakit/react';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG, font } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\n\nexport const StyledTabList = styled( Ariakit.TabList )`\n\tdisplay: flex;\n\talign-items: stretch;\n\toverflow-x: auto;\n\n\t&[aria-orientation='vertical'] {\n\t\tflex-direction: column;\n\t}\n\n\t:where( [aria-orientation='horizontal'] ) {\n\t\twidth: fit-content;\n\t}\n\n\t--direction-factor: 1;\n\t--direction-start: left;\n\t--direction-end: right;\n\t--selected-start: var( --selected-left, 0 );\n\t&:dir( rtl ) {\n\t\t--direction-factor: -1;\n\t\t--direction-start: right;\n\t\t--direction-end: left;\n\t\t--selected-start: var( --selected-right, 0 );\n\t}\n\n\t@media not ( prefers-reduced-motion ) {\n\t\t&[data-indicator-animated]::before {\n\t\t\ttransition-property: transform, border-radius, border-block;\n\t\t\ttransition-duration: 0.2s;\n\t\t\ttransition-timing-function: ease-out;\n\t\t}\n\t}\n\tposition: relative;\n\t&::before {\n\t\tcontent: '';\n\t\tposition: absolute;\n\t\tpointer-events: none;\n\t\ttransform-origin: var( --direction-start ) top;\n\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: -1px;\n\t}\n\n\t/* Using a large value to avoid antialiasing rounding issues\n\t\t\twhen scaling in the transform, see: https://stackoverflow.com/a/52159123 */\n\t--antialiasing-factor: 100;\n\t&[aria-orientation='horizontal'] {\n\t\t--fade-width: 64px;\n\t\t--fade-gradient-base: transparent 0%, black var( --fade-width );\n\t\t--fade-gradient-composed: var( --fade-gradient-base ), black 60%,\n\t\t\ttransparent 50%;\n\t\t&.is-overflowing-first {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-end ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-start ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-first.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\t\tto right,\n\t\t\t\t\tvar( --fade-gradient-composed )\n\t\t\t\t),\n\t\t\t\tlinear-gradient( to left, var( --fade-gradient-composed ) );\n\t\t}\n\n\t\t&::before {\n\t\t\tbottom: 0;\n\t\t\theight: 0;\n\t\t\twidth: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-start ) * var( --direction-factor ) *\n\t\t\t\t\t\t\t1px\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\tscaleX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-width, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tborder-bottom: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t}\n\t}\n\t&[aria-orientation='vertical'] {\n\t\t&::before {\n\t\t\t/* Adjusting the border radius to match the scaling in the y axis. */\n\t\t\tborder-radius: ${ CONFIG.radiusSmall } /\n\t\t\t\tcalc(\n\t\t\t\t\t${ CONFIG.radiusSmall } /\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t\t)\n\t\t\t\t);\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\twidth: 100%;\n\t\t\theight: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateY( calc( var( --selected-top, 0 ) * 1px ) )\n\t\t\t\tscaleY(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tbackground-color: color-mix(\n\t\t\t\tin srgb,\n\t\t\t\t${ COLORS.theme.accent },\n\t\t\t\ttransparent 96%\n\t\t\t);\n\t\t}\n\t\t&[data-select-on-move='true']:has(\n\t\t\t\t:is( :focus-visible, [data-focus-visible] )\n\t\t\t)::before {\n\t\t\tbox-sizing: border-box;\n\t\t\tborder: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\t/* Adjusting the border width to match the scaling in the y axis. */\n\t\t\tborder-block-width: calc(\n\t\t\t\tvar( --wp-admin-border-width-focus, 1px ) /\n\t\t\t\t\t(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}\n`;\n\nexport const Tab = styled( Ariakit.Tab )`\n\t& {\n\t\t/* Resets */\n\t\tborder-radius: 0;\n\t\tbackground: transparent;\n\t\tborder: none;\n\t\tbox-shadow: none;\n\n\t\tflex: 1 0 auto;\n\t\twhite-space: nowrap;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcursor: pointer;\n\t\tline-height: 1.2; // Characters in some languages (e.g. Japanese) may have a native higher line-height.\n\t\tfont-weight: 400;\n\t\tfont-size: ${ font( 'default.fontSize' ) };\n\t\tcolor: ${ COLORS.theme.foreground };\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: default;\n\t\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\t}\n\n\t\t&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ) {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t}\n\n\t\t&:focus:not( :disabled ) {\n\t\t\tbox-shadow: none;\n\t\t\toutline: none;\n\t\t}\n\n\t\t// Focus indicator.\n\t\tposition: relative;\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tpointer-events: none;\n\n\t\t\t// Draw the indicator.\n\t\t\t// Outline works for Windows high contrast mode as well.\n\t\t\toutline: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\tborder-radius: ${ CONFIG.radiusSmall };\n\n\t\t\t// Animation\n\t\t\topacity: 0;\n\n\t\t\t@media not ( prefers-reduced-motion ) {\n\t\t\t\ttransition: opacity 0.1s linear;\n\t\t\t}\n\t\t}\n\n\t\t&[data-focus-visible]::after {\n\t\t\topacity: 1;\n\t\t}\n\t}\n\n\t[aria-orientation='horizontal'] & {\n\t\tpadding-inline: ${ space( 4 ) };\n\t\theight: ${ space( 12 ) };\n\t\tscroll-margin: 24px;\n\n\t\t&::after {\n\t\t\tcontent: '';\n\t\t\tinset: ${ space( 3 ) };\n\t\t}\n\t}\n\n\t[aria-orientation='vertical'] & {\n\t\tpadding: ${ space( 2 ) } ${ space( 3 ) };\n\t\tmin-height: ${ space( 10 ) };\n\n\t\t&[aria-selected='true'] {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t\tfill: currentColor;\n\t\t}\n\t}\n\t[aria-orientation='vertical'][data-select-on-move='false'] &::after {\n\t\tcontent: '';\n\t\tinset: var( --wp-admin-border-width-focus );\n\t}\n`;\n\nexport const TabChildren = styled.span`\n\tflex-grow: 1;\n\n\tdisplay: flex;\n\talign-items: center;\n\n\t[aria-orientation='horizontal'] & {\n\t\tjustify-content: center;\n\t}\n\t[aria-orientation='vertical'] & {\n\t\tjustify-content: start;\n\t}\n`;\n\nexport const TabChevron = styled( Icon )`\n\tflex-shrink: 0;\n\tmargin-inline-end: ${ space( -1 ) };\n\t[aria-orientation='horizontal'] & {\n\t\tdisplay: none;\n\t}\n\topacity: 0;\n\t[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) & {\n\t\topacity: 1;\n\t}\n\t// The chevron is transitioned into existence when selectOnMove is enabled,\n\t// because otherwise it looks jarring, as it shows up outside of the focus\n\t// indicator that's being animated at the same time.\n\t@media not ( prefers-reduced-motion ) {\n\t\t[data-select-on-move='true']\n\t\t\t[role='tab']:is( [aria-selected='true'],  )\n\t\t\t& {\n\t\t\ttransition: opacity 0.15s 0.15s linear;\n\t\t}\n\t}\n\t&:dir( rtl ) {\n\t\trotate: 180deg;\n\t}\n`;\n\nexport const TabPanel = styled( Ariakit.TabPanel )`\n\t&:focus {\n\t\tbox-shadow: none;\n\t\toutline: none;\n\t}\n\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 var( --wp-admin-border-width-focus )\n\t\t\t${ COLORS.theme.accent };\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: 0;\n\t}\n`;\n"]} */")); 53201 var Tab22 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(Tab, false ? { 53202 target: "enfox0g3" 53203 } : { 53204 target: "enfox0g3", 53205 label: "Tab" 53206 })("&{border-radius:0;background:transparent;border:none;box-shadow:none;flex:1 0 auto;white-space:nowrap;display:flex;align-items:center;cursor:pointer;line-height:1.2;font-weight:400;font-size:", font("default.fontSize"), ";color:", COLORS.theme.foreground, ";position:relative;&[aria-disabled='true']{cursor:default;color:", COLORS.ui.textDisabled, ";}&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ){color:", COLORS.theme.accent, ";}&:focus:not( :disabled ){box-shadow:none;outline:none;}&::after{position:absolute;pointer-events:none;outline:var( --wp-admin-border-width-focus ) solid ", COLORS.theme.accent, ";border-radius:", config_values_default.radiusSmall, ";opacity:0;@media not ( prefers-reduced-motion ){transition:opacity 0.1s linear;}}&[data-focus-visible]::after{opacity:1;}}[aria-orientation='horizontal'] &{padding-inline:", space(4), ";height:", space(12), ";scroll-margin:24px;&::after{content:'';inset:", space(3), ";}}[aria-orientation='vertical'] &{padding:", space(2), " ", space(3), ";min-height:", space(10), ";&[aria-selected='true']{color:", COLORS.theme.accent, ";fill:currentColor;}}[aria-orientation='vertical'][data-select-on-move='false'] &::after{content:'';inset:var( --wp-admin-border-width-focus );}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAsJwC","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport * as Ariakit from '@ariakit/react';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG, font } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\n\nexport const StyledTabList = styled( Ariakit.TabList )`\n\tdisplay: flex;\n\talign-items: stretch;\n\toverflow-x: auto;\n\n\t&[aria-orientation='vertical'] {\n\t\tflex-direction: column;\n\t}\n\n\t:where( [aria-orientation='horizontal'] ) {\n\t\twidth: fit-content;\n\t}\n\n\t--direction-factor: 1;\n\t--direction-start: left;\n\t--direction-end: right;\n\t--selected-start: var( --selected-left, 0 );\n\t&:dir( rtl ) {\n\t\t--direction-factor: -1;\n\t\t--direction-start: right;\n\t\t--direction-end: left;\n\t\t--selected-start: var( --selected-right, 0 );\n\t}\n\n\t@media not ( prefers-reduced-motion ) {\n\t\t&[data-indicator-animated]::before {\n\t\t\ttransition-property: transform, border-radius, border-block;\n\t\t\ttransition-duration: 0.2s;\n\t\t\ttransition-timing-function: ease-out;\n\t\t}\n\t}\n\tposition: relative;\n\t&::before {\n\t\tcontent: '';\n\t\tposition: absolute;\n\t\tpointer-events: none;\n\t\ttransform-origin: var( --direction-start ) top;\n\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: -1px;\n\t}\n\n\t/* Using a large value to avoid antialiasing rounding issues\n\t\t\twhen scaling in the transform, see: https://stackoverflow.com/a/52159123 */\n\t--antialiasing-factor: 100;\n\t&[aria-orientation='horizontal'] {\n\t\t--fade-width: 64px;\n\t\t--fade-gradient-base: transparent 0%, black var( --fade-width );\n\t\t--fade-gradient-composed: var( --fade-gradient-base ), black 60%,\n\t\t\ttransparent 50%;\n\t\t&.is-overflowing-first {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-end ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-start ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-first.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\t\tto right,\n\t\t\t\t\tvar( --fade-gradient-composed )\n\t\t\t\t),\n\t\t\t\tlinear-gradient( to left, var( --fade-gradient-composed ) );\n\t\t}\n\n\t\t&::before {\n\t\t\tbottom: 0;\n\t\t\theight: 0;\n\t\t\twidth: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-start ) * var( --direction-factor ) *\n\t\t\t\t\t\t\t1px\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\tscaleX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-width, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tborder-bottom: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t}\n\t}\n\t&[aria-orientation='vertical'] {\n\t\t&::before {\n\t\t\t/* Adjusting the border radius to match the scaling in the y axis. */\n\t\t\tborder-radius: ${ CONFIG.radiusSmall } /\n\t\t\t\tcalc(\n\t\t\t\t\t${ CONFIG.radiusSmall } /\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t\t)\n\t\t\t\t);\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\twidth: 100%;\n\t\t\theight: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateY( calc( var( --selected-top, 0 ) * 1px ) )\n\t\t\t\tscaleY(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tbackground-color: color-mix(\n\t\t\t\tin srgb,\n\t\t\t\t${ COLORS.theme.accent },\n\t\t\t\ttransparent 96%\n\t\t\t);\n\t\t}\n\t\t&[data-select-on-move='true']:has(\n\t\t\t\t:is( :focus-visible, [data-focus-visible] )\n\t\t\t)::before {\n\t\t\tbox-sizing: border-box;\n\t\t\tborder: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\t/* Adjusting the border width to match the scaling in the y axis. */\n\t\t\tborder-block-width: calc(\n\t\t\t\tvar( --wp-admin-border-width-focus, 1px ) /\n\t\t\t\t\t(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}\n`;\n\nexport const Tab = styled( Ariakit.Tab )`\n\t& {\n\t\t/* Resets */\n\t\tborder-radius: 0;\n\t\tbackground: transparent;\n\t\tborder: none;\n\t\tbox-shadow: none;\n\n\t\tflex: 1 0 auto;\n\t\twhite-space: nowrap;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcursor: pointer;\n\t\tline-height: 1.2; // Characters in some languages (e.g. Japanese) may have a native higher line-height.\n\t\tfont-weight: 400;\n\t\tfont-size: ${ font( 'default.fontSize' ) };\n\t\tcolor: ${ COLORS.theme.foreground };\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: default;\n\t\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\t}\n\n\t\t&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ) {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t}\n\n\t\t&:focus:not( :disabled ) {\n\t\t\tbox-shadow: none;\n\t\t\toutline: none;\n\t\t}\n\n\t\t// Focus indicator.\n\t\tposition: relative;\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tpointer-events: none;\n\n\t\t\t// Draw the indicator.\n\t\t\t// Outline works for Windows high contrast mode as well.\n\t\t\toutline: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\tborder-radius: ${ CONFIG.radiusSmall };\n\n\t\t\t// Animation\n\t\t\topacity: 0;\n\n\t\t\t@media not ( prefers-reduced-motion ) {\n\t\t\t\ttransition: opacity 0.1s linear;\n\t\t\t}\n\t\t}\n\n\t\t&[data-focus-visible]::after {\n\t\t\topacity: 1;\n\t\t}\n\t}\n\n\t[aria-orientation='horizontal'] & {\n\t\tpadding-inline: ${ space( 4 ) };\n\t\theight: ${ space( 12 ) };\n\t\tscroll-margin: 24px;\n\n\t\t&::after {\n\t\t\tcontent: '';\n\t\t\tinset: ${ space( 3 ) };\n\t\t}\n\t}\n\n\t[aria-orientation='vertical'] & {\n\t\tpadding: ${ space( 2 ) } ${ space( 3 ) };\n\t\tmin-height: ${ space( 10 ) };\n\n\t\t&[aria-selected='true'] {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t\tfill: currentColor;\n\t\t}\n\t}\n\t[aria-orientation='vertical'][data-select-on-move='false'] &::after {\n\t\tcontent: '';\n\t\tinset: var( --wp-admin-border-width-focus );\n\t}\n`;\n\nexport const TabChildren = styled.span`\n\tflex-grow: 1;\n\n\tdisplay: flex;\n\talign-items: center;\n\n\t[aria-orientation='horizontal'] & {\n\t\tjustify-content: center;\n\t}\n\t[aria-orientation='vertical'] & {\n\t\tjustify-content: start;\n\t}\n`;\n\nexport const TabChevron = styled( Icon )`\n\tflex-shrink: 0;\n\tmargin-inline-end: ${ space( -1 ) };\n\t[aria-orientation='horizontal'] & {\n\t\tdisplay: none;\n\t}\n\topacity: 0;\n\t[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) & {\n\t\topacity: 1;\n\t}\n\t// The chevron is transitioned into existence when selectOnMove is enabled,\n\t// because otherwise it looks jarring, as it shows up outside of the focus\n\t// indicator that's being animated at the same time.\n\t@media not ( prefers-reduced-motion ) {\n\t\t[data-select-on-move='true']\n\t\t\t[role='tab']:is( [aria-selected='true'],  )\n\t\t\t& {\n\t\t\ttransition: opacity 0.15s 0.15s linear;\n\t\t}\n\t}\n\t&:dir( rtl ) {\n\t\trotate: 180deg;\n\t}\n`;\n\nexport const TabPanel = styled( Ariakit.TabPanel )`\n\t&:focus {\n\t\tbox-shadow: none;\n\t\toutline: none;\n\t}\n\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 var( --wp-admin-border-width-focus )\n\t\t\t${ COLORS.theme.accent };\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: 0;\n\t}\n`;\n"]} */")); 53207 var TabChildren = /* @__PURE__ */ emotion_styled_base_browser_esm_default("span", false ? { 53208 target: "enfox0g2" 53209 } : { 53210 target: "enfox0g2", 53211 label: "TabChildren" 53212 })(false ? { 53213 name: "9at4z3", 53214 styles: "flex-grow:1;display:flex;align-items:center;[aria-orientation='horizontal'] &{justify-content:center;}[aria-orientation='vertical'] &{justify-content:start;}" 53215 } : { 53216 name: "9at4z3", 53217 styles: "flex-grow:1;display:flex;align-items:center;[aria-orientation='horizontal'] &{justify-content:center;}[aria-orientation='vertical'] &{justify-content:start;}", 53218 map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAyOsC","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport * as Ariakit from '@ariakit/react';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG, font } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\n\nexport const StyledTabList = styled( Ariakit.TabList )`\n\tdisplay: flex;\n\talign-items: stretch;\n\toverflow-x: auto;\n\n\t&[aria-orientation='vertical'] {\n\t\tflex-direction: column;\n\t}\n\n\t:where( [aria-orientation='horizontal'] ) {\n\t\twidth: fit-content;\n\t}\n\n\t--direction-factor: 1;\n\t--direction-start: left;\n\t--direction-end: right;\n\t--selected-start: var( --selected-left, 0 );\n\t&:dir( rtl ) {\n\t\t--direction-factor: -1;\n\t\t--direction-start: right;\n\t\t--direction-end: left;\n\t\t--selected-start: var( --selected-right, 0 );\n\t}\n\n\t@media not ( prefers-reduced-motion ) {\n\t\t&[data-indicator-animated]::before {\n\t\t\ttransition-property: transform, border-radius, border-block;\n\t\t\ttransition-duration: 0.2s;\n\t\t\ttransition-timing-function: ease-out;\n\t\t}\n\t}\n\tposition: relative;\n\t&::before {\n\t\tcontent: '';\n\t\tposition: absolute;\n\t\tpointer-events: none;\n\t\ttransform-origin: var( --direction-start ) top;\n\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: -1px;\n\t}\n\n\t/* Using a large value to avoid antialiasing rounding issues\n\t\t\twhen scaling in the transform, see: https://stackoverflow.com/a/52159123 */\n\t--antialiasing-factor: 100;\n\t&[aria-orientation='horizontal'] {\n\t\t--fade-width: 64px;\n\t\t--fade-gradient-base: transparent 0%, black var( --fade-width );\n\t\t--fade-gradient-composed: var( --fade-gradient-base ), black 60%,\n\t\t\ttransparent 50%;\n\t\t&.is-overflowing-first {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-end ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-start ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-first.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\t\tto right,\n\t\t\t\t\tvar( --fade-gradient-composed )\n\t\t\t\t),\n\t\t\t\tlinear-gradient( to left, var( --fade-gradient-composed ) );\n\t\t}\n\n\t\t&::before {\n\t\t\tbottom: 0;\n\t\t\theight: 0;\n\t\t\twidth: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-start ) * var( --direction-factor ) *\n\t\t\t\t\t\t\t1px\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\tscaleX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-width, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tborder-bottom: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t}\n\t}\n\t&[aria-orientation='vertical'] {\n\t\t&::before {\n\t\t\t/* Adjusting the border radius to match the scaling in the y axis. */\n\t\t\tborder-radius: ${ CONFIG.radiusSmall } /\n\t\t\t\tcalc(\n\t\t\t\t\t${ CONFIG.radiusSmall } /\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t\t)\n\t\t\t\t);\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\twidth: 100%;\n\t\t\theight: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateY( calc( var( --selected-top, 0 ) * 1px ) )\n\t\t\t\tscaleY(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tbackground-color: color-mix(\n\t\t\t\tin srgb,\n\t\t\t\t${ COLORS.theme.accent },\n\t\t\t\ttransparent 96%\n\t\t\t);\n\t\t}\n\t\t&[data-select-on-move='true']:has(\n\t\t\t\t:is( :focus-visible, [data-focus-visible] )\n\t\t\t)::before {\n\t\t\tbox-sizing: border-box;\n\t\t\tborder: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\t/* Adjusting the border width to match the scaling in the y axis. */\n\t\t\tborder-block-width: calc(\n\t\t\t\tvar( --wp-admin-border-width-focus, 1px ) /\n\t\t\t\t\t(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}\n`;\n\nexport const Tab = styled( Ariakit.Tab )`\n\t& {\n\t\t/* Resets */\n\t\tborder-radius: 0;\n\t\tbackground: transparent;\n\t\tborder: none;\n\t\tbox-shadow: none;\n\n\t\tflex: 1 0 auto;\n\t\twhite-space: nowrap;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcursor: pointer;\n\t\tline-height: 1.2; // Characters in some languages (e.g. Japanese) may have a native higher line-height.\n\t\tfont-weight: 400;\n\t\tfont-size: ${ font( 'default.fontSize' ) };\n\t\tcolor: ${ COLORS.theme.foreground };\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: default;\n\t\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\t}\n\n\t\t&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ) {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t}\n\n\t\t&:focus:not( :disabled ) {\n\t\t\tbox-shadow: none;\n\t\t\toutline: none;\n\t\t}\n\n\t\t// Focus indicator.\n\t\tposition: relative;\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tpointer-events: none;\n\n\t\t\t// Draw the indicator.\n\t\t\t// Outline works for Windows high contrast mode as well.\n\t\t\toutline: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\tborder-radius: ${ CONFIG.radiusSmall };\n\n\t\t\t// Animation\n\t\t\topacity: 0;\n\n\t\t\t@media not ( prefers-reduced-motion ) {\n\t\t\t\ttransition: opacity 0.1s linear;\n\t\t\t}\n\t\t}\n\n\t\t&[data-focus-visible]::after {\n\t\t\topacity: 1;\n\t\t}\n\t}\n\n\t[aria-orientation='horizontal'] & {\n\t\tpadding-inline: ${ space( 4 ) };\n\t\theight: ${ space( 12 ) };\n\t\tscroll-margin: 24px;\n\n\t\t&::after {\n\t\t\tcontent: '';\n\t\t\tinset: ${ space( 3 ) };\n\t\t}\n\t}\n\n\t[aria-orientation='vertical'] & {\n\t\tpadding: ${ space( 2 ) } ${ space( 3 ) };\n\t\tmin-height: ${ space( 10 ) };\n\n\t\t&[aria-selected='true'] {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t\tfill: currentColor;\n\t\t}\n\t}\n\t[aria-orientation='vertical'][data-select-on-move='false'] &::after {\n\t\tcontent: '';\n\t\tinset: var( --wp-admin-border-width-focus );\n\t}\n`;\n\nexport const TabChildren = styled.span`\n\tflex-grow: 1;\n\n\tdisplay: flex;\n\talign-items: center;\n\n\t[aria-orientation='horizontal'] & {\n\t\tjustify-content: center;\n\t}\n\t[aria-orientation='vertical'] & {\n\t\tjustify-content: start;\n\t}\n`;\n\nexport const TabChevron = styled( Icon )`\n\tflex-shrink: 0;\n\tmargin-inline-end: ${ space( -1 ) };\n\t[aria-orientation='horizontal'] & {\n\t\tdisplay: none;\n\t}\n\topacity: 0;\n\t[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) & {\n\t\topacity: 1;\n\t}\n\t// The chevron is transitioned into existence when selectOnMove is enabled,\n\t// because otherwise it looks jarring, as it shows up outside of the focus\n\t// indicator that's being animated at the same time.\n\t@media not ( prefers-reduced-motion ) {\n\t\t[data-select-on-move='true']\n\t\t\t[role='tab']:is( [aria-selected='true'],  )\n\t\t\t& {\n\t\t\ttransition: opacity 0.15s 0.15s linear;\n\t\t}\n\t}\n\t&:dir( rtl ) {\n\t\trotate: 180deg;\n\t}\n`;\n\nexport const TabPanel = styled( Ariakit.TabPanel )`\n\t&:focus {\n\t\tbox-shadow: none;\n\t\toutline: none;\n\t}\n\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 var( --wp-admin-border-width-focus )\n\t\t\t${ COLORS.theme.accent };\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: 0;\n\t}\n`;\n"]} */", 53219 toString: _EMOTION_STRINGIFIED_CSS_ERROR__43 53220 }); 53221 var TabChevron = /* @__PURE__ */ emotion_styled_base_browser_esm_default(icon_default3, false ? { 53222 target: "enfox0g1" 53223 } : { 53224 target: "enfox0g1", 53225 label: "TabChevron" 53226 })("flex-shrink:0;margin-inline-end:", space(-1), ";[aria-orientation='horizontal'] &{display:none;}opacity:0;[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) &{opacity:1;}@media not ( prefers-reduced-motion ){[data-select-on-move='true'] [role='tab']:is( [aria-selected='true'], ) &{transition:opacity 0.15s 0.15s linear;}}&:dir( rtl ){rotate:180deg;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAuPwC","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport * as Ariakit from '@ariakit/react';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG, font } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\n\nexport const StyledTabList = styled( Ariakit.TabList )`\n\tdisplay: flex;\n\talign-items: stretch;\n\toverflow-x: auto;\n\n\t&[aria-orientation='vertical'] {\n\t\tflex-direction: column;\n\t}\n\n\t:where( [aria-orientation='horizontal'] ) {\n\t\twidth: fit-content;\n\t}\n\n\t--direction-factor: 1;\n\t--direction-start: left;\n\t--direction-end: right;\n\t--selected-start: var( --selected-left, 0 );\n\t&:dir( rtl ) {\n\t\t--direction-factor: -1;\n\t\t--direction-start: right;\n\t\t--direction-end: left;\n\t\t--selected-start: var( --selected-right, 0 );\n\t}\n\n\t@media not ( prefers-reduced-motion ) {\n\t\t&[data-indicator-animated]::before {\n\t\t\ttransition-property: transform, border-radius, border-block;\n\t\t\ttransition-duration: 0.2s;\n\t\t\ttransition-timing-function: ease-out;\n\t\t}\n\t}\n\tposition: relative;\n\t&::before {\n\t\tcontent: '';\n\t\tposition: absolute;\n\t\tpointer-events: none;\n\t\ttransform-origin: var( --direction-start ) top;\n\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: -1px;\n\t}\n\n\t/* Using a large value to avoid antialiasing rounding issues\n\t\t\twhen scaling in the transform, see: https://stackoverflow.com/a/52159123 */\n\t--antialiasing-factor: 100;\n\t&[aria-orientation='horizontal'] {\n\t\t--fade-width: 64px;\n\t\t--fade-gradient-base: transparent 0%, black var( --fade-width );\n\t\t--fade-gradient-composed: var( --fade-gradient-base ), black 60%,\n\t\t\ttransparent 50%;\n\t\t&.is-overflowing-first {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-end ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-start ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-first.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\t\tto right,\n\t\t\t\t\tvar( --fade-gradient-composed )\n\t\t\t\t),\n\t\t\t\tlinear-gradient( to left, var( --fade-gradient-composed ) );\n\t\t}\n\n\t\t&::before {\n\t\t\tbottom: 0;\n\t\t\theight: 0;\n\t\t\twidth: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-start ) * var( --direction-factor ) *\n\t\t\t\t\t\t\t1px\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\tscaleX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-width, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tborder-bottom: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t}\n\t}\n\t&[aria-orientation='vertical'] {\n\t\t&::before {\n\t\t\t/* Adjusting the border radius to match the scaling in the y axis. */\n\t\t\tborder-radius: ${ CONFIG.radiusSmall } /\n\t\t\t\tcalc(\n\t\t\t\t\t${ CONFIG.radiusSmall } /\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t\t)\n\t\t\t\t);\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\twidth: 100%;\n\t\t\theight: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateY( calc( var( --selected-top, 0 ) * 1px ) )\n\t\t\t\tscaleY(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tbackground-color: color-mix(\n\t\t\t\tin srgb,\n\t\t\t\t${ COLORS.theme.accent },\n\t\t\t\ttransparent 96%\n\t\t\t);\n\t\t}\n\t\t&[data-select-on-move='true']:has(\n\t\t\t\t:is( :focus-visible, [data-focus-visible] )\n\t\t\t)::before {\n\t\t\tbox-sizing: border-box;\n\t\t\tborder: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\t/* Adjusting the border width to match the scaling in the y axis. */\n\t\t\tborder-block-width: calc(\n\t\t\t\tvar( --wp-admin-border-width-focus, 1px ) /\n\t\t\t\t\t(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}\n`;\n\nexport const Tab = styled( Ariakit.Tab )`\n\t& {\n\t\t/* Resets */\n\t\tborder-radius: 0;\n\t\tbackground: transparent;\n\t\tborder: none;\n\t\tbox-shadow: none;\n\n\t\tflex: 1 0 auto;\n\t\twhite-space: nowrap;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcursor: pointer;\n\t\tline-height: 1.2; // Characters in some languages (e.g. Japanese) may have a native higher line-height.\n\t\tfont-weight: 400;\n\t\tfont-size: ${ font( 'default.fontSize' ) };\n\t\tcolor: ${ COLORS.theme.foreground };\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: default;\n\t\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\t}\n\n\t\t&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ) {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t}\n\n\t\t&:focus:not( :disabled ) {\n\t\t\tbox-shadow: none;\n\t\t\toutline: none;\n\t\t}\n\n\t\t// Focus indicator.\n\t\tposition: relative;\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tpointer-events: none;\n\n\t\t\t// Draw the indicator.\n\t\t\t// Outline works for Windows high contrast mode as well.\n\t\t\toutline: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\tborder-radius: ${ CONFIG.radiusSmall };\n\n\t\t\t// Animation\n\t\t\topacity: 0;\n\n\t\t\t@media not ( prefers-reduced-motion ) {\n\t\t\t\ttransition: opacity 0.1s linear;\n\t\t\t}\n\t\t}\n\n\t\t&[data-focus-visible]::after {\n\t\t\topacity: 1;\n\t\t}\n\t}\n\n\t[aria-orientation='horizontal'] & {\n\t\tpadding-inline: ${ space( 4 ) };\n\t\theight: ${ space( 12 ) };\n\t\tscroll-margin: 24px;\n\n\t\t&::after {\n\t\t\tcontent: '';\n\t\t\tinset: ${ space( 3 ) };\n\t\t}\n\t}\n\n\t[aria-orientation='vertical'] & {\n\t\tpadding: ${ space( 2 ) } ${ space( 3 ) };\n\t\tmin-height: ${ space( 10 ) };\n\n\t\t&[aria-selected='true'] {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t\tfill: currentColor;\n\t\t}\n\t}\n\t[aria-orientation='vertical'][data-select-on-move='false'] &::after {\n\t\tcontent: '';\n\t\tinset: var( --wp-admin-border-width-focus );\n\t}\n`;\n\nexport const TabChildren = styled.span`\n\tflex-grow: 1;\n\n\tdisplay: flex;\n\talign-items: center;\n\n\t[aria-orientation='horizontal'] & {\n\t\tjustify-content: center;\n\t}\n\t[aria-orientation='vertical'] & {\n\t\tjustify-content: start;\n\t}\n`;\n\nexport const TabChevron = styled( Icon )`\n\tflex-shrink: 0;\n\tmargin-inline-end: ${ space( -1 ) };\n\t[aria-orientation='horizontal'] & {\n\t\tdisplay: none;\n\t}\n\topacity: 0;\n\t[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) & {\n\t\topacity: 1;\n\t}\n\t// The chevron is transitioned into existence when selectOnMove is enabled,\n\t// because otherwise it looks jarring, as it shows up outside of the focus\n\t// indicator that's being animated at the same time.\n\t@media not ( prefers-reduced-motion ) {\n\t\t[data-select-on-move='true']\n\t\t\t[role='tab']:is( [aria-selected='true'],  )\n\t\t\t& {\n\t\t\ttransition: opacity 0.15s 0.15s linear;\n\t\t}\n\t}\n\t&:dir( rtl ) {\n\t\trotate: 180deg;\n\t}\n`;\n\nexport const TabPanel = styled( Ariakit.TabPanel )`\n\t&:focus {\n\t\tbox-shadow: none;\n\t\toutline: none;\n\t}\n\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 var( --wp-admin-border-width-focus )\n\t\t\t${ COLORS.theme.accent };\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: 0;\n\t}\n`;\n"]} */")); 53227 var TabPanel23 = /* @__PURE__ */ emotion_styled_base_browser_esm_default(TabPanel, false ? { 53228 target: "enfox0g0" 53229 } : { 53230 target: "enfox0g0", 53231 label: "TabPanel" 53232 })("&:focus{box-shadow:none;outline:none;}&[data-focus-visible]{box-shadow:0 0 0 var( --wp-admin-border-width-focus ) ", COLORS.theme.accent, ";outline:2px solid transparent;outline-offset:0;}" + (false ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["styles.ts"],"names":[],"mappings":"AAgRkD","file":"styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport * as Ariakit from '@ariakit/react';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, CONFIG, font } from '../utils';\nimport { space } from '../utils/space';\nimport Icon from '../icon';\n\nexport const StyledTabList = styled( Ariakit.TabList )`\n\tdisplay: flex;\n\talign-items: stretch;\n\toverflow-x: auto;\n\n\t&[aria-orientation='vertical'] {\n\t\tflex-direction: column;\n\t}\n\n\t:where( [aria-orientation='horizontal'] ) {\n\t\twidth: fit-content;\n\t}\n\n\t--direction-factor: 1;\n\t--direction-start: left;\n\t--direction-end: right;\n\t--selected-start: var( --selected-left, 0 );\n\t&:dir( rtl ) {\n\t\t--direction-factor: -1;\n\t\t--direction-start: right;\n\t\t--direction-end: left;\n\t\t--selected-start: var( --selected-right, 0 );\n\t}\n\n\t@media not ( prefers-reduced-motion ) {\n\t\t&[data-indicator-animated]::before {\n\t\t\ttransition-property: transform, border-radius, border-block;\n\t\t\ttransition-duration: 0.2s;\n\t\t\ttransition-timing-function: ease-out;\n\t\t}\n\t}\n\tposition: relative;\n\t&::before {\n\t\tcontent: '';\n\t\tposition: absolute;\n\t\tpointer-events: none;\n\t\ttransform-origin: var( --direction-start ) top;\n\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: -1px;\n\t}\n\n\t/* Using a large value to avoid antialiasing rounding issues\n\t\t\twhen scaling in the transform, see: https://stackoverflow.com/a/52159123 */\n\t--antialiasing-factor: 100;\n\t&[aria-orientation='horizontal'] {\n\t\t--fade-width: 64px;\n\t\t--fade-gradient-base: transparent 0%, black var( --fade-width );\n\t\t--fade-gradient-composed: var( --fade-gradient-base ), black 60%,\n\t\t\ttransparent 50%;\n\t\t&.is-overflowing-first {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-end ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\tto var( --direction-start ),\n\t\t\t\tvar( --fade-gradient-base )\n\t\t\t);\n\t\t}\n\t\t&.is-overflowing-first.is-overflowing-last {\n\t\t\tmask-image: linear-gradient(\n\t\t\t\t\tto right,\n\t\t\t\t\tvar( --fade-gradient-composed )\n\t\t\t\t),\n\t\t\t\tlinear-gradient( to left, var( --fade-gradient-composed ) );\n\t\t}\n\n\t\t&::before {\n\t\t\tbottom: 0;\n\t\t\theight: 0;\n\t\t\twidth: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-start ) * var( --direction-factor ) *\n\t\t\t\t\t\t\t1px\n\t\t\t\t\t)\n\t\t\t\t)\n\t\t\t\tscaleX(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-width, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tborder-bottom: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t}\n\t}\n\t&[aria-orientation='vertical'] {\n\t\t&::before {\n\t\t\t/* Adjusting the border radius to match the scaling in the y axis. */\n\t\t\tborder-radius: ${ CONFIG.radiusSmall } /\n\t\t\t\tcalc(\n\t\t\t\t\t${ CONFIG.radiusSmall } /\n\t\t\t\t\t\t(\n\t\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t\t)\n\t\t\t\t);\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\twidth: 100%;\n\t\t\theight: calc( var( --antialiasing-factor ) * 1px );\n\t\t\ttransform: translateY( calc( var( --selected-top, 0 ) * 1px ) )\n\t\t\t\tscaleY(\n\t\t\t\t\tcalc(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\tbackground-color: color-mix(\n\t\t\t\tin srgb,\n\t\t\t\t${ COLORS.theme.accent },\n\t\t\t\ttransparent 96%\n\t\t\t);\n\t\t}\n\t\t&[data-select-on-move='true']:has(\n\t\t\t\t:is( :focus-visible, [data-focus-visible] )\n\t\t\t)::before {\n\t\t\tbox-sizing: border-box;\n\t\t\tborder: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\t/* Adjusting the border width to match the scaling in the y axis. */\n\t\t\tborder-block-width: calc(\n\t\t\t\tvar( --wp-admin-border-width-focus, 1px ) /\n\t\t\t\t\t(\n\t\t\t\t\t\tvar( --selected-height, 0 ) /\n\t\t\t\t\t\t\tvar( --antialiasing-factor )\n\t\t\t\t\t)\n\t\t\t);\n\t\t}\n\t}\n`;\n\nexport const Tab = styled( Ariakit.Tab )`\n\t& {\n\t\t/* Resets */\n\t\tborder-radius: 0;\n\t\tbackground: transparent;\n\t\tborder: none;\n\t\tbox-shadow: none;\n\n\t\tflex: 1 0 auto;\n\t\twhite-space: nowrap;\n\t\tdisplay: flex;\n\t\talign-items: center;\n\t\tcursor: pointer;\n\t\tline-height: 1.2; // Characters in some languages (e.g. Japanese) may have a native higher line-height.\n\t\tfont-weight: 400;\n\t\tfont-size: ${ font( 'default.fontSize' ) };\n\t\tcolor: ${ COLORS.theme.foreground };\n\n\t\t&[aria-disabled='true'] {\n\t\t\tcursor: default;\n\t\t\tcolor: ${ COLORS.ui.textDisabled };\n\t\t}\n\n\t\t&:not( [aria-disabled='true'] ):is( :hover, [data-focus-visible] ) {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t}\n\n\t\t&:focus:not( :disabled ) {\n\t\t\tbox-shadow: none;\n\t\t\toutline: none;\n\t\t}\n\n\t\t// Focus indicator.\n\t\tposition: relative;\n\t\t&::after {\n\t\t\tposition: absolute;\n\t\t\tpointer-events: none;\n\n\t\t\t// Draw the indicator.\n\t\t\t// Outline works for Windows high contrast mode as well.\n\t\t\toutline: var( --wp-admin-border-width-focus ) solid\n\t\t\t\t${ COLORS.theme.accent };\n\t\t\tborder-radius: ${ CONFIG.radiusSmall };\n\n\t\t\t// Animation\n\t\t\topacity: 0;\n\n\t\t\t@media not ( prefers-reduced-motion ) {\n\t\t\t\ttransition: opacity 0.1s linear;\n\t\t\t}\n\t\t}\n\n\t\t&[data-focus-visible]::after {\n\t\t\topacity: 1;\n\t\t}\n\t}\n\n\t[aria-orientation='horizontal'] & {\n\t\tpadding-inline: ${ space( 4 ) };\n\t\theight: ${ space( 12 ) };\n\t\tscroll-margin: 24px;\n\n\t\t&::after {\n\t\t\tcontent: '';\n\t\t\tinset: ${ space( 3 ) };\n\t\t}\n\t}\n\n\t[aria-orientation='vertical'] & {\n\t\tpadding: ${ space( 2 ) } ${ space( 3 ) };\n\t\tmin-height: ${ space( 10 ) };\n\n\t\t&[aria-selected='true'] {\n\t\t\tcolor: ${ COLORS.theme.accent };\n\t\t\tfill: currentColor;\n\t\t}\n\t}\n\t[aria-orientation='vertical'][data-select-on-move='false'] &::after {\n\t\tcontent: '';\n\t\tinset: var( --wp-admin-border-width-focus );\n\t}\n`;\n\nexport const TabChildren = styled.span`\n\tflex-grow: 1;\n\n\tdisplay: flex;\n\talign-items: center;\n\n\t[aria-orientation='horizontal'] & {\n\t\tjustify-content: center;\n\t}\n\t[aria-orientation='vertical'] & {\n\t\tjustify-content: start;\n\t}\n`;\n\nexport const TabChevron = styled( Icon )`\n\tflex-shrink: 0;\n\tmargin-inline-end: ${ space( -1 ) };\n\t[aria-orientation='horizontal'] & {\n\t\tdisplay: none;\n\t}\n\topacity: 0;\n\t[role='tab']:is( [aria-selected='true'], [data-focus-visible], :hover ) & {\n\t\topacity: 1;\n\t}\n\t// The chevron is transitioned into existence when selectOnMove is enabled,\n\t// because otherwise it looks jarring, as it shows up outside of the focus\n\t// indicator that's being animated at the same time.\n\t@media not ( prefers-reduced-motion ) {\n\t\t[data-select-on-move='true']\n\t\t\t[role='tab']:is( [aria-selected='true'],  )\n\t\t\t& {\n\t\t\ttransition: opacity 0.15s 0.15s linear;\n\t\t}\n\t}\n\t&:dir( rtl ) {\n\t\trotate: 180deg;\n\t}\n`;\n\nexport const TabPanel = styled( Ariakit.TabPanel )`\n\t&:focus {\n\t\tbox-shadow: none;\n\t\toutline: none;\n\t}\n\n\t&[data-focus-visible] {\n\t\tbox-shadow: 0 0 0 var( --wp-admin-border-width-focus )\n\t\t\t${ COLORS.theme.accent };\n\t\t// Windows high contrast mode.\n\t\toutline: 2px solid transparent;\n\t\toutline-offset: 0;\n\t}\n`;\n"]} */")); 53233 53234 // packages/components/build-module/tabs/tab.js 53235 var import_jsx_runtime314 = __toESM(require_jsx_runtime()); 53236 var Tab3 = (0, import_element238.forwardRef)(function Tab23({ 53237 children, 53238 tabId, 53239 disabled, 53240 render, 53241 ...otherProps 53242 }, ref) { 53243 var _useTabsContext; 53244 const { 53245 store, 53246 instanceId 53247 } = (_useTabsContext = useTabsContext()) !== null && _useTabsContext !== void 0 ? _useTabsContext : {}; 53248 if (!store) { 53249 true ? (0, import_warning12.default)("`Tabs.Tab` must be wrapped in a `Tabs` component.") : void 0; 53250 return null; 53251 } 53252 const instancedTabId = `$instanceId}-$tabId}`; 53253 return /* @__PURE__ */ (0, import_jsx_runtime314.jsxs)(Tab22, { 53254 ref, 53255 store, 53256 id: instancedTabId, 53257 disabled, 53258 render, 53259 ...otherProps, 53260 children: [/* @__PURE__ */ (0, import_jsx_runtime314.jsx)(TabChildren, { 53261 children 53262 }), /* @__PURE__ */ (0, import_jsx_runtime314.jsx)(TabChevron, { 53263 icon: chevron_right_default 53264 })] 53265 }); 53266 }); 53267 53268 // packages/components/build-module/tabs/tablist.js 53269 var import_warning13 = __toESM(require_warning()); 53270 var import_element240 = __toESM(require_element()); 53271 var import_compose86 = __toESM(require_compose()); 53272 53273 // packages/components/build-module/tabs/use-track-overflow.js 53274 var import_element239 = __toESM(require_element()); 53275 var import_compose85 = __toESM(require_compose()); 53276 function useTrackOverflow(parent, children) { 53277 const [first, setFirst] = (0, import_element239.useState)(false); 53278 const [last3, setLast] = (0, import_element239.useState)(false); 53279 const [observer, setObserver] = (0, import_element239.useState)(); 53280 const callback = (0, import_compose85.useEvent)((entries) => { 53281 for (const entry of entries) { 53282 if (entry.target === children.first) { 53283 setFirst(!entry.isIntersecting); 53284 } 53285 if (entry.target === children.last) { 53286 setLast(!entry.isIntersecting); 53287 } 53288 } 53289 }); 53290 (0, import_element239.useEffect)(() => { 53291 if (!parent || !window.IntersectionObserver) { 53292 return; 53293 } 53294 const newObserver = new IntersectionObserver(callback, { 53295 root: parent, 53296 threshold: 0.9 53297 }); 53298 setObserver(newObserver); 53299 return () => newObserver.disconnect(); 53300 }, [callback, parent]); 53301 (0, import_element239.useEffect)(() => { 53302 if (!observer) { 53303 return; 53304 } 53305 if (children.first) { 53306 observer.observe(children.first); 53307 } 53308 if (children.last) { 53309 observer.observe(children.last); 53310 } 53311 return () => { 53312 if (children.first) { 53313 observer.unobserve(children.first); 53314 } 53315 if (children.last) { 53316 observer.unobserve(children.last); 53317 } 53318 }; 53319 }, [children.first, children.last, observer]); 53320 return { 53321 first, 53322 last: last3 53323 }; 53324 } 53325 53326 // packages/components/build-module/tabs/tablist.js 53327 var import_jsx_runtime315 = __toESM(require_jsx_runtime()); 53328 var DEFAULT_SCROLL_MARGIN = 24; 53329 function useScrollRectIntoView(parent, rect, { 53330 margin = DEFAULT_SCROLL_MARGIN 53331 } = {}) { 53332 (0, import_element240.useLayoutEffect)(() => { 53333 if (!parent || !rect) { 53334 return; 53335 } 53336 const { 53337 scrollLeft: parentScroll 53338 } = parent; 53339 const parentWidth = parent.getBoundingClientRect().width; 53340 const { 53341 left: childLeft, 53342 width: childWidth 53343 } = rect; 53344 const parentRightEdge = parentScroll + parentWidth; 53345 const childRightEdge = childLeft + childWidth; 53346 const rightOverflow = childRightEdge + margin - parentRightEdge; 53347 const leftOverflow = parentScroll - (childLeft - margin); 53348 let scrollLeft = null; 53349 if (leftOverflow > 0) { 53350 scrollLeft = parentScroll - leftOverflow; 53351 } else if (rightOverflow > 0) { 53352 scrollLeft = parentScroll + rightOverflow; 53353 } 53354 if (scrollLeft !== null) { 53355 parent.scroll?.({ 53356 left: scrollLeft 53357 }); 53358 } 53359 }, [margin, parent, rect]); 53360 } 53361 var TabList3 = (0, import_element240.forwardRef)(function TabList22({ 53362 children, 53363 ...otherProps 53364 }, ref) { 53365 var _useTabsContext; 53366 const { 53367 store 53368 } = (_useTabsContext = useTabsContext()) !== null && _useTabsContext !== void 0 ? _useTabsContext : {}; 53369 const selectedId = useStoreState(store, "selectedId"); 53370 const activeId = useStoreState(store, "activeId"); 53371 const selectOnMove = useStoreState(store, "selectOnMove"); 53372 const items = useStoreState(store, "items"); 53373 const [parent, setParent] = (0, import_element240.useState)(); 53374 const refs = (0, import_compose86.useMergeRefs)([ref, setParent]); 53375 const selectedItem = store?.item(selectedId); 53376 const renderedItems = useStoreState(store, "renderedItems"); 53377 const selectedItemIndex = renderedItems && selectedItem ? renderedItems.indexOf(selectedItem) : -1; 53378 const selectedRect = useTrackElementOffsetRect(selectedItem?.element, [selectedItemIndex]); 53379 const overflow = useTrackOverflow(parent, { 53380 first: items?.at(0)?.element, 53381 last: items?.at(-1)?.element 53382 }); 53383 useAnimatedOffsetRect(parent, selectedRect, { 53384 prefix: "selected", 53385 dataAttribute: "indicator-animated", 53386 transitionEndFilter: (event) => event.pseudoElement === "::before", 53387 roundRect: true 53388 }); 53389 useScrollRectIntoView(parent, selectedRect); 53390 const onBlur = () => { 53391 if (!selectOnMove) { 53392 return; 53393 } 53394 if (selectedId !== activeId) { 53395 store?.setActiveId(selectedId); 53396 } 53397 }; 53398 if (!store) { 53399 true ? (0, import_warning13.default)("`Tabs.TabList` must be wrapped in a `Tabs` component.") : void 0; 53400 return null; 53401 } 53402 return /* @__PURE__ */ (0, import_jsx_runtime315.jsx)(StyledTabList, { 53403 ref: refs, 53404 store, 53405 render: (props) => { 53406 var _props$tabIndex; 53407 return /* @__PURE__ */ (0, import_jsx_runtime315.jsx)("div", { 53408 ...props, 53409 // Fallback to -1 to prevent browsers from making the tablist 53410 // tabbable when it is a scrolling container. 53411 tabIndex: (_props$tabIndex = props.tabIndex) !== null && _props$tabIndex !== void 0 ? _props$tabIndex : -1 53412 }); 53413 }, 53414 onBlur, 53415 "data-select-on-move": selectOnMove ? "true" : "false", 53416 ...otherProps, 53417 className: clsx_default(overflow.first && "is-overflowing-first", overflow.last && "is-overflowing-last", otherProps.className), 53418 children 53419 }); 53420 }); 53421 53422 // packages/components/build-module/tabs/tabpanel.js 53423 var import_element241 = __toESM(require_element()); 53424 var import_warning14 = __toESM(require_warning()); 53425 var import_jsx_runtime316 = __toESM(require_jsx_runtime()); 53426 var TabPanel3 = (0, import_element241.forwardRef)(function TabPanel24({ 53427 children, 53428 tabId, 53429 focusable = true, 53430 ...otherProps 53431 }, ref) { 53432 const context = useTabsContext(); 53433 const selectedId = useStoreState(context?.store, "selectedId"); 53434 if (!context) { 53435 true ? (0, import_warning14.default)("`Tabs.TabPanel` must be wrapped in a `Tabs` component.") : void 0; 53436 return null; 53437 } 53438 const { 53439 store, 53440 instanceId 53441 } = context; 53442 const instancedTabId = `$instanceId}-$tabId}`; 53443 return /* @__PURE__ */ (0, import_jsx_runtime316.jsx)(TabPanel23, { 53444 ref, 53445 store, 53446 id: `$instancedTabId}-view`, 53447 tabId: instancedTabId, 53448 focusable, 53449 ...otherProps, 53450 children: selectedId === instancedTabId && children 53451 }); 53452 }); 53453 53454 // packages/components/build-module/tabs/index.js 53455 var import_jsx_runtime317 = __toESM(require_jsx_runtime()); 53456 function externalToInternalTabId(externalId, instanceId) { 53457 return externalId && `$instanceId}-$externalId}`; 53458 } 53459 function internalToExternalTabId(internalId, instanceId) { 53460 return typeof internalId === "string" ? internalId.replace(`$instanceId}-`, "") : internalId; 53461 } 53462 var Tabs = Object.assign(function Tabs2({ 53463 selectOnMove = true, 53464 defaultTabId, 53465 orientation = "horizontal", 53466 onSelect, 53467 children, 53468 selectedTabId, 53469 activeTabId, 53470 defaultActiveTabId, 53471 onActiveTabIdChange 53472 }) { 53473 const instanceId = (0, import_compose87.useInstanceId)(Tabs2, "tabs"); 53474 const store = useTabStore({ 53475 selectOnMove, 53476 orientation, 53477 defaultSelectedId: externalToInternalTabId(defaultTabId, instanceId), 53478 setSelectedId: (newSelectedId) => { 53479 onSelect?.(internalToExternalTabId(newSelectedId, instanceId)); 53480 }, 53481 selectedId: externalToInternalTabId(selectedTabId, instanceId), 53482 defaultActiveId: externalToInternalTabId(defaultActiveTabId, instanceId), 53483 setActiveId: (newActiveId) => { 53484 onActiveTabIdChange?.(internalToExternalTabId(newActiveId, instanceId)); 53485 }, 53486 activeId: externalToInternalTabId(activeTabId, instanceId), 53487 rtl: (0, import_i18n80.isRTL)() 53488 }); 53489 const { 53490 items, 53491 activeId 53492 } = useStoreState(store); 53493 const { 53494 setActiveId 53495 } = store; 53496 (0, import_element242.useEffect)(() => { 53497 requestAnimationFrame(() => { 53498 const focusedElement = items?.[0]?.element?.ownerDocument.activeElement; 53499 if (!focusedElement || !items.some((item2) => focusedElement === item2.element)) { 53500 return; 53501 } 53502 if (activeId !== focusedElement.id) { 53503 setActiveId(focusedElement.id); 53504 } 53505 }); 53506 }, [activeId, items, setActiveId]); 53507 const contextValue = (0, import_element242.useMemo)(() => ({ 53508 store, 53509 instanceId 53510 }), [store, instanceId]); 53511 return /* @__PURE__ */ (0, import_jsx_runtime317.jsx)(TabsContext.Provider, { 53512 value: contextValue, 53513 children 53514 }); 53515 }, { 53516 /** 53517 * Renders a single tab. 53518 * 53519 * The currently active tab receives default styling that can be 53520 * overridden with CSS targeting `[aria-selected="true"]`. 53521 */ 53522 Tab: Object.assign(Tab3, { 53523 displayName: "Tabs.Tab" 53524 }), 53525 /** 53526 * A wrapper component for the `Tab` components. 53527 * 53528 * It is responsible for rendering the list of tabs. 53529 */ 53530 TabList: Object.assign(TabList3, { 53531 displayName: "Tabs.TabList" 53532 }), 53533 /** 53534 * Renders the content to display for a single tab once that tab is selected. 53535 */ 53536 TabPanel: Object.assign(TabPanel3, { 53537 displayName: "Tabs.TabPanel" 53538 }), 53539 Context: Object.assign(TabsContext, { 53540 displayName: "Tabs.Context" 53541 }) 53542 }); 53543 53544 // packages/components/build-module/lock-unlock.js 53545 var import_private_apis = __toESM(require_private_apis()); 53546 var { 53547 lock, 53548 unlock 53549 } = (0, import_private_apis.__dangerousOptInToUnstableAPIsOnlyForCoreModules)("I acknowledge private features are not for use in themes or plugins and doing so will break in the next version of WordPress.", "@wordpress/components"); 53550 53551 // packages/components/build-module/badge/index.js 53552 var import_jsx_runtime318 = __toESM(require_jsx_runtime()); 53553 function contextBasedIcon(intent = "default") { 53554 switch (intent) { 53555 case "info": 53556 return info_default; 53557 case "success": 53558 return published_default; 53559 case "warning": 53560 return caution_default; 53561 case "error": 53562 return error_default; 53563 default: 53564 return null; 53565 } 53566 } 53567 function Badge({ 53568 className: className2, 53569 intent = "default", 53570 children, 53571 ...props 53572 }) { 53573 const icon = contextBasedIcon(intent); 53574 const hasIcon = !!icon; 53575 return /* @__PURE__ */ (0, import_jsx_runtime318.jsx)("span", { 53576 className: clsx_default("components-badge", className2, { 53577 [`is-$intent}`]: intent, 53578 "has-icon": hasIcon 53579 }), 53580 ...props, 53581 children: /* @__PURE__ */ (0, import_jsx_runtime318.jsxs)("span", { 53582 className: "components-badge__flex-wrapper", 53583 children: [hasIcon && /* @__PURE__ */ (0, import_jsx_runtime318.jsx)(icon_default3, { 53584 icon, 53585 size: 16, 53586 fill: "currentColor", 53587 className: "components-badge__icon" 53588 }), /* @__PURE__ */ (0, import_jsx_runtime318.jsx)("span", { 53589 className: "components-badge__content", 53590 children 53591 })] 53592 }) 53593 }); 53594 } 53595 var badge_default = Badge; 53596 53597 // node_modules/react-day-picker/dist/esm/DayPicker.js 53598 var import_react165 = __toESM(require_react(), 1); 53599 53600 // node_modules/@date-fns/tz/constants/index.js 53601 var constructFromSymbol = Symbol.for("constructDateFrom"); 53602 53603 // node_modules/@date-fns/tz/tzOffset/index.js 53604 var offsetFormatCache = {}; 53605 var offsetCache = {}; 53606 function tzOffset(timeZone, date) { 53607 try { 53608 const format3 = offsetFormatCache[timeZone] ||= new Intl.DateTimeFormat("en-GB", { 53609 timeZone, 53610 hour: "numeric", 53611 timeZoneName: "longOffset" 53612 }).format; 53613 const offsetStr = format3(date).split("GMT")[1] || ""; 53614 if (offsetStr in offsetCache) return offsetCache[offsetStr]; 53615 return calcOffset(offsetStr, offsetStr.split(":")); 53616 } catch { 53617 if (timeZone in offsetCache) return offsetCache[timeZone]; 53618 const captures = timeZone?.match(offsetRe); 53619 if (captures) return calcOffset(timeZone, captures.slice(1)); 53620 return NaN; 53621 } 53622 } 53623 var offsetRe = /([+-]\d\d):?(\d\d)?/; 53624 function calcOffset(cacheStr, values) { 53625 const hours = +values[0]; 53626 const minutes = +(values[1] || 0); 53627 return offsetCache[cacheStr] = hours > 0 ? hours * 60 + minutes : hours * 60 - minutes; 53628 } 53629 53630 // node_modules/@date-fns/tz/date/mini.js 53631 var TZDateMini = class _TZDateMini extends Date { 53632 //#region static 53633 constructor(...args) { 53634 super(); 53635 if (args.length > 1 && typeof args[args.length - 1] === "string") { 53636 this.timeZone = args.pop(); 53637 } 53638 this.internal = /* @__PURE__ */ new Date(); 53639 if (isNaN(tzOffset(this.timeZone, this))) { 53640 this.setTime(NaN); 53641 } else { 53642 if (!args.length) { 53643 this.setTime(Date.now()); 53644 } else if (typeof args[0] === "number" && (args.length === 1 || args.length === 2 && typeof args[1] !== "number")) { 53645 this.setTime(args[0]); 53646 } else if (typeof args[0] === "string") { 53647 this.setTime(+new Date(args[0])); 53648 } else if (args[0] instanceof Date) { 53649 this.setTime(+args[0]); 53650 } else { 53651 this.setTime(+new Date(...args)); 53652 adjustToSystemTZ(this, NaN); 53653 syncToInternal(this); 53654 } 53655 } 53656 } 53657 static tz(tz, ...args) { 53658 return args.length ? new _TZDateMini(...args, tz) : new _TZDateMini(Date.now(), tz); 53659 } 53660 //#endregion 53661 //#region time zone 53662 withTimeZone(timeZone) { 53663 return new _TZDateMini(+this, timeZone); 53664 } 53665 getTimezoneOffset() { 53666 return -tzOffset(this.timeZone, this); 53667 } 53668 //#endregion 53669 //#region time 53670 setTime(time2) { 53671 Date.prototype.setTime.apply(this, arguments); 53672 syncToInternal(this); 53673 return +this; 53674 } 53675 //#endregion 53676 //#region date-fns integration 53677 [Symbol.for("constructDateFrom")](date) { 53678 return new _TZDateMini(+new Date(date), this.timeZone); 53679 } 53680 //#endregion 53681 }; 53682 var re2 = /^(get|set)(?!UTC)/; 53683 Object.getOwnPropertyNames(Date.prototype).forEach((method) => { 53684 if (!re2.test(method)) return; 53685 const utcMethod = method.replace(re2, "$1UTC"); 53686 if (!TZDateMini.prototype[utcMethod]) return; 53687 if (method.startsWith("get")) { 53688 TZDateMini.prototype[method] = function() { 53689 return this.internal[utcMethod](); 53690 }; 53691 } else { 53692 TZDateMini.prototype[method] = function() { 53693 Date.prototype[utcMethod].apply(this.internal, arguments); 53694 syncFromInternal(this); 53695 return +this; 53696 }; 53697 TZDateMini.prototype[utcMethod] = function() { 53698 Date.prototype[utcMethod].apply(this, arguments); 53699 syncToInternal(this); 53700 return +this; 53701 }; 53702 } 53703 }); 53704 function syncToInternal(date) { 53705 date.internal.setTime(+date); 53706 date.internal.setUTCMinutes(date.internal.getUTCMinutes() - date.getTimezoneOffset()); 53707 } 53708 function syncFromInternal(date) { 53709 Date.prototype.setFullYear.call(date, date.internal.getUTCFullYear(), date.internal.getUTCMonth(), date.internal.getUTCDate()); 53710 Date.prototype.setHours.call(date, date.internal.getUTCHours(), date.internal.getUTCMinutes(), date.internal.getUTCSeconds(), date.internal.getUTCMilliseconds()); 53711 adjustToSystemTZ(date); 53712 } 53713 function adjustToSystemTZ(date) { 53714 const offset3 = tzOffset(date.timeZone, date); 53715 const prevHour = /* @__PURE__ */ new Date(+date); 53716 prevHour.setUTCHours(prevHour.getUTCHours() - 1); 53717 const systemOffset = -(/* @__PURE__ */ new Date(+date)).getTimezoneOffset(); 53718 const prevHourSystemOffset = -(/* @__PURE__ */ new Date(+prevHour)).getTimezoneOffset(); 53719 const systemDSTChange = systemOffset - prevHourSystemOffset; 53720 const dstShift = Date.prototype.getHours.apply(date) !== date.internal.getUTCHours(); 53721 if (systemDSTChange && dstShift) date.internal.setUTCMinutes(date.internal.getUTCMinutes() + systemDSTChange); 53722 const offsetDiff = systemOffset - offset3; 53723 if (offsetDiff) Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + offsetDiff); 53724 const postOffset = tzOffset(date.timeZone, date); 53725 const postSystemOffset = -(/* @__PURE__ */ new Date(+date)).getTimezoneOffset(); 53726 const postOffsetDiff = postSystemOffset - postOffset; 53727 const offsetChanged = postOffset !== offset3; 53728 const postDiff = postOffsetDiff - offsetDiff; 53729 if (offsetChanged && postDiff) { 53730 Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + postDiff); 53731 const newOffset = tzOffset(date.timeZone, date); 53732 const offsetChange = postOffset - newOffset; 53733 if (offsetChange) { 53734 date.internal.setUTCMinutes(date.internal.getUTCMinutes() + offsetChange); 53735 Date.prototype.setUTCMinutes.call(date, Date.prototype.getUTCMinutes.call(date) + offsetChange); 53736 } 53737 } 53738 } 53739 53740 // node_modules/@date-fns/tz/date/index.js 53741 var TZDate = class _TZDate extends TZDateMini { 53742 //#region static 53743 static tz(tz, ...args) { 53744 return args.length ? new _TZDate(...args, tz) : new _TZDate(Date.now(), tz); 53745 } 53746 //#endregion 53747 //#region representation 53748 toISOString() { 53749 const [sign, hours, minutes] = this.tzComponents(); 53750 const tz = `$sign}$hours}:$minutes}`; 53751 return this.internal.toISOString().slice(0, -1) + tz; 53752 } 53753 toString() { 53754 return `$this.toDateString()} $this.toTimeString()}`; 53755 } 53756 toDateString() { 53757 const [day, date, month, year] = this.internal.toUTCString().split(" "); 53758 return `$day?.slice(0, -1)} $month} $date} $year}`; 53759 } 53760 toTimeString() { 53761 const time2 = this.internal.toUTCString().split(" ")[4]; 53762 const [sign, hours, minutes] = this.tzComponents(); 53763 return `$time2} GMT$sign}$hours}$minutes} ($tzName(this.timeZone, this)})`; 53764 } 53765 toLocaleString(locales, options2) { 53766 return Date.prototype.toLocaleString.call(this, locales, { 53767 ...options2, 53768 timeZone: options2?.timeZone || this.timeZone 53769 }); 53770 } 53771 toLocaleDateString(locales, options2) { 53772 return Date.prototype.toLocaleDateString.call(this, locales, { 53773 ...options2, 53774 timeZone: options2?.timeZone || this.timeZone 53775 }); 53776 } 53777 toLocaleTimeString(locales, options2) { 53778 return Date.prototype.toLocaleTimeString.call(this, locales, { 53779 ...options2, 53780 timeZone: options2?.timeZone || this.timeZone 53781 }); 53782 } 53783 //#endregion 53784 //#region private 53785 tzComponents() { 53786 const offset3 = this.getTimezoneOffset(); 53787 const sign = offset3 > 0 ? "-" : "+"; 53788 const hours = String(Math.floor(Math.abs(offset3) / 60)).padStart(2, "0"); 53789 const minutes = String(Math.abs(offset3) % 60).padStart(2, "0"); 53790 return [sign, hours, minutes]; 53791 } 53792 //#endregion 53793 withTimeZone(timeZone) { 53794 return new _TZDate(+this, timeZone); 53795 } 53796 //#region date-fns integration 53797 [Symbol.for("constructDateFrom")](date) { 53798 return new _TZDate(+new Date(date), this.timeZone); 53799 } 53800 //#endregion 53801 }; 53802 function tzName(tz, date) { 53803 return new Intl.DateTimeFormat("en-GB", { 53804 timeZone: tz, 53805 timeZoneName: "long" 53806 }).format(date).slice(12); 53807 } 53808 53809 // node_modules/react-day-picker/dist/esm/UI.js 53810 var UI2; 53811 (function(UI3) { 53812 UI3["Root"] = "root"; 53813 UI3["Chevron"] = "chevron"; 53814 UI3["Day"] = "day"; 53815 UI3["DayButton"] = "day_button"; 53816 UI3["CaptionLabel"] = "caption_label"; 53817 UI3["Dropdowns"] = "dropdowns"; 53818 UI3["Dropdown"] = "dropdown"; 53819 UI3["DropdownRoot"] = "dropdown_root"; 53820 UI3["Footer"] = "footer"; 53821 UI3["MonthGrid"] = "month_grid"; 53822 UI3["MonthCaption"] = "month_caption"; 53823 UI3["MonthsDropdown"] = "months_dropdown"; 53824 UI3["Month"] = "month"; 53825 UI3["Months"] = "months"; 53826 UI3["Nav"] = "nav"; 53827 UI3["NextMonthButton"] = "button_next"; 53828 UI3["PreviousMonthButton"] = "button_previous"; 53829 UI3["Week"] = "week"; 53830 UI3["Weeks"] = "weeks"; 53831 UI3["Weekday"] = "weekday"; 53832 UI3["Weekdays"] = "weekdays"; 53833 UI3["WeekNumber"] = "week_number"; 53834 UI3["WeekNumberHeader"] = "week_number_header"; 53835 UI3["YearsDropdown"] = "years_dropdown"; 53836 })(UI2 || (UI2 = {})); 53837 var DayFlag; 53838 (function(DayFlag2) { 53839 DayFlag2["disabled"] = "disabled"; 53840 DayFlag2["hidden"] = "hidden"; 53841 DayFlag2["outside"] = "outside"; 53842 DayFlag2["focused"] = "focused"; 53843 DayFlag2["today"] = "today"; 53844 })(DayFlag || (DayFlag = {})); 53845 var SelectionState; 53846 (function(SelectionState2) { 53847 SelectionState2["range_end"] = "range_end"; 53848 SelectionState2["range_middle"] = "range_middle"; 53849 SelectionState2["range_start"] = "range_start"; 53850 SelectionState2["selected"] = "selected"; 53851 })(SelectionState || (SelectionState = {})); 53852 var Animation; 53853 (function(Animation2) { 53854 Animation2["weeks_before_enter"] = "weeks_before_enter"; 53855 Animation2["weeks_before_exit"] = "weeks_before_exit"; 53856 Animation2["weeks_after_enter"] = "weeks_after_enter"; 53857 Animation2["weeks_after_exit"] = "weeks_after_exit"; 53858 Animation2["caption_after_enter"] = "caption_after_enter"; 53859 Animation2["caption_after_exit"] = "caption_after_exit"; 53860 Animation2["caption_before_enter"] = "caption_before_enter"; 53861 Animation2["caption_before_exit"] = "caption_before_exit"; 53862 })(Animation || (Animation = {})); 53863 53864 // node_modules/react-day-picker/node_modules/date-fns/constants.js 53865 var daysInYear2 = 365.2425; 53866 var maxTime2 = Math.pow(10, 8) * 24 * 60 * 60 * 1e3; 53867 var minTime2 = -maxTime2; 53868 var millisecondsInWeek2 = 6048e5; 53869 var millisecondsInDay2 = 864e5; 53870 var secondsInHour2 = 3600; 53871 var secondsInDay2 = secondsInHour2 * 24; 53872 var secondsInWeek2 = secondsInDay2 * 7; 53873 var secondsInYear2 = secondsInDay2 * daysInYear2; 53874 var secondsInMonth2 = secondsInYear2 / 12; 53875 var secondsInQuarter2 = secondsInMonth2 * 3; 53876 var constructFromSymbol2 = Symbol.for("constructDateFrom"); 53877 53878 // node_modules/react-day-picker/node_modules/date-fns/constructFrom.js 53879 function constructFrom2(date, value) { 53880 if (typeof date === "function") return date(value); 53881 if (date && typeof date === "object" && constructFromSymbol2 in date) 53882 return date[constructFromSymbol2](value); 53883 if (date instanceof Date) return new date.constructor(value); 53884 return new Date(value); 53885 } 53886 53887 // node_modules/react-day-picker/node_modules/date-fns/toDate.js 53888 function toDate2(argument, context) { 53889 return constructFrom2(context || argument, argument); 53890 } 53891 53892 // node_modules/react-day-picker/node_modules/date-fns/addDays.js 53893 function addDays2(date, amount, options2) { 53894 const _date = toDate2(date, options2?.in); 53895 if (isNaN(amount)) return constructFrom2(options2?.in || date, NaN); 53896 if (!amount) return _date; 53897 _date.setDate(_date.getDate() + amount); 53898 return _date; 53899 } 53900 53901 // node_modules/react-day-picker/node_modules/date-fns/addMonths.js 53902 function addMonths2(date, amount, options2) { 53903 const _date = toDate2(date, options2?.in); 53904 if (isNaN(amount)) return constructFrom2(options2?.in || date, NaN); 53905 if (!amount) { 53906 return _date; 53907 } 53908 const dayOfMonth = _date.getDate(); 53909 const endOfDesiredMonth = constructFrom2(options2?.in || date, _date.getTime()); 53910 endOfDesiredMonth.setMonth(_date.getMonth() + amount + 1, 0); 53911 const daysInMonth = endOfDesiredMonth.getDate(); 53912 if (dayOfMonth >= daysInMonth) { 53913 return endOfDesiredMonth; 53914 } else { 53915 _date.setFullYear( 53916 endOfDesiredMonth.getFullYear(), 53917 endOfDesiredMonth.getMonth(), 53918 dayOfMonth 53919 ); 53920 return _date; 53921 } 53922 } 53923 53924 // node_modules/react-day-picker/node_modules/date-fns/_lib/defaultOptions.js 53925 var defaultOptions3 = {}; 53926 function getDefaultOptions2() { 53927 return defaultOptions3; 53928 } 53929 53930 // node_modules/react-day-picker/node_modules/date-fns/startOfWeek.js 53931 function startOfWeek2(date, options2) { 53932 const defaultOptions4 = getDefaultOptions2(); 53933 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 53934 const _date = toDate2(date, options2?.in); 53935 const day = _date.getDay(); 53936 const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn; 53937 _date.setDate(_date.getDate() - diff); 53938 _date.setHours(0, 0, 0, 0); 53939 return _date; 53940 } 53941 53942 // node_modules/react-day-picker/node_modules/date-fns/startOfISOWeek.js 53943 function startOfISOWeek2(date, options2) { 53944 return startOfWeek2(date, { ...options2, weekStartsOn: 1 }); 53945 } 53946 53947 // node_modules/react-day-picker/node_modules/date-fns/getISOWeekYear.js 53948 function getISOWeekYear2(date, options2) { 53949 const _date = toDate2(date, options2?.in); 53950 const year = _date.getFullYear(); 53951 const fourthOfJanuaryOfNextYear = constructFrom2(_date, 0); 53952 fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4); 53953 fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0); 53954 const startOfNextYear = startOfISOWeek2(fourthOfJanuaryOfNextYear); 53955 const fourthOfJanuaryOfThisYear = constructFrom2(_date, 0); 53956 fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4); 53957 fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0); 53958 const startOfThisYear = startOfISOWeek2(fourthOfJanuaryOfThisYear); 53959 if (_date.getTime() >= startOfNextYear.getTime()) { 53960 return year + 1; 53961 } else if (_date.getTime() >= startOfThisYear.getTime()) { 53962 return year; 53963 } else { 53964 return year - 1; 53965 } 53966 } 53967 53968 // node_modules/react-day-picker/node_modules/date-fns/_lib/getTimezoneOffsetInMilliseconds.js 53969 function getTimezoneOffsetInMilliseconds2(date) { 53970 const _date = toDate2(date); 53971 const utcDate = new Date( 53972 Date.UTC( 53973 _date.getFullYear(), 53974 _date.getMonth(), 53975 _date.getDate(), 53976 _date.getHours(), 53977 _date.getMinutes(), 53978 _date.getSeconds(), 53979 _date.getMilliseconds() 53980 ) 53981 ); 53982 utcDate.setUTCFullYear(_date.getFullYear()); 53983 return +date - +utcDate; 53984 } 53985 53986 // node_modules/react-day-picker/node_modules/date-fns/_lib/normalizeDates.js 53987 function normalizeDates(context, ...dates) { 53988 const normalize2 = constructFrom2.bind( 53989 null, 53990 context || dates.find((date) => typeof date === "object") 53991 ); 53992 return dates.map(normalize2); 53993 } 53994 53995 // node_modules/react-day-picker/node_modules/date-fns/startOfDay.js 53996 function startOfDay2(date, options2) { 53997 const _date = toDate2(date, options2?.in); 53998 _date.setHours(0, 0, 0, 0); 53999 return _date; 54000 } 54001 54002 // node_modules/react-day-picker/node_modules/date-fns/differenceInCalendarDays.js 54003 function differenceInCalendarDays2(laterDate, earlierDate, options2) { 54004 const [laterDate_, earlierDate_] = normalizeDates( 54005 options2?.in, 54006 laterDate, 54007 earlierDate 54008 ); 54009 const laterStartOfDay = startOfDay2(laterDate_); 54010 const earlierStartOfDay = startOfDay2(earlierDate_); 54011 const laterTimestamp = +laterStartOfDay - getTimezoneOffsetInMilliseconds2(laterStartOfDay); 54012 const earlierTimestamp = +earlierStartOfDay - getTimezoneOffsetInMilliseconds2(earlierStartOfDay); 54013 return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay2); 54014 } 54015 54016 // node_modules/react-day-picker/node_modules/date-fns/startOfISOWeekYear.js 54017 function startOfISOWeekYear2(date, options2) { 54018 const year = getISOWeekYear2(date, options2); 54019 const fourthOfJanuary = constructFrom2(options2?.in || date, 0); 54020 fourthOfJanuary.setFullYear(year, 0, 4); 54021 fourthOfJanuary.setHours(0, 0, 0, 0); 54022 return startOfISOWeek2(fourthOfJanuary); 54023 } 54024 54025 // node_modules/react-day-picker/node_modules/date-fns/addWeeks.js 54026 function addWeeks2(date, amount, options2) { 54027 return addDays2(date, amount * 7, options2); 54028 } 54029 54030 // node_modules/react-day-picker/node_modules/date-fns/addYears.js 54031 function addYears2(date, amount, options2) { 54032 return addMonths2(date, amount * 12, options2); 54033 } 54034 54035 // node_modules/react-day-picker/node_modules/date-fns/max.js 54036 function max2(dates, options2) { 54037 let result; 54038 let context = options2?.in; 54039 dates.forEach((date) => { 54040 if (!context && typeof date === "object") 54041 context = constructFrom2.bind(null, date); 54042 const date_ = toDate2(date, context); 54043 if (!result || result < date_ || isNaN(+date_)) result = date_; 54044 }); 54045 return constructFrom2(context, result || NaN); 54046 } 54047 54048 // node_modules/react-day-picker/node_modules/date-fns/min.js 54049 function min2(dates, options2) { 54050 let result; 54051 let context = options2?.in; 54052 dates.forEach((date) => { 54053 if (!context && typeof date === "object") 54054 context = constructFrom2.bind(null, date); 54055 const date_ = toDate2(date, context); 54056 if (!result || result > date_ || isNaN(+date_)) result = date_; 54057 }); 54058 return constructFrom2(context, result || NaN); 54059 } 54060 54061 // node_modules/react-day-picker/node_modules/date-fns/isSameDay.js 54062 function isSameDay2(laterDate, earlierDate, options2) { 54063 const [dateLeft_, dateRight_] = normalizeDates( 54064 options2?.in, 54065 laterDate, 54066 earlierDate 54067 ); 54068 return +startOfDay2(dateLeft_) === +startOfDay2(dateRight_); 54069 } 54070 54071 // node_modules/react-day-picker/node_modules/date-fns/isDate.js 54072 function isDate2(value) { 54073 return value instanceof Date || typeof value === "object" && Object.prototype.toString.call(value) === "[object Date]"; 54074 } 54075 54076 // node_modules/react-day-picker/node_modules/date-fns/isValid.js 54077 function isValid2(date) { 54078 return !(!isDate2(date) && typeof date !== "number" || isNaN(+toDate2(date))); 54079 } 54080 54081 // node_modules/react-day-picker/node_modules/date-fns/differenceInCalendarMonths.js 54082 function differenceInCalendarMonths(laterDate, earlierDate, options2) { 54083 const [laterDate_, earlierDate_] = normalizeDates( 54084 options2?.in, 54085 laterDate, 54086 earlierDate 54087 ); 54088 const yearsDiff = laterDate_.getFullYear() - earlierDate_.getFullYear(); 54089 const monthsDiff = laterDate_.getMonth() - earlierDate_.getMonth(); 54090 return yearsDiff * 12 + monthsDiff; 54091 } 54092 54093 // node_modules/react-day-picker/node_modules/date-fns/endOfMonth.js 54094 function endOfMonth2(date, options2) { 54095 const _date = toDate2(date, options2?.in); 54096 const month = _date.getMonth(); 54097 _date.setFullYear(_date.getFullYear(), month + 1, 0); 54098 _date.setHours(23, 59, 59, 999); 54099 return _date; 54100 } 54101 54102 // node_modules/react-day-picker/node_modules/date-fns/_lib/normalizeInterval.js 54103 function normalizeInterval(context, interval) { 54104 const [start, end] = normalizeDates(context, interval.start, interval.end); 54105 return { start, end }; 54106 } 54107 54108 // node_modules/react-day-picker/node_modules/date-fns/eachMonthOfInterval.js 54109 function eachMonthOfInterval2(interval, options2) { 54110 const { start, end } = normalizeInterval(options2?.in, interval); 54111 let reversed = +start > +end; 54112 const endTime = reversed ? +start : +end; 54113 const date = reversed ? end : start; 54114 date.setHours(0, 0, 0, 0); 54115 date.setDate(1); 54116 let step = options2?.step ?? 1; 54117 if (!step) return []; 54118 if (step < 0) { 54119 step = -step; 54120 reversed = !reversed; 54121 } 54122 const dates = []; 54123 while (+date <= endTime) { 54124 dates.push(constructFrom2(start, date)); 54125 date.setMonth(date.getMonth() + step); 54126 } 54127 return reversed ? dates.reverse() : dates; 54128 } 54129 54130 // node_modules/react-day-picker/node_modules/date-fns/startOfMonth.js 54131 function startOfMonth2(date, options2) { 54132 const _date = toDate2(date, options2?.in); 54133 _date.setDate(1); 54134 _date.setHours(0, 0, 0, 0); 54135 return _date; 54136 } 54137 54138 // node_modules/react-day-picker/node_modules/date-fns/endOfYear.js 54139 function endOfYear(date, options2) { 54140 const _date = toDate2(date, options2?.in); 54141 const year = _date.getFullYear(); 54142 _date.setFullYear(year + 1, 0, 0); 54143 _date.setHours(23, 59, 59, 999); 54144 return _date; 54145 } 54146 54147 // node_modules/react-day-picker/node_modules/date-fns/startOfYear.js 54148 function startOfYear2(date, options2) { 54149 const date_ = toDate2(date, options2?.in); 54150 date_.setFullYear(date_.getFullYear(), 0, 1); 54151 date_.setHours(0, 0, 0, 0); 54152 return date_; 54153 } 54154 54155 // node_modules/react-day-picker/node_modules/date-fns/endOfWeek.js 54156 function endOfWeek2(date, options2) { 54157 const defaultOptions4 = getDefaultOptions2(); 54158 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 54159 const _date = toDate2(date, options2?.in); 54160 const day = _date.getDay(); 54161 const diff = (day < weekStartsOn ? -7 : 0) + 6 - (day - weekStartsOn); 54162 _date.setDate(_date.getDate() + diff); 54163 _date.setHours(23, 59, 59, 999); 54164 return _date; 54165 } 54166 54167 // node_modules/react-day-picker/node_modules/date-fns/endOfISOWeek.js 54168 function endOfISOWeek(date, options2) { 54169 return endOfWeek2(date, { ...options2, weekStartsOn: 1 }); 54170 } 54171 54172 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatDistance.js 54173 var formatDistanceLocale2 = { 54174 lessThanXSeconds: { 54175 one: "less than a second", 54176 other: "less than {{count}} seconds" 54177 }, 54178 xSeconds: { 54179 one: "1 second", 54180 other: "{{count}} seconds" 54181 }, 54182 halfAMinute: "half a minute", 54183 lessThanXMinutes: { 54184 one: "less than a minute", 54185 other: "less than {{count}} minutes" 54186 }, 54187 xMinutes: { 54188 one: "1 minute", 54189 other: "{{count}} minutes" 54190 }, 54191 aboutXHours: { 54192 one: "about 1 hour", 54193 other: "about {{count}} hours" 54194 }, 54195 xHours: { 54196 one: "1 hour", 54197 other: "{{count}} hours" 54198 }, 54199 xDays: { 54200 one: "1 day", 54201 other: "{{count}} days" 54202 }, 54203 aboutXWeeks: { 54204 one: "about 1 week", 54205 other: "about {{count}} weeks" 54206 }, 54207 xWeeks: { 54208 one: "1 week", 54209 other: "{{count}} weeks" 54210 }, 54211 aboutXMonths: { 54212 one: "about 1 month", 54213 other: "about {{count}} months" 54214 }, 54215 xMonths: { 54216 one: "1 month", 54217 other: "{{count}} months" 54218 }, 54219 aboutXYears: { 54220 one: "about 1 year", 54221 other: "about {{count}} years" 54222 }, 54223 xYears: { 54224 one: "1 year", 54225 other: "{{count}} years" 54226 }, 54227 overXYears: { 54228 one: "over 1 year", 54229 other: "over {{count}} years" 54230 }, 54231 almostXYears: { 54232 one: "almost 1 year", 54233 other: "almost {{count}} years" 54234 } 54235 }; 54236 var formatDistance2 = (token2, count, options2) => { 54237 let result; 54238 const tokenValue = formatDistanceLocale2[token2]; 54239 if (typeof tokenValue === "string") { 54240 result = tokenValue; 54241 } else if (count === 1) { 54242 result = tokenValue.one; 54243 } else { 54244 result = tokenValue.other.replace("{{count}}", count.toString()); 54245 } 54246 if (options2?.addSuffix) { 54247 if (options2.comparison && options2.comparison > 0) { 54248 return "in " + result; 54249 } else { 54250 return result + " ago"; 54251 } 54252 } 54253 return result; 54254 }; 54255 54256 // node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildFormatLongFn.js 54257 function buildFormatLongFn2(args) { 54258 return (options2 = {}) => { 54259 const width = options2.width ? String(options2.width) : args.defaultWidth; 54260 const format3 = args.formats[width] || args.formats[args.defaultWidth]; 54261 return format3; 54262 }; 54263 } 54264 54265 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatLong.js 54266 var dateFormats2 = { 54267 full: "EEEE, MMMM do, y", 54268 long: "MMMM do, y", 54269 medium: "MMM d, y", 54270 short: "MM/dd/yyyy" 54271 }; 54272 var timeFormats2 = { 54273 full: "h:mm:ss a zzzz", 54274 long: "h:mm:ss a z", 54275 medium: "h:mm:ss a", 54276 short: "h:mm a" 54277 }; 54278 var dateTimeFormats2 = { 54279 full: "{{date}} 'at' {{time}}", 54280 long: "{{date}} 'at' {{time}}", 54281 medium: "{{date}}, {{time}}", 54282 short: "{{date}}, {{time}}" 54283 }; 54284 var formatLong2 = { 54285 date: buildFormatLongFn2({ 54286 formats: dateFormats2, 54287 defaultWidth: "full" 54288 }), 54289 time: buildFormatLongFn2({ 54290 formats: timeFormats2, 54291 defaultWidth: "full" 54292 }), 54293 dateTime: buildFormatLongFn2({ 54294 formats: dateTimeFormats2, 54295 defaultWidth: "full" 54296 }) 54297 }; 54298 54299 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/formatRelative.js 54300 var formatRelativeLocale2 = { 54301 lastWeek: "'last' eeee 'at' p", 54302 yesterday: "'yesterday at' p", 54303 today: "'today at' p", 54304 tomorrow: "'tomorrow at' p", 54305 nextWeek: "eeee 'at' p", 54306 other: "P" 54307 }; 54308 var formatRelative2 = (token2, _date, _baseDate, _options) => formatRelativeLocale2[token2]; 54309 54310 // node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildLocalizeFn.js 54311 function buildLocalizeFn2(args) { 54312 return (value, options2) => { 54313 const context = options2?.context ? String(options2.context) : "standalone"; 54314 let valuesArray; 54315 if (context === "formatting" && args.formattingValues) { 54316 const defaultWidth = args.defaultFormattingWidth || args.defaultWidth; 54317 const width = options2?.width ? String(options2.width) : defaultWidth; 54318 valuesArray = args.formattingValues[width] || args.formattingValues[defaultWidth]; 54319 } else { 54320 const defaultWidth = args.defaultWidth; 54321 const width = options2?.width ? String(options2.width) : args.defaultWidth; 54322 valuesArray = args.values[width] || args.values[defaultWidth]; 54323 } 54324 const index2 = args.argumentCallback ? args.argumentCallback(value) : value; 54325 return valuesArray[index2]; 54326 }; 54327 } 54328 54329 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/localize.js 54330 var eraValues2 = { 54331 narrow: ["B", "A"], 54332 abbreviated: ["BC", "AD"], 54333 wide: ["Before Christ", "Anno Domini"] 54334 }; 54335 var quarterValues2 = { 54336 narrow: ["1", "2", "3", "4"], 54337 abbreviated: ["Q1", "Q2", "Q3", "Q4"], 54338 wide: ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"] 54339 }; 54340 var monthValues2 = { 54341 narrow: ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"], 54342 abbreviated: [ 54343 "Jan", 54344 "Feb", 54345 "Mar", 54346 "Apr", 54347 "May", 54348 "Jun", 54349 "Jul", 54350 "Aug", 54351 "Sep", 54352 "Oct", 54353 "Nov", 54354 "Dec" 54355 ], 54356 wide: [ 54357 "January", 54358 "February", 54359 "March", 54360 "April", 54361 "May", 54362 "June", 54363 "July", 54364 "August", 54365 "September", 54366 "October", 54367 "November", 54368 "December" 54369 ] 54370 }; 54371 var dayValues2 = { 54372 narrow: ["S", "M", "T", "W", "T", "F", "S"], 54373 short: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"], 54374 abbreviated: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], 54375 wide: [ 54376 "Sunday", 54377 "Monday", 54378 "Tuesday", 54379 "Wednesday", 54380 "Thursday", 54381 "Friday", 54382 "Saturday" 54383 ] 54384 }; 54385 var dayPeriodValues2 = { 54386 narrow: { 54387 am: "a", 54388 pm: "p", 54389 midnight: "mi", 54390 noon: "n", 54391 morning: "morning", 54392 afternoon: "afternoon", 54393 evening: "evening", 54394 night: "night" 54395 }, 54396 abbreviated: { 54397 am: "AM", 54398 pm: "PM", 54399 midnight: "midnight", 54400 noon: "noon", 54401 morning: "morning", 54402 afternoon: "afternoon", 54403 evening: "evening", 54404 night: "night" 54405 }, 54406 wide: { 54407 am: "a.m.", 54408 pm: "p.m.", 54409 midnight: "midnight", 54410 noon: "noon", 54411 morning: "morning", 54412 afternoon: "afternoon", 54413 evening: "evening", 54414 night: "night" 54415 } 54416 }; 54417 var formattingDayPeriodValues2 = { 54418 narrow: { 54419 am: "a", 54420 pm: "p", 54421 midnight: "mi", 54422 noon: "n", 54423 morning: "in the morning", 54424 afternoon: "in the afternoon", 54425 evening: "in the evening", 54426 night: "at night" 54427 }, 54428 abbreviated: { 54429 am: "AM", 54430 pm: "PM", 54431 midnight: "midnight", 54432 noon: "noon", 54433 morning: "in the morning", 54434 afternoon: "in the afternoon", 54435 evening: "in the evening", 54436 night: "at night" 54437 }, 54438 wide: { 54439 am: "a.m.", 54440 pm: "p.m.", 54441 midnight: "midnight", 54442 noon: "noon", 54443 morning: "in the morning", 54444 afternoon: "in the afternoon", 54445 evening: "in the evening", 54446 night: "at night" 54447 } 54448 }; 54449 var ordinalNumber2 = (dirtyNumber, _options) => { 54450 const number2 = Number(dirtyNumber); 54451 const rem100 = number2 % 100; 54452 if (rem100 > 20 || rem100 < 10) { 54453 switch (rem100 % 10) { 54454 case 1: 54455 return number2 + "st"; 54456 case 2: 54457 return number2 + "nd"; 54458 case 3: 54459 return number2 + "rd"; 54460 } 54461 } 54462 return number2 + "th"; 54463 }; 54464 var localize2 = { 54465 ordinalNumber: ordinalNumber2, 54466 era: buildLocalizeFn2({ 54467 values: eraValues2, 54468 defaultWidth: "wide" 54469 }), 54470 quarter: buildLocalizeFn2({ 54471 values: quarterValues2, 54472 defaultWidth: "wide", 54473 argumentCallback: (quarter) => quarter - 1 54474 }), 54475 month: buildLocalizeFn2({ 54476 values: monthValues2, 54477 defaultWidth: "wide" 54478 }), 54479 day: buildLocalizeFn2({ 54480 values: dayValues2, 54481 defaultWidth: "wide" 54482 }), 54483 dayPeriod: buildLocalizeFn2({ 54484 values: dayPeriodValues2, 54485 defaultWidth: "wide", 54486 formattingValues: formattingDayPeriodValues2, 54487 defaultFormattingWidth: "wide" 54488 }) 54489 }; 54490 54491 // node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildMatchFn.js 54492 function buildMatchFn2(args) { 54493 return (string, options2 = {}) => { 54494 const width = options2.width; 54495 const matchPattern = width && args.matchPatterns[width] || args.matchPatterns[args.defaultMatchWidth]; 54496 const matchResult = string.match(matchPattern); 54497 if (!matchResult) { 54498 return null; 54499 } 54500 const matchedString = matchResult[0]; 54501 const parsePatterns = width && args.parsePatterns[width] || args.parsePatterns[args.defaultParseWidth]; 54502 const key = Array.isArray(parsePatterns) ? findIndex2(parsePatterns, (pattern) => pattern.test(matchedString)) : ( 54503 // [TODO] -- I challenge you to fix the type 54504 findKey2(parsePatterns, (pattern) => pattern.test(matchedString)) 54505 ); 54506 let value; 54507 value = args.valueCallback ? args.valueCallback(key) : key; 54508 value = options2.valueCallback ? ( 54509 // [TODO] -- I challenge you to fix the type 54510 options2.valueCallback(value) 54511 ) : value; 54512 const rest = string.slice(matchedString.length); 54513 return { value, rest }; 54514 }; 54515 } 54516 function findKey2(object, predicate) { 54517 for (const key in object) { 54518 if (Object.prototype.hasOwnProperty.call(object, key) && predicate(object[key])) { 54519 return key; 54520 } 54521 } 54522 return void 0; 54523 } 54524 function findIndex2(array, predicate) { 54525 for (let key = 0; key < array.length; key++) { 54526 if (predicate(array[key])) { 54527 return key; 54528 } 54529 } 54530 return void 0; 54531 } 54532 54533 // node_modules/react-day-picker/node_modules/date-fns/locale/_lib/buildMatchPatternFn.js 54534 function buildMatchPatternFn2(args) { 54535 return (string, options2 = {}) => { 54536 const matchResult = string.match(args.matchPattern); 54537 if (!matchResult) return null; 54538 const matchedString = matchResult[0]; 54539 const parseResult = string.match(args.parsePattern); 54540 if (!parseResult) return null; 54541 let value = args.valueCallback ? args.valueCallback(parseResult[0]) : parseResult[0]; 54542 value = options2.valueCallback ? options2.valueCallback(value) : value; 54543 const rest = string.slice(matchedString.length); 54544 return { value, rest }; 54545 }; 54546 } 54547 54548 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US/_lib/match.js 54549 var matchOrdinalNumberPattern2 = /^(\d+)(th|st|nd|rd)?/i; 54550 var parseOrdinalNumberPattern2 = /\d+/i; 54551 var matchEraPatterns2 = { 54552 narrow: /^(b|a)/i, 54553 abbreviated: /^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i, 54554 wide: /^(before christ|before common era|anno domini|common era)/i 54555 }; 54556 var parseEraPatterns2 = { 54557 any: [/^b/i, /^(a|c)/i] 54558 }; 54559 var matchQuarterPatterns2 = { 54560 narrow: /^[1234]/i, 54561 abbreviated: /^q[1234]/i, 54562 wide: /^[1234](th|st|nd|rd)? quarter/i 54563 }; 54564 var parseQuarterPatterns2 = { 54565 any: [/1/i, /2/i, /3/i, /4/i] 54566 }; 54567 var matchMonthPatterns2 = { 54568 narrow: /^[jfmasond]/i, 54569 abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i, 54570 wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i 54571 }; 54572 var parseMonthPatterns2 = { 54573 narrow: [ 54574 /^j/i, 54575 /^f/i, 54576 /^m/i, 54577 /^a/i, 54578 /^m/i, 54579 /^j/i, 54580 /^j/i, 54581 /^a/i, 54582 /^s/i, 54583 /^o/i, 54584 /^n/i, 54585 /^d/i 54586 ], 54587 any: [ 54588 /^ja/i, 54589 /^f/i, 54590 /^mar/i, 54591 /^ap/i, 54592 /^may/i, 54593 /^jun/i, 54594 /^jul/i, 54595 /^au/i, 54596 /^s/i, 54597 /^o/i, 54598 /^n/i, 54599 /^d/i 54600 ] 54601 }; 54602 var matchDayPatterns2 = { 54603 narrow: /^[smtwf]/i, 54604 short: /^(su|mo|tu|we|th|fr|sa)/i, 54605 abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i, 54606 wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i 54607 }; 54608 var parseDayPatterns2 = { 54609 narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i], 54610 any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i] 54611 }; 54612 var matchDayPeriodPatterns2 = { 54613 narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i, 54614 any: /^([ap]\.?\s?m\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i 54615 }; 54616 var parseDayPeriodPatterns2 = { 54617 any: { 54618 am: /^a/i, 54619 pm: /^p/i, 54620 midnight: /^mi/i, 54621 noon: /^no/i, 54622 morning: /morning/i, 54623 afternoon: /afternoon/i, 54624 evening: /evening/i, 54625 night: /night/i 54626 } 54627 }; 54628 var match4 = { 54629 ordinalNumber: buildMatchPatternFn2({ 54630 matchPattern: matchOrdinalNumberPattern2, 54631 parsePattern: parseOrdinalNumberPattern2, 54632 valueCallback: (value) => parseInt(value, 10) 54633 }), 54634 era: buildMatchFn2({ 54635 matchPatterns: matchEraPatterns2, 54636 defaultMatchWidth: "wide", 54637 parsePatterns: parseEraPatterns2, 54638 defaultParseWidth: "any" 54639 }), 54640 quarter: buildMatchFn2({ 54641 matchPatterns: matchQuarterPatterns2, 54642 defaultMatchWidth: "wide", 54643 parsePatterns: parseQuarterPatterns2, 54644 defaultParseWidth: "any", 54645 valueCallback: (index2) => index2 + 1 54646 }), 54647 month: buildMatchFn2({ 54648 matchPatterns: matchMonthPatterns2, 54649 defaultMatchWidth: "wide", 54650 parsePatterns: parseMonthPatterns2, 54651 defaultParseWidth: "any" 54652 }), 54653 day: buildMatchFn2({ 54654 matchPatterns: matchDayPatterns2, 54655 defaultMatchWidth: "wide", 54656 parsePatterns: parseDayPatterns2, 54657 defaultParseWidth: "any" 54658 }), 54659 dayPeriod: buildMatchFn2({ 54660 matchPatterns: matchDayPeriodPatterns2, 54661 defaultMatchWidth: "any", 54662 parsePatterns: parseDayPeriodPatterns2, 54663 defaultParseWidth: "any" 54664 }) 54665 }; 54666 54667 // node_modules/react-day-picker/node_modules/date-fns/locale/en-US.js 54668 var enUS2 = { 54669 code: "en-US", 54670 formatDistance: formatDistance2, 54671 formatLong: formatLong2, 54672 formatRelative: formatRelative2, 54673 localize: localize2, 54674 match: match4, 54675 options: { 54676 weekStartsOn: 0, 54677 firstWeekContainsDate: 1 54678 } 54679 }; 54680 54681 // node_modules/react-day-picker/node_modules/date-fns/getDayOfYear.js 54682 function getDayOfYear2(date, options2) { 54683 const _date = toDate2(date, options2?.in); 54684 const diff = differenceInCalendarDays2(_date, startOfYear2(_date)); 54685 const dayOfYear = diff + 1; 54686 return dayOfYear; 54687 } 54688 54689 // node_modules/react-day-picker/node_modules/date-fns/getISOWeek.js 54690 function getISOWeek2(date, options2) { 54691 const _date = toDate2(date, options2?.in); 54692 const diff = +startOfISOWeek2(_date) - +startOfISOWeekYear2(_date); 54693 return Math.round(diff / millisecondsInWeek2) + 1; 54694 } 54695 54696 // node_modules/react-day-picker/node_modules/date-fns/getWeekYear.js 54697 function getWeekYear2(date, options2) { 54698 const _date = toDate2(date, options2?.in); 54699 const year = _date.getFullYear(); 54700 const defaultOptions4 = getDefaultOptions2(); 54701 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 54702 const firstWeekOfNextYear = constructFrom2(options2?.in || date, 0); 54703 firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate); 54704 firstWeekOfNextYear.setHours(0, 0, 0, 0); 54705 const startOfNextYear = startOfWeek2(firstWeekOfNextYear, options2); 54706 const firstWeekOfThisYear = constructFrom2(options2?.in || date, 0); 54707 firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate); 54708 firstWeekOfThisYear.setHours(0, 0, 0, 0); 54709 const startOfThisYear = startOfWeek2(firstWeekOfThisYear, options2); 54710 if (+_date >= +startOfNextYear) { 54711 return year + 1; 54712 } else if (+_date >= +startOfThisYear) { 54713 return year; 54714 } else { 54715 return year - 1; 54716 } 54717 } 54718 54719 // node_modules/react-day-picker/node_modules/date-fns/startOfWeekYear.js 54720 function startOfWeekYear2(date, options2) { 54721 const defaultOptions4 = getDefaultOptions2(); 54722 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 54723 const year = getWeekYear2(date, options2); 54724 const firstWeek = constructFrom2(options2?.in || date, 0); 54725 firstWeek.setFullYear(year, 0, firstWeekContainsDate); 54726 firstWeek.setHours(0, 0, 0, 0); 54727 const _date = startOfWeek2(firstWeek, options2); 54728 return _date; 54729 } 54730 54731 // node_modules/react-day-picker/node_modules/date-fns/getWeek.js 54732 function getWeek2(date, options2) { 54733 const _date = toDate2(date, options2?.in); 54734 const diff = +startOfWeek2(_date, options2) - +startOfWeekYear2(_date, options2); 54735 return Math.round(diff / millisecondsInWeek2) + 1; 54736 } 54737 54738 // node_modules/react-day-picker/node_modules/date-fns/_lib/addLeadingZeros.js 54739 function addLeadingZeros2(number2, targetLength) { 54740 const sign = number2 < 0 ? "-" : ""; 54741 const output = Math.abs(number2).toString().padStart(targetLength, "0"); 54742 return sign + output; 54743 } 54744 54745 // node_modules/react-day-picker/node_modules/date-fns/_lib/format/lightFormatters.js 54746 var lightFormatters2 = { 54747 // Year 54748 y(date, token2) { 54749 const signedYear = date.getFullYear(); 54750 const year = signedYear > 0 ? signedYear : 1 - signedYear; 54751 return addLeadingZeros2(token2 === "yy" ? year % 100 : year, token2.length); 54752 }, 54753 // Month 54754 M(date, token2) { 54755 const month = date.getMonth(); 54756 return token2 === "M" ? String(month + 1) : addLeadingZeros2(month + 1, 2); 54757 }, 54758 // Day of the month 54759 d(date, token2) { 54760 return addLeadingZeros2(date.getDate(), token2.length); 54761 }, 54762 // AM or PM 54763 a(date, token2) { 54764 const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? "pm" : "am"; 54765 switch (token2) { 54766 case "a": 54767 case "aa": 54768 return dayPeriodEnumValue.toUpperCase(); 54769 case "aaa": 54770 return dayPeriodEnumValue; 54771 case "aaaaa": 54772 return dayPeriodEnumValue[0]; 54773 case "aaaa": 54774 default: 54775 return dayPeriodEnumValue === "am" ? "a.m." : "p.m."; 54776 } 54777 }, 54778 // Hour [1-12] 54779 h(date, token2) { 54780 return addLeadingZeros2(date.getHours() % 12 || 12, token2.length); 54781 }, 54782 // Hour [0-23] 54783 H(date, token2) { 54784 return addLeadingZeros2(date.getHours(), token2.length); 54785 }, 54786 // Minute 54787 m(date, token2) { 54788 return addLeadingZeros2(date.getMinutes(), token2.length); 54789 }, 54790 // Second 54791 s(date, token2) { 54792 return addLeadingZeros2(date.getSeconds(), token2.length); 54793 }, 54794 // Fraction of second 54795 S(date, token2) { 54796 const numberOfDigits = token2.length; 54797 const milliseconds = date.getMilliseconds(); 54798 const fractionalSeconds = Math.trunc( 54799 milliseconds * Math.pow(10, numberOfDigits - 3) 54800 ); 54801 return addLeadingZeros2(fractionalSeconds, token2.length); 54802 } 54803 }; 54804 54805 // node_modules/react-day-picker/node_modules/date-fns/_lib/format/formatters.js 54806 var dayPeriodEnum2 = { 54807 am: "am", 54808 pm: "pm", 54809 midnight: "midnight", 54810 noon: "noon", 54811 morning: "morning", 54812 afternoon: "afternoon", 54813 evening: "evening", 54814 night: "night" 54815 }; 54816 var formatters2 = { 54817 // Era 54818 G: function(date, token2, localize3) { 54819 const era = date.getFullYear() > 0 ? 1 : 0; 54820 switch (token2) { 54821 // AD, BC 54822 case "G": 54823 case "GG": 54824 case "GGG": 54825 return localize3.era(era, { width: "abbreviated" }); 54826 // A, B 54827 case "GGGGG": 54828 return localize3.era(era, { width: "narrow" }); 54829 // Anno Domini, Before Christ 54830 case "GGGG": 54831 default: 54832 return localize3.era(era, { width: "wide" }); 54833 } 54834 }, 54835 // Year 54836 y: function(date, token2, localize3) { 54837 if (token2 === "yo") { 54838 const signedYear = date.getFullYear(); 54839 const year = signedYear > 0 ? signedYear : 1 - signedYear; 54840 return localize3.ordinalNumber(year, { unit: "year" }); 54841 } 54842 return lightFormatters2.y(date, token2); 54843 }, 54844 // Local week-numbering year 54845 Y: function(date, token2, localize3, options2) { 54846 const signedWeekYear = getWeekYear2(date, options2); 54847 const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear; 54848 if (token2 === "YY") { 54849 const twoDigitYear = weekYear % 100; 54850 return addLeadingZeros2(twoDigitYear, 2); 54851 } 54852 if (token2 === "Yo") { 54853 return localize3.ordinalNumber(weekYear, { unit: "year" }); 54854 } 54855 return addLeadingZeros2(weekYear, token2.length); 54856 }, 54857 // ISO week-numbering year 54858 R: function(date, token2) { 54859 const isoWeekYear = getISOWeekYear2(date); 54860 return addLeadingZeros2(isoWeekYear, token2.length); 54861 }, 54862 // Extended year. This is a single number designating the year of this calendar system. 54863 // The main difference between `y` and `u` localizers are B.C. years: 54864 // | Year | `y` | `u` | 54865 // |------|-----|-----| 54866 // | AC 1 | 1 | 1 | 54867 // | BC 1 | 1 | 0 | 54868 // | BC 2 | 2 | -1 | 54869 // Also `yy` always returns the last two digits of a year, 54870 // while `uu` pads single digit years to 2 characters and returns other years unchanged. 54871 u: function(date, token2) { 54872 const year = date.getFullYear(); 54873 return addLeadingZeros2(year, token2.length); 54874 }, 54875 // Quarter 54876 Q: function(date, token2, localize3) { 54877 const quarter = Math.ceil((date.getMonth() + 1) / 3); 54878 switch (token2) { 54879 // 1, 2, 3, 4 54880 case "Q": 54881 return String(quarter); 54882 // 01, 02, 03, 04 54883 case "QQ": 54884 return addLeadingZeros2(quarter, 2); 54885 // 1st, 2nd, 3rd, 4th 54886 case "Qo": 54887 return localize3.ordinalNumber(quarter, { unit: "quarter" }); 54888 // Q1, Q2, Q3, Q4 54889 case "QQQ": 54890 return localize3.quarter(quarter, { 54891 width: "abbreviated", 54892 context: "formatting" 54893 }); 54894 // 1, 2, 3, 4 (narrow quarter; could be not numerical) 54895 case "QQQQQ": 54896 return localize3.quarter(quarter, { 54897 width: "narrow", 54898 context: "formatting" 54899 }); 54900 // 1st quarter, 2nd quarter, ... 54901 case "QQQQ": 54902 default: 54903 return localize3.quarter(quarter, { 54904 width: "wide", 54905 context: "formatting" 54906 }); 54907 } 54908 }, 54909 // Stand-alone quarter 54910 q: function(date, token2, localize3) { 54911 const quarter = Math.ceil((date.getMonth() + 1) / 3); 54912 switch (token2) { 54913 // 1, 2, 3, 4 54914 case "q": 54915 return String(quarter); 54916 // 01, 02, 03, 04 54917 case "qq": 54918 return addLeadingZeros2(quarter, 2); 54919 // 1st, 2nd, 3rd, 4th 54920 case "qo": 54921 return localize3.ordinalNumber(quarter, { unit: "quarter" }); 54922 // Q1, Q2, Q3, Q4 54923 case "qqq": 54924 return localize3.quarter(quarter, { 54925 width: "abbreviated", 54926 context: "standalone" 54927 }); 54928 // 1, 2, 3, 4 (narrow quarter; could be not numerical) 54929 case "qqqqq": 54930 return localize3.quarter(quarter, { 54931 width: "narrow", 54932 context: "standalone" 54933 }); 54934 // 1st quarter, 2nd quarter, ... 54935 case "qqqq": 54936 default: 54937 return localize3.quarter(quarter, { 54938 width: "wide", 54939 context: "standalone" 54940 }); 54941 } 54942 }, 54943 // Month 54944 M: function(date, token2, localize3) { 54945 const month = date.getMonth(); 54946 switch (token2) { 54947 case "M": 54948 case "MM": 54949 return lightFormatters2.M(date, token2); 54950 // 1st, 2nd, ..., 12th 54951 case "Mo": 54952 return localize3.ordinalNumber(month + 1, { unit: "month" }); 54953 // Jan, Feb, ..., Dec 54954 case "MMM": 54955 return localize3.month(month, { 54956 width: "abbreviated", 54957 context: "formatting" 54958 }); 54959 // J, F, ..., D 54960 case "MMMMM": 54961 return localize3.month(month, { 54962 width: "narrow", 54963 context: "formatting" 54964 }); 54965 // January, February, ..., December 54966 case "MMMM": 54967 default: 54968 return localize3.month(month, { width: "wide", context: "formatting" }); 54969 } 54970 }, 54971 // Stand-alone month 54972 L: function(date, token2, localize3) { 54973 const month = date.getMonth(); 54974 switch (token2) { 54975 // 1, 2, ..., 12 54976 case "L": 54977 return String(month + 1); 54978 // 01, 02, ..., 12 54979 case "LL": 54980 return addLeadingZeros2(month + 1, 2); 54981 // 1st, 2nd, ..., 12th 54982 case "Lo": 54983 return localize3.ordinalNumber(month + 1, { unit: "month" }); 54984 // Jan, Feb, ..., Dec 54985 case "LLL": 54986 return localize3.month(month, { 54987 width: "abbreviated", 54988 context: "standalone" 54989 }); 54990 // J, F, ..., D 54991 case "LLLLL": 54992 return localize3.month(month, { 54993 width: "narrow", 54994 context: "standalone" 54995 }); 54996 // January, February, ..., December 54997 case "LLLL": 54998 default: 54999 return localize3.month(month, { width: "wide", context: "standalone" }); 55000 } 55001 }, 55002 // Local week of year 55003 w: function(date, token2, localize3, options2) { 55004 const week = getWeek2(date, options2); 55005 if (token2 === "wo") { 55006 return localize3.ordinalNumber(week, { unit: "week" }); 55007 } 55008 return addLeadingZeros2(week, token2.length); 55009 }, 55010 // ISO week of year 55011 I: function(date, token2, localize3) { 55012 const isoWeek = getISOWeek2(date); 55013 if (token2 === "Io") { 55014 return localize3.ordinalNumber(isoWeek, { unit: "week" }); 55015 } 55016 return addLeadingZeros2(isoWeek, token2.length); 55017 }, 55018 // Day of the month 55019 d: function(date, token2, localize3) { 55020 if (token2 === "do") { 55021 return localize3.ordinalNumber(date.getDate(), { unit: "date" }); 55022 } 55023 return lightFormatters2.d(date, token2); 55024 }, 55025 // Day of year 55026 D: function(date, token2, localize3) { 55027 const dayOfYear = getDayOfYear2(date); 55028 if (token2 === "Do") { 55029 return localize3.ordinalNumber(dayOfYear, { unit: "dayOfYear" }); 55030 } 55031 return addLeadingZeros2(dayOfYear, token2.length); 55032 }, 55033 // Day of week 55034 E: function(date, token2, localize3) { 55035 const dayOfWeek = date.getDay(); 55036 switch (token2) { 55037 // Tue 55038 case "E": 55039 case "EE": 55040 case "EEE": 55041 return localize3.day(dayOfWeek, { 55042 width: "abbreviated", 55043 context: "formatting" 55044 }); 55045 // T 55046 case "EEEEE": 55047 return localize3.day(dayOfWeek, { 55048 width: "narrow", 55049 context: "formatting" 55050 }); 55051 // Tu 55052 case "EEEEEE": 55053 return localize3.day(dayOfWeek, { 55054 width: "short", 55055 context: "formatting" 55056 }); 55057 // Tuesday 55058 case "EEEE": 55059 default: 55060 return localize3.day(dayOfWeek, { 55061 width: "wide", 55062 context: "formatting" 55063 }); 55064 } 55065 }, 55066 // Local day of week 55067 e: function(date, token2, localize3, options2) { 55068 const dayOfWeek = date.getDay(); 55069 const localDayOfWeek = (dayOfWeek - options2.weekStartsOn + 8) % 7 || 7; 55070 switch (token2) { 55071 // Numerical value (Nth day of week with current locale or weekStartsOn) 55072 case "e": 55073 return String(localDayOfWeek); 55074 // Padded numerical value 55075 case "ee": 55076 return addLeadingZeros2(localDayOfWeek, 2); 55077 // 1st, 2nd, ..., 7th 55078 case "eo": 55079 return localize3.ordinalNumber(localDayOfWeek, { unit: "day" }); 55080 case "eee": 55081 return localize3.day(dayOfWeek, { 55082 width: "abbreviated", 55083 context: "formatting" 55084 }); 55085 // T 55086 case "eeeee": 55087 return localize3.day(dayOfWeek, { 55088 width: "narrow", 55089 context: "formatting" 55090 }); 55091 // Tu 55092 case "eeeeee": 55093 return localize3.day(dayOfWeek, { 55094 width: "short", 55095 context: "formatting" 55096 }); 55097 // Tuesday 55098 case "eeee": 55099 default: 55100 return localize3.day(dayOfWeek, { 55101 width: "wide", 55102 context: "formatting" 55103 }); 55104 } 55105 }, 55106 // Stand-alone local day of week 55107 c: function(date, token2, localize3, options2) { 55108 const dayOfWeek = date.getDay(); 55109 const localDayOfWeek = (dayOfWeek - options2.weekStartsOn + 8) % 7 || 7; 55110 switch (token2) { 55111 // Numerical value (same as in `e`) 55112 case "c": 55113 return String(localDayOfWeek); 55114 // Padded numerical value 55115 case "cc": 55116 return addLeadingZeros2(localDayOfWeek, token2.length); 55117 // 1st, 2nd, ..., 7th 55118 case "co": 55119 return localize3.ordinalNumber(localDayOfWeek, { unit: "day" }); 55120 case "ccc": 55121 return localize3.day(dayOfWeek, { 55122 width: "abbreviated", 55123 context: "standalone" 55124 }); 55125 // T 55126 case "ccccc": 55127 return localize3.day(dayOfWeek, { 55128 width: "narrow", 55129 context: "standalone" 55130 }); 55131 // Tu 55132 case "cccccc": 55133 return localize3.day(dayOfWeek, { 55134 width: "short", 55135 context: "standalone" 55136 }); 55137 // Tuesday 55138 case "cccc": 55139 default: 55140 return localize3.day(dayOfWeek, { 55141 width: "wide", 55142 context: "standalone" 55143 }); 55144 } 55145 }, 55146 // ISO day of week 55147 i: function(date, token2, localize3) { 55148 const dayOfWeek = date.getDay(); 55149 const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek; 55150 switch (token2) { 55151 // 2 55152 case "i": 55153 return String(isoDayOfWeek); 55154 // 02 55155 case "ii": 55156 return addLeadingZeros2(isoDayOfWeek, token2.length); 55157 // 2nd 55158 case "io": 55159 return localize3.ordinalNumber(isoDayOfWeek, { unit: "day" }); 55160 // Tue 55161 case "iii": 55162 return localize3.day(dayOfWeek, { 55163 width: "abbreviated", 55164 context: "formatting" 55165 }); 55166 // T 55167 case "iiiii": 55168 return localize3.day(dayOfWeek, { 55169 width: "narrow", 55170 context: "formatting" 55171 }); 55172 // Tu 55173 case "iiiiii": 55174 return localize3.day(dayOfWeek, { 55175 width: "short", 55176 context: "formatting" 55177 }); 55178 // Tuesday 55179 case "iiii": 55180 default: 55181 return localize3.day(dayOfWeek, { 55182 width: "wide", 55183 context: "formatting" 55184 }); 55185 } 55186 }, 55187 // AM or PM 55188 a: function(date, token2, localize3) { 55189 const hours = date.getHours(); 55190 const dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am"; 55191 switch (token2) { 55192 case "a": 55193 case "aa": 55194 return localize3.dayPeriod(dayPeriodEnumValue, { 55195 width: "abbreviated", 55196 context: "formatting" 55197 }); 55198 case "aaa": 55199 return localize3.dayPeriod(dayPeriodEnumValue, { 55200 width: "abbreviated", 55201 context: "formatting" 55202 }).toLowerCase(); 55203 case "aaaaa": 55204 return localize3.dayPeriod(dayPeriodEnumValue, { 55205 width: "narrow", 55206 context: "formatting" 55207 }); 55208 case "aaaa": 55209 default: 55210 return localize3.dayPeriod(dayPeriodEnumValue, { 55211 width: "wide", 55212 context: "formatting" 55213 }); 55214 } 55215 }, 55216 // AM, PM, midnight, noon 55217 b: function(date, token2, localize3) { 55218 const hours = date.getHours(); 55219 let dayPeriodEnumValue; 55220 if (hours === 12) { 55221 dayPeriodEnumValue = dayPeriodEnum2.noon; 55222 } else if (hours === 0) { 55223 dayPeriodEnumValue = dayPeriodEnum2.midnight; 55224 } else { 55225 dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am"; 55226 } 55227 switch (token2) { 55228 case "b": 55229 case "bb": 55230 return localize3.dayPeriod(dayPeriodEnumValue, { 55231 width: "abbreviated", 55232 context: "formatting" 55233 }); 55234 case "bbb": 55235 return localize3.dayPeriod(dayPeriodEnumValue, { 55236 width: "abbreviated", 55237 context: "formatting" 55238 }).toLowerCase(); 55239 case "bbbbb": 55240 return localize3.dayPeriod(dayPeriodEnumValue, { 55241 width: "narrow", 55242 context: "formatting" 55243 }); 55244 case "bbbb": 55245 default: 55246 return localize3.dayPeriod(dayPeriodEnumValue, { 55247 width: "wide", 55248 context: "formatting" 55249 }); 55250 } 55251 }, 55252 // in the morning, in the afternoon, in the evening, at night 55253 B: function(date, token2, localize3) { 55254 const hours = date.getHours(); 55255 let dayPeriodEnumValue; 55256 if (hours >= 17) { 55257 dayPeriodEnumValue = dayPeriodEnum2.evening; 55258 } else if (hours >= 12) { 55259 dayPeriodEnumValue = dayPeriodEnum2.afternoon; 55260 } else if (hours >= 4) { 55261 dayPeriodEnumValue = dayPeriodEnum2.morning; 55262 } else { 55263 dayPeriodEnumValue = dayPeriodEnum2.night; 55264 } 55265 switch (token2) { 55266 case "B": 55267 case "BB": 55268 case "BBB": 55269 return localize3.dayPeriod(dayPeriodEnumValue, { 55270 width: "abbreviated", 55271 context: "formatting" 55272 }); 55273 case "BBBBB": 55274 return localize3.dayPeriod(dayPeriodEnumValue, { 55275 width: "narrow", 55276 context: "formatting" 55277 }); 55278 case "BBBB": 55279 default: 55280 return localize3.dayPeriod(dayPeriodEnumValue, { 55281 width: "wide", 55282 context: "formatting" 55283 }); 55284 } 55285 }, 55286 // Hour [1-12] 55287 h: function(date, token2, localize3) { 55288 if (token2 === "ho") { 55289 let hours = date.getHours() % 12; 55290 if (hours === 0) hours = 12; 55291 return localize3.ordinalNumber(hours, { unit: "hour" }); 55292 } 55293 return lightFormatters2.h(date, token2); 55294 }, 55295 // Hour [0-23] 55296 H: function(date, token2, localize3) { 55297 if (token2 === "Ho") { 55298 return localize3.ordinalNumber(date.getHours(), { unit: "hour" }); 55299 } 55300 return lightFormatters2.H(date, token2); 55301 }, 55302 // Hour [0-11] 55303 K: function(date, token2, localize3) { 55304 const hours = date.getHours() % 12; 55305 if (token2 === "Ko") { 55306 return localize3.ordinalNumber(hours, { unit: "hour" }); 55307 } 55308 return addLeadingZeros2(hours, token2.length); 55309 }, 55310 // Hour [1-24] 55311 k: function(date, token2, localize3) { 55312 let hours = date.getHours(); 55313 if (hours === 0) hours = 24; 55314 if (token2 === "ko") { 55315 return localize3.ordinalNumber(hours, { unit: "hour" }); 55316 } 55317 return addLeadingZeros2(hours, token2.length); 55318 }, 55319 // Minute 55320 m: function(date, token2, localize3) { 55321 if (token2 === "mo") { 55322 return localize3.ordinalNumber(date.getMinutes(), { unit: "minute" }); 55323 } 55324 return lightFormatters2.m(date, token2); 55325 }, 55326 // Second 55327 s: function(date, token2, localize3) { 55328 if (token2 === "so") { 55329 return localize3.ordinalNumber(date.getSeconds(), { unit: "second" }); 55330 } 55331 return lightFormatters2.s(date, token2); 55332 }, 55333 // Fraction of second 55334 S: function(date, token2) { 55335 return lightFormatters2.S(date, token2); 55336 }, 55337 // Timezone (ISO-8601. If offset is 0, output is always `'Z'`) 55338 X: function(date, token2, _localize) { 55339 const timezoneOffset = date.getTimezoneOffset(); 55340 if (timezoneOffset === 0) { 55341 return "Z"; 55342 } 55343 switch (token2) { 55344 // Hours and optional minutes 55345 case "X": 55346 return formatTimezoneWithOptionalMinutes2(timezoneOffset); 55347 // Hours, minutes and optional seconds without `:` delimiter 55348 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 55349 // so this token always has the same output as `XX` 55350 case "XXXX": 55351 case "XX": 55352 return formatTimezone2(timezoneOffset); 55353 // Hours, minutes and optional seconds with `:` delimiter 55354 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 55355 // so this token always has the same output as `XXX` 55356 case "XXXXX": 55357 case "XXX": 55358 // Hours and minutes with `:` delimiter 55359 default: 55360 return formatTimezone2(timezoneOffset, ":"); 55361 } 55362 }, 55363 // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent) 55364 x: function(date, token2, _localize) { 55365 const timezoneOffset = date.getTimezoneOffset(); 55366 switch (token2) { 55367 // Hours and optional minutes 55368 case "x": 55369 return formatTimezoneWithOptionalMinutes2(timezoneOffset); 55370 // Hours, minutes and optional seconds without `:` delimiter 55371 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 55372 // so this token always has the same output as `xx` 55373 case "xxxx": 55374 case "xx": 55375 return formatTimezone2(timezoneOffset); 55376 // Hours, minutes and optional seconds with `:` delimiter 55377 // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets 55378 // so this token always has the same output as `xxx` 55379 case "xxxxx": 55380 case "xxx": 55381 // Hours and minutes with `:` delimiter 55382 default: 55383 return formatTimezone2(timezoneOffset, ":"); 55384 } 55385 }, 55386 // Timezone (GMT) 55387 O: function(date, token2, _localize) { 55388 const timezoneOffset = date.getTimezoneOffset(); 55389 switch (token2) { 55390 // Short 55391 case "O": 55392 case "OO": 55393 case "OOO": 55394 return "GMT" + formatTimezoneShort2(timezoneOffset, ":"); 55395 // Long 55396 case "OOOO": 55397 default: 55398 return "GMT" + formatTimezone2(timezoneOffset, ":"); 55399 } 55400 }, 55401 // Timezone (specific non-location) 55402 z: function(date, token2, _localize) { 55403 const timezoneOffset = date.getTimezoneOffset(); 55404 switch (token2) { 55405 // Short 55406 case "z": 55407 case "zz": 55408 case "zzz": 55409 return "GMT" + formatTimezoneShort2(timezoneOffset, ":"); 55410 // Long 55411 case "zzzz": 55412 default: 55413 return "GMT" + formatTimezone2(timezoneOffset, ":"); 55414 } 55415 }, 55416 // Seconds timestamp 55417 t: function(date, token2, _localize) { 55418 const timestamp = Math.trunc(+date / 1e3); 55419 return addLeadingZeros2(timestamp, token2.length); 55420 }, 55421 // Milliseconds timestamp 55422 T: function(date, token2, _localize) { 55423 return addLeadingZeros2(+date, token2.length); 55424 } 55425 }; 55426 function formatTimezoneShort2(offset3, delimiter2 = "") { 55427 const sign = offset3 > 0 ? "-" : "+"; 55428 const absOffset = Math.abs(offset3); 55429 const hours = Math.trunc(absOffset / 60); 55430 const minutes = absOffset % 60; 55431 if (minutes === 0) { 55432 return sign + String(hours); 55433 } 55434 return sign + String(hours) + delimiter2 + addLeadingZeros2(minutes, 2); 55435 } 55436 function formatTimezoneWithOptionalMinutes2(offset3, delimiter2) { 55437 if (offset3 % 60 === 0) { 55438 const sign = offset3 > 0 ? "-" : "+"; 55439 return sign + addLeadingZeros2(Math.abs(offset3) / 60, 2); 55440 } 55441 return formatTimezone2(offset3, delimiter2); 55442 } 55443 function formatTimezone2(offset3, delimiter2 = "") { 55444 const sign = offset3 > 0 ? "-" : "+"; 55445 const absOffset = Math.abs(offset3); 55446 const hours = addLeadingZeros2(Math.trunc(absOffset / 60), 2); 55447 const minutes = addLeadingZeros2(absOffset % 60, 2); 55448 return sign + hours + delimiter2 + minutes; 55449 } 55450 55451 // node_modules/react-day-picker/node_modules/date-fns/_lib/format/longFormatters.js 55452 var dateLongFormatter2 = (pattern, formatLong3) => { 55453 switch (pattern) { 55454 case "P": 55455 return formatLong3.date({ width: "short" }); 55456 case "PP": 55457 return formatLong3.date({ width: "medium" }); 55458 case "PPP": 55459 return formatLong3.date({ width: "long" }); 55460 case "PPPP": 55461 default: 55462 return formatLong3.date({ width: "full" }); 55463 } 55464 }; 55465 var timeLongFormatter2 = (pattern, formatLong3) => { 55466 switch (pattern) { 55467 case "p": 55468 return formatLong3.time({ width: "short" }); 55469 case "pp": 55470 return formatLong3.time({ width: "medium" }); 55471 case "ppp": 55472 return formatLong3.time({ width: "long" }); 55473 case "pppp": 55474 default: 55475 return formatLong3.time({ width: "full" }); 55476 } 55477 }; 55478 var dateTimeLongFormatter2 = (pattern, formatLong3) => { 55479 const matchResult = pattern.match(/(P+)(p+)?/) || []; 55480 const datePattern = matchResult[1]; 55481 const timePattern = matchResult[2]; 55482 if (!timePattern) { 55483 return dateLongFormatter2(pattern, formatLong3); 55484 } 55485 let dateTimeFormat; 55486 switch (datePattern) { 55487 case "P": 55488 dateTimeFormat = formatLong3.dateTime({ width: "short" }); 55489 break; 55490 case "PP": 55491 dateTimeFormat = formatLong3.dateTime({ width: "medium" }); 55492 break; 55493 case "PPP": 55494 dateTimeFormat = formatLong3.dateTime({ width: "long" }); 55495 break; 55496 case "PPPP": 55497 default: 55498 dateTimeFormat = formatLong3.dateTime({ width: "full" }); 55499 break; 55500 } 55501 return dateTimeFormat.replace("{{date}}", dateLongFormatter2(datePattern, formatLong3)).replace("{{time}}", timeLongFormatter2(timePattern, formatLong3)); 55502 }; 55503 var longFormatters2 = { 55504 p: timeLongFormatter2, 55505 P: dateTimeLongFormatter2 55506 }; 55507 55508 // node_modules/react-day-picker/node_modules/date-fns/_lib/protectedTokens.js 55509 var dayOfYearTokenRE2 = /^D+$/; 55510 var weekYearTokenRE2 = /^Y+$/; 55511 var throwTokens2 = ["D", "DD", "YY", "YYYY"]; 55512 function isProtectedDayOfYearToken2(token2) { 55513 return dayOfYearTokenRE2.test(token2); 55514 } 55515 function isProtectedWeekYearToken2(token2) { 55516 return weekYearTokenRE2.test(token2); 55517 } 55518 function warnOrThrowProtectedError2(token2, format3, input) { 55519 const _message = message2(token2, format3, input); 55520 console.warn(_message); 55521 if (throwTokens2.includes(token2)) throw new RangeError(_message); 55522 } 55523 function message2(token2, format3, input) { 55524 const subject = token2[0] === "Y" ? "years" : "days of the month"; 55525 return `Use \`$token2.toLowerCase()}\` instead of \`$token2}\` (in \`$format3}\`) for formatting $subject} to the input \`$input}\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`; 55526 } 55527 55528 // node_modules/react-day-picker/node_modules/date-fns/format.js 55529 var formattingTokensRegExp2 = /[yYQqMLwIdDecihHKkms]o|(\w)\1*|''|'(''|[^'])+('|$)|./g; 55530 var longFormattingTokensRegExp2 = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g; 55531 var escapedStringRegExp2 = /^'([^]*?)'?$/; 55532 var doubleQuoteRegExp2 = /''/g; 55533 var unescapedLatinCharacterRegExp2 = /[a-zA-Z]/; 55534 function format2(date, formatStr, options2) { 55535 const defaultOptions4 = getDefaultOptions2(); 55536 const locale = options2?.locale ?? defaultOptions4.locale ?? enUS2; 55537 const firstWeekContainsDate = options2?.firstWeekContainsDate ?? options2?.locale?.options?.firstWeekContainsDate ?? defaultOptions4.firstWeekContainsDate ?? defaultOptions4.locale?.options?.firstWeekContainsDate ?? 1; 55538 const weekStartsOn = options2?.weekStartsOn ?? options2?.locale?.options?.weekStartsOn ?? defaultOptions4.weekStartsOn ?? defaultOptions4.locale?.options?.weekStartsOn ?? 0; 55539 const originalDate = toDate2(date, options2?.in); 55540 if (!isValid2(originalDate)) { 55541 throw new RangeError("Invalid time value"); 55542 } 55543 let parts = formatStr.match(longFormattingTokensRegExp2).map((substring) => { 55544 const firstCharacter = substring[0]; 55545 if (firstCharacter === "p" || firstCharacter === "P") { 55546 const longFormatter = longFormatters2[firstCharacter]; 55547 return longFormatter(substring, locale.formatLong); 55548 } 55549 return substring; 55550 }).join("").match(formattingTokensRegExp2).map((substring) => { 55551 if (substring === "''") { 55552 return { isToken: false, value: "'" }; 55553 } 55554 const firstCharacter = substring[0]; 55555 if (firstCharacter === "'") { 55556 return { isToken: false, value: cleanEscapedString2(substring) }; 55557 } 55558 if (formatters2[firstCharacter]) { 55559 return { isToken: true, value: substring }; 55560 } 55561 if (firstCharacter.match(unescapedLatinCharacterRegExp2)) { 55562 throw new RangeError( 55563 "Format string contains an unescaped latin alphabet character `" + firstCharacter + "`" 55564 ); 55565 } 55566 return { isToken: false, value: substring }; 55567 }); 55568 if (locale.localize.preprocessor) { 55569 parts = locale.localize.preprocessor(originalDate, parts); 55570 } 55571 const formatterOptions = { 55572 firstWeekContainsDate, 55573 weekStartsOn, 55574 locale 55575 }; 55576 return parts.map((part) => { 55577 if (!part.isToken) return part.value; 55578 const token2 = part.value; 55579 if (!options2?.useAdditionalWeekYearTokens && isProtectedWeekYearToken2(token2) || !options2?.useAdditionalDayOfYearTokens && isProtectedDayOfYearToken2(token2)) { 55580 warnOrThrowProtectedError2(token2, formatStr, String(date)); 55581 } 55582 const formatter = formatters2[token2[0]]; 55583 return formatter(originalDate, token2, locale.localize, formatterOptions); 55584 }).join(""); 55585 } 55586 function cleanEscapedString2(input) { 55587 const matched = input.match(escapedStringRegExp2); 55588 if (!matched) { 55589 return input; 55590 } 55591 return matched[1].replace(doubleQuoteRegExp2, "'"); 55592 } 55593 55594 // node_modules/react-day-picker/node_modules/date-fns/getDaysInMonth.js 55595 function getDaysInMonth2(date, options2) { 55596 const _date = toDate2(date, options2?.in); 55597 const year = _date.getFullYear(); 55598 const monthIndex = _date.getMonth(); 55599 const lastDayOfMonth = constructFrom2(_date, 0); 55600 lastDayOfMonth.setFullYear(year, monthIndex + 1, 0); 55601 lastDayOfMonth.setHours(0, 0, 0, 0); 55602 return lastDayOfMonth.getDate(); 55603 } 55604 55605 // node_modules/react-day-picker/node_modules/date-fns/getMonth.js 55606 function getMonth(date, options2) { 55607 return toDate2(date, options2?.in).getMonth(); 55608 } 55609 55610 // node_modules/react-day-picker/node_modules/date-fns/getYear.js 55611 function getYear(date, options2) { 55612 return toDate2(date, options2?.in).getFullYear(); 55613 } 55614 55615 // node_modules/react-day-picker/node_modules/date-fns/isAfter.js 55616 function isAfter2(date, dateToCompare) { 55617 return +toDate2(date) > +toDate2(dateToCompare); 55618 } 55619 55620 // node_modules/react-day-picker/node_modules/date-fns/isBefore.js 55621 function isBefore2(date, dateToCompare) { 55622 return +toDate2(date) < +toDate2(dateToCompare); 55623 } 55624 55625 // node_modules/react-day-picker/node_modules/date-fns/isSameMonth.js 55626 function isSameMonth2(laterDate, earlierDate, options2) { 55627 const [laterDate_, earlierDate_] = normalizeDates( 55628 options2?.in, 55629 laterDate, 55630 earlierDate 55631 ); 55632 return laterDate_.getFullYear() === earlierDate_.getFullYear() && laterDate_.getMonth() === earlierDate_.getMonth(); 55633 } 55634 55635 // node_modules/react-day-picker/node_modules/date-fns/isSameYear.js 55636 function isSameYear(laterDate, earlierDate, options2) { 55637 const [laterDate_, earlierDate_] = normalizeDates( 55638 options2?.in, 55639 laterDate, 55640 earlierDate 55641 ); 55642 return laterDate_.getFullYear() === earlierDate_.getFullYear(); 55643 } 55644 55645 // node_modules/react-day-picker/node_modules/date-fns/setMonth.js 55646 function setMonth2(date, month, options2) { 55647 const _date = toDate2(date, options2?.in); 55648 const year = _date.getFullYear(); 55649 const day = _date.getDate(); 55650 const midMonth = constructFrom2(options2?.in || date, 0); 55651 midMonth.setFullYear(year, month, 15); 55652 midMonth.setHours(0, 0, 0, 0); 55653 const daysInMonth = getDaysInMonth2(midMonth); 55654 _date.setMonth(month, Math.min(day, daysInMonth)); 55655 return _date; 55656 } 55657 55658 // node_modules/react-day-picker/node_modules/date-fns/setYear.js 55659 function setYear2(date, year, options2) { 55660 const date_ = toDate2(date, options2?.in); 55661 if (isNaN(+date_)) return constructFrom2(options2?.in || date, NaN); 55662 date_.setFullYear(year); 55663 return date_; 55664 } 55665 55666 // node_modules/react-day-picker/dist/esm/helpers/getBroadcastWeeksInMonth.js 55667 var FIVE_WEEKS = 5; 55668 var FOUR_WEEKS = 4; 55669 function getBroadcastWeeksInMonth(month, dateLib) { 55670 const firstDayOfMonth = dateLib.startOfMonth(month); 55671 const firstDayOfWeek = firstDayOfMonth.getDay() > 0 ? firstDayOfMonth.getDay() : 7; 55672 const broadcastStartDate = dateLib.addDays(month, -firstDayOfWeek + 1); 55673 const lastDateOfLastWeek = dateLib.addDays(broadcastStartDate, FIVE_WEEKS * 7 - 1); 55674 const numberOfWeeks = dateLib.getMonth(month) === dateLib.getMonth(lastDateOfLastWeek) ? FIVE_WEEKS : FOUR_WEEKS; 55675 return numberOfWeeks; 55676 } 55677 55678 // node_modules/react-day-picker/dist/esm/helpers/startOfBroadcastWeek.js 55679 function startOfBroadcastWeek(date, dateLib) { 55680 const firstOfMonth = dateLib.startOfMonth(date); 55681 const dayOfWeek = firstOfMonth.getDay(); 55682 if (dayOfWeek === 1) { 55683 return firstOfMonth; 55684 } else if (dayOfWeek === 0) { 55685 return dateLib.addDays(firstOfMonth, -1 * 6); 55686 } else { 55687 return dateLib.addDays(firstOfMonth, -1 * (dayOfWeek - 1)); 55688 } 55689 } 55690 55691 // node_modules/react-day-picker/dist/esm/helpers/endOfBroadcastWeek.js 55692 function endOfBroadcastWeek(date, dateLib) { 55693 const startDate = startOfBroadcastWeek(date, dateLib); 55694 const numberOfWeeks = getBroadcastWeeksInMonth(date, dateLib); 55695 const endDate = dateLib.addDays(startDate, numberOfWeeks * 7 - 1); 55696 return endDate; 55697 } 55698 55699 // node_modules/react-day-picker/dist/esm/classes/DateLib.js 55700 var DateLib = class { 55701 /** 55702 * Creates an instance of `DateLib`. 55703 * 55704 * @param options Configuration options for the date library. 55705 * @param overrides Custom overrides for the date library functions. 55706 */ 55707 constructor(options2, overrides) { 55708 this.Date = Date; 55709 this.today = () => { 55710 if (this.overrides?.today) { 55711 return this.overrides.today(); 55712 } 55713 if (this.options.timeZone) { 55714 return TZDate.tz(this.options.timeZone); 55715 } 55716 return new this.Date(); 55717 }; 55718 this.newDate = (year, monthIndex, date) => { 55719 if (this.overrides?.newDate) { 55720 return this.overrides.newDate(year, monthIndex, date); 55721 } 55722 if (this.options.timeZone) { 55723 return new TZDate(year, monthIndex, date, this.options.timeZone); 55724 } 55725 return new Date(year, monthIndex, date); 55726 }; 55727 this.addDays = (date, amount) => { 55728 return this.overrides?.addDays ? this.overrides.addDays(date, amount) : addDays2(date, amount); 55729 }; 55730 this.addMonths = (date, amount) => { 55731 return this.overrides?.addMonths ? this.overrides.addMonths(date, amount) : addMonths2(date, amount); 55732 }; 55733 this.addWeeks = (date, amount) => { 55734 return this.overrides?.addWeeks ? this.overrides.addWeeks(date, amount) : addWeeks2(date, amount); 55735 }; 55736 this.addYears = (date, amount) => { 55737 return this.overrides?.addYears ? this.overrides.addYears(date, amount) : addYears2(date, amount); 55738 }; 55739 this.differenceInCalendarDays = (dateLeft, dateRight) => { 55740 return this.overrides?.differenceInCalendarDays ? this.overrides.differenceInCalendarDays(dateLeft, dateRight) : differenceInCalendarDays2(dateLeft, dateRight); 55741 }; 55742 this.differenceInCalendarMonths = (dateLeft, dateRight) => { 55743 return this.overrides?.differenceInCalendarMonths ? this.overrides.differenceInCalendarMonths(dateLeft, dateRight) : differenceInCalendarMonths(dateLeft, dateRight); 55744 }; 55745 this.eachMonthOfInterval = (interval) => { 55746 return this.overrides?.eachMonthOfInterval ? this.overrides.eachMonthOfInterval(interval) : eachMonthOfInterval2(interval); 55747 }; 55748 this.endOfBroadcastWeek = (date) => { 55749 return this.overrides?.endOfBroadcastWeek ? this.overrides.endOfBroadcastWeek(date) : endOfBroadcastWeek(date, this); 55750 }; 55751 this.endOfISOWeek = (date) => { 55752 return this.overrides?.endOfISOWeek ? this.overrides.endOfISOWeek(date) : endOfISOWeek(date); 55753 }; 55754 this.endOfMonth = (date) => { 55755 return this.overrides?.endOfMonth ? this.overrides.endOfMonth(date) : endOfMonth2(date); 55756 }; 55757 this.endOfWeek = (date, options3) => { 55758 return this.overrides?.endOfWeek ? this.overrides.endOfWeek(date, options3) : endOfWeek2(date, this.options); 55759 }; 55760 this.endOfYear = (date) => { 55761 return this.overrides?.endOfYear ? this.overrides.endOfYear(date) : endOfYear(date); 55762 }; 55763 this.format = (date, formatStr, options3) => { 55764 const formatted = this.overrides?.format ? this.overrides.format(date, formatStr, this.options) : format2(date, formatStr, this.options); 55765 if (this.options.numerals && this.options.numerals !== "latn") { 55766 return this.replaceDigits(formatted); 55767 } 55768 return formatted; 55769 }; 55770 this.getISOWeek = (date) => { 55771 return this.overrides?.getISOWeek ? this.overrides.getISOWeek(date) : getISOWeek2(date); 55772 }; 55773 this.getMonth = (date, options3) => { 55774 return this.overrides?.getMonth ? this.overrides.getMonth(date, this.options) : getMonth(date, this.options); 55775 }; 55776 this.getYear = (date, options3) => { 55777 return this.overrides?.getYear ? this.overrides.getYear(date, this.options) : getYear(date, this.options); 55778 }; 55779 this.getWeek = (date, options3) => { 55780 return this.overrides?.getWeek ? this.overrides.getWeek(date, this.options) : getWeek2(date, this.options); 55781 }; 55782 this.isAfter = (date, dateToCompare) => { 55783 return this.overrides?.isAfter ? this.overrides.isAfter(date, dateToCompare) : isAfter2(date, dateToCompare); 55784 }; 55785 this.isBefore = (date, dateToCompare) => { 55786 return this.overrides?.isBefore ? this.overrides.isBefore(date, dateToCompare) : isBefore2(date, dateToCompare); 55787 }; 55788 this.isDate = (value) => { 55789 return this.overrides?.isDate ? this.overrides.isDate(value) : isDate2(value); 55790 }; 55791 this.isSameDay = (dateLeft, dateRight) => { 55792 return this.overrides?.isSameDay ? this.overrides.isSameDay(dateLeft, dateRight) : isSameDay2(dateLeft, dateRight); 55793 }; 55794 this.isSameMonth = (dateLeft, dateRight) => { 55795 return this.overrides?.isSameMonth ? this.overrides.isSameMonth(dateLeft, dateRight) : isSameMonth2(dateLeft, dateRight); 55796 }; 55797 this.isSameYear = (dateLeft, dateRight) => { 55798 return this.overrides?.isSameYear ? this.overrides.isSameYear(dateLeft, dateRight) : isSameYear(dateLeft, dateRight); 55799 }; 55800 this.max = (dates) => { 55801 return this.overrides?.max ? this.overrides.max(dates) : max2(dates); 55802 }; 55803 this.min = (dates) => { 55804 return this.overrides?.min ? this.overrides.min(dates) : min2(dates); 55805 }; 55806 this.setMonth = (date, month) => { 55807 return this.overrides?.setMonth ? this.overrides.setMonth(date, month) : setMonth2(date, month); 55808 }; 55809 this.setYear = (date, year) => { 55810 return this.overrides?.setYear ? this.overrides.setYear(date, year) : setYear2(date, year); 55811 }; 55812 this.startOfBroadcastWeek = (date, dateLib) => { 55813 return this.overrides?.startOfBroadcastWeek ? this.overrides.startOfBroadcastWeek(date, this) : startOfBroadcastWeek(date, this); 55814 }; 55815 this.startOfDay = (date) => { 55816 return this.overrides?.startOfDay ? this.overrides.startOfDay(date) : startOfDay2(date); 55817 }; 55818 this.startOfISOWeek = (date) => { 55819 return this.overrides?.startOfISOWeek ? this.overrides.startOfISOWeek(date) : startOfISOWeek2(date); 55820 }; 55821 this.startOfMonth = (date) => { 55822 return this.overrides?.startOfMonth ? this.overrides.startOfMonth(date) : startOfMonth2(date); 55823 }; 55824 this.startOfWeek = (date, options3) => { 55825 return this.overrides?.startOfWeek ? this.overrides.startOfWeek(date, this.options) : startOfWeek2(date, this.options); 55826 }; 55827 this.startOfYear = (date) => { 55828 return this.overrides?.startOfYear ? this.overrides.startOfYear(date) : startOfYear2(date); 55829 }; 55830 this.options = { locale: enUS2, ...options2 }; 55831 this.overrides = overrides; 55832 } 55833 /** 55834 * Generates a mapping of Arabic digits (0-9) to the target numbering system 55835 * digits. 55836 * 55837 * @since 9.5.0 55838 * @returns A record mapping Arabic digits to the target numerals. 55839 */ 55840 getDigitMap() { 55841 const { numerals = "latn" } = this.options; 55842 const formatter = new Intl.NumberFormat("en-US", { 55843 numberingSystem: numerals 55844 }); 55845 const digitMap = {}; 55846 for (let i3 = 0; i3 < 10; i3++) { 55847 digitMap[i3.toString()] = formatter.format(i3); 55848 } 55849 return digitMap; 55850 } 55851 /** 55852 * Replaces Arabic digits in a string with the target numbering system digits. 55853 * 55854 * @since 9.5.0 55855 * @param input The string containing Arabic digits. 55856 * @returns The string with digits replaced. 55857 */ 55858 replaceDigits(input) { 55859 const digitMap = this.getDigitMap(); 55860 return input.replace(/\d/g, (digit) => digitMap[digit] || digit); 55861 } 55862 /** 55863 * Formats a number using the configured numbering system. 55864 * 55865 * @since 9.5.0 55866 * @param value The number to format. 55867 * @returns The formatted number as a string. 55868 */ 55869 formatNumber(value) { 55870 return this.replaceDigits(value.toString()); 55871 } 55872 }; 55873 var defaultDateLib = new DateLib(); 55874 55875 // node_modules/react-day-picker/dist/esm/classes/CalendarDay.js 55876 var CalendarDay = class { 55877 constructor(date, displayMonth, dateLib = defaultDateLib) { 55878 this.date = date; 55879 this.displayMonth = displayMonth; 55880 this.outside = Boolean(displayMonth && !dateLib.isSameMonth(date, displayMonth)); 55881 this.dateLib = dateLib; 55882 } 55883 /** 55884 * Checks if this day is equal to another `CalendarDay`, considering both the 55885 * date and the displayed month. 55886 * 55887 * @param day The `CalendarDay` to compare with. 55888 * @returns `true` if the days are equal, otherwise `false`. 55889 */ 55890 isEqualTo(day) { 55891 return this.dateLib.isSameDay(day.date, this.date) && this.dateLib.isSameMonth(day.displayMonth, this.displayMonth); 55892 } 55893 }; 55894 55895 // node_modules/react-day-picker/dist/esm/classes/CalendarMonth.js 55896 var CalendarMonth = class { 55897 constructor(month, weeks) { 55898 this.date = month; 55899 this.weeks = weeks; 55900 } 55901 }; 55902 55903 // node_modules/react-day-picker/dist/esm/classes/CalendarWeek.js 55904 var CalendarWeek = class { 55905 constructor(weekNumber, days) { 55906 this.days = days; 55907 this.weekNumber = weekNumber; 55908 } 55909 }; 55910 55911 // node_modules/react-day-picker/dist/esm/utils/rangeIncludesDate.js 55912 function rangeIncludesDate(range, date, excludeEnds = false, dateLib = defaultDateLib) { 55913 let { from: from2, to } = range; 55914 const { differenceInCalendarDays: differenceInCalendarDays3, isSameDay: isSameDay3 } = dateLib; 55915 if (from2 && to) { 55916 const isRangeInverted = differenceInCalendarDays3(to, from2) < 0; 55917 if (isRangeInverted) { 55918 [from2, to] = [to, from2]; 55919 } 55920 const isInRange = differenceInCalendarDays3(date, from2) >= (excludeEnds ? 1 : 0) && differenceInCalendarDays3(to, date) >= (excludeEnds ? 1 : 0); 55921 return isInRange; 55922 } 55923 if (!excludeEnds && to) { 55924 return isSameDay3(to, date); 55925 } 55926 if (!excludeEnds && from2) { 55927 return isSameDay3(from2, date); 55928 } 55929 return false; 55930 } 55931 55932 // node_modules/react-day-picker/dist/esm/utils/typeguards.js 55933 function isDateInterval(matcher) { 55934 return Boolean(matcher && typeof matcher === "object" && "before" in matcher && "after" in matcher); 55935 } 55936 function isDateRange(value) { 55937 return Boolean(value && typeof value === "object" && "from" in value); 55938 } 55939 function isDateAfterType(value) { 55940 return Boolean(value && typeof value === "object" && "after" in value); 55941 } 55942 function isDateBeforeType(value) { 55943 return Boolean(value && typeof value === "object" && "before" in value); 55944 } 55945 function isDayOfWeekType(value) { 55946 return Boolean(value && typeof value === "object" && "dayOfWeek" in value); 55947 } 55948 function isDatesArray(value, dateLib) { 55949 return Array.isArray(value) && value.every(dateLib.isDate); 55950 } 55951 55952 // node_modules/react-day-picker/dist/esm/utils/dateMatchModifiers.js 55953 function dateMatchModifiers(date, matchers, dateLib = defaultDateLib) { 55954 const matchersArr = !Array.isArray(matchers) ? [matchers] : matchers; 55955 const { isSameDay: isSameDay3, differenceInCalendarDays: differenceInCalendarDays3, isAfter: isAfter3 } = dateLib; 55956 return matchersArr.some((matcher) => { 55957 if (typeof matcher === "boolean") { 55958 return matcher; 55959 } 55960 if (dateLib.isDate(matcher)) { 55961 return isSameDay3(date, matcher); 55962 } 55963 if (isDatesArray(matcher, dateLib)) { 55964 return matcher.includes(date); 55965 } 55966 if (isDateRange(matcher)) { 55967 return rangeIncludesDate(matcher, date, false, dateLib); 55968 } 55969 if (isDayOfWeekType(matcher)) { 55970 if (!Array.isArray(matcher.dayOfWeek)) { 55971 return matcher.dayOfWeek === date.getDay(); 55972 } 55973 return matcher.dayOfWeek.includes(date.getDay()); 55974 } 55975 if (isDateInterval(matcher)) { 55976 const diffBefore = differenceInCalendarDays3(matcher.before, date); 55977 const diffAfter = differenceInCalendarDays3(matcher.after, date); 55978 const isDayBefore = diffBefore > 0; 55979 const isDayAfter = diffAfter < 0; 55980 const isClosedInterval = isAfter3(matcher.before, matcher.after); 55981 if (isClosedInterval) { 55982 return isDayAfter && isDayBefore; 55983 } else { 55984 return isDayBefore || isDayAfter; 55985 } 55986 } 55987 if (isDateAfterType(matcher)) { 55988 return differenceInCalendarDays3(date, matcher.after) > 0; 55989 } 55990 if (isDateBeforeType(matcher)) { 55991 return differenceInCalendarDays3(matcher.before, date) > 0; 55992 } 55993 if (typeof matcher === "function") { 55994 return matcher(date); 55995 } 55996 return false; 55997 }); 55998 } 55999 56000 // node_modules/react-day-picker/dist/esm/helpers/createGetModifiers.js 56001 function createGetModifiers(days, props, dateLib) { 56002 const { disabled, hidden, modifiers, showOutsideDays, broadcastCalendar, today } = props; 56003 const { isSameDay: isSameDay3, isSameMonth: isSameMonth3, startOfMonth: startOfMonth3, isBefore: isBefore3, endOfMonth: endOfMonth3, isAfter: isAfter3 } = dateLib; 56004 const startMonth = props.startMonth && startOfMonth3(props.startMonth); 56005 const endMonth = props.endMonth && endOfMonth3(props.endMonth); 56006 const internalModifiersMap = { 56007 [DayFlag.focused]: [], 56008 [DayFlag.outside]: [], 56009 [DayFlag.disabled]: [], 56010 [DayFlag.hidden]: [], 56011 [DayFlag.today]: [] 56012 }; 56013 const customModifiersMap = {}; 56014 for (const day of days) { 56015 const { date, displayMonth } = day; 56016 const isOutside = Boolean(displayMonth && !isSameMonth3(date, displayMonth)); 56017 const isBeforeStartMonth = Boolean(startMonth && isBefore3(date, startMonth)); 56018 const isAfterEndMonth = Boolean(endMonth && isAfter3(date, endMonth)); 56019 const isDisabled = Boolean(disabled && dateMatchModifiers(date, disabled, dateLib)); 56020 const isHidden2 = Boolean(hidden && dateMatchModifiers(date, hidden, dateLib)) || isBeforeStartMonth || isAfterEndMonth || // Broadcast calendar will show outside days as default 56021 !broadcastCalendar && !showOutsideDays && isOutside || broadcastCalendar && showOutsideDays === false && isOutside; 56022 const isToday = isSameDay3(date, today ?? dateLib.today()); 56023 if (isOutside) 56024 internalModifiersMap.outside.push(day); 56025 if (isDisabled) 56026 internalModifiersMap.disabled.push(day); 56027 if (isHidden2) 56028 internalModifiersMap.hidden.push(day); 56029 if (isToday) 56030 internalModifiersMap.today.push(day); 56031 if (modifiers) { 56032 Object.keys(modifiers).forEach((name) => { 56033 const modifierValue = modifiers?.[name]; 56034 const isMatch = modifierValue ? dateMatchModifiers(date, modifierValue, dateLib) : false; 56035 if (!isMatch) 56036 return; 56037 if (customModifiersMap[name]) { 56038 customModifiersMap[name].push(day); 56039 } else { 56040 customModifiersMap[name] = [day]; 56041 } 56042 }); 56043 } 56044 } 56045 return (day) => { 56046 const dayFlags = { 56047 [DayFlag.focused]: false, 56048 [DayFlag.disabled]: false, 56049 [DayFlag.hidden]: false, 56050 [DayFlag.outside]: false, 56051 [DayFlag.today]: false 56052 }; 56053 const customModifiers = {}; 56054 for (const name in internalModifiersMap) { 56055 const days2 = internalModifiersMap[name]; 56056 dayFlags[name] = days2.some((d3) => d3 === day); 56057 } 56058 for (const name in customModifiersMap) { 56059 customModifiers[name] = customModifiersMap[name].some((d3) => d3 === day); 56060 } 56061 return { 56062 ...dayFlags, 56063 // custom modifiers should override all the previous ones 56064 ...customModifiers 56065 }; 56066 }; 56067 } 56068 56069 // node_modules/react-day-picker/dist/esm/helpers/getClassNamesForModifiers.js 56070 function getClassNamesForModifiers(modifiers, classNames, modifiersClassNames = {}) { 56071 const modifierClassNames = Object.entries(modifiers).filter(([, active]) => active === true).reduce((previousValue, [key]) => { 56072 if (modifiersClassNames[key]) { 56073 previousValue.push(modifiersClassNames[key]); 56074 } else if (classNames[DayFlag[key]]) { 56075 previousValue.push(classNames[DayFlag[key]]); 56076 } else if (classNames[SelectionState[key]]) { 56077 previousValue.push(classNames[SelectionState[key]]); 56078 } 56079 return previousValue; 56080 }, [classNames[UI2.Day]]); 56081 return modifierClassNames; 56082 } 56083 56084 // node_modules/react-day-picker/dist/esm/components/custom-components.js 56085 var custom_components_exports = {}; 56086 __export(custom_components_exports, { 56087 Button: () => Button4, 56088 CaptionLabel: () => CaptionLabel, 56089 Chevron: () => Chevron, 56090 Day: () => Day3, 56091 DayButton: () => DayButton2, 56092 Dropdown: () => Dropdown2, 56093 DropdownNav: () => DropdownNav, 56094 Footer: () => Footer2, 56095 Month: () => Month, 56096 MonthCaption: () => MonthCaption, 56097 MonthGrid: () => MonthGrid, 56098 Months: () => Months, 56099 MonthsDropdown: () => MonthsDropdown, 56100 Nav: () => Nav, 56101 NextMonthButton: () => NextMonthButton, 56102 Option: () => Option3, 56103 PreviousMonthButton: () => PreviousMonthButton, 56104 Root: () => Root5, 56105 Select: () => Select4, 56106 Week: () => Week, 56107 WeekNumber: () => WeekNumber, 56108 WeekNumberHeader: () => WeekNumberHeader, 56109 Weekday: () => Weekday, 56110 Weekdays: () => Weekdays, 56111 Weeks: () => Weeks, 56112 YearsDropdown: () => YearsDropdown 56113 }); 56114 56115 // node_modules/react-day-picker/dist/esm/components/Button.js 56116 var import_react134 = __toESM(require_react(), 1); 56117 function Button4(props) { 56118 return import_react134.default.createElement("button", { ...props }); 56119 } 56120 56121 // node_modules/react-day-picker/dist/esm/components/CaptionLabel.js 56122 var import_react135 = __toESM(require_react(), 1); 56123 function CaptionLabel(props) { 56124 return import_react135.default.createElement("span", { ...props }); 56125 } 56126 56127 // node_modules/react-day-picker/dist/esm/components/Chevron.js 56128 var import_react136 = __toESM(require_react(), 1); 56129 function Chevron(props) { 56130 const { size: size3 = 24, orientation = "left", className: className2 } = props; 56131 return import_react136.default.createElement( 56132 "svg", 56133 { className: className2, width: size3, height: size3, viewBox: "0 0 24 24" }, 56134 orientation === "up" && import_react136.default.createElement("polygon", { points: "6.77 17 12.5 11.43 18.24 17 20 15.28 12.5 8 5 15.28" }), 56135 orientation === "down" && import_react136.default.createElement("polygon", { points: "6.77 8 12.5 13.57 18.24 8 20 9.72 12.5 17 5 9.72" }), 56136 orientation === "left" && import_react136.default.createElement("polygon", { points: "16 18.112 9.81111111 12 16 5.87733333 14.0888889 4 6 12 14.0888889 20" }), 56137 orientation === "right" && import_react136.default.createElement("polygon", { points: "8 18.112 14.18888889 12 8 5.87733333 9.91111111 4 18 12 9.91111111 20" }) 56138 ); 56139 } 56140 56141 // node_modules/react-day-picker/dist/esm/components/Day.js 56142 var import_react137 = __toESM(require_react(), 1); 56143 function Day3(props) { 56144 const { day, modifiers, ...tdProps } = props; 56145 return import_react137.default.createElement("td", { ...tdProps }); 56146 } 56147 56148 // node_modules/react-day-picker/dist/esm/components/DayButton.js 56149 var import_react138 = __toESM(require_react(), 1); 56150 function DayButton2(props) { 56151 const { day, modifiers, ...buttonProps } = props; 56152 const ref = import_react138.default.useRef(null); 56153 import_react138.default.useEffect(() => { 56154 if (modifiers.focused) 56155 ref.current?.focus(); 56156 }, [modifiers.focused]); 56157 return import_react138.default.createElement("button", { ref, ...buttonProps }); 56158 } 56159 56160 // node_modules/react-day-picker/dist/esm/components/Dropdown.js 56161 var import_react139 = __toESM(require_react(), 1); 56162 function Dropdown2(props) { 56163 const { options: options2, className: className2, components, classNames, ...selectProps } = props; 56164 const cssClassSelect = [classNames[UI2.Dropdown], className2].join(" "); 56165 const selectedOption = options2?.find(({ value }) => value === selectProps.value); 56166 return import_react139.default.createElement( 56167 "span", 56168 { "data-disabled": selectProps.disabled, className: classNames[UI2.DropdownRoot] }, 56169 import_react139.default.createElement(components.Select, { className: cssClassSelect, ...selectProps }, options2?.map(({ value, label, disabled }) => import_react139.default.createElement(components.Option, { key: value, value, disabled }, label))), 56170 import_react139.default.createElement( 56171 "span", 56172 { className: classNames[UI2.CaptionLabel], "aria-hidden": true }, 56173 selectedOption?.label, 56174 import_react139.default.createElement(components.Chevron, { orientation: "down", size: 18, className: classNames[UI2.Chevron] }) 56175 ) 56176 ); 56177 } 56178 56179 // node_modules/react-day-picker/dist/esm/components/DropdownNav.js 56180 var import_react140 = __toESM(require_react(), 1); 56181 function DropdownNav(props) { 56182 return import_react140.default.createElement("div", { ...props }); 56183 } 56184 56185 // node_modules/react-day-picker/dist/esm/components/Footer.js 56186 var import_react141 = __toESM(require_react(), 1); 56187 function Footer2(props) { 56188 return import_react141.default.createElement("div", { ...props }); 56189 } 56190 56191 // node_modules/react-day-picker/dist/esm/components/Month.js 56192 var import_react142 = __toESM(require_react(), 1); 56193 function Month(props) { 56194 const { calendarMonth, displayIndex, ...divProps } = props; 56195 return import_react142.default.createElement("div", { ...divProps }, props.children); 56196 } 56197 56198 // node_modules/react-day-picker/dist/esm/components/MonthCaption.js 56199 var import_react143 = __toESM(require_react(), 1); 56200 function MonthCaption(props) { 56201 const { calendarMonth, displayIndex, ...divProps } = props; 56202 return import_react143.default.createElement("div", { ...divProps }); 56203 } 56204 56205 // node_modules/react-day-picker/dist/esm/components/MonthGrid.js 56206 var import_react144 = __toESM(require_react(), 1); 56207 function MonthGrid(props) { 56208 return import_react144.default.createElement("table", { ...props }); 56209 } 56210 56211 // node_modules/react-day-picker/dist/esm/components/Months.js 56212 var import_react145 = __toESM(require_react(), 1); 56213 function Months(props) { 56214 return import_react145.default.createElement("div", { ...props }); 56215 } 56216 56217 // node_modules/react-day-picker/dist/esm/components/MonthsDropdown.js 56218 var import_react147 = __toESM(require_react(), 1); 56219 56220 // node_modules/react-day-picker/dist/esm/useDayPicker.js 56221 var import_react146 = __toESM(require_react(), 1); 56222 var dayPickerContext = (0, import_react146.createContext)(void 0); 56223 function useDayPicker() { 56224 const context = (0, import_react146.useContext)(dayPickerContext); 56225 if (context === void 0) { 56226 throw new Error("useDayPicker() must be used within a custom component."); 56227 } 56228 return context; 56229 } 56230 56231 // node_modules/react-day-picker/dist/esm/components/MonthsDropdown.js 56232 function MonthsDropdown(props) { 56233 const { components } = useDayPicker(); 56234 return import_react147.default.createElement(components.Dropdown, { ...props }); 56235 } 56236 56237 // node_modules/react-day-picker/dist/esm/components/Nav.js 56238 var import_react148 = __toESM(require_react(), 1); 56239 function Nav(props) { 56240 const { onPreviousClick, onNextClick, previousMonth, nextMonth, ...navProps } = props; 56241 const { components, classNames, labels: { labelPrevious: labelPrevious2, labelNext: labelNext2 } } = useDayPicker(); 56242 const handleNextClick = (0, import_react148.useCallback)((e3) => { 56243 if (nextMonth) { 56244 onNextClick?.(e3); 56245 } 56246 }, [nextMonth, onNextClick]); 56247 const handlePreviousClick = (0, import_react148.useCallback)((e3) => { 56248 if (previousMonth) { 56249 onPreviousClick?.(e3); 56250 } 56251 }, [previousMonth, onPreviousClick]); 56252 return import_react148.default.createElement( 56253 "nav", 56254 { ...navProps }, 56255 import_react148.default.createElement( 56256 components.PreviousMonthButton, 56257 { type: "button", className: classNames[UI2.PreviousMonthButton], tabIndex: previousMonth ? void 0 : -1, "aria-disabled": previousMonth ? void 0 : true, "aria-label": labelPrevious2(previousMonth), onClick: handlePreviousClick }, 56258 import_react148.default.createElement(components.Chevron, { disabled: previousMonth ? void 0 : true, className: classNames[UI2.Chevron], orientation: "left" }) 56259 ), 56260 import_react148.default.createElement( 56261 components.NextMonthButton, 56262 { type: "button", className: classNames[UI2.NextMonthButton], tabIndex: nextMonth ? void 0 : -1, "aria-disabled": nextMonth ? void 0 : true, "aria-label": labelNext2(nextMonth), onClick: handleNextClick }, 56263 import_react148.default.createElement(components.Chevron, { disabled: nextMonth ? void 0 : true, orientation: "right", className: classNames[UI2.Chevron] }) 56264 ) 56265 ); 56266 } 56267 56268 // node_modules/react-day-picker/dist/esm/components/NextMonthButton.js 56269 var import_react149 = __toESM(require_react(), 1); 56270 function NextMonthButton(props) { 56271 const { components } = useDayPicker(); 56272 return import_react149.default.createElement(components.Button, { ...props }); 56273 } 56274 56275 // node_modules/react-day-picker/dist/esm/components/Option.js 56276 var import_react150 = __toESM(require_react(), 1); 56277 function Option3(props) { 56278 return import_react150.default.createElement("option", { ...props }); 56279 } 56280 56281 // node_modules/react-day-picker/dist/esm/components/PreviousMonthButton.js 56282 var import_react151 = __toESM(require_react(), 1); 56283 function PreviousMonthButton(props) { 56284 const { components } = useDayPicker(); 56285 return import_react151.default.createElement(components.Button, { ...props }); 56286 } 56287 56288 // node_modules/react-day-picker/dist/esm/components/Root.js 56289 var import_react152 = __toESM(require_react(), 1); 56290 function Root5(props) { 56291 const { rootRef, ...rest } = props; 56292 return import_react152.default.createElement("div", { ...rest, ref: rootRef }); 56293 } 56294 56295 // node_modules/react-day-picker/dist/esm/components/Select.js 56296 var import_react153 = __toESM(require_react(), 1); 56297 function Select4(props) { 56298 return import_react153.default.createElement("select", { ...props }); 56299 } 56300 56301 // node_modules/react-day-picker/dist/esm/components/Week.js 56302 var import_react154 = __toESM(require_react(), 1); 56303 function Week(props) { 56304 const { week, ...trProps } = props; 56305 return import_react154.default.createElement("tr", { ...trProps }); 56306 } 56307 56308 // node_modules/react-day-picker/dist/esm/components/Weekday.js 56309 var import_react155 = __toESM(require_react(), 1); 56310 function Weekday(props) { 56311 return import_react155.default.createElement("th", { ...props }); 56312 } 56313 56314 // node_modules/react-day-picker/dist/esm/components/Weekdays.js 56315 var import_react156 = __toESM(require_react(), 1); 56316 function Weekdays(props) { 56317 return import_react156.default.createElement( 56318 "thead", 56319 { "aria-hidden": true }, 56320 import_react156.default.createElement("tr", { ...props }) 56321 ); 56322 } 56323 56324 // node_modules/react-day-picker/dist/esm/components/WeekNumber.js 56325 var import_react157 = __toESM(require_react(), 1); 56326 function WeekNumber(props) { 56327 const { week, ...thProps } = props; 56328 return import_react157.default.createElement("th", { ...thProps }); 56329 } 56330 56331 // node_modules/react-day-picker/dist/esm/components/WeekNumberHeader.js 56332 var import_react158 = __toESM(require_react(), 1); 56333 function WeekNumberHeader(props) { 56334 return import_react158.default.createElement("th", { ...props }); 56335 } 56336 56337 // node_modules/react-day-picker/dist/esm/components/Weeks.js 56338 var import_react159 = __toESM(require_react(), 1); 56339 function Weeks(props) { 56340 return import_react159.default.createElement("tbody", { ...props }); 56341 } 56342 56343 // node_modules/react-day-picker/dist/esm/components/YearsDropdown.js 56344 var import_react160 = __toESM(require_react(), 1); 56345 function YearsDropdown(props) { 56346 const { components } = useDayPicker(); 56347 return import_react160.default.createElement(components.Dropdown, { ...props }); 56348 } 56349 56350 // node_modules/react-day-picker/dist/esm/helpers/getComponents.js 56351 function getComponents(customComponents) { 56352 return { 56353 ...custom_components_exports, 56354 ...customComponents 56355 }; 56356 } 56357 56358 // node_modules/react-day-picker/dist/esm/helpers/getDataAttributes.js 56359 function getDataAttributes(props) { 56360 const dataAttributes = { 56361 "data-mode": props.mode ?? void 0, 56362 "data-required": "required" in props ? props.required : void 0, 56363 "data-multiple-months": props.numberOfMonths && props.numberOfMonths > 1 || void 0, 56364 "data-week-numbers": props.showWeekNumber || void 0, 56365 "data-broadcast-calendar": props.broadcastCalendar || void 0, 56366 "data-nav-layout": props.navLayout || void 0 56367 }; 56368 Object.entries(props).forEach(([key, val]) => { 56369 if (key.startsWith("data-")) { 56370 dataAttributes[key] = val; 56371 } 56372 }); 56373 return dataAttributes; 56374 } 56375 56376 // node_modules/react-day-picker/dist/esm/helpers/getDefaultClassNames.js 56377 function getDefaultClassNames() { 56378 const classNames = {}; 56379 for (const key in UI2) { 56380 classNames[UI2[key]] = `rdp-$UI2[key]}`; 56381 } 56382 for (const key in DayFlag) { 56383 classNames[DayFlag[key]] = `rdp-$DayFlag[key]}`; 56384 } 56385 for (const key in SelectionState) { 56386 classNames[SelectionState[key]] = `rdp-$SelectionState[key]}`; 56387 } 56388 for (const key in Animation) { 56389 classNames[Animation[key]] = `rdp-$Animation[key]}`; 56390 } 56391 return classNames; 56392 } 56393 56394 // node_modules/react-day-picker/dist/esm/formatters/index.js 56395 var formatters_exports = {}; 56396 __export(formatters_exports, { 56397 formatCaption: () => formatCaption, 56398 formatDay: () => formatDay, 56399 formatMonthCaption: () => formatMonthCaption, 56400 formatMonthDropdown: () => formatMonthDropdown, 56401 formatWeekNumber: () => formatWeekNumber, 56402 formatWeekNumberHeader: () => formatWeekNumberHeader, 56403 formatWeekdayName: () => formatWeekdayName, 56404 formatYearCaption: () => formatYearCaption, 56405 formatYearDropdown: () => formatYearDropdown 56406 }); 56407 56408 // node_modules/react-day-picker/dist/esm/formatters/formatCaption.js 56409 function formatCaption(month, options2, dateLib) { 56410 return (dateLib ?? new DateLib(options2)).format(month, "LLLL y"); 56411 } 56412 var formatMonthCaption = formatCaption; 56413 56414 // node_modules/react-day-picker/dist/esm/formatters/formatDay.js 56415 function formatDay(date, options2, dateLib) { 56416 return (dateLib ?? new DateLib(options2)).format(date, "d"); 56417 } 56418 56419 // node_modules/react-day-picker/dist/esm/formatters/formatMonthDropdown.js 56420 function formatMonthDropdown(month, dateLib = defaultDateLib) { 56421 return dateLib.format(month, "LLLL"); 56422 } 56423 56424 // node_modules/react-day-picker/dist/esm/formatters/formatWeekNumber.js 56425 function formatWeekNumber(weekNumber, dateLib = defaultDateLib) { 56426 if (weekNumber < 10) { 56427 return dateLib.formatNumber(`0$weekNumber.toLocaleString()}`); 56428 } 56429 return dateLib.formatNumber(`$weekNumber.toLocaleString()}`); 56430 } 56431 56432 // node_modules/react-day-picker/dist/esm/formatters/formatWeekNumberHeader.js 56433 function formatWeekNumberHeader() { 56434 return ``; 56435 } 56436 56437 // node_modules/react-day-picker/dist/esm/formatters/formatWeekdayName.js 56438 function formatWeekdayName(weekday, options2, dateLib) { 56439 return (dateLib ?? new DateLib(options2)).format(weekday, "cccccc"); 56440 } 56441 56442 // node_modules/react-day-picker/dist/esm/formatters/formatYearDropdown.js 56443 function formatYearDropdown(year, dateLib = defaultDateLib) { 56444 return dateLib.format(year, "yyyy"); 56445 } 56446 var formatYearCaption = formatYearDropdown; 56447 56448 // node_modules/react-day-picker/dist/esm/helpers/getFormatters.js 56449 function getFormatters(customFormatters) { 56450 if (customFormatters?.formatMonthCaption && !customFormatters.formatCaption) { 56451 customFormatters.formatCaption = customFormatters.formatMonthCaption; 56452 } 56453 if (customFormatters?.formatYearCaption && !customFormatters.formatYearDropdown) { 56454 customFormatters.formatYearDropdown = customFormatters.formatYearCaption; 56455 } 56456 return { 56457 ...formatters_exports, 56458 ...customFormatters 56459 }; 56460 } 56461 56462 // node_modules/react-day-picker/dist/esm/helpers/getMonthOptions.js 56463 function getMonthOptions(displayMonth, navStart, navEnd, formatters3, dateLib) { 56464 const { startOfMonth: startOfMonth3, startOfYear: startOfYear3, endOfYear: endOfYear2, eachMonthOfInterval: eachMonthOfInterval3, getMonth: getMonth2 } = dateLib; 56465 const months = eachMonthOfInterval3({ 56466 start: startOfYear3(displayMonth), 56467 end: endOfYear2(displayMonth) 56468 }); 56469 const options2 = months.map((month) => { 56470 const label = formatters3.formatMonthDropdown(month, dateLib); 56471 const value = getMonth2(month); 56472 const disabled = navStart && month < startOfMonth3(navStart) || navEnd && month > startOfMonth3(navEnd) || false; 56473 return { value, label, disabled }; 56474 }); 56475 return options2; 56476 } 56477 56478 // node_modules/react-day-picker/dist/esm/helpers/getStyleForModifiers.js 56479 function getStyleForModifiers(dayModifiers, styles3 = {}, modifiersStyles = {}) { 56480 let style2 = { ...styles3?.[UI2.Day] }; 56481 Object.entries(dayModifiers).filter(([, active]) => active === true).forEach(([modifier]) => { 56482 style2 = { 56483 ...style2, 56484 ...modifiersStyles?.[modifier] 56485 }; 56486 }); 56487 return style2; 56488 } 56489 56490 // node_modules/react-day-picker/dist/esm/helpers/getWeekdays.js 56491 function getWeekdays(dateLib, ISOWeek, broadcastCalendar) { 56492 const today = dateLib.today(); 56493 const start = broadcastCalendar ? dateLib.startOfBroadcastWeek(today, dateLib) : ISOWeek ? dateLib.startOfISOWeek(today) : dateLib.startOfWeek(today); 56494 const days = []; 56495 for (let i3 = 0; i3 < 7; i3++) { 56496 const day = dateLib.addDays(start, i3); 56497 days.push(day); 56498 } 56499 return days; 56500 } 56501 56502 // node_modules/react-day-picker/dist/esm/helpers/getYearOptions.js 56503 function getYearOptions(navStart, navEnd, formatters3, dateLib) { 56504 if (!navStart) 56505 return void 0; 56506 if (!navEnd) 56507 return void 0; 56508 const { startOfYear: startOfYear3, endOfYear: endOfYear2, addYears: addYears3, getYear: getYear2, isBefore: isBefore3, isSameYear: isSameYear2 } = dateLib; 56509 const firstNavYear = startOfYear3(navStart); 56510 const lastNavYear = endOfYear2(navEnd); 56511 const years = []; 56512 let year = firstNavYear; 56513 while (isBefore3(year, lastNavYear) || isSameYear2(year, lastNavYear)) { 56514 years.push(year); 56515 year = addYears3(year, 1); 56516 } 56517 return years.map((year2) => { 56518 const label = formatters3.formatYearDropdown(year2, dateLib); 56519 return { 56520 value: getYear2(year2), 56521 label, 56522 disabled: false 56523 }; 56524 }); 56525 } 56526 56527 // node_modules/react-day-picker/dist/esm/labels/index.js 56528 var labels_exports = {}; 56529 __export(labels_exports, { 56530 labelCaption: () => labelCaption, 56531 labelDay: () => labelDay, 56532 labelDayButton: () => labelDayButton, 56533 labelGrid: () => labelGrid, 56534 labelGridcell: () => labelGridcell, 56535 labelMonthDropdown: () => labelMonthDropdown, 56536 labelNav: () => labelNav, 56537 labelNext: () => labelNext, 56538 labelPrevious: () => labelPrevious, 56539 labelWeekNumber: () => labelWeekNumber, 56540 labelWeekNumberHeader: () => labelWeekNumberHeader, 56541 labelWeekday: () => labelWeekday, 56542 labelYearDropdown: () => labelYearDropdown 56543 }); 56544 56545 // node_modules/react-day-picker/dist/esm/labels/labelGrid.js 56546 function labelGrid(date, options2, dateLib) { 56547 return (dateLib ?? new DateLib(options2)).format(date, "LLLL y"); 56548 } 56549 var labelCaption = labelGrid; 56550 56551 // node_modules/react-day-picker/dist/esm/labels/labelGridcell.js 56552 function labelGridcell(date, modifiers, options2, dateLib) { 56553 let label = (dateLib ?? new DateLib(options2)).format(date, "PPPP"); 56554 if (modifiers?.today) { 56555 label = `Today, $label}`; 56556 } 56557 return label; 56558 } 56559 56560 // node_modules/react-day-picker/dist/esm/labels/labelDayButton.js 56561 function labelDayButton(date, modifiers, options2, dateLib) { 56562 let label = (dateLib ?? new DateLib(options2)).format(date, "PPPP"); 56563 if (modifiers.today) 56564 label = `Today, $label}`; 56565 if (modifiers.selected) 56566 label = `$label}, selected`; 56567 return label; 56568 } 56569 var labelDay = labelDayButton; 56570 56571 // node_modules/react-day-picker/dist/esm/labels/labelNav.js 56572 function labelNav() { 56573 return ""; 56574 } 56575 56576 // node_modules/react-day-picker/dist/esm/labels/labelMonthDropdown.js 56577 function labelMonthDropdown(options2) { 56578 return "Choose the Month"; 56579 } 56580 56581 // node_modules/react-day-picker/dist/esm/labels/labelNext.js 56582 function labelNext(month) { 56583 return "Go to the Next Month"; 56584 } 56585 56586 // node_modules/react-day-picker/dist/esm/labels/labelPrevious.js 56587 function labelPrevious(month) { 56588 return "Go to the Previous Month"; 56589 } 56590 56591 // node_modules/react-day-picker/dist/esm/labels/labelWeekday.js 56592 function labelWeekday(date, options2, dateLib) { 56593 return (dateLib ?? new DateLib(options2)).format(date, "cccc"); 56594 } 56595 56596 // node_modules/react-day-picker/dist/esm/labels/labelWeekNumber.js 56597 function labelWeekNumber(weekNumber, options2) { 56598 return `Week $weekNumber}`; 56599 } 56600 56601 // node_modules/react-day-picker/dist/esm/labels/labelWeekNumberHeader.js 56602 function labelWeekNumberHeader(options2) { 56603 return "Week Number"; 56604 } 56605 56606 // node_modules/react-day-picker/dist/esm/labels/labelYearDropdown.js 56607 function labelYearDropdown(options2) { 56608 return "Choose the Year"; 56609 } 56610 56611 // node_modules/react-day-picker/dist/esm/useAnimation.js 56612 var import_react161 = __toESM(require_react(), 1); 56613 var asHtmlElement = (element) => { 56614 if (element instanceof HTMLElement) 56615 return element; 56616 return null; 56617 }; 56618 var queryMonthEls = (element) => [ 56619 ...element.querySelectorAll("[data-animated-month]") ?? [] 56620 ]; 56621 var queryMonthEl = (element) => asHtmlElement(element.querySelector("[data-animated-month]")); 56622 var queryCaptionEl = (element) => asHtmlElement(element.querySelector("[data-animated-caption]")); 56623 var queryWeeksEl = (element) => asHtmlElement(element.querySelector("[data-animated-weeks]")); 56624 var queryNavEl = (element) => asHtmlElement(element.querySelector("[data-animated-nav]")); 56625 var queryWeekdaysEl = (element) => asHtmlElement(element.querySelector("[data-animated-weekdays]")); 56626 function useAnimation(rootElRef, enabled, { classNames, months, focused, dateLib }) { 56627 const previousRootElSnapshotRef = (0, import_react161.useRef)(null); 56628 const previousMonthsRef = (0, import_react161.useRef)(months); 56629 const animatingRef = (0, import_react161.useRef)(false); 56630 (0, import_react161.useLayoutEffect)(() => { 56631 const previousMonths = previousMonthsRef.current; 56632 previousMonthsRef.current = months; 56633 if (!enabled || !rootElRef.current || // safety check because the ref can be set to anything by consumers 56634 !(rootElRef.current instanceof HTMLElement) || // validation required for the animation to work as expected 56635 months.length === 0 || previousMonths.length === 0 || months.length !== previousMonths.length) { 56636 return; 56637 } 56638 const isSameMonth3 = dateLib.isSameMonth(months[0].date, previousMonths[0].date); 56639 const isAfterPreviousMonth = dateLib.isAfter(months[0].date, previousMonths[0].date); 56640 const captionAnimationClass = isAfterPreviousMonth ? classNames[Animation.caption_after_enter] : classNames[Animation.caption_before_enter]; 56641 const weeksAnimationClass = isAfterPreviousMonth ? classNames[Animation.weeks_after_enter] : classNames[Animation.weeks_before_enter]; 56642 const previousRootElSnapshot = previousRootElSnapshotRef.current; 56643 const rootElSnapshot = rootElRef.current.cloneNode(true); 56644 if (rootElSnapshot instanceof HTMLElement) { 56645 const currentMonthElsSnapshot = queryMonthEls(rootElSnapshot); 56646 currentMonthElsSnapshot.forEach((currentMonthElSnapshot) => { 56647 if (!(currentMonthElSnapshot instanceof HTMLElement)) 56648 return; 56649 const previousMonthElSnapshot = queryMonthEl(currentMonthElSnapshot); 56650 if (previousMonthElSnapshot && currentMonthElSnapshot.contains(previousMonthElSnapshot)) { 56651 currentMonthElSnapshot.removeChild(previousMonthElSnapshot); 56652 } 56653 const captionEl = queryCaptionEl(currentMonthElSnapshot); 56654 if (captionEl) { 56655 captionEl.classList.remove(captionAnimationClass); 56656 } 56657 const weeksEl = queryWeeksEl(currentMonthElSnapshot); 56658 if (weeksEl) { 56659 weeksEl.classList.remove(weeksAnimationClass); 56660 } 56661 }); 56662 previousRootElSnapshotRef.current = rootElSnapshot; 56663 } else { 56664 previousRootElSnapshotRef.current = null; 56665 } 56666 if (animatingRef.current || isSameMonth3 || // skip animation if a day is focused because it can cause issues to the animation and is better for a11y 56667 focused) { 56668 return; 56669 } 56670 const previousMonthEls = previousRootElSnapshot instanceof HTMLElement ? queryMonthEls(previousRootElSnapshot) : []; 56671 const currentMonthEls = queryMonthEls(rootElRef.current); 56672 if (currentMonthEls && currentMonthEls.every((el) => el instanceof HTMLElement) && previousMonthEls && previousMonthEls.every((el) => el instanceof HTMLElement)) { 56673 animatingRef.current = true; 56674 const cleanUpFunctions = []; 56675 rootElRef.current.style.isolation = "isolate"; 56676 const navEl = queryNavEl(rootElRef.current); 56677 if (navEl) { 56678 navEl.style.zIndex = "1"; 56679 } 56680 currentMonthEls.forEach((currentMonthEl, index2) => { 56681 const previousMonthEl = previousMonthEls[index2]; 56682 if (!previousMonthEl) { 56683 return; 56684 } 56685 currentMonthEl.style.position = "relative"; 56686 currentMonthEl.style.overflow = "hidden"; 56687 const captionEl = queryCaptionEl(currentMonthEl); 56688 if (captionEl) { 56689 captionEl.classList.add(captionAnimationClass); 56690 } 56691 const weeksEl = queryWeeksEl(currentMonthEl); 56692 if (weeksEl) { 56693 weeksEl.classList.add(weeksAnimationClass); 56694 } 56695 const cleanUp = () => { 56696 animatingRef.current = false; 56697 if (rootElRef.current) { 56698 rootElRef.current.style.isolation = ""; 56699 } 56700 if (navEl) { 56701 navEl.style.zIndex = ""; 56702 } 56703 if (captionEl) { 56704 captionEl.classList.remove(captionAnimationClass); 56705 } 56706 if (weeksEl) { 56707 weeksEl.classList.remove(weeksAnimationClass); 56708 } 56709 currentMonthEl.style.position = ""; 56710 currentMonthEl.style.overflow = ""; 56711 if (currentMonthEl.contains(previousMonthEl)) { 56712 currentMonthEl.removeChild(previousMonthEl); 56713 } 56714 }; 56715 cleanUpFunctions.push(cleanUp); 56716 previousMonthEl.style.pointerEvents = "none"; 56717 previousMonthEl.style.position = "absolute"; 56718 previousMonthEl.style.overflow = "hidden"; 56719 previousMonthEl.setAttribute("aria-hidden", "true"); 56720 const previousWeekdaysEl = queryWeekdaysEl(previousMonthEl); 56721 if (previousWeekdaysEl) { 56722 previousWeekdaysEl.style.opacity = "0"; 56723 } 56724 const previousCaptionEl = queryCaptionEl(previousMonthEl); 56725 if (previousCaptionEl) { 56726 previousCaptionEl.classList.add(isAfterPreviousMonth ? classNames[Animation.caption_before_exit] : classNames[Animation.caption_after_exit]); 56727 previousCaptionEl.addEventListener("animationend", cleanUp); 56728 } 56729 const previousWeeksEl = queryWeeksEl(previousMonthEl); 56730 if (previousWeeksEl) { 56731 previousWeeksEl.classList.add(isAfterPreviousMonth ? classNames[Animation.weeks_before_exit] : classNames[Animation.weeks_after_exit]); 56732 } 56733 currentMonthEl.insertBefore(previousMonthEl, currentMonthEl.firstChild); 56734 }); 56735 } 56736 }); 56737 } 56738 56739 // node_modules/react-day-picker/dist/esm/useCalendar.js 56740 var import_react163 = __toESM(require_react(), 1); 56741 56742 // node_modules/react-day-picker/dist/esm/helpers/getDates.js 56743 function getDates(displayMonths, maxDate, props, dateLib) { 56744 const firstMonth = displayMonths[0]; 56745 const lastMonth = displayMonths[displayMonths.length - 1]; 56746 const { ISOWeek, fixedWeeks, broadcastCalendar } = props ?? {}; 56747 const { addDays: addDays3, differenceInCalendarDays: differenceInCalendarDays3, differenceInCalendarMonths: differenceInCalendarMonths2, endOfBroadcastWeek: endOfBroadcastWeek2, endOfISOWeek: endOfISOWeek2, endOfMonth: endOfMonth3, endOfWeek: endOfWeek3, isAfter: isAfter3, startOfBroadcastWeek: startOfBroadcastWeek2, startOfISOWeek: startOfISOWeek3, startOfWeek: startOfWeek3 } = dateLib; 56748 const startWeekFirstDate = broadcastCalendar ? startOfBroadcastWeek2(firstMonth, dateLib) : ISOWeek ? startOfISOWeek3(firstMonth) : startOfWeek3(firstMonth); 56749 const endWeekLastDate = broadcastCalendar ? endOfBroadcastWeek2(lastMonth) : ISOWeek ? endOfISOWeek2(endOfMonth3(lastMonth)) : endOfWeek3(endOfMonth3(lastMonth)); 56750 const nOfDays = differenceInCalendarDays3(endWeekLastDate, startWeekFirstDate); 56751 const nOfMonths = differenceInCalendarMonths2(lastMonth, firstMonth) + 1; 56752 const dates = []; 56753 for (let i3 = 0; i3 <= nOfDays; i3++) { 56754 const date = addDays3(startWeekFirstDate, i3); 56755 if (maxDate && isAfter3(date, maxDate)) { 56756 break; 56757 } 56758 dates.push(date); 56759 } 56760 const nrOfDaysWithFixedWeeks = broadcastCalendar ? 35 : 42; 56761 const extraDates = nrOfDaysWithFixedWeeks * nOfMonths; 56762 if (fixedWeeks && dates.length < extraDates) { 56763 const daysToAdd = extraDates - dates.length; 56764 for (let i3 = 0; i3 < daysToAdd; i3++) { 56765 const date = addDays3(dates[dates.length - 1], 1); 56766 dates.push(date); 56767 } 56768 } 56769 return dates; 56770 } 56771 56772 // node_modules/react-day-picker/dist/esm/helpers/getDays.js 56773 function getDays(calendarMonths) { 56774 const initialDays = []; 56775 return calendarMonths.reduce((days, month) => { 56776 const weekDays = month.weeks.reduce((weekDays2, week) => { 56777 return [...weekDays2, ...week.days]; 56778 }, initialDays); 56779 return [...days, ...weekDays]; 56780 }, initialDays); 56781 } 56782 56783 // node_modules/react-day-picker/dist/esm/helpers/getDisplayMonths.js 56784 function getDisplayMonths(firstDisplayedMonth, calendarEndMonth, props, dateLib) { 56785 const { numberOfMonths = 1 } = props; 56786 const months = []; 56787 for (let i3 = 0; i3 < numberOfMonths; i3++) { 56788 const month = dateLib.addMonths(firstDisplayedMonth, i3); 56789 if (calendarEndMonth && month > calendarEndMonth) { 56790 break; 56791 } 56792 months.push(month); 56793 } 56794 return months; 56795 } 56796 56797 // node_modules/react-day-picker/dist/esm/helpers/getInitialMonth.js 56798 function getInitialMonth(props, dateLib) { 56799 const { month, defaultMonth, today = dateLib.today(), numberOfMonths = 1, endMonth, startMonth } = props; 56800 let initialMonth = month || defaultMonth || today; 56801 const { differenceInCalendarMonths: differenceInCalendarMonths2, addMonths: addMonths3, startOfMonth: startOfMonth3 } = dateLib; 56802 if (endMonth && differenceInCalendarMonths2(endMonth, initialMonth) < 0) { 56803 const offset3 = -1 * (numberOfMonths - 1); 56804 initialMonth = addMonths3(endMonth, offset3); 56805 } 56806 if (startMonth && differenceInCalendarMonths2(initialMonth, startMonth) < 0) { 56807 initialMonth = startMonth; 56808 } 56809 return startOfMonth3(initialMonth); 56810 } 56811 56812 // node_modules/react-day-picker/dist/esm/helpers/getMonths.js 56813 function getMonths(displayMonths, dates, props, dateLib) { 56814 const { addDays: addDays3, endOfBroadcastWeek: endOfBroadcastWeek2, endOfISOWeek: endOfISOWeek2, endOfMonth: endOfMonth3, endOfWeek: endOfWeek3, getISOWeek: getISOWeek3, getWeek: getWeek3, startOfBroadcastWeek: startOfBroadcastWeek2, startOfISOWeek: startOfISOWeek3, startOfWeek: startOfWeek3 } = dateLib; 56815 const dayPickerMonths = displayMonths.reduce((months, month) => { 56816 const firstDateOfFirstWeek = props.broadcastCalendar ? startOfBroadcastWeek2(month, dateLib) : props.ISOWeek ? startOfISOWeek3(month) : startOfWeek3(month); 56817 const lastDateOfLastWeek = props.broadcastCalendar ? endOfBroadcastWeek2(month) : props.ISOWeek ? endOfISOWeek2(endOfMonth3(month)) : endOfWeek3(endOfMonth3(month)); 56818 const monthDates = dates.filter((date) => { 56819 return date >= firstDateOfFirstWeek && date <= lastDateOfLastWeek; 56820 }); 56821 const nrOfDaysWithFixedWeeks = props.broadcastCalendar ? 35 : 42; 56822 if (props.fixedWeeks && monthDates.length < nrOfDaysWithFixedWeeks) { 56823 const extraDates = dates.filter((date) => { 56824 const daysToAdd = nrOfDaysWithFixedWeeks - monthDates.length; 56825 return date > lastDateOfLastWeek && date <= addDays3(lastDateOfLastWeek, daysToAdd); 56826 }); 56827 monthDates.push(...extraDates); 56828 } 56829 const weeks = monthDates.reduce((weeks2, date) => { 56830 const weekNumber = props.ISOWeek ? getISOWeek3(date) : getWeek3(date); 56831 const week = weeks2.find((week2) => week2.weekNumber === weekNumber); 56832 const day = new CalendarDay(date, month, dateLib); 56833 if (!week) { 56834 weeks2.push(new CalendarWeek(weekNumber, [day])); 56835 } else { 56836 week.days.push(day); 56837 } 56838 return weeks2; 56839 }, []); 56840 const dayPickerMonth = new CalendarMonth(month, weeks); 56841 months.push(dayPickerMonth); 56842 return months; 56843 }, []); 56844 if (!props.reverseMonths) { 56845 return dayPickerMonths; 56846 } else { 56847 return dayPickerMonths.reverse(); 56848 } 56849 } 56850 56851 // node_modules/react-day-picker/dist/esm/helpers/getNavMonth.js 56852 function getNavMonths(props, dateLib) { 56853 let { startMonth, endMonth } = props; 56854 const { startOfYear: startOfYear3, startOfDay: startOfDay3, startOfMonth: startOfMonth3, endOfMonth: endOfMonth3, addYears: addYears3, endOfYear: endOfYear2, newDate, today } = dateLib; 56855 const { fromYear, toYear, fromMonth, toMonth } = props; 56856 if (!startMonth && fromMonth) { 56857 startMonth = fromMonth; 56858 } 56859 if (!startMonth && fromYear) { 56860 startMonth = dateLib.newDate(fromYear, 0, 1); 56861 } 56862 if (!endMonth && toMonth) { 56863 endMonth = toMonth; 56864 } 56865 if (!endMonth && toYear) { 56866 endMonth = newDate(toYear, 11, 31); 56867 } 56868 const hasYearDropdown = props.captionLayout === "dropdown" || props.captionLayout === "dropdown-years"; 56869 if (startMonth) { 56870 startMonth = startOfMonth3(startMonth); 56871 } else if (fromYear) { 56872 startMonth = newDate(fromYear, 0, 1); 56873 } else if (!startMonth && hasYearDropdown) { 56874 startMonth = startOfYear3(addYears3(props.today ?? today(), -100)); 56875 } 56876 if (endMonth) { 56877 endMonth = endOfMonth3(endMonth); 56878 } else if (toYear) { 56879 endMonth = newDate(toYear, 11, 31); 56880 } else if (!endMonth && hasYearDropdown) { 56881 endMonth = endOfYear2(props.today ?? today()); 56882 } 56883 return [ 56884 startMonth ? startOfDay3(startMonth) : startMonth, 56885 endMonth ? startOfDay3(endMonth) : endMonth 56886 ]; 56887 } 56888 56889 // node_modules/react-day-picker/dist/esm/helpers/getNextMonth.js 56890 function getNextMonth(firstDisplayedMonth, calendarEndMonth, options2, dateLib) { 56891 if (options2.disableNavigation) { 56892 return void 0; 56893 } 56894 const { pagedNavigation, numberOfMonths = 1 } = options2; 56895 const { startOfMonth: startOfMonth3, addMonths: addMonths3, differenceInCalendarMonths: differenceInCalendarMonths2 } = dateLib; 56896 const offset3 = pagedNavigation ? numberOfMonths : 1; 56897 const month = startOfMonth3(firstDisplayedMonth); 56898 if (!calendarEndMonth) { 56899 return addMonths3(month, offset3); 56900 } 56901 const monthsDiff = differenceInCalendarMonths2(calendarEndMonth, firstDisplayedMonth); 56902 if (monthsDiff < numberOfMonths) { 56903 return void 0; 56904 } 56905 return addMonths3(month, offset3); 56906 } 56907 56908 // node_modules/react-day-picker/dist/esm/helpers/getPreviousMonth.js 56909 function getPreviousMonth(firstDisplayedMonth, calendarStartMonth, options2, dateLib) { 56910 if (options2.disableNavigation) { 56911 return void 0; 56912 } 56913 const { pagedNavigation, numberOfMonths } = options2; 56914 const { startOfMonth: startOfMonth3, addMonths: addMonths3, differenceInCalendarMonths: differenceInCalendarMonths2 } = dateLib; 56915 const offset3 = pagedNavigation ? numberOfMonths ?? 1 : 1; 56916 const month = startOfMonth3(firstDisplayedMonth); 56917 if (!calendarStartMonth) { 56918 return addMonths3(month, -offset3); 56919 } 56920 const monthsDiff = differenceInCalendarMonths2(month, calendarStartMonth); 56921 if (monthsDiff <= 0) { 56922 return void 0; 56923 } 56924 return addMonths3(month, -offset3); 56925 } 56926 56927 // node_modules/react-day-picker/dist/esm/helpers/getWeeks.js 56928 function getWeeks(months) { 56929 const initialWeeks = []; 56930 return months.reduce((weeks, month) => { 56931 return [...weeks, ...month.weeks]; 56932 }, initialWeeks); 56933 } 56934 56935 // node_modules/react-day-picker/dist/esm/helpers/useControlledValue.js 56936 var import_react162 = __toESM(require_react(), 1); 56937 function useControlledValue2(defaultValue2, controlledValue) { 56938 const [uncontrolledValue, setValue] = (0, import_react162.useState)(defaultValue2); 56939 const value = controlledValue === void 0 ? uncontrolledValue : controlledValue; 56940 return [value, setValue]; 56941 } 56942 56943 // node_modules/react-day-picker/dist/esm/useCalendar.js 56944 function useCalendar(props, dateLib) { 56945 const [navStart, navEnd] = getNavMonths(props, dateLib); 56946 const { startOfMonth: startOfMonth3, endOfMonth: endOfMonth3 } = dateLib; 56947 const initialMonth = getInitialMonth(props, dateLib); 56948 const [firstMonth, setFirstMonth] = useControlledValue2( 56949 initialMonth, 56950 // initialMonth is always computed from props.month if provided 56951 props.month ? initialMonth : void 0 56952 ); 56953 (0, import_react163.useEffect)(() => { 56954 const newInitialMonth = getInitialMonth(props, dateLib); 56955 setFirstMonth(newInitialMonth); 56956 }, [props.timeZone]); 56957 const displayMonths = getDisplayMonths(firstMonth, navEnd, props, dateLib); 56958 const dates = getDates(displayMonths, props.endMonth ? endOfMonth3(props.endMonth) : void 0, props, dateLib); 56959 const months = getMonths(displayMonths, dates, props, dateLib); 56960 const weeks = getWeeks(months); 56961 const days = getDays(months); 56962 const previousMonth = getPreviousMonth(firstMonth, navStart, props, dateLib); 56963 const nextMonth = getNextMonth(firstMonth, navEnd, props, dateLib); 56964 const { disableNavigation, onMonthChange } = props; 56965 const isDayInCalendar = (day) => weeks.some((week) => week.days.some((d3) => d3.isEqualTo(day))); 56966 const goToMonth = (date) => { 56967 if (disableNavigation) { 56968 return; 56969 } 56970 let newMonth = startOfMonth3(date); 56971 if (navStart && newMonth < startOfMonth3(navStart)) { 56972 newMonth = startOfMonth3(navStart); 56973 } 56974 if (navEnd && newMonth > startOfMonth3(navEnd)) { 56975 newMonth = startOfMonth3(navEnd); 56976 } 56977 setFirstMonth(newMonth); 56978 onMonthChange?.(newMonth); 56979 }; 56980 const goToDay = (day) => { 56981 if (isDayInCalendar(day)) { 56982 return; 56983 } 56984 goToMonth(day.date); 56985 }; 56986 const calendar = { 56987 months, 56988 weeks, 56989 days, 56990 navStart, 56991 navEnd, 56992 previousMonth, 56993 nextMonth, 56994 goToMonth, 56995 goToDay 56996 }; 56997 return calendar; 56998 } 56999 57000 // node_modules/react-day-picker/dist/esm/useFocus.js 57001 var import_react164 = __toESM(require_react(), 1); 57002 57003 // node_modules/react-day-picker/dist/esm/helpers/calculateFocusTarget.js 57004 var FocusTargetPriority; 57005 (function(FocusTargetPriority2) { 57006 FocusTargetPriority2[FocusTargetPriority2["Today"] = 0] = "Today"; 57007 FocusTargetPriority2[FocusTargetPriority2["Selected"] = 1] = "Selected"; 57008 FocusTargetPriority2[FocusTargetPriority2["LastFocused"] = 2] = "LastFocused"; 57009 FocusTargetPriority2[FocusTargetPriority2["FocusedModifier"] = 3] = "FocusedModifier"; 57010 })(FocusTargetPriority || (FocusTargetPriority = {})); 57011 function isFocusableDay(modifiers) { 57012 return !modifiers[DayFlag.disabled] && !modifiers[DayFlag.hidden] && !modifiers[DayFlag.outside]; 57013 } 57014 function calculateFocusTarget(days, getModifiers, isSelected2, lastFocused) { 57015 let focusTarget; 57016 let foundFocusTargetPriority = -1; 57017 for (const day of days) { 57018 const modifiers = getModifiers(day); 57019 if (isFocusableDay(modifiers)) { 57020 if (modifiers[DayFlag.focused] && foundFocusTargetPriority < FocusTargetPriority.FocusedModifier) { 57021 focusTarget = day; 57022 foundFocusTargetPriority = FocusTargetPriority.FocusedModifier; 57023 } else if (lastFocused?.isEqualTo(day) && foundFocusTargetPriority < FocusTargetPriority.LastFocused) { 57024 focusTarget = day; 57025 foundFocusTargetPriority = FocusTargetPriority.LastFocused; 57026 } else if (isSelected2(day.date) && foundFocusTargetPriority < FocusTargetPriority.Selected) { 57027 focusTarget = day; 57028 foundFocusTargetPriority = FocusTargetPriority.Selected; 57029 } else if (modifiers[DayFlag.today] && foundFocusTargetPriority < FocusTargetPriority.Today) { 57030 focusTarget = day; 57031 foundFocusTargetPriority = FocusTargetPriority.Today; 57032 } 57033 } 57034 } 57035 if (!focusTarget) { 57036 focusTarget = days.find((day) => isFocusableDay(getModifiers(day))); 57037 } 57038 return focusTarget; 57039 } 57040 57041 // node_modules/react-day-picker/dist/esm/helpers/getFocusableDate.js 57042 function getFocusableDate(moveBy, moveDir, refDate, navStart, navEnd, props, dateLib) { 57043 const { ISOWeek, broadcastCalendar } = props; 57044 const { addDays: addDays3, addMonths: addMonths3, addWeeks: addWeeks3, addYears: addYears3, endOfBroadcastWeek: endOfBroadcastWeek2, endOfISOWeek: endOfISOWeek2, endOfWeek: endOfWeek3, max: max3, min: min3, startOfBroadcastWeek: startOfBroadcastWeek2, startOfISOWeek: startOfISOWeek3, startOfWeek: startOfWeek3 } = dateLib; 57045 const moveFns = { 57046 day: addDays3, 57047 week: addWeeks3, 57048 month: addMonths3, 57049 year: addYears3, 57050 startOfWeek: (date) => broadcastCalendar ? startOfBroadcastWeek2(date, dateLib) : ISOWeek ? startOfISOWeek3(date) : startOfWeek3(date), 57051 endOfWeek: (date) => broadcastCalendar ? endOfBroadcastWeek2(date) : ISOWeek ? endOfISOWeek2(date) : endOfWeek3(date) 57052 }; 57053 let focusableDate = moveFns[moveBy](refDate, moveDir === "after" ? 1 : -1); 57054 if (moveDir === "before" && navStart) { 57055 focusableDate = max3([navStart, focusableDate]); 57056 } else if (moveDir === "after" && navEnd) { 57057 focusableDate = min3([navEnd, focusableDate]); 57058 } 57059 return focusableDate; 57060 } 57061 57062 // node_modules/react-day-picker/dist/esm/helpers/getNextFocus.js 57063 function getNextFocus(moveBy, moveDir, refDay, calendarStartMonth, calendarEndMonth, props, dateLib, attempt = 0) { 57064 if (attempt > 365) { 57065 return void 0; 57066 } 57067 const focusableDate = getFocusableDate(moveBy, moveDir, refDay.date, calendarStartMonth, calendarEndMonth, props, dateLib); 57068 const isDisabled = Boolean(props.disabled && dateMatchModifiers(focusableDate, props.disabled, dateLib)); 57069 const isHidden2 = Boolean(props.hidden && dateMatchModifiers(focusableDate, props.hidden, dateLib)); 57070 const targetMonth = focusableDate; 57071 const focusDay = new CalendarDay(focusableDate, targetMonth, dateLib); 57072 if (!isDisabled && !isHidden2) { 57073 return focusDay; 57074 } 57075 return getNextFocus(moveBy, moveDir, focusDay, calendarStartMonth, calendarEndMonth, props, dateLib, attempt + 1); 57076 } 57077 57078 // node_modules/react-day-picker/dist/esm/useFocus.js 57079 function useFocus(props, calendar, getModifiers, isSelected2, dateLib) { 57080 const { autoFocus } = props; 57081 const [lastFocused, setLastFocused] = (0, import_react164.useState)(); 57082 const focusTarget = calculateFocusTarget(calendar.days, getModifiers, isSelected2 || (() => false), lastFocused); 57083 const [focusedDay, setFocused] = (0, import_react164.useState)(autoFocus ? focusTarget : void 0); 57084 const blur = () => { 57085 setLastFocused(focusedDay); 57086 setFocused(void 0); 57087 }; 57088 const moveFocus = (moveBy, moveDir) => { 57089 if (!focusedDay) 57090 return; 57091 const nextFocus = getNextFocus(moveBy, moveDir, focusedDay, calendar.navStart, calendar.navEnd, props, dateLib); 57092 if (!nextFocus) 57093 return; 57094 calendar.goToDay(nextFocus); 57095 setFocused(nextFocus); 57096 }; 57097 const isFocusTarget = (day) => { 57098 return Boolean(focusTarget?.isEqualTo(day)); 57099 }; 57100 const useFocus2 = { 57101 isFocusTarget, 57102 setFocused, 57103 focused: focusedDay, 57104 blur, 57105 moveFocus 57106 }; 57107 return useFocus2; 57108 } 57109 57110 // node_modules/react-day-picker/dist/esm/selection/useMulti.js 57111 function useMulti(props, dateLib) { 57112 const { selected: initiallySelected, required, onSelect } = props; 57113 const [internallySelected, setSelected] = useControlledValue2(initiallySelected, onSelect ? initiallySelected : void 0); 57114 const selected = !onSelect ? internallySelected : initiallySelected; 57115 const { isSameDay: isSameDay3 } = dateLib; 57116 const isSelected2 = (date) => { 57117 return selected?.some((d3) => isSameDay3(d3, date)) ?? false; 57118 }; 57119 const { min: min3, max: max3 } = props; 57120 const select = (triggerDate, modifiers, e3) => { 57121 let newDates = [...selected ?? []]; 57122 if (isSelected2(triggerDate)) { 57123 if (selected?.length === min3) { 57124 return; 57125 } 57126 if (required && selected?.length === 1) { 57127 return; 57128 } 57129 newDates = selected?.filter((d3) => !isSameDay3(d3, triggerDate)); 57130 } else { 57131 if (selected?.length === max3) { 57132 newDates = [triggerDate]; 57133 } else { 57134 newDates = [...newDates, triggerDate]; 57135 } 57136 } 57137 if (!onSelect) { 57138 setSelected(newDates); 57139 } 57140 onSelect?.(newDates, triggerDate, modifiers, e3); 57141 return newDates; 57142 }; 57143 return { 57144 selected, 57145 select, 57146 isSelected: isSelected2 57147 }; 57148 } 57149 57150 // node_modules/react-day-picker/dist/esm/utils/addToRange.js 57151 function addToRange(date, initialRange, min3 = 0, max3 = 0, required = false, dateLib = defaultDateLib) { 57152 const { from: from2, to } = initialRange || {}; 57153 const { isSameDay: isSameDay3, isAfter: isAfter3, isBefore: isBefore3 } = dateLib; 57154 let range; 57155 if (!from2 && !to) { 57156 range = { from: date, to: min3 > 0 ? void 0 : date }; 57157 } else if (from2 && !to) { 57158 if (isSameDay3(from2, date)) { 57159 if (required) { 57160 range = { from: from2, to: void 0 }; 57161 } else { 57162 range = void 0; 57163 } 57164 } else if (isBefore3(date, from2)) { 57165 range = { from: date, to: from2 }; 57166 } else { 57167 range = { from: from2, to: date }; 57168 } 57169 } else if (from2 && to) { 57170 if (isSameDay3(from2, date) && isSameDay3(to, date)) { 57171 if (required) { 57172 range = { from: from2, to }; 57173 } else { 57174 range = void 0; 57175 } 57176 } else if (isSameDay3(from2, date)) { 57177 range = { from: from2, to: min3 > 0 ? void 0 : date }; 57178 } else if (isSameDay3(to, date)) { 57179 range = { from: date, to: min3 > 0 ? void 0 : date }; 57180 } else if (isBefore3(date, from2)) { 57181 range = { from: date, to }; 57182 } else if (isAfter3(date, from2)) { 57183 range = { from: from2, to: date }; 57184 } else if (isAfter3(date, to)) { 57185 range = { from: from2, to: date }; 57186 } else { 57187 throw new Error("Invalid range"); 57188 } 57189 } 57190 if (range?.from && range?.to) { 57191 const diff = dateLib.differenceInCalendarDays(range.to, range.from); 57192 if (max3 > 0 && diff > max3) { 57193 range = { from: date, to: void 0 }; 57194 } else if (min3 > 1 && diff < min3) { 57195 range = { from: date, to: void 0 }; 57196 } 57197 } 57198 return range; 57199 } 57200 57201 // node_modules/react-day-picker/dist/esm/utils/rangeContainsDayOfWeek.js 57202 function rangeContainsDayOfWeek(range, dayOfWeek, dateLib = defaultDateLib) { 57203 const dayOfWeekArr = !Array.isArray(dayOfWeek) ? [dayOfWeek] : dayOfWeek; 57204 let date = range.from; 57205 const totalDays = dateLib.differenceInCalendarDays(range.to, range.from); 57206 const totalDaysLimit = Math.min(totalDays, 6); 57207 for (let i3 = 0; i3 <= totalDaysLimit; i3++) { 57208 if (dayOfWeekArr.includes(date.getDay())) { 57209 return true; 57210 } 57211 date = dateLib.addDays(date, 1); 57212 } 57213 return false; 57214 } 57215 57216 // node_modules/react-day-picker/dist/esm/utils/rangeOverlaps.js 57217 function rangeOverlaps(rangeLeft, rangeRight, dateLib = defaultDateLib) { 57218 return rangeIncludesDate(rangeLeft, rangeRight.from, false, dateLib) || rangeIncludesDate(rangeLeft, rangeRight.to, false, dateLib) || rangeIncludesDate(rangeRight, rangeLeft.from, false, dateLib) || rangeIncludesDate(rangeRight, rangeLeft.to, false, dateLib); 57219 } 57220 57221 // node_modules/react-day-picker/dist/esm/utils/rangeContainsModifiers.js 57222 function rangeContainsModifiers(range, modifiers, dateLib = defaultDateLib) { 57223 const matchers = Array.isArray(modifiers) ? modifiers : [modifiers]; 57224 const nonFunctionMatchers = matchers.filter((matcher) => typeof matcher !== "function"); 57225 const nonFunctionMatchersResult = nonFunctionMatchers.some((matcher) => { 57226 if (typeof matcher === "boolean") 57227 return matcher; 57228 if (dateLib.isDate(matcher)) { 57229 return rangeIncludesDate(range, matcher, false, dateLib); 57230 } 57231 if (isDatesArray(matcher, dateLib)) { 57232 return matcher.some((date) => rangeIncludesDate(range, date, false, dateLib)); 57233 } 57234 if (isDateRange(matcher)) { 57235 if (matcher.from && matcher.to) { 57236 return rangeOverlaps(range, { from: matcher.from, to: matcher.to }, dateLib); 57237 } 57238 return false; 57239 } 57240 if (isDayOfWeekType(matcher)) { 57241 return rangeContainsDayOfWeek(range, matcher.dayOfWeek, dateLib); 57242 } 57243 if (isDateInterval(matcher)) { 57244 const isClosedInterval = dateLib.isAfter(matcher.before, matcher.after); 57245 if (isClosedInterval) { 57246 return rangeOverlaps(range, { 57247 from: dateLib.addDays(matcher.after, 1), 57248 to: dateLib.addDays(matcher.before, -1) 57249 }, dateLib); 57250 } 57251 return dateMatchModifiers(range.from, matcher, dateLib) || dateMatchModifiers(range.to, matcher, dateLib); 57252 } 57253 if (isDateAfterType(matcher) || isDateBeforeType(matcher)) { 57254 return dateMatchModifiers(range.from, matcher, dateLib) || dateMatchModifiers(range.to, matcher, dateLib); 57255 } 57256 return false; 57257 }); 57258 if (nonFunctionMatchersResult) { 57259 return true; 57260 } 57261 const functionMatchers = matchers.filter((matcher) => typeof matcher === "function"); 57262 if (functionMatchers.length) { 57263 let date = range.from; 57264 const totalDays = dateLib.differenceInCalendarDays(range.to, range.from); 57265 for (let i3 = 0; i3 <= totalDays; i3++) { 57266 if (functionMatchers.some((matcher) => matcher(date))) { 57267 return true; 57268 } 57269 date = dateLib.addDays(date, 1); 57270 } 57271 } 57272 return false; 57273 } 57274 57275 // node_modules/react-day-picker/dist/esm/selection/useRange.js 57276 function useRange(props, dateLib) { 57277 const { disabled, excludeDisabled, selected: initiallySelected, required, onSelect } = props; 57278 const [internallySelected, setSelected] = useControlledValue2(initiallySelected, onSelect ? initiallySelected : void 0); 57279 const selected = !onSelect ? internallySelected : initiallySelected; 57280 const isSelected2 = (date) => selected && rangeIncludesDate(selected, date, false, dateLib); 57281 const select = (triggerDate, modifiers, e3) => { 57282 const { min: min3, max: max3 } = props; 57283 const newRange = triggerDate ? addToRange(triggerDate, selected, min3, max3, required, dateLib) : void 0; 57284 if (excludeDisabled && disabled && newRange?.from && newRange.to) { 57285 if (rangeContainsModifiers({ from: newRange.from, to: newRange.to }, disabled, dateLib)) { 57286 newRange.from = triggerDate; 57287 newRange.to = void 0; 57288 } 57289 } 57290 if (!onSelect) { 57291 setSelected(newRange); 57292 } 57293 onSelect?.(newRange, triggerDate, modifiers, e3); 57294 return newRange; 57295 }; 57296 return { 57297 selected, 57298 select, 57299 isSelected: isSelected2 57300 }; 57301 } 57302 57303 // node_modules/react-day-picker/dist/esm/selection/useSingle.js 57304 function useSingle(props, dateLib) { 57305 const { selected: initiallySelected, required, onSelect } = props; 57306 const [internallySelected, setSelected] = useControlledValue2(initiallySelected, onSelect ? initiallySelected : void 0); 57307 const selected = !onSelect ? internallySelected : initiallySelected; 57308 const { isSameDay: isSameDay3 } = dateLib; 57309 const isSelected2 = (compareDate) => { 57310 return selected ? isSameDay3(selected, compareDate) : false; 57311 }; 57312 const select = (triggerDate, modifiers, e3) => { 57313 let newDate = triggerDate; 57314 if (!required && selected && selected && isSameDay3(triggerDate, selected)) { 57315 newDate = void 0; 57316 } 57317 if (!onSelect) { 57318 setSelected(newDate); 57319 } 57320 if (required) { 57321 onSelect?.(newDate, triggerDate, modifiers, e3); 57322 } else { 57323 onSelect?.(newDate, triggerDate, modifiers, e3); 57324 } 57325 return newDate; 57326 }; 57327 return { 57328 selected, 57329 select, 57330 isSelected: isSelected2 57331 }; 57332 } 57333 57334 // node_modules/react-day-picker/dist/esm/useSelection.js 57335 function useSelection(props, dateLib) { 57336 const single = useSingle(props, dateLib); 57337 const multi = useMulti(props, dateLib); 57338 const range = useRange(props, dateLib); 57339 switch (props.mode) { 57340 case "single": 57341 return single; 57342 case "multiple": 57343 return multi; 57344 case "range": 57345 return range; 57346 default: 57347 return void 0; 57348 } 57349 } 57350 57351 // node_modules/react-day-picker/dist/esm/DayPicker.js 57352 function DayPicker(initialProps) { 57353 let props = initialProps; 57354 if (props.timeZone) { 57355 props = { 57356 ...initialProps 57357 }; 57358 if (props.today) { 57359 props.today = new TZDate(props.today, props.timeZone); 57360 } 57361 if (props.month) { 57362 props.month = new TZDate(props.month, props.timeZone); 57363 } 57364 if (props.defaultMonth) { 57365 props.defaultMonth = new TZDate(props.defaultMonth, props.timeZone); 57366 } 57367 if (props.startMonth) { 57368 props.startMonth = new TZDate(props.startMonth, props.timeZone); 57369 } 57370 if (props.endMonth) { 57371 props.endMonth = new TZDate(props.endMonth, props.timeZone); 57372 } 57373 if (props.mode === "single" && props.selected) { 57374 props.selected = new TZDate(props.selected, props.timeZone); 57375 } else if (props.mode === "multiple" && props.selected) { 57376 props.selected = props.selected?.map((date) => new TZDate(date, props.timeZone)); 57377 } else if (props.mode === "range" && props.selected) { 57378 props.selected = { 57379 from: props.selected.from ? new TZDate(props.selected.from, props.timeZone) : void 0, 57380 to: props.selected.to ? new TZDate(props.selected.to, props.timeZone) : void 0 57381 }; 57382 } 57383 } 57384 const { components, formatters: formatters3, labels, dateLib, locale, classNames } = (0, import_react165.useMemo)(() => { 57385 const locale2 = { ...enUS2, ...props.locale }; 57386 const dateLib2 = new DateLib({ 57387 locale: locale2, 57388 weekStartsOn: props.broadcastCalendar ? 1 : props.weekStartsOn, 57389 firstWeekContainsDate: props.firstWeekContainsDate, 57390 useAdditionalWeekYearTokens: props.useAdditionalWeekYearTokens, 57391 useAdditionalDayOfYearTokens: props.useAdditionalDayOfYearTokens, 57392 timeZone: props.timeZone, 57393 numerals: props.numerals 57394 }, props.dateLib); 57395 return { 57396 dateLib: dateLib2, 57397 components: getComponents(props.components), 57398 formatters: getFormatters(props.formatters), 57399 labels: { ...labels_exports, ...props.labels }, 57400 locale: locale2, 57401 classNames: { ...getDefaultClassNames(), ...props.classNames } 57402 }; 57403 }, [ 57404 props.locale, 57405 props.broadcastCalendar, 57406 props.weekStartsOn, 57407 props.firstWeekContainsDate, 57408 props.useAdditionalWeekYearTokens, 57409 props.useAdditionalDayOfYearTokens, 57410 props.timeZone, 57411 props.numerals, 57412 props.dateLib, 57413 props.components, 57414 props.formatters, 57415 props.labels, 57416 props.classNames 57417 ]); 57418 const { captionLayout, mode: mode2, navLayout, numberOfMonths = 1, onDayBlur, onDayClick, onDayFocus, onDayKeyDown, onDayMouseEnter, onDayMouseLeave, onNextClick, onPrevClick, showWeekNumber, styles: styles3 } = props; 57419 const { formatCaption: formatCaption2, formatDay: formatDay2, formatMonthDropdown: formatMonthDropdown2, formatWeekNumber: formatWeekNumber2, formatWeekNumberHeader: formatWeekNumberHeader2, formatWeekdayName: formatWeekdayName2, formatYearDropdown: formatYearDropdown2 } = formatters3; 57420 const calendar = useCalendar(props, dateLib); 57421 const { days, months, navStart, navEnd, previousMonth, nextMonth, goToMonth } = calendar; 57422 const getModifiers = createGetModifiers(days, props, dateLib); 57423 const { isSelected: isSelected2, select, selected: selectedValue } = useSelection(props, dateLib) ?? {}; 57424 const { blur, focused, isFocusTarget, moveFocus, setFocused } = useFocus(props, calendar, getModifiers, isSelected2 ?? (() => false), dateLib); 57425 const { labelDayButton: labelDayButton2, labelGridcell: labelGridcell2, labelGrid: labelGrid2, labelMonthDropdown: labelMonthDropdown2, labelNav: labelNav2, labelPrevious: labelPrevious2, labelNext: labelNext2, labelWeekday: labelWeekday2, labelWeekNumber: labelWeekNumber2, labelWeekNumberHeader: labelWeekNumberHeader2, labelYearDropdown: labelYearDropdown2 } = labels; 57426 const weekdays = (0, import_react165.useMemo)(() => getWeekdays(dateLib, props.ISOWeek), [dateLib, props.ISOWeek]); 57427 const isInteractive = mode2 !== void 0 || onDayClick !== void 0; 57428 const handlePreviousClick = (0, import_react165.useCallback)(() => { 57429 if (!previousMonth) 57430 return; 57431 goToMonth(previousMonth); 57432 onPrevClick?.(previousMonth); 57433 }, [previousMonth, goToMonth, onPrevClick]); 57434 const handleNextClick = (0, import_react165.useCallback)(() => { 57435 if (!nextMonth) 57436 return; 57437 goToMonth(nextMonth); 57438 onNextClick?.(nextMonth); 57439 }, [goToMonth, nextMonth, onNextClick]); 57440 const handleDayClick = (0, import_react165.useCallback)((day, m3) => (e3) => { 57441 e3.preventDefault(); 57442 e3.stopPropagation(); 57443 setFocused(day); 57444 select?.(day.date, m3, e3); 57445 onDayClick?.(day.date, m3, e3); 57446 }, [select, onDayClick, setFocused]); 57447 const handleDayFocus = (0, import_react165.useCallback)((day, m3) => (e3) => { 57448 setFocused(day); 57449 onDayFocus?.(day.date, m3, e3); 57450 }, [onDayFocus, setFocused]); 57451 const handleDayBlur = (0, import_react165.useCallback)((day, m3) => (e3) => { 57452 blur(); 57453 onDayBlur?.(day.date, m3, e3); 57454 }, [blur, onDayBlur]); 57455 const handleDayKeyDown = (0, import_react165.useCallback)((day, modifiers) => (e3) => { 57456 const keyMap = { 57457 ArrowLeft: ["day", props.dir === "rtl" ? "after" : "before"], 57458 ArrowRight: ["day", props.dir === "rtl" ? "before" : "after"], 57459 ArrowDown: ["week", "after"], 57460 ArrowUp: ["week", "before"], 57461 PageUp: [e3.shiftKey ? "year" : "month", "before"], 57462 PageDown: [e3.shiftKey ? "year" : "month", "after"], 57463 Home: ["startOfWeek", "before"], 57464 End: ["endOfWeek", "after"] 57465 }; 57466 if (keyMap[e3.key]) { 57467 e3.preventDefault(); 57468 e3.stopPropagation(); 57469 const [moveBy, moveDir] = keyMap[e3.key]; 57470 moveFocus(moveBy, moveDir); 57471 } 57472 onDayKeyDown?.(day.date, modifiers, e3); 57473 }, [moveFocus, onDayKeyDown, props.dir]); 57474 const handleDayMouseEnter = (0, import_react165.useCallback)((day, modifiers) => (e3) => { 57475 onDayMouseEnter?.(day.date, modifiers, e3); 57476 }, [onDayMouseEnter]); 57477 const handleDayMouseLeave = (0, import_react165.useCallback)((day, modifiers) => (e3) => { 57478 onDayMouseLeave?.(day.date, modifiers, e3); 57479 }, [onDayMouseLeave]); 57480 const handleMonthChange = (0, import_react165.useCallback)((date) => (e3) => { 57481 const selectedMonth = Number(e3.target.value); 57482 const month = dateLib.setMonth(dateLib.startOfMonth(date), selectedMonth); 57483 goToMonth(month); 57484 }, [dateLib, goToMonth]); 57485 const handleYearChange = (0, import_react165.useCallback)((date) => (e3) => { 57486 const selectedYear = Number(e3.target.value); 57487 const month = dateLib.setYear(dateLib.startOfMonth(date), selectedYear); 57488 goToMonth(month); 57489 }, [dateLib, goToMonth]); 57490 const { className: className2, style: style2 } = (0, import_react165.useMemo)(() => ({ 57491 className: [classNames[UI2.Root], props.className].filter(Boolean).join(" "), 57492 style: { ...styles3?.[UI2.Root], ...props.style } 57493 }), [classNames, props.className, props.style, styles3]); 57494 const dataAttributes = getDataAttributes(props); 57495 const rootElRef = (0, import_react165.useRef)(null); 57496 useAnimation(rootElRef, Boolean(props.animate), { 57497 classNames, 57498 months, 57499 focused, 57500 dateLib 57501 }); 57502 const contextValue = { 57503 dayPickerProps: props, 57504 selected: selectedValue, 57505 select, 57506 isSelected: isSelected2, 57507 months, 57508 nextMonth, 57509 previousMonth, 57510 goToMonth, 57511 getModifiers, 57512 components, 57513 classNames, 57514 styles: styles3, 57515 labels, 57516 formatters: formatters3 57517 }; 57518 return import_react165.default.createElement( 57519 dayPickerContext.Provider, 57520 { value: contextValue }, 57521 import_react165.default.createElement( 57522 components.Root, 57523 { rootRef: props.animate ? rootElRef : void 0, className: className2, style: style2, dir: props.dir, id: props.id, lang: props.lang, nonce: props.nonce, title: props.title, role: props.role, "aria-label": props["aria-label"], ...dataAttributes }, 57524 import_react165.default.createElement( 57525 components.Months, 57526 { className: classNames[UI2.Months], style: styles3?.[UI2.Months] }, 57527 !props.hideNavigation && !navLayout && import_react165.default.createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : void 0, className: classNames[UI2.Nav], style: styles3?.[UI2.Nav], "aria-label": labelNav2(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth, nextMonth }), 57528 months.map((calendarMonth, displayIndex) => { 57529 const dropdownMonths = getMonthOptions(calendarMonth.date, navStart, navEnd, formatters3, dateLib); 57530 const dropdownYears = getYearOptions(navStart, navEnd, formatters3, dateLib); 57531 return import_react165.default.createElement( 57532 components.Month, 57533 { "data-animated-month": props.animate ? "true" : void 0, className: classNames[UI2.Month], style: styles3?.[UI2.Month], key: displayIndex, displayIndex, calendarMonth }, 57534 navLayout === "around" && !props.hideNavigation && displayIndex === 0 && import_react165.default.createElement( 57535 components.PreviousMonthButton, 57536 { type: "button", className: classNames[UI2.PreviousMonthButton], tabIndex: previousMonth ? void 0 : -1, "aria-disabled": previousMonth ? void 0 : true, "aria-label": labelPrevious2(previousMonth), onClick: handlePreviousClick, "data-animated-button": props.animate ? "true" : void 0 }, 57537 import_react165.default.createElement(components.Chevron, { disabled: previousMonth ? void 0 : true, className: classNames[UI2.Chevron], orientation: props.dir === "rtl" ? "right" : "left" }) 57538 ), 57539 import_react165.default.createElement(components.MonthCaption, { "data-animated-caption": props.animate ? "true" : void 0, className: classNames[UI2.MonthCaption], style: styles3?.[UI2.MonthCaption], calendarMonth, displayIndex }, captionLayout?.startsWith("dropdown") ? import_react165.default.createElement( 57540 components.DropdownNav, 57541 { className: classNames[UI2.Dropdowns], style: styles3?.[UI2.Dropdowns] }, 57542 captionLayout === "dropdown" || captionLayout === "dropdown-months" ? import_react165.default.createElement(components.MonthsDropdown, { className: classNames[UI2.MonthsDropdown], "aria-label": labelMonthDropdown2(), classNames, components, disabled: Boolean(props.disableNavigation), onChange: handleMonthChange(calendarMonth.date), options: dropdownMonths, style: styles3?.[UI2.Dropdown], value: dateLib.getMonth(calendarMonth.date) }) : import_react165.default.createElement("span", null, formatMonthDropdown2(calendarMonth.date, dateLib)), 57543 captionLayout === "dropdown" || captionLayout === "dropdown-years" ? import_react165.default.createElement(components.YearsDropdown, { className: classNames[UI2.YearsDropdown], "aria-label": labelYearDropdown2(dateLib.options), classNames, components, disabled: Boolean(props.disableNavigation), onChange: handleYearChange(calendarMonth.date), options: dropdownYears, style: styles3?.[UI2.Dropdown], value: dateLib.getYear(calendarMonth.date) }) : import_react165.default.createElement("span", null, formatYearDropdown2(calendarMonth.date, dateLib)), 57544 import_react165.default.createElement("span", { role: "status", "aria-live": "polite", style: { 57545 border: 0, 57546 clip: "rect(0 0 0 0)", 57547 height: "1px", 57548 margin: "-1px", 57549 overflow: "hidden", 57550 padding: 0, 57551 position: "absolute", 57552 width: "1px", 57553 whiteSpace: "nowrap", 57554 wordWrap: "normal" 57555 } }, formatCaption2(calendarMonth.date, dateLib.options, dateLib)) 57556 ) : import_react165.default.createElement(components.CaptionLabel, { className: classNames[UI2.CaptionLabel], role: "status", "aria-live": "polite" }, formatCaption2(calendarMonth.date, dateLib.options, dateLib))), 57557 navLayout === "around" && !props.hideNavigation && displayIndex === numberOfMonths - 1 && import_react165.default.createElement( 57558 components.NextMonthButton, 57559 { type: "button", className: classNames[UI2.NextMonthButton], tabIndex: nextMonth ? void 0 : -1, "aria-disabled": nextMonth ? void 0 : true, "aria-label": labelNext2(nextMonth), onClick: handleNextClick, "data-animated-button": props.animate ? "true" : void 0 }, 57560 import_react165.default.createElement(components.Chevron, { disabled: nextMonth ? void 0 : true, className: classNames[UI2.Chevron], orientation: props.dir === "rtl" ? "left" : "right" }) 57561 ), 57562 displayIndex === numberOfMonths - 1 && navLayout === "after" && !props.hideNavigation && import_react165.default.createElement(components.Nav, { "data-animated-nav": props.animate ? "true" : void 0, className: classNames[UI2.Nav], style: styles3?.[UI2.Nav], "aria-label": labelNav2(), onPreviousClick: handlePreviousClick, onNextClick: handleNextClick, previousMonth, nextMonth }), 57563 import_react165.default.createElement( 57564 components.MonthGrid, 57565 { role: "grid", "aria-multiselectable": mode2 === "multiple" || mode2 === "range", "aria-label": labelGrid2(calendarMonth.date, dateLib.options, dateLib) || void 0, className: classNames[UI2.MonthGrid], style: styles3?.[UI2.MonthGrid] }, 57566 !props.hideWeekdays && import_react165.default.createElement( 57567 components.Weekdays, 57568 { "data-animated-weekdays": props.animate ? "true" : void 0, className: classNames[UI2.Weekdays], style: styles3?.[UI2.Weekdays] }, 57569 showWeekNumber && import_react165.default.createElement(components.WeekNumberHeader, { "aria-label": labelWeekNumberHeader2(dateLib.options), className: classNames[UI2.WeekNumberHeader], style: styles3?.[UI2.WeekNumberHeader], scope: "col" }, formatWeekNumberHeader2()), 57570 weekdays.map((weekday, i3) => import_react165.default.createElement(components.Weekday, { "aria-label": labelWeekday2(weekday, dateLib.options, dateLib), className: classNames[UI2.Weekday], key: i3, style: styles3?.[UI2.Weekday], scope: "col" }, formatWeekdayName2(weekday, dateLib.options, dateLib))) 57571 ), 57572 import_react165.default.createElement(components.Weeks, { "data-animated-weeks": props.animate ? "true" : void 0, className: classNames[UI2.Weeks], style: styles3?.[UI2.Weeks] }, calendarMonth.weeks.map((week, weekIndex) => { 57573 return import_react165.default.createElement( 57574 components.Week, 57575 { className: classNames[UI2.Week], key: week.weekNumber, style: styles3?.[UI2.Week], week }, 57576 showWeekNumber && import_react165.default.createElement(components.WeekNumber, { week, style: styles3?.[UI2.WeekNumber], "aria-label": labelWeekNumber2(week.weekNumber, { 57577 locale 57578 }), className: classNames[UI2.WeekNumber], scope: "row", role: "rowheader" }, formatWeekNumber2(week.weekNumber, dateLib)), 57579 week.days.map((day) => { 57580 const { date } = day; 57581 const modifiers = getModifiers(day); 57582 modifiers[DayFlag.focused] = !modifiers.hidden && Boolean(focused?.isEqualTo(day)); 57583 modifiers[SelectionState.selected] = isSelected2?.(date) || modifiers.selected; 57584 if (isDateRange(selectedValue)) { 57585 const { from: from2, to } = selectedValue; 57586 modifiers[SelectionState.range_start] = Boolean(from2 && to && dateLib.isSameDay(date, from2)); 57587 modifiers[SelectionState.range_end] = Boolean(from2 && to && dateLib.isSameDay(date, to)); 57588 modifiers[SelectionState.range_middle] = rangeIncludesDate(selectedValue, date, true, dateLib); 57589 } 57590 const style3 = getStyleForModifiers(modifiers, styles3, props.modifiersStyles); 57591 const className3 = getClassNamesForModifiers(modifiers, classNames, props.modifiersClassNames); 57592 const ariaLabel = !isInteractive && !modifiers.hidden ? labelGridcell2(date, modifiers, dateLib.options, dateLib) : void 0; 57593 return import_react165.default.createElement(components.Day, { key: `$dateLib.format(date, "yyyy-MM-dd")}_$dateLib.format(day.displayMonth, "yyyy-MM")}`, day, modifiers, className: className3.join(" "), style: style3, role: "gridcell", "aria-selected": modifiers.selected || void 0, "aria-label": ariaLabel, "data-day": dateLib.format(date, "yyyy-MM-dd"), "data-month": day.outside ? dateLib.format(date, "yyyy-MM") : void 0, "data-selected": modifiers.selected || void 0, "data-disabled": modifiers.disabled || void 0, "data-hidden": modifiers.hidden || void 0, "data-outside": day.outside || void 0, "data-focused": modifiers.focused || void 0, "data-today": modifiers.today || void 0 }, !modifiers.hidden && isInteractive ? import_react165.default.createElement(components.DayButton, { className: classNames[UI2.DayButton], style: styles3?.[UI2.DayButton], type: "button", day, modifiers, disabled: modifiers.disabled || void 0, tabIndex: isFocusTarget(day) ? 0 : -1, "aria-label": labelDayButton2(date, modifiers, dateLib.options, dateLib), onClick: handleDayClick(day, modifiers), onBlur: handleDayBlur(day, modifiers), onFocus: handleDayFocus(day, modifiers), onKeyDown: handleDayKeyDown(day, modifiers), onMouseEnter: handleDayMouseEnter(day, modifiers), onMouseLeave: handleDayMouseLeave(day, modifiers) }, formatDay2(date, dateLib.options, dateLib)) : !modifiers.hidden && formatDay2(day.date, dateLib.options, dateLib)); 57594 }) 57595 ); 57596 })) 57597 ) 57598 ); 57599 }) 57600 ), 57601 props.footer && import_react165.default.createElement(components.Footer, { className: classNames[UI2.Footer], style: styles3?.[UI2.Footer], role: "status", "aria-live": "polite" }, props.footer) 57602 ) 57603 ); 57604 } 57605 57606 // packages/components/build-module/calendar/date-calendar/index.js 57607 var import_element244 = __toESM(require_element()); 57608 57609 // packages/components/build-module/calendar/utils/day-cell.js 57610 var import_jsx_runtime319 = __toESM(require_jsx_runtime()); 57611 var PreviewDashStartAndEnd = () => { 57612 return /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("svg", { 57613 viewBox: "0 0 32 32", 57614 xmlns: "http://www.w3.org/2000/svg", 57615 fill: "none", 57616 stroke: "currentColor", 57617 strokeDasharray: "3.7677", 57618 strokeDashoffset: "3.2", 57619 strokeWidth: "1", 57620 children: /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("path", { 57621 d: "M29.5,0.5 h-27 a2,2 0 0 0 -2,2 v27 a2,2 0 0 0 2,2 h27 a2,2 0 0 0 2,-2 v-27 a2,2 0 0 0 -2,-2" 57622 }) 57623 }); 57624 }; 57625 var PreviewDashStart = () => { 57626 return /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("svg", { 57627 viewBox: "0 0 32 32", 57628 xmlns: "http://www.w3.org/2000/svg", 57629 fill: "none", 57630 stroke: "currentColor", 57631 strokeDasharray: "3.84516", 57632 strokeDashoffset: "1.9226", 57633 strokeWidth: "1", 57634 children: /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("path", { 57635 d: "M32,0.5 h-29.5 a2,2 0 0 0 -2,2 v27 a2,2 0 0 0 2,2 h30" 57636 }) 57637 }); 57638 }; 57639 var PreviewDashMiddle = () => { 57640 return /* @__PURE__ */ (0, import_jsx_runtime319.jsxs)("svg", { 57641 viewBox: "0 0 32 32", 57642 xmlns: "http://www.w3.org/2000/svg", 57643 fill: "none", 57644 stroke: "currentColor", 57645 strokeDasharray: "3.9 4", 57646 strokeDashoffset: "2", 57647 strokeWidth: "1", 57648 children: [/* @__PURE__ */ (0, import_jsx_runtime319.jsx)("line", { 57649 x1: "0", 57650 y1: "0.5", 57651 x2: "100", 57652 y2: "0.5" 57653 }), /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("line", { 57654 x1: "0", 57655 y1: "31.5", 57656 x2: "100", 57657 y2: "31.5" 57658 })] 57659 }); 57660 }; 57661 var PreviewDashEnd = () => { 57662 return /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("svg", { 57663 viewBox: "0 0 32 32", 57664 xmlns: "http://www.w3.org/2000/svg", 57665 fill: "none", 57666 stroke: "currentColor", 57667 strokeDasharray: "3.84516", 57668 strokeDashoffset: "1.9226", 57669 strokeWidth: "1", 57670 children: /* @__PURE__ */ (0, import_jsx_runtime319.jsx)("path", { 57671 d: "M0,0.5 h29.5 a2,2 0 0 1 2,2 v27 a2,2 0 0 1 -2,2 h-29.5" 57672 }) 57673 }); 57674 }; 57675 function Day4(props) { 57676 const { 57677 day, 57678 modifiers, 57679 children, 57680 ...tdProps 57681 } = props; 57682 let PreviewDash; 57683 if (modifiers.preview_start && modifiers.preview_end) { 57684 PreviewDash = PreviewDashStartAndEnd; 57685 } else if (modifiers.preview_start) { 57686 PreviewDash = PreviewDashStart; 57687 } else if (modifiers.preview_end) { 57688 PreviewDash = PreviewDashEnd; 57689 } else if (modifiers.preview) { 57690 PreviewDash = PreviewDashMiddle; 57691 } 57692 return /* @__PURE__ */ (0, import_jsx_runtime319.jsxs)("td", { 57693 ...tdProps, 57694 children: [PreviewDash && /* @__PURE__ */ (0, import_jsx_runtime319.jsx)(PreviewDash, {}), children] 57695 }); 57696 } 57697 57698 // packages/components/build-module/calendar/utils/constants.js 57699 var CLASSNAMES = { 57700 root: "components-calendar", 57701 day: "components-calendar__day", 57702 day_button: "components-calendar__day-button", 57703 caption_label: "components-calendar__caption-label", 57704 button_next: "components-calendar__button-next", 57705 button_previous: "components-calendar__button-previous", 57706 chevron: "components-calendar__chevron", 57707 nav: "components-calendar__nav", 57708 month_caption: "components-calendar__month-caption", 57709 months: "components-calendar__months", 57710 month_grid: "components-calendar__month-grid", 57711 weekday: "components-calendar__weekday", 57712 today: "components-calendar__day--today", 57713 selected: "components-calendar__day--selected", 57714 disabled: "components-calendar__day--disabled", 57715 hidden: "components-calendar__day--hidden", 57716 range_start: "components-calendar__range-start", 57717 range_end: "components-calendar__range-end", 57718 range_middle: "components-calendar__range-middle", 57719 weeks_before_enter: "components-calendar__weeks-before-enter", 57720 weeks_before_exit: "components-calendar__weeks-before-exit", 57721 weeks_after_enter: "components-calendar__weeks-after-enter", 57722 weeks_after_exit: "components-calendar__weeks-after-exit", 57723 caption_after_enter: "components-calendar__caption-after-enter", 57724 caption_after_exit: "components-calendar__caption-after-exit", 57725 caption_before_enter: "components-calendar__caption-before-enter", 57726 caption_before_exit: "components-calendar__caption-before-exit" 57727 }; 57728 var MODIFIER_CLASSNAMES = { 57729 preview: "components-calendar__day--preview", 57730 preview_start: "components-calendar__day--preview-start", 57731 preview_end: "components-calendar__day--preview-end" 57732 }; 57733 var COMMON_PROPS = { 57734 animate: true, 57735 // Only show days in the current month 57736 showOutsideDays: false, 57737 // Hide week number column 57738 showWeekNumber: false, 57739 // Show weekdays row 57740 hideWeekdays: false, 57741 // Month and year caption are not interactive 57742 captionLayout: "label", 57743 // Show a variable number of weeks depending on the month 57744 fixedWeeks: false, 57745 // Show navigation buttons 57746 hideNavigation: false, 57747 // Class names 57748 classNames: CLASSNAMES, 57749 // Default role 57750 role: "application", 57751 components: { 57752 Day: Day4 57753 } 57754 }; 57755 57756 // packages/components/build-module/calendar/utils/misc.js 57757 function clampNumberOfMonths(numberOfMonths) { 57758 return Math.min(3, Math.max(1, numberOfMonths)); 57759 } 57760 57761 // packages/components/build-module/calendar/utils/use-localization-props.js 57762 var import_i18n81 = __toESM(require_i18n()); 57763 var import_element243 = __toESM(require_element()); 57764 function isLocaleRTL(localeCode) { 57765 const localeObj = new Intl.Locale(localeCode); 57766 if ("getTextInfo" in localeObj) { 57767 return localeObj.getTextInfo().direction === "rtl"; 57768 } 57769 return [ 57770 "ar", 57771 // Arabic 57772 "he", 57773 // Hebrew 57774 "fa", 57775 // Persian (Farsi) 57776 "ur", 57777 // Urdu 57778 "ps", 57779 // Pashto 57780 "syr", 57781 // Syriac 57782 "dv", 57783 // Divehi 57784 "ku", 57785 // Kurdish (Sorani) 57786 "yi" 57787 // Yiddish 57788 ].includes(localeObj.language); 57789 } 57790 var useLocalizationProps = ({ 57791 locale, 57792 timeZone, 57793 mode: mode2 57794 }) => { 57795 return (0, import_element243.useMemo)(() => { 57796 const monthNameFormatter = new Intl.DateTimeFormat(locale.code, { 57797 year: "numeric", 57798 month: "long", 57799 timeZone 57800 }); 57801 const weekdayNarrowFormatter = new Intl.DateTimeFormat(locale.code, { 57802 weekday: "narrow", 57803 timeZone 57804 }); 57805 const weekdayLongFormatter = new Intl.DateTimeFormat(locale.code, { 57806 weekday: "long", 57807 timeZone 57808 }); 57809 const fullDateFormatter = new Intl.DateTimeFormat(locale.code, { 57810 weekday: "long", 57811 year: "numeric", 57812 month: "long", 57813 day: "numeric", 57814 timeZone 57815 }); 57816 return { 57817 "aria-label": mode2 === "single" ? (0, import_i18n81.__)("Date calendar") : (0, import_i18n81.__)("Date range calendar"), 57818 labels: { 57819 /** 57820 * The label for the month grid. 57821 * @param date 57822 */ 57823 labelGrid: (date) => monthNameFormatter.format(date), 57824 /** 57825 * The label for the gridcell, when the calendar is not interactive. 57826 * @param date 57827 * @param modifiers 57828 */ 57829 labelGridcell: (date, modifiers) => { 57830 const formattedDate = fullDateFormatter.format(date); 57831 let label = formattedDate; 57832 if (modifiers?.today) { 57833 label = (0, import_i18n81.sprintf)( 57834 // translators: %s is the full date (e.g. "Monday, April 29, 2025") 57835 (0, import_i18n81.__)("Today, %s"), 57836 formattedDate 57837 ); 57838 } 57839 return label; 57840 }, 57841 /** The label for the "next month" button. */ 57842 labelNext: () => (0, import_i18n81.__)("Go to the Next Month"), 57843 /** The label for the "previous month" button. */ 57844 labelPrevious: () => (0, import_i18n81.__)("Go to the Previous Month"), 57845 /** 57846 * The label for the day button. 57847 * @param date 57848 * @param modifiers 57849 */ 57850 labelDayButton: (date, modifiers) => { 57851 const formattedDate = fullDateFormatter.format(date); 57852 let label = formattedDate; 57853 if (modifiers?.today) { 57854 label = (0, import_i18n81.sprintf)( 57855 // translators: %s is the full date (e.g. "Monday, April 29, 2025") 57856 (0, import_i18n81.__)("Today, %s"), 57857 formattedDate 57858 ); 57859 } 57860 if (modifiers?.selected) { 57861 label = (0, import_i18n81.sprintf)( 57862 // translators: %s is the full date (e.g. "Monday, April 29, 2025") 57863 (0, import_i18n81.__)("%s, selected"), 57864 formattedDate 57865 ); 57866 } 57867 return label; 57868 }, 57869 /** 57870 * The label for the weekday. 57871 * @param date 57872 */ 57873 labelWeekday: (date) => weekdayLongFormatter.format(date) 57874 }, 57875 locale, 57876 dir: isLocaleRTL(locale.code) ? "rtl" : "ltr", 57877 formatters: { 57878 formatWeekdayName: (date) => { 57879 return weekdayNarrowFormatter.format(date); 57880 }, 57881 formatCaption: (date) => { 57882 return monthNameFormatter.format(date); 57883 } 57884 }, 57885 timeZone 57886 }; 57887 }, [locale, timeZone, mode2]); 57888 }; 57889 57890 // packages/components/build-module/calendar/date-calendar/index.js 57891 var import_jsx_runtime320 = __toESM(require_jsx_runtime()); 57892 var DateCalendar = ({ 57893 defaultSelected, 57894 selected: selectedProp, 57895 onSelect, 57896 numberOfMonths = 1, 57897 locale = enUS2, 57898 timeZone, 57899 ...props 57900 }) => { 57901 const localizationProps = useLocalizationProps({ 57902 locale, 57903 timeZone, 57904 mode: "single" 57905 }); 57906 const onChange = (0, import_element244.useCallback)((selected2, triggerDate, modifiers, e3) => { 57907 onSelect?.(selected2 !== null && selected2 !== void 0 ? selected2 : void 0, triggerDate, modifiers, e3); 57908 }, [onSelect]); 57909 const [selected, setSelected] = useControlledValue({ 57910 defaultValue: defaultSelected, 57911 value: selectedProp, 57912 onChange 57913 }); 57914 return /* @__PURE__ */ (0, import_jsx_runtime320.jsx)(DayPicker, { 57915 ...COMMON_PROPS, 57916 ...localizationProps, 57917 ...props, 57918 mode: "single", 57919 numberOfMonths: clampNumberOfMonths(numberOfMonths), 57920 selected: selected !== null && selected !== void 0 ? selected : void 0, 57921 onSelect: setSelected 57922 }); 57923 }; 57924 57925 // packages/components/build-module/calendar/date-range-calendar/index.js 57926 var import_element245 = __toESM(require_element()); 57927 var import_jsx_runtime321 = __toESM(require_jsx_runtime()); 57928 function usePreviewRange({ 57929 selected, 57930 hoveredDate, 57931 excludeDisabled, 57932 min: min3, 57933 max: max3, 57934 disabled 57935 }) { 57936 return (0, import_element245.useMemo)(() => { 57937 if (!hoveredDate || !selected?.from) { 57938 return; 57939 } 57940 let previewHighlight; 57941 let potentialNewRange; 57942 if (hoveredDate < selected.from) { 57943 var _selected$to; 57944 previewHighlight = { 57945 from: hoveredDate, 57946 to: selected.from 57947 }; 57948 potentialNewRange = { 57949 from: hoveredDate, 57950 to: (_selected$to = selected.to) !== null && _selected$to !== void 0 ? _selected$to : selected.from 57951 }; 57952 } else if (selected.to && hoveredDate > selected.from && hoveredDate < selected.to) { 57953 previewHighlight = { 57954 from: selected.from, 57955 to: hoveredDate 57956 }; 57957 potentialNewRange = { 57958 from: selected.from, 57959 to: hoveredDate 57960 }; 57961 } else if (hoveredDate > selected.from) { 57962 var _selected$to2; 57963 previewHighlight = { 57964 from: (_selected$to2 = selected.to) !== null && _selected$to2 !== void 0 ? _selected$to2 : selected.from, 57965 to: hoveredDate 57966 }; 57967 potentialNewRange = { 57968 from: selected.from, 57969 to: hoveredDate 57970 }; 57971 } 57972 if (min3 !== void 0 && min3 > 0 && potentialNewRange && differenceInCalendarDays(potentialNewRange.to, potentialNewRange.from) < min3) { 57973 previewHighlight = { 57974 from: hoveredDate, 57975 to: hoveredDate 57976 }; 57977 } 57978 if (max3 !== void 0 && max3 > 0 && potentialNewRange && differenceInCalendarDays(potentialNewRange.to, potentialNewRange.from) > max3) { 57979 previewHighlight = { 57980 from: hoveredDate, 57981 to: hoveredDate 57982 }; 57983 } 57984 if (excludeDisabled && disabled && potentialNewRange && rangeContainsModifiers(potentialNewRange, disabled)) { 57985 previewHighlight = { 57986 from: hoveredDate, 57987 to: hoveredDate 57988 }; 57989 } 57990 return previewHighlight; 57991 }, [selected, hoveredDate, excludeDisabled, min3, max3, disabled]); 57992 } 57993 var DateRangeCalendar = ({ 57994 defaultSelected, 57995 selected: selectedProp, 57996 onSelect, 57997 numberOfMonths = 1, 57998 excludeDisabled, 57999 min: min3, 58000 max: max3, 58001 disabled, 58002 locale = enUS2, 58003 timeZone, 58004 ...props 58005 }) => { 58006 const localizationProps = useLocalizationProps({ 58007 locale, 58008 timeZone, 58009 mode: "range" 58010 }); 58011 const onChange = (0, import_element245.useCallback)((selected2, triggerDate, modifiers2, e3) => { 58012 onSelect?.(selected2 !== null && selected2 !== void 0 ? selected2 : void 0, triggerDate, modifiers2, e3); 58013 }, [onSelect]); 58014 const [selected, setSelected] = useControlledValue({ 58015 defaultValue: defaultSelected, 58016 value: selectedProp, 58017 onChange 58018 }); 58019 const [hoveredDate, setHoveredDate] = (0, import_element245.useState)(void 0); 58020 const previewRange = usePreviewRange({ 58021 selected, 58022 hoveredDate, 58023 excludeDisabled, 58024 min: min3, 58025 max: max3, 58026 disabled 58027 }); 58028 const modifiers = (0, import_element245.useMemo)(() => { 58029 return { 58030 preview: previewRange, 58031 preview_start: previewRange?.from, 58032 preview_end: previewRange?.to 58033 }; 58034 }, [previewRange]); 58035 return /* @__PURE__ */ (0, import_jsx_runtime321.jsx)(DayPicker, { 58036 ...COMMON_PROPS, 58037 ...localizationProps, 58038 ...props, 58039 mode: "range", 58040 numberOfMonths: clampNumberOfMonths(numberOfMonths), 58041 disabled, 58042 excludeDisabled, 58043 min: min3, 58044 max: max3, 58045 selected: selected !== null && selected !== void 0 ? selected : void 0, 58046 onSelect: setSelected, 58047 onDayMouseEnter: (date) => setHoveredDate(date), 58048 onDayMouseLeave: () => setHoveredDate(void 0), 58049 modifiers, 58050 modifiersClassNames: MODIFIER_CLASSNAMES 58051 }); 58052 }; 58053 58054 // packages/components/build-module/validated-form-controls/components/checkbox-control.js 58055 var import_compose88 = __toESM(require_compose()); 58056 var import_element247 = __toESM(require_element()); 58057 58058 // packages/components/build-module/validated-form-controls/control-with-error.js 58059 var import_i18n82 = __toESM(require_i18n()); 58060 var import_element246 = __toESM(require_element()); 58061 58062 // packages/components/build-module/validated-form-controls/validity-indicator.js 58063 var import_jsx_runtime322 = __toESM(require_jsx_runtime()); 58064 function ValidityIndicator({ 58065 type, 58066 message: message3 58067 }) { 58068 const ICON = { 58069 valid: published_default, 58070 invalid: error_default 58071 }; 58072 return /* @__PURE__ */ (0, import_jsx_runtime322.jsxs)("p", { 58073 className: clsx_default("components-validated-control__indicator", `is-$type}`), 58074 children: [type === "validating" ? /* @__PURE__ */ (0, import_jsx_runtime322.jsx)(spinner_default, { 58075 className: "components-validated-control__indicator-spinner" 58076 }) : /* @__PURE__ */ (0, import_jsx_runtime322.jsx)(icon_default3, { 58077 className: "components-validated-control__indicator-icon", 58078 icon: ICON[type], 58079 size: 16, 58080 fill: "currentColor" 58081 }), message3] 58082 }); 58083 } 58084 58085 // packages/components/build-module/validated-form-controls/control-with-error.js 58086 var import_jsx_runtime323 = __toESM(require_jsx_runtime()); 58087 function appendRequiredIndicator(label, required, markWhenOptional) { 58088 if (required && !markWhenOptional) { 58089 return /* @__PURE__ */ (0, import_jsx_runtime323.jsxs)(import_jsx_runtime323.Fragment, { 58090 children: [label, " ", `(${(0, import_i18n82.__)("Required")})`] 58091 }); 58092 } 58093 if (!required && markWhenOptional) { 58094 return /* @__PURE__ */ (0, import_jsx_runtime323.jsxs)(import_jsx_runtime323.Fragment, { 58095 children: [label, " ", `(${(0, import_i18n82.__)("Optional")})`] 58096 }); 58097 } 58098 return label; 58099 } 58100 var VALIDITY_VISIBLE_ATTRIBUTE = "data-validity-visible"; 58101 var className = "components-validated-control"; 58102 function UnforwardedControlWithError({ 58103 required, 58104 markWhenOptional, 58105 customValidity, 58106 getValidityTarget, 58107 children 58108 }, forwardedRef) { 58109 const [errorMessage, setErrorMessage] = (0, import_element246.useState)(); 58110 const [statusMessage, setStatusMessage] = (0, import_element246.useState)(); 58111 const [showMessage, setShowMessage] = (0, import_element246.useState)(false); 58112 const [isTouched, setIsTouched] = (0, import_element246.useState)(false); 58113 (0, import_element246.useEffect)(() => { 58114 const validityTarget = getValidityTarget(); 58115 const handler = () => { 58116 setShowMessage(true); 58117 validityTarget?.setAttribute(VALIDITY_VISIBLE_ATTRIBUTE, ""); 58118 }; 58119 validityTarget?.addEventListener("invalid", handler); 58120 return () => validityTarget?.removeEventListener("invalid", handler); 58121 }, [getValidityTarget]); 58122 (0, import_element246.useEffect)(() => { 58123 var _validityTarget$close; 58124 const validityTarget = getValidityTarget(); 58125 const suppressNativePopover = (event) => { 58126 var _target$form$elements; 58127 event.preventDefault(); 58128 const target = event.target; 58129 const firstErrorInForm = Array.from((_target$form$elements = target.form?.elements) !== null && _target$form$elements !== void 0 ? _target$form$elements : []).find((el) => !el.validity.valid); 58130 if (!target.form || firstErrorInForm === target) { 58131 target.focus(); 58132 } 58133 }; 58134 const radioSibilings = validityTarget?.type === "radio" && validityTarget?.name ? Array.from((_validityTarget$close = validityTarget?.closest(`.$className}`)?.querySelectorAll(`input[type="radio"][name="$validityTarget?.name}"]`)) !== null && _validityTarget$close !== void 0 ? _validityTarget$close : []).filter((sibling) => sibling !== validityTarget) : []; 58135 validityTarget?.addEventListener("invalid", suppressNativePopover); 58136 radioSibilings.forEach((sibling) => sibling.addEventListener("invalid", suppressNativePopover)); 58137 return () => { 58138 validityTarget?.removeEventListener("invalid", suppressNativePopover); 58139 radioSibilings.forEach((sibling) => sibling.removeEventListener("invalid", suppressNativePopover)); 58140 }; 58141 }, [getValidityTarget]); 58142 (0, import_element246.useEffect)(() => { 58143 const validityTarget = getValidityTarget(); 58144 if (!customValidity?.type) { 58145 validityTarget?.setCustomValidity(""); 58146 setErrorMessage(validityTarget?.validationMessage); 58147 setStatusMessage(void 0); 58148 return; 58149 } 58150 switch (customValidity.type) { 58151 case "validating": { 58152 validityTarget?.setCustomValidity(""); 58153 setErrorMessage(void 0); 58154 setStatusMessage({ 58155 type: "validating", 58156 message: customValidity.message 58157 }); 58158 break; 58159 } 58160 case "valid": { 58161 validityTarget?.setCustomValidity(""); 58162 setErrorMessage(validityTarget?.validationMessage); 58163 setStatusMessage({ 58164 type: "valid", 58165 message: customValidity.message 58166 }); 58167 break; 58168 } 58169 case "invalid": { 58170 var _customValidity$messa; 58171 validityTarget?.setCustomValidity((_customValidity$messa = customValidity.message) !== null && _customValidity$messa !== void 0 ? _customValidity$messa : ""); 58172 setErrorMessage(validityTarget?.validationMessage); 58173 setStatusMessage(void 0); 58174 break; 58175 } 58176 } 58177 }, [customValidity, getValidityTarget]); 58178 (0, import_element246.useEffect)(() => { 58179 if (!isTouched || showMessage) { 58180 return; 58181 } 58182 if (customValidity?.type === "validating") { 58183 const timer = setTimeout(() => { 58184 setShowMessage(true); 58185 }, 1e3); 58186 return () => clearTimeout(timer); 58187 } 58188 setShowMessage(true); 58189 }, [isTouched, customValidity?.type, showMessage]); 58190 const onBlur = (event) => { 58191 if (isTouched) { 58192 return; 58193 } 58194 if (!event.relatedTarget || !event.currentTarget.contains(event.relatedTarget)) { 58195 setIsTouched(true); 58196 getValidityTarget()?.setAttribute(VALIDITY_VISIBLE_ATTRIBUTE, ""); 58197 } 58198 }; 58199 const message3 = () => { 58200 if (errorMessage) { 58201 return /* @__PURE__ */ (0, import_jsx_runtime323.jsx)(ValidityIndicator, { 58202 type: "invalid", 58203 message: errorMessage 58204 }); 58205 } 58206 if (statusMessage?.type) { 58207 return /* @__PURE__ */ (0, import_jsx_runtime323.jsx)(ValidityIndicator, { 58208 type: statusMessage.type, 58209 message: statusMessage.message 58210 }); 58211 } 58212 return null; 58213 }; 58214 return /* @__PURE__ */ (0, import_jsx_runtime323.jsxs)("div", { 58215 className, 58216 ref: forwardedRef, 58217 onBlur, 58218 children: [(0, import_element246.cloneElement)(children, { 58219 label: appendRequiredIndicator(children.props.label, required, markWhenOptional), 58220 required 58221 }), /* @__PURE__ */ (0, import_jsx_runtime323.jsx)("div", { 58222 "aria-live": "polite", 58223 children: showMessage && message3() 58224 })] 58225 }); 58226 } 58227 var ControlWithError = (0, import_element246.forwardRef)(UnforwardedControlWithError); 58228 58229 // packages/components/build-module/validated-form-controls/components/checkbox-control.js 58230 var import_jsx_runtime324 = __toESM(require_jsx_runtime()); 58231 var UnforwardedValidatedCheckboxControl = ({ 58232 required, 58233 customValidity, 58234 markWhenOptional, 58235 ...restProps 58236 }, forwardedRef) => { 58237 const validityTargetRef = (0, import_element247.useRef)(null); 58238 const mergedRefs = (0, import_compose88.useMergeRefs)([forwardedRef, validityTargetRef]); 58239 return /* @__PURE__ */ (0, import_jsx_runtime324.jsx)(ControlWithError, { 58240 required, 58241 markWhenOptional, 58242 ref: mergedRefs, 58243 customValidity, 58244 getValidityTarget: () => validityTargetRef.current?.querySelector('input[type="checkbox"]'), 58245 children: /* @__PURE__ */ (0, import_jsx_runtime324.jsx)( 58246 checkbox_control_default, 58247 { 58248 ...restProps 58249 } 58250 ) 58251 }); 58252 }; 58253 var ValidatedCheckboxControl = (0, import_element247.forwardRef)(UnforwardedValidatedCheckboxControl); 58254 58255 // packages/components/build-module/validated-form-controls/components/form-token-field.js 58256 var import_element248 = __toESM(require_element()); 58257 var import_jsx_runtime325 = __toESM(require_jsx_runtime()); 58258 var UnforwardedValidatedFormTokenField = ({ 58259 required, 58260 customValidity, 58261 markWhenOptional, 58262 ...restProps 58263 }, forwardedRef) => { 58264 const validityTargetRef = (0, import_element248.useRef)(null); 58265 return /* @__PURE__ */ (0, import_jsx_runtime325.jsxs)("div", { 58266 className: "components-validated-control__wrapper-with-error-delegate", 58267 ref: forwardedRef, 58268 children: [/* @__PURE__ */ (0, import_jsx_runtime325.jsx)(ControlWithError, { 58269 required, 58270 markWhenOptional, 58271 customValidity, 58272 getValidityTarget: () => validityTargetRef.current, 58273 children: /* @__PURE__ */ (0, import_jsx_runtime325.jsx)(FormTokenField, { 58274 __next40pxDefaultSize: true, 58275 ...restProps 58276 }) 58277 }), /* @__PURE__ */ (0, import_jsx_runtime325.jsx)("input", { 58278 className: "components-validated-control__error-delegate", 58279 type: "text", 58280 ref: validityTargetRef, 58281 required, 58282 value: restProps.value && restProps.value.length > 0 ? "hasvalue" : "", 58283 tabIndex: -1, 58284 onChange: () => { 58285 }, 58286 onFocus: (e3) => { 58287 e3.target.previousElementSibling?.querySelector('input[type="text"]')?.focus(); 58288 } 58289 })] 58290 }); 58291 }; 58292 var ValidatedFormTokenField = (0, import_element248.forwardRef)(UnforwardedValidatedFormTokenField); 58293 58294 // packages/components/build-module/validated-form-controls/components/input-control.js 58295 var import_element249 = __toESM(require_element()); 58296 var import_compose89 = __toESM(require_compose()); 58297 var import_jsx_runtime326 = __toESM(require_jsx_runtime()); 58298 var UnforwardedValidatedInputControl = ({ 58299 required, 58300 customValidity, 58301 markWhenOptional, 58302 ...restProps 58303 }, forwardedRef) => { 58304 const validityTargetRef = (0, import_element249.useRef)(null); 58305 const mergedRefs = (0, import_compose89.useMergeRefs)([forwardedRef, validityTargetRef]); 58306 return /* @__PURE__ */ (0, import_jsx_runtime326.jsx)(ControlWithError, { 58307 required, 58308 markWhenOptional, 58309 customValidity, 58310 getValidityTarget: () => validityTargetRef.current, 58311 children: /* @__PURE__ */ (0, import_jsx_runtime326.jsx)(input_control_default, { 58312 __next40pxDefaultSize: true, 58313 ref: mergedRefs, 58314 ...restProps 58315 }) 58316 }); 58317 }; 58318 var ValidatedInputControl = (0, import_element249.forwardRef)(UnforwardedValidatedInputControl); 58319 58320 // packages/components/build-module/validated-form-controls/components/number-control.js 58321 var import_element250 = __toESM(require_element()); 58322 var import_compose90 = __toESM(require_compose()); 58323 var import_jsx_runtime327 = __toESM(require_jsx_runtime()); 58324 var UnforwardedValidatedNumberControl = ({ 58325 required, 58326 customValidity, 58327 markWhenOptional, 58328 ...restProps 58329 }, forwardedRef) => { 58330 const validityTargetRef = (0, import_element250.useRef)(null); 58331 const mergedRefs = (0, import_compose90.useMergeRefs)([forwardedRef, validityTargetRef]); 58332 return /* @__PURE__ */ (0, import_jsx_runtime327.jsx)(ControlWithError, { 58333 required, 58334 markWhenOptional, 58335 customValidity, 58336 getValidityTarget: () => validityTargetRef.current, 58337 children: /* @__PURE__ */ (0, import_jsx_runtime327.jsx)(number_control_default, { 58338 __next40pxDefaultSize: true, 58339 ref: mergedRefs, 58340 ...restProps 58341 }) 58342 }); 58343 }; 58344 var ValidatedNumberControl = (0, import_element250.forwardRef)(UnforwardedValidatedNumberControl); 58345 58346 // packages/components/build-module/validated-form-controls/components/radio-control.js 58347 var import_compose91 = __toESM(require_compose()); 58348 var import_element251 = __toESM(require_element()); 58349 var import_jsx_runtime328 = __toESM(require_jsx_runtime()); 58350 var UnforwardedValidatedRadioControl = ({ 58351 required, 58352 customValidity, 58353 markWhenOptional, 58354 ...restProps 58355 }, forwardedRef) => { 58356 const validityTargetRef = (0, import_element251.useRef)(null); 58357 const mergedRefs = (0, import_compose91.useMergeRefs)([forwardedRef, validityTargetRef]); 58358 return /* @__PURE__ */ (0, import_jsx_runtime328.jsx)(ControlWithError, { 58359 required, 58360 markWhenOptional, 58361 ref: mergedRefs, 58362 customValidity, 58363 getValidityTarget: () => validityTargetRef.current?.querySelector('input[type="radio"]'), 58364 children: /* @__PURE__ */ (0, import_jsx_runtime328.jsx)(radio_control_default, { 58365 ...restProps 58366 }) 58367 }); 58368 }; 58369 var ValidatedRadioControl = (0, import_element251.forwardRef)(UnforwardedValidatedRadioControl); 58370 58371 // packages/components/build-module/validated-form-controls/components/select-control.js 58372 var import_element252 = __toESM(require_element()); 58373 var import_compose92 = __toESM(require_compose()); 58374 var import_jsx_runtime329 = __toESM(require_jsx_runtime()); 58375 var UnforwardedValidatedSelectControl = ({ 58376 required, 58377 customValidity, 58378 markWhenOptional, 58379 ...restProps 58380 }, forwardedRef) => { 58381 const validityTargetRef = (0, import_element252.useRef)(null); 58382 const mergedRefs = (0, import_compose92.useMergeRefs)([forwardedRef, validityTargetRef]); 58383 return /* @__PURE__ */ (0, import_jsx_runtime329.jsx)(ControlWithError, { 58384 required, 58385 markWhenOptional, 58386 customValidity, 58387 getValidityTarget: () => validityTargetRef.current, 58388 children: /* @__PURE__ */ (0, import_jsx_runtime329.jsx)(select_control_default, { 58389 __next40pxDefaultSize: true, 58390 ref: mergedRefs, 58391 ...restProps 58392 }) 58393 }); 58394 }; 58395 var ValidatedSelectControl = (0, import_element252.forwardRef)(UnforwardedValidatedSelectControl); 58396 58397 // packages/components/build-module/validated-form-controls/components/text-control.js 58398 var import_compose93 = __toESM(require_compose()); 58399 var import_element253 = __toESM(require_element()); 58400 var import_jsx_runtime330 = __toESM(require_jsx_runtime()); 58401 var UnforwardedValidatedTextControl = ({ 58402 required, 58403 customValidity, 58404 markWhenOptional, 58405 ...restProps 58406 }, forwardedRef) => { 58407 const validityTargetRef = (0, import_element253.useRef)(null); 58408 const mergedRefs = (0, import_compose93.useMergeRefs)([forwardedRef, validityTargetRef]); 58409 return /* @__PURE__ */ (0, import_jsx_runtime330.jsx)(ControlWithError, { 58410 required, 58411 markWhenOptional, 58412 customValidity, 58413 getValidityTarget: () => validityTargetRef.current, 58414 children: /* @__PURE__ */ (0, import_jsx_runtime330.jsx)(text_control_default, { 58415 __next40pxDefaultSize: true, 58416 ref: mergedRefs, 58417 ...restProps 58418 }) 58419 }); 58420 }; 58421 var ValidatedTextControl = (0, import_element253.forwardRef)(UnforwardedValidatedTextControl); 58422 58423 // packages/components/build-module/validated-form-controls/components/textarea-control.js 58424 var import_element254 = __toESM(require_element()); 58425 var import_compose94 = __toESM(require_compose()); 58426 var import_jsx_runtime331 = __toESM(require_jsx_runtime()); 58427 var UnforwardedValidatedTextareaControl = ({ 58428 required, 58429 customValidity, 58430 markWhenOptional, 58431 ...restProps 58432 }, forwardedRef) => { 58433 const validityTargetRef = (0, import_element254.useRef)(null); 58434 const mergedRefs = (0, import_compose94.useMergeRefs)([forwardedRef, validityTargetRef]); 58435 return /* @__PURE__ */ (0, import_jsx_runtime331.jsx)(ControlWithError, { 58436 required, 58437 markWhenOptional, 58438 customValidity, 58439 getValidityTarget: () => validityTargetRef.current, 58440 children: /* @__PURE__ */ (0, import_jsx_runtime331.jsx)(textarea_control_default, { 58441 ref: mergedRefs, 58442 ...restProps 58443 }) 58444 }); 58445 }; 58446 var ValidatedTextareaControl = (0, import_element254.forwardRef)(UnforwardedValidatedTextareaControl); 58447 58448 // packages/components/build-module/validated-form-controls/components/toggle-control.js 58449 var import_element255 = __toESM(require_element()); 58450 var import_compose95 = __toESM(require_compose()); 58451 var import_jsx_runtime332 = __toESM(require_jsx_runtime()); 58452 var UnforwardedValidatedToggleControl = ({ 58453 required, 58454 customValidity, 58455 markWhenOptional, 58456 ...restProps 58457 }, forwardedRef) => { 58458 const validityTargetRef = (0, import_element255.useRef)(null); 58459 const mergedRefs = (0, import_compose95.useMergeRefs)([forwardedRef, validityTargetRef]); 58460 (0, import_element255.useEffect)(() => { 58461 if (validityTargetRef.current) { 58462 validityTargetRef.current.required = required !== null && required !== void 0 ? required : false; 58463 } 58464 }, [required]); 58465 return /* @__PURE__ */ (0, import_jsx_runtime332.jsx)(ControlWithError, { 58466 required, 58467 markWhenOptional, 58468 customValidity, 58469 getValidityTarget: () => validityTargetRef.current, 58470 children: /* @__PURE__ */ (0, import_jsx_runtime332.jsx)(toggle_control_default, { 58471 ref: mergedRefs, 58472 ...restProps 58473 }) 58474 }); 58475 }; 58476 var ValidatedToggleControl = (0, import_element255.forwardRef)(UnforwardedValidatedToggleControl); 58477 58478 // packages/components/build-module/validated-form-controls/components/toggle-group-control.js 58479 var import_element256 = __toESM(require_element()); 58480 var import_jsx_runtime333 = __toESM(require_jsx_runtime()); 58481 var UnforwardedValidatedToggleGroupControl = ({ 58482 required, 58483 customValidity, 58484 markWhenOptional, 58485 ...restProps 58486 }, forwardedRef) => { 58487 const validityTargetRef = (0, import_element256.useRef)(null); 58488 const nameAttr = (0, import_element256.useId)(); 58489 return /* @__PURE__ */ (0, import_jsx_runtime333.jsxs)("div", { 58490 className: "components-validated-control__wrapper-with-error-delegate", 58491 children: [/* @__PURE__ */ (0, import_jsx_runtime333.jsx)(ControlWithError, { 58492 required, 58493 markWhenOptional, 58494 customValidity, 58495 getValidityTarget: () => validityTargetRef.current, 58496 children: /* @__PURE__ */ (0, import_jsx_runtime333.jsx)(component_default12, { 58497 __next40pxDefaultSize: true, 58498 ref: forwardedRef, 58499 ...restProps 58500 }) 58501 }), /* @__PURE__ */ (0, import_jsx_runtime333.jsx)("input", { 58502 className: "components-validated-control__error-delegate", 58503 type: "radio", 58504 ref: validityTargetRef, 58505 required, 58506 checked: restProps.value !== void 0, 58507 tabIndex: -1, 58508 name: nameAttr, 58509 onChange: () => { 58510 }, 58511 onFocus: (e3) => { 58512 e3.target.previousElementSibling?.querySelector('[data-active-item="true"]')?.focus(); 58513 } 58514 })] 58515 }); 58516 }; 58517 var ValidatedToggleGroupControl = (0, import_element256.forwardRef)(UnforwardedValidatedToggleGroupControl); 58518 58519 // packages/components/build-module/private-apis.js 58520 var privateApis = {}; 58521 lock(privateApis, { 58522 __experimentalPopoverLegacyPositionToPlacement: positionToPlacement, 58523 ComponentsContext, 58524 Tabs, 58525 Theme: theme_default, 58526 Menu: Menu3, 58527 kebabCase, 58528 withIgnoreIMEEvents, 58529 Badge: badge_default, 58530 normalizeTextString, 58531 DateCalendar, 58532 DateRangeCalendar, 58533 TZDate, 58534 Picker, 58535 ValidatedInputControl, 58536 ValidatedCheckboxControl, 58537 ValidatedNumberControl, 58538 ValidatedSelectControl, 58539 ValidatedRadioControl, 58540 ValidatedTextControl, 58541 ValidatedTextareaControl, 58542 ValidatedToggleControl, 58543 ValidatedToggleGroupControl, 58544 ValidatedFormTokenField 58545 }); 58546 return __toCommonJS(index_exports); 58547 })(); 58548 /*! Bundled license information: 58549 58550 use-sync-external-store/cjs/use-sync-external-store-shim.development.js: 58551 (** 58552 * @license React 58553 * use-sync-external-store-shim.development.js 58554 * 58555 * Copyright (c) Meta Platforms, Inc. and affiliates. 58556 * 58557 * This source code is licensed under the MIT license found in the 58558 * LICENSE file in the root directory of this source tree. 58559 *) 58560 58561 react-is/cjs/react-is.development.js: 58562 (** @license React v16.13.1 58563 * react-is.development.js 58564 * 58565 * Copyright (c) Facebook, Inc. and its affiliates. 58566 * 58567 * This source code is licensed under the MIT license found in the 58568 * LICENSE file in the root directory of this source tree. 58569 *) 58570 58571 is-plain-object/dist/is-plain-object.mjs: 58572 (*! 58573 * is-plain-object <https://github.com/jonschlinkert/is-plain-object> 58574 * 58575 * Copyright (c) 2014-2017, Jon Schlinkert. 58576 * Released under the MIT License. 58577 *) 58578 */
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
| Generated : Thu Feb 26 08:20:04 2026 | Cross-referenced by PHPXref |