Thursday, November 16, 2017

Order Import interface program

CREATE OR REPLACE PACKAGE BODY APPS.Cmg_Load_Ret_Pck AS

/*****************************************************************************
-- +=========================================================================+
-- |              Comag Marketing Group, LLC                                 |
-- +=========================================================================+
-- |                                                                         |
-- |                                                                         |
-- |  Package Spec                                                           |
-- |                                                                         |
-- |  FILENAME:       CMG_LOAD_RET_PCK                                       |
-- |                                                                         |
-- |  DESCRIPTION:    Load Return Process                                    |
-- |                                                                         |
-- |                                                                         |
-- |Change Record:                                                           |
-- |===============                                                          |
-- |Version   Date        Author           Remarks                           |
-- |=======  ===========  ==============   ==================================|
-- |  1.11   14-Nov-2007  Azhar Hussain    Modification made as per SCR 4295 |
-- |                                   Cover Price and Selling Price Changes |
-- |                                                                         |
-- |  1.12   20-Oct-2010   Uday T           SCR 6658                         |
--    1.13   20-Oct-2014   Uday T           SCR  8385                        |
-- |  1.14   09-June-2016 Uday T           SCR 8637                          |
-- +=========================================================================+
*****************************************************************************/
/******************************************************************************
   NAME:       CMG_LOAD_RET_PCK
   PURPOSE:

   REVISIONS:
   Ver        Date        Author           Description
   ---------  ----------  ---------------  ------------------------------------
   1.0        5/9/2005    Jim Stuart       Created this package body.
   1.1        7/7/05      J.Stuart         Changed ordered_date to equal sysdate.
   1.2        7/8/05      J.Stuart         Changed values for orig_sys_document_ref, line.attrobute14,
                                           to_char date format for line dff. Added column
                                           customer_po_number for header.
   1.3        7/13/05     J.Stuart         Changes for default salesrep_id,sales_channel_code.
                                           Changed cursor c_cur to only select line quantities gretater than 0.
   1.4        7/17/05     J.Stuart         If return reason code is bad product, check item id,
                                           if null, assign invalid item id.
   1.5        7/18/05     J.Stuart         Added attribute6 to c_item_info cursor. If bipad from
                                           adjustment table is null use item bipad.
   1.6        7/20/05     J.Stuart         Fixed grouping of orders, unit_selling_price, bipad for
                                           certain reason codes.
   1.7        7/28/05     J.Stuart         Made sure certain columns are getting populated.

******************************************************************************/

-- cursor definitions
-- this is the main cursor for this package
CURSOR c_cur
IS
SELECT /*+ FIRST_ROWS */
       hdr.adjustment_header_id,
       hdr.created_by,
       hdr.creation_date,
       hdr.last_updated_by,
       hdr.last_update_date,
       hdr.customer_ref_nr,
       hdr.tally_nr,
       hdr.adjustment_flag,
       hdr.record_interfaced,
       hdr.account_nr,
       hdr.source,
       hdr.total_copies,
       hdr.customer_id,
       hdr.customer_name,
       hdr.bill_to_site_use_id,
       hdr.ship_to_site_use_id,
       hdr.return_date,
       hdr.processed_date,
       hdr.employee_assigned_to,
       hdr.order_category,
       hdr.order_type_id,
       hdr.valid_status_flag,
       hdr.duplicate_flag,
       hdr.store_nr,
       hdr.price_list_id,
       hdr.salesrep_id,
       hdr.sales_channel_code,
       hdr.original_order_header_id,
       hdr.soh_original_system_ref,
       hrl.original_order_header_id line_orig_header_id,
       hrl.original_order_line_id,
       hrl.extended_price,
       hrl.unit_price,
       hrl.inventory_item_id,
       hrl.warehouse_id,
       hrl.line_nr,
       hrl.add_on_code,
       hrl.adjustment_line_id,
       hrl.item_nr,
       hrl.quantity,
       hrl.adjustment_flag line_adjustment_flag,
       hrl.corrected_flag,
       hrl.user_rejected_flag,
       hrl.override_flag,
       hrl.line_interfaced,
       hrl.bar_code,
       hrl.bipad,
       hrl.isbn,
       hrl.magazine,
       hrl.issue_code,
       hrl.cover_date_txt,
       hrl.en_title,
       hrl.upc,
       hrl.cover_price,
       hrl.valid_status_flag line_valid_status_flag,
       hrl.invalid_reason_code,
       NVL(hrl.netsale_revalidation_level,'BILL_TO') netsale_revalidation_level,
       hrl.sol_original_system_line_ref
  FROM apps.hdg_ret_adj_lines_tbl@prodapps.world hrl,
       apps.hdg_ret_adj_header_tbl@prodapps.world hdr
 WHERE hrl.quantity != 0
   AND hrl.adjustment_header_id     = hdr.adjustment_header_id
   AND hrl.line_interfaced          = 'N'
   AND hdr.record_interfaced        = 'N'
   AND hdr.valid_status_flag        = 'Y'
   AND hdr.order_category           = 'RMA'
   AND hrl.adjustment_header_id=1554570 and issue_code='201551'
   ORDER BY hdr.adjustment_header_id;

-- gets the original sales order header
CURSOR c_orig_sales_header( p_header_id IN  oe_order_headers.header_id%TYPE )
IS
  SELECT *
  FROM oe_order_headers
  WHERE header_id = p_header_id;

-- gets the original sales order line
-- if a return then it walks up the tree to the original
CURSOR c_orig_sales_line( p_line_id    IN  oe_order_lines.line_id%TYPE )
IS
  SELECT *
  FROM   oe_order_lines
  START WITH line_id                 = p_line_id
  CONNECT BY PRIOR reference_line_id = line_id
  ORDER BY LEVEL DESC;

-- sales order line pricing attribute
CURSOR c_line_attribs( p_header_id  IN  oe_order_headers.header_id%TYPE,
                       p_line_id    IN  oe_order_lines.line_id%TYPE )
IS
  SELECT pricing_context,
         pricing_attribute1
  FROM   oe_order_price_attribs
  WHERE  line_id   = p_line_id
  AND    header_id = p_header_id;

-- gets the order source id
CURSOR c_ord_source( p_source_name   IN  oe_order_sources.name%TYPE )
IS
SELECT order_source_id
FROM   oe_order_sources
WHERE  name = p_source_name;

-- gets the order type information
-- this will be based on the return or the customer attributes
CURSOR c_trans_type( p_type_id  IN oe_transaction_types.transaction_type_id%TYPE )
IS
  SELECT order_category_code,
         currency_code,
         transaction_type_id,
         conversion_type_code,
         accounting_rule_id,
         invoicing_rule_id
  FROM   oe_transaction_types
  WHERE  transaction_type_id = p_type_id
  AND    TRUNC(SYSDATE) BETWEEN start_date_active AND NVL(end_date_active,TRUNC(SYSDATE+1));

-- get the customer attributes
CURSOR c_cust_attribs( p_cust_id  IN ra_customers.customer_id%TYPE )
IS
  SELECT cca.price_list_id,
         cca.order_type_id,
         cca.primary_salesrep_id,
         cca.tax_code,
         qlh.currency_code
  FROM   qp_list_headers qlh,
         cmg_customer_attributes_vw cca
  WHERE  qlh.list_header_id = cca.price_list_id
  AND    cca.customer_id    = p_cust_id;

-- get the editions information for an item
CURSOR c_edition( p_item_id     IN  mtl_system_items.inventory_item_id%TYPE,
                  p_issue_code  IN  mtl_item_revisions.attribute7%TYPE )
IS
  SELECT attribute7       issue_code,
         attribute8       cover_date,
         attribute10      upc_code,
         attribute13      edition,
         TO_CHAR(effectivity_date,'DD-MON-YYYY') on_sale_date,
         attribute11      off_sale_date,
         attribute12      last_return_date
  FROM   mtl_item_revisions
  WHERE  organization_id   = Cmg_Utility_Pck.org_id('HDG')
  AND    attribute7 = p_issue_code
  AND    inventory_item_id = p_item_id
  and    nvl(attribute1,'N') ='N'
  AND    ROWNUM            = 1;

