egroupware/doc/etemplate2/pages/tutorials/converting-to-webcomponents.md

3.4 KiB

Converting to webComponents

WebComponents have a different lifecycle and timing than our previous widgets. This can cause issues when they are used together.

Equivalent methods

Old WebComponent
constructor(_parent, _attrs? : WidgetConfig, _child? : object) constructor()
destroy() N/A
attachToDOM() connectedCallback()
detachFromDOM() disconnectedCallback()
transformAttributes(_attrs) transformAttributes(_attrs)
parseXMLAttrs(_attrsObj, _target, _proto) N/A
doLoadingFinished() N/A
set_[property](...) widget.[property] = ...
get_[property]() widget.[property]
set_value(...) set_value(...) remains, and is used when loading content from a template file.
loadingFinished(waiting : Promise[]) loadingFinished(waiting:Promise[]) remains for legacy compatability, but updateComplete() is the replacement

Accessing widget internals

Don't.

Widgets should be considered closed boxes, and will regenerate their contents as needed. They will also malfunction if you try to alter their internal structure directly. Use their properties, methods, slots and parts.

Is it ready

A lot of strange problems occur when trying to interact with a widget before it is "complete". The webComponent widgets can update and will redraw their contents as needed. You can wait until they are ready using updateComplete:

    // FAILS, but may sometimes succeed just to be difficult
    let templateWidget = ...
    let label = templateWidget.getWidgetById("label");
    label.value = "Details":
    
    // Let it load
    let templateWidget = ...
    templateWidget.updateComplete.then(() => {
        let label = template.getWidgetById("label");
        label.value = "Details";
    });