import frappe from frappe.utils import get_fullname def get_leaderboards(): return { "User": { "fields": ["points"], "method": "frappe.desk.leaderboard.get_energy_point_leaderboard", "company_disabled": 1, "icon": "users", } } @frappe.whitelist() def get_energy_point_leaderboard(date_range, company=None, field=None, limit=None): users = frappe.get_list( "User", filters={ "name": ["not in", ["Administrator", "Guest"]], "enabled": 1, "user_type": ["!=", "Website User"], }, pluck="name", ) filters = [["type", "!=", "Review"], ["user", "in", users]] if date_range: date_range = frappe.parse_json(date_range) filters.append(["creation", "between", [date_range[0], date_range[1]]]) energy_point_users = frappe.get_all( "Energy Point Log", fields=["user as name", "sum(points) as value"], filters=filters, group_by="user", order_by="value desc", ) energy_point_users_list = list(map(lambda x: x["name"], energy_point_users)) for user in users: if user not in energy_point_users_list: energy_point_users.append({"name": user, "value": 0}) for user in energy_point_users: user_id = user["name"] user["name"] = get_fullname(user["name"]) user["formatted_name"] = f'{get_fullname(user_id)}' return energy_point_users