No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
[[File:2021-05-18 11h45 14.png|none|thumb]] | [[File:2021-05-18 11h45 14.png|none|thumb]] | ||
ViewInView (View in View) is a way to bring one View into another | ViewInView (View in View) is a way to bring one View into another as a control. | ||
You can use the UIFirst definition helper to set this up or you can do it manually: | You can use the UIFirst definition helper to set this up or you can do it manually: | ||
# Create a list of objects - so that it renders as a Table | # Create a list of objects - so that it renders as a Table | ||
# On the Nesting of the Table add TaggedValue "ViewModel" with value true | # On the Nesting of the Table, add TaggedValue "ViewModel" with the value true | ||
# Delete all columns from the table and have only 1 column named ViewModel | # Delete all columns from the table and have only 1 column named ViewModel | ||
# Make the ViewModel column return a valid name of a ViewModel compatible with the object on the table row | # Make the ViewModel column return a valid name of a ViewModel compatible with the object on the table row | ||
Now the table is not rendered | Now the table is not rendered but is, instead, a ListView in WPF and a list of IFrames in Turnkey that contain the resolved ViewModel rooted in the object per row in the table. | ||
In | In Turnkey, the whole application is rendered in such a cell with a special mode given by Turnkey/AngularAppUC instead of Turnkey/AngularApp. | ||
====== Who | ====== Who Owns the State of a ViewInView ====== | ||
Changes done in a ViewInView control are owned by the | Changes done in a ViewInView control are owned by the Parent view. The Parent view's save and cancel buttons should light up when changes in the ViewInView control are done. | ||
====== Turnkey ViewOverrides and TagExpander in ViewInView ====== | ====== Turnkey ViewOverrides and TagExpander in ViewInView ====== | ||
If the ViewInView-ViewModel has an override file as discussed in Fashion_with_tagexpander or [[Turnkey session 9: View Override]] this will be applied before rendering | If the ViewInView-ViewModel has an override file as discussed in Fashion_with_tagexpander or [[Turnkey session 9: View Override]], this will be applied before rendering: | ||
[[File:2021-05-18 13h11 18.png|none|thumb|620x620px]] | [[File:2021-05-18 13h11 18.png|none|thumb|620x620px]] | ||
[[File:2021-05-18 13h13 08.png|none|thumb|510x510px]] | [[File:2021-05-18 13h13 08.png|none|thumb|510x510px]] |
Revision as of 12:03, 10 February 2023
ViewInView (View in View) is a way to bring one View into another as a control.
You can use the UIFirst definition helper to set this up or you can do it manually:
- Create a list of objects - so that it renders as a Table
- On the Nesting of the Table, add TaggedValue "ViewModel" with the value true
- Delete all columns from the table and have only 1 column named ViewModel
- Make the ViewModel column return a valid name of a ViewModel compatible with the object on the table row
Now the table is not rendered but is, instead, a ListView in WPF and a list of IFrames in Turnkey that contain the resolved ViewModel rooted in the object per row in the table.
In Turnkey, the whole application is rendered in such a cell with a special mode given by Turnkey/AngularAppUC instead of Turnkey/AngularApp.
Who Owns the State of a ViewInView
Changes done in a ViewInView control are owned by the Parent view. The Parent view's save and cancel buttons should light up when changes in the ViewInView control are done.
Turnkey ViewOverrides and TagExpander in ViewInView
If the ViewInView-ViewModel has an override file as discussed in Fashion_with_tagexpander or Turnkey session 9: View Override, this will be applied before rendering: