Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
A standalone dev environment for Enact apps using Webpack, Babel, React, and a collection of other tools.
All that's needed to install enact-dev is to use npm to install it globally. For Linux sudo
may be required.
npm install -g enact-dev
Note: Node 6.x+ is highly recommended for optimum speed and efficiency, however anything since Node 4.x is compatible.
The only time you're ever want to directly use the Enact CLI is when you want to create a new project.
enact create [directory]
This will generate a basic App template, complete with npm scripts and dependencies setup. If no directory path is specified, it will be generated within the working directory.
Advanced: If you've used
npm link
on separate installations of the Enact repo, you can include--link
to theinit
command and NPM will symlink your Enact repo, rather than reinstall. Additionally, you can link in the Enact dependencies post-install via theenact link
command.
Within the project directory, you can run:
npm run serve
Builds and serves the app in the development mode.
Open http://localhost:8080 to view it in the browser.
The page will reload if you make edits.
npm run pack
and npm run pack-p
Builds the project in the working directory. Specifically, pack
builds in development mode with code un-minified and with debug code included, whereas pack-p
builds in production mode, with everything minified and optimized for performance. Be sure to avoid shipping or performance testing on development mode builds.
npm run watch
Builds the project in development mode and keeps watch over the project directory. Whenever files are changed, added, or deleted, the project will automatically get rebuilt using an active shared cache to speed up the process. This is similar to the serve
task, but without the http server.
npm run clean
Deletes previous build fragments from ./dist.
npm run lint
Runs the Enact configuration of Eslint on the project for syntax analysis.
npm run test
, npm run test-json
, and npm run test-watch
These tasks will execute all valid tests (files that end in -specs.js
) that are within the project directory. The test
is a standard execution pass, test-json
uses a json reporter for output, and test-watch
will set up a watcher to re-execute tests when files change.
npm run license
Outputs a JSON representation of the licenses for modules referenced by the current project as well as any licenses of modules used by enact-dev
that may be included in a production build of an app.
The enact-dev tool will check the project's package.json
looking for an optional enact
object for a few customization options:
template
[string] - Filepath to an alternate HTML template to use with the Webpack html-webpack-plugin.isomorphic
[boolean|string] - If true
, it indicates the default entrypoint is isomorphic-compatible (and can be built via the --isomorphic
enact-dev flag). If the value is a string, then it will use that value as a filepath to a custom isomorphic-compatible entrypoint.title
[string] - Title text that should be put within the HTML's <title></title>
tags. Note: if this is a webOS-project, the title by default will be auto-detected from the appinfo.json content.ri
[object] - Resolution independence options to be forwarded to the LESS plugin.screenTypes
[array|string] - Array of 1 or more screentype definitions to be used with prerender HTML initialization. Can alternatively reference a json filepath to read for screentype definitons. Defaults to moonstone definitions.deep
[string|array] - 1 or more javascript conditions that, when met, indicate deeplinking and any prerender should be discarded.node
[object] - Configuration settings for polyfilling NodeJS built-ins. See node
webpack option.proxy
[string] - Proxy target during project serve
to be used within the http-proxy-middleware.For example:
{
...
"enact": {
"isomorphic": true,
"ri": {
"baseSize":24
}
}
...
}
Some editors, including Sublime Text, Atom, and Visual Studio Code, provide plugins for ESLint.
They are not required for linting. You should see the linter output right in your terminal. However, if you prefer the lint results to appear right in your editor, there are some extra steps you can do.
You would need to install an ESLint plugin for your editor first.
A note for Atom
linter-eslint
users
If you are using the Atom
linter-eslint
plugin, make sure that Use global ESLint installation option is checked:
Then, you will need to install some packages globally:
npm install -g eslint eslint-plugin-react eslint-plugin-babel babel-eslint eslint-plugin-enact eslint-config-enact
We recognize that this is suboptimal, but it is currently required due to the way we hide the ESLint dependency. The ESLint team is already working on a solution to this so this may become unnecessary in a couple of months.
Unless otherwise specified, all content, including all source code files and documentation files in this repository are:
Copyright (c) 2012-2017 LG Electronics
Unless otherwise specified or set forth in the NOTICE file, all content, including all source code files and documentation files in this repository are: Licensed under the BSD License (the "License"); you may not use this content except in compliance with the License. You may obtain a copy of the License at
https://opensource.org/licenses/BSD-3-Clause
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Portions of this project are based upon create-react-app, Copyright (C) 2016-present Facebook, Inc.
0.9.2 (September 7, 2017)
screenTypes
within the enact
object in the package.json
. Can now be:
deep
option within the enact
object in the package.json
. It represents 1 or more javascript conditions that, when met, indicate the page load was originating from an external deep link, and the prerender should not be shown (as the initial state of the window will not be the prerendered content). This can be a string or a string array.FAQs
Full-featured build environment for Enact applications.
The npm package enact-dev receives a total of 7 weekly downloads. As such, enact-dev popularity was classified as not popular.
We found that enact-dev 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.