[{"data":1,"prerenderedAt":3928},["ShallowReactive",2],{"navigation_docs":3,"-apps-app-development-guides-shared-field-factories":1905,"-apps-app-development-guides-shared-field-factories-surround":3923},[4,136,463,647,1532,1622,1628,1634,1693,1792],{"title":5,"path":6,"stem":7,"children":8},"Getting Started","/getting-started","0.getting-started/0.index",[9,10,14,18,56,81,115,132],{"title":5,"path":6,"stem":7},{"title":11,"path":12,"stem":13},"Starting new project","/getting-started/starting-new-project","0.getting-started/1.starting-new-project",{"title":15,"path":16,"stem":17},"What is Laioutr?","/getting-started/what-is-laioutr","0.getting-started/2.what-is-laioutr",{"title":19,"path":20,"stem":21,"children":22,"page":55},"Key Concepts","/getting-started/key-concepts","0.getting-started/3.key-concepts",[23,27,31,35,39,43,47,51],{"title":24,"path":25,"stem":26},"Architecture","/getting-started/key-concepts/architecture","0.getting-started/3.key-concepts/1.architecture",{"title":28,"path":29,"stem":30},"Data Model","/getting-started/key-concepts/data-model","0.getting-started/3.key-concepts/2.data-model",{"title":32,"path":33,"stem":34},"Internationalization","/getting-started/key-concepts/5.internationalization","0.getting-started/3.key-concepts/3.5.internationalization",{"title":36,"path":37,"stem":38},"Data Flow","/getting-started/key-concepts/data-flow","0.getting-started/3.key-concepts/3.data-flow",{"title":40,"path":41,"stem":42},"Extensibility","/getting-started/key-concepts/extensibility","0.getting-started/3.key-concepts/4.extensibility",{"title":44,"path":45,"stem":46},"Philosophy","/getting-started/key-concepts/philosophy","0.getting-started/3.key-concepts/5.philosophy",{"title":48,"path":49,"stem":50},"CI/CD Pipeline","/getting-started/key-concepts/ci-cd-pipeline","0.getting-started/3.key-concepts/6.ci-cd-pipeline",{"title":52,"path":53,"stem":54},"Multi-tenancy","/getting-started/key-concepts/multi-tenancy","0.getting-started/3.key-concepts/multi-tenancy",false,{"title":57,"path":58,"stem":59,"children":60,"page":55},"Next Steps","/getting-started/next-steps","0.getting-started/4.next-steps",[61,65,69,73,77],{"title":62,"path":63,"stem":64},"Create Organization and Project","/getting-started/next-steps/create-org-and-project","0.getting-started/4.next-steps/0.create-org-and-project",{"title":66,"path":67,"stem":68},"First Project Configuration","/getting-started/next-steps/first-project-config","0.getting-started/4.next-steps/1.first-project-config",{"title":70,"path":71,"stem":72},"Setup Local Development Environment","/getting-started/next-steps/local-setup","0.getting-started/4.next-steps/3.local-setup",{"title":74,"path":75,"stem":76},"Create your first custom app","/getting-started/next-steps/create-custom-app","0.getting-started/4.next-steps/4.create-custom-app",{"title":78,"path":79,"stem":80},"CLI","/getting-started/next-steps/cli","0.getting-started/4.next-steps/5.cli",{"title":82,"path":83,"stem":84,"children":85},"Changelogs","/getting-started/changelogs","0.getting-started/5.Changelogs/0.index",[86,87,91,95,99,103,107,111],{"title":82,"path":83,"stem":84},{"title":88,"path":89,"stem":90},"Canonical Types Changelog","/getting-started/changelogs/canonical-types-changelog","0.getting-started/5.Changelogs/canonical-types-changelog",{"title":92,"path":93,"stem":94},"CLI Changelog","/getting-started/changelogs/cli-changelog","0.getting-started/5.Changelogs/cli-changelog",{"title":96,"path":97,"stem":98},"Cockpit Changelog","/getting-started/changelogs/cockpit-changelog","0.getting-started/5.Changelogs/cockpit-changelog",{"title":100,"path":101,"stem":102},"Figma Kit Changelog","/getting-started/changelogs/figma-kit-changelog","0.getting-started/5.Changelogs/figma-kit-changelog",{"title":104,"path":105,"stem":106},"Frontend Changelog","/getting-started/changelogs/frontend-changelog","0.getting-started/5.Changelogs/frontend-changelog",{"title":108,"path":109,"stem":110},"Orchestr Changelog","/getting-started/changelogs/orchestr-changelog","0.getting-started/5.Changelogs/orchestr-changelog",{"title":112,"path":113,"stem":114},"UI Changelog","/getting-started/changelogs/ui-changelog","0.getting-started/5.Changelogs/ui-changelog",{"title":116,"path":117,"stem":118,"children":119,"page":55},"Hints And Tips","/getting-started/hints-and-tips","0.getting-started/6.Hints-and-Tips",[120,124,128],{"title":121,"path":122,"stem":123},"Introduction","/getting-started/hints-and-tips/introduction","0.getting-started/6.Hints-and-Tips/0.introduction",{"title":125,"path":126,"stem":127},"Developer tools","/getting-started/hints-and-tips/developer-tools","0.getting-started/6.Hints-and-Tips/1.developer-tools",{"title":129,"path":130,"stem":131},"Claude Code plugin","/getting-started/hints-and-tips/claude-marketplace","0.getting-started/6.Hints-and-Tips/2.claude-marketplace",{"title":133,"path":134,"stem":135},"MCP Server","/getting-started/mcp-server","0.getting-started/7.mcp-server",{"title":137,"path":138,"stem":139,"children":140},"Frontend","/frontend","1.Frontend/0.index",[141,142,153,215,241,305],{"title":137,"path":138,"stem":139},{"title":121,"path":143,"stem":144,"children":145,"page":55},"/frontend/introduction","1.Frontend/1.Introduction",[146,149],{"title":19,"path":147,"stem":148},"/frontend/introduction/key-concepts","1.Frontend/1.Introduction/0.key-concepts",{"title":150,"path":151,"stem":152},"Tech Stack","/frontend/introduction/tech-stack","1.Frontend/1.Introduction/1.tech-stack",{"title":154,"path":155,"stem":156,"children":157},"Features","/frontend/features","1.Frontend/2.Features/0.index",[158,159,163,167,171,175,179,183,187,191,195,199,203,207,211],{"title":154,"path":155,"stem":156},{"title":160,"path":161,"stem":162},"Consent Management","/frontend/features/consent-management","1.Frontend/2.Features/consent-management",{"title":164,"path":165,"stem":166},"Currencies","/frontend/features/currencies","1.Frontend/2.Features/currencies",{"title":168,"path":169,"stem":170},"Environments & Staging","/frontend/features/environments","1.Frontend/2.Features/environments",{"title":172,"path":173,"stem":174},"Hooks","/frontend/features/hooks","1.Frontend/2.Features/hooks",{"title":176,"path":177,"stem":178},"Media and Media Library","/frontend/features/media","1.Frontend/2.Features/media",{"title":180,"path":181,"stem":182},"Multi-language Support","/frontend/features/multi-language-support","1.Frontend/2.Features/multi-language-support",{"title":184,"path":185,"stem":186},"Multi-market","/frontend/features/multi-market","1.Frontend/2.Features/multi-market",{"title":188,"path":189,"stem":190},"Page Types","/frontend/features/pagetypes","1.Frontend/2.Features/pagetypes",{"title":192,"path":193,"stem":194},"PWA","/frontend/features/pwa","1.Frontend/2.Features/pwa",{"title":196,"path":197,"stem":198},"Redirects","/frontend/features/redirects","1.Frontend/2.Features/redirects",{"title":200,"path":201,"stem":202},"Routing","/frontend/features/routing","1.Frontend/2.Features/routing",{"title":204,"path":205,"stem":206},"Server-Side Rendering (SSR) and Caching","/frontend/features/ssr-and-caching","1.Frontend/2.Features/ssr-and-caching",{"title":208,"path":209,"stem":210},"Tracking","/frontend/features/tracking","1.Frontend/2.Features/tracking",{"title":212,"path":213,"stem":214},"Z-Ordering","/frontend/features/z-ordering","1.Frontend/2.Features/z-ordering",{"title":216,"path":217,"stem":218,"children":219},"SEO","/frontend/seo","1.Frontend/3.SEO/0.index",[220,221,225,229,233,237],{"title":216,"path":217,"stem":218},{"title":222,"path":223,"stem":224},"Link Checker","/frontend/seo/link-checker","1.Frontend/3.SEO/link-checker",{"title":226,"path":227,"stem":228},"OG Image","/frontend/seo/og-image","1.Frontend/3.SEO/og-image",{"title":230,"path":231,"stem":232},"Robots.txt","/frontend/seo/robots-txt","1.Frontend/3.SEO/robots-txt",{"title":234,"path":235,"stem":236},"Schema.org","/frontend/seo/schema-org","1.Frontend/3.SEO/schema-org",{"title":238,"path":239,"stem":240},"Sitemap","/frontend/seo/sitemap","1.Frontend/3.SEO/sitemap",{"title":242,"path":243,"stem":244,"children":245},"Backend for Frontend","/frontend/orchestr","1.Frontend/4.Orchestr/0.index",[246,247,273,277,281,285,289,293,297,301],{"title":242,"path":243,"stem":244},{"title":248,"path":249,"stem":250,"children":251},"Recipes","/frontend/orchestr/recipes","1.Frontend/4.Orchestr/99.recipes/0.index",[252,253,257,261,265,269],{"title":248,"path":249,"stem":250},{"title":254,"path":255,"stem":256},"Analytics components from query handlers","/frontend/orchestr/recipes/analytics-from-query-handlers","1.Frontend/4.Orchestr/99.recipes/analytics-from-query-handlers",{"title":258,"path":259,"stem":260},"Identity cookies (cart and visitor IDs)","/frontend/orchestr/recipes/identity-cookies","1.Frontend/4.Orchestr/99.recipes/identity-cookies",{"title":262,"path":263,"stem":264},"System bootstrap in extendRequest","/frontend/orchestr/recipes/system-bootstrap","1.Frontend/4.Orchestr/99.recipes/system-bootstrap",{"title":266,"path":267,"stem":268},"Translating vendor errors","/frontend/orchestr/recipes/translating-vendor-errors","1.Frontend/4.Orchestr/99.recipes/translating-vendor-errors",{"title":270,"path":271,"stem":272},"Userland cache patterns","/frontend/orchestr/recipes/userland-cache-patterns","1.Frontend/4.Orchestr/99.recipes/userland-cache-patterns",{"title":274,"path":275,"stem":276},"Actions","/frontend/orchestr/actions","1.Frontend/4.Orchestr/Actions",{"title":278,"path":279,"stem":280},"Caching","/frontend/orchestr/caching","1.Frontend/4.Orchestr/Caching",{"title":282,"path":283,"stem":284},"Middleware","/frontend/orchestr/middleware","1.Frontend/4.Orchestr/Middleware",{"title":286,"path":287,"stem":288},"Queries & Links","/frontend/orchestr/queries","1.Frontend/4.Orchestr/Queries",{"title":290,"path":291,"stem":292},"Component Resolvers","/frontend/orchestr/component-resolvers","1.Frontend/4.Orchestr/component-resolvers",{"title":294,"path":295,"stem":296},"Filters","/frontend/orchestr/filters","1.Frontend/4.Orchestr/filters",{"title":298,"path":299,"stem":300},"URL Query Parameters","/frontend/orchestr/url-query-params","1.Frontend/4.Orchestr/url-query-params",{"title":302,"path":303,"stem":304},"Orchestr Wire Format","/frontend/orchestr/wire-format","1.Frontend/4.Orchestr/wire-format",{"title":306,"path":307,"stem":308,"children":309},"API Reference","/frontend/api-reference","1.Frontend/99.api-reference/0.index",[310,311,373,376,406,422,430,441,449,456],{"title":306,"path":307,"stem":308},{"title":312,"path":313,"stem":314,"children":315},"Entities","/frontend/api-reference/entities","1.Frontend/99.api-reference/01.entities/0.index",[316,317,321,325,329,333,337,341,345,349,353,357,361,365,369],{"title":312,"path":313,"stem":314},{"title":318,"path":319,"stem":320},"Product","/frontend/api-reference/entities/product","1.Frontend/99.api-reference/01.entities/1.product",{"title":322,"path":323,"stem":324},"SuggestedSearch","/frontend/api-reference/entities/suggested-search","1.Frontend/99.api-reference/01.entities/10.suggested-search",{"title":326,"path":327,"stem":328},"SuggestedSearchEntry","/frontend/api-reference/entities/suggested-search-entry","1.Frontend/99.api-reference/01.entities/11.suggested-search-entry",{"title":330,"path":331,"stem":332},"BlogCollection","/frontend/api-reference/entities/blog-collection","1.Frontend/99.api-reference/01.entities/12.blog-collection",{"title":334,"path":335,"stem":336},"Comment","/frontend/api-reference/entities/comment","1.Frontend/99.api-reference/01.entities/13.comment",{"title":338,"path":339,"stem":340},"Location","/frontend/api-reference/entities/location","1.Frontend/99.api-reference/01.entities/14.location",{"title":342,"path":343,"stem":344},"ProductVariant","/frontend/api-reference/entities/product-variant","1.Frontend/99.api-reference/01.entities/2.product-variant",{"title":346,"path":347,"stem":348},"Category","/frontend/api-reference/entities/category","1.Frontend/99.api-reference/01.entities/3.category",{"title":350,"path":351,"stem":352},"Cart","/frontend/api-reference/entities/cart","1.Frontend/99.api-reference/01.entities/4.cart",{"title":354,"path":355,"stem":356},"CartItem","/frontend/api-reference/entities/cart-item","1.Frontend/99.api-reference/01.entities/5.cart-item",{"title":358,"path":359,"stem":360},"Review","/frontend/api-reference/entities/review","1.Frontend/99.api-reference/01.entities/6.review",{"title":362,"path":363,"stem":364},"BreadcrumbItem","/frontend/api-reference/entities/breadcrumb-item","1.Frontend/99.api-reference/01.entities/7.breadcrumb-item",{"title":366,"path":367,"stem":368},"MenuItem","/frontend/api-reference/entities/menu-item","1.Frontend/99.api-reference/01.entities/8.menu-item",{"title":370,"path":371,"stem":372},"BlogPost","/frontend/api-reference/entities/blog-post","1.Frontend/99.api-reference/01.entities/9.blog-post",{"title":188,"path":374,"stem":375},"/frontend/api-reference/page-types","1.Frontend/99.api-reference/02.page-types",{"title":377,"path":378,"stem":379,"children":380},"Common Types","/frontend/api-reference/common-types","1.Frontend/99.api-reference/03.common-types/0.index",[381,382,386,390,394,398,402],{"title":377,"path":378,"stem":379},{"title":383,"path":384,"stem":385},"Link","/frontend/api-reference/common-types/link","1.Frontend/99.api-reference/03.common-types/1.link",{"title":387,"path":388,"stem":389},"Media","/frontend/api-reference/common-types/media","1.Frontend/99.api-reference/03.common-types/2.media",{"title":391,"path":392,"stem":393},"Money","/frontend/api-reference/common-types/money","1.Frontend/99.api-reference/03.common-types/3.money",{"title":395,"path":396,"stem":397},"UnitPrice","/frontend/api-reference/common-types/unit-price","1.Frontend/99.api-reference/03.common-types/4.unit-price",{"title":399,"path":400,"stem":401},"Measurement","/frontend/api-reference/common-types/measurement","1.Frontend/99.api-reference/03.common-types/5.measurement",{"title":403,"path":404,"stem":405},"Opening Hours","/frontend/api-reference/common-types/opening-hours","1.Frontend/99.api-reference/03.common-types/6.opening-hours",{"title":407,"path":408,"stem":409,"children":410,"page":55},"Ecommerce","/frontend/api-reference/ecommerce","1.Frontend/99.api-reference/10.ecommerce",[411,414,418],{"title":274,"path":412,"stem":413},"/frontend/api-reference/ecommerce/actions","1.Frontend/99.api-reference/10.ecommerce/1.actions",{"title":415,"path":416,"stem":417},"Queries","/frontend/api-reference/ecommerce/queries","1.Frontend/99.api-reference/10.ecommerce/2.queries",{"title":419,"path":420,"stem":421},"Errors","/frontend/api-reference/ecommerce/errors","1.Frontend/99.api-reference/10.ecommerce/3.errors",{"title":423,"path":424,"stem":425,"children":426,"page":55},"Newsletter","/frontend/api-reference/newsletter","1.Frontend/99.api-reference/11.newsletter",[427],{"title":274,"path":428,"stem":429},"/frontend/api-reference/newsletter/actions","1.Frontend/99.api-reference/11.newsletter/1.actions",{"title":431,"path":432,"stem":433,"children":434,"page":55},"Blog","/frontend/api-reference/blog","1.Frontend/99.api-reference/12.blog",[435,438],{"title":415,"path":436,"stem":437},"/frontend/api-reference/blog/queries","1.Frontend/99.api-reference/12.blog/1.queries",{"title":419,"path":439,"stem":440},"/frontend/api-reference/blog/errors","1.Frontend/99.api-reference/12.blog/2.errors",{"title":442,"path":443,"stem":444,"children":445,"page":55},"Suggested Search","/frontend/api-reference/suggested-search","1.Frontend/99.api-reference/13.suggested-search",[446],{"title":415,"path":447,"stem":448},"/frontend/api-reference/suggested-search/queries","1.Frontend/99.api-reference/13.suggested-search/1.queries",{"title":208,"path":450,"stem":451,"children":452,"page":55},"/frontend/api-reference/tracking","1.Frontend/99.api-reference/14.tracking",[453],{"title":274,"path":454,"stem":455},"/frontend/api-reference/tracking/actions","1.Frontend/99.api-reference/14.tracking/1.actions",{"title":338,"path":457,"stem":458,"children":459,"page":55},"/frontend/api-reference/location","1.Frontend/99.api-reference/15.location",[460],{"title":415,"path":461,"stem":462},"/frontend/api-reference/location/queries","1.Frontend/99.api-reference/15.location/1.queries",{"title":464,"path":465,"stem":466,"children":467},"Apps","/apps","2.Apps/0.index",[468,469,545,631],{"title":464,"path":465,"stem":466},{"title":470,"path":471,"stem":472,"children":473},"App Development","/apps/app-development","2.Apps/app-development/0.index",[474,475,497,501,505,509,513,517,521,525,529,533,537,541],{"title":470,"path":471,"stem":472},{"title":476,"path":477,"stem":478,"children":479},"Guides","/apps/app-development/guides","2.Apps/app-development/99.guides/0.index",[480,481,485,489,493],{"title":476,"path":477,"stem":478},{"title":482,"path":483,"stem":484},"Separate schema components from UI components","/apps/app-development/guides/schema-components-vs-ui-components","2.Apps/app-development/99.guides/schema-components-vs-ui-components",{"title":486,"path":487,"stem":488},"Section config standard","/apps/app-development/guides/section-config-standard","2.Apps/app-development/99.guides/section-config-standard",{"title":490,"path":491,"stem":492},"Shared field factories","/apps/app-development/guides/shared-field-factories","2.Apps/app-development/99.guides/shared-field-factories",{"title":494,"path":495,"stem":496},"How to write CSS","/apps/app-development/guides/writing-css","2.Apps/app-development/99.guides/writing-css",{"title":498,"path":499,"stem":500},"App Configuration","/apps/app-development/app-configuration","2.Apps/app-development/app-configuration",{"title":502,"path":503,"stem":504},"App Starter","/apps/app-development/app-starter","2.Apps/app-development/app-starter",{"title":506,"path":507,"stem":508},"Best Practice","/apps/app-development/best-practice","2.Apps/app-development/best-practice",{"title":510,"path":511,"stem":512},"Block Definitions","/apps/app-development/block-definitions","2.Apps/app-development/block-definitions",{"title":514,"path":515,"stem":516},"Coding Standards","/apps/app-development/coding-standards","2.Apps/app-development/coding-standards",{"title":518,"path":519,"stem":520},"Consent Adapters","/apps/app-development/consent-adapters","2.Apps/app-development/consent-adapters",{"title":522,"path":523,"stem":524},"Consuming Query Fields","/apps/app-development/consuming-query-fields","2.Apps/app-development/consuming-query-fields",{"title":526,"path":527,"stem":528},"Implementation Overview","/apps/app-development/implementation-overview","2.Apps/app-development/implementation-overview",{"title":530,"path":531,"stem":532},"Platform Dependencies","/apps/app-development/platform-dependencies","2.Apps/app-development/platform-dependencies",{"title":534,"path":535,"stem":536},"Schema Fields","/apps/app-development/schema-fields","2.Apps/app-development/schema-fields",{"title":538,"path":539,"stem":540},"Section Definitions","/apps/app-development/section-definitions","2.Apps/app-development/section-definitions",{"title":542,"path":543,"stem":544},"Studio Icons","/apps/app-development/studio-icons","2.Apps/app-development/studio-icons",{"title":546,"path":547,"stem":548,"children":549},"App Docs","/apps/app-docs","2.Apps/app-docs/0.index",[550,551,555,559,563,567,571,575,579,583,587,591,595,599,603,607,611,615,619,623,627],{"title":546,"path":547,"stem":548},{"title":552,"path":553,"stem":554},"Actindo","/apps/app-docs/actindo","2.Apps/app-docs/actindo",{"title":556,"path":557,"stem":558},"Adobe Commerce","/apps/app-docs/adobe-commerce","2.Apps/app-docs/adobe-commerce",{"title":560,"path":561,"stem":562},"B2Bsellers","/apps/app-docs/b2bsellers","2.Apps/app-docs/b2bsellers",{"title":564,"path":565,"stem":566},"Battery Included","/apps/app-docs/battery-included","2.Apps/app-docs/battery-included",{"title":568,"path":569,"stem":570},"CCM19","/apps/app-docs/ccm19","2.Apps/app-docs/ccm19",{"title":572,"path":573,"stem":574},"Cookiebot","/apps/app-docs/cookiebot","2.Apps/app-docs/cookiebot",{"title":576,"path":577,"stem":578},"Google Tag Manager (GTM)","/apps/app-docs/gtm","2.Apps/app-docs/gtm",{"title":580,"path":581,"stem":582},"Hygraph","/apps/app-docs/hygraph","2.Apps/app-docs/hygraph",{"title":584,"path":585,"stem":586},"JTL Platform","/apps/app-docs/jtl-platform","2.Apps/app-docs/jtl-platform",{"title":588,"path":589,"stem":590},"Nimstrata Google Retail API","/apps/app-docs/nimstrata","2.Apps/app-docs/nimstrata",{"title":592,"path":593,"stem":594},"Pimcore","/apps/app-docs/pimcore","2.Apps/app-docs/pimcore",{"title":596,"path":597,"stem":598},"Sylius","/apps/app-docs/sylius","2.Apps/app-docs/sylius",{"title":600,"path":601,"stem":602},"Commercetools","/apps/app-docs/commercetools","2.apps/app-docs/commercetools",{"title":604,"path":605,"stem":606},"Emporix","/apps/app-docs/emporix","2.apps/app-docs/emporix",{"title":608,"path":609,"stem":610},"Klaviyo","/apps/app-docs/klaviyo","2.apps/app-docs/klaviyo",{"title":612,"path":613,"stem":614},"OXID eShop","/apps/app-docs/oxid","2.apps/app-docs/oxid",{"title":616,"path":617,"stem":618},"Shopify","/apps/app-docs/shopify","2.apps/app-docs/shopify",{"title":620,"path":621,"stem":622},"Shopware","/apps/app-docs/shopware","2.apps/app-docs/shopware",{"title":624,"path":625,"stem":626},"Vercel Analytics","/apps/app-docs/vercel-analytics","2.apps/app-docs/vercel-analytics",{"title":628,"path":629,"stem":630},"Vercel Speed Insights","/apps/app-docs/vercel-speed-insights","2.apps/app-docs/vercel-speed-insights",{"title":632,"path":633,"stem":634,"children":635,"page":55},"Essentials","/apps/essentials","2.Apps/essentials",[636,640,644],{"title":637,"path":638,"stem":639},"Legal","/apps/essentials/legal","2.Apps/essentials/legal",{"title":641,"path":642,"stem":643},"Mailer","/apps/essentials/mailer","2.Apps/essentials/mailer",{"title":216,"path":645,"stem":646},"/apps/essentials/seo","2.Apps/essentials/seo",{"title":648,"path":649,"stem":650,"children":651},"Laioutr UI","/laioutr-ui","3.laioutr-ui/0.index",[652,653,685,691,697,885,902,908,914,968,986,1116],{"title":648,"path":649,"stem":650},{"title":5,"path":654,"stem":655,"children":656},"/laioutr-ui/getting-started","3.laioutr-ui/01.getting-started/0.index",[657,658,662,666,670,674,678,682],{"title":5,"path":654,"stem":655},{"title":659,"path":660,"stem":661},"Browser support","/laioutr-ui/getting-started/browser-support","3.laioutr-ui/01.getting-started/1.browser-support",{"title":663,"path":664,"stem":665},"Common Data","/laioutr-ui/getting-started/common-data","3.laioutr-ui/01.getting-started/99.common-data",{"title":667,"path":668,"stem":669},"CSS Layers","/laioutr-ui/getting-started/css-layers","3.laioutr-ui/01.getting-started/css-layers",{"title":671,"path":672,"stem":673},"Figma Kit","/laioutr-ui/getting-started/figma-kit","3.laioutr-ui/01.getting-started/figma-kit",{"title":675,"path":676,"stem":677},"Surface Tone","/laioutr-ui/getting-started/surface-tone","3.laioutr-ui/01.getting-started/surface-tone",{"title":679,"path":680,"stem":681},"Theming","/laioutr-ui/getting-started/theming","3.laioutr-ui/01.getting-started/theming",{"title":212,"path":683,"stem":684},"/laioutr-ui/getting-started/z-ordering","3.laioutr-ui/01.getting-started/z-ordering",{"title":686,"path":687,"stem":688,"children":689},"B2B","/laioutr-ui/b2b","3.laioutr-ui/b2b/0.index",[690],{"title":686,"path":687,"stem":688},{"title":692,"path":693,"stem":694,"children":695},"Booking","/laioutr-ui/booking","3.laioutr-ui/booking/0.index",[696],{"title":692,"path":693,"stem":694},{"title":698,"path":699,"stem":700,"children":701},"CMS","/laioutr-ui/cms","3.laioutr-ui/cms/0.index",[702,703,709,734,746,750,754,758,762,766,778,799,820,836],{"title":698,"path":699,"stem":700},{"title":704,"path":705,"stem":706,"children":707},"Alphabetical Index","/laioutr-ui/cms/alphabetical-index","3.laioutr-ui/cms/alphabetical-index",[708],{"title":704,"path":705,"stem":706},{"title":710,"path":711,"stem":712,"children":713,"page":55},"Banner","/laioutr-ui/cms/banner","3.laioutr-ui/cms/banner",[714,718,722,726,730],{"title":715,"path":716,"stem":717},"Banner Basic","/laioutr-ui/cms/banner/banner-basic","3.laioutr-ui/cms/banner/banner-basic",{"title":719,"path":720,"stem":721},"Banner Integrated","/laioutr-ui/cms/banner/banner-integrated","3.laioutr-ui/cms/banner/banner-integrated",{"title":723,"path":724,"stem":725},"Banner Showcase","/laioutr-ui/cms/banner/banner-showcase","3.laioutr-ui/cms/banner/banner-showcase",{"title":727,"path":728,"stem":729},"Media + Text","/laioutr-ui/cms/banner/media-text","3.laioutr-ui/cms/banner/media-text",{"title":731,"path":732,"stem":733},"USP Banner","/laioutr-ui/cms/banner/usp-banner","3.laioutr-ui/cms/banner/usp-banner",{"title":431,"path":735,"stem":736,"children":737,"page":55},"/laioutr-ui/cms/blog","3.laioutr-ui/cms/blog",[738,742],{"title":739,"path":740,"stem":741},"Blog Post Detail","/laioutr-ui/cms/blog/blog-post-detail","3.laioutr-ui/cms/blog/blog-post-detail",{"title":743,"path":744,"stem":745},"Blog Post Listing","/laioutr-ui/cms/blog/blog-post-listing","3.laioutr-ui/cms/blog/blog-post-listing",{"title":747,"path":748,"stem":749},"Brand Hero","/laioutr-ui/cms/brand-hero","3.laioutr-ui/cms/brand-hero",{"title":751,"path":752,"stem":753},"Container","/laioutr-ui/cms/container","3.laioutr-ui/cms/container",{"title":755,"path":756,"stem":757},"Content Grid","/laioutr-ui/cms/content-grid","3.laioutr-ui/cms/content-grid",{"title":759,"path":760,"stem":761},"Editorial Grid","/laioutr-ui/cms/editorial-grid","3.laioutr-ui/cms/editorial-grid",{"title":763,"path":764,"stem":765},"Media Gallery","/laioutr-ui/cms/media-gallery","3.laioutr-ui/cms/media-gallery",{"title":423,"path":767,"stem":768,"children":769,"page":55},"/laioutr-ui/cms/newsletter","3.laioutr-ui/cms/newsletter",[770,774],{"title":771,"path":772,"stem":773},"Email Input Form","/laioutr-ui/cms/newsletter/email-input-form","3.laioutr-ui/cms/newsletter/email-input-form",{"title":775,"path":776,"stem":777},"Newsletter Registration","/laioutr-ui/cms/newsletter/newsletter-registration","3.laioutr-ui/cms/newsletter/newsletter-registration",{"title":779,"path":780,"stem":781,"children":782,"page":55},"Popups","/laioutr-ui/cms/popups","3.laioutr-ui/cms/popups",[783,787,791,795],{"title":784,"path":785,"stem":786},"PopUp","/laioutr-ui/cms/popups/pop-up","3.laioutr-ui/cms/popups/pop-up",{"title":788,"path":789,"stem":790},"PopUp Info","/laioutr-ui/cms/popups/pop-up-info","3.laioutr-ui/cms/popups/pop-up-info",{"title":792,"path":793,"stem":794},"PopUp Newsletter","/laioutr-ui/cms/popups/pop-up-newsletter","3.laioutr-ui/cms/popups/pop-up-newsletter",{"title":796,"path":797,"stem":798},"PopUp Promotion","/laioutr-ui/cms/popups/pop-up-promotion","3.laioutr-ui/cms/popups/pop-up-promotion",{"title":800,"path":801,"stem":802,"children":803,"page":55},"Quotes","/laioutr-ui/cms/quotes","3.laioutr-ui/cms/quotes",[804,808,812,816],{"title":805,"path":806,"stem":807},"Persona Quote","/laioutr-ui/cms/quotes/persona-quote","3.laioutr-ui/cms/quotes/persona-quote",{"title":809,"path":810,"stem":811},"Persona Quote Slider","/laioutr-ui/cms/quotes/persona-quote-slider","3.laioutr-ui/cms/quotes/persona-quote-slider",{"title":813,"path":814,"stem":815},"Quote Card","/laioutr-ui/cms/quotes/quote-card","3.laioutr-ui/cms/quotes/quote-card",{"title":817,"path":818,"stem":819},"Quote Card Slider","/laioutr-ui/cms/quotes/quote-card-slider","3.laioutr-ui/cms/quotes/quote-card-slider",{"title":821,"path":822,"stem":823,"children":824,"page":55},"Reviews","/laioutr-ui/cms/reviews","3.laioutr-ui/cms/reviews",[825,828,832],{"title":358,"path":826,"stem":827},"/laioutr-ui/cms/reviews/review","3.laioutr-ui/cms/reviews/review",{"title":829,"path":830,"stem":831},"Review Form","/laioutr-ui/cms/reviews/review-form","3.laioutr-ui/cms/reviews/review-form",{"title":833,"path":834,"stem":835},"Social Share","/laioutr-ui/cms/reviews/social-share","3.laioutr-ui/cms/reviews/social-share",{"title":837,"path":838,"stem":839,"children":840,"page":55},"Slider","/laioutr-ui/cms/slider","3.laioutr-ui/cms/slider",[841,845,849,853,857,861,865,869,873,877,881],{"title":842,"path":843,"stem":844},"Content Slider","/laioutr-ui/cms/slider/content-slider","3.laioutr-ui/cms/slider/content-slider",{"title":846,"path":847,"stem":848},"Hero Slider","/laioutr-ui/cms/slider/hero-slider","3.laioutr-ui/cms/slider/hero-slider",{"title":850,"path":851,"stem":852},"Logo Grid","/laioutr-ui/cms/slider/logo-grid","3.laioutr-ui/cms/slider/logo-grid",{"title":854,"path":855,"stem":856},"Logo Slider","/laioutr-ui/cms/slider/logo-slider","3.laioutr-ui/cms/slider/logo-slider",{"title":858,"path":859,"stem":860},"Swiper Arrows","/laioutr-ui/cms/slider/swiper-arrows","3.laioutr-ui/cms/slider/swiper-arrows",{"title":862,"path":863,"stem":864},"Swiper Bullets","/laioutr-ui/cms/slider/swiper-bullets","3.laioutr-ui/cms/slider/swiper-bullets",{"title":866,"path":867,"stem":868},"Swiper Chrome","/laioutr-ui/cms/slider/swiper-chrome","3.laioutr-ui/cms/slider/swiper-chrome",{"title":870,"path":871,"stem":872},"Swiper Nav Bar","/laioutr-ui/cms/slider/swiper-nav-bar","3.laioutr-ui/cms/slider/swiper-nav-bar",{"title":874,"path":875,"stem":876},"Swiper Numbers","/laioutr-ui/cms/slider/swiper-numbers","3.laioutr-ui/cms/slider/swiper-numbers",{"title":878,"path":879,"stem":880},"Swiper Scrollbar","/laioutr-ui/cms/slider/swiper-scrollbar","3.laioutr-ui/cms/slider/swiper-scrollbar",{"title":882,"path":883,"stem":884},"Thumbnails Slider","/laioutr-ui/cms/slider/thumbnails-slider","3.laioutr-ui/cms/slider/thumbnails-slider",{"title":338,"path":886,"stem":887,"children":888},"/laioutr-ui/location","3.laioutr-ui/location/0.index",[889,890,894,898],{"title":338,"path":886,"stem":887},{"title":891,"path":892,"stem":893},"Location Card","/laioutr-ui/location/location-card","3.laioutr-ui/location/location-card",{"title":895,"path":896,"stem":897},"Location Detail","/laioutr-ui/location/location-detail","3.laioutr-ui/location/location-detail",{"title":899,"path":900,"stem":901},"Location Finder","/laioutr-ui/location/location-finder","3.laioutr-ui/location/location-finder",{"title":903,"path":904,"stem":905,"children":906},"Marketplace","/laioutr-ui/marketplace","3.laioutr-ui/marketplace/0.index",[907],{"title":903,"path":904,"stem":905},{"title":909,"path":910,"stem":911,"children":912},"Multichannel","/laioutr-ui/multichannel","3.laioutr-ui/multichannel/0.index",[913],{"title":909,"path":910,"stem":911},{"title":915,"path":916,"stem":917,"children":918},"Navigation & Headers","/laioutr-ui/navigation","3.laioutr-ui/navigation/0.index",[919,920,924,928,932,936,940,944,948,952,956,960,964],{"title":915,"path":916,"stem":917},{"title":921,"path":922,"stem":923},"Breadcrumbs","/laioutr-ui/navigation/breadcrumbs","3.laioutr-ui/navigation/breadcrumbs",{"title":925,"path":926,"stem":927},"Footer","/laioutr-ui/navigation/footer","3.laioutr-ui/navigation/footer",{"title":929,"path":930,"stem":931},"Footer Menu","/laioutr-ui/navigation/footer-menu","3.laioutr-ui/navigation/footer-menu",{"title":933,"path":934,"stem":935},"Header Basic","/laioutr-ui/navigation/header-basic","3.laioutr-ui/navigation/header-basic",{"title":937,"path":938,"stem":939},"Header Shop","/laioutr-ui/navigation/header-shop","3.laioutr-ui/navigation/header-shop",{"title":941,"path":942,"stem":943},"Mega Menu","/laioutr-ui/navigation/mega-menu","3.laioutr-ui/navigation/mega-menu",{"title":945,"path":946,"stem":947},"Menu Side by Side","/laioutr-ui/navigation/menu-side-by-side","3.laioutr-ui/navigation/menu-side-by-side",{"title":949,"path":950,"stem":951},"Mobile Menu (Basic)","/laioutr-ui/navigation/mobile-menu-basic","3.laioutr-ui/navigation/mobile-menu-basic",{"title":953,"path":954,"stem":955},"Mobile Menu (Shop)","/laioutr-ui/navigation/mobile-menu-shop","3.laioutr-ui/navigation/mobile-menu-shop",{"title":957,"path":958,"stem":959},"Page Not Found","/laioutr-ui/navigation/page-not-found","3.laioutr-ui/navigation/page-not-found",{"title":961,"path":962,"stem":963},"Search Auto-Suggest","/laioutr-ui/navigation/search-auto-suggest","3.laioutr-ui/navigation/search-auto-suggest",{"title":965,"path":966,"stem":967},"Top Bar","/laioutr-ui/navigation/top-bar","3.laioutr-ui/navigation/top-bar",{"title":969,"path":970,"stem":971,"children":972},"SaaS","/laioutr-ui/saas","3.laioutr-ui/saas/0.index",[973,974,978,982],{"title":969,"path":970,"stem":971},{"title":975,"path":976,"stem":977},"Plan Card","/laioutr-ui/saas/plan-card","3.laioutr-ui/saas/plan-card",{"title":979,"path":980,"stem":981},"Plan Card Slider","/laioutr-ui/saas/plan-card-slider","3.laioutr-ui/saas/plan-card-slider",{"title":983,"path":984,"stem":985},"Plan Comparison Table","/laioutr-ui/saas/plan-comparison-table","3.laioutr-ui/saas/plan-comparison-table",{"title":987,"path":988,"stem":989,"children":990},"Shop","/laioutr-ui/shop","3.laioutr-ui/shop/0.index",[991,992,1020,1024,1028,1032,1036,1092,1096,1100,1104,1108,1112],{"title":987,"path":988,"stem":989},{"title":350,"path":993,"stem":994,"children":995,"page":55},"/laioutr-ui/shop/cart","3.laioutr-ui/shop/cart",[996,1000,1004,1008,1012,1016],{"title":997,"path":998,"stem":999},"Cart Coupon Code Accordion","/laioutr-ui/shop/cart/cart-coupon-code-accordion","3.laioutr-ui/shop/cart/cart-coupon-code-accordion",{"title":1001,"path":1002,"stem":1003},"Cart List Item","/laioutr-ui/shop/cart/cart-list-item","3.laioutr-ui/shop/cart/cart-list-item",{"title":1005,"path":1006,"stem":1007},"Cart Sheet","/laioutr-ui/shop/cart/cart-sheet","3.laioutr-ui/shop/cart/cart-sheet",{"title":1009,"path":1010,"stem":1011},"Cart Summary Box","/laioutr-ui/shop/cart/cart-summary-box","3.laioutr-ui/shop/cart/cart-summary-box",{"title":1013,"path":1014,"stem":1015},"Empty State Cart","/laioutr-ui/shop/cart/empty-state-cart","3.laioutr-ui/shop/cart/empty-state-cart",{"title":1017,"path":1018,"stem":1019},"Free Delivery Progress","/laioutr-ui/shop/cart/free-delivery-progress","3.laioutr-ui/shop/cart/free-delivery-progress",{"title":1021,"path":1022,"stem":1023},"Category Card Grid","/laioutr-ui/shop/category-card-grid","3.laioutr-ui/shop/category-card-grid",{"title":1025,"path":1026,"stem":1027},"Category Card Slider","/laioutr-ui/shop/category-card-slider","3.laioutr-ui/shop/category-card-slider",{"title":1029,"path":1030,"stem":1031},"Filter Bar","/laioutr-ui/shop/filter-bar","3.laioutr-ui/shop/filter-bar",{"title":1033,"path":1034,"stem":1035},"Filter Off Canvas","/laioutr-ui/shop/filter-off-canvas","3.laioutr-ui/shop/filter-off-canvas",{"title":1037,"path":1038,"stem":1039,"children":1040,"page":55},"Product Detail","/laioutr-ui/shop/product-detail","3.laioutr-ui/shop/product-detail",[1041,1045,1049,1053,1057,1061,1064,1068,1072,1076,1080,1084,1088],{"title":1042,"path":1043,"stem":1044},"Add to Cart","/laioutr-ui/shop/product-detail/add-to-cart","3.laioutr-ui/shop/product-detail/add-to-cart",{"title":1046,"path":1047,"stem":1048},"Benefits Box","/laioutr-ui/shop/product-detail/benefits-box","3.laioutr-ui/shop/product-detail/benefits-box",{"title":1050,"path":1051,"stem":1052},"Coupon Box","/laioutr-ui/shop/product-detail/coupon-box","3.laioutr-ui/shop/product-detail/coupon-box",{"title":1054,"path":1055,"stem":1056},"Energy Label","/laioutr-ui/shop/product-detail/energy-label","3.laioutr-ui/shop/product-detail/energy-label",{"title":1058,"path":1059,"stem":1060},"Price Info","/laioutr-ui/shop/product-detail/price-info","3.laioutr-ui/shop/product-detail/price-info",{"title":1037,"path":1062,"stem":1063},"/laioutr-ui/shop/product-detail/product-detail","3.laioutr-ui/shop/product-detail/product-detail",{"title":1065,"path":1066,"stem":1067},"Product Image Gallery","/laioutr-ui/shop/product-detail/product-image-gallery","3.laioutr-ui/shop/product-detail/product-image-gallery",{"title":1069,"path":1070,"stem":1071},"Product Title","/laioutr-ui/shop/product-detail/product-title","3.laioutr-ui/shop/product-detail/product-title",{"title":1073,"path":1074,"stem":1075},"Quantity Discount","/laioutr-ui/shop/product-detail/quantity-discount","3.laioutr-ui/shop/product-detail/quantity-discount",{"title":1077,"path":1078,"stem":1079},"Variant Off Canvas","/laioutr-ui/shop/product-detail/variant-off-canvas","3.laioutr-ui/shop/product-detail/variant-off-canvas",{"title":1081,"path":1082,"stem":1083},"Variant Selector Configurator","/laioutr-ui/shop/product-detail/variant-selector-configurator","3.laioutr-ui/shop/product-detail/variant-selector-configurator",{"title":1085,"path":1086,"stem":1087},"Variant Selector (Multiple)","/laioutr-ui/shop/product-detail/variant-selector-multiple","3.laioutr-ui/shop/product-detail/variant-selector-multiple",{"title":1089,"path":1090,"stem":1091},"Variant Selector Options","/laioutr-ui/shop/product-detail/variant-selector-options","3.laioutr-ui/shop/product-detail/variant-selector-options",{"title":1093,"path":1094,"stem":1095},"Product Listing Grid","/laioutr-ui/shop/product-listing-grid","3.laioutr-ui/shop/product-listing-grid",{"title":1097,"path":1098,"stem":1099},"Product Slider","/laioutr-ui/shop/product-slider","3.laioutr-ui/shop/product-slider",{"title":1101,"path":1102,"stem":1103},"Product Slider Showcase","/laioutr-ui/shop/product-slider-showcase","3.laioutr-ui/shop/product-slider-showcase",{"title":1105,"path":1106,"stem":1107},"Product Tile (Basic)","/laioutr-ui/shop/product-tile-basic","3.laioutr-ui/shop/product-tile-basic",{"title":1109,"path":1110,"stem":1111},"Search Result Hero","/laioutr-ui/shop/search-result-hero","3.laioutr-ui/shop/search-result-hero",{"title":1113,"path":1114,"stem":1115},"Sort Modes","/laioutr-ui/shop/sort-modes","3.laioutr-ui/shop/sort-modes",{"title":1117,"path":1118,"stem":1119,"children":1120},"UI Kit","/laioutr-ui/ui-kit","3.laioutr-ui/ui-kit/0.index",[1121,1122,1282,1306,1327,1344,1381,1490,1519],{"title":1117,"path":1118,"stem":1119},{"title":1123,"path":1124,"stem":1125,"children":1126,"page":55},"General","/laioutr-ui/ui-kit/general","3.laioutr-ui/ui-kit/01.general",[1127,1131,1135,1139,1143,1147,1151,1155,1159,1163,1167,1170,1174,1178,1182,1186,1190,1194,1198,1202,1206,1210,1214,1218,1222,1226,1230,1234,1238,1242,1246,1250,1254,1258,1262,1266,1270,1274,1278],{"title":1128,"path":1129,"stem":1130},"Accordion","/laioutr-ui/ui-kit/general/accordion","3.laioutr-ui/ui-kit/01.general/Accordion",{"title":1132,"path":1133,"stem":1134},"Avatar","/laioutr-ui/ui-kit/general/avatar","3.laioutr-ui/ui-kit/01.general/Avatar",{"title":1136,"path":1137,"stem":1138},"Backdrop","/laioutr-ui/ui-kit/general/backdrop","3.laioutr-ui/ui-kit/01.general/Backdrop",{"title":1140,"path":1141,"stem":1142},"Dropdown Menu","/laioutr-ui/ui-kit/general/dropdownmenu","3.laioutr-ui/ui-kit/01.general/DropdownMenu",{"title":1144,"path":1145,"stem":1146},"Edge Glow","/laioutr-ui/ui-kit/general/edgeglow","3.laioutr-ui/ui-kit/01.general/EdgeGlow",{"title":1148,"path":1149,"stem":1150},"Empty State","/laioutr-ui/ui-kit/general/emptystate","3.laioutr-ui/ui-kit/01.general/EmptyState",{"title":1152,"path":1153,"stem":1154},"Icon","/laioutr-ui/ui-kit/general/icon","3.laioutr-ui/ui-kit/01.general/Icon",{"title":1156,"path":1157,"stem":1158},"Image Contrast Overlay","/laioutr-ui/ui-kit/general/imagecontrastoverlay","3.laioutr-ui/ui-kit/01.general/ImageContrastOverlay",{"title":1160,"path":1161,"stem":1162},"Lightbox","/laioutr-ui/ui-kit/general/lightbox","3.laioutr-ui/ui-kit/01.general/Lightbox",{"title":1164,"path":1165,"stem":1166},"Loading Spinner","/laioutr-ui/ui-kit/general/loadingspinner","3.laioutr-ui/ui-kit/01.general/LoadingSpinner",{"title":387,"path":1168,"stem":1169},"/laioutr-ui/ui-kit/general/media","3.laioutr-ui/ui-kit/01.general/Media",{"title":1171,"path":1172,"stem":1173},"Navigation Bullets","/laioutr-ui/ui-kit/general/navigationbullets","3.laioutr-ui/ui-kit/01.general/NavigationBullets",{"title":1175,"path":1176,"stem":1177},"Placeholder","/laioutr-ui/ui-kit/general/placeholder","3.laioutr-ui/ui-kit/01.general/Placeholder",{"title":1179,"path":1180,"stem":1181},"Progress Bar","/laioutr-ui/ui-kit/general/progressbar","3.laioutr-ui/ui-kit/01.general/ProgressBar",{"title":1183,"path":1184,"stem":1185},"Scrollbar","/laioutr-ui/ui-kit/general/scrollbar","3.laioutr-ui/ui-kit/01.general/Scrollbar",{"title":1187,"path":1188,"stem":1189},"Swatch","/laioutr-ui/ui-kit/general/swatch","3.laioutr-ui/ui-kit/01.general/Swatch",{"title":1191,"path":1192,"stem":1193},"SwiperScrollbar","/laioutr-ui/ui-kit/general/swiperscrollbar","3.laioutr-ui/ui-kit/01.general/SwiperScrollbar",{"title":1195,"path":1196,"stem":1197},"Thumbnail","/laioutr-ui/ui-kit/general/thumbnail","3.laioutr-ui/ui-kit/01.general/Thumbnail",{"title":1199,"path":1200,"stem":1201},"Tooltip","/laioutr-ui/ui-kit/general/tooltip","3.laioutr-ui/ui-kit/01.general/Tooltip",{"title":1203,"path":1204,"stem":1205},"Amount Pill","/laioutr-ui/ui-kit/general/amount-pill","3.laioutr-ui/ui-kit/01.general/amount-pill",{"title":1207,"path":1208,"stem":1209},"Dark Mode Switch","/laioutr-ui/ui-kit/general/dark-mode-switch","3.laioutr-ui/ui-kit/01.general/dark-mode-switch",{"title":1211,"path":1212,"stem":1213},"Language Switcher","/laioutr-ui/ui-kit/general/language-switcher","3.laioutr-ui/ui-kit/01.general/language-switcher",{"title":1215,"path":1216,"stem":1217},"Media Preview","/laioutr-ui/ui-kit/general/media-preview","3.laioutr-ui/ui-kit/01.general/media-preview",{"title":1219,"path":1220,"stem":1221},"Media Stage","/laioutr-ui/ui-kit/general/media-stage","3.laioutr-ui/ui-kit/01.general/media-stage",{"title":1223,"path":1224,"stem":1225},"Nav Link Item","/laioutr-ui/ui-kit/general/nav-link-item","3.laioutr-ui/ui-kit/01.general/nav-link-item",{"title":1227,"path":1228,"stem":1229},"Nav Section Heading","/laioutr-ui/ui-kit/general/nav-section-heading","3.laioutr-ui/ui-kit/01.general/nav-section-heading",{"title":1231,"path":1232,"stem":1233},"OnSurface","/laioutr-ui/ui-kit/general/on-surface","3.laioutr-ui/ui-kit/01.general/on-surface",{"title":1235,"path":1236,"stem":1237},"Opening Hours Weekly Table","/laioutr-ui/ui-kit/general/opening-hours-weekly-table","3.laioutr-ui/ui-kit/01.general/opening-hours-weekly-table",{"title":1239,"path":1240,"stem":1241},"Opening Status","/laioutr-ui/ui-kit/general/opening-status","3.laioutr-ui/ui-kit/01.general/opening-status",{"title":1243,"path":1244,"stem":1245},"Opening Status Detail","/laioutr-ui/ui-kit/general/opening-status-detail","3.laioutr-ui/ui-kit/01.general/opening-status-detail",{"title":1247,"path":1248,"stem":1249},"Opening Status Indicator","/laioutr-ui/ui-kit/general/opening-status-indicator","3.laioutr-ui/ui-kit/01.general/opening-status-indicator",{"title":1251,"path":1252,"stem":1253},"Rating Progress Bar Filter","/laioutr-ui/ui-kit/general/rating-progress-bar-filter","3.laioutr-ui/ui-kit/01.general/rating-progress-bar-filter",{"title":1255,"path":1256,"stem":1257},"Status Message","/laioutr-ui/ui-kit/general/status-message","3.laioutr-ui/ui-kit/01.general/status-message",{"title":1259,"path":1260,"stem":1261},"Stock Info Summary","/laioutr-ui/ui-kit/general/stock-info-summary","3.laioutr-ui/ui-kit/01.general/stock-info-summary",{"title":1263,"path":1264,"stem":1265},"Swatch Chip","/laioutr-ui/ui-kit/general/swatch-chip","3.laioutr-ui/ui-kit/01.general/swatch-chip",{"title":1267,"path":1268,"stem":1269},"Swatch Option","/laioutr-ui/ui-kit/general/swatch-option","3.laioutr-ui/ui-kit/01.general/swatch-option",{"title":1271,"path":1272,"stem":1273},"Swatch Summary","/laioutr-ui/ui-kit/general/swatch-summary","3.laioutr-ui/ui-kit/01.general/swatch-summary",{"title":1275,"path":1276,"stem":1277},"Zoom Level (Segmented)","/laioutr-ui/ui-kit/general/zoom-level-segmented","3.laioutr-ui/ui-kit/01.general/zoom-level-segmented",{"title":1279,"path":1280,"stem":1281},"Zoom Level (Stepper)","/laioutr-ui/ui-kit/general/zoom-level-stepper","3.laioutr-ui/ui-kit/01.general/zoom-level-stepper",{"title":1283,"path":1284,"stem":1285,"children":1286,"page":55},"Typography","/laioutr-ui/ui-kit/typography","3.laioutr-ui/ui-kit/02.typography",[1287,1291,1294,1298,1302],{"title":1288,"path":1289,"stem":1290},"Icon List","/laioutr-ui/ui-kit/typography/iconlist","3.laioutr-ui/ui-kit/02.typography/IconList",{"title":383,"path":1292,"stem":1293},"/laioutr-ui/ui-kit/typography/link","3.laioutr-ui/ui-kit/02.typography/Link",{"title":1295,"path":1296,"stem":1297},"Rich Content","/laioutr-ui/ui-kit/typography/richcontent","3.laioutr-ui/ui-kit/02.typography/RichContent",{"title":1299,"path":1300,"stem":1301},"Text","/laioutr-ui/ui-kit/typography/text","3.laioutr-ui/ui-kit/02.typography/Text",{"title":1303,"path":1304,"stem":1305},"Text Group","/laioutr-ui/ui-kit/typography/text-group","3.laioutr-ui/ui-kit/02.typography/text-group",{"title":1307,"path":1308,"stem":1309,"children":1310,"page":55},"Layout","/laioutr-ui/ui-kit/layout","3.laioutr-ui/ui-kit/03.layout",[1311,1315,1319,1323],{"title":1312,"path":1313,"stem":1314},"Grid Fill","/laioutr-ui/ui-kit/layout/gridfill","3.laioutr-ui/ui-kit/03.layout/GridFill",{"title":1316,"path":1317,"stem":1318},"Grid Masonry","/laioutr-ui/ui-kit/layout/gridmasonry","3.laioutr-ui/ui-kit/03.layout/GridMasonry",{"title":1320,"path":1321,"stem":1322},"Scroll Area","/laioutr-ui/ui-kit/layout/scrollarea","3.laioutr-ui/ui-kit/03.layout/ScrollArea",{"title":1324,"path":1325,"stem":1326},"Separator","/laioutr-ui/ui-kit/layout/separator","3.laioutr-ui/ui-kit/03.layout/Separator",{"title":1328,"path":1329,"stem":1330,"children":1331,"page":55},"Content","/laioutr-ui/ui-kit/content","3.laioutr-ui/ui-kit/04.content",[1332,1336,1340],{"title":1333,"path":1334,"stem":1335},"Card","/laioutr-ui/ui-kit/content/card","3.laioutr-ui/ui-kit/04.content/Card",{"title":1337,"path":1338,"stem":1339},"Description List","/laioutr-ui/ui-kit/content/description-list","3.laioutr-ui/ui-kit/04.content/description-list",{"title":1341,"path":1342,"stem":1343},"Link Tile","/laioutr-ui/ui-kit/content/link-tile","3.laioutr-ui/ui-kit/04.content/link-tile",{"title":1345,"path":1346,"stem":1347,"children":1348,"page":55},"Surfaces","/laioutr-ui/ui-kit/surfaces","3.laioutr-ui/ui-kit/05.surfaces",[1349,1353,1357,1361,1365,1369,1373,1377],{"title":1350,"path":1351,"stem":1352},"Alert Dialog","/laioutr-ui/ui-kit/surfaces/alertdialog","3.laioutr-ui/ui-kit/05.surfaces/AlertDialog",{"title":1354,"path":1355,"stem":1356},"Popover","/laioutr-ui/ui-kit/surfaces/popover","3.laioutr-ui/ui-kit/05.surfaces/Popover",{"title":1358,"path":1359,"stem":1360},"Sheet","/laioutr-ui/ui-kit/surfaces/sheet","3.laioutr-ui/ui-kit/05.surfaces/Sheet",{"title":1362,"path":1363,"stem":1364},"Tabs","/laioutr-ui/ui-kit/surfaces/tabs","3.laioutr-ui/ui-kit/05.surfaces/Tabs",{"title":1366,"path":1367,"stem":1368},"Toast","/laioutr-ui/ui-kit/surfaces/toast","3.laioutr-ui/ui-kit/05.surfaces/Toast",{"title":1370,"path":1371,"stem":1372},"Toaster","/laioutr-ui/ui-kit/surfaces/toaster","3.laioutr-ui/ui-kit/05.surfaces/Toaster",{"title":1374,"path":1375,"stem":1376},"Context Menu","/laioutr-ui/ui-kit/surfaces/context-menu","3.laioutr-ui/ui-kit/05.surfaces/context-menu",{"title":1378,"path":1379,"stem":1380},"Navigation Menu","/laioutr-ui/ui-kit/surfaces/navigation-menu","3.laioutr-ui/ui-kit/05.surfaces/navigation-menu",{"title":1382,"path":1383,"stem":1384,"children":1385,"page":55},"Form","/laioutr-ui/ui-kit/form","3.laioutr-ui/ui-kit/06.form",[1386,1390,1394,1398,1402,1406,1410,1414,1418,1422,1426,1430,1434,1438,1442,1446,1450,1454,1458,1462,1466,1470,1474,1478,1482,1486],{"title":1387,"path":1388,"stem":1389},"Button","/laioutr-ui/ui-kit/form/button","3.laioutr-ui/ui-kit/06.form/Button",{"title":1391,"path":1392,"stem":1393},"Checkbox","/laioutr-ui/ui-kit/form/checkbox","3.laioutr-ui/ui-kit/06.form/Checkbox",{"title":1395,"path":1396,"stem":1397},"Field","/laioutr-ui/ui-kit/form/field","3.laioutr-ui/ui-kit/06.form/Field",{"title":1399,"path":1400,"stem":1401},"Input","/laioutr-ui/ui-kit/form/input","3.laioutr-ui/ui-kit/06.form/Input",{"title":1403,"path":1404,"stem":1405},"Label","/laioutr-ui/ui-kit/form/label","3.laioutr-ui/ui-kit/06.form/Label",{"title":1407,"path":1408,"stem":1409},"Load More","/laioutr-ui/ui-kit/form/loadmore","3.laioutr-ui/ui-kit/06.form/LoadMore",{"title":1411,"path":1412,"stem":1413},"Pagination","/laioutr-ui/ui-kit/form/pagination","3.laioutr-ui/ui-kit/06.form/Pagination",{"title":1415,"path":1416,"stem":1417},"Quantity Picker","/laioutr-ui/ui-kit/form/quantitypicker","3.laioutr-ui/ui-kit/06.form/QuantityPicker",{"title":1419,"path":1420,"stem":1421},"Select","/laioutr-ui/ui-kit/form/select","3.laioutr-ui/ui-kit/06.form/Select",{"title":1423,"path":1424,"stem":1425},"Switch","/laioutr-ui/ui-kit/form/switch","3.laioutr-ui/ui-kit/06.form/Switch",{"title":1427,"path":1428,"stem":1429},"Highlight Toggle","/laioutr-ui/ui-kit/form/highlight-toggle","3.laioutr-ui/ui-kit/06.form/highlight-toggle",{"title":1431,"path":1432,"stem":1433},"Icon Button","/laioutr-ui/ui-kit/form/icon-button","3.laioutr-ui/ui-kit/06.form/icon-button",{"title":1435,"path":1436,"stem":1437},"Input Autocomplete","/laioutr-ui/ui-kit/form/input-autocomplete","3.laioutr-ui/ui-kit/06.form/input-autocomplete",{"title":1439,"path":1440,"stem":1441},"Input Checkbox","/laioutr-ui/ui-kit/form/input-checkbox","3.laioutr-ui/ui-kit/06.form/input-checkbox",{"title":1443,"path":1444,"stem":1445},"Input Combobox","/laioutr-ui/ui-kit/form/input-combobox","3.laioutr-ui/ui-kit/06.form/input-combobox",{"title":1447,"path":1448,"stem":1449},"Input Group","/laioutr-ui/ui-kit/form/input-group","3.laioutr-ui/ui-kit/06.form/input-group",{"title":1451,"path":1452,"stem":1453},"Input Password","/laioutr-ui/ui-kit/form/input-password","3.laioutr-ui/ui-kit/06.form/input-password",{"title":1455,"path":1456,"stem":1457},"Input Pin","/laioutr-ui/ui-kit/form/input-pin","3.laioutr-ui/ui-kit/06.form/input-pin",{"title":1459,"path":1460,"stem":1461},"Input Radio","/laioutr-ui/ui-kit/form/input-radio","3.laioutr-ui/ui-kit/06.form/input-radio",{"title":1463,"path":1464,"stem":1465},"Input Rating","/laioutr-ui/ui-kit/form/input-rating","3.laioutr-ui/ui-kit/06.form/input-rating",{"title":1467,"path":1468,"stem":1469},"Input Search","/laioutr-ui/ui-kit/form/input-search","3.laioutr-ui/ui-kit/06.form/input-search",{"title":1471,"path":1472,"stem":1473},"Input Slider","/laioutr-ui/ui-kit/form/input-slider","3.laioutr-ui/ui-kit/06.form/input-slider",{"title":1475,"path":1476,"stem":1477},"Listbox","/laioutr-ui/ui-kit/form/listbox","3.laioutr-ui/ui-kit/06.form/listbox",{"title":1479,"path":1480,"stem":1481},"Option Tile (Image)","/laioutr-ui/ui-kit/form/option-tile-image","3.laioutr-ui/ui-kit/06.form/option-tile-image",{"title":1483,"path":1484,"stem":1485},"Option Tile (Text)","/laioutr-ui/ui-kit/form/option-tile-text","3.laioutr-ui/ui-kit/06.form/option-tile-text",{"title":1487,"path":1488,"stem":1489},"Variant Selection Card","/laioutr-ui/ui-kit/form/variant-selection-card","3.laioutr-ui/ui-kit/06.form/variant-selection-card",{"title":1491,"path":1492,"stem":1493,"children":1494,"page":55},"Indicators","/laioutr-ui/ui-kit/indicators","3.laioutr-ui/ui-kit/07.indicators",[1495,1499,1503,1507,1511,1515],{"title":1496,"path":1497,"stem":1498},"Badge","/laioutr-ui/ui-kit/indicators/badge","3.laioutr-ui/ui-kit/07.indicators/Badge",{"title":1500,"path":1501,"stem":1502},"Caption Flag","/laioutr-ui/ui-kit/indicators/captionflag","3.laioutr-ui/ui-kit/07.indicators/CaptionFlag",{"title":1504,"path":1505,"stem":1506},"Product Tile Flag","/laioutr-ui/ui-kit/indicators/producttileflag","3.laioutr-ui/ui-kit/07.indicators/ProductTileFlag",{"title":1508,"path":1509,"stem":1510},"Rating Summary","/laioutr-ui/ui-kit/indicators/ratingsummary","3.laioutr-ui/ui-kit/07.indicators/RatingSummary",{"title":1512,"path":1513,"stem":1514},"Stars Rating","/laioutr-ui/ui-kit/indicators/starsrating","3.laioutr-ui/ui-kit/07.indicators/StarsRating",{"title":1516,"path":1517,"stem":1518},"Badge Promotion","/laioutr-ui/ui-kit/indicators/badge-promotion","3.laioutr-ui/ui-kit/07.indicators/badge-promotion",{"title":1520,"path":1521,"stem":1522,"children":1523,"page":55},"Utility Components","/laioutr-ui/ui-kit/utility-components","3.laioutr-ui/ui-kit/08.utility-components",[1524,1528],{"title":1525,"path":1526,"stem":1527},"Highlighted Text","/laioutr-ui/ui-kit/utility-components/highlighted-text","3.laioutr-ui/ui-kit/08.utility-components/highlighted-text",{"title":1529,"path":1530,"stem":1531},"Sizer","/laioutr-ui/ui-kit/utility-components/sizer","3.laioutr-ui/ui-kit/08.utility-components/sizer",{"title":1533,"path":1534,"stem":1535,"children":1536},"Hosting","/hosting","4.hosting/0.index",[1537,1538,1544,1574,1592],{"title":1533,"path":1534,"stem":1535},{"title":1539,"path":1540,"stem":1541,"children":1542},"Laioutr Cloud","/hosting/laioutr-cloud","4.hosting/0.laioutr-cloud/0.index",[1543],{"title":1539,"path":1540,"stem":1541},{"title":1545,"path":1546,"stem":1547,"children":1548},"Hyperscaler","/hosting/hyperscaler","4.hosting/1.hyperscaler/0.index",[1549,1550,1554,1558,1562,1566,1570],{"title":1545,"path":1546,"stem":1547},{"title":1551,"path":1552,"stem":1553},"Akamai Adapter","/hosting/hyperscaler/akamai-adapter","4.hosting/1.hyperscaler/akamai-adapter",{"title":1555,"path":1556,"stem":1557},"AWS Adapter","/hosting/hyperscaler/aws-adapter","4.hosting/1.hyperscaler/aws-adapter",{"title":1559,"path":1560,"stem":1561},"Azure Adapter","/hosting/hyperscaler/azure-adapter","4.hosting/1.hyperscaler/azure-adapter",{"title":1563,"path":1564,"stem":1565},"Google Adapter","/hosting/hyperscaler/google-adapter","4.hosting/1.hyperscaler/google-adapter",{"title":1567,"path":1568,"stem":1569},"Netlify Adapter","/hosting/hyperscaler/netlify-adapter","4.hosting/1.hyperscaler/netlify-adapter",{"title":1571,"path":1572,"stem":1573},"Vercel Adapter","/hosting/hyperscaler/vercel-adapter","4.hosting/1.hyperscaler/vercel-adapter",{"title":1575,"path":1576,"stem":1577,"children":1578},"Native Hosting","/hosting/native-hosting-providers","4.hosting/2.native-hosting-providers/0.index",[1579,1580,1584,1588],{"title":1575,"path":1576,"stem":1577},{"title":1581,"path":1582,"stem":1583},"maxcluster","/hosting/native-hosting-providers/maxcluster","4.hosting/2.native-hosting-providers/maxcluster",{"title":1585,"path":1586,"stem":1587},"profihost","/hosting/native-hosting-providers/profihost","4.hosting/2.native-hosting-providers/profihost",{"title":1589,"path":1590,"stem":1591},"ScaleCommerce","/hosting/native-hosting-providers/scale-commerce","4.hosting/2.native-hosting-providers/scale-commerce",{"title":1593,"path":1594,"stem":1595,"children":1596},"Bring Your Own Server (BYOS)","/hosting/bring-your-own-server-byos","4.hosting/3.bring-your-own-server-byos/0.index",[1597,1598,1602,1606,1610,1614,1618],{"title":1593,"path":1594,"stem":1595},{"title":1599,"path":1600,"stem":1601},"BYOS Agent","/hosting/bring-your-own-server-byos/byos-agent","4.hosting/3.bring-your-own-server-byos/byos-agent",{"title":1603,"path":1604,"stem":1605},"Changelog","/hosting/bring-your-own-server-byos/changelog","4.hosting/3.bring-your-own-server-byos/changelog",{"title":1607,"path":1608,"stem":1609},"DevOps Components","/hosting/bring-your-own-server-byos/devops","4.hosting/3.bring-your-own-server-byos/devops",{"title":1611,"path":1612,"stem":1613},"Infrastructure Requirements","/hosting/bring-your-own-server-byos/infrastructure","4.hosting/3.bring-your-own-server-byos/infrastructure",{"title":1615,"path":1616,"stem":1617},"Software Requirements","/hosting/bring-your-own-server-byos/software","4.hosting/3.bring-your-own-server-byos/software",{"title":1619,"path":1620,"stem":1621},"Webhook Configuration","/hosting/bring-your-own-server-byos/webhook-config","4.hosting/3.bring-your-own-server-byos/webhook-config",{"title":1623,"path":1624,"stem":1625,"children":1626},"Checkout","/checkout","5.Checkout/0.index",[1627],{"title":1623,"path":1624,"stem":1625},{"title":1629,"path":1630,"stem":1631,"children":1632},"Larry AI","/larry-ai","6.Larry-AI/0.index",[1633],{"title":1629,"path":1630,"stem":1631},{"title":671,"path":1635,"stem":1636,"children":1637},"/figma-kit","7.Figma Kit/0.index",[1638,1639,1655],{"title":671,"path":1635,"stem":1636},{"title":121,"path":1640,"stem":1641,"children":1642,"page":55},"/figma-kit/introduction","7.Figma Kit/1.Introduction",[1643,1647,1651],{"title":1644,"path":1645,"stem":1646},"How to Start","/figma-kit/introduction/howtostart","7.Figma Kit/1.Introduction/0.howtostart",{"title":1648,"path":1649,"stem":1650},"Figma Variables","/figma-kit/introduction/figma-variables","7.Figma Kit/1.Introduction/figma-variables",{"title":1652,"path":1653,"stem":1654},"Library Connections","/figma-kit/introduction/library-connections","7.Figma Kit/1.Introduction/library-connections",{"title":1656,"path":1657,"stem":1658,"children":1659,"page":55},"Kits","/figma-kit/kits","7.Figma Kit/Kits",[1660,1663,1666,1669,1673,1676,1680,1684,1687,1690],{"title":686,"path":1661,"stem":1662},"/figma-kit/kits/b2b","7.Figma Kit/Kits/b2b",{"title":692,"path":1664,"stem":1665},"/figma-kit/kits/booking","7.Figma Kit/Kits/booking",{"title":698,"path":1667,"stem":1668},"/figma-kit/kits/cms","7.Figma Kit/Kits/cms",{"title":1670,"path":1671,"stem":1672},"Inpage Navigation","/figma-kit/kits/inpage-navigation","7.Figma Kit/Kits/inpage-navigation",{"title":903,"path":1674,"stem":1675},"/figma-kit/kits/marketplace","7.Figma Kit/Kits/marketplace",{"title":1677,"path":1678,"stem":1679},"Retail & Multichannel","/figma-kit/kits/multichannel","7.Figma Kit/Kits/multichannel",{"title":1681,"path":1682,"stem":1683},"Navigation","/figma-kit/kits/navigation","7.Figma Kit/Kits/navigation",{"title":969,"path":1685,"stem":1686},"/figma-kit/kits/saas","7.Figma Kit/Kits/saas",{"title":987,"path":1688,"stem":1689},"/figma-kit/kits/shop","7.Figma Kit/Kits/shop",{"title":1117,"path":1691,"stem":1692},"/figma-kit/kits/ui-kit","7.Figma Kit/Kits/ui-kit",{"title":1694,"path":1695,"stem":1696,"children":1697},"Cockpit","/cockpit","8.Cockpit/0.index",[1698,1699,1729,1746,1763],{"title":1694,"path":1695,"stem":1696},{"title":154,"path":1700,"stem":1701,"children":1702,"page":55},"/cockpit/features","8.Cockpit/1.Features",[1703,1706,1710,1714,1718,1721,1725],{"title":464,"path":1704,"stem":1705},"/cockpit/features/apps","8.Cockpit/1.Features/apps",{"title":1707,"path":1708,"stem":1709},"Content (Collections)","/cockpit/features/content-collections","8.Cockpit/1.Features/content-collections",{"title":1711,"path":1712,"stem":1713},"Deployments","/cockpit/features/deployments","8.Cockpit/1.Features/deployments",{"title":1715,"path":1716,"stem":1717},"Markets","/cockpit/features/markets","8.Cockpit/1.Features/markets",{"title":196,"path":1719,"stem":1720},"/cockpit/features/redirects","8.Cockpit/1.Features/redirects",{"title":1722,"path":1723,"stem":1724},"Studio","/cockpit/features/studio","8.Cockpit/1.Features/studio",{"title":1726,"path":1727,"stem":1728},"Translations","/cockpit/features/translations","8.Cockpit/1.Features/translations",{"title":1730,"path":1731,"stem":1732,"children":1733,"page":55},"Project Settings","/cockpit/project-settings","8.Cockpit/2.Project-Settings",[1734,1738,1742],{"title":1735,"path":1736,"stem":1737},"Delete a project","/cockpit/project-settings/delete-project","8.Cockpit/2.Project-Settings/delete-project",{"title":1739,"path":1740,"stem":1741},"NPM","/cockpit/project-settings/npm","8.Cockpit/2.Project-Settings/npm",{"title":1743,"path":1744,"stem":1745},"Project secret key","/cockpit/project-settings/project-secret-key","8.Cockpit/2.Project-Settings/project-secret-key",{"title":1747,"path":1748,"stem":1749,"children":1750,"page":55},"Account Settings","/cockpit/account-settings","8.Cockpit/3.Account-Settings",[1751,1755,1759],{"title":1752,"path":1753,"stem":1754},"Notifications","/cockpit/account-settings/notifications","8.Cockpit/3.Account-Settings/notifications",{"title":1756,"path":1757,"stem":1758},"Preferences","/cockpit/account-settings/preferences","8.Cockpit/3.Account-Settings/preferences",{"title":1760,"path":1761,"stem":1762},"Security","/cockpit/account-settings/security","8.Cockpit/3.Account-Settings/security",{"title":1764,"path":1765,"stem":1766,"children":1767,"page":55},"Organisation Settings","/cockpit/organisation-settings","8.Cockpit/4.Organisation-Settings",[1768,1772,1776,1780,1784,1788],{"title":1769,"path":1770,"stem":1771},"API keys","/cockpit/organisation-settings/api-keys","8.Cockpit/4.Organisation-Settings/api-keys",{"title":1773,"path":1774,"stem":1775},"Billing","/cockpit/organisation-settings/billing","8.Cockpit/4.Organisation-Settings/billing",{"title":1777,"path":1778,"stem":1779},"General settings","/cockpit/organisation-settings/general-settings","8.Cockpit/4.Organisation-Settings/general-settings",{"title":1781,"path":1782,"stem":1783},"Members","/cockpit/organisation-settings/members","8.Cockpit/4.Organisation-Settings/members",{"title":1785,"path":1786,"stem":1787},"Projects","/cockpit/organisation-settings/projects","8.Cockpit/4.Organisation-Settings/projects",{"title":1789,"path":1790,"stem":1791},"Roles","/cockpit/organisation-settings/roles","8.Cockpit/4.Organisation-Settings/roles",{"title":1793,"path":1794,"stem":1795,"children":1796},"Offering","/offering","9.Offering/0.index",[1797,1798,1830,1843,1856,1890,1899],{"title":1793,"path":1794,"stem":1795},{"title":1799,"path":1800,"stem":1801,"children":1802},"Products","/offering/products","9.Offering/1.Products/0.index",[1803,1804,1809,1814,1819,1825],{"title":1799,"path":1800,"stem":1801},{"title":137,"path":1805,"stem":1806,"children":1807},"/offering/products/frontend","9.Offering/1.Products/1.Frontend/0.index",[1808],{"title":137,"path":1805,"stem":1806},{"title":1694,"path":1810,"stem":1811,"children":1812},"/offering/products/cockpit","9.Offering/1.Products/2.Cockpit/0.index",[1813],{"title":1694,"path":1810,"stem":1811},{"title":1623,"path":1815,"stem":1816,"children":1817},"/offering/products/checkout","9.Offering/1.Products/3.Checkout/0.index",[1818],{"title":1623,"path":1815,"stem":1816},{"title":1820,"path":1821,"stem":1822,"children":1823},"Cloud","/offering/products/cloud","9.Offering/1.Products/4.cloud/0.index",[1824],{"title":1820,"path":1821,"stem":1822},{"title":1629,"path":1826,"stem":1827,"children":1828},"/offering/products/larry-ai","9.Offering/1.Products/5.larry-ai/0.index",[1829],{"title":1629,"path":1826,"stem":1827},{"title":1831,"path":1832,"stem":1833,"children":1834,"page":55},"Service Level Agreement","/offering/service-level-agreement","9.Offering/2.service-level-agreement",[1835,1839],{"title":1836,"path":1837,"stem":1838},"Standard Service Level Agreement Composable Frontend","/offering/service-level-agreement/standard-service-level-agreement","9.Offering/2.service-level-agreement/1.standard-service-level-agreement",{"title":1840,"path":1841,"stem":1842},"Backups","/offering/service-level-agreement/backups","9.Offering/2.service-level-agreement/backups",{"title":1844,"path":1845,"stem":1846,"children":1847,"page":55},"Customer Support","/offering/customer-support","9.Offering/3.customer-support",[1848,1852],{"title":1849,"path":1850,"stem":1851},"Standard Customer Support","/offering/customer-support/standard-customer-support","9.Offering/3.customer-support/1.standard-customer-support",{"title":1853,"path":1854,"stem":1855},"Customer Support Severity Levels of Laioutr products","/offering/customer-support/maximum-serverity-levels","9.Offering/3.customer-support/maximum-serverity-levels",{"title":1857,"path":1858,"stem":1859,"children":1860},"Trust Center","/offering/trust-center","9.Offering/4.trust-center/0.index",[1861,1862,1866,1870,1874,1878,1882,1886],{"title":1857,"path":1858,"stem":1859},{"title":1863,"path":1864,"stem":1865},"Data Protection (GDPR)","/offering/trust-center/data-protection","9.Offering/4.trust-center/1.data-protection",{"title":1867,"path":1868,"stem":1869},"Subprocessors","/offering/trust-center/subprocessors","9.Offering/4.trust-center/2.subprocessors",{"title":1871,"path":1872,"stem":1873},"Infrastructure & Hosting","/offering/trust-center/infrastructure","9.Offering/4.trust-center/3.infrastructure",{"title":1875,"path":1876,"stem":1877},"Security Measures","/offering/trust-center/security-measures","9.Offering/4.trust-center/4.security-measures",{"title":1879,"path":1880,"stem":1881},"Incident Response","/offering/trust-center/incident-response","9.Offering/4.trust-center/5.incident-response",{"title":1883,"path":1884,"stem":1885},"Compliance & Certifications","/offering/trust-center/compliance","9.Offering/4.trust-center/6.compliance",{"title":1887,"path":1888,"stem":1889},"FAQ","/offering/trust-center/faq","9.Offering/4.trust-center/7.faq",{"title":1891,"path":1892,"stem":1893,"children":1894,"page":55},"Policies","/offering/policies","9.Offering/5.policies",[1895],{"title":1896,"path":1897,"stem":1898},"Fair usage policy","/offering/policies/fair-usage-policy","9.Offering/5.policies/fair-usage-policy",{"title":1900,"path":1901,"stem":1902,"children":1903},"Academy","/offering/academy","9.Offering/6.academy/0.index",[1904],{"title":1900,"path":1901,"stem":1902},{"id":1906,"title":490,"aliases":1907,"body":1908,"changelogKeys":3909,"description":3910,"extension":3911,"links":3909,"meta":3912,"navigation":1987,"path":491,"playground":3909,"seo":3913,"sitemap":3916,"stem":492,"__hash__":3922},"docs/2.Apps/app-development/99.guides/shared-field-factories.md",[],{"type":1909,"value":1910,"toc":3900},"minimark",[1911,1930,1933,2236,2239,2316,2323,2328,2354,2378,2385,2389,2396,2635,2650,2653,2687,2691,2694,2822,2833,2980,2983,3053,3064,3068,3078,3116,3148,3161,3647,3662,3665,3793,3797,3800,3803,3807,3821,3868,3877,3881,3896],[1912,1913,1914,1915,1919,1920,1919,1923,1919,1926,1929],"p",{},"Your app has six sections and four of them have the same margin field: a select with ",[1916,1917,1918],"code",{},"none",", ",[1916,1921,1922],{},"s",[1916,1924,1925],{},"m",[1916,1927,1928],{},"l",". The fifth section adds it. The sixth section is about to. You're now maintaining the same option list in six places, and the option labels drift apart by the second copy.",[1912,1931,1932],{},"Promote the field to a factory. A tiny one-liner like this:",[1934,1935,1941],"pre",{"className":1936,"code":1937,"filename":1938,"language":1939,"meta":1940,"style":1940},"language-ts shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import type { StudioFieldDefinition } from '@laioutr-core/core-types/fields';\n\nexport const marginField = {\n  type: 'select',\n  name: 'margin',\n  label: 'Margin',\n  default: 'none',\n  options: [\n    { label: 'None', value: 'none' },\n    { label: 'S', value: 's' },\n    { label: 'M', value: 'm' },\n    { label: 'L', value: 'l' },\n  ],\n} satisfies StudioFieldDefinition;\n","shared-fields/margin.ts","ts","",[1916,1942,1943,1982,1989,2008,2028,2045,2062,2078,2089,2124,2154,2184,2214,2222],{"__ignoreMap":1940},[1944,1945,1948,1952,1955,1959,1963,1966,1969,1972,1976,1979],"span",{"class":1946,"line":1947},"line",1,[1944,1949,1951],{"class":1950},"s7zQu","import",[1944,1953,1954],{"class":1950}," type",[1944,1956,1958],{"class":1957},"sMK4o"," {",[1944,1960,1962],{"class":1961},"sTEyZ"," StudioFieldDefinition",[1944,1964,1965],{"class":1957}," }",[1944,1967,1968],{"class":1950}," from",[1944,1970,1971],{"class":1957}," '",[1944,1973,1975],{"class":1974},"sfazB","@laioutr-core/core-types/fields",[1944,1977,1978],{"class":1957},"'",[1944,1980,1981],{"class":1957},";\n",[1944,1983,1985],{"class":1946,"line":1984},2,[1944,1986,1988],{"emptyLinePlaceholder":1987},true,"\n",[1944,1990,1992,1995,1999,2002,2005],{"class":1946,"line":1991},3,[1944,1993,1994],{"class":1950},"export",[1944,1996,1998],{"class":1997},"spNyl"," const",[1944,2000,2001],{"class":1961}," marginField ",[1944,2003,2004],{"class":1957},"=",[1944,2006,2007],{"class":1957}," {\n",[1944,2009,2011,2015,2018,2020,2023,2025],{"class":1946,"line":2010},4,[1944,2012,2014],{"class":2013},"swJcz","  type",[1944,2016,2017],{"class":1957},":",[1944,2019,1971],{"class":1957},[1944,2021,2022],{"class":1974},"select",[1944,2024,1978],{"class":1957},[1944,2026,2027],{"class":1957},",\n",[1944,2029,2031,2034,2036,2038,2041,2043],{"class":1946,"line":2030},5,[1944,2032,2033],{"class":2013},"  name",[1944,2035,2017],{"class":1957},[1944,2037,1971],{"class":1957},[1944,2039,2040],{"class":1974},"margin",[1944,2042,1978],{"class":1957},[1944,2044,2027],{"class":1957},[1944,2046,2048,2051,2053,2055,2058,2060],{"class":1946,"line":2047},6,[1944,2049,2050],{"class":2013},"  label",[1944,2052,2017],{"class":1957},[1944,2054,1971],{"class":1957},[1944,2056,2057],{"class":1974},"Margin",[1944,2059,1978],{"class":1957},[1944,2061,2027],{"class":1957},[1944,2063,2065,2068,2070,2072,2074,2076],{"class":1946,"line":2064},7,[1944,2066,2067],{"class":2013},"  default",[1944,2069,2017],{"class":1957},[1944,2071,1971],{"class":1957},[1944,2073,1918],{"class":1974},[1944,2075,1978],{"class":1957},[1944,2077,2027],{"class":1957},[1944,2079,2081,2084,2086],{"class":1946,"line":2080},8,[1944,2082,2083],{"class":2013},"  options",[1944,2085,2017],{"class":1957},[1944,2087,2088],{"class":1961}," [\n",[1944,2090,2092,2095,2098,2100,2102,2105,2107,2110,2113,2115,2117,2119,2121],{"class":1946,"line":2091},9,[1944,2093,2094],{"class":1957},"    {",[1944,2096,2097],{"class":2013}," label",[1944,2099,2017],{"class":1957},[1944,2101,1971],{"class":1957},[1944,2103,2104],{"class":1974},"None",[1944,2106,1978],{"class":1957},[1944,2108,2109],{"class":1957},",",[1944,2111,2112],{"class":2013}," value",[1944,2114,2017],{"class":1957},[1944,2116,1971],{"class":1957},[1944,2118,1918],{"class":1974},[1944,2120,1978],{"class":1957},[1944,2122,2123],{"class":1957}," },\n",[1944,2125,2127,2129,2131,2133,2135,2138,2140,2142,2144,2146,2148,2150,2152],{"class":1946,"line":2126},10,[1944,2128,2094],{"class":1957},[1944,2130,2097],{"class":2013},[1944,2132,2017],{"class":1957},[1944,2134,1971],{"class":1957},[1944,2136,2137],{"class":1974},"S",[1944,2139,1978],{"class":1957},[1944,2141,2109],{"class":1957},[1944,2143,2112],{"class":2013},[1944,2145,2017],{"class":1957},[1944,2147,1971],{"class":1957},[1944,2149,1922],{"class":1974},[1944,2151,1978],{"class":1957},[1944,2153,2123],{"class":1957},[1944,2155,2157,2159,2161,2163,2165,2168,2170,2172,2174,2176,2178,2180,2182],{"class":1946,"line":2156},11,[1944,2158,2094],{"class":1957},[1944,2160,2097],{"class":2013},[1944,2162,2017],{"class":1957},[1944,2164,1971],{"class":1957},[1944,2166,2167],{"class":1974},"M",[1944,2169,1978],{"class":1957},[1944,2171,2109],{"class":1957},[1944,2173,2112],{"class":2013},[1944,2175,2017],{"class":1957},[1944,2177,1971],{"class":1957},[1944,2179,1925],{"class":1974},[1944,2181,1978],{"class":1957},[1944,2183,2123],{"class":1957},[1944,2185,2187,2189,2191,2193,2195,2198,2200,2202,2204,2206,2208,2210,2212],{"class":1946,"line":2186},12,[1944,2188,2094],{"class":1957},[1944,2190,2097],{"class":2013},[1944,2192,2017],{"class":1957},[1944,2194,1971],{"class":1957},[1944,2196,2197],{"class":1974},"L",[1944,2199,1978],{"class":1957},[1944,2201,2109],{"class":1957},[1944,2203,2112],{"class":2013},[1944,2205,2017],{"class":1957},[1944,2207,1971],{"class":1957},[1944,2209,1928],{"class":1974},[1944,2211,1978],{"class":1957},[1944,2213,2123],{"class":1957},[1944,2215,2217,2220],{"class":1946,"line":2216},13,[1944,2218,2219],{"class":1961},"  ]",[1944,2221,2027],{"class":1957},[1944,2223,2225,2228,2231,2234],{"class":1946,"line":2224},14,[1944,2226,2227],{"class":1957},"}",[1944,2229,2230],{"class":1950}," satisfies",[1944,2232,1962],{"class":2233},"sBMFI",[1944,2235,1981],{"class":1957},[1912,2237,2238],{},"Then reuse it:",[1934,2240,2243],{"className":1936,"code":2241,"filename":2242,"language":1939,"meta":1940,"style":1940},"schema: [\n  {\n    label: 'Design',\n    fields: [\n      marginField,\n      // ...\n    ],\n  },\n],\n","sections/SectionHero.vue",[1916,2244,2245,2254,2259,2275,2284,2291,2297,2304,2309],{"__ignoreMap":1940},[1944,2246,2247,2250,2252],{"class":1946,"line":1947},[1944,2248,2249],{"class":2233},"schema",[1944,2251,2017],{"class":1957},[1944,2253,2088],{"class":1961},[1944,2255,2256],{"class":1946,"line":1984},[1944,2257,2258],{"class":1957},"  {\n",[1944,2260,2261,2264,2266,2268,2271,2273],{"class":1946,"line":1991},[1944,2262,2263],{"class":2013},"    label",[1944,2265,2017],{"class":1957},[1944,2267,1971],{"class":1957},[1944,2269,2270],{"class":1974},"Design",[1944,2272,1978],{"class":1957},[1944,2274,2027],{"class":1957},[1944,2276,2277,2280,2282],{"class":1946,"line":2010},[1944,2278,2279],{"class":2013},"    fields",[1944,2281,2017],{"class":1957},[1944,2283,2088],{"class":1961},[1944,2285,2286,2289],{"class":1946,"line":2030},[1944,2287,2288],{"class":1961},"      marginField",[1944,2290,2027],{"class":1957},[1944,2292,2293],{"class":1946,"line":2047},[1944,2294,2296],{"class":2295},"sHwdD","      // ...\n",[1944,2298,2299,2302],{"class":1946,"line":2064},[1944,2300,2301],{"class":1961},"    ]",[1944,2303,2027],{"class":1957},[1944,2305,2306],{"class":1946,"line":2080},[1944,2307,2308],{"class":1957},"  },\n",[1944,2310,2311,2314],{"class":1946,"line":2091},[1944,2312,2313],{"class":1961},"]",[1944,2315,2027],{"class":1957},[1912,2317,2318,2319,2322],{},"That works for the simple case. The rest of this guide is about the cases where the simple case fails: when TypeScript silently widens your literals and ",[1916,2320,2321],{},"definitionToProps"," stops producing narrow types.",[2324,2325,2327],"h2",{"id":2326},"the-widening-problem","The widening problem",[1912,2329,2330,2331,2334,2335,1919,2338,1919,2341,2344,2345,2349,2350,2353],{},"The reason factories are non-trivial is that schema field arrays in ",[1916,2332,2333],{},"defineSection"," are typed as a union of every possible field type. Each member carries ",[1916,2336,2337],{},"name: string",[1916,2339,2340],{},"type: string",[1916,2342,2343],{},"value: string",". When TypeScript resolves your factory call inside that array, it lines up your return against the union and ",[2346,2347,2348],"strong",{},"widens"," literals to plain ",[1916,2351,2352],{},"string"," along the way.",[1912,2355,2356,2357,2359,2360,2363,2364,2367,2368,2370,2371,2373,2374,2377],{},"The result: ",[1916,2358,2321],{}," derives prop types from ",[1916,2361,2362],{},"options[i].value",". If your ",[1916,2365,2366],{},"value"," widens to ",[1916,2369,2352],{},", the prop type widens to ",[1916,2372,2352],{},". You lose the ",[1916,2375,2376],{},"'none' | 's' | 'm' | 'l'"," discrimination that you wanted.",[1912,2379,2380,2381,2384],{},"The fix is to write factories whose return types are derived ",[2346,2382,2383],{},"structurally"," from the input, not inferred as independent generic parameters with defaults.",[2324,2386,2388],{"id":2387},"pattern-1-static-field-no-generics","Pattern 1: static field, no generics",[1912,2390,2391,2392,2395],{},"When the field shape is fixed (margin, padding, fixed enum), you don't need generics. Use ",[1916,2393,2394],{},"satisfies"," to keep literal types intact:",[1934,2397,2400],{"className":1936,"code":2398,"filename":2399,"language":1939,"meta":1940,"style":1940},"import type { StudioFieldDefinition } from '@laioutr-core/core-types/fields';\n\nexport const paddingField = {\n  type: 'select',\n  name: 'padding',\n  label: 'Padding',\n  default: 'none',\n  options: [\n    { label: 'None', value: 'none' },\n    { label: 'S', value: 's' },\n    { label: 'M', value: 'm' },\n    { label: 'L', value: 'l' },\n  ],\n} satisfies StudioFieldDefinition;\n","shared-fields/padding.ts",[1916,2401,2402,2424,2428,2441,2455,2470,2485,2499,2507,2535,2563,2591,2619,2625],{"__ignoreMap":1940},[1944,2403,2404,2406,2408,2410,2412,2414,2416,2418,2420,2422],{"class":1946,"line":1947},[1944,2405,1951],{"class":1950},[1944,2407,1954],{"class":1950},[1944,2409,1958],{"class":1957},[1944,2411,1962],{"class":1961},[1944,2413,1965],{"class":1957},[1944,2415,1968],{"class":1950},[1944,2417,1971],{"class":1957},[1944,2419,1975],{"class":1974},[1944,2421,1978],{"class":1957},[1944,2423,1981],{"class":1957},[1944,2425,2426],{"class":1946,"line":1984},[1944,2427,1988],{"emptyLinePlaceholder":1987},[1944,2429,2430,2432,2434,2437,2439],{"class":1946,"line":1991},[1944,2431,1994],{"class":1950},[1944,2433,1998],{"class":1997},[1944,2435,2436],{"class":1961}," paddingField ",[1944,2438,2004],{"class":1957},[1944,2440,2007],{"class":1957},[1944,2442,2443,2445,2447,2449,2451,2453],{"class":1946,"line":2010},[1944,2444,2014],{"class":2013},[1944,2446,2017],{"class":1957},[1944,2448,1971],{"class":1957},[1944,2450,2022],{"class":1974},[1944,2452,1978],{"class":1957},[1944,2454,2027],{"class":1957},[1944,2456,2457,2459,2461,2463,2466,2468],{"class":1946,"line":2030},[1944,2458,2033],{"class":2013},[1944,2460,2017],{"class":1957},[1944,2462,1971],{"class":1957},[1944,2464,2465],{"class":1974},"padding",[1944,2467,1978],{"class":1957},[1944,2469,2027],{"class":1957},[1944,2471,2472,2474,2476,2478,2481,2483],{"class":1946,"line":2047},[1944,2473,2050],{"class":2013},[1944,2475,2017],{"class":1957},[1944,2477,1971],{"class":1957},[1944,2479,2480],{"class":1974},"Padding",[1944,2482,1978],{"class":1957},[1944,2484,2027],{"class":1957},[1944,2486,2487,2489,2491,2493,2495,2497],{"class":1946,"line":2064},[1944,2488,2067],{"class":2013},[1944,2490,2017],{"class":1957},[1944,2492,1971],{"class":1957},[1944,2494,1918],{"class":1974},[1944,2496,1978],{"class":1957},[1944,2498,2027],{"class":1957},[1944,2500,2501,2503,2505],{"class":1946,"line":2080},[1944,2502,2083],{"class":2013},[1944,2504,2017],{"class":1957},[1944,2506,2088],{"class":1961},[1944,2508,2509,2511,2513,2515,2517,2519,2521,2523,2525,2527,2529,2531,2533],{"class":1946,"line":2091},[1944,2510,2094],{"class":1957},[1944,2512,2097],{"class":2013},[1944,2514,2017],{"class":1957},[1944,2516,1971],{"class":1957},[1944,2518,2104],{"class":1974},[1944,2520,1978],{"class":1957},[1944,2522,2109],{"class":1957},[1944,2524,2112],{"class":2013},[1944,2526,2017],{"class":1957},[1944,2528,1971],{"class":1957},[1944,2530,1918],{"class":1974},[1944,2532,1978],{"class":1957},[1944,2534,2123],{"class":1957},[1944,2536,2537,2539,2541,2543,2545,2547,2549,2551,2553,2555,2557,2559,2561],{"class":1946,"line":2126},[1944,2538,2094],{"class":1957},[1944,2540,2097],{"class":2013},[1944,2542,2017],{"class":1957},[1944,2544,1971],{"class":1957},[1944,2546,2137],{"class":1974},[1944,2548,1978],{"class":1957},[1944,2550,2109],{"class":1957},[1944,2552,2112],{"class":2013},[1944,2554,2017],{"class":1957},[1944,2556,1971],{"class":1957},[1944,2558,1922],{"class":1974},[1944,2560,1978],{"class":1957},[1944,2562,2123],{"class":1957},[1944,2564,2565,2567,2569,2571,2573,2575,2577,2579,2581,2583,2585,2587,2589],{"class":1946,"line":2156},[1944,2566,2094],{"class":1957},[1944,2568,2097],{"class":2013},[1944,2570,2017],{"class":1957},[1944,2572,1971],{"class":1957},[1944,2574,2167],{"class":1974},[1944,2576,1978],{"class":1957},[1944,2578,2109],{"class":1957},[1944,2580,2112],{"class":2013},[1944,2582,2017],{"class":1957},[1944,2584,1971],{"class":1957},[1944,2586,1925],{"class":1974},[1944,2588,1978],{"class":1957},[1944,2590,2123],{"class":1957},[1944,2592,2593,2595,2597,2599,2601,2603,2605,2607,2609,2611,2613,2615,2617],{"class":1946,"line":2186},[1944,2594,2094],{"class":1957},[1944,2596,2097],{"class":2013},[1944,2598,2017],{"class":1957},[1944,2600,1971],{"class":1957},[1944,2602,2197],{"class":1974},[1944,2604,1978],{"class":1957},[1944,2606,2109],{"class":1957},[1944,2608,2112],{"class":2013},[1944,2610,2017],{"class":1957},[1944,2612,1971],{"class":1957},[1944,2614,1928],{"class":1974},[1944,2616,1978],{"class":1957},[1944,2618,2123],{"class":1957},[1944,2620,2621,2623],{"class":1946,"line":2216},[1944,2622,2219],{"class":1961},[1944,2624,2027],{"class":1957},[1944,2626,2627,2629,2631,2633],{"class":1946,"line":2224},[1944,2628,2227],{"class":1957},[1944,2630,2230],{"class":1950},[1944,2632,1962],{"class":2233},[1944,2634,1981],{"class":1957},[1912,2636,2637,2639,2640,2643,2644,2646,2647,2649],{},[1916,2638,2394],{}," checks that the literal matches ",[1916,2641,2642],{},"StudioFieldDefinition"," without changing the inferred type of the object. The values stay as ",[1916,2645,2376],{},", not ",[1916,2648,2352],{},".",[1912,2651,2652],{},"Do not annotate the type directly:",[1934,2654,2656],{"className":1936,"code":2655,"language":1939,"meta":1940,"style":1940},"// Don't: this widens every literal to string\nexport const paddingField: StudioFieldDefinition = { /* ... */ };\n",[1916,2657,2658,2663],{"__ignoreMap":1940},[1944,2659,2660],{"class":1946,"line":1947},[1944,2661,2662],{"class":2295},"// Don't: this widens every literal to string\n",[1944,2664,2665,2667,2669,2672,2674,2676,2679,2681,2684],{"class":1946,"line":1984},[1944,2666,1994],{"class":1950},[1944,2668,1998],{"class":1997},[1944,2670,2671],{"class":1961}," paddingField",[1944,2673,2017],{"class":1957},[1944,2675,1962],{"class":2233},[1944,2677,2678],{"class":1957}," =",[1944,2680,1958],{"class":1957},[1944,2682,2683],{"class":2295}," /* ... */",[1944,2685,2686],{"class":1957}," };\n",[2324,2688,2690],{"id":2689},"pattern-2-reusable-option-lists","Pattern 2: reusable option lists",[1912,2692,2693],{},"When you want to share an options array (not a whole field), wrap it in a helper that enforces the non-empty tuple shape while preserving literals:",[1934,2695,2698],{"className":1936,"code":2696,"filename":2697,"language":1939,"meta":1940,"style":1940},"import type { FieldDefinitionSelectOption } from '@laioutr-core/core-types/fields';\n\nexport const defineSelectOptions = \u003C\n  const T extends readonly [FieldDefinitionSelectOption, ...FieldDefinitionSelectOption[]],\n>(\n  options: T,\n): [...T] => [...options];\n","shared-fields/defineSelectOptions.ts",[1916,2699,2700,2723,2727,2741,2773,2781,2792],{"__ignoreMap":1940},[1944,2701,2702,2704,2706,2708,2711,2713,2715,2717,2719,2721],{"class":1946,"line":1947},[1944,2703,1951],{"class":1950},[1944,2705,1954],{"class":1950},[1944,2707,1958],{"class":1957},[1944,2709,2710],{"class":1961}," FieldDefinitionSelectOption",[1944,2712,1965],{"class":1957},[1944,2714,1968],{"class":1950},[1944,2716,1971],{"class":1957},[1944,2718,1975],{"class":1974},[1944,2720,1978],{"class":1957},[1944,2722,1981],{"class":1957},[1944,2724,2725],{"class":1946,"line":1984},[1944,2726,1988],{"emptyLinePlaceholder":1987},[1944,2728,2729,2731,2733,2736,2738],{"class":1946,"line":1991},[1944,2730,1994],{"class":1950},[1944,2732,1998],{"class":1997},[1944,2734,2735],{"class":1961}," defineSelectOptions ",[1944,2737,2004],{"class":1957},[1944,2739,2740],{"class":1957}," \u003C\n",[1944,2742,2743,2746,2749,2752,2755,2758,2761,2763,2766,2768,2771],{"class":1946,"line":2010},[1944,2744,2745],{"class":1997},"  const",[1944,2747,2748],{"class":2233}," T",[1944,2750,2751],{"class":1997}," extends",[1944,2753,2754],{"class":1997}," readonly",[1944,2756,2757],{"class":1961}," [",[1944,2759,2760],{"class":2233},"FieldDefinitionSelectOption",[1944,2762,2109],{"class":1957},[1944,2764,2765],{"class":1957}," ...",[1944,2767,2760],{"class":2233},[1944,2769,2770],{"class":1961},"[]]",[1944,2772,2027],{"class":1957},[1944,2774,2775,2778],{"class":1946,"line":2030},[1944,2776,2777],{"class":1957},">",[1944,2779,2780],{"class":1961},"(\n",[1944,2782,2783,2786,2788,2790],{"class":1946,"line":2047},[1944,2784,2083],{"class":2785},"sHdIc",[1944,2787,2017],{"class":1957},[1944,2789,2748],{"class":2233},[1944,2791,2027],{"class":1957},[1944,2793,2794,2797,2799,2801,2804,2807,2810,2813,2815,2817,2820],{"class":1946,"line":2064},[1944,2795,2796],{"class":1961},")",[1944,2798,2017],{"class":1957},[1944,2800,2757],{"class":1961},[1944,2802,2803],{"class":1957},"...",[1944,2805,2806],{"class":2233},"T",[1944,2808,2809],{"class":1961},"] ",[1944,2811,2812],{"class":1997},"=>",[1944,2814,2757],{"class":1961},[1944,2816,2803],{"class":1957},[1944,2818,2819],{"class":1961},"options]",[1944,2821,1981],{"class":1957},[1912,2823,2824,2825,2828,2829,2832],{},"The ",[1916,2826,2827],{},"const T"," modifier tells TypeScript to keep the literal types. The function returns a fresh array, so callers can assign it directly to a field's ",[1916,2830,2831],{},"options"," and mutations cannot corrupt the shared export.",[1934,2834,2837],{"className":1936,"code":2835,"filename":2836,"language":1939,"meta":1940,"style":1940},"import { defineSelectOptions } from './defineSelectOptions';\n\nexport const buttonVariantOptions = defineSelectOptions([\n  { label: 'Primary', value: 'primary' },\n  { label: 'Secondary', value: 'secondary' },\n  { label: 'Tertiary', value: 'tertiary' },\n]);\n","shared-fields/buttonVariant.ts",[1916,2838,2839,2861,2865,2882,2913,2943,2973],{"__ignoreMap":1940},[1944,2840,2841,2843,2845,2848,2850,2852,2854,2857,2859],{"class":1946,"line":1947},[1944,2842,1951],{"class":1950},[1944,2844,1958],{"class":1957},[1944,2846,2847],{"class":1961}," defineSelectOptions",[1944,2849,1965],{"class":1957},[1944,2851,1968],{"class":1950},[1944,2853,1971],{"class":1957},[1944,2855,2856],{"class":1974},"./defineSelectOptions",[1944,2858,1978],{"class":1957},[1944,2860,1981],{"class":1957},[1944,2862,2863],{"class":1946,"line":1984},[1944,2864,1988],{"emptyLinePlaceholder":1987},[1944,2866,2867,2869,2871,2874,2876,2879],{"class":1946,"line":1991},[1944,2868,1994],{"class":1950},[1944,2870,1998],{"class":1997},[1944,2872,2873],{"class":1961}," buttonVariantOptions ",[1944,2875,2004],{"class":1957},[1944,2877,2847],{"class":2878},"s2Zo4",[1944,2880,2881],{"class":1961},"([\n",[1944,2883,2884,2887,2889,2891,2893,2896,2898,2900,2902,2904,2906,2909,2911],{"class":1946,"line":2010},[1944,2885,2886],{"class":1957},"  {",[1944,2888,2097],{"class":2013},[1944,2890,2017],{"class":1957},[1944,2892,1971],{"class":1957},[1944,2894,2895],{"class":1974},"Primary",[1944,2897,1978],{"class":1957},[1944,2899,2109],{"class":1957},[1944,2901,2112],{"class":2013},[1944,2903,2017],{"class":1957},[1944,2905,1971],{"class":1957},[1944,2907,2908],{"class":1974},"primary",[1944,2910,1978],{"class":1957},[1944,2912,2123],{"class":1957},[1944,2914,2915,2917,2919,2921,2923,2926,2928,2930,2932,2934,2936,2939,2941],{"class":1946,"line":2030},[1944,2916,2886],{"class":1957},[1944,2918,2097],{"class":2013},[1944,2920,2017],{"class":1957},[1944,2922,1971],{"class":1957},[1944,2924,2925],{"class":1974},"Secondary",[1944,2927,1978],{"class":1957},[1944,2929,2109],{"class":1957},[1944,2931,2112],{"class":2013},[1944,2933,2017],{"class":1957},[1944,2935,1971],{"class":1957},[1944,2937,2938],{"class":1974},"secondary",[1944,2940,1978],{"class":1957},[1944,2942,2123],{"class":1957},[1944,2944,2945,2947,2949,2951,2953,2956,2958,2960,2962,2964,2966,2969,2971],{"class":1946,"line":2047},[1944,2946,2886],{"class":1957},[1944,2948,2097],{"class":2013},[1944,2950,2017],{"class":1957},[1944,2952,1971],{"class":1957},[1944,2954,2955],{"class":1974},"Tertiary",[1944,2957,1978],{"class":1957},[1944,2959,2109],{"class":1957},[1944,2961,2112],{"class":2013},[1944,2963,2017],{"class":1957},[1944,2965,1971],{"class":1957},[1944,2967,2968],{"class":1974},"tertiary",[1944,2970,1978],{"class":1957},[1944,2972,2123],{"class":1957},[1944,2974,2975,2978],{"class":1946,"line":2064},[1944,2976,2977],{"class":1961},"])",[1944,2979,1981],{"class":1957},[1912,2981,2982],{},"Then use it in any field:",[1934,2984,2986],{"className":1936,"code":2985,"language":1939,"meta":1940,"style":1940},"{\n  type: 'select',\n  name: 'variant',\n  label: 'Variant',\n  options: buttonVariantOptions,\n}\n",[1916,2987,2988,2993,3007,3022,3037,3048],{"__ignoreMap":1940},[1944,2989,2990],{"class":1946,"line":1947},[1944,2991,2992],{"class":1957},"{\n",[1944,2994,2995,2997,2999,3001,3003,3005],{"class":1946,"line":1984},[1944,2996,2014],{"class":2233},[1944,2998,2017],{"class":1957},[1944,3000,1971],{"class":1957},[1944,3002,2022],{"class":1974},[1944,3004,1978],{"class":1957},[1944,3006,2027],{"class":1957},[1944,3008,3009,3011,3013,3015,3018,3020],{"class":1946,"line":1991},[1944,3010,2033],{"class":2233},[1944,3012,2017],{"class":1957},[1944,3014,1971],{"class":1957},[1944,3016,3017],{"class":1974},"variant",[1944,3019,1978],{"class":1957},[1944,3021,2027],{"class":1957},[1944,3023,3024,3026,3028,3030,3033,3035],{"class":1946,"line":2010},[1944,3025,2050],{"class":2233},[1944,3027,2017],{"class":1957},[1944,3029,1971],{"class":1957},[1944,3031,3032],{"class":1974},"Variant",[1944,3034,1978],{"class":1957},[1944,3036,2027],{"class":1957},[1944,3038,3039,3041,3043,3046],{"class":1946,"line":2030},[1944,3040,2083],{"class":2233},[1944,3042,2017],{"class":1957},[1944,3044,3045],{"class":1961}," buttonVariantOptions",[1944,3047,2027],{"class":1957},[1944,3049,3050],{"class":1946,"line":2047},[1944,3051,3052],{"class":1957},"}\n",[1912,3054,3055,3056,3058,3059,2646,3062,2649],{},"The prop type for ",[1916,3057,3017],{}," will be ",[1916,3060,3061],{},"'primary' | 'secondary' | 'tertiary'",[1916,3063,2352],{},[2324,3065,3067],{"id":3066},"pattern-3-dynamic-factory-with-computed-name","Pattern 3: dynamic factory with computed name",[1912,3069,3070,3071,3074,3075,2017],{},"Sometimes the field's ",[1916,3072,3073],{},"name"," is derived from an argument. A visibility checkbox toggles another field; its name should be ",[1916,3076,3077],{},"${target}Visible",[1934,3079,3081],{"className":1936,"code":3080,"language":1939,"meta":1940,"style":1940},"visibilityField({ for: 'heading' })\n// => { type: 'checkbox', as: 'visibility', for: 'heading', name: 'headingVisible' }\n",[1916,3082,3083,3111],{"__ignoreMap":1940},[1944,3084,3085,3088,3091,3094,3097,3099,3101,3104,3106,3108],{"class":1946,"line":1947},[1944,3086,3087],{"class":2878},"visibilityField",[1944,3089,3090],{"class":1961},"(",[1944,3092,3093],{"class":1957},"{",[1944,3095,3096],{"class":2013}," for",[1944,3098,2017],{"class":1957},[1944,3100,1971],{"class":1957},[1944,3102,3103],{"class":1974},"heading",[1944,3105,1978],{"class":1957},[1944,3107,1965],{"class":1957},[1944,3109,3110],{"class":1961},")\n",[1944,3112,3113],{"class":1946,"line":1984},[1944,3114,3115],{"class":2295},"// => { type: 'checkbox', as: 'visibility', for: 'heading', name: 'headingVisible' }\n",[1912,3117,3118,3119,3122,3123,3126,3127,3130,3131,3133,3136,3137,2352,3140,3143,3144,3147],{},"The obvious implementation has two generic parameters: ",[1916,3120,3121],{},"ForKey extends string"," and ",[1916,3124,3125],{},"Name extends string = \\","${ForKey}Visible`",[1916,3128,3129],{},". **This does not work.** Inside a"," fields: ",[1944,3132,2803],{},[1916,3134,3135],{},"array, contextual typing widens","Name",[1916,3138,3139],{},"to",[1916,3141,3142],{},", and the resulting field's"," name",[1916,3145,3146],{},"property loses its literal type.","definitionToProps` then matches the visibility checkbox against fields it shouldn't, and prop types break in surprising ways.",[1912,3149,3150,3151,3154,3155,3157,3158,2017],{},"The fix: collapse the generics into a single ",[1916,3152,3153],{},"const Opts"," parameter and derive the resolved name ",[2346,3156,2383],{}," from ",[1916,3159,3160],{},"Opts",[1934,3162,3165],{"className":1936,"code":3163,"filename":3164,"language":1939,"meta":1940,"style":1940},"export const visibilityField = \u003C\n  const Opts extends {\n    for: string;\n    name?: string;\n    label?: string;\n    default?: boolean;\n  },\n>(\n  opts: Opts,\n) => {\n  type ResolvedName = Opts extends { name: string }\n    ? Opts['name']\n    : `${Opts['for']}Visible`;\n\n  const field: {\n    type: 'checkbox';\n    as: 'visibility';\n    for: Opts['for'];\n    name: ResolvedName;\n    label?: string;\n    default?: boolean;\n  } = {\n    type: 'checkbox',\n    as: 'visibility',\n    for: opts.for,\n    name: (opts.name ?? `${opts.for}Visible`) as ResolvedName,\n  };\n\n  if (opts.label !== undefined) field.label = opts.label;\n  if (opts.default !== undefined) field.default = opts.default;\n  return field;\n};\n","shared-fields/visibility.ts",[1916,3166,3167,3180,3191,3203,3215,3225,3237,3241,3247,3258,3267,3291,3310,3341,3345,3357,3374,3391,3412,3423,3434,3445,3455,3470,3485,3501,3544,3550,3555,3595,3631,3641],{"__ignoreMap":1940},[1944,3168,3169,3171,3173,3176,3178],{"class":1946,"line":1947},[1944,3170,1994],{"class":1950},[1944,3172,1998],{"class":1997},[1944,3174,3175],{"class":1961}," visibilityField ",[1944,3177,2004],{"class":1957},[1944,3179,2740],{"class":1957},[1944,3181,3182,3184,3187,3189],{"class":1946,"line":1984},[1944,3183,2745],{"class":1997},[1944,3185,3186],{"class":2233}," Opts",[1944,3188,2751],{"class":1997},[1944,3190,2007],{"class":1957},[1944,3192,3193,3196,3198,3201],{"class":1946,"line":1991},[1944,3194,3195],{"class":2013},"    for",[1944,3197,2017],{"class":1957},[1944,3199,3200],{"class":2233}," string",[1944,3202,1981],{"class":1957},[1944,3204,3205,3208,3211,3213],{"class":1946,"line":2010},[1944,3206,3207],{"class":2013},"    name",[1944,3209,3210],{"class":1957},"?:",[1944,3212,3200],{"class":2233},[1944,3214,1981],{"class":1957},[1944,3216,3217,3219,3221,3223],{"class":1946,"line":2030},[1944,3218,2263],{"class":2013},[1944,3220,3210],{"class":1957},[1944,3222,3200],{"class":2233},[1944,3224,1981],{"class":1957},[1944,3226,3227,3230,3232,3235],{"class":1946,"line":2047},[1944,3228,3229],{"class":2013},"    default",[1944,3231,3210],{"class":1957},[1944,3233,3234],{"class":2233}," boolean",[1944,3236,1981],{"class":1957},[1944,3238,3239],{"class":1946,"line":2064},[1944,3240,2308],{"class":1957},[1944,3242,3243,3245],{"class":1946,"line":2080},[1944,3244,2777],{"class":1957},[1944,3246,2780],{"class":1961},[1944,3248,3249,3252,3254,3256],{"class":1946,"line":2091},[1944,3250,3251],{"class":2785},"  opts",[1944,3253,2017],{"class":1957},[1944,3255,3186],{"class":2233},[1944,3257,2027],{"class":1957},[1944,3259,3260,3263,3265],{"class":1946,"line":2126},[1944,3261,3262],{"class":1961},") ",[1944,3264,2812],{"class":1997},[1944,3266,2007],{"class":1957},[1944,3268,3269,3271,3274,3276,3278,3280,3282,3284,3286,3288],{"class":1946,"line":2156},[1944,3270,2014],{"class":1997},[1944,3272,3273],{"class":2233}," ResolvedName",[1944,3275,2678],{"class":1957},[1944,3277,3186],{"class":2233},[1944,3279,2751],{"class":1997},[1944,3281,1958],{"class":1957},[1944,3283,3143],{"class":2013},[1944,3285,2017],{"class":1957},[1944,3287,3200],{"class":2233},[1944,3289,3290],{"class":1957}," }\n",[1944,3292,3293,3296,3298,3301,3303,3305,3307],{"class":1946,"line":2186},[1944,3294,3295],{"class":1957},"    ?",[1944,3297,3186],{"class":2233},[1944,3299,3300],{"class":2013},"[",[1944,3302,1978],{"class":1957},[1944,3304,3073],{"class":1974},[1944,3306,1978],{"class":1957},[1944,3308,3309],{"class":2013},"]\n",[1944,3311,3312,3315,3318,3320,3322,3324,3327,3329,3331,3333,3336,3339],{"class":1946,"line":2216},[1944,3313,3314],{"class":1957},"    :",[1944,3316,3317],{"class":1957}," `${",[1944,3319,3160],{"class":2233},[1944,3321,3300],{"class":1961},[1944,3323,1978],{"class":1957},[1944,3325,3326],{"class":1974},"for",[1944,3328,1978],{"class":1957},[1944,3330,2313],{"class":1961},[1944,3332,2227],{"class":1957},[1944,3334,3335],{"class":1974},"Visible",[1944,3337,3338],{"class":1957},"`",[1944,3340,1981],{"class":1957},[1944,3342,3343],{"class":1946,"line":2224},[1944,3344,1988],{"emptyLinePlaceholder":1987},[1944,3346,3348,3350,3353,3355],{"class":1946,"line":3347},15,[1944,3349,2745],{"class":1997},[1944,3351,3352],{"class":1961}," field",[1944,3354,2017],{"class":1957},[1944,3356,2007],{"class":1957},[1944,3358,3360,3363,3365,3367,3370,3372],{"class":1946,"line":3359},16,[1944,3361,3362],{"class":2013},"    type",[1944,3364,2017],{"class":1957},[1944,3366,1971],{"class":1957},[1944,3368,3369],{"class":1974},"checkbox",[1944,3371,1978],{"class":1957},[1944,3373,1981],{"class":1957},[1944,3375,3377,3380,3382,3384,3387,3389],{"class":1946,"line":3376},17,[1944,3378,3379],{"class":2013},"    as",[1944,3381,2017],{"class":1957},[1944,3383,1971],{"class":1957},[1944,3385,3386],{"class":1974},"visibility",[1944,3388,1978],{"class":1957},[1944,3390,1981],{"class":1957},[1944,3392,3394,3396,3398,3400,3402,3404,3406,3408,3410],{"class":1946,"line":3393},18,[1944,3395,3195],{"class":2013},[1944,3397,2017],{"class":1957},[1944,3399,3186],{"class":2233},[1944,3401,3300],{"class":2013},[1944,3403,1978],{"class":1957},[1944,3405,3326],{"class":1974},[1944,3407,1978],{"class":1957},[1944,3409,2313],{"class":2013},[1944,3411,1981],{"class":1957},[1944,3413,3415,3417,3419,3421],{"class":1946,"line":3414},19,[1944,3416,3207],{"class":2013},[1944,3418,2017],{"class":1957},[1944,3420,3273],{"class":2233},[1944,3422,1981],{"class":1957},[1944,3424,3426,3428,3430,3432],{"class":1946,"line":3425},20,[1944,3427,2263],{"class":2013},[1944,3429,3210],{"class":1957},[1944,3431,3200],{"class":2233},[1944,3433,1981],{"class":1957},[1944,3435,3437,3439,3441,3443],{"class":1946,"line":3436},21,[1944,3438,3229],{"class":2013},[1944,3440,3210],{"class":1957},[1944,3442,3234],{"class":2233},[1944,3444,1981],{"class":1957},[1944,3446,3448,3451,3453],{"class":1946,"line":3447},22,[1944,3449,3450],{"class":1957},"  }",[1944,3452,2678],{"class":1957},[1944,3454,2007],{"class":1957},[1944,3456,3458,3460,3462,3464,3466,3468],{"class":1946,"line":3457},23,[1944,3459,3362],{"class":2013},[1944,3461,2017],{"class":1957},[1944,3463,1971],{"class":1957},[1944,3465,3369],{"class":1974},[1944,3467,1978],{"class":1957},[1944,3469,2027],{"class":1957},[1944,3471,3473,3475,3477,3479,3481,3483],{"class":1946,"line":3472},24,[1944,3474,3379],{"class":2013},[1944,3476,2017],{"class":1957},[1944,3478,1971],{"class":1957},[1944,3480,3386],{"class":1974},[1944,3482,1978],{"class":1957},[1944,3484,2027],{"class":1957},[1944,3486,3488,3490,3492,3495,3497,3499],{"class":1946,"line":3487},25,[1944,3489,3195],{"class":2013},[1944,3491,2017],{"class":1957},[1944,3493,3494],{"class":1961}," opts",[1944,3496,2649],{"class":1957},[1944,3498,3326],{"class":1961},[1944,3500,2027],{"class":1957},[1944,3502,3504,3506,3508,3511,3514,3516,3518,3521,3523,3525,3527,3529,3531,3533,3535,3537,3540,3542],{"class":1946,"line":3503},26,[1944,3505,3207],{"class":2013},[1944,3507,2017],{"class":1957},[1944,3509,3510],{"class":2013}," (",[1944,3512,3513],{"class":1961},"opts",[1944,3515,2649],{"class":1957},[1944,3517,3073],{"class":1961},[1944,3519,3520],{"class":1957}," ??",[1944,3522,3317],{"class":1957},[1944,3524,3513],{"class":1961},[1944,3526,2649],{"class":1957},[1944,3528,3326],{"class":1961},[1944,3530,2227],{"class":1957},[1944,3532,3335],{"class":1974},[1944,3534,3338],{"class":1957},[1944,3536,3262],{"class":2013},[1944,3538,3539],{"class":1950},"as",[1944,3541,3273],{"class":2233},[1944,3543,2027],{"class":1957},[1944,3545,3547],{"class":1946,"line":3546},27,[1944,3548,3549],{"class":1957},"  };\n",[1944,3551,3553],{"class":1946,"line":3552},28,[1944,3554,1988],{"emptyLinePlaceholder":1987},[1944,3556,3558,3561,3563,3565,3567,3570,3573,3576,3578,3581,3583,3585,3587,3589,3591,3593],{"class":1946,"line":3557},29,[1944,3559,3560],{"class":1950},"  if",[1944,3562,3510],{"class":2013},[1944,3564,3513],{"class":1961},[1944,3566,2649],{"class":1957},[1944,3568,3569],{"class":1961},"label",[1944,3571,3572],{"class":1957}," !==",[1944,3574,3575],{"class":1957}," undefined",[1944,3577,3262],{"class":2013},[1944,3579,3580],{"class":1961},"field",[1944,3582,2649],{"class":1957},[1944,3584,3569],{"class":1961},[1944,3586,2678],{"class":1957},[1944,3588,3494],{"class":1961},[1944,3590,2649],{"class":1957},[1944,3592,3569],{"class":1961},[1944,3594,1981],{"class":1957},[1944,3596,3598,3600,3602,3604,3606,3609,3611,3613,3615,3617,3619,3621,3623,3625,3627,3629],{"class":1946,"line":3597},30,[1944,3599,3560],{"class":1950},[1944,3601,3510],{"class":2013},[1944,3603,3513],{"class":1961},[1944,3605,2649],{"class":1957},[1944,3607,3608],{"class":1961},"default",[1944,3610,3572],{"class":1957},[1944,3612,3575],{"class":1957},[1944,3614,3262],{"class":2013},[1944,3616,3580],{"class":1961},[1944,3618,2649],{"class":1957},[1944,3620,3608],{"class":1961},[1944,3622,2678],{"class":1957},[1944,3624,3494],{"class":1961},[1944,3626,2649],{"class":1957},[1944,3628,3608],{"class":1961},[1944,3630,1981],{"class":1957},[1944,3632,3634,3637,3639],{"class":1946,"line":3633},31,[1944,3635,3636],{"class":1950},"  return",[1944,3638,3352],{"class":1961},[1944,3640,1981],{"class":1957},[1944,3642,3644],{"class":1946,"line":3643},32,[1944,3645,3646],{"class":1957},"};\n",[1912,3648,3649,3650,3653,3654,3657,3658,3661],{},"The key is ",[1916,3651,3652],{},"type ResolvedName = Opts extends { name: string } ? Opts['name'] : \\","${Opts ",[1944,3655,3656],{},"'for'"," }Visible`",[1916,3659,3660],{},". The resolved name is computed from"," Opts`, not declared as a separate inferable generic. Contextual typing cannot widen what it cannot see.",[1912,3663,3664],{},"Use it inside a schema:",[1934,3666,3668],{"className":1936,"code":3667,"language":1939,"meta":1940,"style":1940},"schema: [\n  {\n    label: 'Content',\n    fields: [\n      { type: 'text', name: 'heading', label: 'Heading' },\n      visibilityField({ for: 'heading' }),\n      // ResolvedName is 'headingVisible' (literal)\n    ],\n  },\n],\n",[1916,3669,3670,3678,3682,3696,3704,3747,3772,3777,3783,3787],{"__ignoreMap":1940},[1944,3671,3672,3674,3676],{"class":1946,"line":1947},[1944,3673,2249],{"class":2233},[1944,3675,2017],{"class":1957},[1944,3677,2088],{"class":1961},[1944,3679,3680],{"class":1946,"line":1984},[1944,3681,2258],{"class":1957},[1944,3683,3684,3686,3688,3690,3692,3694],{"class":1946,"line":1991},[1944,3685,2263],{"class":2013},[1944,3687,2017],{"class":1957},[1944,3689,1971],{"class":1957},[1944,3691,1328],{"class":1974},[1944,3693,1978],{"class":1957},[1944,3695,2027],{"class":1957},[1944,3697,3698,3700,3702],{"class":1946,"line":2010},[1944,3699,2279],{"class":2013},[1944,3701,2017],{"class":1957},[1944,3703,2088],{"class":1961},[1944,3705,3706,3709,3711,3713,3715,3718,3720,3722,3724,3726,3728,3730,3732,3734,3736,3738,3740,3743,3745],{"class":1946,"line":2030},[1944,3707,3708],{"class":1957},"      {",[1944,3710,1954],{"class":2013},[1944,3712,2017],{"class":1957},[1944,3714,1971],{"class":1957},[1944,3716,3717],{"class":1974},"text",[1944,3719,1978],{"class":1957},[1944,3721,2109],{"class":1957},[1944,3723,3143],{"class":2013},[1944,3725,2017],{"class":1957},[1944,3727,1971],{"class":1957},[1944,3729,3103],{"class":1974},[1944,3731,1978],{"class":1957},[1944,3733,2109],{"class":1957},[1944,3735,2097],{"class":2013},[1944,3737,2017],{"class":1957},[1944,3739,1971],{"class":1957},[1944,3741,3742],{"class":1974},"Heading",[1944,3744,1978],{"class":1957},[1944,3746,2123],{"class":1957},[1944,3748,3749,3752,3754,3756,3758,3760,3762,3764,3766,3768,3770],{"class":1946,"line":2047},[1944,3750,3751],{"class":2878},"      visibilityField",[1944,3753,3090],{"class":1961},[1944,3755,3093],{"class":1957},[1944,3757,3096],{"class":2013},[1944,3759,2017],{"class":1957},[1944,3761,1971],{"class":1957},[1944,3763,3103],{"class":1974},[1944,3765,1978],{"class":1957},[1944,3767,1965],{"class":1957},[1944,3769,2796],{"class":1961},[1944,3771,2027],{"class":1957},[1944,3773,3774],{"class":1946,"line":2064},[1944,3775,3776],{"class":2295},"      // ResolvedName is 'headingVisible' (literal)\n",[1944,3778,3779,3781],{"class":1946,"line":2080},[1944,3780,2301],{"class":1961},[1944,3782,2027],{"class":1957},[1944,3784,3785],{"class":1946,"line":2091},[1944,3786,2308],{"class":1957},[1944,3788,3789,3791],{"class":1946,"line":2126},[1944,3790,2313],{"class":1961},[1944,3792,2027],{"class":1957},[2324,3794,3796],{"id":3795},"when-to-write-a-factory","When to write a factory",[1912,3798,3799],{},"A simple test: count the copies. One section: keep it inline. Two: probably still inline (the duplication is cheap, and the two sections might diverge). Three or more: promote to a factory.",[1912,3801,3802],{},"A second test: are the option values stable, or do you find yourself touching them in every section? Stable values that you copy unchanged are perfect factory candidates. Per-section tweaks suggest the field is component-specific, not shared.",[2324,3804,3806],{"id":3805},"detecting-widening-regressions","Detecting widening regressions",[1912,3808,3809,3810,3812,3813,3816,3817,3820],{},"If ",[1916,3811,2321],{}," suddenly produces a prop type like ",[1916,3814,3815],{},"string | boolean"," (or ",[1916,3818,3819],{},"string | number",") where you expected a single primitive, suspect a widened factory. The fastest check is to inspect the schema type directly:",[1934,3822,3824],{"className":1936,"code":3823,"language":1939,"meta":1940,"style":1940},"type Check = typeof definition['schema'][number]['fields'][number];\n//   ^? Inspect this in your editor\n",[1916,3825,3826,3863],{"__ignoreMap":1940},[1944,3827,3828,3831,3834,3836,3839,3842,3844,3846,3848,3851,3853,3856,3858,3861],{"class":1946,"line":1947},[1944,3829,3830],{"class":1997},"type",[1944,3832,3833],{"class":2233}," Check",[1944,3835,2678],{"class":1957},[1944,3837,3838],{"class":1957}," typeof",[1944,3840,3841],{"class":1961}," definition[",[1944,3843,1978],{"class":1957},[1944,3845,2249],{"class":1974},[1944,3847,1978],{"class":1957},[1944,3849,3850],{"class":1961},"][number][",[1944,3852,1978],{"class":1957},[1944,3854,3855],{"class":1974},"fields",[1944,3857,1978],{"class":1957},[1944,3859,3860],{"class":1961},"][number]",[1944,3862,1981],{"class":1957},[1944,3864,3865],{"class":1946,"line":1984},[1944,3866,3867],{"class":2295},"//   ^? Inspect this in your editor\n",[1912,3869,3870,3871,3873,3874,3876],{},"If a checkbox or select inside the array shows ",[1916,3872,2337],{}," instead of the literal you expect, a factory is widening. Switch it to the ",[1916,3875,3153],{}," pattern.",[2324,3878,3880],{"id":3879},"related","Related",[3882,3883,3884,3891],"ul",{},[3885,3886,3887,3890],"li",{},[3888,3889,486],"a",{"href":487}," for the canonical names and types that good candidates for factories follow.",[3885,3892,3893,3895],{},[3888,3894,534],{"href":535}," for the field types and properties these factories produce.",[3897,3898,3899],"style",{},"html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}",{"title":1940,"searchDepth":1984,"depth":1984,"links":3901},[3902,3903,3904,3905,3906,3907,3908],{"id":2326,"depth":1984,"text":2327},{"id":2387,"depth":1984,"text":2388},{"id":2689,"depth":1984,"text":2690},{"id":3066,"depth":1984,"text":3067},{"id":3795,"depth":1984,"text":3796},{"id":3805,"depth":1984,"text":3806},{"id":3879,"depth":1984,"text":3880},null,"When the same field shape appears in three or more sections, promote it to a factory function. The trick is keeping the literal types intact, so definitionToProps still produces narrow prop types.","md",{},{"title":3914,"description":3915},"Shared field factories | Laioutr","A pattern for reusing schema fields across sections and blocks without losing literal types.",{"loc":491,"lastmod":3917,"changefreq":3918,"priority":3919,"videos":3920,"images":3921},"2026-05-15","monthly",0.9,[],[],"XaJt741kC4iiKo9SMx134Qqnq_Rux2M4i6E6Rzt14f8",[3924,3926],{"title":486,"path":487,"stem":488,"description":3925,"children":-1},"A canonical sidebar layout and field-naming convention for every section and block. Same ordering and the same names everywhere, so editors learn one app and know them all.",{"title":494,"path":495,"stem":496,"description":3927,"children":-1},"A short checklist for writing component CSS in a Laioutr app. Restyleable from the outside, responsive without JavaScript, predictable in SSR.",1783259593922]