mirror of
https://github.com/status-im/consul.git
synced 2025-01-19 02:03:00 +00:00
e4e85a8f83
* Add before and after skip links portals * Move EmptyState and ErrorState to use a @login action/function * Move page title setting to the Route component * Add Routes and Outlets everywhere, and use those to access login modal * Add some aria-labels to the modals * Docs * Remove the label/input now we no longer need it, fixup pageobject * Add basic modal docs * Switch out old toggle names for ids * Wrap nspace Route template in a Route component * type > class
--- class: ember --- # ModalDialog ## Arguments | Argument | Type | Default | Description | | --- | --- | --- | --- | | `onopen` | `Function` | `undefined` | A function to call when the modal has opened | | `onclose` | `Function` | `undefined` | A function to call when the modal has closed | | `aria` | `Object` | `undefined` | A `hash` of aria properties used in the component, currently only label is supported | ## Exports | Name | Type | Description | | --- | --- | --- | | `open` | `Function` | Opens the modal dialog | | `close` | `Function` | Closes the modal dialog | Works in tandem with `<ModalLayer />` to render modals. First of all ensure you have a modal layer on the page (it doesn't have to be in the same template) ```hbs <ModalLayer /> ``` Then all modals will be rendered into the `<ModalLayer />` for example: ```hbs preview-template <ModalDialog @onclose={{noop}} @onopen={{noop}} @aria={{hash label="Screenread name of the modal" }} as |modal|> <!-- Save a reference to the modal component so we can call its methods --> {{did-insert (set this 'modal' modal)}} <BlockSlot @name="header"> <h2> Modal Header </h2> </BlockSlot> <BlockSlot @name="body"> <p> Modal body </p> </BlockSlot> <BlockSlot @name="actions"> <button type="button" {{on "click" modal.close}} > Close modal </button> </BlockSlot> </ModalDialog> <button type="button" {{on 'click' (optional this.modal.open)}} > Open Modal </button> ```