NC65二开经验总结

发布时间 2023-12-26 10:10:42作者: Kwoky

公式相关

1.显示公式没执行

列表界面显示,卡片界面不显示:
Handler的onBoCard执行:

getBillCardPanel().execHeadLoadFormulas();

Controller的isLoadCardFormula返回true
另外,字段录入长度不够时,列表显示,卡片不显示

2.带出数据执行公式

表头显示公式,执行

getBillCardPanel().execHeadLoadFormulas();

表体显示公式,执行

getBillCardPanel().getBillModel().execLoadFormula();

补充:上面是最简单的方法,其它自己测试。比如,指定表体行执行公式:

// 下面的方法必须设置编辑公式 –- 用for循环效果等于上面的方法
getBillCardPanel().execBodyFormula(i, "pk_supdoc");

UI

1.列表界面设置可多选

public ClientUI(){
  super();
  getBillListPanel().setMultiSelect(true);
}

2.查询条件

UIDialog dlg = getQueryUI();
if(dlg.showModal() != 1) return;
INormalQuery query = (INormalQuery)dlg;
String sql = query.getWhereSql();

3.隐藏表体字段

BillData bs = getBillCardPanel().getBillData();
BillItem[] items = bs.getBillModel().getBodyItems();
for (int i = 0; i < items.length; i++) {
    items[i].setShow(false);
}
getBillCardPanel().setBillData(bs); // 必须有这一行

4.隐藏表头字段

// 方法一
billCardPanel.getHeadItem("hzdy42").getComponent().setVisible(false);
billCardPanel.getHeadItem("hzdy42").getCaptionLabel().setText("");

// 方法二
billCardPanel.hideHeadItem(new String[]	{"hzdy38","hzdy39","hzdy40","hzdy41","hzdy42"});

5.将AggVO显示到单据界面上

billCardPanel.setBillValueVO(aggvo);

系统变量相关

1.单据号

前置任务:配置单据号规则
创建单据号:

new HYPubBO().getBillNo(单据类型, 组织, null, null);

或者:

getVbillCode(单据类型,组织);
new BillcodeGenerater ().getBillCode (单据类型, 组织,null,null);

或者

// 调用系统编码规则生成单据号
IBillcodeManage iBillcodeManage = (IBillcodeManage) NCLocator.getInstance().lookup(IBillcodeManage.class.getName());
String billNo = iBillcodeManage.getBillCode_RequiresNew("YX72", "集团主键", "组织主键", new BXHeaderVO());

2.主键

KeyGenerator.getInstance().getKey(20);

3.获取nchome路径

RuntimeEnv.getInstance().getNCHome();

4.系统变量

InvocationInfoProxy
WorkbenchEnvironment
ClientEnvironment

5.设置客户端背景色

F:\NC63\AceHome\ierp\sf\themeconf.xml

模块相关

1.添加模块

META-INF里面必须有module.xml,Sysconfig下才能找到该模块

2.单据类型没有定义所属模块

产生这个异常的原因是:单据类型没在添加在项目模块里,而是在自己的模块里,在单据类型表里:bd_billtype,把单据的systemcode改为项目模块即可

单据动作相关

1.动作注册

从pub_billaction表里复制其它单据的动作,修改单据类型、ID即可

2.动作代码路径

modules -> 单据类型所在模块 -> META-INF -> var -> source

3.按钮显示

只显示isEnabled()==true的按钮:

int[] btnAry = ((LController) getUIManageController()).getCardButtonAry();

for (int i = 0; i < btnAry.length; i++) {
    getBillUI().getButtonManager().getButton(btnAry[i]).setVisible(getBillUI().getButtonManager().getButton(btnAry[i]).isEnabled());
}

单据模版相关

1.下拉字段

数据库里保存的是 0、1、2、3.。。。所以vo里对应Integer

getBillCardWrapper().initHeadComboBox("vname", new String[]{"A","B","C"}, true);

2.日期型字段

单据模板是日期型时,vo要为UFDate

3.日期型默认取值

4.查询所有的默认查询条件

