@konkres/babel-plugin-quark

0.0.3-canary.1 • Public • Published

@konkres/babel-plugin-after

Babel plugin to add additional chunk info to asyncComponent() in Quarkjs.

How It's Wokring

  1. search for import statements from these paths 'quark' and 'quark/asyncComponent'
  2. then it finds a local name for asyncComponent import statement
// example1.js
import { asyncComponent } from 'quark'; // localname is asyncComponent

// example2.js
import { asyncComponent as foo } from 'quark'; // localname is foo

// example3.js
import asyncComponent from 'quark/asyncComponent'; // localname is asyncComponent

// example4.js
import foo from 'quark/asyncComponent'; // localname is foo

// example5.js
import { asyncComponent as foo, Quark } from 'quark'; // localname is foo

// example6.js
import { Quark } from 'quark'; // there is no `asyncComponent` import so babel plugin skips this file

// example7.js
import loader from 'quark/asyncComponent'; // localname is loader
import { asyncComponent, Quark } from 'quark'; // localname is asyncComponent

// localname = [`loader`, `asyncComponent`] :)
  1. then it searches for FunctionCalls that have these conditions:
  1. name of function that get called matches localname array
  2. that function act as value of property
  3. the name of property must be component
import { asyncComponent } from 'quark'; // localname is asyncComponent

// let's look for localname (`asyncComponent`) and see where it get called
// ...

// oh nice I found a call to that function
{
  component: asyncComponent({
    loader: () =>
      import(
        `./pages/ProductDetail`
      )
  }),
}

// now let me check and see if it's value of an object property that named `component`
{ // <- it's an object
  // 👇 and property name is `component`
  component: asyncComponent({
    loader: () =>
      import(
        `./pages/ProductDetail`
      )
  })
}

Examples

In

{
  path: "/product/:name",
  component: asyncComponent({
    loader: () =>
      import(
        `./pages/ProductDetail`
      )
  })
}

Out

{
  path: "/product/:name",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'pages-ProductDetail' */
        `./pages/ProductDetail`
      )
    chunkName: "pages-ProductDetail",
  })
}

// 👆 as you can see `./pages/ProductDetail` changed to `pages-ProductDetail`,
// because for web servers `/` means a folder
// and webpackChunkName is name of file that saved on disk,
// so `/` in file name may break our app

In

{
  path: "/product/:name",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'HelloWorld' */
        `./pages/ProductDetail`
      )
  })
}

Out

{
  path: "/product/:name",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'HelloWorld' */
        `./pages/ProductDetail`
      ),
      chunkName: "HelloWorld",
  })
}

In

const name = "SlimShady"
{
  path: "/rap/god",
  component: asyncComponent({
    loader: () =>
      import(
        `./pages/${name}`
      )
  })
}

Out

const name = "SlimShady"
{
  path: "/rap/god",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: '[request]' */
        `./pages/${name}`
      ),
    chunkName: name,
  })
}

In

{
  path: "/test",
  component: asyncComponent({
    loader: () =>
      import(
        `./pages/test`
      ),
    chunkName: "my-custom-chunk-name",
  })
}

Out

{
  path: "/test",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'my-custom-chunk-name' */
        `./pages/test`
      ),
      chunkName: "my-custom-chunk-name",
  })
}

In

{
  path: "/test",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'my-custom-chunk-name' */
        `./pages/test`
      ),
    chunkName: "i-will-replace-magic-comment",
  })
}

Out

{
  path: "/test",
  component: asyncComponent({
    loader: () =>
      import(
        /* webpackChunkName: 'i-will-replace-magic-comment' */
        `./pages/test`
      ),
    chunkName: "i-will-replace-magic-comment",
  })
}

Installation

$ npm install babel-plugin-after --save-dev

or if you use Yarn like me:

$ yarn add -D babel-plugin-after

Usage

Via .babelrc (Recommended)

.babelrc

{
  "plugins": ["after"]
}

Options

  • prefix: string (defaults: "") String used to append before chunkName and webpackChunkName.
{
  "plugins": ["after", { "prefix": "MyPrefix-" }]
}

Via CLI

$ babel --plugins after script.js

Via Node API

require('babel-core').transform('code', {
  plugins: ['after'],
});

Readme

Keywords

Package Sidebar

Install

npm i @konkres/babel-plugin-quark

Weekly Downloads

0

Version

0.0.3-canary.1

License

MIT

Unpacked Size

22.3 kB

Total Files

8

Last publish

Collaborators

  • _nolansym