AP_INVOICES_INTERFACE
-----------------------
1)INVOICE_ID not null Required, Primary key. This value is assigned in
the Invoice Gateway by the AP_INVOICES_INTERFACE_S sequence.
2) INVOICE_NUM Required if there is more than one invoice for the
supplier during import
3)VENDOR_ID or VENDOR_NAME or VENDOR_NUM  is reqd if not matched to PO
4)VENDOR_SITE_ID or VENDOR_SITE_CODE is reqd if not matched to PO
5)INVOICE_AMOUNT
6)PO_NUMBER
6)INVOICE_CURRENCY_CODE:if not eneterd defaulted to functional currency
7)EXCHANGE_RATE_TYPE :User,Spot, Corporate, EMU Fixed, and user–defined.for Spot, Corporate, or any user–defined rate type, the value you enter here is validated against
the GL Daily Rates table.If you use EMU Fixed,Payables will provide the exchange rate during import. If you use User as the exchange rate type,you must enter a value for EXCHANGE_RATE orthe record will be rejected during import.
8)TERMS_NAME or TERMS_ID.:Payables searches1)invoice record header 2)purchase order terms if invoice is matched to PO 3)supplier site.
9)SOURCE
10)DOC_CATEGORY_CODE  :
If you are using automatic sequential numbering, then Payables Open
Interface Import uses this column to assign a document category to the
invoice it creates.If the Sequential Numbering profile value is ”Always” and you do not
enter a value in this column, then during import Payables will use STANDARD as the category if the invoice amount is zero or positive,and CREDIT if the invoice amount is negative.
If you enable the Allow Document Category Override Payables option,you can enter the document category you want Open Interface Import to assign to the invoice created from this record
10)VOUCHER_NUM:If you use manual sequential numbering, then enter a unique value
11)PAYMENT_CURRENCY_CODE:Currency code for the payment. If you do not provide a value, then
during import PAYMENT_CURRENCY_CODE will be set to the same value as the INVOICE_CURRENCY_CODE,
12)PAYMENT_METHOD_LOOKUP_CODE:Method that will be used to pay the invoice.
The value must be a valid value for the PAYMENT_METHOD lookup code: Validation:
13)ACCTS_PAY_CODE_COMBINATION_ID:Liability account.
14)ORG_ID
AP_INVOICE_LINES_INTERFACE
----------------------------
1)INVOICE_ID :required
2)INVOICE_LINE_ID :not reqd,use AP_INVOICE_LINES_INTERFACE_S
3)LINE_NUMBER:unique ,reqd
4)LINE_TYPE_LOOKUP_CODE:valid values ITEM, TAX,MISCELLANEOUS, or FREIGHT.
5)AMOUNT :Invoice distribution amount
6)ACCOUNTING_DATE:The GL Date for the invoice distributions. The date must be in an open
or future period.
7)PO_HEADER_ID or PO_NUMBER
8)PO_LINE_ID or PO_LINE_NUMBER
9)dist_code_combination_id or DIST_CODE_CONCATENATED
10)ORG_ID
Document Category Assignment and Document Sequence Setup:
from fnd_doc_sequence_assignment,fnd_document_sequences 
Now create both headers and line in one package:
Create or Replace Procedure  m_ap_invoices(ERRBUF out VARCHAR2, RETCODE out VARCHAR2)
IS
--starts the declaring variables for headers
v_invoice_id   ap_invoices_interface.INVOICE_ID%TYPE ;
v_type    ap_invoices_interface.INVOICE_TYPE_LOOKUP_CODE %TYPE ;
v_supplier   ap_invoices_interface.VENDOR_NAME %TYPE ;
v_invoice_date   ap_invoices_interface.INVOICE_DATE %TYPE;
v_invoice_num   ap_invoices_interface.INVOICE_NUM %TYPE;
v_invoice_curr   ap_invoices_interface.INVOICE_CURRENCY_CODE%TYPE;
v_invoice_amount  ap_invoices_interface.INVOICE_AMOUNT %TYPE;
v_payment_cross_rate  ap_invoices_interface.PAYMENT_CROSS_RATE%TYPE;
v_cross_payment_curr  ap_invoices_interface.PAYMENT_CURRENCY_CODE%TYPE;
v_pay_rate_date   ap_invoices_interface.PAYMENT_CROSS_RATE_DATE%TYPE;
v_payment_rate_type  ap_invoices_interface.PAYMENT_CROSS_RATE_TYPE%TYPE;
v_description   ap_invoices_interface.DESCRIPTION%TYPE;
v_rate_type   ap_invoices_interface.EXCHANGE_RATE_TYPE%TYPE;
v_exchange_date   ap_invoices_interface.EXCHANGE_DATE%TYPE;
v_exchange_rate   ap_invoices_interface.EXCHANGE_RATE%TYPE;
v_terms_date   ap_invoices_interface.TERMS_DATE%TYPE;
v_terms    ap_invoices_interface.TERMS_ID%TYPE;
v_payment_method  ap_invoices_interface.PAYMENT_METHOD_LOOKUP_CODE%TYPE;
v_discountable_amt  ap_invoices_interface.AMOUNT_APPLICABLE_TO_DISCOUNT%TYPE;
v_invoice_recieved_date  ap_invoices_interface.INVOICE_RECEIVED_DATE%TYPE;
v_recieved_goods_date  ap_invoices_interface.GOODS_RECEIVED_DATE%TYPE;
v_pay_code_combination_id  ap_invoices_interface.ACCTS_PAY_CODE_COMBINATION_ID%TYPE;
v_status   ap_invoices_interface.STATUS%TYPE;
v_po_number   ap_invoices_interface.PO_NUMBER%TYPE := NULL;
v_attribute1             ap_invoices_interface.attribute1%TYPE;
v_attribute2   ap_invoices_interface.attribute2%TYPE;
v_attribute3   ap_invoices_interface.attribute3%TYPE;
v_attribute4   ap_invoices_interface.attribute4%TYPE;
v_attribute5   ap_invoices_interface.attribute5%TYPE;
v_attribute6   ap_invoices_interface.attribute6%TYPE;
v_attribute7   ap_invoices_interface.attribute7%TYPE;
v_attribute8   ap_invoices_interface.attribute8%TYPE;
v_attribute9   ap_invoices_interface.attribute9%TYPE;
v_attribute10   ap_invoices_interface.attribute10%TYPE;
v_vendor_id   po_vendors.vendor_id%TYPE;
v_vendor_site_cd  po_vendor_sites.vendor_site_code%TYPE;
v_vendor_site_id  po_vendor_sites.vendor_site_id%TYPE;
v_currency_code   fnd_currencies.currency_code%TYPE;
v_lookup_code   ap_lookup_codes.lookup_code%TYPE;
v_code_comb   gl_code_combinations.code_combination_id%TYPE;
v_segment1   po_headers_all.segment1%TYPE;
v_term_name   ap_terms.name%TYPE;
v_term_id   ap_terms.term_id%TYPE;
v_closed_date            po_headers_all.closed_date%type;
v_process_flag   char(1) := NULL;
v_last_date   DATE;
v_count    number;
--ends the declaring variables for headers
--statrts the declaring variables for lines
 --v_invoice_id   ap_invoice_lines_interface.invoice_id%type;
 v_line_no   ap_invoice_lines_interface.line_number%type;
 v_amount         ap_invoice_lines_interface.amount%type;
 v_expence_account  ap_invoice_lines_interface.dist_code_combination_id%type;
 v_expence_Account1      ap_invoice_lines_interface.dist_code_concatenated%type;
 v_line_type   ap_invoice_lines_interface.line_type_lookup_code%type;
 v_accounting_date  ap_invoice_lines_interface.accounting_date%type;
 v_invoice_line_id  ap_invoice_lines_interface.invoice_line_id%type;
 v_line_attribute1             ap_invoice_lines_interface.attribute1%TYPE;
 v_line_attribute2  ap_invoice_lines_interface.attribute2%TYPE;
 v_line_attribute3  ap_invoice_lines_interface.attribute3%TYPE;
 v_line_attribute4  ap_invoice_lines_interface.attribute4%TYPE;
 v_line_attribute5  ap_invoice_lines_interface.attribute5%TYPE;
 v_line_attribute6  ap_invoice_lines_interface.attribute6%TYPE;
 v_line_attribute7  ap_invoice_lines_interface.attribute7%TYPE;
 v_line_attribute8  ap_invoice_lines_interface.attribute8%TYPE;
 v_line_attribute9  ap_invoice_lines_interface.attribute9%TYPE;
 v_line_attribute10  ap_invoice_lines_interface.attribute10%TYPE;
 v_receipt_number  ap_invoice_lines_interface.receipt_number%TYPE;
