Package Exports
- @polymer/paper-behaviors/paper-button-behavior
- @polymer/paper-behaviors/paper-button-behavior.js
- @polymer/paper-behaviors/paper-checked-element-behavior.js
- @polymer/paper-behaviors/paper-inky-focus-behavior.js
- @polymer/paper-behaviors/paper-ripple-behavior.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@polymer/paper-behaviors) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
<paper-behaviors>
<paper-behaviors> is a set of behaviours to help implement Material Design elements:
PaperCheckedElementBehaviorto implement a custom element that has acheckedproperty similar toIronCheckedElementBehaviorand is compatible with having a ripple effect.PaperInkyFocusBehaviorimplements a ripple when the element has keyboard focus.PaperRippleBehaviordynamically implements a ripple when the element has focus via pointer or keyboard. This behavior is intended to be used in conjunction with and afterIronButtonStateandIronControlState.
See: Documentation, Demo.
Usage
Installation
npm install --save @polymer/paper-behaviorsExample of using one of the behaviours in a Polymer 3 element
import {PolymerElement, html} from '@polymer/polymer';
import {mixinBehaviors} from '@polymer/polymer/lib/legacy/class.js';
import {PaperButtonBehavior} from '@polymer/paper-behaviors/paper-button-behavior.js';
class SampleElement extends mixinBehaviors([PaperButtonBehavior], PolymerElement) {
static get template() {
return html`
<style>
:host {
display: block;
}
/* Some properties inherited from the behaviour */
:host([disabled]) {
background-color: grey;
pointer-events: none;
}
:host([active]),
:host([pressed]) {
background-color: blue;
}
</style>
<div>I am a ripple-y button</div>
`;
}
}
customElements.define('sample-element', SampleElement);Contributing
If you want to send a PR to this element, here are the instructions for running the tests and demo locally:
Installation
git clone https://github.com/PolymerElements/paper-behaviors
cd paper-behaviors
npm install
npm install -g polymer-cliRunning the demo locally
polymer serve --npm
open http://127.0.0.1:<port>/demo/Running the tests
polymer test --npm