ALVtree 显示BOM结构
INCLUDE <icon>.
cl_gui_cfw DEFINITION
LOAD .
mr_toolbar TYPE REF TO
cl_gui_toolbar .
gt_stpox TYPE stpox OCCURS
0,
gt_fieldcatalog TYPE lvc_t_fcat,
gt_item_layout TYPE
lvc_t_laci,
gs_item_layout TYPE lvc_s_laci,
okcode
LIKE sy-ucomm .
INCLUDE STRUCTURE stpox.
TYPES:
node_key TYPE lvc_nkey,
END OF gs_f.
DATA: gs_xstpox
TYPE gs_f ,
gt_xstpox TYPE gs_f OCCURS 0.
DATA:
l_custom_container TYPE REF TO cl_gui_custom_container.
wa_dstst TYPE
csdata-xfeld.
p_werks
LIKE ekpo-werks DEFAULT '1010' .
PERFORM getdata.
*&
Form
getdata
*&---------------------------------------------------------------------*
FORM
getdata.
EXPORTING
capid = 'CAD1' " p_capid
datuv =
sy-datum
mehrs = 'X' "p_mehrs
stlal = '01' "可选BOM
stlan =
'2' "BOM 用途
mtnrv = P_MATNR
werks = P_WERKS
emeng = 1
IMPORTING
topmat = wa_topmat
dstst = wa_dstst
TABLES
stb =
gt_stpox
matcat = it_matcat
EXCEPTIONS
alt_not_found = 1
call_invalid = 2
material_not_found = 3
missing_authorization = 4
no_bom_found = 5
no_plant_data = 6
no_suitable_bom_found = 7
conversion_error = 8
OTHERS = 9.
CASE sy-subrc .
WHEN 1 .
MESSAGE
e899(fi) WITH 'alt_not_found'.
WHEN 2 .
MESSAGE e899(fi) WITH
'call_invalid '.
WHEN 3 .
MESSAGE e899(fi) WITH
'material_not_found'.
WHEN 4 .
MESSAGE e899(fi) WITH
'missing_authorization'.
WHEN 5 .
MESSAGE e899(fi) WITH
'no_bom_found'.
WHEN 6 .
MESSAGE e899(fi) WITH
'no_plant_data'.
WHEN 7 .
MESSAGE e899(fi) WITH
'no_suitable_bom_found'.
WHEN 8 .
MESSAGE e899(fi) WITH
'conversion_error'.
WHEN 9 .
MESSAGE e899(fi) WITH 'OTHERS
Error'.
ENDCASE.
MOVE-CORRESPONDING gs_stpox TO
gs_xstpox .
APPEND gs_xstpox TO gt_xstpox.
ENDLOOP.
"getdata
*----------------------------------------------------------------------*
*
MODULE status_9000
OUTPUT
*----------------------------------------------------------------------*
MODULE
status_9000 OUTPUT.
SET PF-STATUS 'MAIN'.
SET TITLEBAR 'TITLE'.
IF tree1 IS INITIAL.
PERFORM init_tree.
ENDIF.
CALL METHOD
cl_gui_cfw=>flush.
ENDMODULE. " PBO_9000
OUTPUT
*----------------------------------------------------------------------*
*
MODULE user_command_9000
INPUT
*----------------------------------------------------------------------*
MODULE
user_command_9000 INPUT.
CASE okcode.
WHEN 'EXIT' OR 'BACK' OR
'CANC'.
CALL METHOD tree1->free.
LEAVE PROGRAM .
CALL METHOD cl_gui_cfw=>dispatch.
ENDCASE.
CALL METHOD
cl_gui_cfw=>flush.
ENDMODULE. " okcode INPUT
*&
Form
init_tree
*&---------------------------------------------------------------------*
FORM
init_tree .
PERFORM build_fieldcatalog.
* CREATE OBJECT
l_custom_container
* EXPORTING
* container_name =
'TREE1'
* EXCEPTIONS
* cntl_error =
1
* cntl_system_error = 2
*
create_error = 3
* lifetime_error =
4
* lifetime_dynpro_dynpro_link = 5.
* IF sy-subrc <>
0.
* MESSAGE e000 WITH '创建容器:TREE1 错误'.
* ENDIF.
*
ENDIF.
EXPORTING
*
parent = l_custom_container
parent = cl_gui_container=>screen0
node_selection_mode =
cl_gui_column_tree=>node_sel_mode_single
item_selection
= 'X'
no_html_header = 'X'
no_toolbar = ' '
EXCEPTIONS
cntl_error = 1
cntl_system_error =
2
create_error = 3
lifetime_error
= 4
illegal_node_selection_mode = 5
failed = 6
illegal_column_name = 7.
IF sy-subrc <> 0.
MESSAGE e000 WITH '创建TREE错误'.
ENDIF.
PERFORM
build_hierarchy_header CHANGING l_hierarchy_header.
ls_variant-report =
sy-repid.
EXPORTING
is_hierarchy_header = l_hierarchy_header
i_background_id = 'ALV_BACKGROUND'
i_save =
'A'
is_variant = ls_variant
CHANGING
it_outtab = gt_stpox "table must be emty !!
it_fieldcatalog = gt_fieldcatalog.
lvc_nkey ,
l5 TYPE lvc_nkey ,l6 TYPE lvc_nkey ,l7 TYPE lvc_nkey ,l8
TYPE lvc_nkey ,
l_key TYPE lvc_nkey,
l_last_key TYPE
lvc_nkey ,
added .
LOOP AT gt_xstpox INTO gs_xstpox .
WHEN '1'.
l_key =
''.
WHEN '2'.
l_key = l1.
WHEN '3'.
l_key = l2.
WHEN '4'.
l_key = l3.
WHEN
'5'.
l_key = l4.
WHEN '6'.
l_key = l5.
ENDCASE.
l_key
CHANGING l_last_key.
gs_xstpox-node_key = l_last_key.
WHEN '1'.
l1 =
l_last_key.
WHEN '2'.
l2 = l_last_key.
WHEN
'3'.
l3 = l_last_key.
WHEN '4'.
l4 =
l_last_key.
WHEN '5'.
l5 = l_last_key.
WHEN
'6'.
l6 = l_last_key.
ENDCASE.
ENDLOOP.
CALL METHOD
tree1->frontend_update.
ENDFORM. " init_tree
*&
Form
build_fieldcatalog
*&---------------------------------------------------------------------*
FORM
build_fieldcatalog.
CALL FUNCTION 'LVC_FIELDCATALOG_MERGE'
EXPORTING
i_structure_name = 'STPOX'
CHANGING
ct_fieldcat = gt_fieldcatalog.
LOOP AT gt_fieldcatalog INTO
ls_fieldcatalog.
* CASE ls_fieldcatalog-fieldname.
* WHEN 'CARRID'
OR 'CONNID' OR 'FLDATE'.
* ls_fieldcatalog-no_out = 'X'.
*
ls_fieldcatalog-key = ''.
* WHEN 'PRICE' OR 'SEATSOCC' OR 'SEATSMAX'
OR 'PAYMENTSUM'.
** ls_fieldcatalog-do_sum = 'X'.
* WHEN
'PLANETYPE'.
* ls_fieldcatalog-edit = 'X'.
*
ls_fieldcatalog-style = cl_gui_alv_grid=>mc_style_enabled .
*
ENDCASE.
MODIFY gt_fieldcatalog FROM ls_fieldcatalog.
ENDLOOP.
ENDFORM. " build_fieldcatalog
*&
Form
build_hierarchy_header
*&---------------------------------------------------------------------*
FORM
build_hierarchy_header CHANGING
p_hierarchy_header TYPE treev_hhdr.
*
p_hierarchy_header-heading =
'BOM层次'.
p_hierarchy_header-tooltip = 'ToolTip'.
p_hierarchy_header-width = 30.
p_hierarchy_header-width_pix =
''.
*
ENDFORM. "
build_hierarchy_header
*&
Form
add_complete_line
*&---------------------------------------------------------------------*
FORM
add_complete_line USING ps_stpox TYPE stpox
p_relat_key TYPE lvc_nkey
CHANGING p_node_key TYPE
lvc_nkey.
DATA: l_node_text TYPE lvc_value.
* set item-layout
DATA:
lt_item_layout TYPE lvc_t_layi,
ls_item_layout TYPE lvc_s_layi.
DATA: stufe_num(2) TYPE n.
ls_item_layout-class = cl_gui_column_tree=>item_class_text.
*
ls_item_layout-editable = 'X'.
* ls_item_layout-chosen = 'X'. "
设置为选中状态
stufe_num = ps_stpox-stufe.
CONCATENATE stufe_num ',' ps_stpox-ojtxp INTO l_node_text.
EXPORTING
i_relat_node_key
= p_relat_key
i_relationship =
cl_gui_column_tree=>relat_last_child
is_outtab_line =
ps_stpox
i_node_text = l_node_text
it_item_layout =
lt_item_layout
IMPORTING
e_new_node_key =
p_node_key.
ENDFORM. " add_complete_line
ALVtree 显示BOM结构的更多相关文章
- ABAP DEMO ALVtree显示BOM层级
展示效果: *&---------------------------------------------------------------------* *& Report YCX ...
- 按树型显示BOM的结构
在制造企业中,生产的每一个产品都由一道或多道工序组成,在组成成品之前,每一道工序经由物料--物料组成半成品,或物料--半成品组成新的半成品,亦或由半成品--半成品组成新的半成品.复杂的成品经由多道工序 ...
- 【转】linux tree命令以树形结构显示文件目录结构 ---- 不错
原文网址:http://jingyan.baidu.com/article/acf728fd19c7eff8e510a3eb.html 今天小编来给分享Linux 系统下一个非常有用的命令的使用:tr ...
- 不显示BOM清单的版本
应用 Oracle Bill Of Materiel 层 Level Function 函数名 Funcgtion Name BOM_BOMFDBOM 表单名 Form Name BOMFDBOM ...
- 配置Tomcat直接显示目录结构和文件列表
Tomcat是直接显示目录结构和文件列表,只是在配置里面给关闭了. 关键在这里:\conf\web.xml 这个文件有一段配置直接控制Tomcat是允许显示目录结构和文件列表. <servlet ...
- 【IntelliJ IDEA】idea导入项目只显示项目中的文件,不显示项目结构
导入项目之后,只显示项目文件,不显示项目结构 解决方法 1.点击file->project structure..->Modules 点击右上角+加号 ->import Module ...
- Winform中实现向窗体中拖放照片并显示以及拖放文件夹显示树形结构(附代码下载)
场景 向窗体中拖拽照片并显示效果 向窗体中拖拽文件夹并显示树形结构效果 注: 博客主页: https://blog.csdn.net/badao_liumang_qizhi 关注公众号 霸道的程序猿 ...
- InteractiveHtmlBom 在手机上无法显示 BOM List 和装配图的问题
InteractiveHtmlBom 在手机上无法显示 BOM List 和装配图的问题 InteractiveHtmlBom 插件是一款用于 KiCad BOM 装配图生成插件. 最近新生成的 文件 ...
- 如何使用Shell写一个显示目录结构的命令?
公众号关注 「开源Linux」 回复「学习」,有我为您特别筛选的学习资料~ 在Linux中使用Shell写一个显示目录结构的命令,快速寻找目录结构. 1.代码 #!/usr/bin/env bash ...
随机推荐
- 【Luogu】P1131时态同步(树形DP)
题目链接 甚矣吾衰也!这么简单的DP我都不会了 太恐怖了 树形DP,从子树里选出时间最长的来,剩下的调到这个最长时间即可. #include<cstdio> #include<cct ...
- POJ 3468 线段树 成段更新 懒惰标记
A Simple Problem with Integers Time Limit:5000MS Memory Limit:131072K Case Time Limit:2000MS Descr ...
- Snoop resynchronization mechanism to preserve read ordering
A processor employing a post-cache (LS2) buffer. Loads are stored into the LS2buffer after probing t ...
- 三国武将查询系统 //Java 访问 数据库
import java.awt.*; import javax.swing.*; import java.awt.event.ActionListener; import java.awt.event ...
- 关于 最短路条数 和 边不可重复最短路条数问题 /hdu3599(边不可重复最短路)
原先一直在做一道省赛题,由于题意错误理解成球最短路条数,误打误撞敲了最短路条数,又发现hdu3599(多校)求边不可重复最短路条数.下面说说俩种问题解法: 最短路条数: 求一个图一共一几条最短路径,思 ...
- linux find grep 查找命令
原文:fhqdddddd.blog.163.com/blog/static/186991542012417105729415/ find 1.作用 find命令的作用是在目录中搜索文件,它的使用权限是 ...
- [转] java中volatile关键字的含义
在java线程并发处理中,有一个关键字volatile的使用目前存在很大的混淆,以为使用这个关键字,在进行多线程并发处理的时候就可以万事大吉. Java语言是支持多线程的,为了解决线程并发的问题,在语 ...
- 开源天气预报api整理
高德天气:https://lbs.amap.com/api/webservice/guide/api/weatherinfo/? github上对开源api的整理:https://github.com ...
- PythonCookbook读书笔记
第一章 数据结构和算法 1.1 将序列分解为单独的变量 适用于元组.列表.字符串等.只要是可迭代的对象,都可以执行分解操作.唯一的要求是变量的总数和结构要与序列相同. 1.2 从任意长度的可迭代对象中 ...
- Mysql导出导入相关操作记录
一.使用source source sql脚本文件路径 二.使用mysqldump 命令行下具体用法如下: mysqldump -u用户名 -p密码 -d 数据库名 表名 脚本名; 1.导出数据库為 ...