59 lines
1.4 KiB
Python
59 lines
1.4 KiB
Python
|
# Copyright (c) 2013, Frappe Technologies Pvt. Ltd. and contributors
|
||
|
# For license information, please see license.txt
|
||
|
|
||
|
from __future__ import unicode_literals
|
||
|
import frappe
|
||
|
from frappe import msgprint, _
|
||
|
|
||
|
def execute(filters=None):
|
||
|
if not filters: filters = {}
|
||
|
|
||
|
if not filters.get("date"):
|
||
|
frappe.throw(_("Please select date"))
|
||
|
|
||
|
columns = get_columns(filters)
|
||
|
|
||
|
date = filters.get("date")
|
||
|
|
||
|
data = []
|
||
|
|
||
|
if not filters.get("shareholder"):
|
||
|
pass
|
||
|
else:
|
||
|
share_type, no_of_shares, rate, amount = 1, 2, 3, 4
|
||
|
|
||
|
all_shares = get_all_shares(filters.get("shareholder"))
|
||
|
for share_entry in all_shares:
|
||
|
row = False
|
||
|
for datum in data:
|
||
|
if datum[share_type] == share_entry.share_type:
|
||
|
datum[no_of_shares] += share_entry.no_of_shares
|
||
|
datum[amount] += share_entry.amount
|
||
|
if datum[no_of_shares] == 0:
|
||
|
datum[rate] = 0
|
||
|
else:
|
||
|
datum[rate] = datum[amount] / datum[no_of_shares]
|
||
|
row = True
|
||
|
break
|
||
|
# new entry
|
||
|
if not row:
|
||
|
row = [filters.get("shareholder"),
|
||
|
share_entry.share_type, share_entry.no_of_shares, share_entry.rate, share_entry.amount]
|
||
|
|
||
|
data.append(row)
|
||
|
|
||
|
return columns, data
|
||
|
|
||
|
def get_columns(filters):
|
||
|
columns = [
|
||
|
_("Shareholder") + ":Link/Shareholder:150",
|
||
|
_("Share Type") + "::90",
|
||
|
_("No of Shares") + "::90",
|
||
|
_("Average Rate") + ":Currency:90",
|
||
|
_("Amount") + ":Currency:90"
|
||
|
]
|
||
|
return columns
|
||
|
|
||
|
def get_all_shares(shareholder):
|
||
|
return frappe.get_doc('Shareholder', shareholder).share_balance
|