
Security News
Attackers Are Hunting High-Impact Node.js Maintainers in a Coordinated Social Engineering Campaign
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.
@framejs/cli
Advanced tools
Frame CLI is a dead simple reusable web component compiler and documentation tool.
Tiny tooling, non-opinionated, zero configuration, Typescript and SASS support with no overhead.
Compiles into UMD, bundle and clean vanillaJS automatically.
Compiles Markdown into static HTML and JSON, with live examples.
$ npm install -g @framejs/cli
project/
├── my-component.ts
├── my-component.scss
└── readme.md
From the project root run:
$ frame build
This will generate:
project/
├── dist
│ ├── my-component.html // Component demo file
│ ├── my-component.json // Parsed markdown in json (including frontmatter keys)
│ ├── my-component.js // es6
│ ├── my-component.js.map // sourcemap
│ ├── my-component.bundle.js // Rollup IIFE es6 bundle
│ ├── my-component.bundle.js.map // Bundle sourcemap
│ ├── my-component.module.js // UMD module
│ ├── my-component.module.js.map // Module sourcemap
│ └── readme.md // Copied readme.md
├── my-component.ts
├── my-component.scss
└── readme.md
In a <style> tag, make an absolute path reference to sass file:
const template = `
<style>
@style('project/my-component.scss')
</style>
`
SASS compiles into autoprefixed CSS 2 browser versions behind based on caniuse
Frame CLI compiles all .md into HTML and JSON, not limited to components and follows the directory structure.
In markdown write:
<!--
```
<custom-element-demo>
<template>
<script src="my-component.bundle.js"></script>
<next-code-block></next-code-block>
</template>
</custom-element-demo>
```
-->
```html
<my-component></my-component>
```
Paths should be relative from the files location in dist folder.
All code in
<template>...</template>will execute on demo page load.
If you have a project like this, make a single my-component-libary.ts file that imports the other components and the compiler compiles it into UMD, bundle and es6:
project/
├── my-component-libary.ts
└── components
├── my-component
│ ├── my-component.ts
│ ├── my-component.scss
│ └── my-component.md
└── my-other-component
├── my-other-component.ts
└── my-other-component.md
In my-component-libary.ts:
@import './components/my-component/my-component.js';
@import './components/my-other-component/my-other-component.js';
When referencing to component files use ending .js so it works with native modules loading in supported browsers
Work on components in sandbox / styleguide mode using the cli:
$ frame start --open
This creates a directory listing with links to independent component/docs in your project. To serve only a single component/doc use:
$ frame start --open --index path/to/component_or_doc.md
To share your component and documentation from project root run (assuming the project is a git repo):
$ frame build && frame publish
see more options in the CLI options table
| Command | Option | Description |
|---|---|---|
frame build | Compiles all files in project folder. | |
frame build | -i, --index path_to.md | Relative path to .md file to use as index html, defaults to a directory listing. |
| Command | Option | Description |
|---|---|---|
frame start | Compiles and watches for file changes | |
frame start | -o, --open | Opens styleguide in the default browser |
frame build | -i, --index path_to.md | Relative path to .md file to use as index html, defaults to a directory listing. |
| Command | Option | Description |
|---|---|---|
frame publish | Publish dist to github pages (defaults to branch:gh-pages) | |
frame publish | -d, --dir path/to/dist | The base directory for all source files (defaults to dist). |
frame publish | -s, --source **/* | The minimatch pattern or array of patterns used to select which files should be published.') |
frame publish | -b, --branch branch | The name of the branch you'll be pushing to. The default uses GitHub's gh-pages branch, but this can be configured to push to any branch on any remote. |
frame publish | -r, --repository https://example.com/other/repo.git | Url for the origin remote of the current dir (assumes a git repository) |
frame publish | -o, --origin origin | The name of the remote you'll be pushing to. The default is your 'origin' remote, but this can be configured to push to any remote. |
frame publish | -m, --message 'commit message' | The commit message for all commits (defaults to: 'update') |
frame publish | -t, --tag tag | Create a tag after committing changes on the target branch. By default, no tag is created. To create a tag, provide the tag name as the option value. |
Yes! The more people (and bots) the better.
Please create an issue, make a pull request, start a discussion or ping me on twitter - @emolrmoeller.
For development, you can use this demo project that uses all the features of the cli web-component-ui-demo
FAQs
CLI tool for compiling web components and documentation
The npm package @framejs/cli receives a total of 2 weekly downloads. As such, @framejs/cli popularity was classified as not popular.
We found that @framejs/cli demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
Multiple high-impact npm maintainers confirm they have been targeted in the same social engineering campaign that compromised Axios.

Security News
Axios compromise traced to social engineering, showing how attacks on maintainers can bypass controls and expose the broader software supply chain.

Security News
Node.js has paused its bug bounty program after funding ended, removing payouts for vulnerability reports but keeping its security process unchanged.