Skip to content
This repository has been archived by the owner on Jan 13, 2025. It is now read-only.

feat(ripple): Add setUnbounded to foundation #1826

Merged
merged 3 commits into from
Dec 22, 2017
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions packages/mdc-ripple/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,7 @@ ripple to. The adapter API is as follows:
| --- | --- |
| `browserSupportsCssVars() => boolean` | Whether or not the given browser supports CSS Variables. When implementing this, please take the [Edge](#caveat-edge) and [Safari 9](#caveat-safari) considerations into account. We provide a `supportsCssVariables` function within the `util.js` which we recommend using, as it handles this for you. |
| `isUnbounded() => boolean` | Whether or not the ripple should be considered unbounded. |
| `setUnbounded(unbounded: boolean) => void` | Adds the unbounded class when truthy, removes when falsy |
| `isSurfaceActive() => boolean` | Whether or not the surface the ripple is acting upon is [active](https://www.w3.org/TR/css3-selectors/#useraction-pseudos). We use this to detect whether or not a keyboard event has activated the surface the ripple is on. This does not need to make use of `:active` (which is what we do); feel free to supply your own heuristics for it. |
| `isSurfaceDisabled() => boolean` | Whether or not the ripple is attached to a disabled component. If true, the ripple will not activate. |
| `addClass(className: string) => void` | Adds a class to the ripple surface |
Expand Down
10 changes: 10 additions & 0 deletions packages/mdc-ripple/foundation.js
Original file line number Diff line number Diff line change
Expand Up @@ -503,6 +503,16 @@ class MDCRippleFoundation extends MDCFoundation {
this.adapter_.updateCssVariable(VAR_TOP, `${this.unboundedCoords_.top}px`);
}
}

/** @param {boolean} unbounded */
setUnbounded(unbounded) {
const {UNBOUNDED} = MDCRippleFoundation.cssClasses;
if (unbounded) {
this.adapter_.addClass(UNBOUNDED);
} else {
this.adapter_.removeClass(UNBOUNDED);
}
}
}

export default MDCRippleFoundation;
12 changes: 6 additions & 6 deletions packages/mdc-ripple/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,13 +82,13 @@ class MDCRipple extends MDCComponent {

/** @param {boolean} unbounded */
set unbounded(unbounded) {
const {UNBOUNDED} = MDCRippleFoundation.cssClasses;
this.unbounded_ = Boolean(unbounded);
if (this.unbounded_) {
this.root_.classList.add(UNBOUNDED);
} else {
this.root_.classList.remove(UNBOUNDED);
}
this.setUnbounded_();
}

/** @private */
setUnbounded_() {
this.foundation_.setUnbounded(this.unbounded_);
}

activate() {
Expand Down
10 changes: 10 additions & 0 deletions test/unit/mdc-ripple/foundation.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -255,3 +255,13 @@ testFoundation('#layout resets debounce latch when layout frame is run', ({found
foundation.layout();
assert.equal(mockRaf.pendingFrames.length, 1);
});

testFoundation('#setUnbounded adds unbounded class when unbounded is truthy', ({adapter, foundation}) => {
foundation.setUnbounded(true);
td.verify(adapter.addClass(cssClasses.UNBOUNDED));
});

testFoundation('#setUnbounded removes unbounded class when unbounded is falsy', ({adapter, foundation}) => {
foundation.setUnbounded(false);
td.verify(adapter.removeClass(cssClasses.UNBOUNDED));
});