Wed Aug 21 2024 • ☕️☕️ 8 min read • you like my writing? Buy me a coffee
To get started with development we need to set up your local development environment for Sitecore XM Cloud, you clone the project repository from GitHub or Azure DevOps, install necessary packages, and connect to the XM Cloud preview endpoint. This involves creating a .env.local
file with environment variables, running npm install
to install dependencies, and starting the application locally with npm run start:connected
. Finally, you can view your application at http://localhost:3000/
to confirm the setup.
This is described in Set up your local development environment | Sitecore Documentation But along the way I would like to add some comments, and give some clarification.
Node.js is an essential part of our development setup. It’s a JavaScript runtime that allows us to run JavaScript code on our local machine, outside of a browser. For our project, we’ll be using Node.js to run scripts, manage dependencies, and start our local development server. To ensure compatibility, make sure you have the latest stable version of Node.js installed on your machine. You can download it from Node.js official website.
The installation of Node.js is a global installation, and if you work on multiple Node.js projects on the same computer I would advise to use a Node version manager. A Node version manager allows you to install and switch between multiple versions of Node.js, which can be very useful if different projects require different versions. the most well-known Node version manager is NVM. The documentation on NVM can be found at nvm-sh/nvm: Node Version Manager - POSIX-compliant bash script to manage multiple active node.js versions (github.com).
If you want to install Node Version Manager (NVM) on Windows:
nvm --version
.Now, you can manage and switch between different versions of Node.js using NVM on Windows.
Note that the maintainer of NVM for Windows, Corey Butler, stopped development on NVM for Windows, and started work on Runtime, the successor to NVM for Windows. I personally still worked with the “old” version and could not find any details on how to install this Runtime thing.
Another player in this field is Schniz/fnm: 🚀 Fast and simple Node.js version manager, built in Rust (github.com). As colleagues work with this version I decided to try it out.
To prevent collision between Node version managers, I decided to first uninstall NVM and its installed Node versions.
The first step is to delete the Node.js versions managed by NVM for Windows:
nvm list
.nvm uninstall <version_number>
. Replace <version_number>
with the version you want to delete (e.g., nvm uninstall 18.16.0
).Repeat the uninstall command for each version you want to remove. This will delete the corresponding Node.js versions managed by NVM. As I installed some of my Node.js version with administrative rights, I needed to start my Command Prompt as administrator to uninstall them.
Next step is to uninstall NVM on Windows itself. To uninstall NVM on Windows:
Alternatively, you can manually delete the nvm
folder (usually located in C:\Program Files\nvm
or wherever you installed it) and remove the related environment variables.
Installation of FNM on Windows is simple:
winget install Schniz.fnm
Don’t forget to restart your shell after installation.
FNM needs some environment variables configured, as described in https://github.com/Schniz/fnm#shell-setup.
In PowerShell you can use the following command:
fnm env --use-on-cd --shell power-shell
Copy the output, execute notepad $profile
(create if the file does not exist yet) and paste the output to the end of this file.
Next step (as documented in the Sitecore documentation) is to use the latest Node.js LTS version. On Node.js — Run JavaScript Everywhere (nodejs.org) we can see this is version 20.16.0 at the time of writing.
![[image-20240816001326092.png]]
We can now type the following command to install and use Node.js version 20.16.0:
fnm use 20.16.0
Which asks you to install Node.js version 20.16.0 if not installed yet, and makes it the current version.
This all worked like a breeze, so my new Node version manager is from now on FNM!
For detailed documentation on how to use FNM have a look at fnm/docs/commands.md at master · Schniz/fnm (github.com).
Head over XM Cloud Deploy at https://deploy.sitecorecloud.io/. Under Projects select your project and environment, and select the Developer settings tab:
![[image-20240816005247952.png]]
On this Developer settings tab we find all required information.
As XM Cloud Deploy creates a GitHub repository based on sitecorelabs/xmcloud-foundation-head it is now time to have a look at the scaffolded codebase.
Although I normally do my development under Windows with WSL2, for this post I checked out the code under Windows. Reason: working with the Docker container for local development only works under Windows.
The clone command can be found under the Local development section:
C:\p> git clone https://github.com/svdoever/xmcloud-project-sergedemo
Cloning into 'xmcloud-project-sergedemo'...
remote: Enumerating objects: 338, done.
remote: Counting objects: 100% (338/338), done.
remote: Compressing objects: 100% (296/296), done.
remote: Total 338 (delta 8), reused 269 (delta 4), pack-reused 0 (from 0)
Receiving objects: 100% (338/338), 292.32 KiB | 893.00 KiB/s, done.
Resolving deltas: 100% (8/8), done.
C:\p>
After running these commands, you should have a local copy of the ‘xmcloud-project-sergedemo’ repository on your machine. You can now navigate into this directory to explore the codebase and start development.
I personally do all my development with Visual Studio Code, especially because I do most of my development in a front-end related stack using React, TypeScript, Next.js and other front-end related technology.
Open VSCode op the root folder of the repository, and open an integrated terminal. In the terminal window type:
npm install
The next step is to configure the front-end project with the correct environment variables.
Because we are configuring for development, set the context switcher to Preview, and copy the environment variables. Next create a new file src/sxastarter/.env.local
, and paste the environment variables in this file.
And finally execute:
npm run start:connected
If you navigate to http://localhost:3000 you will now see:
![[image-20240816013346736.png]]
Although we normally talk about the “rendering host” regarding the front-end application, in Sitecore XM Cloud, editing hosts and rendering hosts serve distinct yet complementary roles. The rendering host is the front-end application responsible for displaying content to end users. In contrast, the editing host is a similar application but tailored for content editing within tools like the Experience Editor. While both hosts share the same codebase, the editing host is not intended for live traffic. When setting up your environment, Sitecore provides a default editing host. It is not possible to only deploy the front-end application to this editing host.
For more technical details, visit the official Sitecore documentation.
We now have our site (front-end) running locally, using the content and pages as configured in XM Cloud. But if we create new components, we first need to deploy our complete solution to XM Cloud so the internal editing host is updated, and components become available within the Experience Editor, Pages, or for direct page composition in the Content Editor.
There are three ways to speed up this development cycle, so only the front-end solution needs to run, or needs to get deployed:
Discuss on Twitter • Edit on GitHub
This work is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License. You are free to share and adapt this work for non-commercial purposes, provided you give appropriate credit, provide a link to the license, and indicate if changes were made. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc/4.0/.
Personal blog by Serge van den Oever - als je maar lol hebt...
X: @svdoever
LinkedIn: Serge van den Oever - articles on LinkedIn
GitHub: svdoever
Technology Consultant @ Macaw
2021-2024 Sitecore Technology MVP