Ghost/ghost/admin/mirage/config/members.js

84 lines
2.3 KiB
JavaScript
Raw Normal View History

import faker from 'faker';
import moment from 'moment';
import {paginatedResponse} from '../utils';
export function mockMembersStats(server) {
server.get('/members/stats/', function (db, {queryParams}) {
let {days} = queryParams;
let firstSubscriberDays = faker.random.number({min: 30, max: 600});
if (days === 'all-time') {
days = firstSubscriberDays;
} else {
days = Number(days);
}
let total = 0;
if (firstSubscriberDays > days) {
total += faker.random.number({max: 1000});
}
let rangeTotal = 0;
// simulate sql GROUP BY where days with 0 subscribers are missing
let dateCounts = {};
let i = 0;
while (i < days) {
let date = moment().subtract(i, 'days').format('YYYY-MM-DD');
let count = faker.random.number({min: 0, max: 30});
if (count !== 0) {
rangeTotal += count;
dateCounts[date] = count;
}
i += 1;
}
// similar to what we'll need to do on the server
let totalOnDate = {};
let j = days - 1;
while (j >= 0) {
let date = moment().subtract(j, 'days').format('YYYY-MM-DD');
totalOnDate[date] = total + (dateCounts[date] || 0);
total += (dateCounts[date] || 0);
j -= 1;
}
return {
totalMembers: total,
totalMembersInRange: rangeTotal,
totalMembersOnDate: totalOnDate,
newMembersToday: dateCounts[moment().format('YYYY-MM-DD')]
};
});
}
export default function mockMembers(server) {
server.post('/members/', function ({members}) {
let attrs = this.normalizedRequestAttrs();
return members.create(Object.assign({}, attrs, {id: 99}));
});
server.get('/members/', paginatedResponse('members'));
server.get('/members/:id/', function ({members}, {params}) {
let {id} = params;
let member = members.find(id);
return member || new Response(404, {}, {
errors: [{
type: 'NotFoundError',
message: 'Member not found.'
}]
});
});
server.put('/members/:id/');
server.del('/members/:id/');
mockMembersStats(server);
}