Files
rio/frontend/code/components/placeholder.ts
2024-06-18 21:34:25 +02:00

27 lines
769 B
TypeScript

import { ComponentBase, ComponentState } from './componentBase';
import { ComponentId } from '../dataModels';
export type PlaceholderState = ComponentState & {
_type_: 'Placeholder'; // Not 'Placeholder-builtin'!
_child_?: ComponentId;
};
export class PlaceholderComponent extends ComponentBase {
state: Required<PlaceholderState>;
createElement(): HTMLElement {
let element = document.createElement('div');
element.classList.add('rio-placeholder');
return element;
}
updateElement(
deltaState: PlaceholderState,
latentComponents: Set<ComponentBase>
): void {
super.updateElement(deltaState, latentComponents);
this.replaceOnlyChild(latentComponents, deltaState._child_);
}
}