Skip to content

Latest commit

 

History

History
492 lines (431 loc) · 19.9 KB

README.md

File metadata and controls

492 lines (431 loc) · 19.9 KB

Selection

The selection components (d2l-selection-action, d2l-selection-input, d2l-selection-select-all, d2l-selection-summary, d2l-selection-action) are low-level components that provide the ability to create selection interfaces with select-all and bulk-action behaviours.

Use Case

The d2l-list already extends SelectionMixin and should always be used for lists, however a custom selection control can be defined to enable the use of these selection controls in different semantic contexts or radically different layouts. See SelectionMixin.

SelectionMixin

The SelectionMixin enables the creation of custom selection control components. The selection components below work with a component that extends the SelectionMixin which acts like a controller for the checkboxes, radios, actions and other selection components. The selection components below must be contained within a component that extends the SelectionMixin. The d2l-selection-input component must be placed within the component that extends the SelectionMixin. The other selection components may also be placed inside the SelectionMixin component, or in the same DOM scope with the selection-for attribute set to the id of that component.

The SelectionMixin defines the selection-single attribute that consumers can specify for single selection behaviour.

<script type="module">
  import { css, html, LitElement } from 'lit';
  import { SelectionMixin } from '@brightspace-ui/core/components/selection/selection-mixin.js';

  class DemoSelection extends SelectionMixin(LitElement) {
    static get styles() {
      return css`
        :host {
          display: block;
        }
      `;
    }
    render() {
      return html`
        <slot></slot>
      `;
    }
  }
  customElements.define('d2l-demo-selection', DemoSelection);
</script>
<script type="module">
  import '@brightspace-ui/core/components/selection/selection-action.js';
  import '@brightspace-ui/core/components/selection/selection-controls.js';
  import '@brightspace-ui/core/components/selection/selection-input.js';
  import '@brightspace-ui/core/components/selection/selection-select-all.js';
  import '@brightspace-ui/core/components/selection/selection-summary.js';
</script>
<!-- docs: start hidden content -->
<script type="module">
  import '@brightspace-ui/core/components/selection/demo/demo-selection.js';
</script>
<style>
  ul {
    padding: 0;
  }
  li {
    list-style-type: none;
    align-items: center;
    display: flex;
  }
  d2l-selection-input {
    margin-right: 10px;
  }
  [dir="rtl"] d2l-selection-input {
    margin-left: 10px;
    margin-right: 0;
  }
</style>
<!-- docs: end hidden content -->
<d2l-demo-selection>
  <d2l-selection-controls no-sticky>
    <d2l-selection-action text="Bookmark" icon="tier1:bookmark-hollow" requires-selection></d2l-selection-action>
    <d2l-selection-action text="Settings" icon="tier1:gear"></d2l-selection-action>
  </d2l-selection-controls>
  <ul>
    <li><d2l-selection-input key="geo" label="Geography" selected></d2l-selection-input>Geography</li>
    <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
    <li><d2l-selection-input key="mth" label="Math"></d2l-selection-input>Math</li>
  </ul>
</d2l-demo-selection>

Properties

Property Type Description
item-count Number Total number of items. Required when selecting all pages is allowed.
selection-single Boolean Whether to render with single selection behaviour. If selection-single is specified, the nested d2l-selection-input elements will render radios instead of checkboxes, and the selection component will maintain a single selected item.

Usage

Define a custom web component that extends the SelectionMixin. The selection components can then be used within the custom selection component as shown above, or the non-d2l-selection-input components can be used outside the custom selection component as long as they are in the same DOM scope:

<div>
  <d2l-selection-select-all selection-for="custom"></d2l-selection-select-all>
  <d2l-selection-action selection-for="custom" text="Settings" icon="tier1:gear"></d2l-selection-action>
  <d2l-selection-summary selection-for="custom"></d2l-selection-summary>
</div>
<d2l-demo-selection id="custom">
  <ul>
    <li><d2l-selection-input key="geo" label="Geography" selected></d2l-selection-input>Geography</li>
    <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
  </ul>
</d2l-demo-selection>

Selection Action [d2l-selection-action]

The d2l-selection-action is an optional component that provides a button for actions associated with the selection control (ex. bulk actions). The requires-selection attribute may be specified to indicate that the button should be non-interactive if nothing is selected.

<script type="module">
  import '@brightspace-ui/core/components/selection/selection-action.js';
</script>
<d2l-selection-action text="Bookmark" icon="tier1:bookmark-hollow"></d2l-selection-action>

Properties

Property Type Description
icon String Preset icon key (e.g. "tier1:gear").
requires-selection Boolean Whether the action requires one or more selected items. If no items are selected, the action button will be focusable and a hint displayed in a tooltip.
selection-for String Id of the corresponding SelectionMixin component, if not placed within it.
text String, required Text to be shown for the action.

Events

Event Description
d2l-selection-action-click Dispatched when the user clicks the action button. The SelectionInfo is provided as the event detail. If requires-selection was specified then the event will only be dispatched if items are selected.

Selection Action Dropdown [d2l-selection-action-dropdown]

The d2l-selection-action-dropdown is an optional component that provides a button opener for dropdown content associated with the selection control (ex. bulk actions). The requires-selection attribute may be specified to indicate that the opener should be non-interactive if nothing is selected.

<script type="module">
  import '@brightspace-ui/core/components/dropdown/dropdown-menu.js';
  import '@brightspace-ui/core/components/menu/menu.js';
  import '@brightspace-ui/core/components/selection/selection-action-dropdown.js';
</script>
<d2l-selection-action-dropdown text="Actions" requires-selection>
  <d2l-dropdown-menu>
    <d2l-menu label="Actions">
      <!-- This is where you add instances of <d2l-selection-action-menu-item>. -->
    </d2l-menu>
  </d2l-dropdown-menu>
</d2l-selection-action-dropdown>

Properties

Property Type Description
requires-selection Boolean Whether the action dropdown opener requires one or more selected items. If no items are selected, the opener will be focusable and a hint displayed in a tooltip.
selection-for String Id of the corresponding SelectionMixin component, if not placed within it.
text String, required Text for the dropdown opener button.

Selection Action Menu Item [d2l-selection-action-menu-item]

The d2l-selection-action-menu-item is an optional component that is a menu item for actions associated with the selection control (ex. bulk actions). The requires-selection attribute may be specified to indicate that the menu item should be non-interactive if nothing is selected. This component enables the app to define an opener that is enabled regardless of the selection state, while having a menu containing one or more menu items that requires-selection.

<script type="module">
  import '@brightspace-ui/core/components/dropdown/dropdown-button-subtle.js';
  import '@brightspace-ui/core/components/dropdown/dropdown-menu.js';
  import '@brightspace-ui/core/components/menu/menu.js';
  import '@brightspace-ui/core/components/selection/selection-action-menu-item.js';
</script>
<d2l-dropdown-button-subtle text="Actions">
  <d2l-dropdown-menu>
    <d2l-menu label="Actions">
      <d2l-selection-action-menu-item text="Action 1" requires-selection></d2l-selection-action-menu-item>
      <d2l-selection-action-menu-item text="Action 2"></d2l-selection-action-menu-item>
    </d2l-menu>
  </d2l-dropdown-menu>
</d2l-dropdown-button-subtle>

Properties

Property Type Description
requires-selection Boolean Whether the action menu-item requires one or more selected items.
selection-for String Id of the corresponding SelectionMixin component, if not placed within it.
text String, required Text to be shown for the action menu-item.

Events

Event Description
d2l-selection-action-click Dispatched when the user clicks the action menu-item. The SelectionInfo is provided as the event detail. If requires-selection was specified then the event will only be dispatched if items are selected.

Selection Input [d2l-selection-input]

The d2l-selection-input is a required component in selection controls - without it, there wouldn't be anything for the user to select! This component must be placed within the selection control.

If d2l-selection-input is placed within a selection control that specifies selection-single, then radios will be rendered instead of checkboxes.

Note: d2l-list-item already provides a selection input for selectable list items.

<script type="module">
  import '@brightspace-ui/core/components/selection/selection-input.js';
  import '@brightspace-ui/core/components/selection/demo/demo-selection.js';
