flowbased-polymer
FlowBasedProgramming with web-components
flowbased-polymer
installation
For Polymer 3 and higher use npm:
npm i --save @furo/fpb
For Polymer 2 and below use bower:
bower install --save veith/flowbased-polymer
The flowbased-polymer mixin offers you the possibility to write your components or apps fully declaratively. No more manual/imperative adding of eventListeners in the source code and no searching for IDs to access the component you want.
You can use it to simply save adding eventlisteners in your source or to write entire components and applications according to the FBP programming paradigm without using a single line of JS. It's up to you how far you want to go.
FBP code is also easy testable. It takes about 2 minutes to understand the main concept.
It is a hybrid form of flow-based programming and ordinary polymer and works with every component which is useable by polymer.
Simple Introduction
In short, FBP combines events from one component @-event
with methods from another component ƒ-method
to trigger them. We call the connection a wire.
<paper-button raised @-click="--btnPropsClicked">Show Props</paper-button>
<left-drawer ƒ-hide="--btnPropsClicked">Menu...</left-drawer>
<right-drawer ƒ-show="--btnPropsClicked">Props...</right-drawer>
Explanation
When the user clicks on the paper-button
, the left-drawer
is hidden and the right-drawer
is displayed.
The button does not need to know that there is a left-drawer or right-drawer. It only informs about the wire --btnPropsClicked
that it was clicked.
Further documentation
Please read the documentation page for more information.
Usage
After importing the Mixin, extend your component with the FBPMixin. Thats all you have to do.
import {PolymerElement, html} from '@polymer/polymer';
import {FBP} from "@furo/fbp";
// ...
/**
* `my-component`
*
*
* @summary
* @customElement
* @polymer
* @mixes FBP
*/
class MyComponent extends FBP(PolymerElement) {
static get template() {
// language=HTML
return html`
<style>
:host {
display: block;
}
</style>
<paper-button raised @-click="--btnPropsClicked">Show Props</paper-button>
<left-drawer ƒ-hide="--btnPropsClicked">Menu...</left-drawer>
<right-drawer ƒ-show="--btnPropsClicked">Props...</right-drawer>
`;
}
}
window.customElements.define('my-component', MyComponent);
Detailed documentation
Read more about FBPolymer on the documentation pages.
License
MIT
Links
Compatibility
Was this helpful? Need more help?
Leave a comment or a question below. You can also join
the chat on Discord or
ask questions on StackOverflow.
Version
Dependencies
- Released
- 2019-05-03
- Maturity
- IMPORTED
- License
- MIT License
Compatibility
- Framework
- Polymer 3.0+ in 4.3.1
- Polymer 2.0+ in 3.4.1
- Polymer 1.0+ in 1.16.0
- Browser
- Browser Independent