/**
* PS custom HTML elements and Preact handling.
* By Mia and Zarel
*/
import preact from 'preact';
import render from 'preact-render-to-string';
import {Utils} from '../lib';
/** For easy concenation of Preact nodes with strings */
export function html(
strings: TemplateStringsArray, ...args: (preact.VNode | string | number | null | undefined)[]
) {
let buf = strings[0];
let i = 0;
while (i < args.length) {
buf += typeof args[i] === 'string' || typeof args[i] === 'number' ?
Utils.escapeHTML(args[i] as string | number) :
render(args[i] as preact.VNode);
buf += strings[++i];
}
return buf;
}
/** client-side custom elements */
export interface PSElements extends preact.JSX.IntrinsicElements {
youtube: {src: string};
twitch: {src: string, width?: number, height?: number};
spotify: {src: string};
username: {name?: string, class?: string, children?: preact.VNode | string};
psicon: {pokemon: string} | {item: string} | {type: string} | {category: string};
center: {class?: string};
}
export {render};
export type VNode = preact.VNode;
export const h = preact.h;
export const Fragment = preact.Fragment;
export const Component = preact.Component;
export class FormatText extends preact.Component<{isTrusted?: boolean, replaceLinebreaks?: boolean}> {
render() {
const child = this.props.children;
if (typeof child !== 'string') throw new Error(`Invalid props.children type: ${!child ? child : typeof child}`);
return ;
}
}