5.调用模板

数据库操作相关

1. HYPubBO_Client

findColValue方法只能查询字符型字段(因为这个方法内嵌了String强转)

2.JdbcSession

JdbcSession session = null;
session = PersistenceManager.getInstance().getJdbcSession();
session = JdbcSessionUtil.createJdbcSession();

密码相关

1.root密码修改

补丁相关

1.如何打补丁

在modules里找到相应的模块,将public、private、client下的代码导出的jar包放到模块的lib文件夹下,开发工具重新加载下即可(怎么重新加载?--重启,再重启,直到开发工具能加载到刚导入的jar包里的类)

运行相关

1.启动中间件报错

2.startup.bat启动服务卡着不动

元数据相关

1.单据日期

配置文件相关

1.配置文件变量名写错

节点相关

1.打开其它节点

直接点开指定的节点,没有数据:SFClientUtil.openFrame("ZZ0102"); // 下面的还没测试

参照相关

1.表头参照多选取值

((UIRefPane) billCardPanel.getHeadItem("hzdy41").getComponent()).getRefModel().getPkValues();

2.动态指定参照类

((UIRefPane)(getBillCardPanelWrapper().getBillCardPanel().getHeadItem("段").getComponent())).setRefModel(参照类.class);

3.设置参照是否支持多选

((UIRefPane)editor.getBillCardPanel().getHeadItem("vpsn").getComponent()).setMultiSelectedEnabled(true);

4. 设置参照只显示一级

5.参照字段实现手输

6.如何知道一个字段的参照类型:

Object obj = ((UIRefPane)getBillCardPanel().getHeadItem("").getComponent()).getRefModel();
Syttem.out.println(obj);

下拉相关

1. 下拉去掉空白选项

预警

1.配置

其它

1.命名规则

2.表空间的概念

3.获取用户有权限的组织

实用方法

1.获取表体所有页签名

getBillCardPanel().getBillData().getBodyTableCodes();

2.获取表体指定行的vo

getBillModel("页签名").getBodyValueRowVO(rownum, className);

3.单据状态栏打印消息

ShowStatusBarMsgUtil.showStatusBarMsg

4.获取ts

CurTime.getCurrentTimeStampString();

5.创建主键

//  uuid生成工具
SequenceGenerator uidUtils = new SequenceGenerator();
uidUtils.generate();

6. 保留小数点后2位,并“四舍五入”

new UFDouble().setScale(2, UFDouble.ROUND_HALF_UP);

7. 处理按钮控制是否可用

在新建按钮组中添加如下方法

/***
* 重写控制是否可用
* @Kwoky
*/
@Override
protected boolean isActionEnable() {
   if ((getModel().getSelectedOperaDatas() == null) || (getModel().getSelectedOperaDatas().length == 0)) {
      return false;
   }
   return true;
}

重点在setModel中时一定要添加

model.addAppEventListener(this);

public void setModel(PsndocMdmModel model) {
    this.model = model;
    model.addAppEventListener(this);
}

8. ComBox设置方式以及常用方法

nc.ui.uif2.components.CommonConfirmDialogUtils --- 处理弹框显示
showConfirmDeleteDialog()

MessageDialog.showErrorDlg(this.getBillForm(), "警告", "请先选择发货仓库再进行替代品选择!!");

// 编辑自己得弹框信息
// 可以在工程目录的resources下面lang.simpchn.ht100101包下的配置文件自行配置
// 注意点编辑完该文件后需要执行转码操作(UTF-16)
String TITLE = ResHelper.getString("ht100101", "ht100101006");
String QUESTION = ResHelper.getString("ht100101", "ht100101006");
int msg = MessageDialog.showYesNoDlg(getParent(), TITLE, QUESTION, 8);
String stryear  = comyear.getSelectedItem().toString();
// 定义ComBox类型
comyear =  new UIComboBox();
// 组装ComBox显示
comyear.addItem("执行ComBox显示的内容 --- 可以参考上面方法写到配置文件中");

9.逻辑更新页面字段值

