Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coachlogix/ember-paper-selection-dialog
Selection dialogs for ember-paper.
https://github.com/coachlogix/ember-paper-selection-dialog
dialog ember ember-paper material-design selection
Last synced: 2 months ago
JSON representation
Selection dialogs for ember-paper.
- Host: GitHub
- URL: https://github.com/coachlogix/ember-paper-selection-dialog
- Owner: CoachLogix
- License: mit
- Created: 2017-02-09T16:48:45.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-10-20T15:17:20.000Z (over 6 years ago)
- Last Synced: 2024-11-16T17:40:49.373Z (2 months ago)
- Topics: dialog, ember, ember-paper, material-design, selection
- Language: JavaScript
- Homepage: https://coachlogix.github.io/ember-paper-selection-dialog/
- Size: 518 KB
- Stars: 11
- Watchers: 6
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# ember-paper-selection-dialog [![Build Status](https://travis-ci.org/CoachLogix/ember-paper-selection-dialog.svg?branch=master)](https://travis-ci.org/CoachLogix/ember-paper-selection-dialog) [![Ember Observer Score](http://emberobserver.com/badges/ember-paper-selection-dialog.svg)](http://emberobserver.com/addons/ember-paper-selection-dialog)
This is an [ember-paper](https://github.com/miguelcobain/ember-paper) addon that provides dialogs for selections. Think of it as a select component, but using dialogs.
## Usage
An example usage:
```hbs
{{#paper-selection-dialog
title="Select a country" class="flex-50" fullscreen=true
options=options selected=singleSelected
onSelect=(action (mut singleSelected)) onClose=(action (mut showSingle) false) as |option index selected|}}
{{option}} {{if selected "Yay, I'm selected"}} #{{index}}
{{/paper-selection-dialog}}
```The component is promise friendly, meaning that it accepts promises in `options` or `selected` properties and will display a `{{paper-circular-progress}}` until both are resolved.
You must specify how you want to render each item in the component's block. Each option is yielded to the block, along with its index. A boolean is also yielded to let you know if that option is currently selected or not.
## Demo
You can see how this addon looks like at https://coachlogix.github.io/ember-paper-selection-dialog/
## Installation
Run:
```bash
ember install ember-paper-selection-dialog
```Don't forget to import your styles in your `app.scss` **after** importing ember paper styles:
```scss
@import "ember-paper";
@import "ember-paper-selection-dialog";
```## API
- All the properties that `paper-dialog` supports.
- `multiple` - defaults to `false` - set it to `true` to support multiple selections.
- `options` - an array or promise that resolves to an array that contains the possible options to choose from.
- `selected` - the currently selected items. Can also be a promise.
- `onSelect` - an action sent when the user clicks the confirm button. Will contain an option on single mode and an array of options on multiple mode.
- `onClose` - an action sent when the cancel or close button are pressed (also sent every time `paper-dialog` sends it)
- `cancelLabel` - defaults to `'Cancel'` - you can specify an alternate text for the cancel button
- `confirmLabel` - defaults to `'Confirm'` - you can specify an alternate text for the confirm button
- `title` - the displayed title of the dialog
- `closeOnConfirm` - defaults to `true` - by default the component will also send the `onClose` action when you click the confirm button
- `noOptionsMessage` - defaults to `'No options.'` - you can specify a message to show when `options` is or resolves to a falsy valueContributing
------------------------------------------------------------------------------### Installation
* `git clone `
* `cd my-addon`
* `npm install`### Linting
* `npm run lint:hbs`
* `npm run lint:js`
* `npm run lint:js -- --fix`### Running tests
* `ember test` – Runs the test suite on the current Ember version
* `ember test --server` – Runs the test suite in "watch mode"
* `ember try:each` – Runs the test suite against multiple Ember versions### Running the dummy application
* `ember serve`
* Visit the dummy application at [http://localhost:4200](http://localhost:4200).For more information on using ember-cli, visit [https://ember-cli.com/](https://ember-cli.com/).
License
------------------------------------------------------------------------------This project is licensed under the [MIT License](LICENSE.md).