Tuesday, 20 December 2016

Supplier Conversion


CREATE OR REPLACE PACKAGE BODY XXCSC_AP_SUPPLIERS_CONV_PKG
AS

/*  $Header: XXCSC_AP_SUPPLIERS_CONV_PKG.pkb version date time object_type module     $
===========================================================================================

===========================================================================================


 History:

  Name                Version     Reason for Change   Date
===========================================================================================
Madhu  Dhare        1.0         Original   12-JUN-2014

===========================================================================================
*/

---------------------------------------------------------------------------------------------
-- Variable Declaration
---------------------------------------------------------------------------------------------


---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPPLIERS_MAPPING_PROC
-- DESCRIPTION     :  Supplier Mapping Activity in Staging Table
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_MAPPING_PROC (x_object_name IN  VARCHAR2
    ,x_stage    IN  VARCHAR2
    )
IS

x_query   VARCHAR2(4000);

CURSOR CUR_MAP IS
SELECT table_name
      ,column_name
      ,legacy_code
      ,legacy_description
      ,target_code
      ,target_description
  FROM XXHR.xxcsc_cmn_mapping_all mt
      ,XXHR.xxcsc_cmn_metadata_all st
 WHERE mt.object_code = st.object_code
   AND mt.object_dep_seq = st.object_dep_seq
   AND st.object_name = x_object_name
   AND mt.enable_flag = x_yes
   AND st.enable_flag = x_yes;

BEGIN

  XXCSC_AP_SUPPLIERS_CONV_PKG.x_object := x_object_name;

--- Update the PROCESS FLAG AS M
   XXCSC_AP_SUPP_STATUS_PROC (x_mapping_flag
                ,NULL -- x_status
    );

   FOR rec_map IN cur_map LOOP
       x_query := 'UPDATE XXHR.' || rec_map.table_name ||' SET ' ||rec_map.column_name || ' = '''|| rec_map.target_code ||''' , status_flag = ''' ||x_mapped_flag || '''  WHERE  EXISTS (SELECT 1 FROM XXHR.xxcsc_cmn_mapping_all b WHERE b.enable_flag = ''Y'' AND b.legacy_code = '|| rec_map.column_name || ' )' ;
       EXECUTE IMMEDIATE (x_query);
       COMMIT;
   END LOOP;

   --- Update the STATUS FLAG AS NM
   XXCSC_AP_SUPP_STATUS_PROC (NULL
                ,x_notmapped_flag -- x_status
     );


   IF x_stage = x_mapping_stg THEN
      XXCSC_AP_SUPP_ERROR_PROC (x_object_name
        ,x_stage
      );
   END IF;

EXCEPTION
   WHEN OTHERS THEN
        XXCSC_AP_SUPP_PRINT_PROC('ERROR :  '|| SQLCODE);
        XXCSC_AP_SUPP_PRINT_PROC('ERROR DESCRIPTION - ' || SQLERRM);
        ROLLBACK;

END XXCSC_AP_SUPP_MAPPING_PROC;

---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPPLIERS_VALIDATION_PROC
-- DESCRIPTION     :  Supplier Validation Activity in Staging table
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_VALIDATION_PROC (x_object_name IN  VARCHAR2
,x_stage       IN  VARCHAR2
)
IS

-- Local Variable Declaration
  x_cnt NUMBER ;
  x_query VARCHAR2(4000);
  x_select VARCHAR2(2000);
  x_str VARCHAR2(100);
  x_arg1         VARCHAR2(100);
  x_arg2         VARCHAR2(100);
  x_arg3         VARCHAR2(100);
  x_arg4         VARCHAR2(100);
  x_pr_flag      VARCHAR2(20);
  x_st_flag      VARCHAR2(20);
  x_val NUMBER;
  x_val1 NUMBER;


-- Ref Cursor Declaration
  TYPE x_ref_cur  IS REF CURSOR;
  x_dyn_cur1  x_ref_cur;
  x_dyn_cur2  x_ref_cur;

-- Cursor Declaration
  CURSOR cur_tbl IS
  SELECT DISTINCT
         st.table_name
        ,st.key_column1  key_column1
        ,NVL(st.key_column2,'1') key_column2
        ,NVL(st.key_column3,'1') key_column3
,st.object_dep_seq  
    FROM XXHR.xxcsc_cmn_metadata_all st    
   WHERE st.object_name = x_object_name
     AND st.enable_flag = x_yes
ORDER BY object_dep_seq;

  CURSOR cur_valid  IS
  SELECT st.table_name
        ,st.key_column1
        ,NVL(st.key_column2,'1') key_column2
        ,NVL(st.key_column3, '1') key_column3            
        ,cv1.valid_code
        ,cv1.valid_message      
        ,cv1.sql_validation
,cv1.valid_type
    FROM XXHR.xxcsc_cmn_validations_all cv1
        ,XXHR.xxcsc_cmn_metadata_all st
   WHERE cv1.object_code = st.object_code
     AND cv1.object_dep_seq = st.object_dep_seq
     AND st.object_name =  x_object_name
     AND st.enable_flag = x_yes
     AND cv1.enable_flag = x_yes
     AND cv1.execution_seq <1000
ORDER BY st.object_dep_seq
        ,cv1.execution_seq;

  CURSOR cur_valid1  IS
  SELECT st.table_name
        ,st.key_column1
        ,NVL(st.key_column2,'1') key_column2
        ,NVL(st.key_column3, '1') key_column3            
        ,cv1.valid_code
        ,cv1.valid_message      
        ,cv1.sql_validation
,cv1.valid_type
    FROM XXHR.xxcsc_cmn_validations_all cv1
        ,XXHR.xxcsc_cmn_metadata_all st
   WHERE cv1.object_code = st.object_code
     AND cv1.object_dep_seq = st.object_dep_seq
     AND st.object_name =  x_object_name
     AND st.enable_flag = x_yes
     AND cv1.enable_flag = x_yes
     AND cv1.execution_seq >=1000
ORDER BY st.object_dep_seq
        ,cv1.execution_seq;

BEGIN
    XXCSC_AP_SUPPLIERS_CONV_PKG.x_object := x_object_name;

    XXCSC_AP_SUPP_STATUS_PROC (x_validate_flag
                 ,NULL -- x_status
     );

    FOR rec_tbl IN cur_tbl LOOP
        x_select := 'SELECT RECORD_ID, '|| rec_tbl.key_column1 ||' ,'||rec_tbl.key_column2 || ' ,'|| rec_tbl.key_column3|| ' FROM XXHR.'|| TRIM(rec_tbl.table_name);
        x_select := REPLACE(x_select,'1','DECODE(1,1,'' '')');

OPEN x_dyn_cur1 FOR x_select;
LOOP
FETCH x_dyn_cur1 INTO x_arg1,x_arg2,x_arg3,x_arg4 ;

        EXIT WHEN x_dyn_cur1%NOTFOUND;

           FOR rec_valid IN cur_valid LOOP
      IF (rec_valid.table_name=rec_tbl.table_name) THEN
BEGIN              
  x_query := rec_valid.sql_validation;
            x_str := ' AND MT.RECORD_ID='||x_arg1;
                   x_query := CONCAT(x_query,x_str);

                   EXECUTE IMMEDIATE (x_query) INTO x_cnt;

  IF x_cnt >0 THEN
                       x_query := 'UPDATE XXHR.'|| TRIM(rec_valid.TABLE_NAME) ||' SET error_code = error_code ||'','|| rec_valid.VALID_CODE || ''', status_flag = ''' || rec_valid.valid_type || ''' WHERE record_id = '||x_arg1 ;
             EXECUTE IMMEDIATE (x_query) ;

                 COMMIT;
  END IF;

     EXCEPTION
WHEN OTHERS THEN
XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED: ' || SQLCODE);
XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED IN VALIDATION STAGE - ' || SQLERRM);
ROLLBACK;

END;

      END IF;
           END LOOP;
