diff --git a/CHANGELOG.md b/CHANGELOG.md index b1842dd..80074db 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,9 @@ # Changelog +## v1.0.2 + +- Added the `Revealer` island for abstracting the common "See more..." functionality. + ## v1.0.1 - Added the `InterObs` island for abstracting the native Intersection Observer diff --git a/islands/InterObs/setup.ts b/islands/InterObs/setup.ts index b143c0a..ff8a870 100644 --- a/islands/InterObs/setup.ts +++ b/islands/InterObs/setup.ts @@ -22,7 +22,7 @@ export type iInterObs = iComponent & { observerOptions: IntersectionObserverInit; }; -/** These are the default values of the `` island's props. */ +/** These are the default values of the `` island's props. */ const defaults: iInterObs = { animation: '', isIntersectingCb: () => null, @@ -34,7 +34,7 @@ const defaults: iInterObs = { }; // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -/** Setup function of the `` island. */ +/** Setup function of the `` island. */ export default (props: Partial) => { const p = apDef(defaults, props); diff --git a/islands/Revealer/index.tsx b/islands/Revealer/index.tsx new file mode 100644 index 0000000..48d0104 --- /dev/null +++ b/islands/Revealer/index.tsx @@ -0,0 +1,34 @@ +// ___ _ +// | _ \_____ _____ __ _| |___ _ _ +// | / -_) V / -_) _` | / -_) '_| +// |_|_\___|\_/\___\__,_|_\___|_| +// +//////////////////////////////////////////////////////////////////////////////////////////////////////// +/** + * ### Revealer + * *Organism* + * + * This module contains the render function for the `` island. + * + * @module + */ +import { useState } from 'preact/hooks'; +import setup, { iRevealer } from './setup.ts'; + +export default function (props: Partial) { + const { children, fwd, actuator, ...p } = setup(props); + const [isRevealed, setRevealed] = useState(false); + + return ( +
+ {isRevealed ? null : ( +
setRevealed(true)}> + {actuator} +
+ )} +
+ {isRevealed ? children : null} +
+
+ ); +} diff --git a/islands/Revealer/setup.ts b/islands/Revealer/setup.ts new file mode 100644 index 0000000..d12a5fd --- /dev/null +++ b/islands/Revealer/setup.ts @@ -0,0 +1,48 @@ +// ___ _ ___ _ +// | _ \_____ _____ __ _| |___ _ _ / __| ___| |_ _ _ _ __ +// | / -_) V / -_) _` | / -_) '_| \__ \/ -_) _| || | '_ \ +// |_|_\___|\_/\___\__,_|_\___|_| |___/\___|\__|\_,_| .__/ +// |_| +//////////////////////////////////////////////////////////////////////////////////////////////////////// +/** + * This module contains the prop type, default values, and styles for the `` island. + * + * @module + */ +import { apDef, forward, o } from '../../src/utils.ts'; +import { iComponent, iFwd } from '../../src/types.ts'; +import Link from '../../components/Link/index.tsx'; +import { ComponentChild } from 'preact'; + +// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +/** Properties of the `` island. */ +export type iRevealer = iComponent & { + actuator: ComponentChild; + fwd: Partial; +}; + +type iRevealerFwd = { + revelation: iFwd; +}; + +/** These are the default values of the `` island's props. */ +const defaults: iRevealer = { + actuator: Link({ children: 'Read more' }), + fwd: { + revelation: {}, + }, +}; + +// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +/** Setup function of the `` island. */ +export default (props: Partial) => { + const p = apDef(defaults, props); + + p.class = o('revealer', { ...p }); + + p.fwd = forward({ + revelation: 'revealer__revelation', + }, p.fwd); + + return p; +};