-
Notifications
You must be signed in to change notification settings - Fork 161
Splitter Specification
- Revision History
- Overview
- User Stories
- Functionality
- Acceptance criteria
- Accessibility
- Internationalization
- Assumptions and Limitations
- Test Scenarios
- References
- Konstantin Dinev | Date:
- Radoslav Mirchev | Date: 09-Apr-2020
- Stefan Ivanov | Date:
Version | User | Date | Notes |
---|---|---|---|
0.1 | Stefan Ivanov | Mar 11, 2020 | Initial draft |
The Splitter component provides a framework for a simple layout splitting the view horizontally or vertically into multiple smaller areas called panes.
As an end-user I want to:
- see two or more content areas side by side with a divider between them e.g. a design surface and its corresponding code view
- resize the panes by dragging the splitter element
- focus the splitter element via the keyboard
- use the keyboard to resize the split panes
- scroll the content if it doesn't fit in the pane in horizontal, vertical, or in both directions
- collapse and expand panes
As a developer I want to:
- provide arbitrary content that is rendered in a splitter's pane
- create a splitter that lays out panes horizontally or vertically determined by an orientation property
- have the vertical splitter layout to respect the right-to-left support that certain cultures may require
- define a default size for each pane
- define a min and max values for the width and height of a pane
- specify a pane as not resizable, which would not allow the user to drag its handle/collapse it
- nest a splitter in another splitter's pane
- have right-to-left support out of the box
Design Hands-Off:
A splitter with a vertical orientation and two panes, where the right one contains scrollable content and shows a scroll bar. On both sides of the drag handle for the splitter separator, there are icons for collapsing the pane to the right/left.
On hover over the splitter, its indicator changes for the dark theme from grays 800 without alpha channel to grays 500 without alpha channel and for light theme from grays 200 without alpha channel to white. If the user hovers above the expand/collapse icons and their extended target area then only the icon fill color will change in a similar fashion, the splitter drag indication will remain in its normal state.
The splitter and its icons will have an extended target area that will make it easier for interacting with them e.g. if the splitter is 4px wide the interactive area will extend 4px to the left and 4 px to the right. The mouse cursor will change accordingly to indicate resize for the whole splitter except for the expand/collapse icons over which a hand cursor will be shown.
Initializing an igxSplitter
is done through a tag of its own igx-splitter
. Inside it multiple panes can be defined via the igx-splitter-pane
tag. The content of the pane is templatable and will be rendered in its own resizable containers.
<igx-splitter>
<igx-splitter-pane>
...
</igx-splitter-pane>
<igx-splitter-pane>
...
</igx-splitter-pane>
</igx-splitter>
More than two splitter panes can be defined under a single igx-splitter.
You can nest splitter components to create a more complex layout inside a splitter pane. For example:
<igx-splitter>
<igx-splitter-pane>
<igx-splitter>
<igx-splitter-pane>
...
</igx-splitter-pane>
<igx-splitter-pane>
...
</igx-splitter-pane>
</igx-splitter>
</igx-splitter-pane>
...
</igx-splitter>
The splitter can be vertical or horizontal, which is defined by the type
Input. The default is Vertical
.
-
igxSplitter
Name Description Type type The igxSplitter
type - can be Horizontal or Vertical.SplitterType -
igxSplitterPane
Name Description Type size Gets/Sets the size of the pane. string minSize Gets/Sets the minimum allowed size of the current pane. Resizing beyond it is not allowed. string maxSize Gets/Sets the maximum allowed size of the current pane. Resizing beyond it is not allowed. string resizable Sets/Gets if the pane allows resizing. boolean hidden Sets/Gets if the pane is hidden (for example as a result of collapsing it via the splitter bar) boolean order Sets/Gets the order of the current of the current pane number
-
igxSplitter
Name Description Return type Parameters togglePane Toggles pane visibility. void IgxSplitterPaneComponent
-
igxSplitter
Name Description Cancelable Arguments panesChange Emits when the panes collection is changed. false IgxSplitterPaneComponent[] -
igxSplitterPane
Name Description Cancelable Arguments onPaneToggle Emits when pane visibility is toggled false IgxSplitterPaneComponent
A
Key | Result |
---|---|
Arrow up | Move the splitter element up |
Arrow down | Move the splitter element down |
Arrow left | Move the splitter element left |
Arrow right | Move the splitter element right |
Ctrl + Arrow | Expand/Collapse a pane with regard to the direction indicated by the arrow |
A
A
A
- Should allow defining a vertical/horizontal splitter with panes.
- Should allow defining nested splitters.
- Should allow resizing the panes using the spliiter bar via drag.
- Should allow collapsing/expading panes via the splitter bar buttons.
While focus is on the splitter bar:
- Should allow moving the splitter bar left/right/up/down via the arrow keys in order to resize the related panes.
- Should allow expanding/collapsing panes using CTRL+ arrow keys.
- Should allow defining minSize/maxSize limit for a pane.
- Should prevent resize if pane is set to not be resizable.
- Should allow toggling a pane via the
togglePane
API method. - Should emit
onPaneToggle
when pane is toggled.
- S
- S