There is no release for any of the packages under this repo. To use it please make use of mrs-developer.
-
Install Nextjs project using
pages
directory. Note: only[email protected]
is supported because of next-auth dependency. -
Add the following scripts under your
package.json
:
{
"scripts": {
"develop": "npx --yes -p mrs-developer missdev --output=../workspaces --no-config",
"develop:npx": "npx --yes -p mrs-developer missdev --output=../workspaces --no-config"
}
}
- Add
pnpm-workspace.yaml
file in your project root, containing:
packages:
- 'workspaces/**/packages/*'
- Add desired dependencies:
{
"dependencies": {
"@edw/base": "workspace:*",
"@edw/drupal": "workspace:*",
},
"devDependencies": {
"eslint-config-custom": "workspace:*",
"tsconfig": "workspace:*",
}
}
- Define
.eslintrc.js
. Override with your project necessities. This requireseslint-config-custom
package.
module.exports = {
extends: ['custom/next'],
rules: {
'react/no-unescaped-entities': 'off',
},
...etc
}
- Define
tsconfig.json
. Override with your project necessities. This requirestsconfig
package.
{
"extends": "tsconfig/nextjs.json",
}
- For eslint perfectionist plugin add
internalPaths
under yourpackage.json
file:
{
"internalPaths": [
"@",
"~",
"@idra"
]
}
- Bootstrap global config in your
pages/_app.tsx
file
import { config } from '@edw/base/src'
import { type DrupalConfigRegistry } from '@edw/drupal/src'
import installSite from '@/siteconfig'
Object.assign(
config as DrupalConfigRegistry,
installSite(config as DrupalConfigRegistry),
)
- Configure
pages/_app.tsx
:
import { App as BaseApp, DefaultLayout } from '@edw/base/src/components'
import { withAuthInitialSession } from '@edw/drupal/src/hof'
import { SessionProvider } from '@edw/drupal/src/lib/auth'
...etc
export default function App({
Component,
pageProps: { initialSession, ...pageProps },
}: AppProps): React.JSX.Element {
const { breadcrumb, error, menus, node } = pageProps
return (
<BaseApp initialAppState={{ breadcrumb, menus, node }} theme={theme()}>
<SessionProvider initialSession={initialSession}>
<DefaultLayout
error={error}
header={<YourHeader />}
footer={<YourFooter />}
>
<Component {...pageProps} />
</DefaultLayout>
</SessionProvider>
</BaseApp>
)
}
App.getInitialProps = withAuthInitialSession()
- Configure
pages/[[...slug]].tsx
import {
compose,
withDrupalCommonResources,
withDrupalNodeResources,
} from '@edw/drupal/src/hof'
...etc
export const getServerSideProps = compose(
withDrupalCommonResources,
withDrupalNodeResources,
)()
- Define
pages/api/auth/[...nextauth].ts
apis for next-auth:
import NextAuth from '@edw/drupal/src/lib/auth'
export default NextAuth
- Nextjs - React-based web development framework
- Drupal-Next - JS lib to communicate with Drupal backends
- Antd - React component library and theming engine
- TanStack/Query - Data management library
- Storybook - Document and test UI Components
- Jest - Javascript testing library
- React - Javascript frontend development library
- Typescript - Superset of JS, provides static types
- Turbo Repo - Incremental bundler and build system
- pnpm - Javascript package manager with support for workspaces
- Docker - Container-based deployment
- basic Nextjs app, uses "pages" router
- typescript
- drupal-next used to integrate with Drupal
- antd with SSR css file generation
- custom theme for antd
- storybook
- jest tests
- makefile shortcuts
The packages/base
folder has the base library
We follow an Atomic Design approach. See this article for a short overview of Atomic Design
We use the following structure to host our components:
atoms
: we don't have yet anymolecules
- basic componentsblocks
- Recipes for bigger componentsglobal
- Site-wide recipes. Such as basic layout, footer, header, etc.templates
- Full pages and layouts
-
improve Dockerfile, see https://github.com/ReeceRose/next.js-template/tree/main
-
See https://levelup.gitconnected.com/how-to-make-your-library-tree-shakable-20b5a446c1e2 to package the library and https://github.com/egoist/tsup
-
https://typescript-eslint.io/blog/parser-options-project-true/
-
https://www.drupal.org/docs/core-modules-and-themes/core-modules/jsonapi-module
-
https://react-typescript-cheatsheet.netlify.app/docs/basic/getting-started/context/ https://dev.to/gvergnaud/bringing-pattern-matching-to-typescript-introducing-ts-pattern-v3-0-o1k
- Select a country from a facet
jq '.meta.facets[] | objects | select(.id == "jsonapi_country").terms[] | select(.values.value == "180")'