// 第一种方式只适合当前鼠标选定的行
getEditor().getBillCardPanel().setHeadItem("state", state);
// 第二种方式
// 只刷新鼠标点击的那个行画面
"不同的地方在于调用的方法"
this.model.directlyUpdate(this.getModel().getSelectedData());
// 更新选择的多行画面
this.model.directlyUpdate(this.getModel().getSelectedOperaDatas());

10.物理刷新页面字段值

// 在需要刷新的画面的XML中配置属性
<property name="dataManager"><ref bean="bmModelModelDataManager"/>	</property>
//在按钮中定义字段获取get/set方法
private (bmModelModelDataManager -- 对应的class类) dataManager

// 在按钮方法中调用刷新方法
getDataManagers().refresh();

11.按钮方法重写

afterDoActionFailed //方法意思:按钮执行失败后执行
afterDoActionSuccessed //方法意思:按钮执行成功后执行
beforeDoAction //方法意思:按钮执行前执行

12.元数据升级操作

// 以本地账号为例
// 需要使用管理员账号lz登陆
// 登陆后搜索 -- 元数据管理
// 即可进行升级操作

13.NC65加减乘除计算函数

ufDouble.add(1.0);//加1
ufDouble.sub(1.0);//减1
ufDouble.multiply(1.0);//乘
ufDouble.div(1.0);//除

13.NC65登录信息获取

//获取当前系统登录集团
InvocationInfoProxy.getInstance().getGroupId()
//获取当前系统登录用户
InvocationInfoProxy.getInstance().getUserId()
// 获取当前用户编码
WorkbenchEnvironment.getInstance().getLoginUser() .getUser_code()
//获取当前系统时间
new UFDateTime(System.currentTimeMillis())
//clent端获取登录用户VO
UserVO user = WorkbenchEnvironment.getInstance().getLoginUser();

14.页面查询功能添加自定义查询条件

package nc.ui.yxzy.yx.depositpool.action;

import nc.ui.pubapp.uif2app.query2.action.DefaultQueryAction;
import nc.ui.querytemplate.querytree.IQueryScheme;

public class NewQueryAction extends DefaultQueryAction {

/**
 * 
 */
private static final long serialVersionUID = 1L;
public static final String QUERY_CONDITION = "all_condition";
/** Key:返回查询条件where语句 */
public static final String KEY_SQL_WHERE = "where";
/** Key:返回表列表式(逗号分隔式)from-where语句 */
public static final String KEY_SQL_TABLE_LIST = "tablelist";
/** Key:返回表列表式(逗号分隔式)from-where语句 */
public static final String KEY_SQL_TABLE_JOIN = "tablejoin";

@Override
protected void executeQuery(IQueryScheme queryScheme) {
	// 判断页面查询条件数据是否存在。
	if (queryScheme != null) {
		// 获取当前页面节点ID
		String funnode = getFunNode();
		// 根据实际情况判断是否为需要处理的查询节点
		if (funnode.equals("YX601010")) {
			// 获取当前页面查询条件
			Object sql = queryScheme.get(KEY_SQL_TABLE_JOIN);
			// 判断查询条件是否存在
			if (sql instanceof nc.ui.querytemplate.querytree.FromWhereSQLImpl) {
				// 将获取页面的查询条件转换给fsi
				nc.ui.querytemplate.querytree.FromWhereSQLImpl fsi = (nc.ui.querytemplate.querytree.FromWhereSQLImpl) sql;
				// 获取sql便于条件追加赋值
				String fromsql = fsi.getWhere();
				// 判断SQL是否存在
				if (fromsql != null) {
					// 拼接所需查询条件
					fromsql = fromsql + " and pk_id = '1001G11000000000222R' and YXZY_DEPOSITPOOL_B.vbdef1 = '1'";
				}
				// 查询条件返回给页面通用查询
				fsi.setWhere(fromsql);
			}
		}
	}
	// 返回查询结果集
	super.executeQuery(queryScheme);
	}
}

15.前台查询使用方法

