213 lines
No EOL
6.1 KiB
JavaScript
213 lines
No EOL
6.1 KiB
JavaScript
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
// License: See license.txt
|
|
|
|
frappe.provide("frappe.activity");
|
|
|
|
frappe.pages['activity'].on_page_load = function(wrapper) {
|
|
var me = this;
|
|
|
|
frappe.ui.make_app_page({
|
|
parent: wrapper,
|
|
single_column: true
|
|
});
|
|
|
|
me.page = wrapper.page;
|
|
me.page.set_title(__("Activity"));
|
|
|
|
frappe.model.with_doctype("Communication", function() {
|
|
me.page.list = new frappe.ui.BaseList({
|
|
hide_refresh: true,
|
|
page: me.page,
|
|
method: 'frappe.desk.page.activity.activity.get_feed',
|
|
parent: $("<div></div>").appendTo(me.page.main),
|
|
render_view: function (values) {
|
|
var me = this;
|
|
wrapper = me.page.main.find(".result-list").get(0)
|
|
values.map(function (value) {
|
|
var row = $('<div class="list-row">')
|
|
.data("data", value)
|
|
.appendTo($(wrapper)).get(0);
|
|
new frappe.activity.Feed(row, value);
|
|
});
|
|
},
|
|
show_filters: true,
|
|
doctype: "Communication",
|
|
get_args: function() {
|
|
if (frappe.route_options && frappe.route_options.show_likes) {
|
|
delete frappe.route_options.show_likes;
|
|
return {
|
|
show_likes: true
|
|
}
|
|
} else {
|
|
return {}
|
|
}
|
|
}
|
|
});
|
|
|
|
me.page.list.run();
|
|
|
|
me.page.set_primary_action(__("Refresh"), function() {
|
|
me.page.list.filter_list.clear_filters();
|
|
me.page.list.run();
|
|
}, "octicon octicon-sync");
|
|
});
|
|
|
|
frappe.activity.render_heatmap(me.page);
|
|
|
|
me.page.main.on("click", ".activity-message", function() {
|
|
var link_doctype = $(this).attr("data-link-doctype"),
|
|
link_name = $(this).attr("data-link-name"),
|
|
doctype = $(this).attr("data-doctype"),
|
|
docname = $(this).attr("data-docname");
|
|
|
|
if (doctype && docname) {
|
|
if (link_doctype && link_name) {
|
|
frappe.route_options = {
|
|
scroll_to: { "doctype": doctype, "name": docname }
|
|
}
|
|
}
|
|
|
|
frappe.set_route(["Form", link_doctype || doctype, link_name || docname]);
|
|
}
|
|
});
|
|
|
|
// Build Report Button
|
|
if(frappe.boot.user.can_get_report.indexOf("Feed")!=-1) {
|
|
this.page.add_menu_item(__('Build Report'), function() {
|
|
frappe.set_route('Report', "Feed");
|
|
}, 'fa fa-th')
|
|
}
|
|
|
|
this.page.add_menu_item(__('Authentication Log'), function() {
|
|
frappe.route_options = {
|
|
"user": frappe.session.user
|
|
}
|
|
|
|
frappe.set_route('Report', "Authentication Log");
|
|
}, 'fa fa-th')
|
|
|
|
this.page.add_menu_item(__('Show Likes'), function() {
|
|
frappe.route_options = {
|
|
show_likes: true
|
|
};
|
|
me.page.list.run();
|
|
}, 'octicon octicon-heart');
|
|
};
|
|
|
|
frappe.pages['activity'].on_page_show = function() {
|
|
frappe.breadcrumbs.add("Desk");
|
|
}
|
|
|
|
frappe.activity.last_feed_date = false;
|
|
frappe.activity.Feed = Class.extend({
|
|
init: function(row, data) {
|
|
this.scrub_data(data);
|
|
this.add_date_separator(row, data);
|
|
if(!data.add_class)
|
|
data.add_class = "label-default";
|
|
|
|
data.link = "";
|
|
if (data.link_doctype && data.link_name) {
|
|
data.link = frappe.format(data.link_name, {fieldtype: "Link", options: data.link_doctype},
|
|
{label: __(data.link_doctype) + " " + __(data.link_name)});
|
|
|
|
} else if (data.feed_type==="Comment" && data.comment_type==="Comment") {
|
|
// hack for backward compatiblity
|
|
data.link_doctype = data.reference_doctype;
|
|
data.link_name = data.reference_name;
|
|
data.reference_doctype = "Communication";
|
|
data.reference_name = data.name;
|
|
|
|
data.link = frappe.format(data.link_name, {fieldtype: "Link", options: data.link_doctype},
|
|
{label: __(data.link_doctype) + " " + __(data.link_name)});
|
|
|
|
} else if (data.reference_doctype && data.reference_name) {
|
|
data.link = frappe.format(data.reference_name, {fieldtype: "Link", options: data.reference_doctype},
|
|
{label: __(data.reference_doctype) + " " + __(data.reference_name)});
|
|
}
|
|
|
|
$(row)
|
|
.append(frappe.render_template("activity_row", data))
|
|
.find("a").addClass("grey");
|
|
},
|
|
scrub_data: function(data) {
|
|
data.by = frappe.user.full_name(data.owner);
|
|
data.avatar = frappe.avatar(data.owner);
|
|
|
|
data.icon = "fa fa-flag";
|
|
|
|
// color for comment
|
|
data.add_class = {
|
|
"Comment": "label-danger",
|
|
"Assignment": "label-warning",
|
|
"Login": "label-default"
|
|
}[data.comment_type || data.communication_medium] || "label-info"
|
|
|
|
data.when = comment_when(data.creation);
|
|
data.feed_type = data.comment_type || data.communication_medium;
|
|
},
|
|
add_date_separator: function(row, data) {
|
|
var date = frappe.datetime.str_to_obj(data.creation);
|
|
var last = frappe.activity.last_feed_date;
|
|
|
|
if((last && frappe.datetime.obj_to_str(last) != frappe.datetime.obj_to_str(date)) || (!last)) {
|
|
var diff = frappe.datetime.get_day_diff(frappe.datetime.get_today(), frappe.datetime.obj_to_str(date));
|
|
var pdate;
|
|
if(diff < 1) {
|
|
pdate = 'Today';
|
|
} else if(diff < 2) {
|
|
pdate = 'Yesterday';
|
|
} else {
|
|
pdate = frappe.datetime.global_date_format(date);
|
|
}
|
|
data.date_sep = pdate;
|
|
data.date_class = pdate=='Today' ? "date-indicator blue" : "date-indicator";
|
|
} else {
|
|
data.date_sep = null;
|
|
data.date_class = "";
|
|
}
|
|
frappe.activity.last_feed_date = date;
|
|
}
|
|
});
|
|
|
|
frappe.activity.render_heatmap = function(page) {
|
|
var me = this;
|
|
$('<div class="heatmap-container" style="text-align:center">\
|
|
<div class="heatmap" style="display:inline-block;"></div></div>\
|
|
<hr style="margin-bottom: 0px;">').prependTo(page.main);
|
|
|
|
frappe.call({
|
|
method: "frappe.desk.page.activity.activity.get_heatmap_data",
|
|
callback: function(r) {
|
|
if(r.message) {
|
|
var legend = [];
|
|
var max = Math.max.apply(this, $.map(r.message, function(v) { return v }));
|
|
var legend = [cint(max/5), cint(max*2/5), cint(max*3/5), cint(max*4/5)];
|
|
var heatmap = new CalHeatMap();
|
|
heatmap.init({
|
|
itemSelector: ".heatmap",
|
|
domain: "month",
|
|
subDomain: "day",
|
|
start: moment().subtract(1, 'year').add(1, 'month').toDate(),
|
|
cellSize: 9,
|
|
cellPadding: 2,
|
|
domainGutter: 2,
|
|
range: 12,
|
|
domainLabelFormat: function(date) {
|
|
return moment(date).format("MMM").toUpperCase();
|
|
},
|
|
displayLegend: false,
|
|
legend: legend,
|
|
tooltip: true,
|
|
subDomainTitleFormat: {
|
|
empty: "{date}",
|
|
filled: "{count} actions on {date}"
|
|
},
|
|
subDomainDateFormat: "%d-%b"
|
|
});
|
|
|
|
heatmap.update(r.message);
|
|
}
|
|
}
|
|
})
|
|
} |