I am migrating a form that retrieves its config object from an angular controller (the config object includes 4 form components, organized on two rows, two components per row)
<div webix-ui="formConfig"></div>
to one which components are defined in html and still retrieve their config object from the controller
At the moment both forms live on the same page. All is good except for the fact the latter form is showing all 4 components each on a separate row (cols are being ignored.)
I am mixing up incompatible initialization styles here?
ok thanks I see what you mean. A new snippet shows what I am really trying to achieve - evolve an entirely js-based form to an html-based one, without changing the rendered output. The move is mainly to take advantage of webix-data and angular. Would you please take a look http://webix.com/snippet/283b730f (there are comments on the html)
The all-in-one-contructor approach does not bode well with the angular/webix-data paradigm and I would like to find out if rendering can be fixed by tweaking some visualization attributes here and there.
(1) As to the problem with auto adjustment, you should be aware of the fact that Webix adjustment rules work only if your app is initialized with one and the same webix.ui constructor.
The webix-ui tag not only gets configuration from the controller, but executes a separate webix.ui call and initializes the component in the given HTML block.
If you can, you should avoid such code patterns. You should initialize the whole app either from config or from markup.
(2) You need to call .show() method for the window to show it on the page. You can do it with webix-ready directive:
But most probably the problem is in the structure of the html-markups: a separate webix.ui (formConfig in your case) should be initialized completely as JSON or as html without calling another webix.ui within it.
webix-ui view=“form” id=“htmlForm” is my target form, it shows its components BUT the rows do not auto adjust their height to the minimum required, and borders are displayed. How can I define “htmlForm” to show exactly the same as “originalForm”?
Also, all 3 components in the popup window have 0 width when shown, how do I define the window body content in html?
Tweaking visualization attributes will require a lot of patience from you, I’m afraid, as you will need to set fixed sizes as well as remove borders, padding or change layout type here and there. And you will loose auto adjustment on window resize.