@browser-modules/buttons
v1.0.8
Published
Button Web Component using ES6 modules
Downloads
25
Readme
Button
Over engineered web component button with:
- Declarative Interface
- Imperative Interface
- Finite State Machine
- Custom Styling and HTML Template
Dependencies
graph TD;
A[Buttons]
A --> B[Utility Service]
B --> C[Template loader]
A --> D[Component]
D --> E[Declaration]
D --> F[Configuration]
D --> G[Metadata]
D --> H[Styling]
A --> I[Modules]
I --> L[Machine]
I --> K[Events]
I --> J[Dictionary]
L --> K
K --> J
module dependencies are managed using NPM Packages.
{ "dependencies": {
"@browser-modules/dictionary": "^1.0.8",
"@browser-modules/events": "^1.1.1",
"@browser-modules/machine": "^1.0.2",
"@browser-modules/web.component": "^1.0.9"
}
}
To enable the browser to find the modules, HTML Importmaps is used:
<script type="importmap">
{
"imports": {
"@browser-modules/dictionary": "../node_modules/@browser-modules/dictionary/lib/dictionary.js",
"@browser-modules/events": "../node_modules/@browser-modules/events/lib/events.js",
"@browser-modules/machine": "../node_modules/@browser-modules/machine/lib/machine.js",
"@browser-modules/web.component": "../node_modules/@browser-modules/web.component/lib/component.js"
}
}
</script>
The finite state machine is an optional module which enable the support of complex workflows. This is a good example of how the dependency tree works.
External dependencies is simply loaded using the import keyword, as declared in the different modules:
// Inside Machine
import { Event as Emitter } from "@browser-modules/events";
// Inside Events
import { Dictionary } from "@browser-modules/dictionary";
Running Demo
To explore and manually interact with the the components imperative interface follow these steps:
Get Started:
- Start Live Server and verify the component is visible in Chrome Browser
- Open Developer Tools in Chrome Browser
- Select the Console in the Developer Tools
- Verify the component loaded successfully
Load the component into the Console:
var button = document.querySelector("button-pin");