* Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript (#265) * Trying a new github workflow to install javascript packages * Bump tailwindcss from 1.9.2 to 1.9.4 in /build/javascript (#266) Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 1.9.2 to 1.9.4. - [Release notes](https://github.com/tailwindlabs/tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/master/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v1.9.2...v1.9.4) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Commit updated Javascript packages * Bump preact from 10.5.4 to 10.5.5 in /build/javascript Bumps [preact](https://github.com/preactjs/preact) from 10.5.4 to 10.5.5. - [Release notes](https://github.com/preactjs/preact/releases) - [Commits](https://github.com/preactjs/preact/compare/10.5.4...10.5.5) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Owncast <owncast@owncast.online> * Bump @justinribeiro/lite-youtube in /build/javascript Bumps [@justinribeiro/lite-youtube](https://github.com/justinribeiro/lite-youtube) from 0.9.0 to 0.9.1. - [Release notes](https://github.com/justinribeiro/lite-youtube/releases) - [Commits](https://github.com/justinribeiro/lite-youtube/commits) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Owncast <owncast@owncast.online> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Gabe Kangas <gabek@real-ity.com>
35 lines
1.0 KiB
JavaScript
35 lines
1.0 KiB
JavaScript
import { createElement } from 'preact';
|
|
import { shallowDiffers } from './util';
|
|
|
|
/**
|
|
* Memoize a component, so that it only updates when the props actually have
|
|
* changed. This was previously known as `React.pure`.
|
|
* @param {import('./internal').FunctionalComponent} c functional component
|
|
* @param {(prev: object, next: object) => boolean} [comparer] Custom equality function
|
|
* @returns {import('./internal').FunctionalComponent}
|
|
*/
|
|
export function memo(c, comparer) {
|
|
function shouldUpdate(nextProps) {
|
|
let ref = this.props.ref;
|
|
let updateRef = ref == nextProps.ref;
|
|
if (!updateRef && ref) {
|
|
ref.call ? ref(null) : (ref.current = null);
|
|
}
|
|
|
|
if (!comparer) {
|
|
return shallowDiffers(this.props, nextProps);
|
|
}
|
|
|
|
return !comparer(this.props, nextProps) || !updateRef;
|
|
}
|
|
|
|
function Memoed(props) {
|
|
this.shouldComponentUpdate = shouldUpdate;
|
|
return createElement(c, props);
|
|
}
|
|
Memoed.displayName = 'Memo(' + (c.displayName || c.name) + ')';
|
|
Memoed.prototype.isReactComponent = true;
|
|
Memoed._forwarded = true;
|
|
return Memoed;
|
|
}
|