-- get the item informatoin
CURSOR c_item_info( p_item_id  IN  oe_order_lines.inventory_item_id%TYPE )
IS
  SELECT primary_uom_code,
         attribute6   bipad_code
  FROM   mtl_system_items
  WHERE  organization_id   = Cmg_Utility_Pck.org_id('HDG')
  AND    inventory_item_id = p_item_id;

-- get the default sales rep id
CURSOR salesrep_id_cur
IS
  SELECT salesrep_id
  FROM   ra_salesreps
  WHERE  UPPER(name) = 'NO SALES CREDIT';

-- get the default sales credit id
CURSOR sales_credit_type_cur
IS
  SELECT sales_credit_type_id
  FROM   oe_sales_credit_types
  WHERE  UPPER(name) = 'QUOTA SALES CREDIT';

-- get the default for bad product item
CURSOR invalid_item_cur
IS
  SELECT inventory_item_id bad_inv_item_id,
         organization_id,
         primary_uom_code
  FROM   mtl_system_items
  WHERE  description     LIKE 'INVALID PRODUCT%'
  AND    organization_id = Cmg_Utility_Pck.org_id('HDG');

-- get the error messages from the order import run
CURSOR c_intf_status( p_source_id  IN  oe_order_sources.order_source_id%TYPE,
                      p_request_id IN  fnd_concurrent_requests.request_id%TYPE )
IS
  SELECT h.orig_sys_document_ref,
         m.entity_code,
         m.message_text
  FROM   oe_processing_msgs_vl m,
         oe_headers_interface h
  WHERE  m.request_id                = h.request_id
  AND    m.order_source_id           = h.order_source_id
  AND    m.original_sys_document_ref = h.orig_sys_document_ref
  AND    ( m.TYPE                    = 'ERROR'
           OR m.TYPE IS NULL )
  AND    m.message_status_code       = 'OPEN'
  AND    h.ready_flag                = 'Y'
  AND    h.error_flag                = 'Y'
  AND    h.order_source_id           = p_source_id
  AND    h.request_id IN ( SELECT fcr.request_id
                           FROM   fnd_concurrent_requests fcr
                           START WITH fcr.parent_request_id = p_request_id
                           CONNECT BY PRIOR fcr.request_id  = fcr.parent_request_id);

-- count to see if any errors occured during the order import process
CURSOR c_err_count( p_request_id  IN  fnd_concurrent_requests.request_id%TYPE )
IS
  SELECT COUNT(*)
  FROM   oe_headers_interface ohi
  WHERE  ohi.request_id IN ( SELECT fcr.request_id
                             FROM   fnd_concurrent_requests fcr
                             START WITH fcr.parent_request_id = p_request_id
                             CONNECT BY PRIOR fcr.request_id  = fcr.parent_request_id)
  AND ohi.error_flag      = 'Y';

-- get the number of order import instances to submit
CURSOR c_num_threads
IS
  SELECT TO_NUMBER(meaning) num_threads
  FROM   hdg_lookup_tbl
  WHERE  lookup_type = 'RMA_IMPORT'
  AND    lookup_code = 'MAXIMUM THREADS';

--  Table definitions
TYPE ord_tbl IS TABLE OF c_cur%ROWTYPE
  INDEX BY BINARY_INTEGER;

TYPE source_rec IS RECORD(
  source_name    oe_order_sources.name%TYPE );

TYPE source_tbl IS TABLE OF source_rec
  INDEX BY BINARY_INTEGER;

ord_rec       ord_tbl;
src_rec       source_tbl;

-- variables
intf_head_rec                   oe_headers_interface%ROWTYPE;
intf_line_rec                   oe_lines_interface%ROWTYPE;
orig_head_rec                   c_orig_sales_header%ROWTYPE;
orig_line_rec                   c_orig_sales_line%ROWTYPE;
line_attribs_rec                c_line_attribs%ROWTYPE;
ord_type_rec                    c_trans_type%ROWTYPE;
cust_attr_rec                   c_cust_attribs%ROWTYPE;
invalid_item_rec                invalid_item_cur%ROWTYPE;
item_rec                        c_item_info%ROWTYPE;
edition_rec                     c_edition%ROWTYPE;
v_credit_type_id                oe_sales_credit_types.sales_credit_type_id%TYPE;
v_salesrep_id                   ra_salesreps.salesrep_id%TYPE;
v_hold                          hdg_ret_adj_header_tbl.adjustment_header_id%TYPE := NULL;
v_retcode                       NUMBER;
v_errbuf                        VARCHAR2(100);
v_dphase                        VARCHAR2(20) ;
v_dstatus                       VARCHAR2(20) ;
v_filename                      VARCHAR2(100);
v_price_context                 VARCHAR2(15)  := 'Upgrade Context';
v_hdr_cnt                       NUMBER        := 0;
v_returnable_qty                NUMBER;
v_err_count                     NUMBER;
v_sysdate                       DATE          := SYSDATE;
load_flag                       BOOLEAN;
i                               INTEGER;
v_request_id                    fnd_concurrent_requests.request_id%TYPE := Fnd_Global.CONC_REQUEST_ID;

FUNCTION get_ord_source( p_source_name  IN  oe_order_sources.name%TYPE )
RETURN oe_order_sources.order_source_id%TYPE
IS

v_hold   oe_order_sources.order_source_id%TYPE;

BEGIN

OPEN  c_ord_source( p_source_name );
FETCH c_ord_source INTO v_hold;
CLOSE c_ord_source;

RETURN NVL(v_hold,-1);

END get_ord_source;

FUNCTION get_thread_count
RETURN NUMBER
IS

v_hold  NUMBER;

BEGIN

OPEN  c_num_threads;
FETCH c_num_threads INTO v_hold;
CLOSE c_num_threads;

RETURN v_hold;

EXCEPTION
  WHEN OTHERS THEN
    RETURN 1;
END get_thread_count;

FUNCTION err_count( p_request_id  IN  fnd_concurrent_requests.request_id%TYPE )
RETURN NUMBER
IS

v_hold   NUMBER;

BEGIN

OPEN  c_err_count( p_request_id );
FETCH c_err_count INTO v_hold;
CLOSE c_err_count;

RETURN NVL(v_hold,0);

END err_count;

FUNCTION get_list_price( p_head  IN  oe_headers_interface%ROWTYPE,
                         p_line  IN  oe_lines_interface%ROWTYPE )
RETURN NUMBER
IS

v_hold                  NUMBER;
v_return_status         VARCHAR2(1);
v_msg_count             NUMBER;

BEGIN

Hdgoea67_Pck.hdgoea67_list_price_prc(
  p_price_list_id     => p_head.price_list_id,
  p_inventory_item_id => p_line.inventory_item_id,
  p_unit_code         => p_line.order_quantity_uom,
  p_pricing_attribute => p_line.pricing_attribute1,
  p_list_price        => v_hold,
  p_return_status     => v_return_status,
  p_msg_data          => v_msg_count );

RETURN NVL(v_hold,0);

END get_list_price;

PROCEDURE intialization
IS
BEGIN

OPEN  salesrep_id_cur;
FETCH salesrep_id_cur INTO v_salesrep_id;
CLOSE salesrep_id_cur;

OPEN  sales_credit_type_cur;
FETCH sales_credit_type_cur INTO v_credit_type_id;
CLOSE sales_credit_type_cur;

OPEN  invalid_item_cur;
FETCH invalid_item_cur INTO invalid_item_rec;
CLOSE invalid_item_cur;

EXCEPTION
  WHEN OTHERS THEN
    Cmg_Utility_Pck.write_output(' Intialization procedure failed => '||SQLERRM);
    RAISE;
END intialization;

PROCEDURE MISMATCH_ORDERTYPE_PRC IS

CURSOR RET_CUR IS
select h.adjustment_header_id,get_isspc_fnc(bipad,issue_code) ISS_PCT_ID,M.WHOLESALER_PROFITCENTER_ID,M.derived_ordertype
from hdg_ret_adj_header_tbl h,
     hdg.hdg_ret_adj_lines_tbl l,
     hdg.gen_profitcenter_mapping_tbl m,
     ra_customers c,
     apps.oe_transaction_types t
