Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/izelnakri/mber
Fast and minimal Ember.js CLI alternative, without broccoli.
https://github.com/izelnakri/mber
cli ember ember-cli emberjs frontend glimmer glimmerjs testing
Last synced: 3 months ago
JSON representation
Fast and minimal Ember.js CLI alternative, without broccoli.
- Host: GitHub
- URL: https://github.com/izelnakri/mber
- Owner: izelnakri
- License: mit
- Created: 2018-03-10T12:31:45.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2023-03-14T00:57:43.000Z (almost 2 years ago)
- Last Synced: 2024-10-31T11:41:29.552Z (3 months ago)
- Topics: cli, ember, ember-cli, emberjs, frontend, glimmer, glimmerjs, testing
- Language: JavaScript
- Homepage:
- Size: 18.1 MB
- Stars: 33
- Watchers: 3
- Forks: 0
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
![docker-based-ci](https://github.com/izelnakri/mber/workflows/docker-based-ci/badge.svg)
# mber: Modern Ember.js CLI alternative, without broccoli.
This build system uses [TypeScript](https://www.typescriptlang.org/docs/handbook/basic-types.html), [Module Unification RFC](https://github.com/emberjs/rfcs/blob/master/text/0143-module-unification.md) and [fastboot](https://www.ember-fastboot.com/) by default.
It also runs JS transpilation, bundling and linting in a multithreaded context with a thread pool in order to utilize all your CPU cores.
I've recently rewrote ember-cli, because it uses a not-so-ideal broccoli build system that does too much counter-intuitive magic.
One day after reading ember-cli source code, I've realized rewriting this from scratch is the only way to move forward for me personally.Mber is a very minimal, fast and strict alternative for ember-cli. Mber does pretty much everything ember-cli does unless you want to create your own addon.
You can use most of the ember addons, as long as the addon itself doesn't inject things to your broccoli/ember-cli runtime.
In future I might support addon creation/testing as well.Lots of thought and effort went into designing this replacement.
Mber has a full test suite. Currently mber has 54 less dependencies than ember-cli as of this writing,
this is without counting the massive sub-dependencies.
It is highly suggested to read the source code, it is very simple, readable and written with ES modules and async/await.
Contributions are always welcome. Mber never blocks the nodejs event loop.
WARNING: No guarantee is given for backward compatibility with ember-cli.I've never benchmarked this against ember-cli, but my observation is, mber is at least 5 times faster than ember-cli. The difference is probably more(can get to 20x+) for complex builds and big apps. Also no more zombie processes that consume your default port, massive tmp folders or immortal/kill-resistant build processes.
## Installation
Make sure you have node.js v15+ installed. `mber` uses the latest native nodejs `worker_thread` to achive multithreading
and the latest node.js native [fs/promises](https://nodejs.org/dist/latest-v15.x/docs/api/fs.html#fs_promise_example)
module. Then install mber CLI:```
npm install -g mber
```Check mber CLI commands:
```
mber
```Create an mber application:
```
mber new [your-app-name]
```run mber server:
```
mber s
```Now your development server is running on http://localhost:1234
### Testing
Running your application test suite is same as before:
```
mber test --server
```You can now view your tests in your browser afterwards.
If you are running your tests in the terminal and CI servers you can use the following:
```
mber test
```If you want to view/debug the browser output:
```
mber test --debug=true
```Currently tests only run on the actual google chrome for CI. In future I might implement CI mode support for other browsers.
### Adding libraries and ember-cli-addons to your build
Instead of ```ember-cli-build.js``` you now have ```index.js``` in your project root which allows you to add 3rd party code to your application and build your application. The syntax is very similar to ember-cli. However here we are slightly more explicit and respect node.js conventions. In far future this design decision will allow node.js imports of your frontend code:
```js
// in your index.js/* eslint-env node */
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;if (environment !== 'somecustomenvironment') {
app.import('node_modules/yourlibrary/dist/', { type: 'vendor '});app.import('node_modules/chart.js/dist/Chart.min.js', {
type: 'application', prepend: true, using: [{
transformation: 'fastbootShim'
}]
}); // NOTE: same sytax as documented in ember-cli docs
}// NOTE: Your addons are now not magically imported for the sake of explicitness and control.
// Instead, for example you can import your code via:
app.importAddon('ember-cli-moment', {
type: 'vendor', using: [{ transformation: 'fastbootShim' }]
});return app.build(environment);
}```
### Whitelisting npm modules
Mber supports importing npm modules or browser javascript as AMD modules. However you need to explicitly state these imports in your build config(index.js). The reason why this is needed is explained [here](https://github.com/izelnakri/mber/blob/master/npm-import-explanation.md):
```js
// in your index.js/* eslint-env node */
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;app.importAsAMDModule('moment', 'node_modules/moment/min/moment.min.js', {
type: 'vendor'
});app.importAsAMDModule('bip39', {
type: 'vendor', using: [{ transformation: 'fastbootShim' }]
});return app.build(environment);
}// then in your application code you can simply import these modules
import Component from '@ember/component';
import moment from 'moment';
import bip39 from 'bip39';export default Component.extend({
phrase: bip39.generateMnemonic()
});
```### Adding dynamic inline-content to your index.html
./index.html supports dynamic inline-content based on your environment configuration:
```html
{{google-analytics}}
{{sentry}}
```
```js
// in your index.js/* eslint-env node */
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;if (environment === 'production') {
app.injectInlineContent('googleAnalytics', `
window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date;
ga('create', '${ENV.googleAnalyticsId}', 'auto');
`);
}if (ENV.sentry.url) {
app.injectInlineContent('sentry', `
Raven.config('${ENV.sentry.url}', {
ignoreUrls: [${ENV.sentry.ignoreUrls}],
ignoreErrors: ${JSON.stringify(ENV.sentry.ignoreErrors)}
}).addPlugin(Raven.Plugins.Ember).install();
`);
}return app.build(environment);
}
```#### Extra: How to exclude ember-data from your application:
By default mber builds an ember application without jQuery. If want jquery in your application do this:
```js
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;// your other configuration ..
app.import('node_modules/jquery/dist/jquery.min.js', {
type: 'vendor', prepend: true
});return app.build(environment);
}
```If you want to exclude EmberData from your application. Add excludeEmberData to your config/environment.js:
```js
'use strict';module.exports = function(environment) {
let ENV = {
modulePrefix: '{{applicationName}}',
environment,
excludeEmberData: true // to exclude ember-data
}// .. remaining code
return ENV;
}
```#### Hipster feature: You can now run your frontend app from your command line:
```mber console```
Yep, now you can.
#### Using ember-i18n with mber
Currently ember-i18n has legacy folder/code under addon directory that gets filtered during ember-cli builds. Until that issue gets resolved you can use mber-i18n instead. Example:
```js
// in your index.js/* eslint-env node */
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;app.importAddon('ember-i18n', 'mber-i18n', { type: 'vendor' }); // here we are telling mber to inject addon code of mber-i18n npm module, however use ember-i18n module name during AMD transpilation
}
```#### Using sinon with mber tests
Sinon is a very large javascript project with 10k+ lines of code, this can make your initial build noticibly slow for tests. When you `importAsAMDModule(file)`, mber by default runs the target javascript file through babel and browserify. In order to disable this transpilation you can use: { transpile: false } option, therefore maintain the exceptional initial build speed:
```js
/* eslint-env node */
const app = require('mber');module.exports = function(ENV) {
const { environment } = ENV;if (environment === 'test') {
app.importAsAMDModule('sinon', 'node_modules/sinon/pkg/sinon-no-sourcemaps.js', {
type: 'test', prepend: true, transpile: false
});
}return app.build(environment);
}
```#### Enabling Ember optional features
Currently ember-source builds toggle two features based on environment configurations. You can toggle them in your `environment.js`:
```js
module.exports = function(environment) {
let ENV = {
_APPLICATION_TEMPLATE_WRAPPER: false, // NOTE: true by default
_TEMPLATE_ONLY_GLIMMER_COMPONENTS: true // NOTE: false by default
}
};
```# CREDITS
This would have been impossible without the great interop libraries, structures, conventions and the framework source code itself which is mainly developed by the ember core team and the community by large.This library is also a message to inspire and demonstrate Embers superiority in design and community to other frontend developers who are not yet fully knowledgeable of Ember.js framework.
The software is currently in beta stage, expect it to become stable shortly with no backward-compatibility promises.