The GOV.UK Design System is an official design framework produced by the UK Government and defines best practices and rules that must be followed to ensure that your code base is GDS Compliant.
You can find the guide at the GOV.UK Design System website.
If you just with to use the package as is direct from the repository then simply install the latest version of the NuGet Package GDS.Components using your favourite package manager.
After installing the package you will need to reference the package in your program.cs file
Add usings to allow references
using Microsoft.Extensions.FileProviders;
using GDS.Components;
Extend the services to allow the compiler to pull in all required references
builder.Services.AddControllersWithViews()
.AddRazorRuntimeCompilation(options =>
{
options.FileProviders.Add(new EmbeddedFileProvider(typeof(ResourceMarker).Assembly));
})
.AddMvcOptions(options =>
{
options.ModelBindingMessageProvider.SetValueMustNotBeNullAccessor(_ => "The field is required.");
});
In your project file you will need to add the following elements to ensure that all the client side files are imported
<ItemGroup>
<GdsCssContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/css/govuk.css" />
<GdsJsContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/js/gds.js" />
<GdsFontContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/css/assets/fonts/bold-affa96571d-v2.woff" />
<GdsFontContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/css/assets/fonts/light-f591b13f7d-v2.woff" />
<GdsFontContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/css/assets/fonts/light-94a07e06a1-v2.woff2" />
<GdsFontContent Include="$(NuGetPackageRoot)gds.components/*/contentFiles/any/any/wwwroot/lib/gds/dist/css/assets/fonts/bold-b542beb274-v2.woff2" />
</ItemGroup>
You will also need to add a target reference to regenerate files on build
<Target Name="CopyGdsContentFiles" AfterTargets="Build">
<MakeDir Directories="$(ProjectDir)wwwroot/lib/gds/dist/css" />
<MakeDir Directories="$(ProjectDir)wwwroot/lib/gds/dist/js" />
<MakeDir Directories="$(ProjectDir)wwwroot/lib/gds/dist/css/assets/fonts" />
<Copy SourceFiles="@(GdsCssContent)" DestinationFolder="$(ProjectDir)wwwroot/lib/gds/dist/css" SkipUnchangedFiles="true" />
<Copy SourceFiles="@(GdsJsContent)" DestinationFolder="$(ProjectDir)wwwroot/lib/gds/dist/js" SkipUnchangedFiles="true" />
<Copy SourceFiles="@(GdsFontContent)" DestinationFolder="$(ProjectDir)wwwroot/lib/gds/dist/css/assets/fonts" SkipUnchangedFiles="true" />
</Target>
After making any changes to the library, all changes and new components must have full unit tests written. Once all code is covered and tests are passing you can now build and package the project. You must increase the Version - this is normally using the minor increment unless there are major changes.
<PropertyGroup>
<TargetFramework>net8.0</TargetFramework>
<ImplicitUsings>enable</ImplicitUsings>
<Nullable>enable</Nullable>
<AssemblyName>GDS.Components</AssemblyName>
<Title>Dot Net GDS Components</Title>
<Description>Shared user controls and view models for GDS Framework in ASP.NET MVC.</Description>
<PackageId>GDS.Components</PackageId>
<GeneratePackageOnBuild>false</GeneratePackageOnBuild>
<RootNamespace>GDS.Components</RootNamespace>
<Version>1.0.0</Version>
</PropertyGroup>