open-nomad/ui/app/components/list-accordion.js

36 lines
980 B
JavaScript
Raw Normal View History

import Component from '@ember/component';
import { computed, get } from '@ember/object';
import { computed as overridable } from 'ember-overridable-computed';
export default Component.extend({
classNames: ['accordion'],
key: 'id',
source: overridable(() => []),
onToggle(/* item, isOpen */) {},
startExpanded: false,
decoratedSource: computed('source.[]', function() {
2019-03-26 07:46:44 +00:00
const stateCache = this.stateCache;
const key = this.key;
const deepKey = `item.${key}`;
2019-03-26 07:46:44 +00:00
const startExpanded = this.startExpanded;
2019-03-26 07:46:44 +00:00
const decoratedSource = this.source.map(item => {
const cacheItem = stateCache.findBy(deepKey, get(item, key));
return {
item,
isOpen: cacheItem ? !!cacheItem.isOpen : startExpanded,
};
});
this.set('stateCache', decoratedSource);
return decoratedSource;
}),
// When source updates come in, the state cache is used to preserve
// open/close state.
stateCache: overridable(() => []),
});