Skip to content

Commit

Permalink
Merge pull request #49 from unicef-polymer/selected-values-improvement
Browse files Browse the repository at this point in the history
Selected values improvement
  • Loading branch information
adi130987 authored Feb 27, 2017
2 parents 73a5fab + ffc0dd7 commit 371d198
Show file tree
Hide file tree
Showing 5 changed files with 219 additions and 115 deletions.
37 changes: 19 additions & 18 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,32 +5,33 @@ Dropdown menu with search and multiple options selection
### Element properties


* allowOutsideScroll - boolean, default: false
* autoValidate - boolean
* customObjectOptions - Boolean, Default: false
* disabled - Boolean Default: false
* dynamicAlign - Boolean Default: false
* emptyValue - Boolean Default: false
* customObjectOptions - Boolean, default: false
* disabled - Boolean, default: false
* dynamicAlign - Boolean, default: false
* emptyValue - Boolean, default: false
* errorMessage - string
* falseValue - Boolean Default: false
* hideSearch - Boolean Default: false
* falseValue - Boolean, default: false
* hideSearch - Boolean, default: false
* invalid - boolean
* label - String
* menuOpened - Boolean Default: false – notifies
* multi - Boolean Default: false
* noChangeEvent - Boolean, Default: false
* optionLabel - String, Default: label
* menuOpened - Boolean, default: false – notifies
* multi - Boolean, default: false
* noChangeEvent - Boolean, default: false
* optionLabel - String, default: label
* options - Array
* optionValue - String, Default: 'value'
* optionValue - String, default: 'value'
* placeholder - string
* readonly - Boolean, Default: false
* readonly - Boolean, default: false
* required - boolean
* search - String
* selected - Number/Array - notifies
* selectedValues - Object notifies
* showLimitWarning - Boolean
* shownItems - Array
* shownItemsLimit - Number Default: 50
* updateSelected - Boolean, Default: false
* shownItemsLimit - Number, default: 50
* updateSelected - Boolean, default: false
* value - String

