smores-react
is a collection of React
components that conform to Marshmallow's Design System - "S'mores".
$ yarn add @mrshmllw/smores-react
# OR
$ npm install @mrshmllw/smores-react
When making changes and creating PR's we use semantic-releases which make use of conventional-commits.
So to ensure our CHANGELOG.md is updated automatically and gets the changes we have made, we just need to name our PR's following this convention (casing matters): e.g
- patch - fix(OPTIONAL bugfix-reference): some bugfix
- minor - feat(OPTIONAL feature-reference): some feature
- major - BREAKING CHANGE: some breaking change
Only the following branches are supported for release:
main
feature/*
chore/*
fix/*
Before releasing, you may want to see the changes that will be included in the next version deployed on NPM, you can do so by:
- Goto our github workflows
- Click
Preview Bump and Publish
- Press
Run workflow
and select themain
branch. - Wait for the
Generate preview CHANGELOG.md
and look at the results!
When you're happy with your changes, you can release & publish your changes to NPM in one fell swoop by:
- Goto our github workflows
- Click
Bump and Publish
- Press
Run workflow
and select themain
branch. - Wait for release!
Note: this workflow will fail if the package version is already on the latest, so you dont have to worry about deploying the same changes multiple times.
Not too different to your usual workflow!
- Checkout a new branch with the prefix
(feature|chore|fix)/<your-branch-name>
e.g.feature/awesome-new-feature
- Open a PR and create your changes as normal using semantic-commits!
- Goto our github workflows
- Click
Bump and Publish
orPreview Bump and Publish
- Press
Run workflow
and select<your-full-branch-name>
branch. - Wait for release!
- This can be done multiple times and it will increment your pre-release package version!
- When you're happy with the changes, simply squash and merge the PR and release
main
!
To run Smores in dev mode follow the below instructions on installing and using Yalc to link up your project repo with Smores.
Install yalc on a global level by running
npm i yalc -g
This only needs to be installed once.
To run Smores in dev mode :
- Make desired changes in Smores repo
- On your Smores branch run
yalc publish
This will copy all the files that should be published into a remote NPM registry
In your project repo (not Smores e.g customer portal/sign up flow etc) run
yalc add @mrshmllw/smores-react
this will copy the current version from the store to your project’s .yalc folder and inject a file: .yalc/@mrshmllw/smores-react dependency into package.json
Every time you make changes in Smores and you wan’t to see it in local
run
yalc publish —private
In your project folder to see your Smores changes run the below to see the changes
yalc update
When you’ve finished deving run the below in your project folder to remove all packages linked
yalc remove --all
- Accordion
- ActionDropdown
- Banner
- Box
- BrandCard
- Button
- Card
- CheckBox
- CheckBoxGroup
- Chip
- Datepicker
- Divider
- Dropdown
- Emoji
- Icon
- IconStrict
- IconWrapper
- LabelledText
- Link
- Loader
- Logo
- Modal
- NumberInput
- Pagination
- RadioButton
- RadioGroup
- RichText
- RichTextEditor
- Row
- SearchInput
- Snackbar
- SupportMessage
- Table
- Tag
- Text
- Textarea
- TextDateOfBirthInput
- TextInput
- Toggle
- Tooltip
import React from 'react';
import {Text, Button} from '@mrshmllw/smores-react';
const App = () => (
<>
<Text>Hey you</Text>
<Button
onClick={() => console.log('thanks for clicking :)')}
>
Click me!
</Button>
</>
);
MIT © Marshmallow