A1 Design System Migration
When to Use
- Migrating an Angular app from NDBX/old design system to One Allianz (A1) Design System
- Applying One Allianz theme (, , or )
- Replacing / with /
- Replacing info buttons with popovers to use the new
- Updating layout from center-aligned to left-aligned (A1 standard)
- Adjusting components, eyebrows and attention-color headlines
How to Apply Changes
- if css is required, add to the component's CSS file. If the component is standalone, add the CSS to the component's array in the decorator.
- write style definitions into components style file. Do not use inline styles in the HTML template.
IMPORTANT: Before starting, tell the user the skill version "0.1.3" and that it's in beta phase. This is important for tracking and future updates.
Step 1: Apply A1 Theme
Important: check if package
is installed.
- if not installed, do not try to install, do not ask the user to install and skip this step and continue with Step 2.
- if installed, continue with the Procedure as described below.
Procedure
- If theme is not specified, ask the user which theme they want: , , or .
- spacious for end customer-facing apps with more white space and larger touch targets
- compact for internal tools and dashboards where more information density is needed
- dense for data-heavy applications where maximum information density is required (e.g. tables, analytics)
- Run the schematic from the project root (where lives):
bash
ng g @allianz/ngx-brand-kit:apply-a1-theme --type=<THEME>
Step 2: Migrate Circle Toggles → Tiles
Stack: Angular standalone components, TypeScript,
Imports
ts
import { NxTileComponent, NxTileGroupComponent } from '@allianz/ng-aquila/tile';
If used in a Standalone Component, add the
NxTileComponent, NxTileGroupComponent
to the components
array.
Decision Rules
| Scenario | Action |
|---|
| not in a group | Multi-select → use nx-tile-group [value]="arrayOfValues"
|
| inside | Single-select → use nx-tile-group [value]="selectedValue"
|
| attribute present | Remove it; add <!-- TODO: revisit once toggle-button component is available -->
|
Selection / Forms Pattern
Before (checked-based):
html
<nx-circle-toggle-group>
<nx-circle-toggle
[checked]="sel==='a'"
value="a"
label="Label A"
icon="icon-name"
></nx-circle-toggle>
<nx-circle-toggle
[checked]="sel==='b'"
value="b"
label="Label B"
icon="icon-name"
></nx-circle-toggle>
</nx-circle-toggle-group>
After (value-based on group):
html
<nx-tile-group [value]="sel">
<nx-tile value="a" label="Label A" icon="icon-name"></nx-tile>
<nx-tile value="b" label="Label B" icon="icon-name"></nx-tile>
</nx-tile-group>
IMPORTANT: Do NOT put content inside
. Use only
,
, and
attributes.
Layout Rules
| Layout found | What to do |
|---|
| No wrapper, no layout CSS | Replace group directly; no extra layout needed |
| / / grid | Derive from lowest number: . Remove grid wrapper. |
| Custom CSS | Translate to on ; copy CSS only if auto-grid is insufficient |
| 2–3 tiles total | Wrap in (half-width) |
For each occurrence found, output a short decision log: what was there, what you chose and why.
Step 3: Migrate Info Popups → new Info Icon Component
- Identify info buttons with popups: look for buttons (e.g. buttons with directive ) that trigger popovers and just have an info icon inside.
- Replace with : use the new component for consistent styling and behavior.
- Example:
html
<nx-info-icon
nxFormfieldAppendix
buttonAriaLabel="Additional information"
popoverDirection="bottom"
popoverWidth="300px"
>
<span>
This is an info icon with a popover. Click the icon to see additional information. Sadipscing
elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam
voluptua.
</span>
</nx-info-icon>
And the corresponding import:
ts
import { NxInfoIconComponent } from '@allianz/ng-aquila/info-icon';
If used in a Standalone Component, add the
to the components
array.
- Important: Do not change buttons inside Formfields (). Only replace standalone info buttons that trigger popovers.
Step 4: Update Layout — Left Alignment
A1 uses left-alignment throughout for accessibility and consistency.
Checklist
- Remove centering on rows: Change or remove → use or remove entirely.
- Remove text centering: Remove ,
style="text-align: center"
, and similar on headings and paragraphs.
- Bottom navigation buttons (Back / Next):
- Must be right-aligned ()
- Must be side-by-side (same , not stacked in separate rows)
- Must use sentence case ("Back", "Next") not ALL CAPS
- only accepts numbers — warning will break; use , or similar
- info on : breakpoints are defined as
nxCol="<tiny>, <small>, <medium>, <large>, <xlarge>, <2xlarge>, <3xlarge>"
- must be vertically centered within the row — if is used, add .
- Margins / padding: Remove , horizontal centering, and ensure content aligns to the left edge.
Vertical Spacing Adjustments
- Important: Skip this step if the is not installed and continue with below. The spacing values below rely on CSS variables from the A1 brand kit, so if it's not installed, leave spacing as-is.
- Find Dividers (, ,
nxCol="12" class="section-divider"
or similar) divider lines that span the full width of the page and add vertical spacing above and below them. Use var(--semantic-gap-all-static-1600)
for this spacing to ensure consistency with A1 design standards.
- Headlines that are used standalone (outside of other components) should have a spacing below them. Use the mapping below
- →
var(--semantic-gap-all-static-1200)
- →
var(--semantic-gap-all-static-1000)
- →
var(--semantic-gap-all-static-800)
- If the element underneath the headline has a top spacing (e.g. or ), remove it to avoid double spacing or subtract the headline spacing from it.
Headline Sizes
Hierarchy rule — applies after the mapping table and overrides it where needed:
The mapping table below is a starting point, not a final answer. After applying it, verify that the resulting sizes form a clear visual hierarchy on the page. If a primary section heading (e.g. an
that is the main title of a page section) maps to a small size like
or
,
override the mapped value to restore the hierarchy. A page with an
at
should use
for its primary
sections,
for sub-sections, and so on — regardless of what the old assignment was.
- if you find with type assignments (e.g. ), translate to attribute. For example, becomes
<h1 nxHeadline size="3xl">
. Ensure the main headline in uses for A1 consistency.
| old assignment | size attribute | use for |
|---|
| nxHeadline="page-bold-caps" | nxHeadline size="4xl" | huge page headlines, only for marketing pages, not for product UIs |
| nxHeadline="page" | nxHeadline size="3xl" | main page headlines |
| nxHeadline="section" | nxHeadline size="2xl" | section headlines |
| nxHeadline="subsection-large" | nxHeadline size="xl" | large subsection headlines |
| nxHeadline="subsection-medium" | nxHeadline size="l" | medium subsection headlines |
| nxHeadline="subsection-small" | nxHeadline size="m" | small subsection headlines |
| nxHeadline="subsection-xsmall" | nxHeadline size="s" | extra small subsection headlines |
After applying the table, check: does the result make sense in context? A primary
section heading should never end up at
just because the old code used
. Promote it to the correct level in the page hierarchy.
Step 5: Adjust Small Stages
5.1 Subline → Eyebrow
Move any
<p nxCopytext="large">Subline</p>
inside
to an eyebrow
above the
:
html
<nx-eyebrow size="s">Subline Text</nx-eyebrow>
<h1 nxHeadline size="3xl">...</h1>
Use the
eyebrow size for nxHeadline size 3xl and smaller. If the user wants a nxHeadline larger than 3xl, use
for the eyebrow.
ts
import { NxEyebrowComponent } from '@allianz/ng-aquila/eyebrow';
If used in a Standalone Component, add the
to the components
array.
5.2 Partial Headline Coloring (required)
Always wrap the most meaningful word or short phrase in the
with an attention-color span. This is a required A1 design standard for
headlines — do not skip it. Choose the word or phrase that carries the most semantic weight (the product, the action, or the subject — not filler words like "your" or "and").
html
<h1 nxHeadline size="3xl">Enter your <span [nx-attention-color]="'aqua'">property details</span></h1>
ts
import { NxAttentionColorComponent } from '@allianz/ng-aquila/text';
If used in a Standalone Component, add the
NxAttentionColorComponent
to the components
array.
5.3 Headline Size
- remove assignments to in HTML headline elements (e.g. ) and replace with
<h1 nxHeadline size="3xl">
for all small stage headlines. Ensure the main headline in uses for A1 consistency.
Migration Tracking
After completing each step, record the migration so adoption can be tracked across teams via GitHub search.
Project-level metadata in
After
Step 1 (theme applied), add an
key to
. After each subsequent step completes, append the step name to the
array:
json
"a1Migration": {
"skillVersion": "0.1.3",
"appliedAt": "YYYY-MM-DD",
"theme": "<spacious|compact|dense>",
"steps": ["theme"]
}
Append step names as they complete:
,
,
,
,
.
A fully migrated project looks like:
json
"a1Migration": {
"skillVersion": "0.1.3",
"appliedAt": "YYYY-MM-DD",
"theme": "<spacious|compact|dense>",
"steps": ["theme", "tiles", "info-icons", "layout", "small-stage"]
}
tracking of additional migration runs
If
already has an
key, add the steps to the array for steps that ran in the current session.