Skip to content

Latest commit

 

History

History
88 lines (66 loc) · 2.44 KB

README.md

File metadata and controls

88 lines (66 loc) · 2.44 KB

Domparty - Component library

A white label component library, ready for you to style. Unbiased on how styling should look on your website, while giving you the handles to kick-start you application with some helpful functional components.

Instructions

Install the component library using npm i @domparty/fe. This will make the library available for your project. Because @domparty/fe uses Goober internally to provide all neat CSS tricks, first implement our provider into your application.

Using Preact?

If you're more into speedy apps, we have also implemented a provider for you! Instead of importing the provider from @domparty/fe/core, import the provider from @domparty/fe/core/preact. This way your application is using the Pragma from Preact, instead of React.

Default React apps

For default React apps, the following snippet can be used.
use import { Provider } from '@domparty/fe/core/preact'; for Preact

import React from 'react';
import { Provider } from '@domparty/fe/core';

export default () => (
  <Provider value={{}}>
    <App />
  </Provider>
);

Next.js apps

To implement @domparty/fe into Next.js make sure the _app.js file implements the component.

import React from 'react';
import { Provider } from '@domparty/fe/core';

export default ({ Component, pageProps }) => (
  <Provider value={{}}>
    <Component {...pageProps} />
  </Provider>
);

SSR (server-side rendering)

To make sure all styles are rendered correctly on the server. The component library exports Goobers' extractCss function for you to implement.

To use this feature in Next.js apps, make sure the getInitialProps in your _document file uses this function.

import Document, { Head, Main, NextScript } from 'next/document';
import { extractCss } from '@domparty/fe/core';

export default class MyDocument extends Document {
  static getInitialProps({ renderPage }) {
    const page = renderPage();

    // Extrach the css for each page render
    const css = extractCss();
    return { ...page, css };
  }

  render() {
    return (
      <html>
        <Head>
          <style
            id={'_goober'}
            // And defined it in here
            dangerouslySetInnerHTML={{ __html: this.props.css }}
          />
        </Head>
        <body>
          <Main />
          <NextScript />
        </body>
      </html>
    );
  }
}

License

MIT