where h.customer_id=c.customer_id
and  h.adjustment_header_id=l.adjustment_header_id
and  l.line_interfaced          = 'N'
and  h.record_interfaced        = 'N'
and  h.valid_status_flag        = 'Y'
and  h.order_category           = 'RMA'
and  h.order_type_id            = t.transaction_type_id
and  substr(c.customer_name,1,1)=m.wholesaler_pc_name
and  substr(t.name,1,1)=m.derived_ordertype
and  l.invalid_reason_code is null  /* it will only look for the lines which are valid and have mixed profitcenter*/
--and h.adjustment_header_id in (1533869,1533870,1533863,1533863,1533864,1533865,1533866,1533867,1533868)
group by get_isspc_fnc(bipad,issue_code),h.adjustment_header_id,M.WHOLESALER_PROFITCENTER_ID,M.derived_ordertype
order by h.adjustment_header_id;


CURSOR GEN_PROFIT_CUR(P_ISS_PCT_ID IN VARCHAR2,P_WH_PCT_ID IN NUMBER,P_ORDER_TYPE IN VARCHAR2) IS
SELECT NVL(COUNT(*),0)
FROM HDG.GEN_PROFITCENTER_MAPPING_TBL
WHERE TO_CHAR(ISSUE_PROFITCENTER_ID)=P_ISS_PCT_ID
AND  WHOLESALER_PROFITCENTER_ID=P_WH_PCT_ID
AND  DERIVED_ORDERTYPE=P_ORDER_TYPE;


V_COUNT NUMBER;


BEGIN

FOR RET_REC IN RET_CUR LOOP
    OPEN GEN_PROFIT_CUR ( RET_REC.ISS_PCT_ID,RET_REC.WHOLESALER_PROFITCENTER_ID,RET_REC.derived_ordertype);
    FETCH GEN_PROFIT_CUR INTO V_COUNT;
      IF V_COUNT =0 AND  RET_REC.ISS_PCT_ID !='NO ISSUE PROFITCENTER' THEN
       -- DBMS_OUTPUT.PUT_LINE('Not a valid  adj id:'||ret_rec.adjustment_header_id||'   '||
         --                                               ret_rec.ISS_PCT_ID||'   '||
           --                                             ret_rec.WHOLESALER_PROFITCENTER_ID||'   '||
             --                                           ret_rec.derived_ordertype);
        UPDATE HDG.HDG_RET_ADJ_HEADER_TBL
        SET VALID_STATUS_FLAG='N'
        WHERE ADJUSTMENT_HEADER_ID=RET_REC.ADJUSTMENT_HEADER_ID;
       
        UPDATE HDG.HDG_RET_ADJ_LINES_TBL
        SET VALID_STATUS_FLAG='N'
        WHERE ADJUSTMENT_HEADER_ID=RET_REC.ADJUSTMENT_HEADER_ID;
         
      END IF;
     
     CLOSE GEN_PROFIT_CUR;
   
END LOOP;

COMMIT;

END MISMATCH_ORDERTYPE_PRC;

PROCEDURE load_source( p_name   IN  oe_order_sources.name%TYPE )
IS

v_exists       VARCHAR2(1);

BEGIN

Cmg_Utility_Pck.log_msg(' Inside load_source',p_name);
Cmg_Utility_Pck.log_msg('  Count',src_rec.COUNT);

v_exists := 'N';

IF src_rec.COUNT > 0 THEN
--   Cmg_Utility_Pck.write_output('in load_source procedure if count>0 ');
  FOR x IN src_rec.FIRST..src_rec.LAST LOOP

    IF src_rec(x).source_name = p_name THEN

      v_exists := 'Y';

    END IF;

    Cmg_Utility_Pck.write_output('v_exists '||v_exists);

  END LOOP;
END IF;

IF v_exists = 'N' THEN

  src_rec(src_rec.COUNT + 1).source_name := p_name;

END IF;

END load_source;

PROCEDURE get_edition( p_item_id     IN  mtl_system_items.inventory_item_id%TYPE,
                       p_issue_code  IN  mtl_item_revisions.attribute7%TYPE )
IS
BEGIN

OPEN  c_edition( p_item_id, p_issue_code );
FETCH c_edition INTO edition_rec;

IF ( c_edition%NOTFOUND OR c_edition%NOTFOUND IS NULL ) THEN
  edition_rec := NULL;
END IF;

CLOSE c_edition;

END get_edition;

PROCEDURE get_ord_type( p_type_id  IN oe_transaction_types.transaction_type_id%TYPE )
IS
BEGIN

OPEN  c_trans_type( p_type_id );
FETCH c_trans_type INTO ord_type_rec;

IF ( c_trans_type%NOTFOUND OR c_trans_type%NOTFOUND IS NULL ) THEN
  ord_type_rec := NULL;
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_trans_type;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_trans_type%isopen THEN
      CLOSE c_trans_type;
    END IF;
    Cmg_Utility_Pck.write_output(' Error with order type => '||p_type_id);
  WHEN OTHERS THEN
    IF c_trans_type%isopen THEN
      CLOSE c_trans_type;
    END IF;
    Cmg_Utility_Pck.write_output(' Error with order type => '||p_type_id);
END get_ord_type;

PROCEDURE get_cust_atts( p_cust_id  IN  ra_customers.customer_id%TYPE )
IS
BEGIN

OPEN  c_cust_attribs( p_cust_id );
FETCH c_cust_attribs INTO cust_attr_rec;

IF ( c_cust_attribs%NOTFOUND OR c_cust_attribs%NOTFOUND IS NULL ) THEN
  cust_attr_rec := NULL;
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_cust_attribs;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_cust_attribs%isopen THEN
      CLOSE c_cust_attribs;
    END IF;
    Cmg_Utility_Pck.write_output(' Error get_cust_atts => '||p_cust_id);
  WHEN OTHERS THEN
    IF c_cust_attribs%isopen THEN
      CLOSE c_cust_attribs;
    END IF;
    Cmg_Utility_Pck.write_output(' Error get_cust_atts => '||p_cust_id);
END get_cust_atts;

PROCEDURE get_item_info( p_item_id  IN  oe_order_lines.inventory_item_id%TYPE )
IS
BEGIN

OPEN  c_item_info( p_item_id );
FETCH c_item_info INTO item_rec;

IF ( c_item_info%NOTFOUND OR c_item_info%NOTFOUND IS NULL ) THEN
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_item_info;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_item_info%isopen THEN
      CLOSE c_item_info;
    END IF;
    Cmg_Utility_Pck.write_output(' Item info error => '||p_item_id||'-'||SQLERRM);
  WHEN OTHERS THEN
    IF c_item_info%isopen THEN
      CLOSE c_item_info;
    END IF;
    Cmg_Utility_Pck.write_output(' Item info error => '||p_item_id||'-'||SQLERRM);
 END get_item_info;

PROCEDURE get_orig_header( p_header_id  IN  oe_order_headers.header_id%TYPE )
IS
BEGIN

OPEN  c_orig_sales_header( p_header_id );
FETCH c_orig_sales_header INTO orig_head_rec;

IF ( c_orig_sales_header%NOTFOUND OR c_orig_sales_header%NOTFOUND IS NULL ) THEN
  orig_head_rec := NULL;
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_orig_sales_header;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_orig_sales_header%isopen THEN
      CLOSE c_orig_sales_header;
    END IF;
    Cmg_Utility_Pck.write_output(' Sales order header error => '||p_header_id||'-'||SQLERRM);
  WHEN OTHERS THEN
    IF c_orig_sales_header%isopen THEN
      CLOSE c_orig_sales_header;
    END IF;
    Cmg_Utility_Pck.write_output(' Sales order header error => '||p_header_id||'-'||SQLERRM);
END get_orig_header;

PROCEDURE get_orig_line( p_line_id    IN  oe_order_lines.line_id%TYPE )
IS
BEGIN

OPEN  c_orig_sales_line( p_line_id );
FETCH c_orig_sales_line INTO orig_line_rec;