## Usage
Expand Down Expand Up @@ -159,9 +160,9 @@ customObjOptions: {
on-value-change="_singleSelectionChanged"></etools-searchable-multiselection-menu>
```

If you need only select an option and get option ID (most use cases) or an array of IDs(for multiselection)
you can use `selected` property of the element. It only works for integer values, for other types use `selectedValues` property.
Additionally you can chose to block the change event. Example:
If you need only to bind a custom element property to the esmm dropdown use `selected` property
to update dropdown's selection or get selected value(s).
In this case change event is automatically disabled. Example:

```html
<p>SelectedID: [[selectedId]]</p>
Expand All @@ -172,7 +173,7 @@ Additionally you can chose to block the change event. Example:
option-value="id"
option-label="option_label"
selected="{{selectedId}}"
update-selected no-change-event>
update-selected>
</etools-searchable-multiselection-menu>
```

Expand Down
2 changes: 1 addition & 1 deletion bower.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "etools-searchable-multiselection-menu",
"description": "Dropdown menu with search and multiple options selection",
"version": "1.0.26",
"version": "1.0.27",
"license": "https://github.com/unicef-polymer/etools-searchable-multiselection-menu/blob/master/LICENSE.md",
"main": "etools-searchable-multiselection-menu.html",
"dependencies": {
Expand Down
104 changes: 31 additions & 73 deletions demo/demo-custom-objects-as-options.html
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,6 @@

<dom-module id="demo-custom-objects-as-options">
<template>
<h3>Old way type of objects with integer value and label string (still working)</h3>
<etools-searchable-multiselection-menu
label="Searchable menu"
options="[[realOptions]]"
on-value-change="_singleSelectionChanged"></etools-searchable-multiselection-menu>

<h3>Single selection, custom objects as options</h3>
<etools-searchable-multiselection-menu
Expand All @@ -16,15 +11,7 @@ <h3>Single selection, custom objects as options</h3>
custom-object-options
option-value="option_key"
option-label="option_label"
on-value-change="_singleSelectionChanged"></etools-searchable-multiselection-menu>

<h3>Multiple selection. Old way type of objects with integer value and label string (still working)</h3>
<etools-searchable-multiselection-menu
label="Multi searchable menu"
options="[[realOptions]]"
placeholder="Please select the options"
on-value-change="_multiSelectionChanged"
multi></etools-searchable-multiselection-menu>
on-value-change="_singleSelectionChanged" dynamic-align></etools-searchable-multiselection-menu>

<h3>Multiple selection, custom objects as options</h3>
<etools-searchable-multiselection-menu
Expand All @@ -35,7 +22,7 @@ <h3>Multiple selection, custom objects as options</h3>
option-label="option_label"
placeholder="Please select the options"
on-value-change="_multiSelectionChanged"
multi></etools-searchable-multiselection-menu>
multi dynamic-align></etools-searchable-multiselection-menu>

<h3>Custom objects as options and selected property with no change events</h3>

Expand All @@ -47,7 +34,7 @@ <h3>Custom objects as options and selected property with no change events</h3>
option-value="id"
option-label="option_label"
selected="{{selectedId}}"
update-selected no-change-event></etools-searchable-multiselection-menu>
update-selected dynamic-align style="width: 350px;"></etools-searchable-multiselection-menu>

<p><span>SelectedIDs:</span> [[_returnIdsString(selectedIds)]]</p>
<etools-searchable-multiselection-menu
Expand All @@ -57,32 +44,10 @@ <h3>Custom objects as options and selected property with no change events</h3>
option-value="id"
option-label="option_label"
selected="{{selectedIds}}"
update-selected no-change-event
update-selected
placeholder="Please select the options"
multi></etools-searchable-multiselection-menu>

<h3>A few options selected by default example</h3>
<etools-searchable-multiselection-menu
label="Searchable menu, custom objects"
options="[[customObjOptions]]"
value="[[selectedObjOptions]]"
custom-object-options
option-value="option_key"
option-label="option_label"
on-value-change="_singleSelectionChanged"></etools-searchable-multiselection-menu>

<etools-searchable-multiselection-menu
label="Multi searchable menu, custom objects"
options="[[customObjOptions]]"
value="[[selectedObjOptions]]"
custom-object-options
option-value="id"
option-label="option_label"
selected="{{selectedIds}}"
update-selected no-change-event
placeholder="Please select the options"
multi></etools-searchable-multiselection-menu>

multi
dynamic-align></etools-searchable-multiselection-menu>

</template>
<script>
Expand All @@ -108,48 +73,29 @@ <h3>A few options selected by default example</h3>

customObjOptions: {
type: Array,
value: function() {
var opt = [];
for(var i = 1; i <= 100; i++) {
opt.push({
id: i,
option_key: 'opt' + i,
option_label: 'Option ' + i,
some_other_property: 'dummy propery for objIdx' + (i -1)
});
}
return opt;
}
},

selectedObjOptions: {
type: Array,
value: function() {
var opt = [];
for(var i = 3; i <= 5; i++) {
opt.push({
id: i,
option_key: 'opt' + i,
option_label: 'Option ' + i,
some_other_property: 'dummy propery for objIdx' + (i -1)
});
}
return opt;
}
value: []
},

selectedId: {
type: Number,
value: null
value: 1001
},
selectedIds: {
type: Array,
value: []
value: [3, 5, 7, 101, 102]
}
},

ready: function() {
// this.set('selectedValues', [{value: 2, label: 'Option 2'}]);
// this.set('selectedValues', [{value: 2, label: 'Option 2'}]);
// this.set('selectedId', 3);

setTimeout(function() {
this.set('customObjOptions', this.generateOptions());
}.bind(this), 3000);

// setTimeout(function() {
// this.set('selectedId', 3);
// }.bind(this), 3000);
},

_returnIdsString: function(vals) {
Expand All @@ -162,6 +108,18 @@ <h3>A few options selected by default example</h3>

_multiSelectionChanged: function(event) {
console.log('_multiSelectionChanged', event.detail);
},
generateOptions: function() {
var opt = [];
for(var i = 1; i <= 100; i++) {
opt.push({
id: i,
option_key: 'opt' + i,
option_label: 'Option ' + i,
some_other_property: 'dummy propery for objIdx' + (i -1)
});
}
return opt;
}
});

Expand Down
3 changes: 2 additions & 1 deletion demo/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@

<div class="vertical-section-container centered">
<h1>etools-searchable-multiselection-menu demo</h1>

<h2>Single selection, with search</h2>
<demo-snippet>
<template is="dom-bind">
Expand Down Expand Up @@ -131,6 +131,7 @@ <h2>Error messages and validations</h2>
<demo-error-messages-and-validations></demo-error-messages-and-validations>
</template>
</demo-snippet>


<h2>Custom objects as options. You can specify value and label properties from object option to be used.</h2>

Expand Down
Loading

0 comments on commit 371d198

Please sign in to comment.