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 ...
随机推荐
- 【霍夫曼树】poj 1339 poker card game (数组排序+辅助队列的方法,预处理O(nlogn),构造霍夫曼树O(n))
poj.org/problem?id=1339 #include<iostream> #include<cstdio> #include<string> #incl ...
- java之线程池面试题
面试官:线程池有哪些?分别的作用是什么? 常用的线程池有: newSingleThreadExecutor newFixedThreadExecutor newCacheThreadExecutor ...
- “a++” 与 “++a” 的区别
很久不写 C++ 程序,今天测试一段代码的过程中,发现自己连最基础的 C++ 知识都忘了,汗!!! a++ 与 ++a 都是表达式,他们都有值.其中: 1)a++ 的值是 a 的原始值,这个表达式的功 ...
- hdu1671 Phone List [字典树 hash]
传送门 Phone List Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- linux 内核源码arch/ 目录的前世今生
历史的痕迹:在最新的linux-2.6.31/arch/arm/文件夹下,仍然保留Linux最初向ARM处理器移植的痕迹,最初的移植由黑客完成,在老的移植的代码文件的头部保留着黑客的名字:最初的ARM ...
- MongoDB数据关系的表达
虽说MongoDB是非关系型数据库,但由于大部分情况下数据之间是存在关系的,所以MongoDB也需要一些方式来表达数据之间的关系.MongoDB表达数据关系的方式有两种:文档嵌套和数据库引用. 一.文 ...
- ORA-01033: ORACLE initialization or shutdown in progress问题
这是Oracle12c中笔者遇到的一个错误提示:ORA-01033: ORACLE initialization or shutdown in progress 错误的中文意思是:Oracle初始化未 ...
- 【WEB基础】HTML & CSS 基础入门(5)边框与背景
前面(HTML图片) 漂亮的网页肯定少不了边框与背景的修饰,本篇笔记就是说明如何为网页上的元素设置边框或者背景(背景颜色和背景图片). 之前,先了解一下HTML中的图片元素,因为图片标签的使用非常简单 ...
- iOS 内存管理实践
内存管理实践 尽管基本的概念在内存管理策略文章中简单得阐述了,但是还有一些实用的步骤让你更容易管理内存:有助于确保你的程序最大限度地减少资源需求的同时,保持可靠和强大. 使用“访问器方法”让内存管理更 ...
- python内存泄露诊断过程记录pyrasite
工具:pyrasite;包含三个命令行 pyrasite / pyrasite-shell / pyrasite-memory-viewer 安装:gdb meliae urwid 说明:Pyrasi ...