ME21N增强

ME21N创建采购订单点击保存或者检查按钮时进入增强(首先根据EKKO-LIFNR、EKPO-MATNR、

EKPO-WERKS LINK自建表1中的供应商、物料和工厂取对应自建表1中“是否管控”字段值是否为N,

如果为N则不进入增强,否则进入增强,并进行以下判断:

1、根据EKKO-LIFNREKPO-MATNREKPO-WERKS LINK自建表1中的供应商+物料+工厂取出报告

到期日(如果取到多条数据,则只取报告到期日最早的那条数据做下面的校验),然后用报告到期日减去

采购订单的凭证日期(EKKO-BEDAT):
1)当报告到期日减去采购订单的凭证日期(EKKO-BEDAT)小于或等于自建表1中的“提醒PO周期(天)”

字段值,并且对应的自建表1中“是否提醒PO”字段不为N,则弹出警告消息:第XXXX行物料XXXX的

子材料XXXX报告编码XXXX还有多少天到期,回车可跳过消息并允许保存订单;
2)当报告到期日减去采购订单的凭证日期(EKKO-BEDAT)大于自建表1中的“控制PO周期(天)”字段

值,并且对应的自建表1中“是否控制PO”字段不为N,则弹出错误消息:第XXXX行物料XXXX的子材料

XXXX报告编码XXXX已超期XXXX天,不允许订单保存。

 

SE19 输入相应的增强BADI 创建相应的增强

 

 

 

IF sy-tcode 'ME21N' .
        DATAlv_data(6TYPE c.
        DATAgt_ztmm035 TYPE TABLE OF ztmm035,
              gs_ztmm035 type ztmm035.
        REFRESHitems.
        CLEAR header.
        CLEAR lv_num.
         header im_header->get_data( ).

        items im_header->get_items( ).

*        SELECT WERKS,MATNR,LIFNR,SFGK,JSRQ,TXPOZQ,TXPO,ZCLMC,KZPOZQ,KZPO
*          INTO TABLE @DATA(gt_ztmm035)
*          FROM ztmm035
*          FOR ALL ENTRIES IN @items
*          WHERE WERKS = @items-waers
*          and matnr = @items-matnr
*          and lifnr = @items-lifnr
*          and SFGK <> 'N'.

*          SORT gt_ztmm035 by WERKS matnr lifnr JSRQ.
*          DATA:gs_ztmm035 TYPE LINE OF gt_ztmm035.

        LOOP AT items INTO line_item.
        lv_num lv_num + 1.
        CLEARpo_line.
        po_line line_item-item->get_data( ).

          SELECT WERKS MATNR LIFNR SFGK JSRQ TXPOZQ TXPO ZCLMC KZPOZQ KZPO
          
INTO CORRESPONDING FIELDS OF TABLE gt_ztmm035
          
FROM ztmm035
          
WHERE WERKS po_line-WERKS
          
and matnr po_line-matnr
          
and lifnr header-lifnr
          
and SFGK <> 'N'.

           SORT gt_ztmm035 by WERKS matnr lifnr JSRQ.
*          DATA:gs_ztmm035 TYPE LINE OF gt_ztmm035.

        CLEAR lv_data.
        READ TABLE gt_ztmm035 INTO gs_ztmm035 WITH  KEY WERKS po_line-WERKS matnr po_line-matnr lifnr header-lifnr BINARY SEARCH.
        if sy-subrc 0.
           CALL FUNCTION 'FIMA_DAYS_AND_MONTHS_AND_YEARS'
            EXPORTING
              I_DATE_FROM    header-bedat
              I_DATE_TO      
gs_ztmm035-JSRQ
              I_FLG_SEPARATE 
' '       "是否单独计算 若有标识,则返回两日期相差的天数
            IMPORTING
              E_DAYS         lv_data.  "返回天数:638

           if lv_data <= gs_ztmm035-TXPOZQ AND gs_ztmm035-TXPO <> 'N'.
             MESSAGE '&& lv_num && '&& gs_ztmm035-matnr && '物料的子材料&& gs_ztmm035-ZCLMC && '还有&& lv_data && '天到期,回车可跳过消息并允许保存订单'
             TYPE 'I' DISPLAY LIKE 'W'.
           ENDIF.

           if lv_data > gs_ztmm035-KZPOZQ AND gs_ztmm035-KZPO <> 'N'.
             MESSAGE '&& lv_num && '&& gs_ztmm035-matnr && '物料的子材料&& gs_ztmm035-ZCLMC && '已超期&& lv_data && ',不允许订单保存'
             TYPE 'I' DISPLAY LIKE 'E'.
           ENDIF.

           ENDIF.
           CLEAR gs_ztmm035.




        ENDLOOP.
      ENDIF.

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值