2017-09-07 16:14:22 +05:30
|
|
|
# Copyright (c) 2017, Frappe and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
import frappe
|
|
|
|
from frappe.utils import today
|
|
|
|
|
|
|
|
def execute():
|
2017-09-15 16:16:36 +05:30
|
|
|
frappe.reload_doc('accounts', 'doctype', 'subscription')
|
2017-09-07 16:14:22 +05:30
|
|
|
frappe.reload_doc('selling', 'doctype', 'sales_order')
|
2017-09-27 17:11:40 +05:30
|
|
|
frappe.reload_doc('selling', 'doctype', 'quotation')
|
2017-09-07 16:14:22 +05:30
|
|
|
frappe.reload_doc('buying', 'doctype', 'purchase_order')
|
2017-09-27 17:11:40 +05:30
|
|
|
frappe.reload_doc('buying', 'doctype', 'supplier_quotation')
|
2017-09-07 16:14:22 +05:30
|
|
|
frappe.reload_doc('accounts', 'doctype', 'sales_invoice')
|
|
|
|
frappe.reload_doc('accounts', 'doctype', 'purchase_invoice')
|
2017-09-27 17:11:40 +05:30
|
|
|
frappe.reload_doc('stock', 'doctype', 'purchase_receipt')
|
|
|
|
frappe.reload_doc('stock', 'doctype', 'delivery_note')
|
|
|
|
frappe.reload_doc('accounts', 'doctype', 'journal_entry')
|
|
|
|
frappe.reload_doc('accounts', 'doctype', 'payment_entry')
|
2017-09-07 16:14:22 +05:30
|
|
|
|
2017-10-25 12:10:44 +05:30
|
|
|
for doctype in ['Sales Order', 'Sales Invoice', 'Purchase Order', 'Purchase Invoice']:
|
|
|
|
date_field = "transaction_date"
|
|
|
|
if doctype in ("Sales Invoice", "Purchase Invoice"):
|
|
|
|
date_field = "posting_date"
|
2017-09-07 16:14:22 +05:30
|
|
|
|
2017-10-25 12:10:44 +05:30
|
|
|
for data in get_data(doctype, date_field):
|
|
|
|
make_subscription(doctype, data, date_field)
|
|
|
|
|
|
|
|
def get_data(doctype, date_field):
|
|
|
|
return frappe.db.sql(""" select name, from_date, end_date, recurring_type, recurring_id,
|
2017-09-07 16:14:22 +05:30
|
|
|
next_date, notify_by_email, notification_email_address, recurring_print_format,
|
2017-10-25 12:10:44 +05:30
|
|
|
repeat_on_day_of_month, submit_on_creation, docstatus, {0}
|
|
|
|
from `tab{1}` where is_recurring = 1 and next_date >= %s and docstatus < 2
|
|
|
|
order by next_date desc
|
|
|
|
""".format(date_field, doctype), today(), as_dict=1)
|
|
|
|
|
|
|
|
def make_subscription(doctype, data, date_field):
|
|
|
|
if data.name == data.recurring_id:
|
|
|
|
start_date = data.get(date_field)
|
|
|
|
else:
|
|
|
|
start_date = frappe.db.get_value(doctype, data.recurring_id, date_field)
|
2017-09-07 16:14:22 +05:30
|
|
|
|
|
|
|
doc = frappe.get_doc({
|
|
|
|
'doctype': 'Subscription',
|
|
|
|
'reference_doctype': doctype,
|
2017-10-25 12:10:44 +05:30
|
|
|
'reference_document': data.recurring_id,
|
|
|
|
'start_date': start_date,
|
2017-09-07 16:14:22 +05:30
|
|
|
'end_date': data.end_date,
|
|
|
|
'frequency': data.recurring_type,
|
|
|
|
'repeat_on_day': data.repeat_on_day_of_month,
|
|
|
|
'notify_by_email': data.notify_by_email,
|
|
|
|
'recipients': data.notification_email_address,
|
|
|
|
'next_schedule_date': data.next_date,
|
|
|
|
'submit_on_creation': data.submit_on_creation
|
|
|
|
}).insert(ignore_permissions=True)
|
|
|
|
|
2017-09-19 12:53:01 +05:30
|
|
|
if data.docstatus == 1:
|
|
|
|
doc.submit()
|