UNPKG

svelte

Version:

Cybernetically enhanced web apps

34 lines (28 loc) 803 B
/** @import { TemplateNode } from '#client' */ import { render_effect, teardown } from '../../reactivity/effects.js'; import { hydrate_node, hydrating, set_hydrate_node } from '../hydration.js'; import { get_first_child } from '../operations.js'; /** * @param {HTMLDivElement | SVGGElement} element * @param {() => Record<string, string>} get_styles * @returns {void} */ export function css_props(element, get_styles) { if (hydrating) { set_hydrate_node(/** @type {TemplateNode} */ (get_first_child(element))); } render_effect(() => { var styles = get_styles(); for (var key in styles) { var value = styles[key]; if (value) { element.style.setProperty(key, value); } else { element.style.removeProperty(key); } } }); teardown(() => { element.remove(); }); }