Skip to content

Commit

Permalink
feat: split css files into optional imports (ory#77)
Browse files Browse the repository at this point in the history
* feat: export internal assets as is

* fix: split css into optional imports

* chore: update examples

* style: format

* fix: css in global context and examples

* fix: nextjs example

* fix: nextjs example

* fix: storybook font smoothing

* fix: package builds

* fix: package builds

* fix: preact build

* style: format

* fix: ts build errors

* style: format

* chore: update storybook packages

* fix: settings cards

* chore: update chromatic workflow

* style: format

* chore: update readme

* fix: chromatic workflow

* fix: storybook package versions

* style: format

* chore: update react-spa example package.json

* fix: storybook chromatic

* style: format

* fix: markup package

* style: format

* chore: update package versions
  • Loading branch information
Benehiko authored Jan 31, 2023
1 parent 1ff0c99 commit 68c4f0f
Show file tree
Hide file tree
Showing 79 changed files with 7,662 additions and 24,779 deletions.
9 changes: 6 additions & 3 deletions .github/workflows/chromatic.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,12 @@ jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- name: Install dependencies
run: npm i
- uses: actions/checkout@v3
with:
fetch-depth: 0
- uses: actions/setup-node@v3
with:
node-version: "16"
- name: Lerna initialize
run: npm run initialize
- name: Lerna build
Expand Down
4 changes: 2 additions & 2 deletions .npmrc
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
shamefully-hoist=true
legacy-peer-deps=true
shamefully-hoist=false
legacy-peer-deps=true
5 changes: 0 additions & 5 deletions .storybook/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,6 @@ module.exports = {
},
async viteFinal(config) {
return mergeConfig(config, {
build: {
rollupOptions: {
external: ["react-dom/client"],
},
},
plugins: [vanillaExtractPlugin()],
})
},
Expand Down
12 changes: 10 additions & 2 deletions .storybook/preview.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,15 @@
import React from "react"
import { ThemeProvider } from "@ory/elements"
import "@ory/elements/assets/normalize.css"

import "@ory/elements/assets/fa-brands.min.css"
import "@ory/elements/assets/fa-solid.min.css"
import "@ory/elements/assets/fontawesome.min.css"
import "@ory/elements/assets/inter-font.css"
import "@ory/elements/assets/jetbrains-mono-font.css"
import "@ory/elements/style.css"

import React from "react"

export const globalTypes = {
theme: {
name: "Theme",
Expand All @@ -20,7 +28,7 @@ export const globalTypes = {
export const withTheme = (StoryFn, context) => {
const theme = context.globals.theme
return (
<ThemeProvider theme={theme}>
<ThemeProvider theme={theme} enableFontSmoothing={true}>
<StoryFn />
</ThemeProvider>
)
Expand Down
77 changes: 61 additions & 16 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,12 @@ Ory Elements supports integrating with:

- React
- Preact
- ExpressJs (experimental)
- Express.js (experimental)

## Getting Started

Install Ory Elements into your existing React / Preact or ExpressJS application.
You can find example apps [here](#example-apps)
Install Ory Elements into your existing React / Preact or Express.js
application. You can find example apps [here](#example-apps)

**React**

Expand All @@ -34,7 +34,7 @@ npm install @ory/elements --save
npm install @ory/elements-preact --save
```

**ExpressJs**
**Express.js**

```shell
npm install @ory/elements-markup --save
Expand Down Expand Up @@ -73,6 +73,37 @@ have explicitly told our React app to use through the `VITE_ORY_SDK_URL` export.
Now you can see Ory Elements in action by opening http://localhost:3000 in your
browser!

## Breaking Changes

### Before v0.0.1-beta.1

Before v0.0.1-beta.1, Ory Elements exposed a singular `style.css` file which
contained all the required fonts and icons necessary to work out of the box.
This was convenient for elements to work out of the box, but caused the bundle
size to be larger than necessary, especially for applications that only use a
few components or their own icons and fonts.

The new version of Ory Elements now only exposes the CSS for the components in
the `style.css` file, and the rest of the CSS are optional and can be imported
individually.

```tsx
// Ory Elements
// optional global css reset
import "@ory/elements/assets/normalize.css"
// optional fontawesome icons
import "@ory/elements/assets/fa-brands.min.css"
import "@ory/elements/assets/fa-solid.min.css"
import "@ory/elements/assets/fontawesome.min.css"

// optional fonts
import "@ory/elements/assets/inter-font.css"
import "@ory/elements/assets/jetbrains-mono-font.css"

// required styles for Ory Elements
import "@ory/elements/style.css"
```

## Quickstart: Storybook

Explore the Ory Elements via [Storybook](https://storybook.js.org/)!
Expand Down Expand Up @@ -227,7 +258,21 @@ Inside our components we provide the `<ThemeProvider />` which exposes the
`themeOverrides` property so that you can implement your own theme.

```tsx
// Ory Elements
// optional global css reset
import "@ory/elements-preact/assets/normalize.css"
// optional fontawesome icons
import "@ory/elements-preact/assets/fa-brands.min.css"
import "@ory/elements-preact/assets/fa-solid.min.css"
import "@ory/elements-preact/assets/fontawesome.min.css"

// optional fonts
import "@ory/elements-preact/assets/inter-font.css"
import "@ory/elements-preact/assets/jetbrains-mono-font.css"

// required styles for Ory Elements
import "@ory/elements-preact/style.css"

const Main = () => {
return (
<ThemeProvider themeOverrides={customTheme}>
Expand All @@ -244,10 +289,10 @@ const Main = () => {
}
```

### Theme CSS in ExpressJS
### Theme CSS in Express.js

For ExpressJS the library also exports a helper function which registers all the
CSS the library produces.
For Express.js the library also exports a helper function which registers all
the CSS the library produces.

```ts
import express, { Application } from "express"
Expand Down Expand Up @@ -323,16 +368,16 @@ provides support to a large React based ecosystem. The project then bundles
these components to their respective needs. An example is bundling for Preact
which you can find in the
[packages](https://github.com/ory/elements/tree/main/packages)' folder. It uses
the React components directly in this case but bundles it specifically for
the React components directly in this case, but bundles it specifically for
Preact support.

Each component relies on some CSS styles, which are located in the
[theme](https://github.com/ory/elements/tree/main/src/theme) directory. To
understand how this works, please refer to the [CSS System](#css-system)

#### Express JS systems
#### Express.js systems

Express JS is an edge-case which requires the React components to be wrapped by
Express.js is an edge-case which requires the React components to be wrapped by
the `ReactDOMServer` to produce static HTML. This essentially does server-side
rendering of the components and removes any client-side JavaScript. Each
component needs to be wrapped by `ComponentWrapper` which essentially uses
Expand Down Expand Up @@ -366,15 +411,15 @@ and are sometimes required by a component. An example is the
## Versioning and Publishing

Ory Elements uses a fully automatic release publishing pipeline. All that is
necessary is to create a new release on GitHub after which the workflow runs all
the necessary steps to release the modules to the NPM registry.
necessary is to create a new release on GitHub, after which the workflow runs
all the necessary steps to release the modules to the NPM registry.

## Using local Ory SDKs

Most of the time, new features to this repository need some work in the
corresponding Ory products to work. To make the development cycle more
productive, it's possible to generate the SDK from a local OpenAPI/Swagger spec
file.
productive, it's possible to generate the SDK from a local OpenAPI / Swagger
spec file.

```bash
export KRATOS_DIR=/path/to/kratos # point this variable to the root of your local Kratos clone
Expand All @@ -385,14 +430,14 @@ make build-sdk
This copies the current OpenAPI spec from the local Kratos repository to the
current Elements directory (`./contrib/sdk/api.json`).

After that it generates the Typescript SDK according to the spec and copies it
After that, it generates the Typescript SDK according to the spec and copies it
to the `node_modules` directory. This overrides the currently installed module!

Now you can use the updated SDK without publishing to NPM first.

## Testing `@ory/elements` changes locally

To test local changes in `@ory/elements` in a local Ory examples repository you
To test local changes in `@ory/elements` in a local Ory examples repository, you
can point NPM to use a local directory instead of a remote package from the
registry.

Expand Down
1 change: 0 additions & 1 deletion examples/nextjs-spa/next.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@
/** @type {import('next').NextConfig} */
const nextConfig = {
reactStrictMode: true,
swcMinify: true,
}

module.exports = nextConfig
Loading

0 comments on commit 68c4f0f

Please sign in to comment.