IF ( c_orig_sales_line%NOTFOUND OR c_orig_sales_line%NOTFOUND IS NULL ) THEN
  orig_line_rec := NULL;
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_orig_sales_line;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_orig_sales_line%isopen THEN
      CLOSE c_orig_sales_line;
    END IF;
    Cmg_Utility_Pck.write_output(' Sales order line error => '||p_line_id||'-'||SQLERRM);
   WHEN OTHERS THEN
    IF c_orig_sales_line%isopen THEN
      CLOSE c_orig_sales_line;
    END IF;
    Cmg_Utility_Pck.write_output(' Sales order line error => '||p_line_id||'-'||SQLERRM);
END get_orig_line;

PROCEDURE get_line_attrs( p_header_id  IN  oe_order_headers.header_id%TYPE,
                          p_line_id    IN  oe_order_lines.line_id%TYPE )
IS
BEGIN

OPEN  c_line_attribs( p_header_id, p_line_id );
FETCH c_line_attribs INTO line_attribs_rec;

IF ( c_line_attribs%NOTFOUND OR c_line_attribs%NOTFOUND IS NULL ) THEN
  RAISE NO_DATA_FOUND;
END IF;

CLOSE c_line_attribs;

EXCEPTION
  WHEN NO_DATA_FOUND THEN
    IF c_line_attribs%isopen THEN
      CLOSE c_line_attribs;
    END IF;
    line_attribs_rec := NULL;
  WHEN OTHERS THEN
    IF c_line_attribs%isopen THEN
      CLOSE c_line_attribs;
    END IF;
    line_attribs_rec := NULL;
END get_line_attrs;

PROCEDURE update_hdr_status( p_rec        IN  c_cur%ROWTYPE,
                             p_status     IN  hdg_ret_adj_lines_tbl.valid_status_flag%TYPE,
                             p_interface  IN  hdg_ret_adj_header_tbl.valid_status_flag%TYPE )
IS
BEGIN

UPDATE hdg_ret_adj_header_tbl
SET    record_interfaced    = p_status,
       last_update_date     = SYSDATE,
       last_updated_by      = Fnd_Global.user_id
WHERE  adjustment_header_id = p_rec.adjustment_header_id;

END update_hdr_status;

PROCEDURE update_lns_status ( p_rec     IN  c_cur%ROWTYPE,
                              p_reason  IN  hdg_ret_adj_lines_tbl.invalid_reason_code%TYPE,
                              p_status  IN  hdg_ret_adj_lines_tbl.valid_status_flag%TYPE )
IS
BEGIN

UPDATE hdg_ret_adj_lines_tbl
SET    line_interfaced      = p_status,
       last_update_date     = SYSDATE,
       last_updated_by      = Fnd_Global.user_id
WHERE  adjustment_line_id   = p_rec.adjustment_line_id
AND    adjustment_header_id = p_rec.adjustment_header_id;

END update_lns_status;

PROCEDURE update_hdr_status( p_header_id  IN  hdg_ret_adj_header_tbl.adjustment_header_id%TYPE,
                             p_status     IN  hdg_ret_adj_lines_tbl.valid_status_flag%TYPE,
                             p_interface  IN  hdg_ret_adj_header_tbl.valid_status_flag%TYPE )
IS
BEGIN

Cmg_Utility_Pck.write_output('before update hdr status ');

UPDATE hdg_ret_adj_header_tbl
SET    record_interfaced    = p_status,
       last_update_date     = SYSDATE,
       last_updated_by      = Fnd_Global.user_id
WHERE  adjustment_header_id = p_header_id;

Cmg_Utility_Pck.write_output('After update hdr status');

END update_hdr_status;

PROCEDURE update_lns_status ( p_header_id  IN  hdg_ret_adj_header_tbl.adjustment_header_id%TYPE,
                              p_line_id    IN hdg_ret_adj_lines_tbl.adjustment_line_id%TYPE,
                              p_reason     IN  hdg_ret_adj_lines_tbl.invalid_reason_code%TYPE,
                              p_status     IN  hdg_ret_adj_lines_tbl.valid_status_flag%TYPE )
IS
BEGIN

UPDATE hdg_ret_adj_lines_tbl
SET    line_interfaced      = p_status,
       last_update_date     = SYSDATE,
       last_updated_by      = Fnd_Global.user_id
WHERE  adjustment_line_id   = p_line_id
AND    adjustment_header_id = p_header_id;

END update_lns_status;

PROCEDURE insert_header( p_rec  IN  oe_headers_interface%ROWTYPE )
IS
BEGIN

Cmg_Utility_Pck.log_msg(' Inside insert_header',p_rec.orig_sys_document_ref);

--Cmg_Utility_Pck.write_output('inside insert header');

INSERT INTO oe_headers_interface(
  created_by ,
  last_updated_by ,
  creation_date ,
  last_update_date ,
  booked_flag,
  ready_flag ,
  rejected_flag  ,
  operation_code ,
  error_flag ,
  order_source_id ,
  order_type_id ,
  order_category ,
  sold_to_org_id ,
  invoice_customer_id,
  ship_to_customer_id ,
  invoice_to_org_id,
  ship_to_org_id ,
  ship_from_org_id ,
  price_list_id ,
  salesrep_id,
  sales_channel_code ,
  orig_sys_document_ref ,
  ordered_date,
  transactional_curr_code ,
  conversion_type_code ,
  customer_payment_term_id ,
  accounting_rule_id ,
  invoicing_rule_id,
  CONTEXT ,
  attribute1,
  attribute2,
  attribute3,
  attribute4,
  attribute5,
  attribute6,
  attribute7,
  attribute8,
  attribute9,
  attribute10,
  attribute11,
  attribute12,
  attribute13,
  attribute14,
  attribute15,
  attribute16,
  attribute17,
  attribute18,
  attribute19,
  attribute20,
  global_attribute20,
  customer_po_number )
VALUES(
  p_rec.created_by ,
  p_rec.last_updated_by ,
  p_rec.creation_date ,
  p_rec.last_update_date ,
  p_rec.booked_flag,
  p_rec.ready_flag ,
  p_rec.rejected_flag  ,
  p_rec.operation_code ,
  p_rec.error_flag ,
  p_rec.order_source_id ,
  p_rec.order_type_id ,
  p_rec.order_category ,
  p_rec.sold_to_org_id ,
  p_rec.invoice_customer_id,
  p_rec.ship_to_customer_id ,
  p_rec.invoice_to_org_id,
  p_rec.ship_to_org_id ,
  p_rec.ship_from_org_id ,
  p_rec.price_list_id ,
  p_rec.salesrep_id,
  p_rec.sales_channel_code ,
  p_rec.orig_sys_document_ref ,
  p_rec.ordered_date,
  p_rec.transactional_curr_code ,
  p_rec.conversion_type_code ,
  p_rec.customer_payment_term_id ,
  p_rec.accounting_rule_id ,
  p_rec.invoicing_rule_id,
  p_rec.CONTEXT ,
  p_rec.attribute1,
  p_rec.attribute2,
  p_rec.attribute3,
  p_rec.attribute4,
  p_rec.attribute5,
  p_rec.attribute6,
  p_rec.attribute7,
  p_rec.attribute8,
  p_rec.attribute9,
  p_rec.attribute10,
  p_rec.attribute11,
  p_rec.attribute12,
  p_rec.attribute13,
  p_rec.attribute14,
  p_rec.attribute15,
  p_rec.attribute16,
  p_rec.attribute17,
  p_rec.attribute18,
  p_rec.attribute19,
  p_rec.attribute20,
  p_rec.global_attribute20,-- adjustment_header_id
  p_rec.customer_po_number );

--  Cmg_Utility_Pck.write_output('after inserting the header interface table ');

EXCEPTION
  WHEN OTHERS THEN
    Cmg_Utility_Pck.write_output(' Error creating header record => '||p_rec.orig_sys_document_ref);
    RAISE;
END insert_header;

PROCEDURE insert_line( p_rec  IN  oe_lines_interface%ROWTYPE )
IS
BEGIN

Cmg_Utility_Pck.log_msg(' Inside insert_line',p_rec.orig_sys_line_ref);