/*following variables for PO related invoices*/
 v_found   char(1) := NULL;
 v_po_header_id  ap_invoice_lines_interface.po_header_id%TYPE;
 v_po_line_id  ap_invoice_lines_interface.po_line_id%TYPE;
 v_po_line_num  ap_invoice_lines_interface.po_line_number%TYPE;
 v_po_segment  ap_invoice_lines_interface.po_number%TYPE;
 v_line_location_id ap_invoice_lines_interface.po_line_location_id%TYPE;
 v_shipment_num  ap_invoice_lines_interface.po_shipment_num%TYPE;
 v_po_distribution_id ap_invoice_lines_interface.po_distribution_id%TYPE;
 v_po_distribution_num ap_invoice_lines_interface.po_distribution_num%TYPE;
--ends the declaring variables for lines
--declaring cursor for fetching header,Lines values from staging table. 
  CURSOR invoice_cur
  IS
  SELECT INVH.REC_ID,
 INVH.TYPE,
   INVH.SUPPLIER,
   INVH.SITE,
   INVH.INVOICE_DATE ,
   INVH.INVOICE_NUM INVOICE_NUM,
   INVH.INVOICE_CURR,
  INVH.INVOICE_AMOUNT,
   INVH.AMOUNT_PAID,
   INVH.PAYMENT_CROSS_RATE,
   INVH.PAYMENT_CROSS_CURR,
   INVH.PAY_RATE_DATE,
   INVH.PAYMENT_RATE_TYPE, 
   INVH.PAYMENT_RATE,
   INVH.PAYMENT_AMT,  
   INVH.DESCRIPTION,      
   INVH.TRANCTION_CODE ,         
   INVH.RATE_TYPE,              
   INVH.EXCHANGE_DATE,              
   INVH.EXCHANGE_RATE,                 
   INVH.FUNCTIONAL_AMOUNT,            
   INVH.TERMS_DATE,                  
   INVH.TERMS,                         
   INVH.PAYMENT_METHOD,               
   INVH.DISCOUNTABLE_AMT,              
   INVH.INVOICE_RECIEVED_DATE,         
   INVH.RECIEVED_GOODS_DATE,           
   INVH.ACCTS_PAY_CODE_COMBINATION_ID, 
   INVH.STATUS,                        
   INVH.PO_NUMBER,                     
   INVH.ATTRIBUTE1 HEADATTR1,                    
   INVH.ATTRIBUTE2 HEADATTR2,                    
   INVH.ATTRIBUTE3 HEADATTR3,                    
   INVH.ATTRIBUTE4 HEADATTR4,                    
   INVH.ATTRIBUTE5 HEADATTR5,                    
   INVH.ATTRIBUTE6 HEADATTR6,                    
   INVH.ATTRIBUTE7 HEADATTR7,                    
   INVH.ATTRIBUTE8 HEADATTR8,                    
   INVH.ATTRIBUTE9 HEADATTR9,                    
   INVH.ATTRIBUTE10 HEADATTR10,                   
   INVH.PROCESS_FLAG,                  
 INVL.INVOICE_NUM LINE_INVOICE_NUM,
   INVL.LINE_NO,
   INVL.AMOUNT,
   INVL.EXPENCE_ACCOUNT,
   INVL.EXPENCE_ACCOUNT1,
   INVL.ACCOUNTING_DATE,
   INVL.ATTRIBUTE1 LINEATTR1,
   INVL.ATTRIBUTE2 LINEATTR2,
   INVL.ATTRIBUTE3 LINEATTR3,
   INVL.ATTRIBUTE4 LINEATTR4,
   INVL.ATTRIBUTE5 LINEATTR5,
   INVL.ATTRIBUTE6 LINEATTR6,
   INVL.ATTRIBUTE7 LINEATTR7,
   INVL.ATTRIBUTE8 LINEATTR8,
   INVL.ATTRIBUTE9 LINEATTR9,
   INVL.ATTRIBUTE10  LINEATTR10  
  FROM M_INVOICE_HEADERS_INT INVH, M_INVOICE_LINES_INT INVL 
  WHERE INVH.REC_ID = INVL.REC_ID;
BEGIN
  FOR cur_invoice  IN invoice_cur
  LOOP
  begin
--Loop starts here to process invoice headers data
 --fetching sequence value for invoice_id
   SELECT ap_invoices_interface_s.nextval INTO v_invoice_id FROM dual;
     v_type   := cur_invoice.type ;
     v_supplier   := cur_invoice.supplier;
     v_invoice_date             := cur_invoice.invoice_date;
     v_invoice_num              :=  cur_invoice.invoice_num;
     v_invoice_curr             := cur_invoice.invoice_curr;
     v_invoice_amount           := cur_invoice.invoice_amount;
     v_payment_cross_rate       := cur_invoice.payment_cross_rate;
     v_cross_payment_curr       := cur_invoice.payment_cross_curr;
     v_pay_rate_date            := cur_invoice.pay_rate_date;
     v_payment_rate_type        := cur_invoice.payment_rate_type;
     v_description              := cur_invoice.description;
     v_rate_type  := cur_invoice.rate_type;
     v_exchange_date  := cur_invoice.exchange_date;
     v_exchange_rate  := cur_invoice.exchange_rate;
     v_terms_date  := cur_invoice.terms_date;
     v_terms   := cur_invoice.terms;
     v_payment_method  := cur_invoice.payment_method;
     v_discountable_amt         := cur_invoice.discountable_amt;
     v_invoice_recieved_date    := cur_invoice.invoice_recieved_date;
     v_recieved_goods_date      := cur_invoice.recieved_goods_date;
     v_pay_code_combination_id := cur_invoice.accts_pay_code_combination_id;
     v_status   := cur_invoice.status;
     v_po_number  := cur_invoice.po_number;
     v_attribute1               := cur_invoice.HEADATTR1;
     v_attribute2  := cur_invoice.HEADATTR2;
     v_attribute3  := cur_invoice.HEADATTR3;
     v_attribute4  := cur_invoice.HEADATTR4;
     v_attribute5  := cur_invoice.HEADATTR5;
     v_attribute6  := cur_invoice.HEADATTR6;
     v_attribute7  := cur_invoice.HEADATTR7;
     v_attribute8  := cur_invoice.HEADATTR8;
     v_attribute9  := cur_invoice.HEADATTR9;
     v_attribute10  := cur_invoice.HEADATTR10;
     v_process_flag  := cur_invoice.process_flag;