</script>
<!-- docs: start hidden content -->
<style>
  ul {
    padding: 0;
  }
  li {
    list-style-type: none;
    align-items: center;
    display: flex;
  }
  d2l-selection-input {
    margin-right: 10px;
  }
</style>
<!-- docs: end hidden content -->
<d2l-demo-selection>
  <ul>
    <li><d2l-selection-input key="geo" label="Geography" selected></d2l-selection-input>Geography</li>
    <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
    <li><d2l-selection-input key="mat" label="Math"></d2l-selection-input>Math</li>
  </ul>
</d2l-demo-selection>

Properties

Property Type Description
key String, required Key to identify the selectable.
label String Accessible hidden label for the input.
labelled-by String Id reference to the accessible label for the input. Note: if specified, it must reference an element in the same DOM context.
disabled Boolean Disables the input element(checkbox/radio btn).
selected Boolean State of the input.

Events

Event Description
d2l-selection-change Dispatched when the state of the input changes.

Accessibility Properties

Either label or labelled-by is required.

Select All [d2l-selection-select-all]

The d2l-selection-select-all is an optional component that provides a checkbox for bulk selecting the selectable elements within the selection control. Its state will also be automatically updated when the state of the selectable elements change.

The d2l-selection-select-all component may be placed inside the selection control, or in the same DOM scope with the selection-for attribute set to the id of that component. In the example below, setting selection-for to other-list demonstrates the ability to use d2l-selection-select-all from outside of the selection control component.

<script type="module">
  import '@brightspace-ui/core/components/selection/selection-action.js';
  import '@brightspace-ui/core/components/selection/selection-input.js';
  import '@brightspace-ui/core/components/selection/selection-select-all.js';
  import '@brightspace-ui/core/components/selection/demo/demo-selection.js';
</script>
<!-- docs: start hidden content -->
<style>
  body {
    overflow-y: hidden;
  }
  .container {
    justify-content: center;
  }
  #other-list {
    padding-top: 2.1rem;
    margin-left: 5rem;
  }
  ul {
    margin: 0;
    padding: 0;
  }
  li {
    align-items: center;
    display: flex;
    list-style-type: none;
  }
  div {
    align-items: center;
    display: flex;
  }
  d2l-selection-input {
    margin-right: 10px;
  }
  @media only screen and (max-width: 350px) {
    .container {
      align-items: flex-start;
      flex-direction: column;
      margin-right: 15px;
    }
    #other-list {
      margin-left: 0;
    }
  }
</style>
<!-- docs: end hidden content -->
<div class="container">
  <d2l-demo-selection>
    <div>
      <d2l-selection-select-all></d2l-selection-select-all>
      <d2l-selection-action text="Bookmark" icon="tier1:bookmark-hollow" requires-selection></d2l-selection-action>
    </div>
    <ul>
      <li><d2l-selection-input key="geo" label="Geography"></d2l-selection-input>Geography</li>
      <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
      <li><d2l-selection-input key="mat" label="Math" disabled></d2l-selection-input>Math</li>
    </ul>
  </d2l-demo-selection>
  <d2l-demo-selection id="other-list">
    <ul>
      <li><d2l-selection-input key="ear" label="Earth"></d2l-selection-input>Earth</li>
      <li><d2l-selection-input key="mar" label="Mars"></d2l-selection-input>Mars</li>
      <li><d2l-selection-input key="jup" label="Jupiter"></d2l-selection-input>Jupiter</li>
    </ul>
  </d2l-demo-selection>
</div>

Properties

Property Type Description
disabled Boolean Disables the select all checkbox
selection-for String Id of the corresponding SelectionMixin component, if not placed within it.

Selection Summary [d2l-selection-summary]

The d2l-selection-summary is an optional component that shows a simple count of the selected items within the selection control.

The d2l-selection-summary component may be placed inside the selection control, or in the same DOM scope with the selection-for attribute set to the id of that component. In the example below, setting selection-for to other-list demonstrates the ability to use d2l-selection-summary from outside of the selection control component.

<script type="module">
  import '@brightspace-ui/core/components/selection/selection-action.js';
  import '@brightspace-ui/core/components/selection/selection-input.js';
  import '@brightspace-ui/core/components/selection/selection-summary.js';
  import '@brightspace-ui/core/components/selection/demo/demo-selection.js';
</script>
<!-- docs: start hidden content -->
<style>
  body {
    overflow-y: hidden;
  }
  .container {
    display: flex;
    justify-content: center;
  }
  #other-list {
    padding-top: 1rem;
    margin-left: 5rem;
  }
  ul {
    margin: 0;
    padding: 0;
  }
  li {
    align-items: center;
    display: flex;
    list-style-type: none;
  }
  div {
    align-items: center;
    display: flex;
  }
  d2l-selection-input {
    margin-right: 10px;
  }
  @media only screen and (max-width: 350px) {
    .container {
      align-items: flex-start;
      flex-direction: column;
    }
    #other-list {
      margin-left: 0;
    }
  }
</style>
<!-- docs: end hidden content -->
<div class="container">
  <d2l-demo-selection>
    <div>
      <d2l-selection-action text="Bookmark" icon="tier1:bookmark-hollow" requires-selection></d2l-selection-action>
      <d2l-selection-summary></d2l-selection-summary>
    </div>
    <ul>
      <li><d2l-selection-input key="geo" label="Geography"></d2l-selection-input>Geography</li>
      <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
      <li><d2l-selection-input key="mat" label="Math" disabled></d2l-selection-input>Math</li>
    </ul>
  </d2l-demo-selection>
  <d2l-demo-selection id="other-list">
    <ul>
      <li><d2l-selection-input key="ear" label="Earth"></d2l-selection-input>Earth</li>
        <li><d2l-selection-input key="mar" label="Mars"></d2l-selection-input>Mars</li>
        <li><d2l-selection-input key="jup" label="Jupiter"></d2l-selection-input>Jupiter</li>
    </ul>
  </d2l-demo-selection>
</div>

Properties

Property Type Description
no-selection-text String Text to display if no items are selected. By default, the "0 selected" message is displayed.
selection-for String Id of the corresponding SelectionMixin component, if not placed within it.

Selection Controls [d2l-selection-controls]

The d2l-selection-controls provides a standardized wrapper to display selection information and actions. It includes a select-all checkbox, summary, a slot for d2l-selection-actions, and overflow-group behaviour.

When using lists, use the list-specific d2l-list-controls instead, which extends this component's behaviour.

<script type="module">
  import '@brightspace-ui/core/components/selection/selection-action.js';
  import '@brightspace-ui/core/components/selection/selection-controls.js';
  import '@brightspace-ui/core/components/selection/selection-input.js';
  import '@brightspace-ui/core/components/selection/demo/demo-selection.js';
</script>
<!-- docs: start hidden content -->
<style>
  #demo-element {
    margin-bottom: 250px;
    margin-top: 0;
  }
  ul {
    padding: 0;
  }
  li {
    list-style-type: none;
    align-items: center;
    display: flex;
  }
  d2l-selection-input {
    margin-right: 10px;
  }
  [dir="rtl"] d2l-selection-input {
    margin-left: 10px;
    margin-right: 0;
  }
</style>
<!-- docs: end hidden content -->
<d2l-demo-selection>
  <d2l-selection-controls>
    <d2l-selection-action text="Bookmark" icon="tier1:bookmark-hollow" requires-selection></d2l-selection-action>
    <d2l-selection-action text="Settings" icon="tier1:gear"></d2l-selection-action>
  </d2l-selection-controls>
  <ul>
    <li><d2l-selection-input key="geo" label="Geography" selected></d2l-selection-input>Geography</li>
    <li><d2l-selection-input key="sci" label="Science"></d2l-selection-input>Science</li>
    <li><d2l-selection-input key="mth" label="Math"></d2l-selection-input>Math</li>
  </ul>
</d2l-demo-selection>

Properties

Property Type Description
no-selection Boolean Whether to render select-all and selection summary
no-selection-text String Text to display if no items are selected (overrides pageable counts)
no-sticky Boolean Disables sticky positioning for the controls
select-all-pages-allowed Boolean Whether all pages can be selected