FezVrasta/popper.js

View on GitHub
website/next.config.mjs

Summary

Maintainability
Test Coverage
import {readFileSync} from 'fs';
import rehypePrettyCode from 'rehype-pretty-code';
import rehypeSlug from 'rehype-slug';
import remarkSmartypants from 'remark-smartypants';
import visit from 'unist-util-visit';

const replaceVariables = () => async (tree) => {
  let packageVersions = ['^1.0.0', '^1.0.0'];

  try {
    packageVersions = await Promise.all(
      ['core', 'dom'].map((name) =>
        fetch(`https://registry.npmjs.org/@floating-ui/${name}/latest`)
          .then((res) => res.json())
          .then((res) => res.version),
      ),
    );
  } catch (e) {
    //
  }

  visit(tree, 'code', (node) => {
    node.value = node.value
      .replaceAll('__CORE_VERSION__', packageVersions[0])
      .replaceAll('__DOM_VERSION__', packageVersions[1]);
  });
};

/** @type {import('rehype-pretty-code').Options} */
const rehypePrettyCodeOptions = {
  theme: {
    dark: JSON.parse(
      readFileSync(new URL('./assets/floating-ui-theme.json', import.meta.url)),
    ),
    light: JSON.parse(
      readFileSync(
        new URL('./assets/floating-ui-light-theme.json', import.meta.url),
      ),
    ),
  },
  keepBackground: false,
  tokensMap: {
    key: 'meta.object-literal.key',
    function: 'entity.name.function',
    param: 'variable.parameter',
    const: 'variable.other.constant',
    class: 'support.class',
  },
};

/**
 * @type {import('next').NextConfig}
 */
export default {
  output: 'export',
  reactStrictMode: true,
  experimental: {esmExternals: true, scrollRestoration: true},
  pageExtensions: ['md', 'mdx', 'tsx', 'ts', 'jsx', 'js'],
  webpack(config, options) {
    config.module.rules.push({
      test: /\.svg$/,
      issuer: {
        and: [/\.(js|ts)x?$/],
      },
      use: ['@svgr/webpack'],
    });

    const imageLoaderRule = config.module.rules.find(
      (rule) => rule.loader === 'next-image-loader',
    );
    imageLoaderRule.exclude = /\.inline\.(png|jpg|svg)$/i;
    config.module.rules.push({
      test: /\.inline\.(png|jpg|gif)$/i,
      use: [
        {
          loader: 'url-loader',
        },
      ],
    });

    config.module.rules.push({
      test: /\.mdx?$/,
      use: [
        // The default `babel-loader` used by Next:
        options.defaultLoaders.babel,
        {
          loader: '@mdx-js/loader',
          /** @type {import('@mdx-js/loader').Options} */
          options: {
            providerImportSource: '@mdx-js/react',
            remarkPlugins: [replaceVariables, remarkSmartypants],
            rehypePlugins: [
              [rehypePrettyCode, rehypePrettyCodeOptions],
              rehypeSlug,
            ],
          },
        },
      ],
    });

    return config;
  },
};