You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Right now, drilldown dataview components, by virtue of the noViewport property, can conveniently overlap the header row of the parent dataview when scrolling down, which is a very nice thing to have as users can always have the correct headers depending on which dataview they are currently examining.
However, it may also be desirable to have handy (visible) the parent data row. As a minimum, conserving the parent data row conserves the control column, which is the usual place where the "expand" button is placed, allowing users to collapse without having to scroll all the way up.
Proposal
Add a new property autoStickExpandedRows that would turn row auto-sticking on and off. Auto-sticking would require the owner of the viewport to keep track of all sticky rows, including child header rows of dataview components with their noViewport property set to true. In other words, the owner of the viewport will require a mechanism to build and reactively maintain a hierarchical data structure of all child dataview components that have no viewport, and its stuck rows.
Pseudo-Algorithm
On initialization, use context to discover the viewport owner and its immediate parent ID.
Register itself with the viewport owner by passing its unique control ID, plus its immediate parent ID.
The above information is immediately used by the viewport owner to update its hierarchical data structure.
Report to the viewport owner the height of the header row, which contains the header row but also the dataview's caption.
At this point, monitor the rows' wjdv.expanded property:
When a row is expanded, measure the height of the data row and report it to the viewport owner. Monitor the height reactively.
Also make the expanded data row sticky by changing its position CSS property, and by setting its top CSS property. The value of the latter must be provided by the viewport owner.
When a row is collapsed, tell the viewport owner to remove the row, and stop monitoring its height.
The text was updated successfully, but these errors were encountered:
Description
Right now, drilldown dataview components, by virtue of the
noViewport
property, can conveniently overlap the header row of the parent dataview when scrolling down, which is a very nice thing to have as users can always have the correct headers depending on which dataview they are currently examining.However, it may also be desirable to have handy (visible) the parent data row. As a minimum, conserving the parent data row conserves the control column, which is the usual place where the "expand" button is placed, allowing users to collapse without having to scroll all the way up.
Proposal
Add a new property
autoStickExpandedRows
that would turn row auto-sticking on and off. Auto-sticking would require the owner of the viewport to keep track of all sticky rows, including child header rows of dataview components with theirnoViewport
property set totrue
. In other words, the owner of the viewport will require a mechanism to build and reactively maintain a hierarchical data structure of all child dataview components that have no viewport, and its stuck rows.Pseudo-Algorithm
At this point, monitor the rows'
wjdv.expanded
property:position
CSS property, and by setting itstop
CSS property. The value of the latter must be provided by the viewport owner.The text was updated successfully, but these errors were encountered: