This is the baseapp-frontend monorepo that contains our apps and packages.
So, everything inside packages
is meant to be part of the @baseapp-frontend
packages, for instance:
- /packages
-/authentication
-/tsconfig
In that case, both authentication
and tsconfig
are unique packages, but they all belong to the @baseapp-frontend
organization.
If one of the apps wants to consume any package feature, we could simply add that package as a dependency like this:
"dependencies": {
"@baseapp-frontend/authentication": "*",
...
},
And then just import the feature needed:
import { useUser } from '@baseapp-frontend/authentication'
export default function Docs() {
const {user} = useUser()
return (
<div>
<h1>Find User</h1>
<p>{user.firstName}<p>
</div>
)
}
authentication
: includes authentication modules such aslogin
,signup
,reset password
,multifactor authentication
and more.config
: includes reusable configurations foreslint
,prettier
andjest
.components
: includes BaseApp modules such ascomments
,notifications
,messages
and more.design-system-mui
: defines ourdesign system configuration
(e.g. color pallete, typography, spacings, etc). It also shares reusablecomponents
that make up the design system as a whole.docs
: an app to document some packages's features.graphql
: includesGraphQL
's configurations and utilities.provider
: includes provider of different kinds that have "use client" directive on top.test
: extendsReact Testing Library
features and export some util functions, mocks and test configurations.tsconfig
: reusabletypescript configs
.utils
: includesconstants
,functions
,hooks
andtypes
that are generic enough to be reused between apps and packages.
This step is optional but it is highly suggested you use NVM.
Installation instructions can be found here: https://github.com/nvm-sh/nvm#installing-and-updating
Once installed run:
nvm use
This repository uses pnpm
for package management. Ensure you have it installed:
To install all dependencies for apps and packages, run the following command at the root of the repository:
pnpm install
To build all apps and packages, run the following command:
pnpm build
# build only the authentication package
pnpm build --filter=authentication
To develop all apps and packages, run the following command:
pnpm dev
This monorepo manages some dependencies using pnpm catalogs. As a rule of thumb, we often add dependencies to the catalogs that are reused across multiple packages, rather than arbitrarily adding dependencies to these lists. This approach ensures that shared dependencies are centrally managed and consistently applied across the codebase.
Cataloging reused dependencies also facilitates easier updates and reduces the chance of dependency mismatches between different parts of the monorepo.
Make sure to keep @baseapp-frontend's catalog
always up to date.
Before using a package from GitHub, remove its catalog entry. This is necessary because pnpm doesn't handle catalogs well when using non-published versions. To remove the catalogs for the desired package, run the following command:
# will replace catalogs for utils and authentication packages
pnpm replace-catalogs utils authentication
# will replace catalogs for all packages
pnpm replace-catalogs
To restore the catalog entries to their original state, run the following command:
# will restore catalogs for utils and authentication packages
pnpm restore-catalogs utils authentication
# will restore catalogs for all packages
pnpm restore-catalogs
This will update all package.json files to include catalog entries again.
If you need to install a package version that hasn't been published yet, follow the steps below. We use GitHub as the source for unpublished versions.
- Remove Catalog Entries:
Refer to the (Remove Catalog Entries)[https://github.com/silverlogic/baseapp-frontend/blob/master/README.md#remove-catalog-entries] section above to temporarily remove catalogs for the relevant packages.
- Commit and Push:
After making the change, commit and push your code. This makes it easy to undo once the package has been published.
git commit -m "Temporarily remove catalogs to use GitHub version"
- Copy the Commit Hash:
Push the code to GitHub and copy the last commit hash. You’ll need this hash to point your consumer app to the correct version of the package.
- Update Consumer App:
In the consumer app (the app that will use the non-published version), update the package entry to the GitHub source. Replace <commit-hash>
with the actual commit hash you copied:
"@baseapp-frontend/components": "git+https://github.com/silverlogic/baseapp-frontend.git#<commit-hash>&path:packages/components",
- Restore Catalog Entries and Merge:
Once you’ve finished testing or using the non-published version, you can restore the catalog entries in one of two ways:
-
Option 1: Run the
restore-catalogs
scriptRefer to the (Restore Catalog Entries)[https://github.com/silverlogic/baseapp-frontend/blob/master/README.md#restore-catalog-entries] section to reapply catalog entries.
-
Option 2: Revert the Commit
Revert the commit that removed the catalogs to restore them to their previous state:
git revert <commit-hash>
Both options will effectively undo the catalog removal, restore the original entries, and allow you to proceed with committing and merging the changes.
We have 3 mandatory steps before pushing modifications:
- If we did any modification in any
package
, before pushing we need to generate a changeset, which basically is a file that summarizes which type of changes we did (major, minor or none) alongside with the summary of those changes. So, to do that we run:
pnpm changeset
After that, we need to choose which packages were changed, and the bump they had and write the summary for that change.
- With the changesets created, we need to consume them to actually increase the package versions accordingly. So, we do:
pnpm version-packages
After running that, you might notice version bumps on the package's version
and an update on the package's CHANGELOG.md
.
- By now, we just need to commit & push those files and, after merging the PR, the
packages updates
will be automatically published :)
To ensure that all pages, components, and utilities are thoroughly documented in Storybook, please follow these steps.
Each component and page should have a corresponding Storybook story that showcases its various states and usage scenarios:
- Include All Possible States: Each story should cover possible states of the component or page, such as default, disabled, loading, or error configurations.
- Use Mocks for Data: Use MSW (Mock Service Worker) to mock any necessary API requests, ensuring stories are self-contained and reproducible.
- Decorators: Pass any necessary decorators to simulate the environment (e.g., authentication with
withTokenSetup
). - Type Safety: Ensure correct typings for all props and arguments.
- Conciseness: Be thorough but concise, focusing on the most relevant states and interactions.
After creating the story:
- Add the story name to
storySort
in thepreview.ts
file to ensure it appears in the correct order. If you’re unsure where to add this, please ask a COP member for assistance.
In addition to stories, create an MDX file to provide detailed documentation for each page or component:
- Create an MDX File: Place the
.mdx
file in the corresponding__storybook__
folder. The file name should match the component or page name (e.g.,Button.mdx
for theButton
component). - Use Consistent Titles: Match the title in the MDX file to the Storybook story for consistency:
- Pages:
@baseapp-frontend-template / Pages/[PageName]
- Components:
@baseapp-frontend-template / [ComponentSection]/[ComponentCategory]/[ComponentName]
- Pages:
For detailed documentation templates and examples, refer to our Tettra page.