/* Validate  invoice  number  if null then assign invoice number equal to week_end_date.*/
IF v_invoice_num is  null THEN
   SELECT    NEXT_DAY(SYSDATE,'FRIDAY')
   INTO V_LAST_DATE
   FROM DUAL;
v_invoice_num := v_last_date;
END IF;
/* validate invoice type*/
IF v_type<>'STANDARD' OR v_type <>'CREDIT' OR v_type <>'DEBIT'  THEN
  V_TYPE :=NULL ;
END IF;
/* validating vendor id */
    BEGIN
     select VENDOR_ID 
     into v_vendor_id
  from PO_VENDORS
  where vendor_name = ltrim(rtrim(upper(v_supplier)))
  and         sysdate >= start_date_active
  AND      sysdate <   end_date_active;
    EXCEPTION
      WHEN NO_DATA_FOUND THEN
        FND_FILE.PUT_LINE(FND_FILE.LOG,'No vendor id found OR vendor status is not active  = ');
      WHEN OTHERS THEN
 FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
    END;
/* Validation for VENDOR_SITE_CODE */
 BEGIN
 select vendor_site_code, vendor_site_id  into v_vendor_site_cd,v_vendor_site_id from  PO_VENDOR_SITES where VENDOR_ID = v_vendor_id;
 EXCEPTION
      WHEN NO_DATA_FOUND THEN
        FND_FILE.PUT_LINE(FND_FILE.LOG,'No vendor site code  found for this vendor -  '||v_supplier);
      WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/* Invoice currecy code  */
 BEGIN
   SELECT  currency_code
   INTO  v_currency_code
   FROM FND_CURRENCIES
   WHERE currency_code =  ltrim(rtrim(upper(v_invoice_curr)))
   and sysdate between nvl(start_date_Active,sysdate) and   nvl(end_date_active,sysdate);
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
          FND_FILE.PUT_LINE(FND_FILE.LOG,'Currency Code Does not Exist for '||v_invoice_curr);
       WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/* validating term id */
 BEGIN
  SELECT TERM_ID ,NAME
  INTO V_TERM_ID ,V_TERM_NAME
  FROM AP_TERMS
  WHERE TERM_ID = v_terms
  and    v_terms_date  between nvl(start_date_Active,sysdate) and nvl(end_date_active,sysdate);  -- v_term_date not in ver 11.5.0
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
          FND_FILE.PUT_LINE(FND_FILE.LOG,'Term id  OR Term name Does not Exist for '||v_terms);
      WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/*validating payment method */
 BEGIN
  SELECT  lookup_code
  INTO  v_lookup_code
  FROM ap_lookup_codes
  WHERE  lookup_code =upper(v_payment_method) ;
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
         FND_FILE.PUT_LINE(FND_FILE.LOG,' Payment Method are not exist
  in lookup table');
       WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/* validating GL Code Combination validation  */
 BEGIN
  SELECT code_combination_id 
  INTO v_code_comb
  FROM gl_code_combinations
  WHERE code_combination_id = v_pay_code_combination_id ;
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
         FND_FILE.PUT_LINE(FND_FILE.LOG,' Code Combination id not exist in table');
       WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
END;
/* validating po number  */
 BEGIN
  IF v_po_number is not null  THEN
   SELECT  segment1 , closed_date
   INTO v_segment1 , v_closed_date
   FROM po_headers_all
   WHERE  segment1 = v_po_number;
   IF v_closed_date is not null  THEN
    FND_FILE.PUT_LINE(FND_FILE.LOG,' P O Staus is inactive');
      END IF;
  END IF;
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
          FND_FILE.PUT_LINE(FND_FILE.LOG,' P O number not found');
        WHEN OTHERS THEN
   FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/*Validating Payment cross rate  */
 BEGIN
  IF  v_invoice_curr = v_cross_payment_curr THEN
      v_payment_cross_rate := 1;
  ELSE
   SELECT  conversion_rate
   INTO v_payment_cross_rate  --v_conversion_rate
   FROM gl_daily_rates
   WHERE from_currency = v_invoice_curr
   and  to_currency=v_cross_payment_curr
   and conversion_date= v_pay_rate_date
   and conversion_type=v_payment_rate_type; 
  END IF;
 EXCEPTION
       WHEN NO_DATA_FOUND THEN
         FND_FILE.PUT_LINE(FND_FILE.LOG,' Conversion rates not found');
       WHEN OTHERS THEN
  FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 END;
/* validating exchange rate */
 IF v_rate_type = 'USER'  and  v_exchange_rate is not null THEN
  NULL;
 ELSIF  v_rate_type = 'USER'  and  v_exchange_rate is  null THEN
     FND_FILE.PUT_LINE(FND_FILE.LOG,' Exchange rate is  null for the invoice number   -'||v_invoice_num);
 ELSIF  v_rate_type <> 'USER'  and  v_exchange_rate is  not null THEN
  v_exchange_rate :=0 ;
 END IF;
/* validating duplication of invoice */
 SELECT COUNT(*)
 INTO v_count
 FROM AP_INVOICES_ALL
 WHERE  INVOICE_NUM = V_INVOICE_NUM
 AND VENDOR_ID     = v_vendor_id;
IF  v_count > 0  THEN
   FND_FILE.PUT_LINE(FND_FILE.LOG,' Invocie already Exists - '||v_invoice_num);
   UPDATE M_INVOICE_HEADERS_INT
   SET process_flag ='N'
   WHERE  invoice_num = v_invoice_num
   and  supplier = v_supplier;
Else
--inserting validated values to interface table(headers)
INSERT INTO ap_invoices_interface (
 invoice_id,
 invoice_num,
 invoice_type_lookup_code,
 invoice_date,
 po_number,
 vendor_id,
 vendor_name,
 vendor_site_id,
 vendor_site_code,
 invoice_amount,
 invoice_currency_code,
 exchange_rate,
 exchange_rate_type,
 exchange_date,
 terms_id,
 terms_name,
 terms_date ,  
 description,
 status,
 source,
  payment_cross_rate_type,
 payment_cross_rate_date,
 payment_cross_rate,
 payment_currency_code,
 payment_method_lookup_code,
 goods_received_date,
 invoice_received_date,
 gl_date,
 accts_pay_code_combination_id,
 amount_applicable_to_discount,
 attribute1,
 attribute2,
 attribute3,
 attribute4,
 attribute5,
 attribute6,
 attribute7,
 attribute8,
 attribute9,
 attribute10,
 creation_date,
 created_by,
 last_update_date,
 last_updated_by
)
VALUES
(
 v_invoice_id,
 v_invoice_num,
 v_type,
 v_invoice_date,
 v_po_number, 
 v_vendor_id,
 v_supplier,
 v_vendor_site_id,
 v_vendor_site_cd,
       nvl(v_invoice_amount,0),
        v_invoice_curr,
      v_exchange_rate,
     v_rate_type,
     v_exchange_date,
     v_terms,
     v_term_name,   
 v_terms_date,   
    v_description,
    v_status,
        'InvoiceGateway',
        v_payment_rate_type,
        v_pay_rate_date,
        v_payment_cross_rate,
        v_cross_payment_curr,
        v_payment_method,
        v_recieved_goods_date,
        v_invoice_recieved_date,
 '30-NOV-2003', 
 v_pay_code_combination_id,
        v_discountable_amt,
 v_attribute1,
    v_attribute2,
 v_attribute3,
 v_attribute4,
 v_attribute5,
 v_attribute6,
 v_attribute7,
 v_attribute8,
 v_attribute9,
 v_attribute10, 
 sysdate,
        FND_GLOBAL.user_id,
        sysdate,
 FND_GLOBAL.user_id
);
 --starts here to process invoice lines data
   --fetching sequence value for invoice_line_id
 select ap_invoice_lines_interface_s.nextval into v_invoice_line_id from dual;
 --assigning values from staging table(lines)
   --v_invoice_num                      :=cur_invoice.invoice_num;       
   v_line_no                          :=cur_invoice.line_no;                 
   v_amount                           :=cur_invoice.amount;                    
   v_expence_account                  :=cur_invoice.expence_account;                  
   v_expence_account1                 :=cur_invoice.expence_account1;                     
   v_accounting_date     :=cur_invoice.accounting_date;
   v_line_type      :='Item';--(Item, Fright,Tax,Miscellaneous)
 v_line_attribute1   :=cur_invoice.LINEATTR1;
 v_line_attribute2   :=cur_invoice.LINEATTR2;
 v_line_attribute3   :=cur_invoice.LINEATTR3;
 v_line_attribute4   :=cur_invoice.LINEATTR4;
 v_line_attribute5   :=cur_invoice.LINEATTR5;
 v_line_attribute6   :=cur_invoice.LINEATTR6;
 v_line_attribute7   :=cur_invoice.LINEATTR7;
 v_line_attribute8   :=cur_invoice.LINEATTR8;
 v_line_attribute9   :=cur_invoice.LINEATTR9;
 v_line_attribute10   :=cur_invoice.LINEATTR10;
 -- Validate Line Level Accounting Date
 BEGIN
        SELECT 'Y'
        INTO   v_found
        FROM   gl_period_statuses
        WHERE  application_id  = 200--ASSUMTION
        AND    set_of_books_id = 3--ASSUMTION
        AND    SYSDATE between start_date AND end_date
        AND    closing_status IN ('O', 'F')
 AND    NVL(adjustment_period_flag, 'N') = 'N'
        AND    ROWNUM = 1;
 EXCEPTION
   WHEN NO_DATA_FOUND THEN
             FND_FILE.PUT_LINE(FND_FILE.log,'Accounting Date Is Not In Open');
    END;
/*------start to Validate Line Level for po_number matching/validating----------*/
 -- get the info of header (if invoice is related to    po_number)
 BEGIN
 Select po_header_id,segment1
 into v_po_header_id, v_po_segment
 From po_headers_all
 where Vendor_ID = vendor_id;
 EXCEPTION
   WHEN NO_DATA_FOUND THEN
             FND_FILE.PUT_LINE(FND_FILE.log,'PO not found in Headers');
    END;
 -- get the info line(if invoice is related to po_number)
 BEGIN
 Select po_line_id,line_num
 into v_po_line_id, v_po_line_num
 From po_lines_all
 where
 Po_Header_ID = v_po_header_id;
 EXCEPTION
   WHEN NO_DATA_FOUND THEN
             FND_FILE.PUT_LINE(FND_FILE.log,'PO not found in Lines');
    END;
 -- get the info location (if invoice is related to po_number)
 BEGIN
 Select line_location_id,shipment_num
 into v_line_location_id, v_shipment_num
 From po_line_locations_all
 where
 Po_Header_ID = v_po_header_id
 and
 Po_Line_ID = v_po_line_id;
 EXCEPTION
   WHEN NO_DATA_FOUND THEN
             FND_FILE.PUT_LINE(FND_FILE.log,'PO not found in Locations');
    END;
 -- get the info of distributions(if invoice is related to po_number)
 BEGIN
 Select po_distribution_id,distribution_num
 into v_po_distribution_id, v_po_distribution_num
 From po_distributions_all
 where
 Po_Header_ID = v_po_header_id
 and
 Po_Line_ID = v_po_line_id
 and
 Line_Location_ID = v_line_location_id;
 EXCEPTION
   WHEN NO_DATA_FOUND THEN
             FND_FILE.PUT_LINE(FND_FILE.log,'PO not found in distributionss');
    END;
/*------end to Validate Line Level for po_number matching/validating----------*/
/*start to inserting invoice line*/ 
 INSERT INTO ap_invoice_lines_interface (
  invoice_id,
  invoice_line_id,
  line_number,
  line_type_lookup_code,
  amount,
  accounting_date,
  dist_code_concatenated,
  dist_code_combination_id,
  po_header_id,
  po_number,
  po_line_id,
  po_line_number,
  po_line_location_id,
  po_shipment_num,
  po_distribution_id,
  po_distribution_num,
  receipt_number,
  attribute1,
  attribute2,
  attribute3,
  attribute4,
  attribute5,
  attribute6,
  attribute7,
  attribute8,
  attribute9,
  attribute10,
  creation_date,
  created_by,
  last_update_date,
  last_updated_by
  )
   VALUES(v_invoice_id,
                 v_invoice_line_id,
                 v_line_no,
   v_line_type,
   v_amount,
                 v_accounting_date,
   v_expence_account1,
   v_expence_account,
   v_po_header_id,
                 v_po_segment,
   v_po_line_id,
   v_po_line_num,
   v_line_location_id,
   v_shipment_num,
   v_po_distribution_id,
   v_po_distribution_num,
   v_receipt_number,
   v_line_attribute1,
      v_line_attribute2,
   v_line_attribute3,
   v_line_attribute4,
   v_line_attribute5,
   v_line_attribute6,
   v_line_attribute7,
   v_line_attribute8,
   v_line_attribute9,
   v_line_attribute10, 
   sysdate,
          FND_GLOBAL.user_id,
          sysdate,
   FND_GLOBAL.user_id
  );
/*end to inserting invoice line*/                
-- ends here to process invoice lines data
END IF;
EXCEPTION
     WHEN NO_DATA_FOUND THEN
        commit;
        exit;
     WHEN OTHERS THEN
 FND_FILE.PUT_LINE(FND_FILE.LOG,'Exception'||SQLERRM);
 rollback;
 exit;
  end;
  END LOOP;--Loop ends here to process invoice headers data
--FND_FILE.PUT_LINE(FND_FILE.log,'Data Transfer is Successfull');
END;      
/
If this notes is useful for any one please submit your comments
thank you
sandeep
 
This code is really helpful and thanks for the effort.
ReplyDeleteThanks a lot... It really help.
ReplyDeleteA good piece of work..thanks for the effort.
ReplyDeleteGood work!
ReplyDeleteGood content. Thnx.
ReplyDeleteGood Work...
ReplyDeleteHi There,
ReplyDeleteIs there a way to identify the sales order lines deleted from ra_transaction_interface where the lines of the sales orders are closed. Is there a way to bring them back to interface for Invocie.
Thanks
G
Good Content , Thank you very much.
ReplyDeleteYes Sandeep it's Very Very Useful to Functional Consultants like us.Thank you for posting such kind of Thank you very much keep it up like Dear Sandeep.
ReplyDeleteHi Sandeep Could u please post GL Interface Detail procoess as it is like this.
ReplyDeleteGood Work Sandeep, Really this clear explanation will help for beginners a lot.
ReplyDeleteThanks a lot
ReplyDeleteHi Sandeep,
ReplyDeleteThanks for this code.
I am trying to submit the Open intarface program in Apps R12.2.3 version, i Got the error, can you please help me.
MSG-00883: After Repport Trigger: Setting the Org Context to Multiple
Thanks a Lot
ReplyDeleteWonderful. Thanks for it.Helps a lot to understand the flow
ReplyDeletethanks, it is very useful for me to learning more
ReplyDeleteHi Sandeep,
ReplyDeleteCould you please give hr_locations interface with full code.
this code belongs to R12 or 11i bcoz i am learner
ReplyDeleteThanks for the FREE help :
ReplyDeleteBilal
Thanks a lot.... It really help
ReplyDeleteThanks a lot... It really help.
ReplyDeleteAnwar
Hi,
ReplyDeleteSandeep can you also provide me script to create table according to this procedure?Because I have created an ADI to load invoice data into custom interface & now i want to use your procedure to transfer data from custom to Oracle Payables Interfaces.
Looking forward for your reply at syed.umairali@live.com
Regards,
Umair
Very use full for Technical resource
ReplyDeletecool
ReplyDeletei am grateful to you for such a helpful material
ReplyDeleteThank you so much
ReplyDeleteExcellent !!!
ReplyDeleteExcellent job!!
ReplyDelete