Studio Developer Manual / Version 2307
Table Of ContentsWhen receiving a Config object, the typical things a constructor does is:
Apply the received
config
on its own Config defaultsHand through the resulting Config to its super constructor
In TypeScript code, this could be done like this:
constructor(config: Config<MyClass>) { super(Object.assign(Config<MyClass>({ id: "4711", configOption1: "bar", configOption2: [42, 24] }), config)); }
Example 5.16. Typical work of constructor done in TypeScript
However, there is a special utility class named ConfigUtils
that helps implementing a specific
merge logic. For array-valued properties, it should be possible to, instead of replacing the whole array,
append or prepend to the existing value. The concrete use cases where this often makes sense are Ext
component's plugins
and items
properties. So at least if your class has any
array-valued properties, you should use the following in your constructor:
import ConfigUtils from "@jangaroo/runtime/ConfigUtils"; //... constructor(config: Config<MyClass>) { super(ConfigUtils.apply(Config<MyClass>({ id: "4711", configOption1: "bar", configOption2: [42, 24] }), config)); } //...
Example 5.17. Using ConfigUtils utility class
Any client using such a component can then use the following:
import ConfigUtils from "@jangaroo/runtime/ConfigUtils"; //... Config(MyClass, { id: "4711", configOption1: "bar", ...ConfigUtils.append({ configOption2: [12] } }), config)); } //...
Example 5.18. Component with utility class in client
The resulting value of configOption2
after merging via ConfigUtils.apply()
will
be [42, 24, 12]
. There is an analogous utility method ConfigUtils.prepend()
.
Both return an object, handing through the given property, complementing it by an internal marker property
that specifies where to insert the value into the previous value. To "lift" these properties into
the surrounding object literal, the spread operator ...
is used.