2019-01-17 14:04:01 -05:00
|
|
|
# Copyright (c) 2018, Frappe Technologies Pvt. Ltd. and contributors
|
|
|
|
# For license information, please see license.txt
|
|
|
|
|
|
|
|
import json
|
2021-01-19 19:01:13 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
from PyPDF2 import PdfFileWriter
|
2021-01-19 19:01:13 +05:30
|
|
|
|
|
|
|
import frappe
|
|
|
|
from erpnext.accounts.utils import get_fiscal_year
|
|
|
|
from frappe import _
|
|
|
|
from frappe.utils import cstr, nowdate
|
|
|
|
from frappe.utils.data import fmt_money
|
|
|
|
from frappe.utils.jinja import render_template
|
2019-01-17 14:04:01 -05:00
|
|
|
from frappe.utils.pdf import get_pdf
|
|
|
|
from frappe.utils.print_format import read_multi_pdf
|
|
|
|
|
2021-01-19 19:01:13 +05:30
|
|
|
IRS_1099_FORMS_FILE_EXTENSION = ".pdf"
|
2019-01-17 14:04:01 -05:00
|
|
|
|
2020-08-26 20:55:16 +05:30
|
|
|
|
2021-01-19 19:01:13 +05:30
|
|
|
def execute(filters=None):
|
|
|
|
filters = filters if isinstance(filters, frappe._dict) else frappe._dict(filters)
|
2019-01-17 14:04:01 -05:00
|
|
|
if not filters:
|
|
|
|
filters.setdefault('fiscal_year', get_fiscal_year(nowdate())[0])
|
2020-08-26 20:55:16 +05:30
|
|
|
filters.setdefault('company', frappe.db.get_default("company"))
|
2020-08-26 18:40:11 +05:30
|
|
|
|
2021-01-19 19:01:13 +05:30
|
|
|
region = frappe.db.get_value("Company",
|
|
|
|
filters={"name": filters.company},
|
|
|
|
fieldname=["country"])
|
|
|
|
|
2020-08-26 18:40:11 +05:30
|
|
|
if region != 'United States':
|
2021-01-19 19:01:13 +05:30
|
|
|
return [], []
|
2020-08-26 20:55:16 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
data = []
|
|
|
|
columns = get_columns()
|
2021-02-11 11:06:12 +05:30
|
|
|
conditions = ""
|
|
|
|
if filters.supplier_group:
|
|
|
|
conditions += "AND s.supplier_group = %s" %frappe.db.escape(filters.get("supplier_group"))
|
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
data = frappe.db.sql("""
|
|
|
|
SELECT
|
|
|
|
s.supplier_group as "supplier_group",
|
|
|
|
gl.party AS "supplier",
|
|
|
|
s.tax_id as "tax_id",
|
2019-03-04 13:22:51 +05:30
|
|
|
SUM(gl.debit_in_account_currency) AS "payments"
|
2019-01-17 14:04:01 -05:00
|
|
|
FROM
|
2021-01-19 19:01:13 +05:30
|
|
|
`tabGL Entry` gl
|
|
|
|
INNER JOIN `tabSupplier` s
|
2019-01-17 14:04:01 -05:00
|
|
|
WHERE
|
|
|
|
s.name = gl.party
|
2021-01-19 19:01:13 +05:30
|
|
|
AND s.irs_1099 = 1
|
|
|
|
AND gl.fiscal_year = %(fiscal_year)s
|
|
|
|
AND gl.party_type = "Supplier"
|
2021-02-11 11:06:12 +05:30
|
|
|
AND gl.company = %(company)s
|
|
|
|
{conditions}
|
2021-08-19 13:41:10 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
GROUP BY
|
|
|
|
gl.party
|
2021-02-11 11:06:12 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
ORDER BY
|
2021-02-11 11:06:12 +05:30
|
|
|
gl.party DESC""".format(conditions=conditions), {
|
|
|
|
"fiscal_year": filters.fiscal_year,
|
|
|
|
"company": filters.company
|
|
|
|
}, as_dict=True)
|
2021-01-19 19:01:13 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
return columns, data
|
|
|
|
|
|
|
|
|
|
|
|
def get_columns():
|
|
|
|
return [
|
|
|
|
{
|
|
|
|
"fieldname": "supplier_group",
|
|
|
|
"label": _("Supplier Group"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"options": "Supplier Group",
|
|
|
|
"width": 200
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "supplier",
|
|
|
|
"label": _("Supplier"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"options": "Supplier",
|
|
|
|
"width": 200
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "tax_id",
|
|
|
|
"label": _("Tax ID"),
|
|
|
|
"fieldtype": "Data",
|
2021-02-11 11:06:12 +05:30
|
|
|
"width": 200
|
2019-01-17 14:04:01 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "payments",
|
|
|
|
"label": _("Total Payments"),
|
|
|
|
"fieldtype": "Currency",
|
2021-02-11 11:06:12 +05:30
|
|
|
"width": 200
|
2019-01-17 14:04:01 -05:00
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
@frappe.whitelist()
|
|
|
|
def irs_1099_print(filters):
|
|
|
|
if not filters:
|
|
|
|
frappe._dict({
|
|
|
|
"company": frappe.db.get_default("Company"),
|
2021-01-19 19:01:13 +05:30
|
|
|
"fiscal_year": frappe.db.get_default("Fiscal Year")
|
|
|
|
})
|
2019-01-17 14:04:01 -05:00
|
|
|
else:
|
|
|
|
filters = frappe._dict(json.loads(filters))
|
2021-01-19 19:01:13 +05:30
|
|
|
|
|
|
|
fiscal_year_doc = get_fiscal_year(fiscal_year=filters.fiscal_year, as_dict=True)
|
|
|
|
fiscal_year = cstr(fiscal_year_doc.year_start_date.year)
|
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
company_address = get_payer_address_html(filters.company)
|
|
|
|
company_tin = frappe.db.get_value("Company", filters.company, "tax_id")
|
2021-01-19 19:01:13 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
columns, data = execute(filters)
|
|
|
|
template = frappe.get_doc("Print Format", "IRS 1099 Form").html
|
|
|
|
output = PdfFileWriter()
|
2021-01-19 19:01:13 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
for row in data:
|
2021-01-19 19:01:13 +05:30
|
|
|
row["fiscal_year"] = fiscal_year
|
2019-01-17 14:04:01 -05:00
|
|
|
row["company"] = filters.company
|
|
|
|
row["company_tin"] = company_tin
|
|
|
|
row["payer_street_address"] = company_address
|
2021-01-19 19:01:13 +05:30
|
|
|
row["recipient_street_address"], row["recipient_city_state"] = get_street_address_html(
|
|
|
|
"Supplier", row.supplier)
|
2019-01-17 14:04:01 -05:00
|
|
|
row["payments"] = fmt_money(row["payments"], precision=0, currency="USD")
|
|
|
|
pdf = get_pdf(render_template(template, row), output=output if output else None)
|
2021-01-19 19:01:13 +05:30
|
|
|
|
|
|
|
frappe.local.response.filename = f"{filters.fiscal_year} {filters.company} IRS 1099 Forms{IRS_1099_FORMS_FILE_EXTENSION}"
|
2019-01-17 14:04:01 -05:00
|
|
|
frappe.local.response.filecontent = read_multi_pdf(output)
|
|
|
|
frappe.local.response.type = "download"
|
|
|
|
|
|
|
|
|
|
|
|
def get_payer_address_html(company):
|
|
|
|
address_list = frappe.db.sql("""
|
|
|
|
SELECT
|
|
|
|
name
|
|
|
|
FROM
|
|
|
|
tabAddress
|
|
|
|
WHERE
|
|
|
|
is_your_company_address = 1
|
|
|
|
ORDER BY
|
|
|
|
address_type="Postal" DESC, address_type="Billing" DESC
|
|
|
|
LIMIT 1
|
2021-01-19 19:01:13 +05:30
|
|
|
""", {"company": company}, as_dict=True)
|
|
|
|
|
|
|
|
address_display = ""
|
2019-01-17 14:04:01 -05:00
|
|
|
if address_list:
|
|
|
|
company_address = address_list[0]["name"]
|
2021-01-19 19:01:13 +05:30
|
|
|
address_display = frappe.get_doc("Address", company_address).get_display()
|
|
|
|
|
|
|
|
return address_display
|
2019-01-17 14:04:01 -05:00
|
|
|
|
|
|
|
|
|
|
|
def get_street_address_html(party_type, party):
|
|
|
|
address_list = frappe.db.sql("""
|
|
|
|
SELECT
|
|
|
|
link.parent
|
2021-01-19 19:01:13 +05:30
|
|
|
FROM
|
|
|
|
`tabDynamic Link` link,
|
|
|
|
`tabAddress` address
|
|
|
|
WHERE
|
|
|
|
link.parenttype = "Address"
|
|
|
|
AND link.link_name = %(party)s
|
|
|
|
ORDER BY
|
|
|
|
address.address_type="Postal" DESC,
|
2019-01-17 14:04:01 -05:00
|
|
|
address.address_type="Billing" DESC
|
|
|
|
LIMIT 1
|
2021-01-19 19:01:13 +05:30
|
|
|
""", {"party": party}, as_dict=True)
|
|
|
|
|
|
|
|
street_address = city_state = ""
|
2019-01-17 14:04:01 -05:00
|
|
|
if address_list:
|
|
|
|
supplier_address = address_list[0]["parent"]
|
|
|
|
doc = frappe.get_doc("Address", supplier_address)
|
2021-01-19 19:01:13 +05:30
|
|
|
|
2019-01-17 14:04:01 -05:00
|
|
|
if doc.address_line2:
|
2021-01-19 19:01:13 +05:30
|
|
|
street_address = doc.address_line1 + "<br>\n" + doc.address_line2 + "<br>\n"
|
2019-01-17 14:04:01 -05:00
|
|
|
else:
|
2021-01-19 19:01:13 +05:30
|
|
|
street_address = doc.address_line1 + "<br>\n"
|
|
|
|
|
|
|
|
city_state = doc.city + ", " if doc.city else ""
|
|
|
|
city_state = city_state + doc.state + " " if doc.state else city_state
|
|
|
|
city_state = city_state + doc.pincode if doc.pincode else city_state
|
|
|
|
city_state += "<br>\n"
|
|
|
|
|
|
|
|
return street_address, city_state
|