Skip to content

Helium-Z/parse-es-import

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

parse-es-import

Inspired by parse-static-imports, and have the same return result as it, and can run both on browser/node sides because it is based on acron.

Will properly parse:

  • Default import. e.g. import utils from 'utils';

  • Star imports. e.g. import * as utils from 'utils';

  • Named imports. e.g. import { Foo as MyFoo } from 'utils';

  • Side effect only imports, e.g. import './App.css';

  • Multi-line imports, like

    import React, { useState, useCallback, useEffect } from 'react';

Installation

npm install --save parse-es-import

Usage

import fs from 'fs';
import parse from 'parse-es-import';

const file = fs.readFileSync('./path/to/file.js', 'utf8');
const results = parse(file);

console.log(JSON.stringify(results, null, 2));

API

  • content: String - Contents of code to parse.
  • options: Object - Receive all parameters of acorn.parse. Its default value is { ecmaVersion: 2021, sourceType: 'module' }.

Returns

{
  "imports": {},
  "exports": {}
}

imports

Attribute Type Default Value Description
moduleName String '' The name of the module imported or a relative path (e.g. 'react-dom')
starImport String '' The name of the star imported module object, if present
namedImports Object[] [] List of named imports as a list of objects
defaultImport String '' The name of the default import, if present
sideEffectOnly Boolean false If the import was side-effect only (e.g. import './App.css';)
startIndex Number 0 Index of the starting character of the import statement
endIndex Number 0 Index of the ending character + 1 of the import statement

Named import objects have the form:

Attribute Type Default Value Description
name String '' The name of the named import (e.g. { useState })
alias String name Will be the alias of a named import if aliased, otherwise defaults to the named import (e.g. import { foo /* the named import */ as bar /* the alias */ } from 'module-name';)

exports

Attribute Type Default Value Description
moduleName String '' The name of the module exported
type String '' The type of module exported
value String '' The value of module exported or a relative path (e.g. '../add.js')
startIndex Number 0 Index of the starting character of the export statement
endIndex Number 0 Index of the ending character + 1 of the export statement

Example

Content to parse:

import React from 'react';
import antd, { Button as AntButton, Alert } from 'antd';
import * as Hello from 'hello';

import 'xx.less';

export default () => {
  return <div>Hello World...</div>;
};

The parse result will be:

{
  "imports": [
    {
      "defaultImport": "React",
      "endIndex": 26,
      "moduleName": "react",
      "namedImports": [],
      "sideEffectOnly": false,
      "starImport": "",
      "startIndex": 0
    },
    {
      "defaultImport": "antd",
      "endIndex": 83,
      "moduleName": "antd",
      "namedImports": [
        {
          "alias": "AntButton",
          "name": "Button"
        },
        {
          "alias": "Alert",
          "name": "Alert"
        }
      ],
      "sideEffectOnly": false,
      "starImport": "",
      "startIndex": 27
    },
    {
      "defaultImport": "",
      "endIndex": 115,
      "moduleName": "hello",
      "namedImports": [],
      "sideEffectOnly": false,
      "starImport": "Hello",
      "startIndex": 84
    },
    {
      "defaultImport": "",
      "endIndex": 134,
      "moduleName": "xx.less",
      "namedImports": [],
      "sideEffectOnly": true,
      "starImport": "",
      "startIndex": 117
    }
  ],
  "exports": [
    {
      "endIndex": 198,
      "moduleName": "Demo",
      "startIndex": 136,
      "type": "FunctionDeclaration",
      "value": "function Demo() {\n  return <div>Hello World...</div>;\n}"
    }
  ]
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published