END LOOP;
    END LOOP;


--Orphan Record Validate Start
   FOR rec_tbl IN cur_tbl LOOP
        x_select := 'SELECT RECORD_ID, '|| rec_tbl.key_column1 ||' ,'||rec_tbl.key_column2 || ' ,'|| rec_tbl.key_column3|| ' FROM XXHR.'|| TRIM(rec_tbl.table_name);
        x_select := REPLACE(x_select,'1','DECODE(1,1,'' '')');

OPEN x_dyn_cur1 FOR x_select;
LOOP
FETCH x_dyn_cur1 INTO x_arg1,x_arg2,x_arg3,x_arg4 ;

        EXIT WHEN x_dyn_cur1%NOTFOUND;

           FOR rec_valid IN cur_valid1 LOOP
      IF (rec_valid.table_name=rec_tbl.table_name) THEN
BEGIN              
  x_query := rec_valid.sql_validation;
            x_str := ' AND MT.RECORD_ID='||x_arg1;
                   x_query := CONCAT(x_query,x_str);

                   EXECUTE IMMEDIATE (x_query) INTO x_cnt;

  IF x_cnt >0 THEN
                       x_query := 'UPDATE XXHR.'|| TRIM(rec_valid.TABLE_NAME) ||' SET error_code = error_code ||'','|| rec_valid.VALID_CODE || ''', status_flag = ''' || rec_valid.valid_type || ''' WHERE record_id = '||x_arg1 ;
             EXECUTE IMMEDIATE (x_query) ;

                 COMMIT;
  END IF;

     EXCEPTION
WHEN OTHERS THEN
XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED: ' || SQLCODE);
XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED IN VALIDATION STAGE - ' || SQLERRM);
ROLLBACK;

END;

      END IF;
           END LOOP;
END LOOP;
    END LOOP;
--Orphan Record  Validate End

   --- Update the STATUS FLAG AS V
   XXCSC_AP_SUPP_STATUS_PROC (NULL
                ,x_validate_flag -- x_status
     );

   IF x_stage = x_validate_stg THEN
      XXCSC_AP_SUPP_ERROR_PROC (x_object_name
        ,x_stage
      );
   END IF;
     

EXCEPTION
   WHEN OTHERS THEN
        XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED: ' || SQLCODE);
        XXCSC_AP_SUPP_PRINT_PROC('ERROR OCCURED IN VALIDATION STAGE - ' || SQLERRM);
        ROLLBACK;

END XXCSC_AP_SUPP_VALIDATION_PROC;

---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPPLIERS_TRANSFER_PROC
-- DESCRIPTION     :  Supplier Data Transfer from Staging Table into Interface Table
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_TRANSFER_PROC (x_object_name IN  VARCHAR2
     ,x_stage IN  VARCHAR2
     )
IS
    x_pr_flag      VARCHAR2(20);
    x_st_flag      VARCHAR2(20);

BEGIN
    XXCSC_AP_SUPPLIERS_CONV_PKG.x_object := x_object_name;
 
 FOR rec_hr IN cur_hr LOOP
       UPDATE XXHR.xxcsc_ap_supplier_headers
          SET process_flag = x_transfer_flag;
     
       COMMIT;
   END LOOP;

--- Update the PROCESS FLAG
   FOR rec_st IN cur_st LOOP
       UPDATE XXHR.xxcsc_ap_supplier_sites
          SET process_flag = x_transfer_flag;

       COMMIT;
   END LOOP;

--- Update the PROCESS FLAG
   FOR rec_cn IN cur_cn LOOP
       UPDATE XXHR.xxcsc_ap_supplier_contacts
          SET process_flag = x_transfer_flag;

       COMMIT;
   END LOOP;

-- Purge Supplier Interface Table

   DELETE FROM APPS.ap_suppliers_int;
   DELETE FROM APPS.ap_supplier_sites_int;
   DELETE FROM APPS.ap_sup_site_contact_int;
   COMMIT;

   FOR rec_hdr IN  cur_hdr (x_validate_flag) LOOP
       BEGIN
          -- SUPPLIER HEADER INSERT INTO INTERFACE TABLE
  INSERT INTO APPS.ap_suppliers_int
         (
  vendor_interface_id
 ,last_update_date
 ,last_updated_by
 ,vendor_name
 ,vendor_name_alt
 ,segment1
 ,summary_flag
 ,enabled_flag
 ,last_update_login
 ,creation_date
 ,created_by
 ,employee_id
 ,vendor_type_lookup_code
 ,customer_num
 ,one_time_flag
 ,min_order_amount
 ,ship_to_location_id
 ,ship_to_location_code
 ,bill_to_location_id
 ,bill_to_location_code
 ,ship_via_lookup_code
 ,freight_terms_lookup_code
 ,fob_lookup_code
 ,terms_id
 ,terms_name
 ,set_of_books_id
 ,always_take_disc_flag
 ,pay_date_basis_lookup_code
 ,pay_group_lookup_code
 ,payment_priority
 ,invoice_currency_code
 ,payment_currency_code
 ,invoice_amount_limit
 ,hold_all_payments_flag
 ,hold_future_payments_flag
 ,hold_reason
 ,distribution_set_id
 ,distribution_set_name
 ,accts_pay_code_combination_id
 ,prepay_code_combination_id
 ,num_1099
 ,type_1099
 ,organization_type_lookup_code
 ,vat_code
 ,start_date_active
 ,end_date_active
 ,minority_group_lookup_code
 ,payment_method_lookup_code
 ,women_owned_flag
 ,small_business_flag
 ,standard_industry_class
 ,hold_flag
 ,purchasing_hold_reason
 ,hold_by
 ,hold_date
 ,terms_date_basis
 ,inspection_required_flag
 ,receipt_required_flag
 ,qty_rcv_tolerance
 ,qty_rcv_exception_code
 ,enforce_ship_to_location_code
 ,days_early_receipt_allowed
 ,days_late_receipt_allowed
 ,receipt_days_exception_code
 ,receiving_routing_id
 ,allow_substitute_receipts_flag
 ,allow_unordered_receipts_flag
 ,hold_unmatched_invoices_flag
 ,exclusive_payment_flag
 ,ap_tax_rounding_rule
 ,auto_tax_calc_flag
 ,auto_tax_calc_override
 ,amount_includes_tax_flag
 ,tax_verification_date
 ,name_control
 ,state_reportable_flag
 ,federal_reportable_flag
 ,attribute_category
 ,attribute1
 ,attribute2
 ,attribute3
 ,attribute4
 ,attribute5
 ,attribute6
 ,attribute7
 ,attribute8
 ,attribute9
 ,attribute10
 ,attribute11
 ,attribute12
 ,attribute13
 ,attribute14
 ,attribute15
 ,request_id
 ,program_application_id
 ,program_id
 ,program_update_date
 ,vat_registration_num
 ,auto_calculate_interest_flag
 ,exclude_freight_from_discount
 ,tax_reporting_name
 ,allow_awt_flag
 ,awt_group_id
 ,awt_group_name
 ,global_attribute1
 ,global_attribute2
 ,global_attribute3
 ,global_attribute4
 ,global_attribute5
 ,global_attribute6
 ,global_attribute7
 ,global_attribute8
 ,global_attribute9
 ,global_attribute10
 ,global_attribute11
 ,global_attribute12
 ,global_attribute13
 ,global_attribute14
 ,global_attribute15
 ,global_attribute16
 ,global_attribute17
 ,global_attribute18
 ,global_attribute19
 ,global_attribute20
 ,global_attribute_category
 ,edi_transaction_handling
 ,edi_payment_method
 ,edi_payment_format
 ,edi_remittance_method
 ,edi_remittance_instruction
 ,bank_charge_bearer
 ,match_option
 ,future_dated_payment_ccid
 ,create_debit_memo_flag
 ,offset_tax_flag
 ,import_request_id
 ,status
 ,reject_code
 ,ece_tp_location_code
 ,iby_bank_charge_bearer
 ,bank_instruction1_code
 ,bank_instruction2_code
 ,bank_instruction_details
 ,payment_reason_code
 ,payment_reason_comments
 ,payment_text_message1
 ,payment_method_code
 )
   VALUES
        (
  rec_hdr.record_id
 ,SYSDATE --last_update_date
 ,APPS.FND_GLOBAL.USER_ID --last_updated_by
 ,rec_hdr.vendor_name
 ,rec_hdr.vendor_name_alt
 ,rec_hdr.vendor_number
 ,rec_hdr.summary_flag
 ,rec_hdr.enabled_flag
 ,APPS.FND_GLOBAL.USER_ID --last_update_login
 ,SYSDATE --creation_date
 ,APPS.FND_GLOBAL.USER_ID --created_by
 ,rec_hdr.employee_id
 ,rec_hdr.vendor_type_lookup_code
 ,rec_hdr.customer_num
 ,rec_hdr.one_time_flag
 ,rec_hdr.min_order_amount
 ,rec_hdr.ship_to_location_id
 ,rec_hdr.ship_to_location_code
 ,rec_hdr.bill_to_location_id
 ,rec_hdr.bill_to_location_code
 ,rec_hdr.ship_via_lookup_code
 ,rec_hdr.freight_terms_lookup_code
 ,rec_hdr.fob_lookup_code
 ,rec_hdr.terms_id
 ,rec_hdr.terms_name
 ,rec_hdr.set_of_books_id
 ,rec_hdr.always_take_disc_flag
 ,rec_hdr.pay_date_basis_lookup_code
 ,rec_hdr.pay_group_lookup_code
 ,rec_hdr.payment_priority
 ,rec_hdr.invoice_currency_code
 ,rec_hdr.payment_currency_code
 ,rec_hdr.invoice_amount_limit
 ,rec_hdr.hold_all_payments_flag
 ,rec_hdr.hold_future_payments_flag
 ,rec_hdr.hold_reason
 ,rec_hdr.distribution_set_id
 ,rec_hdr.distribution_set_name
 ,rec_hdr.accts_pay_code_combination_id
 ,rec_hdr.prepay_code_combination_id
 ,rec_hdr.num_1099
 ,rec_hdr.type_1099
 ,rec_hdr.organization_type_lookup_code
 ,rec_hdr.vat_code
 ,rec_hdr.start_date_active
 ,rec_hdr.end_date_active
 ,rec_hdr.minority_group_lookup_code
 ,rec_hdr.payment_method_lookup_code
 ,rec_hdr.women_owned_flag
 ,rec_hdr.small_business_flag
 ,rec_hdr.standard_industry_class
 ,rec_hdr.hold_flag
 ,rec_hdr.purchasing_hold_reason
 ,rec_hdr.hold_by
 ,rec_hdr.hold_date
 ,rec_hdr.terms_date_basis
 ,rec_hdr.inspection_required_flag
 ,rec_hdr.receipt_required_flag
 ,rec_hdr.qty_rcv_tolerance
 ,rec_hdr.qty_rcv_exception_code
 ,rec_hdr.enforce_ship_to_location_code
 ,rec_hdr.days_early_receipt_allowed
 ,rec_hdr.days_late_receipt_allowed
 ,rec_hdr.receipt_days_exception_code
 ,rec_hdr.receiving_routing_id
 ,rec_hdr.allow_substitute_receipts_flag
 ,rec_hdr.allow_unordered_receipts_flag
 ,rec_hdr.hold_unmatched_invoices_flag
 ,rec_hdr.exclusive_payment_flag
 ,rec_hdr.ap_tax_rounding_rule
 ,rec_hdr.auto_tax_calc_flag
 ,rec_hdr.auto_tax_calc_override
 ,rec_hdr.amount_includes_tax_flag
 ,rec_hdr.tax_verification_date
 ,rec_hdr.name_control
 ,rec_hdr.state_reportable_flag
 ,rec_hdr.federal_reportable_flag
 ,rec_hdr.attribute_category
 ,rec_hdr.attribute1
 ,rec_hdr.attribute2
 ,rec_hdr.attribute3
 ,rec_hdr.attribute4
 ,rec_hdr.attribute5
 ,rec_hdr.attribute6
 ,rec_hdr.attribute7
 ,rec_hdr.attribute8
 ,rec_hdr.attribute9
 ,rec_hdr.attribute10
 ,rec_hdr.attribute11
 ,rec_hdr.attribute12
 ,rec_hdr.attribute13
 ,rec_hdr.attribute14
 ,rec_hdr.attribute15
 ,APPS.FND_GLOBAL.CONC_REQUEST_ID -- request_id
 ,NULL -- program_application_id
 ,NULL -- program_id
 ,NULL -- program_update_date
 ,rec_hdr.vat_registration_num
 ,rec_hdr.auto_calculate_interest_flag
 ,rec_hdr.exclude_freight_from_discount
 ,rec_hdr.tax_reporting_name
 ,rec_hdr.allow_awt_flag
 ,rec_hdr.awt_group_id
 ,rec_hdr.awt_group_name
 ,rec_hdr.global_attribute1
 ,rec_hdr.global_attribute2
 ,rec_hdr.global_attribute3
 ,rec_hdr.global_attribute4
 ,rec_hdr.global_attribute5
 ,rec_hdr.global_attribute6
 ,rec_hdr.global_attribute7
 ,rec_hdr.global_attribute8
 ,rec_hdr.global_attribute9
 ,rec_hdr.global_attribute10
 ,rec_hdr.global_attribute11
 ,rec_hdr.global_attribute12
 ,rec_hdr.global_attribute13
 ,rec_hdr.global_attribute14
 ,rec_hdr.global_attribute15
 ,rec_hdr.global_attribute16
 ,rec_hdr.global_attribute17
 ,rec_hdr.global_attribute18
 ,rec_hdr.global_attribute19
 ,rec_hdr.global_attribute20
 ,rec_hdr.global_attribute_category
 ,rec_hdr.edi_transaction_handling
 ,rec_hdr.edi_payment_method
 ,rec_hdr.edi_payment_format
 ,rec_hdr.edi_remittance_method
 ,rec_hdr.edi_remittance_instruction
 ,rec_hdr.bank_charge_bearer
 ,rec_hdr.match_option
 ,rec_hdr.future_dated_payment_ccid
 ,rec_hdr.create_debit_memo_flag
 ,rec_hdr.offset_tax_flag
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL
 ,NULL);

          UPDATE XXHR.xxcsc_ap_supplier_headers hdr
             SET hdr.status_flag = x_transfered_flag
           WHERE hdr.vendor_number = rec_hdr.vendor_number
    AND hdr.record_id = rec_hdr.record_id;

          FOR rec_sit IN  cur_sit (x_validate_flag,rec_hdr.vendor_number) LOOP
              BEGIN
     
        INSERT INTO APPS.ap_supplier_sites_int
       (
 vendor_interface_id
,last_update_date
,last_updated_by
,vendor_id
,vendor_site_code
,vendor_site_code_alt
,last_update_login
,creation_date
,created_by
,purchasing_site_flag
,rfq_only_site_flag
,pay_site_flag
,attention_ar_flag
,address_line1
,address_lines_alt
,address_line2
,address_line3
,city
,state
,zip
,province
,country
,area_code
,phone
,customer_num
,ship_to_location_id
,ship_to_location_code
,bill_to_location_id
,bill_to_location_code
,ship_via_lookup_code
,freight_terms_lookup_code
,fob_lookup_code
,inactive_date
,fax
,fax_area_code
,telex
,payment_method_lookup_code
,terms_date_basis
,vat_code
,distribution_set_id
,distribution_set_name
,accts_pay_code_combination_id
,prepay_code_combination_id
,pay_group_lookup_code
,payment_priority
,terms_id
,terms_name
,invoice_amount_limit
,pay_date_basis_lookup_code
,always_take_disc_flag
,invoice_currency_code
,payment_currency_code
,hold_all_payments_flag
,hold_future_payments_flag
,hold_reason
,hold_unmatched_invoices_flag
,ap_tax_rounding_rule
,auto_tax_calc_flag
,auto_tax_calc_override
,amount_includes_tax_flag
,exclusive_payment_flag
,tax_reporting_site_flag
,attribute_category
,attribute1
,attribute2
,attribute3
,attribute4
,attribute5
,attribute6
,attribute7
,attribute8
,attribute9
,attribute10
,attribute11
,attribute12
,attribute13
,attribute14
,attribute15
,request_id
,program_application_id
,program_id
,program_update_date
,exclude_freight_from_discount
,vat_registration_num
,org_id
,operating_unit_name
,address_line4
,county
,address_style
,language
,allow_awt_flag
,awt_group_id
,awt_group_name
,global_attribute1
,global_attribute2
,global_attribute3
,global_attribute4
,global_attribute5
,global_attribute6
,global_attribute7
,global_attribute8
,global_attribute9
,global_attribute10
,global_attribute11
,global_attribute12
,global_attribute13
,global_attribute14
,global_attribute15
,global_attribute16
,global_attribute17
,global_attribute18
,global_attribute19
,global_attribute20
,global_attribute_category
,edi_transaction_handling
,edi_id_number
,edi_payment_method
,edi_payment_format
,edi_remittance_method
,bank_charge_bearer
,edi_remittance_instruction
,pay_on_code
,default_pay_site_id
,pay_on_receipt_summary_code
,tp_header_id
,ece_tp_location_code
,pcard_site_flag
,match_option
,country_of_origin_code
,future_dated_payment_ccid
,create_debit_memo_flag
,offset_tax_flag
,supplier_notif_method
,email_address
,remittance_email
,primary_pay_site_flag
,import_request_id
,status
,reject_code
,shipping_control
,duns_number
,tolerance_id
,tolerance_name
,iby_bank_charge_bearer
,bank_instruction1_code
,bank_instruction2_code
,bank_instruction_details
,payment_reason_code
,payment_reason_comments
,delivery_channel_code
,payment_format_code
,settlement_priority
,payment_text_message1
,payment_text_message2
,payment_text_message3
,vendor_site_interface_id
,payment_method_code
,retainage_rate
,gapless_inv_num_flag
,selling_company_identifier
)
  VALUES
        (
         rec_hdr.record_id
,SYSDATE -- last_update_date
,APPS.FND_GLOBAL.USER_ID --last_updated_by
,NULL -- rec_sit.vendor_id
,rec_sit.vendor_site_code
,rec_sit.vendor_site_code_alt
,APPS.FND_GLOBAL.USER_ID -- last_update_login
,SYSDATE -- creation_date
,APPS.FND_GLOBAL.USER_ID               -- created_by
,rec_sit.purchasing_site_flag
,rec_sit.rfq_only_site_flag
,rec_sit.pay_site_flag
,rec_sit.attention_ar_flag
,rec_sit.address_line1
,rec_sit.address_lines_alt
,rec_sit.address_line2
,rec_sit.address_line3
,rec_sit.city
,rec_sit.state
,rec_sit.zip
,rec_sit.province
,rec_sit.country
,rec_sit.area_code
,rec_sit.phone
,rec_sit.customer_num
,rec_sit.ship_to_location_id
,rec_sit.ship_to_location_code
,rec_sit.bill_to_location_id
,rec_sit.bill_to_location_code
,rec_sit.ship_via_lookup_code
,rec_sit.freight_terms_lookup_code
,rec_sit.fob_lookup_code
,rec_sit.inactive_date
,rec_sit.fax
,rec_sit.fax_area_code
,rec_sit.telex
,rec_sit.payment_method_lookup_code
,rec_sit.terms_date_basis
,rec_sit.vat_code
,rec_sit.distribution_set_id
,rec_sit.distribution_set_name
,rec_sit.accts_pay_code_combination_id
,rec_sit.prepay_code_combination_id
,rec_sit.pay_group_lookup_code
,rec_sit.payment_priority
,rec_sit.terms_id
,rec_sit.terms_name
,rec_sit.invoice_amount_limit
,rec_sit.pay_date_basis_lookup_code
,rec_sit.always_take_disc_flag
,rec_sit.invoice_currency_code
,rec_sit.payment_currency_code
,rec_sit.hold_all_payments_flag
,rec_sit.hold_future_payments_flag
,rec_sit.hold_reason
,rec_sit.hold_unmatched_invoices_flag
,rec_sit.ap_tax_rounding_rule
,rec_sit.auto_tax_calc_flag
,rec_sit.auto_tax_calc_override
,rec_sit.amount_includes_tax_flag
,rec_sit.exclusive_payment_flag
,rec_sit.tax_reporting_site_flag
,rec_sit.attribute_category
,rec_sit.attribute1
,rec_sit.attribute2
,rec_sit.attribute3
,rec_sit.attribute4
,rec_sit.attribute5
,rec_sit.attribute6
,rec_sit.attribute7
,rec_sit.attribute8
,rec_sit.attribute9
,rec_sit.attribute10
,rec_sit.attribute11
,rec_sit.attribute12
,rec_sit.attribute13
,rec_sit.attribute14
,rec_sit.attribute15
,rec_sit.request_id
,NULL -- program_application_id
,NULL -- program_id
,NULL -- program_update_date
,rec_sit.exclude_freight_from_discount
,rec_sit.vat_registration_num
,rec_sit.org_id
,rec_sit.org_name
,rec_sit.address_line4
,rec_sit.county
,rec_sit.address_style
,rec_sit.language
,rec_sit.allow_awt_flag
,rec_sit.awt_group_id
,rec_sit.awt_group_name
,rec_sit.global_attribute1
,rec_sit.global_attribute2
,rec_sit.global_attribute3
,rec_sit.global_attribute4
,rec_sit.global_attribute5
,rec_sit.global_attribute6
,rec_sit.global_attribute7
,rec_sit.global_attribute8
,rec_sit.global_attribute9
,rec_sit.global_attribute10
,rec_sit.global_attribute11
,rec_sit.global_attribute12
,rec_sit.global_attribute13
,rec_sit.global_attribute14
,rec_sit.global_attribute15
,rec_sit.global_attribute16
,rec_sit.global_attribute17
,rec_sit.global_attribute18
,rec_sit.global_attribute19
,rec_sit.global_attribute20
,rec_sit.global_attribute_category
,rec_sit.edi_transaction_handling
,rec_sit.edi_id_number
,rec_sit.edi_payment_method
,rec_sit.edi_payment_format
,rec_sit.edi_remittance_method
,rec_sit.bank_charge_bearer
,rec_sit.edi_remittance_instruction
,rec_sit.pay_on_code
,rec_sit.default_pay_site_id
,rec_sit.pay_on_receipt_summary_code
,rec_sit.tp_header_id
,rec_sit.ece_tp_location_code
,rec_sit.pcard_site_flag
,rec_sit.match_option
,rec_sit.country_of_origin_code
,rec_sit.future_dated_payment_ccid
,rec_sit.create_debit_memo_flag
,rec_sit.offset_tax_flag
,rec_sit.supplier_notif_method
,rec_sit.email_address
,rec_sit.remittance_email
,rec_sit.primary_pay_site_flag
,NULL -- import_request_id
,NULL -- status
,NULL -- reject_code
,rec_sit.shipping_control
,rec_sit.duns_number
,rec_sit.tolerance_id
,rec_sit.tolerance_name
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,NULL
,rec_sit.record_id
,NULL
,rec_sit.retainage_rate
,rec_sit.gapless_inv_num_flag
,rec_sit.selling_company_identifier
);

        UPDATE XXHR.xxcsc_ap_supplier_sites sit
                    SET sit.status_flag = x_transfered_flag
                  WHERE sit.vendor_number = rec_hdr.vendor_number
           AND sit.vendor_site_code = rec_sit.vendor_site_code
           AND sit.record_id = rec_sit.record_id;

        FOR rec_con IN  cur_con (x_validate_flag,rec_hdr.vendor_number,rec_sit.vendor_site_code) LOOP
            BEGIN
INSERT INTO APPS.ap_sup_site_contact_int
      (
  last_update_date
  ,last_updated_by
  ,vendor_site_id
  ,vendor_site_code
  ,org_id
  ,operating_unit_name
  ,last_update_login
  ,creation_date
  ,created_by
  ,inactive_date
  ,first_name
  ,middle_name
  ,last_name
  ,prefix
  ,title
  ,mail_stop
  ,area_code
  ,phone
  ,program_application_id
  ,program_id
  ,program_update_date
  ,request_id
  ,contact_name_alt
  ,first_name_alt
  ,last_name_alt
  ,department
  ,import_request_id
  ,status
  ,reject_code
  ,email_address
  ,url
  ,alt_area_code
  ,alt_phone
  ,fax_area_code
  ,fax
  ,vendor_interface_id
  ,vendor_id
  ,vendor_contact_interface_id
)
 VALUES
(
SYSDATE --  last_update_date
  ,APPS.FND_GLOBAL.USER_ID -- last_updated_by
  ,rec_sit.vendor_site_id
  ,rec_con.vendor_site_code
  ,rec_con.org_id -- org_id
  ,rec_con.org_name -- operating_unit_name
  ,APPS.FND_GLOBAL.USER_ID -- last_update_login
  ,SYSDATE -- creation_date
  ,APPS.FND_GLOBAL.USER_ID -- created_by
  ,rec_con.inactive_date
  ,rec_con.first_name
  ,rec_con.middle_name
  ,rec_con.last_name
  ,rec_con.prefix
  ,rec_con.title
  ,rec_con.mail_stop
  ,rec_con.area_code
  ,rec_con.phone
  ,NULL -- program_application_id
  ,NULL -- program_id
  ,NULL -- program_update_date
  ,rec_con.request_id
  ,rec_con.contact_name_alt
  ,rec_con.first_name_alt
  ,rec_con.last_name_alt
  ,rec_con.department
  ,NULL -- import_request_id
  ,NULL -- status
  ,NULL -- reject_code
  ,rec_con.email_address
  ,rec_con.url
  ,rec_con.alt_area_code
  ,rec_con.alt_phone
  ,rec_con.fax_area_code
  ,rec_con.fax
  ,rec_hdr.record_id
  ,NULL -- rec_hdr.record_id
  ,rec_con.record_id
);

                 UPDATE XXHR.xxcsc_ap_supplier_contacts con
                           SET con.status_flag = x_transfered_flag
                         WHERE con.vendor_number = rec_hdr.vendor_number
                  AND con.vendor_site_code = rec_sit.vendor_site_code
                  AND con.record_id = rec_con.record_id;

COMMIT;

            EXCEPTION
                        WHEN OTHERS THEN
                        XXCSC_AP_SUPP_PRINT_PROC ('Contact Error: Error occured while SUPPLIER CONATCS data transfer from Staging table into Interface Table ');
               ROLLBACK;
            END;
        END LOOP;

              EXCEPTION
                 WHEN OTHERS THEN
                 XXCSC_AP_SUPP_PRINT_PROC ('Site Error: Error occured while SUPPLIER SITES data transfer from Staging table into Interface Table ');
        ROLLBACK;
              END;
          END LOOP;

       EXCEPTION
          WHEN OTHERS THEN
          XXCSC_AP_SUPP_PRINT_PROC ('Header Error: Error occured while SUPPLIER HEADERS data transfer from Staging table into Interface Table ');
          ROLLBACK;
       END;
   END LOOP;

      XXCSC_AP_SUPP_STATUS_PROC (NULL
                   ,x_nottransfer_flag -- x_status
       );


    IF x_stage IN (x_transfer_stg, x_all_stg) THEN
      XXCSC_AP_SUPP_ERROR_PROC (x_object_name
        ,x_stage
      );
   END IF;

EXCEPTION
   WHEN OTHERS THEN
        XXCSC_AP_SUPP_PRINT_PROC( 'ERROR OCCURED : '|| SQLCODE );
        XXCSC_AP_SUPP_PRINT_PROC( 'ERROR DESCRIPTION - ' || SQLERRM );
        ROLLBACK;

END XXCSC_AP_SUPP_TRANSFER_PROC;

---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPP_ERROR_PROC
-- DESCRIPTION     :  Error Report Generation
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_ERROR_PROC (x_object_name IN   VARCHAR2
  ,x_stage IN   VARCHAR2
  )
IS
-- Variable Declaration
  x_title VARCHAR2(100);
  x_status VARCHAR2(100);
  x_req_id NUMBER;
  x_req_id_1 NUMBER;
  x_start_dt VARCHAR2(100);
  x_end_dt VARCHAR2(100);
  x_exec_time VARCHAR2(100);
  x_conc_prog_name VARCHAR2(100);
  x_param1 VARCHAR2(100);
  x_param2 VARCHAR2(100);
  x_param3 VARCHAR2(100);
  x_sqlqry VARCHAR2(2000);
  x_sqlqry1 VARCHAR2(2000);
  x_err_desc VARCHAR2(2000);
  x_cnt NUMBER  := 0;
  x_key2 NUMBER;
  x_key3 NUMBER;
  x_arg1 VARCHAR2(300);
  x_arg2 VARCHAR2(300);
  x_arg3 VARCHAR2(300);
  x_arg4 VARCHAR2(300);
  x_arg5 VARCHAR2(300);
  x_flag VARCHAR2(1):= 'Y';
  x_str VARCHAR2(200):=' ';

-- Ref Cursor Delaration

  TYPE x_ref_cur IS ref cursor;
  x_dyn_cur   x_ref_cur;
  x_dyn_cur1  x_ref_cur;

  CURSOR cur_tbl IS
  SELECT st.table_name
        ,st.table_description
    FROM XXHR.xxcsc_cmn_metadata_all st
   WHERE st.object_name = TRIM(x_object_name)
     AND st.enable_flag = x_yes
ORDER BY st.object_dep_seq;

  CURSOR cur_det IS
  SELECT st.table_name
        ,st.table_description
        ,st.key_column1
        ,NVL(st.key_column2,1) AS key_column2
        ,NVL(st.key_column3,1) AS key_column3
    FROM XXHR.xxcsc_cmn_metadata_all st
   WHERE st.object_name =  TRIM(x_object_name)
     AND st.enable_flag = x_yes
ORDER BY st.object_dep_seq;

BEGIN
    XXCSC_AP_SUPPLIERS_CONV_PKG.x_object := x_object_name;

    SELECT MAX(REQUEST_ID)
      INTO x_req_id_1
      FROM APPS.FND_CONCURRENT_REQUESTS CR
          ,APPS.FND_CONCURRENT_PROGRAMS_TL B
     WHERE CR.CONCURRENT_PROGRAM_ID = B.CONCURRENT_PROGRAM_ID
       AND ARGUMENT1 = x_object_name;


     SELECT
        ' CONVERSION SUMMARY DETAILS' AS Title          
        ,DECODE(mt.status_code,'C','COMPLETED','E','ERROR') AS status_code        
        ,mt.request_id AS request_id
        ,TO_CHAR(mt.actual_start_date,'DD-MON-YYYY HH:MI:SS') AS actual_start_date
        ,TO_CHAR(SYSDATE,'DD-MON-YYYY HH:MI:SS') AS actual_completion_date
        ,FLOOR(((SYSDATE - mt.actual_start_date)*24*60*60)/3600)|| ' Hours ' ||
              FLOOR((((SYSDATE - mt.actual_start_date)*24*60*60) -
              FLOOR(((SYSDATE - mt.actual_start_date)*24*60*60)/3600)*3600)/60)|| ' Minutes ' ||
              ROUND((((SYSDATE - mt.actual_start_date)*24*60*60) -
              FLOOR(((SYSDATE - mt.actual_start_date)*24*60*60)/3600)*3600 -
              (FLOOR((((SYSDATE - mt.actual_start_date)*24*60*60) -
              FLOOR(((SYSDATE - mt.actual_start_date)*24*60*60)/3600)*3600)/60)*60) )) || ' Secs '
  AS Duration
        ,b.user_concurrent_program_name  AS user_concurrent_program_name
        ,mt.argument1 AS argument1
        ,mt.argument2 AS argument2
        ,mt.argument3 AS argument3
    INTO x_title
        ,x_status
        ,x_req_id
        ,x_start_dt
        ,x_end_dt
        ,x_exec_time
        ,x_conc_prog_name
        ,x_param1
        ,x_param2
        ,x_param3
    FROM APPS.fnd_concurrent_requests mt
        ,APPS.fnd_concurrent_programs a
        ,APPS.fnd_concurrent_programs_TL b
   WHERE a.concurrent_program_id = b.concurrent_program_id
     AND mt.concurrent_program_id = a.concurrent_program_id
     AND mt.concurrent_program_id = b.concurrent_program_id
     AND mt.argument1 = TRIM(x_object_name)
     AND status_code != 'E'
     AND ROWNUM < 2
     AND mt. request_id = x_req_id_1
ORDER BY request_date DESC;

 -- Print Heading

    XXCSC_AP_SUPP_PRINT_PROC ( '   ');
    XXCSC_AP_SUPP_PRINT_PROC ( '   ');
    XXCSC_AP_SUPP_PRINT_PROC ('**************************************************************************');
    XXCSC_AP_SUPP_PRINT_PROC ( UPPER(x_object_name) ||' CONVERSION SUMMARY AND ERROR REPORT               ');
    XXCSC_AP_SUPP_PRINT_PROC ('**************************************************************************');
    XXCSC_AP_SUPP_PRINT_PROC ( '   ');
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Object Name',30,' ') || ':'||x_object_name);
--S    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Load Status',30,' ') || ':'||x_status);
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Concurrent Request ID',30,' ') || ':'||x_req_id );
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Program Start Date',30,' ') || ':'||x_start_dt );
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Program End Date',30,' ') || ':'||x_end_dt );
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Execution time',30,' ') || ':'||x_exec_time );  
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Concurrent Program Name',30,' ') || ':'||x_conc_prog_name );  
    XXCSC_AP_SUPP_PRINT_PROC ('Parameters:' );  
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Object Name',30,' ') || ':'||x_param1 );  
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Stage',30,' ') || ':'||x_param2 );  
    XXCSC_AP_SUPP_PRINT_PROC (RPAD('Forcefully Submit',30,' ') || ':'||x_param3 );  
    XXCSC_AP_SUPP_PRINT_PROC ('  ' );
    XXCSC_AP_SUPP_PRINT_PROC ('**************************************************************************' );
    XXCSC_AP_SUPP_PRINT_PROC ('  ' );

-- Summary Report

    FOR rec_tbl IN cur_tbl LOOP
        XXCSC_AP_SUPP_PRINT_PROC('  ' );
        XXCSC_AP_SUPP_PRINT_PROC( RPAD(rec_tbl.table_description ||' Conversion Summary Details',50,'  ') );
        XXCSC_AP_SUPP_PRINT_PROC( '**********************************************' );  
        XXCSC_AP_SUPP_PRINT_PROC('  ' );

        x_sqlqry := 'SELECT COUNT(1) FROM XXHR.'||rec_tbl.table_name;
        EXECUTE IMMEDIATE x_sqlqry INTO x_cnt;

        XXCSC_AP_SUPP_PRINT_PROC( RPAD('Total Records in '|| rec_tbl.table_description ,50,' ') || ': ' ||x_cnt );

        IF x_stage IN (x_mapping_stg, x_all_stg) THEN
              x_sqlqry1 := x_sqlqry || ' WHERE status_flag = ''' || x_mapped_flag||'''';
           EXECUTE IMMEDIATE x_sqlqry1 INTO x_cnt;
           XXCSC_AP_SUPP_PRINT_PROC( RPAD('Total Records Mapped in '|| rec_tbl.table_description ,50,' ') || ': ' ||x_cnt );
        END IF;
     
        x_sqlqry1 := ' ';

        IF x_stage IN (x_validate_stg, x_all_stg) THEN
              x_sqlqry1 := x_sqlqry || ' WHERE (status_flag IN ('''|| x_error_flag ||''' , '''|| x_warning_flag || ''') OR error_code IS NOT NULL)';
  EXECUTE IMMEDIATE x_sqlqry1 INTO x_cnt;  
           XXCSC_AP_SUPP_PRINT_PROC( RPAD('Total Records Error in  '|| rec_tbl.table_description ,50,' ') || ': ' ||x_cnt  );
        END IF;
 
        x_sqlqry1 := ' ';

        IF x_stage IN (x_transfer_stg, x_all_stg) THEN
           x_sqlqry1 := x_sqlqry || ' WHERE status_flag =  '''||  x_transfered_flag||'''';
           EXECUTE IMMEDIATE x_sqlqry1 INTO x_cnt;  
           XXCSC_AP_SUPP_PRINT_PROC( RPAD('Total Records Transfered in  '|| rec_tbl.table_description ,50,' ') || ': ' ||x_cnt  );
        END IF;
     
    END LOOP;
 
    IF x_stage IN (x_all_stg, x_validate_stg) THEN

       XXCSC_AP_SUPP_PRINT_PROC( '  ' );
       XXCSC_AP_SUPP_PRINT_PROC( '  ' );
       XXCSC_AP_SUPP_PRINT_PROC( 'SUMMARY ERROR DETAILS' );
       XXCSC_AP_SUPP_PRINT_PROC( '*********************' );
       XXCSC_AP_SUPP_PRINT_PROC( '  ' );

       FOR REC_DET IN CUR_DET LOOP  
  x_sqlqry1 := 'SELECT  count(mt.record_id),st.valid_code,st.valid_message
              FROM  XXHR.' ||REC_DET.TABLE_NAME || ' MT
       ,XXHR.xxcsc_cmn_validations_all st
         WHERE INSTR(mt.error_code,st.valid_code)>0
           AND mt.error_code IS NOT NULL
      GROUP BY st.valid_code,st.valid_message
      ORDER BY COUNT(valid_code) DESC';

  XXCSC_AP_SUPP_PRINT_PROC('  ');
  XXCSC_AP_SUPP_PRINT_PROC('Summary of Error for '||REC_DET.TABLE_DESCRIPTION );
  XXCSC_AP_SUPP_PRINT_PROC(RPAD('*',50,'*') );

  x_flag:='Y';
  OPEN x_dyn_cur1 for x_sqlqry1;
  LOOP
      FETCH x_dyn_cur1 INTO x_arg1,x_arg2,x_arg3 ;
      EXIT WHEN x_dyn_cur1%NOTFOUND;

      IF (x_flag='Y') THEN
 x_flag:='N';
 XXCSC_AP_SUPP_PRINT_PROC(RPAD('COUNT',10,' ')||RPAD('ERROR_CODE',30,' ')||RPAD('ERROR_MESSAGE',100,' ') );
 XXCSC_AP_SUPP_PRINT_PROC(RPAD('-',10,'-')||RPAD('-',30,'-')||RPAD('-',100,'-') );
      END IF;

      XXCSC_AP_SUPP_PRINT_PROC(RPAD(x_arg1,10,' ')||RPAD(x_arg2,30,' ')||RPAD(x_arg3,100,' ') );

  END LOOP;
  CLOSE x_dyn_cur1;
       END LOOP;

-- Detail Report
       XXCSC_AP_SUPP_PRINT_PROC ('   ' );
       XXCSC_AP_SUPP_PRINT_PROC ('   ' );
       XXCSC_AP_SUPP_PRINT_PROC( 'ERROR WITH DETAILS' );
       XXCSC_AP_SUPP_PRINT_PROC( '******************' );  
       XXCSC_AP_SUPP_PRINT_PROC ('   ' );

       FOR REC_DET IN CUR_DET LOOP
           x_sqlqry1 := 'SELECT  MT.'||rec_det.key_column1 ||'
                               ,' ||rec_det.key_column2 ||'
                               ,' ||rec_det.key_column3 ||'
                               ,st.valid_code
                               ,' || 'st.valid_message
                         FROM  XXHR.' ||rec_det.table_name || ' mt
                              ,XXHR.xxcsc_cmn_validations_all st
                        WHERE INSTR(mt.error_code,st.valid_code)>0
                          AND mt.error_code IS NOT NULL';
         
  IF TRIM(rec_det.key_column2) = '1' THEN
     x_key2 := 0;
  ELSE
     x_key2 := 20;
  END IF;

  IF TRIM(rec_det.key_column3) = '1' THEN
     x_key3 := 0;
  ELSE
     x_key3 := 20;
  END IF;

           XXCSC_AP_SUPP_PRINT_PROC( '  ' );    
           XXCSC_AP_SUPP_PRINT_PROC(RPAD('Error Details For '||rec_det.table_description,50,'  ') );
           XXCSC_AP_SUPP_PRINT_PROC(RPAD('*',50,'*') );
           XXCSC_AP_SUPP_PRINT_PROC( '  ' );
           XXCSC_AP_SUPP_PRINT_PROC(RPAD(REPLACE(TO_CHAR(rec_det.key_column1),'1',' '),20,' ')||RPAD(REPLACE(TO_CHAR(rec_det.key_column2),'1',' '),x_key2,' ')||RPAD(REPLACE(TO_CHAR(rec_det.key_column3),'1',' '),x_key3,' ')||RPAD('VALIDATION CODE ',25,' ')||RPAD('VALIDATION DESCRIPTION',75,' ') );
           XXCSC_AP_SUPP_PRINT_PROC(RPAD('-',20,'-')||RPAD('-',20,'-')||RPAD('-',20,'-')||RPAD('-',25,'-')||RPAD('-',75,'-') );
     
           x_sqlqry1 := REPLACE(x_sqlqry1,'1','DECODE(1,1,NULL)' );

           x_flag:= 'Y';

           OPEN x_dyn_cur FOR x_sqlqry1;
           LOOP
               FETCH x_dyn_cur INTO x_arg1,x_arg2,x_arg3,x_arg4,x_arg5 ;
         
      EXIT WHEN x_dyn_cur%NOTFOUND;

               XXCSC_AP_SUPP_PRINT_PROC(RPAD(x_arg1,20,' ')||RPAD(x_arg2,x_key2,' ')||RPAD(x_arg3,x_key3,' ')||RPAD(x_arg4,25,' ')||RPAD(x_arg5,75,' ') );      
           END LOOP;

       CLOSE x_dyn_cur;
       END LOOP;
    END IF;

    XXCSC_AP_SUPP_PRINT_PROC ('  ');
    XXCSC_AP_SUPP_PRINT_PROC(RPAD('*',140,'*') );
    XXCSC_AP_SUPP_PRINT_PROC (RPAD(' ',66,' ')||'END OF REPORT' || RPAD(' ',66,' '));
    XXCSC_AP_SUPP_PRINT_PROC(RPAD('*',140,'*') );


EXCEPTION
   WHEN OTHERS THEN
XXCSC_AP_SUPP_PRINT_PROC( 'ERROR CODE        : ' || SQLCODE );
XXCSC_AP_SUPP_PRINT_PROC( 'ERROR DESCRIPTION : ' || SQLERRM );
        ROLLBACK;

END XXCSC_AP_SUPP_ERROR_PROC;


---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPP_PRINT_PROC
-- DESCRIPTION     :  Error Report Design
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_PRINT_PROC (x_print   IN  VARCHAR2
   )
IS
   file_handle              UTL_FILE.FILE_TYPE;
   x_directory    VARCHAR2(50) := '/usr/tmp';
   x_reid    NUMBER ;
   x_file_name    VARCHAR2(100);
   x_flag                   VARCHAR2(1);
   x_accept    VARCHAR2(1);
 
BEGIN

  x_file_name := 'XXCSC_AP_SUPPLIER_ERROR.dat';

  IF TRIM(XXCSC_AP_SUPPLIERS_CONV_PKG.x_flag) = 'Y' THEN
     x_accept := 'W';
     XXCSC_AP_SUPPLIERS_CONV_PKG.x_flag := 'N';
  ELSE
     x_accept := 'A' ;
  END IF;

  file_handle := UTL_FILE.FOPEN(x_directory, x_file_name ,x_accept);

  UTL_FILE.PUT_LINE(file_handle,x_print);

  UTL_FILE.FCLOSE(file_handle);



EXCEPTION
   WHEN  Utl_File.INVALID_OPERATION THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The file could not be opened or operated on as requested. ');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The file could not be opened or operated on as requested. ');
         Utl_File.FClose_All;
         ROLLBACK;
   WHEN Utl_File.INVALID_PATH THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'File location or filename was invalid.');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'File location or filename was invalid.');
         utl_file.fclose_all;
         ROLLBACK;
   WHEN Utl_File.INVALID_MODE THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The open_mode parameter in FOPEN was invalid. ');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The open_mode parameter in FOPEN was invalid. ');
         Utl_File.FClose_All;
         ROLLBACK;
   WHEN Utl_File.INVALID_FILEHANDLE THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The file handle was invalid. ');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'The file handle was invalid. ');
         Utl_File.FClose_All;
         ROLLBACK;
   WHEN Utl_File.READ_ERROR THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An operating system error occurred during the read operation.');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An operating system error occurred during the read operation.');
         Utl_File.FClose_All;
         ROLLBACK;
   WHEN Utl_File.WRITE_ERROR THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An operating system error occurred during the write operation. ');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An operating system error occurred during the write operation. ');
         Utl_File.FClose_All;
         ROLLBACK;
   WHEN Utl_File.INTERNAL_ERROR THEN
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An unspecified error in PL/SQL. ');
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'An unspecified error in PL/SQL. ');
         utl_file.fclose_all;
         ROLLBACK;
   WHEN OTHERS THEN
        -- fnd_file.new_line(APPS.FND_FILE.LOG,1);
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'error in generating output file '||'$'||x_directory||'$'||'/'||'$'||x_file_name);
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,SQLERRM);
         APPS.FND_FILE.PUT_LINE(APPS.FND_FILE.LOG,'*----*----**----*----**----*----**----*----**----*');
END XXCSC_AP_SUPP_PRINT_PROC;

---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPP_STATUS_PROC
-- DESCRIPTION     :  Update the PROCESS_FLAG and STATUS_FLAG
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_STATUS_PROC (x_process   IN  VARCHAR2
   ,x_status   IN  VARCHAR2
   )
IS

CURSOR cur_hr IS
SELECT hdr.*
  FROM XXHR.xxcsc_ap_supplier_headers hdr;
 
CURSOR cur_st IS
SELECT sit.*
  FROM XXHR.xxcsc_ap_supplier_sites sit;

CURSOR cur_cn IS
SELECT con.*
  FROM XXHR.xxcsc_ap_supplier_contacts con;

BEGIN

---------------------------------------------------------------------------------------------
-- UPDATE PROCESS FLAG
---------------------------------------------------------------------------------------------
   IF NVL(x_process,'$') != '$' THEN
--- Update the PROCESS FLAG
   FOR rec_hr IN cur_hr LOOP
       UPDATE XXHR.xxcsc_ap_supplier_headers
          SET process_flag = x_process
    ,status_flag = NULL
    ,error_code = NULL;
     
       COMMIT;
   END LOOP;

--- Update the PROCESS FLAG
   FOR rec_st IN cur_st LOOP
       UPDATE XXHR.xxcsc_ap_supplier_sites
          SET process_flag = x_process
    ,status_flag = NULL
    ,error_code = NULL;

       COMMIT;
   END LOOP;

--- Update the PROCESS FLAG
   FOR rec_cn IN cur_cn LOOP
       UPDATE XXHR.xxcsc_ap_supplier_contacts
          SET process_flag = x_process
    ,status_flag = NULL
    ,error_code = NULL;

       COMMIT;
   END LOOP;

END IF;
---------------------------------------------------------------------------------------------
-- UPDATE STATUS FLAG
---------------------------------------------------------------------------------------------

   IF NVL(x_status,'$') != '$' THEN
--- Update the STATUS FLAG
   FOR rec_hr IN cur_hr LOOP
       UPDATE XXHR.xxcsc_ap_supplier_headers
          SET status_flag = x_status
        WHERE status_flag IS NULL;
     
       COMMIT;
   END LOOP;

--- Update the STATUS FLAG
   FOR rec_st IN cur_st LOOP
       UPDATE XXHR.xxcsc_ap_supplier_sites
          SET status_flag = x_status
        WHERE status_flag IS NULL;

       COMMIT;
   END LOOP;

--- Update the STATUS FLAG
   FOR rec_cn IN cur_cn  LOOP
       UPDATE XXHR.xxcsc_ap_supplier_contacts
          SET status_flag = x_status
        WHERE status_flag IS NULL;

       COMMIT;
   END LOOP;

END IF;

EXCEPTION
   WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE( 'ERROR CODE        : ' || SQLCODE );
DBMS_OUTPUT.PUT_LINE( 'ERROR DESCRIPTION : ' || SQLERRM );
        ROLLBACK;

END XXCSC_AP_SUPP_STATUS_PROC;

---------------------------------------------------------------------------------------------
-- PROCEDURE NAME  :  XXCSC_AP_SUPP_RECON_PROC
-- DESCRIPTION     :  RECON Report Design
---------------------------------------------------------------------------------------------

PROCEDURE XXCSC_AP_SUPP_RECON_PROC (x_object   IN  VARCHAR2
   )
IS
   file_handle              UTL_FILE.FILE_TYPE;
   x_directory    VARCHAR2(50)  := '/usr/tmp';
   x_file_name    VARCHAR2(100) := 'XXCSC_AP_SUPPLIER_ERROR.dat';

 
   CURSOR cur_recon IS
          SELECT 'SUPPLIER HEADERS RECONCILIATION REPORT' data FROM DUAL
          UNION ALL
          SELECT '*************************************' FROM DUAL
          UNION ALL
          SELECT RPAD('Total Record Count in Staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_headers
          UNION ALL
          SELECT RPAD('Total Record Errored in staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_headers WHERE error_code IS NOT NULL
          UNION ALL
          SELECT RPAD('Total Record transfered from staging into Interface Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_headers WHERE status_flag = 'T' AND process_flag = 'T'
          UNION ALL
          SELECT RPAD('Total Record in Interface Table',80,' ') || COUNT(1) FROM APPS.ap_suppliers_int
          UNION ALL
          SELECT RPAD('Total Record Processed from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_suppliers_int WHERE status ='PROCESSED'
          UNION ALL
          SELECT RPAD('Total Record Rejected while transfering from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_suppliers_int WHERE status ='REJECTED'
          UNION ALL
          SELECT '  ' FROM DUAL
          UNION ALL
          SELECT 'SUPPLIER SITES RECONCILIATION REPORT' FROM DUAL
          UNION ALL
          SELECT '*************************************' FROM DUAL
          UNION ALL
          SELECT RPAD('Total Record Count in Staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_sites
          UNION ALL
          SELECT RPAD('Total Record Errored in staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_sites WHERE error_code IS NOT NULL
          UNION ALL
          SELECT RPAD('Total Record transfered from staging into Interface Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_sites WHERE status_flag = 'T' AND process_flag = 'T'
          UNION ALL
          SELECT RPAD('Total Record in Interface Table',80,' ') || COUNT(1) FROM APPS.ap_supplier_sites_int
          UNION ALL
          SELECT RPAD('Total Record Processed from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_supplier_sites_int WHERE status ='PROCESSED'
          UNION ALL
          SELECT RPAD('Total Record Rejected while transfering from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_supplier_sites_int WHERE status ='REJECTED'
          UNION ALL
          SELECT '  ' FROM DUAL
          UNION ALL
          SELECT 'SUPPLIER CONTACTS RECONCILIATION REPORT' FROM DUAL
          UNION ALL
          SELECT '**************************************' FROM DUAL
          UNION ALL
          SELECT RPAD('Total Record Count in Staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_contacts
          UNION ALL
          SELECT RPAD('Total Record Errored in Staging Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_contacts WHERE error_code IS NOT NULL
          UNION ALL
          SELECT RPAD('Total Record transfered from staging into Interface Table',80,' ') || COUNT(1) FROM XXHR.xxcsc_ap_supplier_contacts WHERE status_flag = 'T' AND process_flag = 'T'
          UNION ALL
          SELECT RPAD('Total Record in Interface Table:',80,' ') || COUNT(1) FROM APPS.ap_sup_site_contact_int
          UNION ALL
          SELECT RPAD('Total Record Processed from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_sup_site_contact_int WHERE status ='PROCESSED'
          UNION ALL
          SELECT RPAD('Total Record Rejected while transfering from Interface into Oracle Base Table',80,' ') || COUNT(1) FROM APPS.ap_sup_site_contact_int WHERE status ='REJECTED'
          UNION ALL
          SELECT '  ' FROM DUAL;
     
   BEGIN
     file_handle := UTL_FILE.FOPEN(x_directory, x_file_name ,'W');

     file_handle := UTL_FILE.FOPEN(x_directory, x_file_name ,'A');

     UTL_FILE.PUT_LINE(file_handle, RPAD('*',85,'*'));  
     UTL_FILE.PUT_LINE(file_handle, RPAD(' ',35,' ')|| x_object ||' CONVERSION RECON REPORT' || RPAD(' ',35, ' '));
     UTL_FILE.PUT_LINE(file_handle, RPAD('*',85,'*'));
     UTL_FILE.PUT_LINE(file_handle, '  ');
     UTL_FILE.PUT_LINE(file_handle, '  ');

   
     FOR rec_recon IN cur_recon LOOP
         UTL_FILE.PUT_LINE(file_handle, rec_recon.data);  
     END LOOP;

     UTL_FILE.PUT_LINE(file_handle, '  ');
     UTL_FILE.PUT_LINE(file_handle, '  ');
     UTL_FILE.PUT_LINE(file_handle, RPAD('*',85,'*'));
     UTL_FILE.PUT_LINE(file_handle, RPAD(' ',35,' ')|| 'END OF THE REPORT' || RPAD(' ',35, ' '));
     UTL_FILE.PUT_LINE(file_handle, RPAD('*',85,'*'));
     UTL_FILE.PUT_LINE(file_handle, '  ');
     UTL_FILE.PUT_LINE(file_handle, '  ');

     UTL_FILE.FCLOSE(file_handle);
 
EXCEPTION
   WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE( 'ERROR CODE        : ' || SQLCODE );
DBMS_OUTPUT.PUT_LINE( 'ERROR DESCRIPTION : ' || SQLERRM );
DBMS_OUTPUT.PUT_LINE( 'ERROR OCCURED WHILE PRINTING THE RECON REPORT');
        ROLLBACK;

END XXCSC_AP_SUPP_RECON_PROC;

END XXCSC_AP_SUPPLIERS_CONV_PKG;

/

No comments :