2012-02-23 07:05:32 +00:00
|
|
|
# ERPNext - web based ERP (http://erpnext.com)
|
|
|
|
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2012-07-19 08:10:31 +00:00
|
|
|
from __future__ import unicode_literals
|
2011-06-14 12:22:03 +00:00
|
|
|
import webnotes
|
2011-07-04 10:53:19 +00:00
|
|
|
from webnotes import msgprint
|
2011-06-14 12:22:03 +00:00
|
|
|
|
|
|
|
feed_dict = {
|
|
|
|
# Project
|
2011-07-06 09:20:30 +00:00
|
|
|
'Project': ['[%(status)s]', '#000080'],
|
2012-12-27 11:20:24 +00:00
|
|
|
'Task': ['[%(status)s] %(subject)s', '#000080'],
|
2011-06-14 12:22:03 +00:00
|
|
|
|
|
|
|
# Sales
|
|
|
|
'Lead': ['%(lead_name)s', '#000080'],
|
|
|
|
'Quotation': ['[%(status)s] To %(customer_name)s worth %(currency)s %(grand_total_export)s', '#4169E1'],
|
|
|
|
'Sales Order': ['[%(status)s] To %(customer_name)s worth %(currency)s %(grand_total_export)s', '#4169E1'],
|
|
|
|
|
|
|
|
# Purchase
|
2013-12-16 07:18:22 +00:00
|
|
|
'Material Request': ['%(supplier_name)s, %(supplier_type)s', '#6495ED'],
|
|
|
|
'Supplier': ['%(supplier_name)s, %(supplier_type)s', '#6495ED'],
|
|
|
|
'Purchase Order': ['[%(status)s] %(name)s To %(supplier_name)s for %(currency)s %(grand_total_import)s', '#4169E1'],
|
2011-06-14 12:22:03 +00:00
|
|
|
|
|
|
|
# Stock
|
|
|
|
'Delivery Note': ['[%(status)s] To %(customer_name)s', '#4169E1'],
|
2012-01-19 11:42:17 +00:00
|
|
|
'Purchase Receipt': ['[%(status)s] From %(supplier)s', '#4169E1'],
|
2011-06-14 12:22:03 +00:00
|
|
|
|
|
|
|
# Accounts
|
|
|
|
'Journal Voucher': ['[%(voucher_type)s] %(name)s', '#4169E1'],
|
2012-03-30 06:59:06 +00:00
|
|
|
'Purchase Invoice': ['To %(supplier_name)s for %(currency)s %(grand_total_import)s', '#4169E1'],
|
|
|
|
'Sales Invoice':['To %(customer_name)s for %(currency)s %(grand_total_export)s', '#4169E1'],
|
2011-06-14 12:22:03 +00:00
|
|
|
|
|
|
|
# HR
|
2012-03-30 06:59:06 +00:00
|
|
|
'Expense Claim': ['[%(approval_status)s] %(name)s by %(employee_name)s', '#4169E1'],
|
2011-06-14 12:22:03 +00:00
|
|
|
'Salary Slip': ['%(employee_name)s for %(month)s %(fiscal_year)s', '#4169E1'],
|
|
|
|
'Leave Transaction':['%(leave_type)s for %(employee)s', '#4169E1'],
|
|
|
|
|
|
|
|
# Support
|
|
|
|
'Customer Issue': ['[%(status)s] %(description)s by %(customer_name)s', '#000080'],
|
|
|
|
'Maintenance Visit':['To %(customer_name)s', '#4169E1'],
|
2012-03-06 11:39:53 +00:00
|
|
|
'Support Ticket': ["[%(status)s] %(subject)s", '#000080'],
|
2012-02-07 06:13:41 +00:00
|
|
|
|
|
|
|
# Website
|
2012-02-07 09:01:49 +00:00
|
|
|
'Web Page': ['%(title)s', '#000080'],
|
|
|
|
'Blog': ['%(title)s', '#000080']
|
2011-06-14 12:22:03 +00:00
|
|
|
}
|
|
|
|
|
2012-02-03 07:26:12 +00:00
|
|
|
def make_feed(feedtype, doctype, name, owner, subject, color):
|
2011-06-14 12:22:03 +00:00
|
|
|
"makes a new Feed record"
|
2011-07-04 10:53:19 +00:00
|
|
|
#msgprint(subject)
|
2011-06-14 12:22:03 +00:00
|
|
|
from webnotes.model.doc import Document
|
2012-02-27 12:33:54 +00:00
|
|
|
from webnotes.utils import get_fullname
|
2012-02-03 07:26:12 +00:00
|
|
|
|
2012-02-08 07:03:13 +00:00
|
|
|
if feedtype in ('Login', 'Comment', 'Assignment'):
|
2012-02-03 07:26:12 +00:00
|
|
|
# delete old login, comment feed
|
|
|
|
webnotes.conn.sql("""delete from tabFeed where
|
2012-02-08 07:03:13 +00:00
|
|
|
datediff(curdate(), creation) > 7 and doc_type in ('Comment', 'Login', 'Assignment')""")
|
2012-02-03 07:26:12 +00:00
|
|
|
else:
|
|
|
|
# one feed per item
|
|
|
|
webnotes.conn.sql("""delete from tabFeed
|
|
|
|
where doc_type=%s and doc_name=%s
|
|
|
|
and ifnull(feed_type,'') != 'Comment'""", (doctype, name))
|
|
|
|
|
2011-06-14 12:22:03 +00:00
|
|
|
f = Document('Feed')
|
2012-02-03 07:26:12 +00:00
|
|
|
f.owner = owner
|
|
|
|
f.feed_type = feedtype
|
|
|
|
f.doc_type = doctype
|
|
|
|
f.doc_name = name
|
2011-06-14 12:22:03 +00:00
|
|
|
f.subject = subject
|
|
|
|
f.color = color
|
2012-02-27 12:33:54 +00:00
|
|
|
f.full_name = get_fullname(owner)
|
2012-02-03 07:26:12 +00:00
|
|
|
f.save()
|
2011-07-04 11:48:01 +00:00
|
|
|
|
2012-12-27 11:20:24 +00:00
|
|
|
def update_feed(controller, method=None):
|
2011-06-14 12:22:03 +00:00
|
|
|
"adds a new feed"
|
2012-12-27 11:20:24 +00:00
|
|
|
doc = controller.doc
|
2012-02-21 12:45:31 +00:00
|
|
|
if method in ['on_update', 'on_submit']:
|
2012-01-20 10:02:18 +00:00
|
|
|
subject, color = feed_dict.get(doc.doctype, [None, None])
|
2012-12-28 07:56:08 +00:00
|
|
|
if subject:
|
2013-09-04 10:50:18 +00:00
|
|
|
make_feed('', doc.doctype, doc.name, doc.owner, subject % doc.fields, color)
|
2013-12-16 07:18:22 +00:00
|
|
|
|
|
|
|
def make_comment_feed(bean, method):
|
|
|
|
"""add comment to feed"""
|
|
|
|
doc = bean.doc
|
|
|
|
make_feed('Comment', doc.comment_doctype, doc.comment_docname, doc.comment_by,
|
|
|
|
'<i>"' + doc.comment + '"</i>', '#6B24B3')
|