Skip to content
This repository has been archived by the owner on Aug 29, 2023. It is now read-only.

Commit

Permalink
feat: use new npm package name, create readme
Browse files Browse the repository at this point in the history
  • Loading branch information
tomschall committed Jan 6, 2023
1 parent 3c22b25 commit 612bc76
Show file tree
Hide file tree
Showing 3 changed files with 321 additions and 35 deletions.
324 changes: 320 additions & 4 deletions packages/design-system-component-library-yeahyeahyeah/README.md
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
## Installing the npm package
## Installing Mumble Component Library

### Create nextjs app
### Create Nextjs App

```bash
nvm use 16.17.0
yarn create next-app --typescript
```

### Create github token and add to .npmrc
### Create Github Token And Add To .npmrc

[Create a classic github token](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token#creating-a-personal-access-token-classic)

Expand All @@ -23,7 +23,7 @@ Create .npmrc and add following line
@smartive-education:registry=https://npm.pkg.github.com
```

### Install the npm package
### Install The NPM Package

With yarn

Expand All @@ -44,3 +44,319 @@ npm i @smartive-education/design-system-component-library-yeahyeahyeah@latest
- [styled-components](https://styled-components.com/)
- [Twin](https://github.com/ben-rogerson/twin.macro)
- [Github](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-npm-registry#installing-packages-from-other-organizations)

# Install Example App with Twin + Next.js + Styled Components + TypeScript + Mumble Component Library

<p><a href="https://github.com/ben-rogerson/twin.macro#gh-light-mode-only" target="_blank"><img src="../.github/twin-light.svg" alt="Twin" width="60" height="70"></a><a href="https://github.com/ben-rogerson/twin.macro#gh-dark-mode-only" target="_blank"><img src="../.github/twin-dark.svg" alt="Twin" width="60" height="70"></a><a href="https://nextjs.org#gh-light-mode-only" target="_blank"><img src="../.github/next-light.svg" alt="Next.js" width="80" height="70"></a><a href="https://nextjs.org#gh-dark-mode-only" target="_blank"><img src="../.github/next-dark.svg" alt="Next.js" width="80" height="70"></a><a href="https://styled-components.com#gh-light-mode-only" target="_blank"><img src="../.github/styled-components-light.svg" alt="Styled components" width="105" height="70"></a><a href="https://styled-components.com#gh-dark-mode-only" target="_blank"><img src="../.github/styled-components-dark.svg" alt="Styled components" width="105" height="70"></a><a href="https://www.typescriptlang.org/" target="_blank"><img src="../.github/typescript.svg" alt="TypeScript" width="60" height="70"></a>
</p>

**Download this example using [git](https://github.com/tomschall/mumble-test-stack-yeahyeahyeah)**

```shell
git clone [email protected]:tomschall/mumble-test-stack-yeahyeahyeah.git folder-name
```

From within the new folder, run `yarn install`, then `yarn dev` to start the dev server.

[](#table-of-contents)

## Table of contents

- [Getting started](#getting-started)
- [Installation](#installation)
- [Add the global styles](#add-the-global-styles)
- [Add the twin config](#add-the-twin-config)
- [Add the TypeScript types](#add-typescript-types)
- [Add the next babel config](#add-the-next-babel-config)
- [Add the server stylesheet](#add-the-server-stylesheet)
- [Customization](#customization)
- [Next steps](#next-steps)

[](#getting-started)

## Getting started

### Installation

Install Next.js

```shell
nvm use 16.17.0
yarn create next-app --typescript
```

Create github token and add to .npmrc

[Create a classic github token](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token#creating-a-personal-access-token-classic)

To authenticate by adding your personal access token (classic) to your ~/.npmrc file, edit the ~/.npmrc file for your project to include the following line, replacing TOKEN with your personal access token. Create a new ~/.npmrc file if one doesn’t exist.

```bash
//npm.pkg.github.com/:_authToken=TOKEN
```

Create .npmrc and add following line

```bash
@smartive-education:registry=https://npm.pkg.github.com
```

Install Mumble Component Library And Other Needed Dependencies

```shell
yarn add styled-components @smartive-education/design-system-component-library-yeahyeahyeah@latest
yarn add twin.macro tailwindcss babel-plugin-macros @types/styled-components babel-loader @babel/plugin-syntax-typescript --dev
```

### Add the global styles

Twin uses the same [preflight base styles](https://unpkg.com/tailwindcss/dist/base.css) as Tailwind to smooth over cross-browser inconsistencies.

The `GlobalStyles` import adds these base styles along with some @keyframes for the animation classes and some global css that makes the [ring classes](https://tailwindcss.com/docs/ring-width) and box-shadows work.

> Due to an issue in styled-components, global styles get added in the wrong order when using styled-components. This gives the tailwind base styles an incorrect specificity.
> Until [the issue](https://github.com/styled-components/styled-components/issues/3146) is fixed, the workaround is to export the styles from another file.
You can import `GlobalStyles` within a new file placed in `styles/GlobalStyles.tsx`:

```js
// styles/GlobalStyles.tsx
import React from 'react';
import { createGlobalStyle } from 'styled-components';
import tw, { theme, GlobalStyles as BaseStyles } from 'twin.macro';

const CustomStyles = createGlobalStyle({
body: {
WebkitTapHighlightColor: theme`colors.purple.500`,
...tw`antialiased`,
},
});

const GlobalStyles = () => (
<>
<BaseStyles />
<CustomStyles />
</>
);

export default GlobalStyles;
```

Then import the GlobalStyles file and Mumble Global CSS file in `pages/_app.tsx`:

Mumble Global CSS has all CSS vars and body styles that are needed for Mumble

Also import

```js
// pages/_app.tsx
import '@smartive-education/design-system-component-library-yeahyeahyeah/tailwind.css';
import type { AppProps } from 'next/app';
import GlobalStyles from '../styles/GlobalStyles';

function MyApp({ Component, pageProps }: AppProps) {
return (
<>
<GlobalStyles />
<Component {...pageProps} />
</>
);
}

export default MyApp;
```

### Add the twin config

Twin’s config must be added.

We add it to `package.json`:

Here we use the tailwind.config.js from our mumble npm package

```js
// package.json
"babelMacros": {
"twin": {
"config": "node_modules/@smartive-education/design-system-component-library-yeahyeahyeah/tailwind.config.js",
"preset": "styled-components"
}
},
```

### Add TypeScript types

Create a `types/twin.d.ts` file and add these declarations:

```typescript
// types/twin.d.ts
import 'twin.macro';
import styledImport, { CSSProp, css as cssImport } from 'styled-components';

declare module 'twin.macro' {
// The styled and css imports
const styled: typeof styledImport;
const css: typeof cssImport;
}

declare module 'react' {
// The css prop
interface HTMLAttributes<T> extends DOMAttributes<T> {
css?: CSSProp;
tw?: string;
}
// The inline svg css prop
interface SVGProps<T> extends SVGProps<SVGSVGElement> {
css?: CSSProp;
tw?: string;
}
}

// The 'as' prop on styled components
declare global {
namespace JSX {
interface IntrinsicAttributes<T> extends DOMAttributes<T> {
as?: string | Element;
}
}
}
```

### Add the next babel config

Create a new file either in the root or in a `config`
subfolder:

```js
// withTwin.js
const path = require('path');

// The folders containing files importing twin.macro
// We have to add the mumble npm package also, because we also import twin.macro inside the package
const includedDirs = [
path.resolve(__dirname, 'pages'),
path.resolve(__dirname, 'styles'),
path.resolve(__dirname, 'node_modules/@smartive-education/design-system-component-library-yeahyeahyeah/dist'),
];

module.exports = function withTwin(nextConfig) {
return {
...nextConfig,
webpack(config, options) {
const { dev, isServer } = options;
config.module = config.module || {};
config.module.rules = config.module.rules || [];
config.module.rules.push({
// mumble npm package components are pure js files, therefor js has also to be included
test: /\.(tsx|ts|js)$/,
include: includedDirs,
use: [
options.defaultLoaders.babel,
{
loader: 'babel-loader',
options: {
sourceMaps: dev,
plugins: [
require.resolve('babel-plugin-macros'),
[require.resolve('babel-plugin-styled-components'), { ssr: true, displayName: true }],
[require.resolve('@babel/plugin-syntax-typescript'), { isTSX: true }],
],
},
},
],
});

if (!isServer) {
config.resolve.fallback = {
...(config.resolve.fallback || {}),
fs: false,
module: false,
path: false,
os: false,
crypto: false,
};
}

if (typeof nextConfig.webpack === 'function') {
return nextConfig.webpack(config, options);
} else {
return config;
}
},
};
};
```

Then in your `next.config.js`, import and wrap the main export with `withTwin(...)`:

```js
// next.config.js
const withTwin = require('./withTwin.js');

/**
* @type {import('next').NextConfig}
*/
module.exports = withTwin({
reactStrictMode: true, // < Recommended by Next
// ...
});
```

### Add the server stylesheet

To avoid the ugly Flash Of Unstyled Content (FOUC), add a server stylesheet in `pages/_document.tsx` that gets read by Next.js:

```js
// pages/_document.tsx
import React from 'react';
import Document, { DocumentContext } from 'next/document';
import { ServerStyleSheet } from 'styled-components';

export default class MyDocument extends Document {
static async getInitialProps(ctx: DocumentContext) {
const sheet = new ServerStyleSheet();
const originalRenderPage = ctx.renderPage;
try {
ctx.renderPage = () =>
originalRenderPage({
enhanceApp: (App) => (props) => sheet.collectStyles(<App {...props} />),
});
const initialProps = await Document.getInitialProps(ctx);

return {
...initialProps,
styles: [
<React.Fragment key="styles">
{initialProps.styles}
{sheet.getStyleElement()}
</React.Fragment>,
],
};
} finally {
sheet.seal();
}
}
}
```

[](#customization)

## Customization

- [View the config options →](https://github.com/ben-rogerson/twin.macro/blob/master/docs/options.md)
- [Customizing the tailwind config →](https://github.com/ben-rogerson/twin.macro/blob/master/docs/customizing-config.md)

[](#next-steps)

## Next steps

Learn how to work with twin

- [The prop styling guide](https://github.com/ben-rogerson/twin.macro/blob/master/docs/prop-styling-guide.md) - A must-read guide to level up on prop styling
- [The styled component guide](https://github.com/ben-rogerson/twin.macro/blob/master/docs/styled-component-guide.md) - A must-read guide on getting productive with styled-components

Learn more about styled-components

- [The css prop](https://styled-components.com/docs/api#css-prop)
- [The css import](https://styled-components.com/docs/api#css)
- [The styled import](https://styled-components.com/docs/api#styled)
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"name": "@smartive-education/design-system-component-library-yeahyeahyeahyeah",
"name": "@smartive-education/design-system-component-library-yeahyeahyeah",
"version": "1.1.0",
"publishConfig": {
"access": "public",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,33 +42,3 @@ body {
color: var(--color-base);
hyphens: var(--hyphens-base);
}

/*
@headings
*/
/* h1 {
@apply text-4xl font-bold m-0;
}
h2 {
@apply text-3xl font-bold;
}
h3 {
@apply text-2xl font-semibold;
}
h4 {
@apply text-xl font-semibold;
} */

/*
@SVG's
*/
/* button svg {
@apply relative -top-1;
}
a svg {
@apply relative -top-1;
} */

0 comments on commit 612bc76

Please sign in to comment.