mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-12-22 14:41:29 +01:00
Some notes on converting to webcomponents
This commit is contained in:
parent
84fb37214a
commit
e014487e86
@ -0,0 +1,46 @@
|
||||
## Converting to webComponents
|
||||
|
||||
WebComponents have a different [lifecycle](https://lit.dev/docs/components/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";
|
||||
});
|
||||
```
|
Loading…
Reference in New Issue
Block a user