mirror of
https://github.com/bringout/oca-ocb-crm.git
synced 2026-04-21 04:52:02 +02:00
70 lines
3.1 KiB
JavaScript
70 lines
3.1 KiB
JavaScript
import { onRpc } from "@web/../tests/web_test_helpers";
|
|
import { deserializeDateTime } from "@web/core/l10n/dates";
|
|
|
|
onRpc("get_rainbowman_message", function getRainbowmanMessage({ args, model }) {
|
|
let message = false;
|
|
if (model !== "crm.lead") {
|
|
return message;
|
|
}
|
|
const records = this.env["crm.lead"];
|
|
const record = records.browse(args[0])[0];
|
|
const won_stage = this.env["crm.stage"].search_read([["is_won", "=", true]])[0];
|
|
if (
|
|
record.stage_id === won_stage.id &&
|
|
record.user_id &&
|
|
record.team_id &&
|
|
record.planned_revenue > 0
|
|
) {
|
|
const now = luxon.DateTime.now();
|
|
const query_result = {};
|
|
// Total won
|
|
query_result["total_won"] = records.filter(
|
|
(r) => r.stage_id === won_stage.id && r.user_id === record.user_id
|
|
).length;
|
|
// Max team 30 days
|
|
const recordsTeam30 = records.filter(
|
|
(r) =>
|
|
r.stage_id === won_stage.id &&
|
|
r.team_id === record.team_id &&
|
|
(!r.date_closed || now.diff(deserializeDateTime(r.date_closed)).as("days") <= 30)
|
|
);
|
|
query_result["max_team_30"] = Math.max(...recordsTeam30.map((r) => r.planned_revenue));
|
|
// Max team 7 days
|
|
const recordsTeam7 = records.filter(
|
|
(r) =>
|
|
r.stage_id === won_stage.id &&
|
|
r.team_id === record.team_id &&
|
|
(!r.date_closed || now.diff(deserializeDateTime(r.date_closed)).as("days") <= 7)
|
|
);
|
|
query_result["max_team_7"] = Math.max(...recordsTeam7.map((r) => r.planned_revenue));
|
|
// Max User 30 days
|
|
const recordsUser30 = records.filter(
|
|
(r) =>
|
|
r.stage_id === won_stage.id &&
|
|
r.user_id === record.user_id &&
|
|
(!r.date_closed || now.diff(deserializeDateTime(r.date_closed)).as("days") <= 30)
|
|
);
|
|
query_result["max_user_30"] = Math.max(...recordsUser30.map((r) => r.planned_revenue));
|
|
// Max User 7 days
|
|
const recordsUser7 = records.filter(
|
|
(r) =>
|
|
r.stage_id === won_stage.id &&
|
|
r.user_id === record.user_id &&
|
|
(!r.date_closed || now.diff(deserializeDateTime(r.date_closed)).as("days") <= 7)
|
|
);
|
|
query_result["max_user_7"] = Math.max(...recordsUser7.map((r) => r.planned_revenue));
|
|
|
|
if (query_result.total_won === 1) {
|
|
message = "Go, go, go! Congrats for your first deal.";
|
|
} else if (query_result.max_team_30 === record.planned_revenue) {
|
|
message = "Boom! Team record for the past 30 days.";
|
|
} else if (query_result.max_team_7 === record.planned_revenue) {
|
|
message = "Yeah! Best deal out of the last 7 days for the team.";
|
|
} else if (query_result.max_user_30 === record.planned_revenue) {
|
|
message = "You just beat your personal record for the past 30 days.";
|
|
} else if (query_result.max_user_7 === record.planned_revenue) {
|
|
message = "You just beat your personal record for the past 7 days.";
|
|
}
|
|
}
|
|
return message;
|
|
});
|