feat: peak level base on configuration
continuous-integration/drone/push Build is passing
Details
continuous-integration/drone/push Build is passing
Details
parent
b38c489777
commit
d73752252a
|
@ -169,9 +169,12 @@ export class QueueService extends BaseDataService<QueueModel> {
|
||||||
const start = moment().startOf('day').valueOf();
|
const start = moment().startOf('day').valueOf();
|
||||||
const end = moment().endOf('day').valueOf();
|
const end = moment().endOf('day').valueOf();
|
||||||
const playEstimations = {};
|
const playEstimations = {};
|
||||||
|
const queuePeakLevel = {};
|
||||||
|
|
||||||
for (const id of ids) {
|
for (const id of ids) {
|
||||||
playEstimations[id] = await this.itemAverageTimeEstimation(id);
|
const est = await this.itemAverageTimeEstimation(id);
|
||||||
|
playEstimations[id] = est.average;
|
||||||
|
queuePeakLevel[id] = est.peakLevel;
|
||||||
}
|
}
|
||||||
|
|
||||||
const queues = await this.repo.find({
|
const queues = await this.repo.find({
|
||||||
|
@ -186,6 +189,7 @@ export class QueueService extends BaseDataService<QueueModel> {
|
||||||
|
|
||||||
queues.forEach((queue) => {
|
queues.forEach((queue) => {
|
||||||
queue.average = playEstimations[queue.item_queue_id];
|
queue.average = playEstimations[queue.item_queue_id];
|
||||||
|
queue.peak_level = queuePeakLevel[queue.item_queue_id];
|
||||||
});
|
});
|
||||||
|
|
||||||
return queues;
|
return queues;
|
||||||
|
@ -193,6 +197,7 @@ export class QueueService extends BaseDataService<QueueModel> {
|
||||||
|
|
||||||
async itemAverageTimeEstimation(item_queue_id: string) {
|
async itemAverageTimeEstimation(item_queue_id: string) {
|
||||||
const items = await this.itemMaster.find({
|
const items = await this.itemMaster.find({
|
||||||
|
relations: ['item_queue'],
|
||||||
where: {
|
where: {
|
||||||
item_queue_id,
|
item_queue_id,
|
||||||
},
|
},
|
||||||
|
@ -200,7 +205,8 @@ export class QueueService extends BaseDataService<QueueModel> {
|
||||||
|
|
||||||
const times = items.map((item) => item.play_estimation ?? 0);
|
const times = items.map((item) => item.play_estimation ?? 0);
|
||||||
const average = times.length > 0 ? math.mean(times) * 60 * 1000 : 0; // change average minute to milliseconds
|
const average = times.length > 0 ? math.mean(times) * 60 * 1000 : 0; // change average minute to milliseconds
|
||||||
return average;
|
const peakLevel = items[0]?.item_queue?.max_peak_level ?? 100;
|
||||||
|
return { average, peakLevel };
|
||||||
}
|
}
|
||||||
|
|
||||||
async getTicketItems(ticket_id: string, item_id: string) {
|
async getTicketItems(ticket_id: string, item_id: string) {
|
||||||
|
|
|
@ -17,11 +17,12 @@ export class QueueCondition {
|
||||||
condition(item_id: string) {
|
condition(item_id: string) {
|
||||||
const queues: QueueModel[] = this.ticketItems[item_id] ?? [];
|
const queues: QueueModel[] = this.ticketItems[item_id] ?? [];
|
||||||
const playEstimation = queues[0]?.average ?? 0;
|
const playEstimation = queues[0]?.average ?? 0;
|
||||||
|
const peakLevel = queues[0]?.peak_level ?? 100;
|
||||||
const [time, last] = this.queueTime(queues, playEstimation);
|
const [time, last] = this.queueTime(queues, playEstimation);
|
||||||
const nearest = time ? toTime(time) : 0;
|
const nearest = time ? toTime(time) : 0;
|
||||||
const lastTime = last ? toTime(last + playEstimation) : 0;
|
const lastTime = last ? toTime(last + playEstimation) : 0;
|
||||||
|
|
||||||
const queuePeople = this.queuePeople(queues);
|
const queuePeople = this.queuePeople(queues, peakLevel);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
available: queuePeople == 0,
|
available: queuePeople == 0,
|
||||||
|
@ -32,12 +33,13 @@ export class QueueCondition {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
queuePeople(queues: QueueModel[]): number {
|
queuePeople(queues: QueueModel[], peakLevel): number {
|
||||||
const queue = this.activeQueue(queues);
|
const queue = this.activeQueue(queues);
|
||||||
|
const level = peakLevel / 100;
|
||||||
const queuePeople = queue.reduce((acc, q) => {
|
const queuePeople = queue.reduce((acc, q) => {
|
||||||
return acc + q.qty;
|
return acc + q.qty;
|
||||||
}, 0);
|
}, 0);
|
||||||
return queuePeople;
|
return queuePeople * level;
|
||||||
}
|
}
|
||||||
|
|
||||||
activeQueue(queues: QueueModel[]) {
|
activeQueue(queues: QueueModel[]) {
|
||||||
|
@ -76,6 +78,7 @@ export class QueueCondition {
|
||||||
return (queue.call_time - queue.time) / 1000;
|
return (queue.call_time - queue.time) / 1000;
|
||||||
});
|
});
|
||||||
|
|
||||||
return Math.ceil(math.mean(times));
|
const avg = Math.ceil(math.mean(times));
|
||||||
|
return Math.max(0, avg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue