mirror of
https://github.com/status-im/consul.git
synced 2025-01-17 17:22:17 +00:00
b2ecc65d21
* Create PopoverSelect component and styling * Create CatalogToolbar component and Styling * ui: Adds `selectable-key-values` helper (#7472) Preferably we want all copy/text to live in the template. Whilst you can achieve what we've done here with a combination of different helpers, as we will be using this approach in various places it's probably best to make a helper. We also hit an ember bug related to using the `let` helper and trying to access `thingThatWasLet.firstObject` (which can also be worked around using `object-at`). Moving everything to a helper 'sorted' everything. Probably worthwhile noting that if the sort option themselves become dynamic, I'm not sure if the helper here would actually react as you would expect (I'm aware that ember helpers on react on the root arguments, not necesarily sub properties of those arguments). If we get to that point this helper could take the same approach as what I believe ember-composable-helpers does to get around this, or move them to the view controller. If we do ever moved this to the view controller, we can still use the exported function from the new helper here to keep using the same functionality and tests we have here. * Create tests for sorting services with CatalogToolbar * Add rule to print 'ember/no-global-jquery' as a warning Co-authored-by: John Cowen <johncowen@users.noreply.github.com>
47 lines
1.0 KiB
JavaScript
47 lines
1.0 KiB
JavaScript
import { helper } from '@ember/component/helper';
|
|
import { slugify } from 'consul-ui/helpers/slugify';
|
|
export const selectableKeyValues = function(params = [], hash = {}) {
|
|
let selected;
|
|
|
|
const items = params.map(function(item, i) {
|
|
let key, value;
|
|
switch (typeof item) {
|
|
case 'string':
|
|
key = slugify([item]);
|
|
value = item;
|
|
break;
|
|
default:
|
|
if (item.length > 1) {
|
|
key = item[0];
|
|
value = item[1];
|
|
} else {
|
|
key = slugify([item[0]]);
|
|
value = item[0];
|
|
}
|
|
break;
|
|
}
|
|
const kv = {
|
|
key: key,
|
|
value: value,
|
|
};
|
|
switch (typeof hash.selected) {
|
|
case 'string':
|
|
if (hash.selected === item[0]) {
|
|
selected = kv;
|
|
}
|
|
break;
|
|
case 'number':
|
|
if (hash.selected === i) {
|
|
selected = kv;
|
|
}
|
|
break;
|
|
}
|
|
return kv;
|
|
});
|
|
return {
|
|
items: items,
|
|
selected: typeof selected === 'undefined' ? items[0] : selected,
|
|
};
|
|
};
|
|
export default helper(selectableKeyValues);
|