npm install
npm run serve
npm run build:lib
npm run test:unit
npm run lint
- Make sure you are logged into the nanonpm npm account.
npm login
-
Update the package version in the
package.json
file under theversion
field. We are using semantic versioning. -
Update the changelog file with the changes you have made.
-
Run the deploy command - this will run 2 commands synchronously: i) npm run build:lib (builds the project) ii) npm publish (published to npm)
npm run deploy
npm run new
This will run a script prompting you for:
- The name of the component in Camelcase ie. MyNewComponent
- The section you would like MyNewComponent to sit under in the Storybookleft menu ie. Forms
It will then create a Vue component, a .stories.js file, an indes.ts (for export) and a types.ts file. These files will be populated with the basic content to allow for quick and easy scaffolding of new components. Upon running this command you should see the new component hotreloaded into Storybook.
When adding new SVG icons, you can use either of the following methods:
- Drop the SVG into the Icons/icons/svg folder ie. Icons/icons/svg/House.svg
- Create a Vue component file for the icon (use the exaxct same name) ie. Icons/icons/House.vue
- Add the SVG into the Vue component template
- Update the Icon name list export in Icons/icons/index.ts to have that icon name (this is used to output the icon in Storybook and for icon name validation).
- Drop the SVG into the Icons/icons/svg folder
- Ensure the SVG only has the
<svg>...</svg>
as the top level node. Remove andy<xml ...>
node - Run
npm run ico
- Look for any output errors in terminal - if there's a file name with a space, or the xml tag remains in the SVG file it won't compile properly.
- You can now add "Full Stack Developer" to your resume ;)
Photon v2 components are a new system of styling photon components.
You can start the local build by running npm run sb
and then navigating to the Photon v2
section of the storybook.
If you want to run it with external theme files you can run npm run sb:external
and then navigate to the Photon v2
section of the storybook.
In order to get the external theme files to load you need to add the the absolute path to your branding folder for onboarding
into the .env
file.
Make sure it does not have a trailing slash /
at the end.
When you next start the storybook application it will load and pick the theme files from your theme folders.
To learn more about the photon v2 system check the documentation bellow creating photon v2 components
This project uses semantic versioning and semantic release to automatically publish new versions to npm.
When you merge a PR into main
, semantic-release will automatically publish a new version to npm.