nc65单据穿透

2023-10-28 08:20
文章标签 穿透 单据 nc65

本文主要是介绍nc65单据穿透,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

nc65单据穿透

jych项目

1.支出合同台账合同号字段可以穿透到对应的单据上

一个合同号穿透到一个物质设备采购合同上

1.支出合同台账单据模板合同号字段卡片下和列表下高级属性勾选是否超链接
在这里插入图片描述

2.支出合同台账中增加监听类
HeadItemLinkListener.java

package nc.ui.jych.zchttz.ace.view;import nc.desktop.ui.WorkbenchEnvironment;
import nc.funcnode.ui.FuncletInitData;
import nc.funcnode.ui.FuncletWindowLauncher;
import nc.ui.pub.bill.BillItemHyperlinkEvent;
import nc.ui.pub.bill.BillItemHyperlinkListener;
import nc.vo.jych.paymentorder.AggPaymentOrderVO;
import nc.vo.jych.utils.PenetrateQuery;
import nc.vo.jych.wzsbcght.AggWzsbcghtVO;
import nc.vo.jych.zchttz.ZchttzVO;
import nc.vo.pub.BusinessException;
import nc.vo.pubapp.pattern.exception.ExceptionUtils;
import nc.vo.sm.funcreg.FuncRegisterVO;
import nc.vo.zkch.utils.NullValueUtils;public class HeadItemLinkListener implements BillItemHyperlinkListener{public ListView list;@Overridepublic void hyperlink(BillItemHyperlinkEvent event) {//获取超链接的字段String key = NullValueUtils.getNullStringValue(event.getItem().getKey());//获取行号int row  = event.getRow();//获取到这一行对应的 ZchttzVO vo = (ZchttzVO) getList().getBillCardPanel().getBillModel().getBodyValueRowVOByVisualValue(row, ZchttzVO.class.getName());String htbh = vo.getHtbh();try {FuncletInitData data = new FuncletInitData();data.setInitType(100);FuncRegisterVO funvo = null;if (key.equals("nyfkmny")) {AggPaymentOrderVO[] queryData = PenetrateQuery.getInstances().getZchttzPaymentData(htbh);data.setInitData(queryData);funvo = WorkbenchEnvironment.getInstance().getFuncRegisterVO("H7H1H136");} else if(key.equals("htbh")){//add by hanhAggWzsbcghtVO[] queryData = PenetrateQuery.getInstances().getQueryWzsbcghtVOByHt(htbh);data.setInitData(queryData);funvo = WorkbenchEnvironment.getInstance().getFuncRegisterVO("H7H1H162");}//需要进入节点FuncletWindowLauncher.openFuncNodeInTabbedPane(getList().getBillCardPanel(), funvo, data, null, true);} catch (BusinessException e) {// TODO 自动生成的 catch 块ExceptionUtils.wrappBusinessException(e.getMessage());}}public ListView getList() {return list;}public void setList(ListView list) {this.list = list;}}

3.给监听类注入到对应字段
ListView.java

package nc.ui.jych.zchttz.ace.view;public class ListView extends nc.ui.pubapp.uif2app.view.ShowUpableBatchBillTable{private static final long serialVersionUID = 1L;@Overridepublic void initUI() {super.initUI();		getBillCardPanel().setTatolRowShow(true);HeadItemLinkListener listener = new HeadItemLinkListener();listener.setList(this);getBillCardPanel().getBodyItem("nyfkmny").addBillItemHyperlinkListener(listener);getBillCardPanel().getBodyItem("htbh").addBillItemHyperlinkListener(listener);}}

4.在public端的工具类util包下的PenetrateQuery.java类中增加根据合同编号查询物质设备采购合同的方法

	/*** 根据合同编号查询物质设备采购合同对应的物质设备采购合同登记* add by hanh*/public AggWzsbcghtVO[] getQueryWzsbcghtVOByHt(String htbh) throws BusinessException {// TODO 自动生成的方法存根SqlBuilder sql = new SqlBuilder();sql.append(" select pk_wzsbcght ");sql.append(" from jych_wzsbcght ");sql.append(" where nvl(dr, 0) = 0	");sql.append(" and htbh = '"+htbh+"'");List<String> list = (List<String>) getBs().executeQuery(sql.toString(), new ColumnListProcessor());if (list != null  && list.size() >0) {AbstractBill[] bills = getQueryService().queryAbstractBillsByPks(AggWzsbcghtVO.class, list.toArray(new String[0]));List<AggWzsbcghtVO> aggvolist = new ArrayList<AggWzsbcghtVO>();for (AbstractBill bill : bills) {AggWzsbcghtVO aggvo = (AggWzsbcghtVO) bill;aggvolist.add(aggvo);}return aggvolist.toArray(new AggWzsbcghtVO[0]);}return null;}

5.在要穿透的物质设备采购合同单据中增加监听类
WzsbcghtListener.java

package nc.ui.jych.wzsbcght.ace.listener;import nc.funcnode.ui.FuncletInitData;
import nc.vo.jych.wzsbcght.AggWzsbcghtVO;public class WzsbcghtListener extends nc.ui.pubapp.uif2app.model.DefaultFuncNodeInitDataListener {@Overridepublic void initData(FuncletInitData data) {// TODO 自动生成的方法存根if (data != null && data.getInitType() == 100) {AggWzsbcghtVO[] aggvos =  (AggWzsbcghtVO[])data.getInitData();getModel().initModel(aggvos);} else {super.initData(data);}}
}

6.在要穿透的物质设备采购合同单据的xml中注入新增加的监听类

	<!-- 打开节点监听 newadd--><bean id="InitDataListener" class="nc.ui.jych.wzsbcght.ace.listener.WzsbcghtListener"><property name="model" ref="bmModel"/><property name="context" ref="context"></property><property name="voClassName" value="nc.vo.jych.wzsbcght.AggWzsbcghtVO"/></bean>

2.销售合同台账合同号字段可以穿透到对应的单据上

一个合同号穿透到一个销售合同登记上(但考虑到这张单子有被金额穿透的情况,这种情况下点击该金额会有多个单子穿透到销售合同登记上,所以要和被按钮穿透的情况公用一个监听类,查到的数据就得用List去接收)

1.HeadItemlinkListener.java

package nc.ui.jych.xshttz.view;import java.util.ArrayList;
import java.util.List;import nc.bs.framework.common.NCLocator;
import nc.desktop.ui.WorkbenchEnvironment;
import nc.funcnode.ui.FuncletInitData;
import nc.funcnode.ui.FuncletWindowLauncher;
import nc.itf.jych.IXshttzMaintain;
import nc.ui.pub.bill.BillItemHyperlinkEvent;
import nc.ui.pub.bill.BillItemHyperlinkListener;
import nc.vo.jych.kpsq.AggKpsqVO;
import nc.vo.jych.receiptvoucher.AggReceiptVoucherVO;
import nc.vo.jych.utils.PenetrateQuery;
import nc.vo.jych.xshtdj.AggXshtdjVO;
import nc.vo.jych.xshttz.XshttzVO;
import nc.vo.pub.BusinessException;
import nc.vo.pubapp.pattern.exception.ExceptionUtils;
import nc.vo.sm.funcreg.FuncRegisterVO;
import nc.vo.zkch.utils.NullValueUtils;/*** 字段超链接监听* @author zhangjk* @ddate 20023-09-11*/
public class HeadItemlinkListener implements BillItemHyperlinkListener{public ListView list;@Overridepublic void hyperlink(BillItemHyperlinkEvent event) {//获取超链接的字段String key = NullValueUtils.getNullStringValue(event.getItem().getKey());//获取行号int row  = event.getRow();//获取到这一行对应的 XshttzVO vo = (XshttzVO) getList().getBillCardPanel().getBillModel().getBodyValueRowVOByVisualValue(row, XshttzVO.class.getName());String pk_xshtdj = vo.getPk_xshtdj();String htbh = vo.getHtbh();try {FuncletInitData data = new FuncletInitData();data.setInitType(100);FuncRegisterVO funvo = null;if (key.equals("ykpje")) {AggKpsqVO[] queryData = PenetrateQuery.getInstances().getQueryKpsqVOByHt(pk_xshtdj);data.setInitData(queryData);funvo = WorkbenchEnvironment.getInstance().getFuncRegisterVO("H7H1H181");} else if (key.equals("yskje")) {AggReceiptVoucherVO[] queryData = PenetrateQuery.getInstances().getQueryReceiptByHt(pk_xshtdj);data.setInitData(queryData);funvo = WorkbenchEnvironment.getInstance().getFuncRegisterVO("H7H1H135");} else if(key.equals("htbh")){//add by hanhAggXshtdjVO[] queryData = PenetrateQuery.getInstances().getQueryXshtdjVOByHt(htbh);List<AggXshtdjVO> list = new ArrayList<AggXshtdjVO>();list.add(queryData[0]);data.setInitData(list);funvo = WorkbenchEnvironment.getInstance().getFuncRegisterVO("H7H1H168");}//需要进入节点FuncletWindowLauncher.openFuncNodeInTabbedPane(getList().getBillCardPanel(), funvo, data, null, true);} catch (BusinessException e) {ExceptionUtils.wrappBusinessException(e.getMessage());}}public ListView getList() {return list;}public void setList(ListView list) {this.list = list;}private IXshttzMaintain service;private IXshttzMaintain getService(){if(service == null){service = NCLocator.getInstance().lookup(IXshttzMaintain.class);}return service;}}

2.XshtdjListener.java

package nc.ui.jych.xshtdj.ace.listener;import java.util.List;import nc.funcnode.ui.FuncletInitData;
import nc.vo.jych.xshtdj.AggXshtdjVO;public class XshtdjListener extends nc.ui.pubapp.uif2app.model.DefaultFuncNodeInitDataListener {@Overridepublic void initData(FuncletInitData data) {// TODO 自动生成的方法存根if (data != null && data.getInitType() == 100) {List<AggXshtdjVO> aggvolist =  (List<AggXshtdjVO>)data.getInitData();getModel().initModel(aggvolist.toArray(new AggXshtdjVO[0]));} else {super.initData(data);}}
}

这篇关于nc65单据穿透的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291918

相关文章

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

防止缓存击穿、缓存穿透和缓存雪崩

使用Redis缓存防止缓存击穿、缓存穿透和缓存雪崩 在高并发系统中,缓存击穿、缓存穿透和缓存雪崩是三种常见的缓存问题。本文将介绍如何使用Redis、分布式锁和布隆过滤器有效解决这些问题,并且会通过Java代码详细说明实现的思路和原因。 1. 背景 缓存穿透:指的是大量请求缓存中不存在且数据库中也不存在的数据,导致大量请求直接打到数据库上,形成数据库压力。 缓存击穿:指的是某个热点数据在

使用lanproxy进行内网穿透

https://github.com/ffay/lanproxy https://www.jianshu.com/p/6482ac354d34

redis缓存预热、缓存穿透的详细教程

前言     作此篇主要在于关于redis的缓存预热、缓存雪崩、缓存击穿和缓存穿透在面试中经常遇到,工作中也是经常遇到。中级程序员基本上不可避免要克服的几个问题,希望一次性解释清楚 缓存预热 MySQL加入新增100条记录,一般默认以MySQL为准为底单数据,如何同步给redis(布隆过滤器) 这是100合法数据,mysql有100条新纪录,但是redis无。     为什么需要预热

ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名

前言 当我们需要把本地开发的应用展示给外部用户时,常常会因为无法直接访问而陷入困境。 就为了展示一下,买服务、域名,搭环境,费钱又费事。 那有没有办法,让客户直接访问自己本机开发的应用呢? 这种需求场景这么多,当然有现成的技术 —— 内网穿透。 什么是内网穿透? 内网穿透是一种网络技术,它允许外部互联网用户访问部署在本地网络(内网)中的服务或设备。 通常,家庭或企业网络都位于内网,连

Redis 缓存深度解析:穿透、击穿、雪崩与预热的全面解读

Redis 缓存深度解析:穿透、击穿、雪崩与预热的全面解读 一 . 什么是缓存 ?二 . 使用 Redis 作为缓存三 . 缓存的更新策略3.1 定期生成3.2 实时生成 四 . 缓存预热、缓存穿透、缓存雪崩、缓存击穿4.1 缓存预热4.2 缓存穿透4.3 缓存雪崩4.4 缓存击穿 Hello , 大家好 , 这个专栏给大家带来的是 Redis 系列 ! 本篇文章给大家讲解的是

使用Python本地搭建http.server文件共享服务并实现公网环境远程访问——“cpolar内网穿透”

前言 本文主要介绍如何在Windows系统电脑上使用python这样的简单程序语言,在自己的电脑上搭建一个共享文件服务器,并通过cpolar创建的公网地址,打造一个可以随时随地远程访问的私人云盘。 数据共享作为和连接作为互联网的基础应用,不仅在商业和办公场景有广泛的应用,对于个人用户也有很强的实用意义。也正因如此,大量数据共享软件被开发出来,云存储的概念也被重复炒作。对于爱好折腾的笔者来说,用

Windows电脑本地安装HFS文件共享服务结合内网穿透搭建低成本NAS

文章目录 前言1.软件下载安装1.1 设置HFS访客1.2 虚拟文件系统 2. 使用cpolar建立一条内网穿透数据隧道2.1 保留隧道2.2 隧道名称2.3 创建二级子域名访问本地hfs 总结 前言 本文主要介绍如何在Windows系统电脑使用HFS并结合cpolar内网穿透工具搭建低成本NAS,并实现使用公网地址远程访问管理本地局域网电脑存储的文件。 云存储作为一个新概念

内网穿透的应用-本地化部署Elasticsearch平替工具OpenObserve并实现无公网IP远程分析数据

文章目录 前言1. 安装Docker2. Docker镜像源添加方法3. 创建并启动OpenObserve容器4. 本地访问测试5. 公网访问本地部署的OpenObserve5.1 内网穿透工具安装5.2 创建公网地址 6. 配置固定公网地址 前言 本文主要介绍如何在Linux系统使用Docker快速本地化部署OpenObserve云原生可观测平台,并结合cpolar内网穿透工

NAT与NAT穿透

5. NAT穿透 5.1 转发      最可靠但又是最低效的点对点通信方法,莫过于将p2p网络通信看作一个C/S结构,通过服务器来转发信息.如下图,两个客户端A和B,均与服务器S初始化了一个TCP或UDP连接,服务器S具有公网固定IP地址,两个客户端分布在不同的私网中,这样,他们各自的NAT代理服务器将不允许他们进行直连.