simplified interface
This commit is contained in:
parent
1dd16d879b
commit
df1eb84e86
23
README.md
23
README.md
|
@ -9,10 +9,12 @@ Useful for composing single-page-apps or developing a Micro-Frontend architectur
|
||||||
|
|
||||||
## API
|
## API
|
||||||
|
|
||||||
Anchor(register = {}, [mix = []])
|
Anchor([options = {}])
|
||||||
|
|
||||||
- `register` {Object} - initial object registry (optional)
|
- `options` {Object} (optional)
|
||||||
- `mixin` {Array} - extend anchor directly (optional)
|
- `register` {Object} - initial object registry (optional)
|
||||||
|
- `global` {Object} - global object to anchor to (default {})
|
||||||
|
- `mixins` {Array} - extend achor directly
|
||||||
|
|
||||||
## Quick Start
|
## Quick Start
|
||||||
|
|
||||||
|
@ -23,7 +25,7 @@ Useful for composing single-page-apps or developing a Micro-Frontend architectur
|
||||||
|
|
||||||
import anchor from 'anchor.js';
|
import anchor from 'anchor.js';
|
||||||
|
|
||||||
let app = new Anchor();
|
let app = Anchor();
|
||||||
|
|
||||||
app.register('version', '1.0.0');
|
app.register('version', '1.0.0');
|
||||||
app.register('log', console);
|
app.register('log', console);
|
||||||
|
@ -42,23 +44,24 @@ import app from 'app.js';
|
||||||
app.log.info('using app version', app.version); // using app version 1.0.0
|
app.log.info('using app version', app.version); // using app version 1.0.0
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also initialize `Anchor` with an object to front-load the registry instead of using `app.register()`
|
You can also initialize `Anchor` with an object to front-loaded the registry via `opts.register` instead of using `app.register()`
|
||||||
|
|
||||||
```js
|
```js
|
||||||
let app = new Anchor({
|
let app = new Anchor({
|
||||||
|
register: {
|
||||||
'version': '1.0.0',
|
'version': '1.0.0',
|
||||||
'log': console,
|
'log': console,
|
||||||
...
|
...
|
||||||
|
}
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
> TIP: Connect multiple spas together, on each spa use `app.register` to extend that spas functionality on its bootstrap file
|
> TIP: Connect multiple spas together, on each spa use `app.register` to extend that spas functionality on its bootstrap file
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
The `Anchor mixin` option acts more like a *merge*, rather than a `registry` and is useful to `mixin` objects directly, for example:
|
The `Anchor` `options.mixins` acts more like a *merge*, rather than a `registry` and is useful to `mixin` to the anchor directly, for example:
|
||||||
|
|
||||||
```js
|
```js
|
||||||
// app.js
|
// app.js
|
||||||
|
@ -66,7 +69,7 @@ The `Anchor mixin` option acts more like a *merge*, rather than a `registry` and
|
||||||
import anchor from 'anchor.js';
|
import anchor from 'anchor.js';
|
||||||
import mitt from 'mitt.js'; // event library
|
import mitt from 'mitt.js'; // event library
|
||||||
|
|
||||||
let app = new Anchor({}, [mitt()]); // adds on, off, emit, all to app
|
let app = new Anchor({mixins: [mitt()]}); // adds on, off, emit, all to app
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -85,9 +88,7 @@ app.events.emit('my-event', " I'm your huckel berry");
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
> WARNING: `mixins` have no safe guards and WILL overwrite duplicates
|
||||||
> WARNING: `mixin` has no safe guards and will overwrite existing duplicate functionality
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Tests
|
## Tests
|
||||||
|
|
16
src/index.js
16
src/index.js
|
@ -1,12 +1,12 @@
|
||||||
/**
|
/**
|
||||||
* Tiny global application registry
|
* Tiny global application registry
|
||||||
*/
|
*/
|
||||||
function Anchor(fasten = {}, mixins = []) {
|
function Anchor(opts = {}) {
|
||||||
// create a unique namespace to avoid collisions
|
// create a unique namespace to avoid collisions
|
||||||
const NAMESPACE = `_${Math.random().toString(36).slice(-6)}_`.toUpperCase();
|
const NAMESPACE = `_${Math.random().toString(36).slice(-6)}_`.toUpperCase();
|
||||||
|
|
||||||
// find environments global object
|
// global object anchor
|
||||||
const GLOBAL = window || global || {};
|
const GLOBAL = opts.global || {};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Register
|
* Register
|
||||||
|
@ -28,26 +28,26 @@ function Anchor(fasten = {}, mixins = []) {
|
||||||
* Builds the Application Anchor
|
* Builds the Application Anchor
|
||||||
*
|
*
|
||||||
* @param {Object} fasten
|
* @param {Object} fasten
|
||||||
* @param {Array} merges
|
* @param {Array} mixins
|
||||||
* @param {Boolean} debug
|
* @param {Boolean} debug
|
||||||
*/
|
*/
|
||||||
function build(fasten, merges, register) {
|
function build(opts, register) {
|
||||||
if (GLOBAL[NAMESPACE]) {
|
if (GLOBAL[NAMESPACE]) {
|
||||||
// already initialized
|
// already initialized
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// add to global instance
|
// add to global instance
|
||||||
GLOBAL[NAMESPACE] = fasten;
|
GLOBAL[NAMESPACE] = opts.register || {};
|
||||||
GLOBAL[NAMESPACE]['register'] = register;
|
GLOBAL[NAMESPACE]['register'] = register;
|
||||||
|
|
||||||
// merge with global instance
|
// merge with global instance
|
||||||
merges.forEach((merge) => Object.assign(GLOBAL[NAMESPACE], merge));
|
(opts.mixins || []).forEach((mixin) => Object.assign(GLOBAL[NAMESPACE], mixin));
|
||||||
|
|
||||||
return GLOBAL[NAMESPACE];
|
return GLOBAL[NAMESPACE];
|
||||||
};
|
};
|
||||||
|
|
||||||
return build(fasten, mixins, register);
|
return build(opts || {}, register);
|
||||||
};
|
};
|
||||||
|
|
||||||
export default Anchor;
|
export default Anchor;
|
||||||
|
|
Loading…
Reference in New Issue