2019-05-15 -> 2021-06-25
- Widget coordinates
- Dynamic variables
- Light execute notation
- The widget variables system
- Page conf updator
- The global controller vars convention
2021-03-12 -> 2021-06-25
Widget coordinates allow you to target a widget in a given page.
The widget coordinates is actually a string with the following format:
- $zoneId.$widgetId
With:
- $zoneId: string, the identifier of the zone
- $widgetId: string, the identifier of the widget, which must be defined at the widget configuration level by using the id key. The widget id must be unique in the context of the zone. If the id key is not defined, the name of the widget is used. However, using the widget name is less precise than using the widget id. That's because the same widget name can be used multiple times on a page (i.e., you can have multiple instances of the same widget on a page).
In an eco-structure where third-party plugins collaborate to create a kit page conf array, the widget coordinates can be used by plugin authors to override the default widget configuration for instance.
2019-05-15
The kit system distinguishes between static and dynamic variables.
Static variables are the ones stored directly in the page configuration.
And the dynamic variables are the ones created by php at runtime.
Static variables can reference dynamic variables by using a special notation, which defaults to the following:
- ${myVar}
(a dollar symbol, followed by an opening curly bracket, then the dynamic variable name, then the closing curly bracket)
Dynamic variables were create to solve the problem of a widget which needs to display "Hello Tim", where "Tim" is the name of the currently logged user, and "Hello" is just one of many variations of a greeting word (could have been Hi, Bonjour, Salut, Guten Tag, Welcome,...).
Because of the number of potential variations of the greeting world ("Hello" in this case), it has to be stored in the widget configuration (and hence in the page configuration): the other approach would be to create one template by variation, but this would obviously lead us to too many template files, that's not a practical solution.
So thanks to the dynamic variable concept, we can store this in the widget configuration:
- Hello ${user_name}
Which solves the problem.
2019-07-15 -> 2020-11-27
Like dynamic variables, the light execute notation system allows you to inject variables dynamically into your templates. However, this time you can call a php method or a light service.
The notation is explained in great details in the light execute notation reference, configuration files section. It looks like this:
- ::(@reverse_router->getUrl(myRoute))::
2021-03-12
The widget variables system allow us to change the "vars" section of a widget's configuration.
It's an array of widget coordinates => newConf, where newConf can be one of:
- an array, the array to merge with the old widget configuration's vars
- a callable, which takes the old widget configuration vars as input, and transforms them (i.e. in place) to the new vars to use for this widget
Note: if the old widget configuration doesn't contain a "vars" entry, it will be created.
2019-07-25 -> 2021-03-12
Note: this system is deprecated, we recommend using the widget variables system instead.
The page conf updator is a simple way to update the page configuration array.
It basically allows controllers to change the kit page configuration array on the fly.
Example:
return $this->renderAdminPage('Light_Kit_Admin/Ling.Light_Kit/zeroadmin/user/user_list', [], PageConfUpdator::create()->updateWidget("body.light_realist", [
'vars' => [
'request_declaration_id' => 'Light_Kit_Admin:lud_user',
],
]));
Why do we need this?
In a Light kit application, the page logic is handled by controllers which then call the LightKitPageRenderer->renderPage method.
In other words, the controllers only have the renderPage method to communicate with the kit page configuration (which is responsible for setting all the layout and widgets of a page, in other words the kit page configuration controls all the gui part of the page).
Now most of the time, the controllers don't need to communicate with the gui. In kit, the controllers call a gui template, and that's it.
However, what if the gui needs more interaction with the controller?
This case happens with forms, where the controller will create form error messages and need to transmit them to the page configuration.
In the previous state of things, we had page transformers (dynamic variables and lazy reference resolver), but it turns out those are mostly useful to convert some data into another.
Plus, setting a page transformer require some extra work; it needs to be registered, and we need to create a PageTransformer object, this is not an optimal solution.
So controllers need a more direct way to interact with the page configuration.
PageConfUpdator is a solution to this problem.
We could technically use a simple array, but the problem is that widgets being indexed numerically, updating a specific widget requires to know the index of the widget.
Usually, we know that index, suffices to look at the kit page configuration.
However, the problem comes with third-party plugins, some plugins will update the page configuration, some others won't, and so the kit page configuration is a dynamic target that might change every time you install/uninstall a plugin.
So, the updator will basically allow us to update widget based on their names or other identifiers, rather than just the index.
In fact, I suggest to leave names for users, and plugin authors should add a key named "id" to the widget configuration, reserved for plugin authors.
So usually, what I believe should happen in practice, is that the plugin author would create the controller and the corresponding widget configuration, so for instance she creates the UserFormController, and then she also creates the userFormWidget configuration, so that she can safely choose her identifier (i.e. the id key).
In other words, the "id" key of a widget should not be changed by the app maintainer, and plugin authors should not update the "name" key, but rather use the "id" key for their own use.
2021-06-25
As an alternative way to pass variables from the controller to the widget templates, we've implemented the global controller vars convention.
We've only implemented this system for the widgets of type prototype so far (i.e., not picasso).