IUAPQueryBS bs = NCLocator.getInstance().lookup(IUAPQueryBS.class);
Object countMap = bs.executeQuery(sql, new MapProcessor());

16、读取以及修改数据源

// 获取数据源
String oldDataSourceName = InvocationInfoProxy.getInstance().getUserDataSource();
// 设置新的数据源
InvocationInfoProxy.getInstance().setUserDataSource("数据源");

17.按钮快捷键功能

// 导包
import javax.swing.Action;
import javax.swing.KeyStroke;
import java.awt.event.InputEvent;
import java.awt.event.KeyEvent;

//这一行是定义一个KeyStore对象,并指定快捷键为"Ctrl+L"
KeyStroke keyStore = KeyStroke.getKeyStroke(KeyEvent.VK_L, InputEvent.CTRL_MASK);
//这一行代码为为该按钮设置定义好的快捷键
this.putValue(Action.ACCELERATOR_KEY, keyStore);

18.导入导出按钮组

<bean id="importExportMenu" class="nc.funcnode.ui.action.MenuAction">
	<property name="code" value="importExport" />
	<property name="name" value="导入/导出" />
	<property name="actions">
		<list>
			<ref bean="ImportData" />        <!-- 导入Excel -->
			<ref bean="ExportData" />        <!-- 导出Excel -->
			<ref bean="ExportTemplate" /> 	 <!-- 导出模板 -->
		</list>
	</property>
</bean>
<!-- 导入Excel(根据模板填充数据) -->
<bean id="ImportData" class="nc.ui.uif2.excelimport.ImportAction">
	<property name="model" ref="bmModel" />
	<property name="importableEditor" ref="ImportExportEditor" />
	<property name="btnName" value="导入Excel" />
</bean>
<!-- 导出模板到Excel -->
<bean id="ExportTemplate" class="nc.ui.uif2.excelimport.ExportExcelTemplateAction">
	<property name="model" ref="bmModel" />
	<property name="importableEditor" ref="ImportExportEditor" />
	<property name="btnName" value="导出模板" />
</bean>
<!-- 导出数据到Excel -->
<bean id="ExportData" class="nc.ui.uif2.excelimport.ExportAction">
	<property name="model" ref="bmModel" />
	<property name="importableEditor" ref="ImportExportEditor" />
	<property name="btnName" value="导出Excel" />
</bean>
<!-- 导入项目编辑器 -->
<bean id="ImportExportEditor" class="nc.ui.ic.eneryconsumption.excel.EneryConsumeImportableEditor">
	<property name="billcardPanelEditor" ref="billForm" />
	<property name="addAction" ref="addAction" />
	<property name="cancelAction" ref="cancelAction" />
	<property name="saveAction" ref="saveScriptAction" />
	<property name="appModel" ref="bmModel" />
</bean>

EneryConsumeImportableEditor文件代码

package nc.ui.ic.eneryconsumption.excel;

import java.util.List;
import nc.ui.trade.excelimport.InputItem;
import nc.ui.pubapp.uif2app.view.util.BillPanelUtils;
import nc.ui.tmpub.field.affect.util.FieldValueUIUtil;
import nc.ui.trade.excelimport.Uif2ImportablePanel;
import nc.ui.uif2.excelimport.DefaultUIF2ImportableEditor;
import nc.vo.pub.ExtendedAggregatedValueObject;

/**
 * 导入时校验
 * @author wsj
 * @date   2022-12-09
 *
 */
public class EneryConsumeImportableEditor extends 	DefaultUIF2ImportableEditor{
@Override
protected void setProcessedVO(ExtendedAggregatedValueObject eavo) {
//标准产品导入时,需填写组织信息,需以下代码,否则部分字段无法带出
getAppModel().getContext().setPk_org(FieldValueUIUtil.getPkOrg(eavo,getBillcardPanelEditor()));
	BillPanelUtils.setOrgForAllRef(getBillcardPanelEditor().getBillCardPanel(), getAppModel().getContext());
	super.setProcessedVO(eavo);
}

@Override
public List<InputItem> getInputItems() {
    return super.getInputItems();
    }
}