mirror of
https://github.com/bringout/oca-ocb-crm.git
synced 2026-04-21 17:12:04 +02:00
19.0 vanilla
This commit is contained in:
parent
dc68f80d3f
commit
7221b9ac46
610 changed files with 135477 additions and 161677 deletions
|
|
@ -0,0 +1,70 @@
|
|||
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;
|
||||
});
|
||||
Loading…
Add table
Add a link
Reference in a new issue