INSERT INTO oe_lines_interface(
  creation_date,
  created_by,
  last_update_date ,
  last_updated_by ,
  error_flag ,
  operation_code ,
  rejected_flag ,
  orig_sys_document_ref,
  orig_sys_line_ref,
  line_number ,
  order_quantity_uom ,
  ordered_quantity ,
  request_date,
  inventory_item_id ,
  ship_to_customer_id ,
  calculate_price_flag ,
  unit_selling_price ,
  unit_list_price ,
  order_source_id  ,
  ship_to_org_id ,
  ship_from_org_id ,
  pricing_context,
  pricing_attribute1,
  attribute1 ,
  attribute2,
  attribute3,
  attribute4,
  attribute5,
  attribute6,
  attribute7,
  attribute8,
  attribute9 ,
  attribute10,
  attribute11,
  attribute12,
  attribute13,
  attribute14,
  attribute15,
  attribute16,
  attribute17,
  attribute18,
  attribute19,
  attribute20,
  return_context,
  return_attribute1,
  return_attribute2,
  return_reason_code,
  reference_type,
  reference_header_id,
  reference_line_id,
  pricing_date,
  sold_to_org_id,
  invoice_to_org_id,
  global_attribute_category,
  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,
  industry_attribute18,
  industry_attribute19,
  industry_attribute20,
  line_category_code,-- SCR 6658
  line_type )-- SCR 6658
VALUES(
  p_rec.creation_date,
  p_rec.created_by,
  p_rec.last_update_date ,
  p_rec.last_updated_by ,
  p_rec.error_flag ,
  p_rec.operation_code ,
  p_rec.rejected_flag ,
  p_rec.orig_sys_document_ref,
  p_rec.orig_sys_line_ref,
  p_rec.line_number ,
  p_rec.order_quantity_uom ,
  p_rec.ordered_quantity ,
  p_rec.request_date,
  p_rec.inventory_item_id ,
  p_rec.ship_to_customer_id ,
  p_rec.calculate_price_flag ,
  p_rec.unit_selling_price ,
  p_rec.unit_list_price ,
  p_rec.order_source_id  ,
  p_rec.ship_to_org_id ,
  p_rec.ship_from_org_id ,
  NVL(p_rec.pricing_context,v_price_context),
  p_rec.pricing_attribute1,
  p_rec.attribute1 ,
  p_rec.attribute2,
  p_rec.attribute3,
  p_rec.attribute4,
   /* if the referenced cover price is null or 0, populate the unit list price from the referenced Sales Order line as the cover price */
  decode(p_rec.attribute5,null,p_rec.unit_list_price,
                          0,p_rec.unit_list_price,
                            p_rec.attribute5),
  p_rec.attribute6,
  p_rec.attribute7,
  p_rec.attribute8,
  p_rec.attribute9 ,
  p_rec.attribute10,
  p_rec.attribute11,
  p_rec.attribute12,
  p_rec.attribute13,
  p_rec.attribute14,
  p_rec.attribute15,
  p_rec.attribute16,
  p_rec.attribute17,
  p_rec.attribute18,
  p_rec.attribute19,
  p_rec.attribute20,
  p_rec.return_context,
  p_rec.return_attribute1,
  p_rec.return_attribute2,
  p_rec.return_reason_code,--NVL(p_rec.return_reason_code,'RETURN'), -- SCR 6658
  p_rec.reference_type,
  p_rec.reference_header_id,
  p_rec.reference_line_id,
  p_rec.pricing_date,
  p_rec.sold_to_org_id,
  p_rec.invoice_to_org_id,
  p_rec.global_attribute_category,
  p_rec.global_attribute1,
  p_rec.global_attribute2,
  p_rec.global_attribute3,
  p_rec.global_attribute4,
  p_rec.global_attribute5,
  p_rec.global_attribute6,
  p_rec.global_attribute7,
  p_rec.global_attribute8,
  p_rec.global_attribute9,
  p_rec.global_attribute10,
  p_rec.global_attribute11,
  p_rec.global_attribute12,
  p_rec.global_attribute13,
  p_rec.global_attribute14,
  p_rec.global_attribute15,
  p_rec.global_attribute16,
  p_rec.global_attribute17,
  p_rec.global_attribute18,
  p_rec.global_attribute19,
  p_rec.global_attribute20,
  p_rec.industry_attribute18,-- refrenced header_id
  p_rec.industry_attribute19,--refrenced_line_id
  p_rec.industry_attribute20, -- adjustment_line_id
  p_rec.line_category_code,-- SCR 6658
  p_rec.line_type );-- SCR 6658

IF p_rec.return_context IS NULL THEN

  INSERT INTO oe_price_atts_interface(
    created_by,
    creation_date,
    last_updated_by,
    last_update_date,
    operation_code,
    orig_sys_document_ref,
    orig_sys_line_ref,
    pricing_context,
    pricing_attribute1,
    order_source_id,
    flex_title )
  VALUES(
    Fnd_Global.user_id,
    SYSDATE,
    Fnd_Global.user_id,
    SYSDATE,
    'CREATE',
    p_rec.orig_sys_document_ref,
    p_rec.orig_sys_line_ref,
    NVL(p_rec.pricing_context,v_price_context),
    p_rec.pricing_attribute1,
    p_rec.order_source_id,
    'QP_ATTR_DEFNS_PRICING' );

END IF;

EXCEPTION
  WHEN OTHERS THEN
    Cmg_Utility_Pck.write_output(' Error creating line record => '||p_rec.orig_sys_document_ref);
    RAISE;
END insert_line;

PROCEDURE set_header( p_rec  IN  ord_tbl )
IS
BEGIN

Cmg_Utility_Pck.log_msg(' Inside set_header',p_rec(p_rec.FIRST).line_orig_header_id);

v_hdr_cnt := v_hdr_cnt + 1;

GET_ORIG_HEADER  ( p_rec(p_rec.FIRST).line_orig_header_id );
-- GET_CUST_INFO    ( p_rec(1).customer_id );
-- GET_NEW_ORD      ( cust_rec );
GET_CUST_ATTS    ( p_rec(p_rec.FIRST).customer_id );

IF p_rec(p_rec.first).order_type_id IS NULL THEN
  GET_ORD_TYPE     ( cust_attr_rec.order_type_id );
ELSE
  GET_ORD_TYPE     ( p_rec(p_rec.FIRST).order_type_id );
END IF;

intf_head_rec                          := NULL;

intf_head_rec.created_by               := p_rec(p_rec.FIRST).created_by;
intf_head_rec.last_updated_by          := p_rec(p_rec.FIRST).created_by;
intf_head_rec.creation_date            := v_sysdate;
intf_head_rec.last_update_date         := intf_head_rec.creation_date;
intf_head_rec.booked_flag              := 'Y';
intf_head_rec.ready_flag               := 'Y';
intf_head_rec.rejected_flag            := 'N';
intf_head_rec.operation_code           := 'CREATE';
-- intf_head_rec.error_flag               := 'Y';

IF p_rec(p_rec.FIRST).adjustment_flag = 'Y' THEN
           -- Since header is a manual adjustment, order source
           -- must either be EN MANUAL ADJ or HDG MANUAL ADJ
  intf_head_rec.order_source_id          := GET_ORD_SOURCE('HDG MANUAL ADJ');
  LOAD_SOURCE('HDG MANUAL ADJ');

ELSE
-- Must be a Price Change or Customer Transfer
  IF p_rec(p_rec.FIRST).soh_original_system_ref LIKE '%GPC%' THEN

    intf_head_rec.order_source_id          := GET_ORD_SOURCE('HDG AUTO PRICE ADJ');
    LOAD_SOURCE('HDG AUTO PRICE ADJ');

  ELSIF p_rec(p_rec.FIRST).soh_original_system_ref LIKE '%ACT%' THEN

    intf_head_rec.order_source_id          := GET_ORD_SOURCE('HDG CUSTOMER TRANSFERS');
    LOAD_SOURCE('HDG CUSTOMER TRANSFERS');

  ELSE
  -- Must be an electronically processed return
   Cmg_Utility_Pck.write_output('getting return  source id');

   intf_head_rec.order_source_id          := GET_ORD_SOURCE('HDG RETURNS');
    LOAD_SOURCE('HDG RETURNS');
    Cmg_Utility_Pck.write_output('after load_source hdg returns ');

  END IF;

