Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
create-evergreen-app
Advanced tools
Create an evergreen web application with no build configuration.
A starter project for getting up and running with an evergreen web application development stack designed by, and for, today's modern web.
The goal of Project Evergreen is to march alongside the web and demonstrate those features projects like these, that can be a reference and starting point, so that both developers and users can benefit from a modern application intended for modern browsers. Evergreen Web Applications aim to be performant, promote usage of modern web features, be accessible to a wide range of users, and be a productive experience for developers.
Make sure you have a LTS version of Node.js (>= 10.x) and then follow these steps to get up and running:
# 1) Create new evergreen app
$ npx create-evergreen-app my-app
# 2) Change Directory
$ cd my-app
# 3) Start developing!
$ npm start
# or
$ yarn start
You can also run the installer locally by cloning the repo and using NodeJS
$ git clone https://github.com/ProjectEvergreen/create-evergreen-app.git
$ cd create-evergreen-app
$ npm ci # install project dependencies
$ node ./tasks/cea-install.js my-app # you can pass other supported CLI params here as well
You can now copy the my-app/ folder anywhere you want and start developing!
Here are some additional commands you can run while running npx create-evergreen-app
# install dependencies with Yarn instead of npm
$ npx create-evergreen-app my-app --yarn
# get help
$ npx create-evergreen-app --help
# get the version
$ npx create-evergreen-app --version
To start developing, simply open the my-app folder in your favorite IDE (VSCode has great modern JavaScript support) and start editing and adding files as you need in src/
.
Automated tasks have been made available as npm scripts that you can run from the command line using yarn
or npm run
:
develop
- To start a development server with live reload and file watchingbuild
- Generate a production build of the app for deploymentserve
- Locally serve a production buildtest
- Run unit tests in TDD mode (prepend with NODE_ENV=production
for "single run" usage)start
- alias to the develop
taske.g. to start developing, run
# yarn
$ yarn develop
or
# npm
$ npm run develop
Your team may choose to use either npm or Yarn, just make sure to pick one and remove the other manager's lock file. Make sure to update the lock file whenever adding / removing a package.
These are some guides related to configuring different parts of this application to customize it for your needs.
There is no right or wrong folder structure per se as with most decisions relating to technology, it's about finding the best tool for the job. Pick the conventions that fit your team / project best.
That said, CEA does come with with a lightly opinionated structure in the src/ directory as one of the main goals of a good folder structure should be to assist in the finding of files / code faster and being predicatable. Here is some info on the approach presented / suggested in this repo:
Unit tests are recommended to be kept side by side with the component /
class
/ etc. For integration and E2E tests, consider making a test/ directory alongside the src/ directory and put those tests there.
In webpack.config.develop.js and lws.config.js are sections for setting up proxies for routing requests, say to an API running in your development envrionment. Edit the placeholders to match your particular needs.
// TODO
Performance is an important consideration for developing and maintaing any modern web application. Out of the box, this project uses webpack's default settings for performance budgets and will error when its thresholds are exceeded.
The goal of this project will be to support good code splitting and lazy loading strategies by default to allow apps to scale horizontally as more pages / features / dependencies get added.
To learn more about performance best practices for modern web application development, check out the wiki.
For convenience, Create Evergreen App comes with the dependencies needed to run two browsers out of the box
Using Firefox
files
array in karma.conf.js related to ~@webcomponents
.browsers
array in karma.conf.js.Chrome headless is enabled by default since it is the most portable between local and continuous integration environments.
This project is made by possible with the much appreciated existence of tools like:
And of course, nods and kudos go out to the maintainers of Create React App (CRA) and Pascal Shlip (@thepassle) of Create Lit App for the inspiration.
Thank you, to all of you!
FAQs
Create an evergreen web application with no build configuration.
The npm package create-evergreen-app receives a total of 9 weekly downloads. As such, create-evergreen-app popularity was classified as not popular.
We found that create-evergreen-app 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
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.