[{"data":1,"prerenderedAt":585},["ShallowReactive",2],{"navigation_docs":3,"-guide-drupal-cms":221,"-guide-drupal-cms-surround":580},[4,27,77,123,157,207],{"title":5,"icon":6,"path":7,"stem":8,"children":9,"page":26},"Get started","majesticons:rocket-3-start-line","\u002Fget-started","1.get-started",[10,14,18,22],{"title":11,"path":12,"stem":13},"How it works","\u002Fget-started\u002Fhow-it-works","1.get-started\u002F10.how-it-works",{"title":15,"path":16,"stem":17},"Play online","\u002Fget-started\u002Fplay-online","1.get-started\u002F20.play-online",{"title":19,"path":20,"stem":21},"Create a new project","\u002Fget-started\u002Fcreate-new-project","1.get-started\u002F30.create-new-project",{"title":23,"path":24,"stem":25},"First steps","\u002Fget-started\u002Ffirst-steps","1.get-started\u002F40.first-steps",false,{"title":28,"icon":29,"path":30,"stem":31,"children":32,"page":26},"Guide","mdi:book-open-page-variant-outline","\u002Fguide","2.guide",[33,37,41,45,49,53,57,61,65,69,73],{"title":34,"path":35,"stem":36},"Customized API Output","\u002Fguide\u002Fcustomized-api-output","2.guide\u002F05.customized-api-output",{"title":38,"path":39,"stem":40},"Pages & Routing","\u002Fguide\u002Fpages-routing","2.guide\u002F10.pages-routing",{"title":42,"path":43,"stem":44},"Site layout & Menus","\u002Fguide\u002Fsite-layout-menus","2.guide\u002F20.site-layout-menus",{"title":46,"path":47,"stem":48},"Authentication","\u002Fguide\u002Fauthentication","2.guide\u002F40.authentication",{"title":50,"path":51,"stem":52},"Metatags & Local tasks","\u002Fguide\u002Fmetatags-local-tasks","2.guide\u002F50.metatags-local-tasks",{"title":54,"path":55,"stem":56},"Breadcrumbs & Messages","\u002Fguide\u002Fbreadcrumbs-messages","2.guide\u002F60.breadcrumbs-messages",{"title":58,"path":59,"stem":60},"Redirects","\u002Fguide\u002Fredirects","2.guide\u002F65.redirects",{"title":62,"path":63,"stem":64},"Editorial previews","\u002Fguide\u002Feditorial-previews","2.guide\u002F70.editorial-previews",{"title":66,"path":67,"stem":68},"Layout builder","\u002Fguide\u002Flayout-builder","2.guide\u002F80.layout-builder",{"title":70,"path":71,"stem":72},"Drupal Canvas","\u002Fguide\u002Fcanvas","2.guide\u002F90.canvas",{"title":74,"path":75,"stem":76},"Drupal CMS","\u002Fguide\u002Fdrupal-cms","2.guide\u002F95.drupal-cms",{"title":78,"icon":79,"path":80,"stem":81,"children":82,"page":26},"Advanced topics","bi:diagram-3","\u002Fadvanced-topics","3.advanced-topics",[83,87,91,95,99,103,107,111,115,119],{"title":84,"path":85,"stem":86},"Multi-frontend","\u002Fadvanced-topics\u002Fmulti-frontend","3.advanced-topics\u002F05.multi-frontend",{"title":88,"path":89,"stem":90},"Listings, Views","\u002Fadvanced-topics\u002Flistings-views","3.advanced-topics\u002F10.listings-views",{"title":92,"path":93,"stem":94},"Searches","\u002Fadvanced-topics\u002Fsearches","3.advanced-topics\u002F20.searches",{"title":96,"path":97,"stem":98},"JSON-API & GraphQL","\u002Fadvanced-topics\u002Fjsonapi-graphql","3.advanced-topics\u002F30.jsonapi-graphql",{"title":100,"path":101,"stem":102},"Caching","\u002Fadvanced-topics\u002Fcaching","3.advanced-topics\u002F40.caching",{"title":104,"path":105,"stem":106},"Error pages","\u002Fadvanced-topics\u002Ferror-pages","3.advanced-topics\u002F50.error-pages",{"title":108,"path":109,"stem":110},"Drupal forms","\u002Fadvanced-topics\u002Fdrupal-forms","3.advanced-topics\u002F60.drupal-forms",{"title":112,"path":113,"stem":114},"Site Templates","\u002Fadvanced-topics\u002Fsite-templates","3.advanced-topics\u002F65.site-templates",{"title":116,"path":117,"stem":118},"Block layout","\u002Fadvanced-topics\u002Fblock-layout","3.advanced-topics\u002F70.block-layout",{"title":120,"path":121,"stem":122},"Debugging API requests","\u002Fadvanced-topics\u002Fdebugging","3.advanced-topics\u002F80.debugging",{"title":124,"icon":125,"path":126,"stem":127,"children":128,"page":26},"Drupal","simple-icons:drupal","\u002Fdrupal","4.drupal",[129,133,137,141,145,149,153],{"title":130,"path":131,"stem":132},"Key modules","\u002Fdrupal\u002Fkey-modules","4.drupal\u002F10.key-modules",{"title":134,"path":135,"stem":136},"Custom elements","\u002Fdrupal\u002Fcustom-elements","4.drupal\u002F20.custom-elements",{"title":138,"path":139,"stem":140},"Routes","\u002Fdrupal\u002Froutes","4.drupal\u002F30.routes",{"title":142,"path":143,"stem":144},"Providing blocks","\u002Fdrupal\u002Fproviding-blocks","4.drupal\u002F40.providing-blocks",{"title":146,"path":147,"stem":148},"Custom Element Processors","\u002Fdrupal\u002Fcustom-element-processors","4.drupal\u002F50.custom-element-processors",{"title":150,"path":151,"stem":152},"Adding Drupal forms","\u002Fdrupal\u002Fadd-drupal-forms","4.drupal\u002F60.add-drupal-forms",{"title":154,"path":155,"stem":156},"Providing themes","\u002Fdrupal\u002Fthemes","4.drupal\u002F70.themes",{"title":158,"icon":159,"path":160,"stem":161,"children":162,"page":26},"Nuxt","simple-icons:nuxtdotjs","\u002Fnuxt","5.nuxt",[163,167,171,175,179,183,187,191,195,199,203],{"title":164,"path":165,"stem":166},"Introduction","\u002Fnuxt\u002Fintroduction","5.nuxt\u002F10.introduction",{"title":168,"path":169,"stem":170},"Setup","\u002Fnuxt\u002Fsetup","5.nuxt\u002F20.setup",{"title":172,"path":173,"stem":174},"Rendering Custom Elements","\u002Fnuxt\u002Frender-custom-elements","5.nuxt\u002F30.render-custom-elements",{"title":176,"path":177,"stem":178},"Default components","\u002Fnuxt\u002Fdefault-components","5.nuxt\u002F32.default-components",{"title":180,"path":181,"stem":182},"Composables","\u002Fnuxt\u002Fcomposables","5.nuxt\u002F35.composables",{"title":184,"path":185,"stem":186},"Custom Routes","\u002Fnuxt\u002Fcustom-routes","5.nuxt\u002F40.custom-routes",{"title":188,"path":189,"stem":190},"Page Layouts","\u002Fnuxt\u002Fpage-layouts","5.nuxt\u002F50.page-layouts",{"title":192,"path":193,"stem":194},"Component Previews","\u002Fnuxt\u002Fcomponent-previews","5.nuxt\u002F55.component-previews",{"title":196,"path":197,"stem":198},"Rendering modes","\u002Fnuxt\u002Frendering-modes","5.nuxt\u002F60.rendering-modes",{"title":200,"path":201,"stem":202},"Deployment options","\u002Fnuxt\u002Fdeployment","5.nuxt\u002F70.deployment",{"title":204,"path":205,"stem":206},"Resources","\u002Fnuxt\u002Fresources","5.nuxt\u002F90.resources",{"title":208,"icon":209,"path":210,"stem":211,"children":212,"page":26},"Deployment","solar:server-square-cloud-linear","\u002Fdeployment","6.deployment",[213,217],{"title":214,"path":215,"stem":216},"Deployment Strategies","\u002Fdeployment\u002Fdeployment-strategy","6.deployment\u002F10.deployment-strategy",{"title":218,"path":219,"stem":220},"Unified Hosting","\u002Fdeployment\u002Funified-hosting","6.deployment\u002F20.unified-hosting",{"id":222,"title":74,"body":223,"description":573,"extension":574,"links":575,"meta":576,"navigation":577,"path":75,"seo":578,"stem":76,"__hash__":579},"docs\u002F2.guide\u002F95.drupal-cms.md",{"type":224,"value":225,"toc":563},"minimark",[226,231,241,250,285,290,293,331,334,414,418,425,429,437,456,462,466,469,489,502,507,518,526,530,533,542,549,553,559],[227,228,230],"h1",{"id":229},"drupal-cms-with-lupus-decoupled","Drupal CMS with Lupus Decoupled",[232,233,234,240],"p",{},[235,236,74],"a",{"href":237,"rel":238},"https:\u002F\u002Fwww.drupal.org\u002Fproject\u002Fcms",[239],"nofollow"," is Drupal's user-friendly distribution aimed at marketers and content teams. Lupus Decoupled supports it via site templates, providing a fully decoupled setup out of the box.",[232,242,243,244,249],{},"The ",[235,245,248],{"href":246,"rel":247},"https:\u002F\u002Fgit.drupalcode.org\u002Fproject\u002Flupus_decoupled_starter",[239],"Lupus Decoupled Starter"," is a ready-to-use Drupal CMS site template that bundles:",[251,252,253,261,267,273],"ul",{},[254,255,256,260],"li",{},[257,258,259],"strong",{},"Drupal CMS base setup",": content types, editorial workflow, and other Drupal CMS defaults",[254,262,263,266],{},[257,264,265],{},"Lupus Decoupled Recipe",": core modules and configuration",[254,268,269,272],{},[257,270,271],{},"Lupus Decoupled Canvas",": Canvas visual editor integration",[254,274,275,278,279,284],{},[257,276,277],{},"Lupus CSR",": client-side rendering theme with the ",[235,280,283],{"href":281,"rel":282},"https:\u002F\u002Fgithub.com\u002Fdrunomics\u002Flupus-decoupled-nuxt-starter",[239],"Nuxt Starter"," (set as default)",[286,287,289],"h2",{"id":288},"installation","Installation",[232,291,292],{},"Install the starter as a site template when setting up Drupal CMS, or apply it manually:",[294,295,300],"pre",{"className":296,"code":297,"language":298,"meta":299,"style":299},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","composer require drupal\u002Flupus_decoupled_starter\ndrush site-install ..\u002Frecipes\u002Flupus_decoupled_starter\n","bash","",[301,302,303,319],"code",{"__ignoreMap":299},[304,305,308,312,316],"span",{"class":306,"line":307},"line",1,[304,309,311],{"class":310},"sBMFI","composer",[304,313,315],{"class":314},"sfazB"," require",[304,317,318],{"class":314}," drupal\u002Flupus_decoupled_starter\n",[304,320,322,325,328],{"class":306,"line":321},2,[304,323,324],{"class":310},"drush",[304,326,327],{"class":314}," site-install",[304,329,330],{"class":314}," ..\u002Frecipes\u002Flupus_decoupled_starter\n",[232,332,333],{},"For a full local setup with DDEV:",[294,335,337],{"className":296,"code":336,"language":298,"meta":299,"style":299},"mkdir my-drupal-site && cd my-drupal-site\nddev config --project-type=drupal11 --docroot=web\nddev composer create-project drupal\u002Fcms\nddev composer require drupal\u002Flupus_decoupled_starter\ndrush site-install ..\u002Frecipes\u002Flupus_decoupled_starter\nddev launch\n",[301,338,339,358,372,386,397,406],{"__ignoreMap":299},[304,340,341,344,347,351,355],{"class":306,"line":307},[304,342,343],{"class":310},"mkdir",[304,345,346],{"class":314}," my-drupal-site",[304,348,350],{"class":349},"sMK4o"," &&",[304,352,354],{"class":353},"s2Zo4"," cd",[304,356,357],{"class":314}," my-drupal-site\n",[304,359,360,363,366,369],{"class":306,"line":321},[304,361,362],{"class":310},"ddev",[304,364,365],{"class":314}," config",[304,367,368],{"class":314}," --project-type=drupal11",[304,370,371],{"class":314}," --docroot=web\n",[304,373,375,377,380,383],{"class":306,"line":374},3,[304,376,362],{"class":310},[304,378,379],{"class":314}," composer",[304,381,382],{"class":314}," create-project",[304,384,385],{"class":314}," drupal\u002Fcms\n",[304,387,389,391,393,395],{"class":306,"line":388},4,[304,390,362],{"class":310},[304,392,379],{"class":314},[304,394,315],{"class":314},[304,396,318],{"class":314},[304,398,400,402,404],{"class":306,"line":399},5,[304,401,324],{"class":310},[304,403,327],{"class":314},[304,405,330],{"class":314},[304,407,409,411],{"class":306,"line":408},6,[304,410,362],{"class":310},[304,412,413],{"class":314}," launch\n",[286,415,417],{"id":416},"first-steps","First Steps",[232,419,420,421,424],{},"After installation, navigate to ",[257,422,423],{},"Content > Pages"," in the Drupal admin to find the provided demo content. Open a page, review it, and try editing it with the Canvas visual page builder to get familiar with the setup.",[286,426,428],{"id":427},"client-side-rendering-csr","Client-Side Rendering (CSR)",[232,430,431,432,436],{},"The starter uses ",[235,433,277],{"href":434,"rel":435},"https:\u002F\u002Fwww.drupal.org\u002Fproject\u002Flupus_csr",[239]," (Client-Side Rendering) as the default theme. This means:",[251,438,439,442,449],{},[254,440,441],{},"The frontend is pre-built and served directly from Drupal, with no separate frontend server needed",[254,443,444,445,448],{},"The frontend JavaScript runs in the browser and fetches content from the CE API at ",[301,446,447],{},"\u002Fce-api\u002F..."," on the same origin, so no CORS configuration is required",[254,450,451,452,455],{},"This is ideal for getting started quickly, but ",[257,453,454],{},"not recommended for SEO-critical production sites"," (use SSR instead)",[232,457,458,459,461],{},"All Lupus Decoupled documentation applies regardless of whether you use CSR or SSR. For Nuxt rendering mode details, see ",[235,460,196],{"href":197},".",[286,463,465],{"id":464},"customizing-the-theme","Customizing the Theme",[232,467,468],{},"To customize the frontend, run a local frontend dev server and point Drupal to it during development:",[251,470,471,482],{},[254,472,473,474,477,478,481],{},"Go to ",[257,475,476],{},"Configuration → Lupus Decoupled Settings"," (",[301,479,480],{},"\u002Fadmin\u002Fconfig\u002Fservices\u002Flupus-decoupled",")",[254,483,484,485,488],{},"Set ",[257,486,487],{},"Frontend base URL"," to your dev server and enable frontend redirects",[232,490,491,492,477,495,498,499,461],{},"Pages and Canvas previews now render via the dev server. When adding new Canvas components or changing their props, go to ",[257,493,494],{},"Administration > Appearance > Components > External JS",[301,496,497],{},"\u002Fadmin\u002Fappearance\u002Fcomponent\u002Fextjs",") and press ",[257,500,501],{},"Update components",[503,504,506],"h3",{"id":505},"provide-an-updated-lupus-csr-theme","Provide an Updated Lupus CSR Theme",[232,508,509,510,513,514,461],{},"Once customization is done, generate a production build of your frontend and configure Lupus CSR to serve it via ",[301,511,512],{},"\u002Fadmin\u002Fappearance\u002Fsettings\u002Flupus_csr",". For sub-theme packaging, see ",[235,515,517],{"href":516},"\u002Fdrupal\u002Fthemes#creating-a-sub-theme","Creating a Sub-Theme",[232,519,520,521,461],{},"For detailed instructions for the Nuxt-based default theme, see ",[235,522,525],{"href":523,"rel":524},"https:\u002F\u002Fgit.drupalcode.org\u002Fproject\u002Flupus_csr\u002F-\u002Fblob\u002F1.x\u002Fexamples\u002Fnuxt-starter\u002FCUSTOMIZING.md?ref_type=heads",[239],"CUSTOMIZING.md",[286,527,529],{"id":528},"switching-to-server-side-rendering","Switching to Server-Side Rendering",[232,531,532],{},"To move from CSR to SSR:",[534,535,536,539],"ol",{},[254,537,538],{},"Set up a separate frontend server",[254,540,541],{},"Configure the Lupus Decoupled frontend URL to point to your frontend server and enable the frontend redirect",[232,543,544,545,548],{},"Refer to ",[235,546,547],{"href":215},"Deployment strategies"," for options.",[286,550,552],{"id":551},"creating-new-site-templates","Creating New Site Templates",[232,554,555,556,558],{},"The Lupus Decoupled Starter is designed to serve as a template for building new Drupal CMS site templates. See the ",[235,557,112],{"href":113}," page for guidance.",[560,561,562],"style",{},"html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}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 .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}",{"title":299,"searchDepth":321,"depth":321,"links":564},[565,566,567,568,571,572],{"id":288,"depth":321,"text":289},{"id":416,"depth":321,"text":417},{"id":427,"depth":321,"text":428},{"id":464,"depth":321,"text":465,"children":569},[570],{"id":505,"depth":374,"text":506},{"id":528,"depth":321,"text":529},{"id":551,"depth":321,"text":552},"Drupal CMS is Drupal's user-friendly distribution aimed at marketers and content teams. Lupus Decoupled supports it via site templates, providing a fully decoupled setup out of the box.","md",null,{},true,{"title":74,"description":573},"dxyxyqBBoEMMAqVY_a4yepaNCkR9CDymdbLjrbu8rEQ",[581,583],{"title":70,"path":71,"stem":72,"description":582,"children":-1},"Drupal Canvas is Drupal's modern page builder (docs). When paired with Lupus Decoupled, Canvas becomes a powerful decoupled page builder that supports varying frontend frameworks.",{"title":84,"path":85,"stem":86,"description":584,"children":-1},"Thanks to the component-oriented decoupling of Lupus Decoupled Drupal, it's really easy to connect a frontend of choice!",1776084716269]