Helix (http://helix.sitecore.net) is a set of overall design principles and conventions for Sitecore development, put forth by Sitecore in hopes of providing the community a path toward standardized solution development.
As part of this principle there are expected file system and Visual Studio Solution structures that are to be used, which can be time intensive to setup. This script is meant to be a utility to ease this setup process.
To make adaption as easy as possible I've simplified setup to the following three steps for you:
- Open PowerShell command prompt as Admin.
- Change the directory to a working/temporary location
- Enter the following
(Invoke-WebRequest -UseBasicParsing -Uri https://raw.githubusercontent.com/gillissm/TheCodeAttic.Helix.PowerShellProjectCreator/master/ProjectCreatorEasyInstall.ps1).Content | Out-File "ProjectCreatorEasyInstall.ps1"
.\ProjectCreatorEasyInstall.ps1
As an alternate to the above, you can pull the script from GitHub and run load it into Package Manager Console each time you need it with the following steps:
- Download (https://github.com/gillissm/TheCodeAttic.Helix.PowerShellProjectCreator/blob/master/Helix.ProjectCreator.psm1) to your local system in the manner that suits your workflow the best.
- Each time you wish to leverage the module in Visual Studio you will need to enter the following in the Package Manager Console
Import-Module "C:\MyFiles\THelix.ProjectCreator.psm1"
OR you could download and configure the module manually each time (this is what ProjectCreatorEasyInstall.ps1 does for you.)
- Go to C:\Users<CURRENT USER DIRECTORY>\Documents\WindowsPowerShell\Modules
- Create a new folder called "Helix.ProjectCreator"
- Download (https://github.com/gillissm/TheCodeAttic.Helix.PowerShellProjectCreator/blob/master/Helix.ProjectCreator.psm1) into the above directory
- Go up a level in the file system, should be at C:\Users<CURRENT USER DIRECTORY>\Documents\WindowsPowerShell\
- Open (or create) NuGet_profile.ps1
- Add the following
Import-Module Helix.ProjectCreator
- Each time you run Visual Studio the module will be available to use in the Package Console Manager
Because the script leverages the native DTE Interface of Visual Studio is can be used to create new solutions, as well as modify existing solutions without any additional tweaks to the code.
The following will allow you to confirm that the module is accessible for usage. This check is most helpful the first time one has used it after leveraging the easy install script.
Get-Module Helix.ProjectCreator -ListAvailable
- Open Visual Studio as Admin
- Open the Package Manager Console
- Create a new Helix based solution by running Invoke-VisualStudioSolution
- Include the parameter '-SolutionName', this will be the name of the VS solution as well the name given to the directory create for the solution
- Include the parameter '-DirectoryPath', this is the fully qualified path to the parent directory the solution should be created at
Invoke-VisualStudioSolution -SolutionName HelixAttic.Sample -DirectoryPath C:\Code\git-TheCodeAttic\
- Open Visual Studio as Admin
- Open your Solution
- Open the Package Manager Console
- Add new module by running Invoke-NewModule
- Set parameter -ModuleName to the name of the module/component, this should NOT include the full namespace, as this will be generated automatcially based on solution name
- Select a value for -Layer from the provided list (Feature, Foundation, Project) depending on need
- Optionally include the -UseUnicorn or -UseTDS flag to setup the corresponding serialization requirements
Invoke-NewModule -ModuleName PageContent -Layer Feature -UseUnicorn
In addition to creating a project with folders and NuGet references, the script can add a blank or empty project with the given name to the solution by including the flag -CreateEmptyProject.
Invoke-NewModule -ModuleName PlaceHolder -Layer Foundation -CreateEmptyProject
See the module file for a listing of all optional parameters, including the ability to set a specific Sitecore version.
Call this to setup Unicorn or TDS project for a given module. When calling, be sure to include the full project name (with namespace).
Invoke-SerializationProject -ProjectName HelixAttic.Sample.Foundation.PlaceHolder -UseUnicorn
Call this to add an empty project to the solution for a layer, this is the same as calling Invoke-NewModule with the 'CreateEmptyProject' flag.
Now go create some awesome Sitecore code with confidence!