Form 个性化-调用自定义程序库(实现:提交请求,自动输出请求结果)

本文介绍了如何在Oracle E-Business Suite(EBS)中通过Form个性化调用自定义程序库CUSTOM.pll来满足特定需求。详细步骤包括下载CUSTOM.pll,编辑并添加自定义代码,上传并编译,以及设置个性化菜单。这种方法在不允许修改标准Form时提供了一种灵活解决方案,但也存在版本控制和潜在影响其他Form的缺点。
摘要由CSDN通过智能技术生成

需求:PO发放界面,原有的菜单【查看文档】,标准输出的报表及数据源XML无法明细到Distribution。

解决思路:客制明细报表,并挂请求,PO发放界面,利用个性化,新增一个菜单项【查看文档-客制】,该菜单项来执行请求并将请求结果自动呈现给用户。

  Form 个性化中,内置的Action提供一种名为:“调用自定义程序库”,其实就是CUSTOM.pll,这个文件。

 当项目中不允许需改标准Form,且利用个性化又无法达到需求目的的时候,CUSTOM.pll,就是个很好的帮手。灵活性很大,但是也有缺点。缺点后面再说。


1.下载CUSTOM.pll文件。

用FTP工具,切换到路径$AU_TOP/resource/目录下,并下载CUSTOM.pll.

2.编辑CUSTOM.pll,新增自己的CODE。

用Form Builder打开CUSTOM.pll文件

此处需要注意的是,CUSTOM.pll其实就是一个package,Event就是自定义程序库的入口程序,其Event_Name的参数就是,个性化的中设置的变元。

建议呢!每个自定义代码都加上加上作者的注释,包括作者、用途、及时间。


此次新增的代码为:

Procedure Run_Blanket_Release_Pdf Is
    v_Po_Header_Id      Number(30) := Name_In('PO_RELEASES.PO_HEADER_ID');
    v_Release_Id        Number(30) := Name_In('PO_RELEASES.PO_RELEASE_ID');
    v_Org_Id            Number(30) := Name_In('PO_RELEASES.ORG_ID');
    l_Request_Id        Number;
    l_Bl_Result         Boolean;
    v_Layout            Boolean;
    x_Phase             Varchar2(100);
    x_Status            Varchar2(100);
    x_Dev_Phase         Varchar2(100);
    x_Dev_Status        Varchar2(100);
    x_Message           Varchar2(100);
    v_Template          Varchar2(100);
    v_Organization_Code Varchar2(10);
  Begin
    If v_Org_Id Is Not Null Then
      Begin
        Select Organization_Code
          Into v_Organization_Code
          From Org_Organization_Definitions t
         Where t.Operating_Unit = v_Org_Id;
      Exception
        When Others Then
          Fnd_Message.Set_String('异常错误,报表输出失败!');
          Fnd_Message.Error;
          Return;
      End;
    End If;

    If v_Organization_Code = 'SZ' Then
      v_Template := 'CUXPOR046_BLK_REL_SZ';
    Else
      v_Template := 'CUXPOR046_BLK_REL_TS';
    End If;
  
    v_Layout := Fnd_Request.Add_Layout('PO'
                                      ,v_Template
                                      ,Null
                                      ,Null
                                      ,'PDF
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值