24681398af
refs https://ghost.slack.com/archives/CTH5NDJMS/p1675194453354469 https://secure.helpscout.net/conversation/2127479135/94711 - replaced tiers filtering by `slug` with `id` as we hit an edge case where the NQL filtering is struggling to handle slugs with a single character, eg `a`, `b`. Now filters by the tier's `id` instead. - added new member, `tier_id` relation to make it possible to filter by id, eg `/?filter=tier_id:<id>`.
101 lines
2.7 KiB
JavaScript
101 lines
2.7 KiB
JavaScript
import Component from '@glimmer/component';
|
|
import {action} from '@ember/object';
|
|
import {inject as service} from '@ember/service';
|
|
import {task} from 'ember-concurrency';
|
|
import {tracked} from '@glimmer/tracking';
|
|
|
|
export default class TiersSegmentSelect extends Component {
|
|
@service store;
|
|
@service feature;
|
|
|
|
@tracked _options = [];
|
|
@tracked tiers = [];
|
|
|
|
get renderInPlace() {
|
|
return this.args.renderInPlace === undefined ? false : this.args.renderInPlace;
|
|
}
|
|
|
|
constructor() {
|
|
super(...arguments);
|
|
this.fetchOptionsTask.perform();
|
|
}
|
|
|
|
get options() {
|
|
return this._options;
|
|
}
|
|
|
|
get flatOptions() {
|
|
const options = [];
|
|
|
|
function getOptions(option) {
|
|
if (option.options) {
|
|
return option.options.forEach(getOptions);
|
|
}
|
|
|
|
options.push(option);
|
|
}
|
|
|
|
this._options.forEach(getOptions);
|
|
|
|
return options;
|
|
}
|
|
|
|
get selectedOptions() {
|
|
const tierList = (this.args.tiers || []).map((tier) => {
|
|
return this.tiers.find((p) => {
|
|
return p.id === tier.id || p.id === tier.id;
|
|
});
|
|
}).filter(d => !!d);
|
|
const tierIdList = tierList.map(d => d.id);
|
|
return this.flatOptions.filter(option => tierIdList.includes(option.id));
|
|
}
|
|
|
|
@action
|
|
setSegment(options) {
|
|
let ids = options.mapBy('id').map((id) => {
|
|
let tier = this.tiers.find((p) => {
|
|
return p.id === id;
|
|
});
|
|
return {
|
|
id: tier.id,
|
|
slug: tier.slug,
|
|
name: tier.name
|
|
};
|
|
}) || [];
|
|
this.args.onChange?.(ids);
|
|
}
|
|
|
|
@task
|
|
*fetchOptionsTask() {
|
|
const options = yield [];
|
|
|
|
// fetch all tiers with count
|
|
// TODO: add `include: 'count.members` to query once API supports
|
|
const tiers = yield this.store.query('tier', {filter: 'type:paid', limit: 'all', include: 'monthly_price,yearly_price,benefits'});
|
|
this.tiers = tiers;
|
|
|
|
if (tiers.length > 0) {
|
|
const tiersGroup = {
|
|
groupName: 'Tiers',
|
|
options: []
|
|
};
|
|
|
|
tiers.forEach((tier) => {
|
|
tiersGroup.options.push({
|
|
name: tier.name,
|
|
id: tier.id,
|
|
count: tier.count?.members,
|
|
class: 'segment-tier'
|
|
});
|
|
});
|
|
|
|
options.push(tiersGroup);
|
|
if (this.args.selectDefaultTier && !this.args.tiers) {
|
|
this.setSegment([tiersGroup.options[0]]);
|
|
}
|
|
}
|
|
|
|
this._options = options;
|
|
}
|
|
}
|