Custom object property types
Purpose of custom (object) property types
The custom object property type can be used by web components to logically group a number of sub-properties (that can be of different types) for easier usage.
Such custom object types are able to send granular updates between server and client. For example if you change from Rhino one subproperty value (or for more complex element property types - such as 'component' type - if something changes in only one of the subproperties) then only that change is sent over to the browser/client instead of the whole custom object (and the other way around - a subproperty change on client doesn't send the full object, just the change to server).
Custom object types are defined in .spec files with a fixed set of subproperties as below:
.spec file
To understand how "pushToServer" .spec setting works on a custom object property (and it's sub-properties), have a look at Data synchronization; it gives details about how nested typed object/arrays work with pushToServer as well.
Advanced .spec options
A configuration option (that you will most likely never need) for custom objects (available starting with Servoy 2019.06) is to be able to convert to null at runtime objects that have any of a set of specific keys set to null at design time ("setToNullAtRuntimeIfAnyOfTheseKeysAreNull": [ "a", "c" ]):
For example if in developer properties view you set on this property { "a": null, "b": 5, "c": "something"} then, at runtime, the property will be null because "a", one of the "setToNullAtRuntimeIfAnyOfTheseKeysAreNull" from .spec, is null. You will probably never need to use this option except for when you want to create advanced custom components that have arrays of columns that contain child components (so _"model": { "columns": { "type" : "column[]", "skipNullItemsAtRuntime": true, "elementConfig": { "setToNullAtRuntimeIfAnyOfTheseKeysAreNull": [ "columnComponent" ] } }, "types": { "column": { "columnHeaderText": "string", "columnComponent": "component" } } _) and where the security settings of a form might not allow some of the child components (columns) to be visible at runtime - depending on the user that logs in. In that case those items in the array would be set to null automatically by Servoy because the columnComponent is set to null automatically if it's not supposed to be visible - and most of the times in this case you want to just get browser-side the columns who's child components you can show in that array and not worry about nulls and not send anything related to that column to client. See also array type to understand what "elementConfig" above does.
Browser/client side value
The browser value of such a property is a Javascript object containing the defined sub-properties:
It is able to send granular updates (so if you change only one property it will only send that one), depending on it's pushToServer configuration.
Server side javascript value
The server side JS value of such a property is a custom implementation based on Javascript object - so you should be able to use it just like a normal JS object.
There is one difference though. In order to be able to send fine-grained updates to the client/browser, those values are 'watched'. That means that whenever you assign a completely new javascript object directly to the property (or if you assign a new object/array to one of it's sub properties on any level), that new value (reference) you assign will not be 'watched' directly; you have to take/read it back from the property (which will give you an equivalent 'watched' value) before using it further in code. Or you can access the value of the property directly every time, not kept as a reference.
Whenever you assign a full new value to that property, it will be replaced by a copy of it (starting with 8.2), but the prototype of the copy will be the same as the one in the initial value. That means that in that prototype you can have for example some methods if you want to build your component/service API like that and those methods - if they are defined in the prototype - will not be lost in the 'instrumentation' process.
For example:
DO it like this
OR like this
DON'T do it like this
Developer handling of custom object properties
Custom object properties can be edited at design-time from Servoy Developer's properties view and/or using drag and drop operations depending on type and configuration options. (TODO add more details here)
Nesting with custom object and array types
Custom object types can be nested with array types. This allows you to organize your model's properties better. For example (in .spec file):
So the 'persons' property at runtime (client side) could look like this:
Last updated