2022-03-22 18:37:17 +03:00
|
|
|
import Component from '@glimmer/component';
|
2022-03-23 18:38:16 +03:00
|
|
|
import {action} from '@ember/object';
|
|
|
|
import {inject as service} from '@ember/service';
|
2022-03-24 11:38:30 +03:00
|
|
|
import {tracked} from '@glimmer/tracking';
|
|
|
|
|
|
|
|
const MODE_OPTIONS = [{
|
|
|
|
name: 'Cadence',
|
|
|
|
value: 'cadence'
|
|
|
|
}, {
|
|
|
|
name: 'Tiers',
|
|
|
|
value: 'tiers'
|
|
|
|
}];
|
2022-03-22 18:37:17 +03:00
|
|
|
|
|
|
|
export default class ChartPaidMix extends Component {
|
2022-03-23 18:38:16 +03:00
|
|
|
@service dashboardStats;
|
|
|
|
|
|
|
|
/**
|
2022-03-31 10:33:18 +03:00
|
|
|
* Call this method when you need to fetch new data from the server.
|
2022-03-23 18:38:16 +03:00
|
|
|
*/
|
|
|
|
@action
|
|
|
|
loadCharts() {
|
|
|
|
// The dashboard stats service will take care or reusing and limiting API-requests between charts
|
|
|
|
if (this.mode === 'cadence') {
|
|
|
|
this.dashboardStats.loadPaidMembersByCadence();
|
|
|
|
} else {
|
|
|
|
this.dashboardStats.loadPaidMembersByTier();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-24 11:38:30 +03:00
|
|
|
@tracked mode = 'cadence';
|
|
|
|
modeOptions = MODE_OPTIONS;
|
|
|
|
|
|
|
|
get selectedModeOption() {
|
|
|
|
return this.modeOptions.find(option => option.value === this.mode);
|
|
|
|
}
|
|
|
|
|
2022-04-01 11:48:01 +03:00
|
|
|
get hasMultipleTiers() {
|
|
|
|
return this.dashboardStats.siteStatus?.hasMultipleTiers;
|
|
|
|
}
|
|
|
|
|
2022-03-24 11:38:30 +03:00
|
|
|
@action
|
|
|
|
onSwitchMode(selected) {
|
|
|
|
this.mode = selected.value;
|
|
|
|
|
|
|
|
if (this.loading) {
|
|
|
|
// We don't have the data yet for the newly selected mode
|
|
|
|
this.loadCharts();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-23 18:38:16 +03:00
|
|
|
get loading() {
|
|
|
|
if (this.mode === 'cadence') {
|
|
|
|
return this.dashboardStats.paidMembersByCadence === null;
|
|
|
|
}
|
|
|
|
return this.dashboardStats.paidMembersByTier === null;
|
|
|
|
}
|
|
|
|
|
2022-03-22 18:37:17 +03:00
|
|
|
get chartType() {
|
2022-04-01 19:02:30 +03:00
|
|
|
return 'doughnut';
|
2022-03-22 18:37:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
get chartData() {
|
2022-03-23 18:38:16 +03:00
|
|
|
if (this.mode === 'cadence') {
|
|
|
|
return {
|
|
|
|
labels: ['Monthly', 'Annual'],
|
|
|
|
datasets: [{
|
|
|
|
data: [this.dashboardStats.paidMembersByCadence.monthly, this.dashboardStats.paidMembersByCadence.annual],
|
|
|
|
fill: false,
|
2022-04-06 20:11:46 +03:00
|
|
|
backgroundColor: ['#7BA4F3']
|
2022-03-23 18:38:16 +03:00
|
|
|
}]
|
|
|
|
};
|
|
|
|
}
|
2022-03-24 11:38:30 +03:00
|
|
|
|
|
|
|
const labels = this.dashboardStats.paidMembersByTier.map(stat => stat.tier.name);
|
|
|
|
const data = this.dashboardStats.paidMembersByTier.map(stat => stat.members);
|
|
|
|
|
|
|
|
return {
|
|
|
|
labels,
|
|
|
|
datasets: [{
|
|
|
|
data,
|
|
|
|
fill: false,
|
2022-04-06 20:11:46 +03:00
|
|
|
backgroundColor: ['#7BA4F3'],
|
|
|
|
borderWidth: 3
|
2022-03-24 11:38:30 +03:00
|
|
|
}]
|
|
|
|
};
|
2022-03-22 18:37:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
get chartOptions() {
|
|
|
|
return {
|
2022-04-06 20:11:46 +03:00
|
|
|
responsive: true,
|
|
|
|
maintainAspectRatio: false,
|
2022-04-01 19:02:30 +03:00
|
|
|
cutoutPercentage: (this.mode === 'cadence' ? 85 : 75),
|
2022-03-22 18:37:17 +03:00
|
|
|
legend: {
|
|
|
|
display: false
|
2022-04-01 16:53:55 +03:00
|
|
|
},
|
|
|
|
animation: {
|
|
|
|
duration: 0
|
2022-04-06 20:11:46 +03:00
|
|
|
},
|
|
|
|
hover: {
|
|
|
|
onHover: function (e) {
|
|
|
|
e.target.style.cursor = 'pointer';
|
|
|
|
}
|
|
|
|
},
|
|
|
|
tooltips: {
|
|
|
|
intersect: false,
|
|
|
|
mode: 'index',
|
|
|
|
displayColors: false,
|
|
|
|
backgroundColor: '#15171A',
|
|
|
|
xPadding: 7,
|
|
|
|
yPadding: 7,
|
|
|
|
cornerRadius: 5,
|
|
|
|
caretSize: 7,
|
|
|
|
caretPadding: 5,
|
|
|
|
bodyFontSize: 12.5,
|
|
|
|
titleFontSize: 12,
|
|
|
|
titleFontStyle: 'normal',
|
|
|
|
titleFontColor: 'rgba(255, 255, 255, 0.7)',
|
|
|
|
titleMarginBottom: 3
|
2022-03-22 18:37:17 +03:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2022-04-06 20:11:46 +03:00
|
|
|
|
|
|
|
get chartHeight() {
|
|
|
|
return 75;
|
|
|
|
}
|
2022-03-22 18:37:17 +03:00
|
|
|
}
|