CREATE OR REPLACE PACKAGE BODY APPS.SI_CON_AP_TRIAL_BAL_RPT_PKG
AS
PROCEDURE aa_con_ap_trial_bal_rpt(p_err_buf OUT VARCHAR2
,p_ret_code OUT NUMBER
,p_application_id IN NUMBER
,p_security_id_int_1 IN NUMBER--org_id
,p_definition_code IN VARCHAR2
--,p_as_of_date IN DATE
,p_as_of_date IN VARCHAR2
,p_third_party_id IN NUMBER
,p_chart_of_accounts_id IN NUMBER
,p_ccid IN NUMBER
,p_aging_basis IN VARCHAR2
,p_conversion_type IN VARCHAR2
)
IS
CURSOR cur_ledger_details
IS
SELECT hou.organization_id org_id
,hou.name ou_name
,ledger.ledger_id
,ledger.name ledger_name
,ledger.currency_code
,ledger.configuration_id
,ledger.chart_of_accounts_id
,xla_tb_def.definition_code
FROM hr_operating_units hou
,gl_ledgers ledger
,xla_tb_definitions_vl xla_tb_def
WHERE hou.organization_id = NVL(p_security_id_int_1, hou.organization_id)
AND hou.business_group_id = fnd_profile.value('PER_BUSINESS_GROUP_ID')
AND TRUNC(NVL(hou.date_to, SYSDATE)) >= TRUNC(SYSDATE)
AND hou.set_of_books_id = ledger.ledger_id
AND ledger.ledger_id = xla_tb_def.ledger_id
AND xla_tb_def.definition_code = NVL(p_definition_code, xla_tb_def.definition_code)
--AND hou.organization_id IN (2815, 2816, 3021, 3122, 3321)
AND EXISTS(SELECT 1
FROM fnd_lookup_values flv
WHERE flv.lookup_type = 'AA CONSOLE OPCO APTB'
AND flv.lookup_code = hou.organization_id
AND flv.language = USERENV('LANG')
AND flv.enabled_flag = 'Y'
AND TRUNC(NVL(end_date_active, SYSDATE)) >= TRUNC(SYSDATE)
)
AND xla_tb_def.enabled_flag = 'Y'
AND (xla_tb_def.definition_code IN (
SELECT xtd.definition_code
FROM xla_tb_defn_je_sources xtd
,xla_subledgers xs
WHERE xtd.je_source_name = xs.je_source_Name
AND xs.application_id = p_application_id--200 for Payables
)
OR DECODE(p_application_id,101,'GL','OTHERS') = 'GL'
)
/*AND (
(NVL(fnd_profile.value('XLA_USE_LEDGER_SECURITY'), 'N') = 'N')
OR
(NVL(fnd_profile.value('XLA_USE_LEDGER_SECURITY'), 'N') = 'Y'
AND EXISTS(SELECT 1
FROM gl_access_sets gas
,gl_access_set_assignments asa
WHERE gas.access_set_id = asa.access_set_id
AND asa.ledger_id = xla_tb_def.ledger_id
AND (gas.access_set_id = NVL(fnd_profile.value('GL_ACCESS_SET_ID'), '-1')
OR gas.access_set_id = NVL(fnd_profile.value('XLA_GL_SECONDARY_ACCESS_SET_ID'), '-1')
)
)
)
)*/
ORDER BY hou.organization_id
;
CURSOR cur_con_trial_bal_dtls(p_ledger_id IN NUMBER
,p_chart_of_accounts_id IN NUMBER
,p_org_id IN NUMBER
,pp_definition_code IN VARCHAR2
)
IS
SELECT main_query.invoice_id
,main_query.exchange_rate
,main_query.business_unit
,main_query.liability_account
,main_query.vendor_name
,main_query.vendor_number
,main_query.vendor_site_code
,main_query.vendor_type_lookup_code
,main_query.pay_group_lookup_code
,main_query.invoice_num
,main_query.invoice_date
,main_query.invoice_received_date
,main_query.attribute8
,main_query.creation_date
,main_query.gl_date
,main_query.invoice_curr
,main_query.invoice_amt_entered
,main_query.invoice_amt_functional
,main_query.amount_paid
,main_query.remaining_amount
,REPLACE(REPLACE(main_query.invoice_description,CHR(10),''),CHR(13),'') invoice_description
,main_query.invoice_amt_wht_functional
,CASE
WHEN main_query.amount_paid = 0
THEN 'Unpaid'
WHEN main_query.remaining_amount = 0
THEN 'Paid'
WHEN main_query.remaining_amount <> 0
THEN 'Partially Paid'
END invoice_payment_status
,main_query.invoice_type
,main_query.source
,main_query.voucher_num
,main_query.vendor_id
,main_query.ledger_id
,DECODE(p_aging_basis,'Invoice Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.invoice_date,'dd-mon-yyyy')
,'GL Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.gl_date,'dd-mon-yyyy')
,'Invoice Received Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.invoice_received_date,'dd-mon-yyyy')
) +1 aging_days
FROM(SELECT aia.invoice_id
,aia.exchange_rate
,gcc.segment1 business_unit
,gcc.segment3 liability_account
,asu.vendor_name
,asu.segment1 vendor_number
,assa.vendor_site_code
,asu.vendor_type_lookup_code
,aia.pay_group_lookup_code
,aia.invoice_num
,aia.invoice_date
,NVL(TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') ,invoice_received_date) invoice_received_date
,TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') attribute8
,aia.creation_date
,aia.gl_date
,aia.invoice_currency_code invoice_curr
,aia.invoice_amount invoice_amt_entered
,aia.invoice_amount * NVL ( aia.exchange_rate, 1 ) invoice_amt_functional
,ROUND(((aia.invoice_amount- NVL ( ap_invoices_utility_pkg.get_amount_withheld ( aia.invoice_id ), 0 )) * NVL(aia.exchange_rate, 1)),2)-NVL((SUM(NVL(tb.acctd_rounded_cr, 0)) - SUM(NVL(tb.acctd_rounded_dr, 0))),0) amount_paid
,SUM((NVL(tb.acctd_rounded_cr, 0)-NVL(tb.acctd_rounded_dr, 0))) remaining_amount
,aia.description invoice_description
,NVL (ap_invoices_utility_pkg.get_amount_withheld ( aia.invoice_id ), 0 ) * NVL ( aia.exchange_rate, 1 ) invoice_amt_wht_functional
,(SELECT flvv.meaning
FROM fnd_lookup_values_vl flvv
WHERE flvv.lookup_code = ap_invoices_utility_pkg.get_payment_status(aia.invoice_id)
AND FLVV.lookup_type = 'INVOICE PAYMENT STATUS'
) invoice_payment_status
,flvv.meaning invoice_type
,aia.source
,aia.doc_sequence_value voucher_num
,aia.vendor_id
,aia.set_of_books_id ledger_id
FROM xla.xla_transaction_entities xte
,ap_invoices_all aia
,gl_ledgers gl
,ap_suppliers asu
,ap_supplier_sites_all assa
,gl_code_combinations gcc
,xla.xla_ae_headers xah
,fnd_lookup_values_vl flvv
,(SELECT /*+ parallel(xtb) leading(xtb) NO_MERGE */
xtb.definition_code
,NVL(xtb.applied_to_entity_id,xtb.source_entity_id) entity_id
,xtb.code_combination_id
,xtb.gl_date
,xtb.ae_header_id
,xtb.source_application_id
,xtb.ledger_id
,xtb.party_id
,xtb.balancing_segment_value
,xtb.natural_account_segment_value
,xtb.cost_center_segment_value
,xtb.intercompany_segment_value
,xtb.management_segment_value
,xtb.event_class_code
,xtb.acctd_rounded_cr
,xtb.acctd_rounded_dr
FROM xla.xla_trial_balances xtb
WHERE --xtb.definition_code = p_definition_code
xtb.definition_code = pp_definition_code
AND xtb.source_application_id = 200
AND xtb.ledger_id = p_ledger_id
AND xtb.gl_date <= fnd_date.canonical_to_date(p_as_of_date)
) tb
WHERE tb.entity_id = xte.entity_id
AND tb.source_application_id = 200
AND xte.entity_code = 'AP_INVOICES'
AND xte.application_id = tb.source_application_id
AND NVL(xte.source_id_int_1,-99) = aia.invoice_id
AND tb.ledger_id = gl.ledger_id
AND gl.ledger_id = p_ledger_id
AND aia.vendor_id = asu.vendor_id
AND aia.vendor_site_id = assa.vendor_site_id
AND asu.vendor_id = assa.vendor_id
AND tb.ae_header_id = xah.ae_header_id
AND gcc.code_combination_id = tb.code_combination_id
AND gcc.chart_of_accounts_id = p_chart_of_accounts_id--Added by Nagaraju Gunti
AND gcc.code_combination_id = NVL(p_ccid, gcc.code_combination_id)
--AND xte.security_id_int_1 = NVL(p_security_id_int_1, xte.security_id_int_1)
AND xte.security_id_int_1 = NVL(p_org_id, xte.security_id_int_1)
AND aia.vendor_id = NVL(p_third_party_id, aia.vendor_id)
--AND aia.invoice_date > p_exl_inv
AND flvv.view_application_id = xte.application_id
AND flvv.lookup_code = aia.invoice_type_lookup_code
AND flvv.lookup_type = 'INVOICE TYPE'
GROUP BY aia.invoice_id
,aia.exchange_rate
,gcc.segment1
,gcc.segment3
,asu.vendor_name
,asu.segment1
,assa.vendor_site_code
,asu.vendor_type_lookup_code
,aia.pay_group_lookup_code
,aia.invoice_num
,aia.invoice_date
,aia.creation_date
,aia.gl_date
,aia.INVOICE_CURRENCY_CODE
,aia.description
,aia.invoice_amount
,aia.invoice_received_date
,aia.attribute8
,NVL(TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') ,invoice_received_date)
,flvv.meaning
,aia.source
,aia.doc_sequence_value
,aia.vendor_id
,aia.set_of_books_id
HAVING SUM((NVL(tb.acctd_rounded_cr, 0)- NVL(tb.acctd_rounded_dr, 0))) <> 0
) main_query
;
l_reporting_level xla_tb_definitions_vl.name%TYPE;
l_ou_name hr_operating_units.name%TYPE;
l_supplier_name ap_suppliers.vendor_name%TYPE;
l_user_id fnd_user.user_id%TYPE;
l_user_name fnd_user.user_name%TYPE;
l_employee_id fnd_user.employee_id%TYPE;
l_person_party_id fnd_user.person_party_id%TYPE;
l_employee_name per_all_people_f.full_name%TYPE;
l_party_name hz_parties.party_name%TYPE;
l_requested_by VARCHAR2(240);
l_concatenated_po_nums VARCHAR2(2000);
l_concatenated_rcpt_nums VARCHAR2(2000);
l_aging1 NUMBER := 0;
l_aging2 NUMBER := 0;
l_aging3 NUMBER := 0;
l_aging4 NUMBER := 0;
l_aging5 NUMBER := 0;
l_aging6 NUMBER := 0;
l_aging7 NUMBER := 0;
l_aging8 NUMBER := 0;
l_aging9 NUMBER := 0;
l_aging10 NUMBER := 0;
l_aging11 NUMBER := 0;
l_outstanding_entered NUMBER;
l_closing_rate NUMBER;
l_outstanding_functional NUMBER;
l_unrealized_gain_loss NUMBER;
l_net_balance NUMBER;
l_gl_date DATE;
l_conversion_rate gl_daily_rates.conversion_rate%TYPE;
BEGIN
fnd_file.put_line(fnd_file.log, 'Program Started at ' || to_char(sysdate,'DD-MON-YYYY HH24:MI:SS'));
l_reporting_level := NULL;
l_ou_name := NULL;
l_supplier_name := NULL;
l_person_party_id := NULL;
l_employee_id := NULL;
l_employee_name := NULL;
l_party_name := NULL;
l_requested_by := NULL;
fnd_file.put_line(fnd_file.log, 'XLA_USE_LEDGER_SECURITY: '||fnd_profile.value('XLA_USE_LEDGER_SECURITY'));
fnd_file.put_line(fnd_file.log, 'GL_ACCESS_SET_ID: '||fnd_profile.value('GL_ACCESS_SET_ID'));
fnd_file.put_line(fnd_file.log, 'XLA_GL_SECONDARY_ACCESS_SET_ID: '||fnd_profile.value('XLA_GL_SECONDARY_ACCESS_SET_ID'));
IF p_definition_code IS NOT NULL THEN
BEGIN
SELECT name
INTO l_reporting_level
FROM xla_tb_definitions_vl
WHERE definition_code = p_definition_code
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Reporting Level Parameter Value.'||SQLERRM);
END;
END IF;
IF p_security_id_int_1 IS NOT NULL THEN
BEGIN
SELECT name
INTO l_ou_name
FROM hr_operating_units
WHERE organization_id = p_security_id_int_1
AND business_group_id = fnd_profile.value('PER_BUSINESS_GROUP_ID')
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Operating Unit Name Parameter Value.'||SQLERRM);
END;
END IF;
IF p_third_party_id IS NULL THEN
l_supplier_name := 'ALL';
ELSE
BEGIN
SELECT vendor_name
INTO l_supplier_name
FROM ap_suppliers
WHERE vendor_id = p_third_party_id
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Supplier Name Parameter Value.'||SQLERRM);
END;
END IF;
l_user_id := fnd_global.user_id;
l_user_name := fnd_global.user_name;
IF l_user_id IS NOT NULL THEN
BEGIN
SELECT fu.person_party_id
,fu.employee_id
INTO l_person_party_id
,l_employee_id
FROM fnd_user fu
WHERE fu.user_id = l_user_id
;
EXCEPTION
WHEN OTHERS THEN
l_person_party_id := NULL;
l_employee_id := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing User Details for logged in User.'||SQLERRM);
END;
IF l_employee_id IS NOT NULL
THEN
BEGIN
SELECT papf.full_name
INTO l_employee_name
FROM per_all_people_f papf
WHERE papf.person_id = l_employee_id
AND TRUNC(SYSDATE) BETWEEN TRUNC(papf.effective_start_date)
AND TRUNC(papf.effective_end_date)
;
EXCEPTION
WHEN OTHERS THEN
l_employee_name := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Employee Details for logged in User.'||SQLERRM);
END;
ELSIF l_person_party_id IS NOT NULL
THEN
BEGIN
SELECT hp.party_name
INTO l_party_name
FROM hz_parties hp
WHERE hp.party_id = l_person_party_id
;
EXCEPTION
WHEN OTHERS THEN
l_party_name := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Party Details for logged in User.'||SQLERRM);
END;
/*ELSE
l_requested_by := l_user_name;*/
END IF;
IF l_employee_name IS NOT NULL THEN
l_requested_by := l_employee_name;
ELSIF l_party_name IS NOT NULL THEN
l_requested_by := l_party_name;
ELSE
l_requested_by := l_user_name;
END IF;
END IF;
fnd_file.put_line(fnd_file.output, 'Console AP Trial Balance Report');
fnd_file.put_line(fnd_file.output, 'Report Parameters: ');
fnd_file.put_line(fnd_file.output, 'Reporting Level :^' ||l_reporting_level);
fnd_file.put_line(fnd_file.output, 'Operating Unit Name:^' ||l_ou_name);
fnd_file.put_line(fnd_file.output, 'Supplier Name:^' ||l_supplier_name);
fnd_file.put_line(fnd_file.output, 'As of Date:^' ||fnd_date.canonical_to_date(p_as_of_date));
fnd_file.put_line(fnd_file.output, 'Aging:^' ||p_aging_basis);
fnd_file.put_line(fnd_file.output, 'Submitted Date:^' ||TO_CHAR(SYSDATE, 'DD-MON-RRRR'));
fnd_file.put_line(fnd_file.output, 'Submitted By:^' ||l_requested_by);
--fnd_file.put_line(fnd_file.output, 'Business Unit$Liability Account$Supplier Name$Supplier No$Supplier Site$Supplier Type$Pay Group$Source$Invoice Type$Invoice No$Invoice Creation Date$Invoice Date$Invoice Received Date$Voucher Number$Barcode Number$Purchase Order Number$Receipt Number$Attribute8$GL Date$Currency$Exchange Rate$Invoice Amount - Entered$Invoice Amount - Functional$WHT - Functional$Total Paid Amount - Functional$Remaining Amount - Functional$Payment Status$Invoice Description$Aging Days$0-30 Days$31-60 Days$61-90 Days$91-180 Days$181-365 Days$1-2 Years$2-3 Years$3-4 Years$4-5 Years$5-6 Years$>6 Years$Incountry GL Date$Outstanding Amount(Entered Currency)$Closing Rate(Monthly Closing)$Outstanding Amount(Functional Currency)$Unrealized Gain / Loss$Net Balance (incl.) Revaluation Amount');
fnd_file.put_line(fnd_file.output, 'Business Unit^Liability Account^Supplier Name^Supplier No^Supplier Site^Supplier Type^Pay Group^Source^Invoice Type^Invoice No^Invoice Creation Date^Invoice Date^Invoice Received Date^Voucher Number^Barcode Number^Purchase Order Number^Receipt Number^Attribute8^GL Date^Currency^Exchange Rate^Invoice Amount - Entered^Invoice Amount - Functional^WHT - Functional^Total Paid Amount - Functional^Remaining Amount - Functional^Payment Status^Invoice Description^Aging Days^0-30 Days^31-60 Days^61-90 Days^91-180 Days^181-365 Days^1-2 Years^2-3 Years^3-4 Years^4-5 Years^5-6 Years^>6 Years^Incountry GL Date^Outstanding Amount(Entered Currency)^Closing Rate(Monthly Closing)^Outstanding Amount(Functional Currency)^Unrealized Gain / Loss^Net Balance (incl.) Revaluation Amount');
FOR rec_ledger_details IN cur_ledger_details
LOOP
fnd_file.put_line(fnd_file.log, 'p_ledger_id: '||rec_ledger_details.ledger_id);
fnd_file.put_line(fnd_file.log, 'p_chart_of_accounts_id: '||rec_ledger_details.chart_of_accounts_id);
fnd_file.put_line(fnd_file.log, 'p_org_id: '||rec_ledger_details.org_id);
fnd_file.put_line(fnd_file.log, 'pp_definition_code: '||rec_ledger_details.definition_code);
FOR rec_con_trial_bal_dtls IN cur_con_trial_bal_dtls(rec_ledger_details.ledger_id
,rec_ledger_details.chart_of_accounts_id
,rec_ledger_details.org_id
,rec_ledger_details.definition_code
)
LOOP
l_concatenated_po_nums := NULL;
l_concatenated_rcpt_nums := NULL;
l_aging1 := 0;
l_aging2 := 0;
l_aging3 := 0;
l_aging4 := 0;
l_aging5 := 0;
l_aging6 := 0;
l_aging7 := 0;
l_aging8 := 0;
l_aging9 := 0;
l_aging10 := 0;
l_aging11 := 0;
l_outstanding_entered := NULL;
l_closing_rate := NULL;
l_outstanding_functional:= NULL;
l_unrealized_gain_loss := 0;
l_net_balance := 0;
l_gl_date := NULL;
l_conversion_rate := NULL;
BEGIN
FOR rec_po_nums
IN (SELECT poh.segment1 po_number
FROM ap_invoices_all api
,ap_invoice_distributions_all aid
,ap_invoice_lines_all ail
,po_distributions_all pod
,po_headers_all poh
WHERE api.invoice_id = ail.invoice_id
AND aid.invoice_id = ail.invoice_id
AND api.vendor_id = rec_con_trial_bal_dtls.vendor_id
AND aid.invoice_line_number = ail.line_number
AND aid.po_distribution_id = pod.po_distribution_id
AND pod.po_header_id = poh.po_header_id
AND api.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND api.invoice_amount != 0
AND api.org_id = rec_ledger_details.org_id
AND api.org_id = aid.org_id
AND ail.discarded_flag <> 'Y'
UNION
SELECT aid.po_number po_number
FROM ap_invoices_interface api
,ap_invoice_lines_interface aid
WHERE api.invoice_id = aid.invoice_id
AND api.vendor_id = rec_con_trial_bal_dtls.vendor_id
AND api.invoice_num = rec_con_trial_bal_dtls.invoice_id
AND api.invoice_amount != 0
AND aid.po_number IS NOT NULL
AND api.org_id = rec_ledger_details.org_id
AND api.org_id = aid.org_id
)
LOOP
l_concatenated_po_nums := l_concatenated_po_nums || ',' ||' '|| rec_po_nums.po_number;
END LOOP;
l_concatenated_po_nums := RTRIM(LTRIM (l_concatenated_po_nums, ','),',');
EXCEPTION
WHEN OTHERS THEN
l_concatenated_po_nums := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing PO Number.'||SUBSTR(SQLERRM, 500));
END;
BEGIN
FOR rec_rcpt_nums IN
(SELECT DISTINCT rsh.receipt_num
FROM rcv_shipment_headers rsh
,rcv_transactions rt
,ap_invoice_lines_all aila
,ap_invoice_distributions_all aida
WHERE rt.shipment_header_id = rsh.shipment_header_id
AND rt.transaction_id = aida.rcv_transaction_id
AND aida.invoice_id = aila.invoice_id
AND aida.invoice_line_number = aila.line_number
AND aila.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND aida.org_id = rec_ledger_details.org_id
AND aila.discarded_flag <> 'Y'
AND aida.distribution_line_number = (SELECT MIN (aid1.distribution_line_number)
FROM ap_invoice_distributions_all aid1
WHERE aid1.invoice_id = rec_con_trial_bal_dtls.invoice_id
)
)
LOOP
l_concatenated_rcpt_nums := l_concatenated_rcpt_nums||', '||rec_rcpt_nums.receipt_num;
END LOOP;
l_concatenated_rcpt_nums := rtrim(ltrim (l_concatenated_rcpt_nums, ','),',');
EXCEPTION
WHEN OTHERS THEN
l_concatenated_po_nums := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing PO Number.'||SUBSTR(SQLERRM, 500));
END;
BEGIN
IF rec_con_trial_bal_dtls.aging_days >= 0
AND rec_con_trial_bal_dtls.aging_days <= 30
THEN
l_aging1 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 30
AND rec_con_trial_bal_dtls.aging_days <= 60
THEN
l_aging2 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 60
AND rec_con_trial_bal_dtls.aging_days <= 90
THEN
l_aging3 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 90
AND rec_con_trial_bal_dtls.aging_days <= 180
THEN
l_aging4 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 180
AND rec_con_trial_bal_dtls.aging_days <= 365
THEN
l_aging5 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 365
AND rec_con_trial_bal_dtls.aging_days <= 730
THEN
l_aging6 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 730
AND rec_con_trial_bal_dtls.aging_days <= 1095
THEN
l_aging7 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1095
AND rec_con_trial_bal_dtls.aging_days <= 1460
THEN
l_aging8 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1460
AND rec_con_trial_bal_dtls.aging_days <= 1825
THEN
l_aging9 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1825
AND rec_con_trial_bal_dtls.aging_days <= 2190
THEN
l_aging10 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 2190
THEN
l_aging11 := rec_con_trial_bal_dtls.remaining_amount;
END IF;
END;
BEGIN
IF rec_ledger_details.currency_code = rec_con_trial_bal_dtls.invoice_curr THEN
l_conversion_rate := 1;
ELSE
BEGIN
SELECT dr.conversion_rate
INTO l_conversion_rate
FROM gl_daily_rates dr
,gl_daily_conversion_types dct
WHERE dr.conversion_type = dct.conversion_type
AND dct.user_conversion_type = p_conversion_type
AND dr.to_currency = rec_ledger_details.currency_code
AND dr.from_currency = rec_con_trial_bal_dtls.invoice_curr
AND TRUNC(dr.conversion_date) = TRUNC(fnd_date.canonical_to_date(p_as_of_date))
;
EXCEPTION
WHEN OTHERS THEN
l_conversion_rate := 0;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Conversion Rate.'||SUBSTR(SQLERRM, 500));
END;
END IF;
EXCEPTION
WHEN OTHERS THEN
l_conversion_rate := 0;
END;
IF rec_ledger_details.currency_code = rec_con_trial_bal_dtls.invoice_curr THEN
l_outstanding_entered := 1;
l_closing_rate := 1;
l_outstanding_functional := rec_con_trial_bal_dtls.remaining_amount;
l_unrealized_gain_loss := 0;
l_net_balance := l_outstanding_functional;
ELSE
l_outstanding_entered := rec_con_trial_bal_dtls.remaining_amount/rec_con_trial_bal_dtls.exchange_rate;
l_closing_rate := l_conversion_rate;
l_outstanding_functional := l_outstanding_entered * l_conversion_rate;
l_unrealized_gain_loss := l_outstanding_functional - rec_con_trial_bal_dtls.remaining_amount;
l_net_balance := l_unrealized_gain_loss + rec_con_trial_bal_dtls.remaining_amount;
END IF;
BEGIN
SELECT af.gl_date
INTO l_gl_date
FROM asi_forex_t af
,gl_code_combinations gcc
,ap_invoices_all aia
WHERE segment1 = af.business_unit
AND business_unit = rec_con_trial_bal_dtls.business_unit
AND aia.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND aia.org_id = rec_ledger_details.org_id
AND liability_account = segment3
AND liability_account = rec_con_trial_bal_dtls.liability_account
AND (aia.invoice_num = af.invoice_num OR '0'||af.invoice_num = aia.invoice_num)
AND ROWNUM = 1;
EXCEPTION
WHEN OTHERS THEN
l_gl_date := NULL;
END;
fnd_file.put_line(fnd_file.output, rec_con_trial_bal_dtls.business_unit
||'^'||rec_con_trial_bal_dtls.liability_account
||'^'||rec_con_trial_bal_dtls.vendor_name
||'^'||rec_con_trial_bal_dtls.vendor_number
||'^'||rec_con_trial_bal_dtls.vendor_site_code
||'^'||rec_con_trial_bal_dtls.vendor_type_lookup_code
||'^'||rec_con_trial_bal_dtls.pay_group_lookup_code
||'^'||rec_con_trial_bal_dtls.source
||'^'||rec_con_trial_bal_dtls.invoice_type
||'^'||rec_con_trial_bal_dtls.invoice_num
||'^'||rec_con_trial_bal_dtls.creation_date
||'^'||rec_con_trial_bal_dtls.invoice_date
||'^'||rec_con_trial_bal_dtls.invoice_received_date
||'^'||rec_con_trial_bal_dtls.voucher_num
||'^'||rec_con_trial_bal_dtls.invoice_id
||'^'||l_concatenated_po_nums
||'^'||l_concatenated_rcpt_nums
||'^'||rec_con_trial_bal_dtls.attribute8
||'^'||rec_con_trial_bal_dtls.gl_date
||'^'||rec_con_trial_bal_dtls.invoice_curr
||'^'||rec_con_trial_bal_dtls.exchange_rate
||'^'||rec_con_trial_bal_dtls.invoice_amt_entered
||'^'||rec_con_trial_bal_dtls.invoice_amt_functional
||'^'||rec_con_trial_bal_dtls.invoice_amt_wht_functional
||'^'||rec_con_trial_bal_dtls.amount_paid
||'^'||rec_con_trial_bal_dtls.remaining_amount
||'^'||rec_con_trial_bal_dtls.invoice_payment_status
||'^'||REPLACE(REPLACE(REPLACE(REPLACE(regexp_replace(rec_con_trial_bal_dtls.invoice_description,'([^[:graph:]|^[:blank:]])',' '),CHR(10),''),CHR(13),''),'"',''),'|',' ')
||'^'||rec_con_trial_bal_dtls.aging_days
||'^'||l_aging1
||'^'||l_aging2
||'^'||l_aging3
||'^'||l_aging4
||'^'||l_aging5
||'^'||l_aging6
||'^'||l_aging7
||'^'||l_aging8
||'^'||l_aging9
||'^'||l_aging10
||'^'||l_aging11
||'^'||l_gl_date
||'^'||l_outstanding_entered
||'^'||l_closing_rate
||'^'||l_outstanding_functional
||'^'||l_unrealized_gain_loss
||'^'||l_net_balance
);
END LOOP;
END LOOP;
fnd_file.put_line(fnd_file.log, 'Program Ended at ' || to_char(sysdate,'DD-MON-YYYY HH24:MI:SS'));
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Main Error in asi_con_ap_trial_bal_rpt_pkg.aa_con_ap_trial_bal_rpt procedure. Error Message: '||SQLERRM);
END aa_con_ap_trial_bal_rpt;
END SI_CON_AP_TRIAL_BAL_RPT_PKG;
/
AS
PROCEDURE aa_con_ap_trial_bal_rpt(p_err_buf OUT VARCHAR2
,p_ret_code OUT NUMBER
,p_application_id IN NUMBER
,p_security_id_int_1 IN NUMBER--org_id
,p_definition_code IN VARCHAR2
--,p_as_of_date IN DATE
,p_as_of_date IN VARCHAR2
,p_third_party_id IN NUMBER
,p_chart_of_accounts_id IN NUMBER
,p_ccid IN NUMBER
,p_aging_basis IN VARCHAR2
,p_conversion_type IN VARCHAR2
)
IS
CURSOR cur_ledger_details
IS
SELECT hou.organization_id org_id
,hou.name ou_name
,ledger.ledger_id
,ledger.name ledger_name
,ledger.currency_code
,ledger.configuration_id
,ledger.chart_of_accounts_id
,xla_tb_def.definition_code
FROM hr_operating_units hou
,gl_ledgers ledger
,xla_tb_definitions_vl xla_tb_def
WHERE hou.organization_id = NVL(p_security_id_int_1, hou.organization_id)
AND hou.business_group_id = fnd_profile.value('PER_BUSINESS_GROUP_ID')
AND TRUNC(NVL(hou.date_to, SYSDATE)) >= TRUNC(SYSDATE)
AND hou.set_of_books_id = ledger.ledger_id
AND ledger.ledger_id = xla_tb_def.ledger_id
AND xla_tb_def.definition_code = NVL(p_definition_code, xla_tb_def.definition_code)
--AND hou.organization_id IN (2815, 2816, 3021, 3122, 3321)
AND EXISTS(SELECT 1
FROM fnd_lookup_values flv
WHERE flv.lookup_type = 'AA CONSOLE OPCO APTB'
AND flv.lookup_code = hou.organization_id
AND flv.language = USERENV('LANG')
AND flv.enabled_flag = 'Y'
AND TRUNC(NVL(end_date_active, SYSDATE)) >= TRUNC(SYSDATE)
)
AND xla_tb_def.enabled_flag = 'Y'
AND (xla_tb_def.definition_code IN (
SELECT xtd.definition_code
FROM xla_tb_defn_je_sources xtd
,xla_subledgers xs
WHERE xtd.je_source_name = xs.je_source_Name
AND xs.application_id = p_application_id--200 for Payables
)
OR DECODE(p_application_id,101,'GL','OTHERS') = 'GL'
)
/*AND (
(NVL(fnd_profile.value('XLA_USE_LEDGER_SECURITY'), 'N') = 'N')
OR
(NVL(fnd_profile.value('XLA_USE_LEDGER_SECURITY'), 'N') = 'Y'
AND EXISTS(SELECT 1
FROM gl_access_sets gas
,gl_access_set_assignments asa
WHERE gas.access_set_id = asa.access_set_id
AND asa.ledger_id = xla_tb_def.ledger_id
AND (gas.access_set_id = NVL(fnd_profile.value('GL_ACCESS_SET_ID'), '-1')
OR gas.access_set_id = NVL(fnd_profile.value('XLA_GL_SECONDARY_ACCESS_SET_ID'), '-1')
)
)
)
)*/
ORDER BY hou.organization_id
;
CURSOR cur_con_trial_bal_dtls(p_ledger_id IN NUMBER
,p_chart_of_accounts_id IN NUMBER
,p_org_id IN NUMBER
,pp_definition_code IN VARCHAR2
)
IS
SELECT main_query.invoice_id
,main_query.exchange_rate
,main_query.business_unit
,main_query.liability_account
,main_query.vendor_name
,main_query.vendor_number
,main_query.vendor_site_code
,main_query.vendor_type_lookup_code
,main_query.pay_group_lookup_code
,main_query.invoice_num
,main_query.invoice_date
,main_query.invoice_received_date
,main_query.attribute8
,main_query.creation_date
,main_query.gl_date
,main_query.invoice_curr
,main_query.invoice_amt_entered
,main_query.invoice_amt_functional
,main_query.amount_paid
,main_query.remaining_amount
,REPLACE(REPLACE(main_query.invoice_description,CHR(10),''),CHR(13),'') invoice_description
,main_query.invoice_amt_wht_functional
,CASE
WHEN main_query.amount_paid = 0
THEN 'Unpaid'
WHEN main_query.remaining_amount = 0
THEN 'Paid'
WHEN main_query.remaining_amount <> 0
THEN 'Partially Paid'
END invoice_payment_status
,main_query.invoice_type
,main_query.source
,main_query.voucher_num
,main_query.vendor_id
,main_query.ledger_id
,DECODE(p_aging_basis,'Invoice Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.invoice_date,'dd-mon-yyyy')
,'GL Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.gl_date,'dd-mon-yyyy')
,'Invoice Received Date', TO_DATE(fnd_date.canonical_to_date(p_as_of_date),'dd-mon-yyyy') - TO_DATE(main_query.invoice_received_date,'dd-mon-yyyy')
) +1 aging_days
FROM(SELECT aia.invoice_id
,aia.exchange_rate
,gcc.segment1 business_unit
,gcc.segment3 liability_account
,asu.vendor_name
,asu.segment1 vendor_number
,assa.vendor_site_code
,asu.vendor_type_lookup_code
,aia.pay_group_lookup_code
,aia.invoice_num
,aia.invoice_date
,NVL(TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') ,invoice_received_date) invoice_received_date
,TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') attribute8
,aia.creation_date
,aia.gl_date
,aia.invoice_currency_code invoice_curr
,aia.invoice_amount invoice_amt_entered
,aia.invoice_amount * NVL ( aia.exchange_rate, 1 ) invoice_amt_functional
,ROUND(((aia.invoice_amount- NVL ( ap_invoices_utility_pkg.get_amount_withheld ( aia.invoice_id ), 0 )) * NVL(aia.exchange_rate, 1)),2)-NVL((SUM(NVL(tb.acctd_rounded_cr, 0)) - SUM(NVL(tb.acctd_rounded_dr, 0))),0) amount_paid
,SUM((NVL(tb.acctd_rounded_cr, 0)-NVL(tb.acctd_rounded_dr, 0))) remaining_amount
,aia.description invoice_description
,NVL (ap_invoices_utility_pkg.get_amount_withheld ( aia.invoice_id ), 0 ) * NVL ( aia.exchange_rate, 1 ) invoice_amt_wht_functional
,(SELECT flvv.meaning
FROM fnd_lookup_values_vl flvv
WHERE flvv.lookup_code = ap_invoices_utility_pkg.get_payment_status(aia.invoice_id)
AND FLVV.lookup_type = 'INVOICE PAYMENT STATUS'
) invoice_payment_status
,flvv.meaning invoice_type
,aia.source
,aia.doc_sequence_value voucher_num
,aia.vendor_id
,aia.set_of_books_id ledger_id
FROM xla.xla_transaction_entities xte
,ap_invoices_all aia
,gl_ledgers gl
,ap_suppliers asu
,ap_supplier_sites_all assa
,gl_code_combinations gcc
,xla.xla_ae_headers xah
,fnd_lookup_values_vl flvv
,(SELECT /*+ parallel(xtb) leading(xtb) NO_MERGE */
xtb.definition_code
,NVL(xtb.applied_to_entity_id,xtb.source_entity_id) entity_id
,xtb.code_combination_id
,xtb.gl_date
,xtb.ae_header_id
,xtb.source_application_id
,xtb.ledger_id
,xtb.party_id
,xtb.balancing_segment_value
,xtb.natural_account_segment_value
,xtb.cost_center_segment_value
,xtb.intercompany_segment_value
,xtb.management_segment_value
,xtb.event_class_code
,xtb.acctd_rounded_cr
,xtb.acctd_rounded_dr
FROM xla.xla_trial_balances xtb
WHERE --xtb.definition_code = p_definition_code
xtb.definition_code = pp_definition_code
AND xtb.source_application_id = 200
AND xtb.ledger_id = p_ledger_id
AND xtb.gl_date <= fnd_date.canonical_to_date(p_as_of_date)
) tb
WHERE tb.entity_id = xte.entity_id
AND tb.source_application_id = 200
AND xte.entity_code = 'AP_INVOICES'
AND xte.application_id = tb.source_application_id
AND NVL(xte.source_id_int_1,-99) = aia.invoice_id
AND tb.ledger_id = gl.ledger_id
AND gl.ledger_id = p_ledger_id
AND aia.vendor_id = asu.vendor_id
AND aia.vendor_site_id = assa.vendor_site_id
AND asu.vendor_id = assa.vendor_id
AND tb.ae_header_id = xah.ae_header_id
AND gcc.code_combination_id = tb.code_combination_id
AND gcc.chart_of_accounts_id = p_chart_of_accounts_id--Added by Nagaraju Gunti
AND gcc.code_combination_id = NVL(p_ccid, gcc.code_combination_id)
--AND xte.security_id_int_1 = NVL(p_security_id_int_1, xte.security_id_int_1)
AND xte.security_id_int_1 = NVL(p_org_id, xte.security_id_int_1)
AND aia.vendor_id = NVL(p_third_party_id, aia.vendor_id)
--AND aia.invoice_date > p_exl_inv
AND flvv.view_application_id = xte.application_id
AND flvv.lookup_code = aia.invoice_type_lookup_code
AND flvv.lookup_type = 'INVOICE TYPE'
GROUP BY aia.invoice_id
,aia.exchange_rate
,gcc.segment1
,gcc.segment3
,asu.vendor_name
,asu.segment1
,assa.vendor_site_code
,asu.vendor_type_lookup_code
,aia.pay_group_lookup_code
,aia.invoice_num
,aia.invoice_date
,aia.creation_date
,aia.gl_date
,aia.INVOICE_CURRENCY_CODE
,aia.description
,aia.invoice_amount
,aia.invoice_received_date
,aia.attribute8
,NVL(TO_DATE(TO_DATE(aia.attribute8,'MM/DD/YYYY'),'DD-Mon-YY') ,invoice_received_date)
,flvv.meaning
,aia.source
,aia.doc_sequence_value
,aia.vendor_id
,aia.set_of_books_id
HAVING SUM((NVL(tb.acctd_rounded_cr, 0)- NVL(tb.acctd_rounded_dr, 0))) <> 0
) main_query
;
l_reporting_level xla_tb_definitions_vl.name%TYPE;
l_ou_name hr_operating_units.name%TYPE;
l_supplier_name ap_suppliers.vendor_name%TYPE;
l_user_id fnd_user.user_id%TYPE;
l_user_name fnd_user.user_name%TYPE;
l_employee_id fnd_user.employee_id%TYPE;
l_person_party_id fnd_user.person_party_id%TYPE;
l_employee_name per_all_people_f.full_name%TYPE;
l_party_name hz_parties.party_name%TYPE;
l_requested_by VARCHAR2(240);
l_concatenated_po_nums VARCHAR2(2000);
l_concatenated_rcpt_nums VARCHAR2(2000);
l_aging1 NUMBER := 0;
l_aging2 NUMBER := 0;
l_aging3 NUMBER := 0;
l_aging4 NUMBER := 0;
l_aging5 NUMBER := 0;
l_aging6 NUMBER := 0;
l_aging7 NUMBER := 0;
l_aging8 NUMBER := 0;
l_aging9 NUMBER := 0;
l_aging10 NUMBER := 0;
l_aging11 NUMBER := 0;
l_outstanding_entered NUMBER;
l_closing_rate NUMBER;
l_outstanding_functional NUMBER;
l_unrealized_gain_loss NUMBER;
l_net_balance NUMBER;
l_gl_date DATE;
l_conversion_rate gl_daily_rates.conversion_rate%TYPE;
BEGIN
fnd_file.put_line(fnd_file.log, 'Program Started at ' || to_char(sysdate,'DD-MON-YYYY HH24:MI:SS'));
l_reporting_level := NULL;
l_ou_name := NULL;
l_supplier_name := NULL;
l_person_party_id := NULL;
l_employee_id := NULL;
l_employee_name := NULL;
l_party_name := NULL;
l_requested_by := NULL;
fnd_file.put_line(fnd_file.log, 'XLA_USE_LEDGER_SECURITY: '||fnd_profile.value('XLA_USE_LEDGER_SECURITY'));
fnd_file.put_line(fnd_file.log, 'GL_ACCESS_SET_ID: '||fnd_profile.value('GL_ACCESS_SET_ID'));
fnd_file.put_line(fnd_file.log, 'XLA_GL_SECONDARY_ACCESS_SET_ID: '||fnd_profile.value('XLA_GL_SECONDARY_ACCESS_SET_ID'));
IF p_definition_code IS NOT NULL THEN
BEGIN
SELECT name
INTO l_reporting_level
FROM xla_tb_definitions_vl
WHERE definition_code = p_definition_code
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Reporting Level Parameter Value.'||SQLERRM);
END;
END IF;
IF p_security_id_int_1 IS NOT NULL THEN
BEGIN
SELECT name
INTO l_ou_name
FROM hr_operating_units
WHERE organization_id = p_security_id_int_1
AND business_group_id = fnd_profile.value('PER_BUSINESS_GROUP_ID')
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Operating Unit Name Parameter Value.'||SQLERRM);
END;
END IF;
IF p_third_party_id IS NULL THEN
l_supplier_name := 'ALL';
ELSE
BEGIN
SELECT vendor_name
INTO l_supplier_name
FROM ap_suppliers
WHERE vendor_id = p_third_party_id
;
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Error while fetcing Supplier Name Parameter Value.'||SQLERRM);
END;
END IF;
l_user_id := fnd_global.user_id;
l_user_name := fnd_global.user_name;
IF l_user_id IS NOT NULL THEN
BEGIN
SELECT fu.person_party_id
,fu.employee_id
INTO l_person_party_id
,l_employee_id
FROM fnd_user fu
WHERE fu.user_id = l_user_id
;
EXCEPTION
WHEN OTHERS THEN
l_person_party_id := NULL;
l_employee_id := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing User Details for logged in User.'||SQLERRM);
END;
IF l_employee_id IS NOT NULL
THEN
BEGIN
SELECT papf.full_name
INTO l_employee_name
FROM per_all_people_f papf
WHERE papf.person_id = l_employee_id
AND TRUNC(SYSDATE) BETWEEN TRUNC(papf.effective_start_date)
AND TRUNC(papf.effective_end_date)
;
EXCEPTION
WHEN OTHERS THEN
l_employee_name := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Employee Details for logged in User.'||SQLERRM);
END;
ELSIF l_person_party_id IS NOT NULL
THEN
BEGIN
SELECT hp.party_name
INTO l_party_name
FROM hz_parties hp
WHERE hp.party_id = l_person_party_id
;
EXCEPTION
WHEN OTHERS THEN
l_party_name := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Party Details for logged in User.'||SQLERRM);
END;
/*ELSE
l_requested_by := l_user_name;*/
END IF;
IF l_employee_name IS NOT NULL THEN
l_requested_by := l_employee_name;
ELSIF l_party_name IS NOT NULL THEN
l_requested_by := l_party_name;
ELSE
l_requested_by := l_user_name;
END IF;
END IF;
fnd_file.put_line(fnd_file.output, 'Console AP Trial Balance Report');
fnd_file.put_line(fnd_file.output, 'Report Parameters: ');
fnd_file.put_line(fnd_file.output, 'Reporting Level :^' ||l_reporting_level);
fnd_file.put_line(fnd_file.output, 'Operating Unit Name:^' ||l_ou_name);
fnd_file.put_line(fnd_file.output, 'Supplier Name:^' ||l_supplier_name);
fnd_file.put_line(fnd_file.output, 'As of Date:^' ||fnd_date.canonical_to_date(p_as_of_date));
fnd_file.put_line(fnd_file.output, 'Aging:^' ||p_aging_basis);
fnd_file.put_line(fnd_file.output, 'Submitted Date:^' ||TO_CHAR(SYSDATE, 'DD-MON-RRRR'));
fnd_file.put_line(fnd_file.output, 'Submitted By:^' ||l_requested_by);
--fnd_file.put_line(fnd_file.output, 'Business Unit$Liability Account$Supplier Name$Supplier No$Supplier Site$Supplier Type$Pay Group$Source$Invoice Type$Invoice No$Invoice Creation Date$Invoice Date$Invoice Received Date$Voucher Number$Barcode Number$Purchase Order Number$Receipt Number$Attribute8$GL Date$Currency$Exchange Rate$Invoice Amount - Entered$Invoice Amount - Functional$WHT - Functional$Total Paid Amount - Functional$Remaining Amount - Functional$Payment Status$Invoice Description$Aging Days$0-30 Days$31-60 Days$61-90 Days$91-180 Days$181-365 Days$1-2 Years$2-3 Years$3-4 Years$4-5 Years$5-6 Years$>6 Years$Incountry GL Date$Outstanding Amount(Entered Currency)$Closing Rate(Monthly Closing)$Outstanding Amount(Functional Currency)$Unrealized Gain / Loss$Net Balance (incl.) Revaluation Amount');
fnd_file.put_line(fnd_file.output, 'Business Unit^Liability Account^Supplier Name^Supplier No^Supplier Site^Supplier Type^Pay Group^Source^Invoice Type^Invoice No^Invoice Creation Date^Invoice Date^Invoice Received Date^Voucher Number^Barcode Number^Purchase Order Number^Receipt Number^Attribute8^GL Date^Currency^Exchange Rate^Invoice Amount - Entered^Invoice Amount - Functional^WHT - Functional^Total Paid Amount - Functional^Remaining Amount - Functional^Payment Status^Invoice Description^Aging Days^0-30 Days^31-60 Days^61-90 Days^91-180 Days^181-365 Days^1-2 Years^2-3 Years^3-4 Years^4-5 Years^5-6 Years^>6 Years^Incountry GL Date^Outstanding Amount(Entered Currency)^Closing Rate(Monthly Closing)^Outstanding Amount(Functional Currency)^Unrealized Gain / Loss^Net Balance (incl.) Revaluation Amount');
FOR rec_ledger_details IN cur_ledger_details
LOOP
fnd_file.put_line(fnd_file.log, 'p_ledger_id: '||rec_ledger_details.ledger_id);
fnd_file.put_line(fnd_file.log, 'p_chart_of_accounts_id: '||rec_ledger_details.chart_of_accounts_id);
fnd_file.put_line(fnd_file.log, 'p_org_id: '||rec_ledger_details.org_id);
fnd_file.put_line(fnd_file.log, 'pp_definition_code: '||rec_ledger_details.definition_code);
FOR rec_con_trial_bal_dtls IN cur_con_trial_bal_dtls(rec_ledger_details.ledger_id
,rec_ledger_details.chart_of_accounts_id
,rec_ledger_details.org_id
,rec_ledger_details.definition_code
)
LOOP
l_concatenated_po_nums := NULL;
l_concatenated_rcpt_nums := NULL;
l_aging1 := 0;
l_aging2 := 0;
l_aging3 := 0;
l_aging4 := 0;
l_aging5 := 0;
l_aging6 := 0;
l_aging7 := 0;
l_aging8 := 0;
l_aging9 := 0;
l_aging10 := 0;
l_aging11 := 0;
l_outstanding_entered := NULL;
l_closing_rate := NULL;
l_outstanding_functional:= NULL;
l_unrealized_gain_loss := 0;
l_net_balance := 0;
l_gl_date := NULL;
l_conversion_rate := NULL;
BEGIN
FOR rec_po_nums
IN (SELECT poh.segment1 po_number
FROM ap_invoices_all api
,ap_invoice_distributions_all aid
,ap_invoice_lines_all ail
,po_distributions_all pod
,po_headers_all poh
WHERE api.invoice_id = ail.invoice_id
AND aid.invoice_id = ail.invoice_id
AND api.vendor_id = rec_con_trial_bal_dtls.vendor_id
AND aid.invoice_line_number = ail.line_number
AND aid.po_distribution_id = pod.po_distribution_id
AND pod.po_header_id = poh.po_header_id
AND api.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND api.invoice_amount != 0
AND api.org_id = rec_ledger_details.org_id
AND api.org_id = aid.org_id
AND ail.discarded_flag <> 'Y'
UNION
SELECT aid.po_number po_number
FROM ap_invoices_interface api
,ap_invoice_lines_interface aid
WHERE api.invoice_id = aid.invoice_id
AND api.vendor_id = rec_con_trial_bal_dtls.vendor_id
AND api.invoice_num = rec_con_trial_bal_dtls.invoice_id
AND api.invoice_amount != 0
AND aid.po_number IS NOT NULL
AND api.org_id = rec_ledger_details.org_id
AND api.org_id = aid.org_id
)
LOOP
l_concatenated_po_nums := l_concatenated_po_nums || ',' ||' '|| rec_po_nums.po_number;
END LOOP;
l_concatenated_po_nums := RTRIM(LTRIM (l_concatenated_po_nums, ','),',');
EXCEPTION
WHEN OTHERS THEN
l_concatenated_po_nums := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing PO Number.'||SUBSTR(SQLERRM, 500));
END;
BEGIN
FOR rec_rcpt_nums IN
(SELECT DISTINCT rsh.receipt_num
FROM rcv_shipment_headers rsh
,rcv_transactions rt
,ap_invoice_lines_all aila
,ap_invoice_distributions_all aida
WHERE rt.shipment_header_id = rsh.shipment_header_id
AND rt.transaction_id = aida.rcv_transaction_id
AND aida.invoice_id = aila.invoice_id
AND aida.invoice_line_number = aila.line_number
AND aila.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND aida.org_id = rec_ledger_details.org_id
AND aila.discarded_flag <> 'Y'
AND aida.distribution_line_number = (SELECT MIN (aid1.distribution_line_number)
FROM ap_invoice_distributions_all aid1
WHERE aid1.invoice_id = rec_con_trial_bal_dtls.invoice_id
)
)
LOOP
l_concatenated_rcpt_nums := l_concatenated_rcpt_nums||', '||rec_rcpt_nums.receipt_num;
END LOOP;
l_concatenated_rcpt_nums := rtrim(ltrim (l_concatenated_rcpt_nums, ','),',');
EXCEPTION
WHEN OTHERS THEN
l_concatenated_po_nums := NULL;
fnd_file.put_line(fnd_file.log, 'Error while fetcing PO Number.'||SUBSTR(SQLERRM, 500));
END;
BEGIN
IF rec_con_trial_bal_dtls.aging_days >= 0
AND rec_con_trial_bal_dtls.aging_days <= 30
THEN
l_aging1 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 30
AND rec_con_trial_bal_dtls.aging_days <= 60
THEN
l_aging2 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 60
AND rec_con_trial_bal_dtls.aging_days <= 90
THEN
l_aging3 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 90
AND rec_con_trial_bal_dtls.aging_days <= 180
THEN
l_aging4 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 180
AND rec_con_trial_bal_dtls.aging_days <= 365
THEN
l_aging5 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 365
AND rec_con_trial_bal_dtls.aging_days <= 730
THEN
l_aging6 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 730
AND rec_con_trial_bal_dtls.aging_days <= 1095
THEN
l_aging7 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1095
AND rec_con_trial_bal_dtls.aging_days <= 1460
THEN
l_aging8 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1460
AND rec_con_trial_bal_dtls.aging_days <= 1825
THEN
l_aging9 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 1825
AND rec_con_trial_bal_dtls.aging_days <= 2190
THEN
l_aging10 := rec_con_trial_bal_dtls.remaining_amount;
ELSIF rec_con_trial_bal_dtls.aging_days > 2190
THEN
l_aging11 := rec_con_trial_bal_dtls.remaining_amount;
END IF;
END;
BEGIN
IF rec_ledger_details.currency_code = rec_con_trial_bal_dtls.invoice_curr THEN
l_conversion_rate := 1;
ELSE
BEGIN
SELECT dr.conversion_rate
INTO l_conversion_rate
FROM gl_daily_rates dr
,gl_daily_conversion_types dct
WHERE dr.conversion_type = dct.conversion_type
AND dct.user_conversion_type = p_conversion_type
AND dr.to_currency = rec_ledger_details.currency_code
AND dr.from_currency = rec_con_trial_bal_dtls.invoice_curr
AND TRUNC(dr.conversion_date) = TRUNC(fnd_date.canonical_to_date(p_as_of_date))
;
EXCEPTION
WHEN OTHERS THEN
l_conversion_rate := 0;
fnd_file.put_line(fnd_file.log, 'Error while fetcing Conversion Rate.'||SUBSTR(SQLERRM, 500));
END;
END IF;
EXCEPTION
WHEN OTHERS THEN
l_conversion_rate := 0;
END;
IF rec_ledger_details.currency_code = rec_con_trial_bal_dtls.invoice_curr THEN
l_outstanding_entered := 1;
l_closing_rate := 1;
l_outstanding_functional := rec_con_trial_bal_dtls.remaining_amount;
l_unrealized_gain_loss := 0;
l_net_balance := l_outstanding_functional;
ELSE
l_outstanding_entered := rec_con_trial_bal_dtls.remaining_amount/rec_con_trial_bal_dtls.exchange_rate;
l_closing_rate := l_conversion_rate;
l_outstanding_functional := l_outstanding_entered * l_conversion_rate;
l_unrealized_gain_loss := l_outstanding_functional - rec_con_trial_bal_dtls.remaining_amount;
l_net_balance := l_unrealized_gain_loss + rec_con_trial_bal_dtls.remaining_amount;
END IF;
BEGIN
SELECT af.gl_date
INTO l_gl_date
FROM asi_forex_t af
,gl_code_combinations gcc
,ap_invoices_all aia
WHERE segment1 = af.business_unit
AND business_unit = rec_con_trial_bal_dtls.business_unit
AND aia.invoice_id = rec_con_trial_bal_dtls.invoice_id
AND aia.org_id = rec_ledger_details.org_id
AND liability_account = segment3
AND liability_account = rec_con_trial_bal_dtls.liability_account
AND (aia.invoice_num = af.invoice_num OR '0'||af.invoice_num = aia.invoice_num)
AND ROWNUM = 1;
EXCEPTION
WHEN OTHERS THEN
l_gl_date := NULL;
END;
fnd_file.put_line(fnd_file.output, rec_con_trial_bal_dtls.business_unit
||'^'||rec_con_trial_bal_dtls.liability_account
||'^'||rec_con_trial_bal_dtls.vendor_name
||'^'||rec_con_trial_bal_dtls.vendor_number
||'^'||rec_con_trial_bal_dtls.vendor_site_code
||'^'||rec_con_trial_bal_dtls.vendor_type_lookup_code
||'^'||rec_con_trial_bal_dtls.pay_group_lookup_code
||'^'||rec_con_trial_bal_dtls.source
||'^'||rec_con_trial_bal_dtls.invoice_type
||'^'||rec_con_trial_bal_dtls.invoice_num
||'^'||rec_con_trial_bal_dtls.creation_date
||'^'||rec_con_trial_bal_dtls.invoice_date
||'^'||rec_con_trial_bal_dtls.invoice_received_date
||'^'||rec_con_trial_bal_dtls.voucher_num
||'^'||rec_con_trial_bal_dtls.invoice_id
||'^'||l_concatenated_po_nums
||'^'||l_concatenated_rcpt_nums
||'^'||rec_con_trial_bal_dtls.attribute8
||'^'||rec_con_trial_bal_dtls.gl_date
||'^'||rec_con_trial_bal_dtls.invoice_curr
||'^'||rec_con_trial_bal_dtls.exchange_rate
||'^'||rec_con_trial_bal_dtls.invoice_amt_entered
||'^'||rec_con_trial_bal_dtls.invoice_amt_functional
||'^'||rec_con_trial_bal_dtls.invoice_amt_wht_functional
||'^'||rec_con_trial_bal_dtls.amount_paid
||'^'||rec_con_trial_bal_dtls.remaining_amount
||'^'||rec_con_trial_bal_dtls.invoice_payment_status
||'^'||REPLACE(REPLACE(REPLACE(REPLACE(regexp_replace(rec_con_trial_bal_dtls.invoice_description,'([^[:graph:]|^[:blank:]])',' '),CHR(10),''),CHR(13),''),'"',''),'|',' ')
||'^'||rec_con_trial_bal_dtls.aging_days
||'^'||l_aging1
||'^'||l_aging2
||'^'||l_aging3
||'^'||l_aging4
||'^'||l_aging5
||'^'||l_aging6
||'^'||l_aging7
||'^'||l_aging8
||'^'||l_aging9
||'^'||l_aging10
||'^'||l_aging11
||'^'||l_gl_date
||'^'||l_outstanding_entered
||'^'||l_closing_rate
||'^'||l_outstanding_functional
||'^'||l_unrealized_gain_loss
||'^'||l_net_balance
);
END LOOP;
END LOOP;
fnd_file.put_line(fnd_file.log, 'Program Ended at ' || to_char(sysdate,'DD-MON-YYYY HH24:MI:SS'));
EXCEPTION
WHEN OTHERS THEN
fnd_file.put_line(fnd_file.log, 'Main Error in asi_con_ap_trial_bal_rpt_pkg.aa_con_ap_trial_bal_rpt procedure. Error Message: '||SQLERRM);
END aa_con_ap_trial_bal_rpt;
END SI_CON_AP_TRIAL_BAL_RPT_PKG;
/
No comments:
Post a Comment