END IF;

intf_head_rec.sold_to_org_id           := p_rec(p_rec.FIRST).customer_id;
intf_head_rec.invoice_customer_id      := p_rec(p_rec.FIRST).customer_id;
intf_head_rec.ship_to_customer_id      := p_rec(p_rec.FIRST).customer_id;
intf_head_rec.invoice_to_org_id        := p_rec(p_rec.FIRST).bill_to_site_use_id;
intf_head_rec.ship_to_org_id           := p_rec(p_rec.FIRST).ship_to_site_use_id;
intf_head_rec.ship_from_org_id         := p_rec(p_rec.FIRST).warehouse_id;
intf_head_rec.price_list_id            := NVL(p_rec(p_rec.FIRST).price_list_id,cust_attr_rec.price_list_id);
intf_head_rec.salesrep_id              := NVL(NVL(p_rec(p_rec.FIRST).salesrep_id,cust_attr_rec.primary_salesrep_id),v_salesrep_id);
intf_head_rec.sales_channel_code       := NVL(p_rec(p_rec.FIRST).sales_channel_code,'HDG DEFAULT');

intf_head_rec.ordered_date             := SYSDATE;  -- nvl(p_rec(p_rec.FIRST).processed_date,sysdate);
intf_head_rec.transactional_curr_code  := NVL(ord_type_rec.currency_code,cust_attr_rec.currency_code);
intf_head_rec.conversion_type_code     := ord_type_rec.conversion_type_code;

intf_head_rec.customer_payment_term_id := orig_head_rec.payment_term_id;

intf_head_rec.accounting_rule_id       := ord_type_rec.accounting_rule_id;
intf_head_rec.invoicing_rule_id        := ord_type_rec.invoicing_rule_id;

intf_head_rec.orig_sys_document_ref    := p_rec(p_rec.FIRST).adjustment_header_id||'-'||
                                          p_rec(p_rec.FIRST).tally_nr||'-'||
                                          p_rec(p_rec.FIRST).customer_ref_nr;

intf_head_rec.customer_po_number       := p_rec(p_rec.FIRST).customer_ref_nr;

intf_head_rec.order_type_id            := NVL(ord_type_rec.transaction_type_id,cust_attr_rec.order_type_id);
intf_head_rec.order_category           := ord_type_rec.order_category_code;

-- dff definitions
intf_head_rec.CONTEXT                  := ord_type_rec.order_category_code;
intf_head_rec.attribute1               := orig_head_rec.attribute1;
intf_head_rec.attribute2               := orig_head_rec.attribute2;
intf_head_rec.attribute3               := p_rec(p_rec.FIRST).customer_ref_nr;
intf_head_rec.attribute4               := p_rec(p_rec.FIRST).return_date;

-- SCR 6658
-- SCR 8637 ( Added %RV-% to include Genera Customer Account Returns Reversals for CMG Publishers)
IF p_rec(p_rec.FIRST).customer_ref_nr like '%RV' OR p_rec(p_rec.FIRST).customer_ref_nr like '%RV-%'then
  intf_head_rec.attribute5 := null;
ELSE
intf_head_rec.attribute5               := p_rec(p_rec.FIRST).tally_nr;
END IF;

intf_head_rec.attribute6               := orig_head_rec.attribute6;
intf_head_rec.attribute7               := orig_head_rec.attribute7;
intf_head_rec.attribute8               := orig_head_rec.attribute8;
intf_head_rec.attribute9               := orig_head_rec.attribute9;
intf_head_rec.attribute10              := orig_head_rec.attribute10;
intf_head_rec.attribute11              := orig_head_rec.attribute11;
intf_head_rec.attribute12              := orig_head_rec.attribute12;
intf_head_rec.attribute13              := orig_head_rec.attribute13;
intf_head_rec.attribute14              := orig_head_rec.attribute14;
intf_head_rec.attribute15              := orig_head_rec.attribute15;
intf_head_rec.attribute16              := orig_head_rec.attribute16;
intf_head_rec.attribute17              := orig_head_rec.attribute17;
intf_head_rec.attribute18              := orig_head_rec.attribute18;
intf_head_rec.attribute19              := orig_head_rec.attribute19;
intf_head_rec.global_attribute20       := p_rec(p_rec.FIRST).adjustment_header_id;

Cmg_Utility_Pck.write_output('Loading into header table');

INSERT_HEADER( intf_head_rec );
Cmg_Utility_Pck.write_output('After insert_header done ');

Cmg_Utility_Pck.write_output('Before update header status ');

UPDATE_HDR_STATUS( p_rec(p_rec.FIRST).adjustment_header_id, 'Y', NULL );

Cmg_Utility_Pck.write_output('after update header status ');

EXCEPTION
  WHEN OTHERS THEN
    Cmg_Utility_Pck.write_output(' set_header: Err others => '||SQLERRM);
    RAISE;
END set_header;

PROCEDURE set_line( p_rec  IN  ord_tbl )
IS
BEGIN

FOR j IN p_rec.FIRST..p_rec.LAST LOOP


  GET_ORIG_LINE  ( p_rec(j).original_order_line_id );
  GET_ITEM_INFO  ( p_rec(j).inventory_item_id );
  GET_LINE_ATTRS ( orig_line_rec.header_id, orig_line_rec.line_id );
  get_edition    ( p_rec(j).inventory_item_id, p_rec(j).issue_code );

/* Get_Edition procedure is modified by passing the necessary issue_code to get the active UPC from the revisions table */
 /* GET_EDITION    ( p_rec(j).inventory_item_id, NULL); */ -- commented out.

  intf_line_rec                       := NULL;

  intf_line_rec.creation_date         := v_sysdate;
  intf_line_rec.created_by            := p_rec(j).created_by;
  intf_line_rec.last_update_date      := v_sysdate;
  intf_line_rec.last_updated_by       := p_rec(j).created_by;
  intf_line_rec.operation_code        := 'CREATE';
  intf_line_rec.rejected_flag         := 'N';

  intf_line_rec.pricing_context       := NVL(line_attribs_rec.pricing_context,orig_line_rec.pricing_context);
  intf_line_rec.pricing_attribute1    := NVL(NVL(line_attribs_rec.pricing_attribute1,
                                                 orig_line_rec.pricing_attribute1),p_rec(j).upc);


  intf_line_rec.orig_sys_document_ref := intf_head_rec.orig_sys_document_ref;
  intf_line_rec.orig_sys_line_ref     := p_rec(j).adjustment_line_id;
  intf_line_rec.line_number           := j;
  intf_line_rec.order_quantity_uom    := item_rec.primary_uom_code;
  intf_line_rec.ordered_quantity      := p_rec(j).quantity;
  intf_line_rec.request_date          := v_sysdate;
  intf_line_rec.inventory_item_id     := p_rec(j).inventory_item_id;
  intf_line_rec.ship_to_customer_id   := intf_head_rec.ship_to_customer_id;
  intf_line_rec.attribute4            := NVL(NVL(p_rec(j).bipad,item_rec.bipad_code),orig_line_rec.attribute4); -- bipad
  intf_line_rec.calculate_price_flag  := 'N';

  intf_line_rec.unit_list_price       := NVL(NVL(orig_line_rec.attribute5,p_rec(j).cover_price),GET_LIST_PRICE( intf_head_rec, intf_line_rec ));
  intf_line_rec.attribute5            := NVL(NVL(orig_line_rec.attribute5,p_rec(j).cover_price),GET_LIST_PRICE( intf_head_rec, intf_line_rec ));
 -- intf_line_rec.unit_selling_price    := NVL(orig_line_rec.unit_selling_price,p_rec(j).unit_price);

   IF orig_line_rec.unit_selling_price = 0 OR orig_line_rec.unit_selling_price IS NULL THEN
            intf_line_rec.unit_selling_price := NVL(p_rec(j).unit_price,0);
   ELSE
        intf_line_rec.unit_selling_price :=orig_line_rec.unit_selling_price;
   END IF;


   IF (p_rec(j).invalid_reason_code IS NOT NULL ) THEN

    IF ( p_rec(j).user_rejected_flag     = 'Y' ) THEN

      intf_line_rec.unit_selling_price   := 0;
      intf_line_rec.attribute5 := NVL(NVL(orig_line_rec.attribute5,p_rec(j).cover_price),GET_LIST_PRICE( intf_head_rec, intf_line_rec ));
      intf_line_rec.unit_list_price := NVL(NVL(orig_line_rec.attribute5,p_rec(j).cover_price),GET_LIST_PRICE( intf_head_rec, intf_line_rec ));

     ELSIF  ( p_rec(j).override_flag ='Y' ) THEN
          IF (p_rec(j).invalid_reason_code IN ('NOT BILLED' ,'BAD ISSUE','BAD PRODUCT'))THEN
             intf_line_rec.calculate_price_flag := 'N';

                      IF orig_line_rec.attribute5 = 0 OR orig_line_rec.attribute5 IS NULL THEN
             intf_line_rec.unit_list_price := NVL(p_rec(j).cover_price,0);
             intf_line_rec.attribute5 := NVL(p_rec(j).cover_price,0);
           --  Cmg_Utility_Pck.write_output(' inside 0 or null  Cover price '|| p_rec(j).cover_price);
          END IF;


          IF orig_line_rec.unit_selling_price = 0 OR orig_line_rec.unit_selling_price IS NULL THEN
            intf_line_rec.unit_selling_price := NVL(p_rec(j).unit_price,0);
          --  Cmg_Utility_Pck.write_output('inside 0 or null  selling price '|| p_rec(j).unit_price );
          END IF;


            intf_line_rec.price_list_id        := cust_attr_rec.price_list_id;
         END IF;

     END IF;

   END IF;


    IF p_rec(j).invalid_reason_code  IN ('BAD PRODUCT' ,'BAD ISSUE','NOT BILLED') THEN

        intf_line_rec.attribute4 :=  NVL(p_rec(j).isbn,item_rec.bipad_code);
        intf_line_rec.inventory_item_id     := NVL(p_rec(j).inventory_item_id,invalid_item_rec.bad_inv_item_id);
    END IF;

  intf_line_rec.pricing_date          := NVL(orig_line_rec.pricing_date,orig_head_rec.ordered_date);

  intf_line_rec.order_source_id       := intf_head_rec.order_source_id;
  intf_line_rec.ship_to_org_id        := intf_head_rec.ship_to_org_id;
  intf_line_rec.ship_from_org_id      := intf_head_rec.ship_from_org_id;
  intf_line_rec.sold_to_org_id        := intf_head_rec.sold_to_org_id;
  intf_line_rec.invoice_to_org_id     := intf_head_rec.invoice_to_org_id;
-- dff definitions
  intf_line_rec.CONTEXT               := NULL;
  intf_line_rec.attribute1            := NVL(p_rec(j).issue_code,orig_line_rec.attribute1);   -- issue code
  intf_line_rec.attribute2            := NVL(orig_line_rec.attribute2,edition_rec.cover_date);  -- cover date
  intf_line_rec.attribute3            := NVL(orig_line_rec.attribute3,edition_rec.edition);  -- edition
  intf_line_rec.attribute6            := NVL(orig_line_rec.attribute6,edition_rec.on_sale_date); -- on sale date
  intf_line_rec.attribute7            := NVL(orig_line_rec.attribute7,edition_rec.off_sale_date); -- off sale date
  intf_line_rec.attribute8            := NVL(orig_line_rec.attribute8,edition_rec.last_return_date); -- last return date
  intf_line_rec.attribute9            := orig_line_rec.attribute9;  -- returnable status
  intf_line_rec.attribute10           := NULL;  -- encore interface flag
  intf_line_rec.attribute11           := orig_line_rec.attribute11;
 -- intf_line_rec.attribute12           := orig_line_rec.attribute12;

 -- SCR 6658
 -- SCR 8637 ( Added %RV-% to include GENERA Account Returns Reversals for CMG Publishers)
  IF p_rec(p_rec.FIRST).customer_ref_nr like '%RV' OR p_rec(p_rec.FIRST).customer_ref_nr like '%RV-%' then
    intf_line_rec.attribute13           := 'S';
    intf_line_rec.attribute14           :=  NULL;
    intf_line_rec.line_category_code    := 'ORDER';
    intf_line_rec.line_type             := 'CMG Order Line';
    intf_line_rec.return_reason_code    :=  NVL(p_rec(j).invalid_reason_code,null);
  ELSE
    intf_line_rec.attribute13           := NULL;
    intf_line_rec.attribute14           := NVL(p_rec(j).invalid_reason_code,'RETURN');
    intf_line_rec.line_category_code    := NULL;
    intf_line_rec.line_type             := NULL;
    intf_line_rec.return_reason_code    := NVL(p_rec(j).invalid_reason_code,'RETURN');
  END IF;


  intf_line_rec.attribute15           := orig_line_rec.attribute15;
  intf_line_rec.attribute16           := orig_line_rec.attribute16;
  intf_line_rec.attribute17           := orig_line_rec.attribute17;
  intf_line_rec.attribute18           := orig_line_rec.attribute18;
  intf_line_rec.attribute19           := orig_line_rec.attribute19;
  intf_line_rec.industry_attribute20  := p_rec(j).adjustment_line_id;
  intf_line_rec.industry_attribute18  := orig_line_rec.header_id;
  intf_line_rec.industry_attribute19  := orig_line_rec.line_id;


  INSERT_LINE( intf_line_rec );

  UPDATE_LNS_STATUS( p_rec(j).adjustment_header_id,
                     p_rec(j).adjustment_line_id,
                     NULL,
                     'Y' );

END LOOP;

EXCEPTION
  WHEN OTHERS THEN
    Cmg_Utility_Pck.write_output(' set_line: Err others => '||SQLERRM);
    RAISE;
END set_line;

PROCEDURE load_table( p_rec  IN  c_cur%ROWTYPE )
IS
BEGIN

Cmg_Utility_Pck.log_msg(' Inside load_table',p_rec.adjustment_header_id);

IF p_rec.line_valid_status_flag = 'N' THEN

fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started8'||p_rec.line_valid_status_flag);
  Cmg_Utility_Pck.log_msg('  line_valid_status_flag',p_rec.line_valid_status_flag);

  load_flag := FALSE;

/*  elsif ( p_rec.override_flag = 'N' or p_rec.user_rejected_flag = 'N' ) then

  v_returnable_qty := hdg_rmaval_pck.hdg_validate_netsale_fnc(
                                      p_rec.netsale_revalidation_level,
                                      p_rec.customer_id,
                                      p_rec.inventory_item_id,
                                      p_rec.warehouse_id,
                                      p_rec.issue_code,
                                      p_rec.quantity,
                                      p_rec.ship_to_site_use_id);

  IF v_returnable_qty < 0 THEN
    cmg_utility_pck.write_output('Net Sale Validation Failed'||
                      ' for the Adj Line Id '||p_rec.adjustment_line_id);

    UPDATE_LNS_STATUS( p_rec, 'OVERDRAW', 'N' );

    UPDATE_HDR_STATUS( p_rec, 'N', null );

    load_flag := FALSE;

  end if;  */
END IF;

Cmg_Utility_Pck.write_output('Inside the load_table procedure');


i := i + 1;

ord_rec(i).adjustment_header_id         := p_rec.adjustment_header_id;
ord_rec(i).created_by                   := p_rec.created_by;
ord_rec(i).creation_date                := p_rec.creation_date;
ord_rec(i).last_updated_by              := p_rec.last_updated_by;
ord_rec(i).last_update_date             := p_rec.last_update_date;
ord_rec(i).customer_ref_nr              := p_rec.customer_ref_nr;
ord_rec(i).tally_nr                     := p_rec.tally_nr;
ord_rec(i).adjustment_flag              := p_rec.adjustment_flag;
ord_rec(i).record_interfaced            := p_rec.record_interfaced;
ord_rec(i).account_nr                   := p_rec.account_nr;
ord_rec(i).source                       := p_rec.source;
ord_rec(i).total_copies                 := p_rec.total_copies;
ord_rec(i).customer_id                  := p_rec.customer_id;
ord_rec(i).customer_name                := p_rec.customer_name;
ord_rec(i).bill_to_site_use_id          := p_rec.bill_to_site_use_id;
ord_rec(i).ship_to_site_use_id          := p_rec.ship_to_site_use_id;
ord_rec(i).return_date                  := p_rec.return_date;
ord_rec(i).processed_date               := p_rec.processed_date;
ord_rec(i).employee_assigned_to         := p_rec.employee_assigned_to;
ord_rec(i).order_category               := p_rec.order_category;
ord_rec(i).order_type_id                := p_rec.order_type_id;
ord_rec(i).valid_status_flag            := p_rec.valid_status_flag;
ord_rec(i).duplicate_flag               := p_rec.duplicate_flag;
ord_rec(i).store_nr                     := p_rec.store_nr;
ord_rec(i).price_list_id                := p_rec.price_list_id;
ord_rec(i).salesrep_id                  := p_rec.salesrep_id;
ord_rec(i).sales_channel_code           := p_rec.sales_channel_code;
ord_rec(i).original_order_header_id     := p_rec.original_order_header_id;
ord_rec(i).soh_original_system_ref      := p_rec.soh_original_system_ref;
ord_rec(i).line_orig_header_id          := p_rec.line_orig_header_id;
ord_rec(i).original_order_line_id       := p_rec.original_order_line_id;
ord_rec(i).extended_price               := p_rec.extended_price;
ord_rec(i).unit_price                   := p_rec.unit_price;
ord_rec(i).inventory_item_id            := p_rec.inventory_item_id;
ord_rec(i).warehouse_id                 := p_rec.warehouse_id;
ord_rec(i).line_nr                      := p_rec.line_nr;
ord_rec(i).add_on_code                  := p_rec.add_on_code;
ord_rec(i).adjustment_line_id           := p_rec.adjustment_line_id;
ord_rec(i).item_nr                      := p_rec.item_nr;
ord_rec(i).quantity                     := p_rec.quantity;
ord_rec(i).line_adjustment_flag         := p_rec.line_adjustment_flag;
ord_rec(i).corrected_flag               := p_rec.corrected_flag;
ord_rec(i).user_rejected_flag           := p_rec.user_rejected_flag;
ord_rec(i).override_flag                := p_rec.override_flag;
ord_rec(i).line_interfaced              := p_rec.line_interfaced;
ord_rec(i).bar_code                     := p_rec.bar_code;
ord_rec(i).bipad                        := p_rec.bipad;
ord_rec(i).isbn                         := p_rec.isbn;
ord_rec(i).magazine                     := p_rec.magazine;
ord_rec(i).issue_code                   := p_rec.issue_code;
ord_rec(i).cover_date_txt               := p_rec.cover_date_txt;
ord_rec(i).en_title                     := p_rec.en_title;
ord_rec(i).upc                          := p_rec.upc;
ord_rec(i).cover_price                  := p_rec.cover_price;
ord_rec(i).line_valid_status_flag       := p_rec.line_valid_status_flag;
ord_rec(i).invalid_reason_code          := p_rec.invalid_reason_code;
ord_rec(i).netsale_revalidation_level   := p_rec.netsale_revalidation_level;
ord_rec(i).sol_original_system_line_ref := p_rec.sol_original_system_line_ref;

--Cmg_Utility_Pck.write_output('after the load_table procedure');

END load_table;

-- start this puppy
PROCEDURE main( errbuf  OUT VARCHAR2,
                retcode OUT NUMBER) IS

BEGIN

Cmg_Utility_Pck.write_output('');
Cmg_Utility_Pck.write_output('       Log File For RMA Import Program');
Cmg_Utility_Pck.write_output('       --------------------------------------');
Cmg_Utility_Pck.write_output('');

Cmg_Utility_Pck.log_msg('CMG_LOAD_RET_PCK.MAIN: Started',TO_CHAR(SYSDATE,'DD-MON-YYYY HH24:MI:SS'));


--CHECK FOR ANY MISMATCH IN ORDER TYPES AND MARK THEM AS INVALID (FOREIGN MIGRATION)
MISMATCH_ORDERTYPE_PRC;
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started1');
load_flag := FALSE;
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started2');
INTIALIZATION;
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started3');

FOR rec IN c_cur LOOP

--Cmg_Utility_Pck.write_outpu--Cmg_Utility_Pck.write_output('v_hold'||v_hold);


  -- Cmg_Utility_Pck.write_output('load flag'|| load_flag);
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started4');
  IF ( v_hold IS NULL OR v_hold <> rec.adjustment_header_id ) THEN

--  Cmg_Utility_Pck.write_output('2');
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started5');

    IF load_flag THEN
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started6');
      SET_HEADER( ord_rec );
--      Cmg_Utility_Pck.write_output('3');
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started7');
      SET_LINE( ord_rec );
--Cmg_Utility_Pck.write_output('4');

    END IF;

    ord_rec.DELETE;

    load_flag       := TRUE;

    i := 0;

    v_hold := rec.adjustment_header_id;

  END IF;

--Cmg_Utility_Pck.write_output('5 ');

  LOAD_TABLE( rec );

--  Cmg_Utility_Pck.write_output('after the load table procedure');
 -- Cmg_Utility_Pck.write_output('5-test');

END LOOP;

Cmg_Utility_Pck.log_msg(' Count',ord_rec.COUNT);

Cmg_Utility_Pck.write_output('count='||ord_rec.count);

IF ( ord_rec.COUNT > 0 AND load_flag ) THEN

--Cmg_Utility_Pck.write_output('6 ');

  SET_HEADER( ord_rec );
fnd_file.put_line(fnd_file.log,'CMG_LOAD_RET_PCK.MAIN: Started9');
  SET_LINE( ord_rec );

END IF;

Cmg_Utility_Pck.write_output(' Total number of RMAs => '||v_hdr_cnt);
Cmg_Utility_Pck.write_output(' ');

--/*test

IF v_hdr_cnt > 0 THEN -- call order import

  FOR x IN src_rec.FIRST..src_rec.LAST LOOP

    Hdg_Ret_Global_Pck.HDG_ORDER_IMPORT_PRC(v_retcode,
                                            v_errbuf,
                                            v_dphase,
                                            v_dstatus,
                                            GET_ORD_SOURCE(src_rec(x).source_name),
                                            v_filename,
                                            GET_THREAD_COUNT );

    Cmg_Utility_Pck.write_output(' Following Order Import Errors Occurred ');
    Cmg_Utility_Pck.write_output(' ');

    FOR intf_rec IN c_intf_status( GET_ORD_SOURCE(src_rec(x).source_name), v_request_id ) LOOP

      Cmg_Utility_Pck.write_output(' Orig Ref => '||intf_rec.orig_sys_document_ref||
         ' Error => '||intf_rec.entity_code||'-'||intf_rec.message_text);

    END LOOP;

  END LOOP;

  Cmg_Ref_Update_Pck.UPDATE_REF( errbuf, retcode );

  v_err_count := ERR_COUNT( v_request_id );

  Cmg_Utility_Pck.write_output(' Number of processed RMAs => '||(NVL(v_hdr_cnt,0) - NVL(v_err_count,0)));
  Cmg_Utility_Pck.write_output(' Number of erred     RMAs => '||v_err_count);
  Cmg_Utility_Pck.write_output('');

END IF;

--*/ --test

COMMIT;

Cmg_Utility_Pck.write_output('---------------------------------------------------');
Cmg_Utility_Pck.write_output('End of RMA Import log file');

Cmg_Utility_Pck.log_msg('CMG_LOAD_RET_PCK.MAIN: Ended',TO_CHAR(SYSDATE,'DD-MON-YYYY HH24:MI:SS'));

retcode := NVL(retcode,SQLCODE);
errbuf  := 'CMG_LOAD_RET_PCK.MAIN: Completed'||errbuf;

EXCEPTION
 WHEN OTHERS THEN
   Cmg_Utility_Pck.write_output(SQLERRM);
   retcode := SQLCODE;
   errbuf  := SUBSTR('CMG_LOAD_RET_PCK.MAIN: Error Others => '||SQLERRM,1,150);
   ROLLBACK;
END main;

END Cmg_Load_Ret_Pck;
/

No comments:

Post a Comment