树形模型需实现 ITreeCodeModel接口。左树右表俩种情况 假设存在 A模型 B模型
1: 左树为A模型,右表为B模型
举例 A模型为类目 B模型为类目属性
模型代码实例:
@Model.model(AriesPlatformCategory.MODEL_MODEL)
@Model(displayName = "平台后台类目", labelFields = "name")
@Model.Advanced(type = ModelTypeEnum.PROXY)
public class AriesPlatformCategory extends AriesCategory {
public static final String MODEL_MODEL = "aries.item.AriesPlatformCategory";
@Field.many2one
@Field.Relation(relationFields = {"parentCateCode"}, referenceFields = {"code"},store = true)
@Field(displayName = "平台父类目")
private AriesPlatformCategory platformCategory;
@Field.one2many
@Field(displayName = "类目属性")
@Field.Relation(relationFields = "code", referenceFields = "categoryCode", store = true)
private List<AriesPlatformCategoryAttr> platformCategoryAttrs;
}
@Model.model(AriesPlatformCategoryAttr.MODEL_MODEL)
@Model(displayName = "Aries_平台类目属性", labelFields = "name")
@Model.Advanced(type = ModelTypeEnum.PROXY)
public class AriesPlatformCategoryAttr extends CategoryAttr {
public static final String MODEL_MODEL = "aries.item.AriesPlatformCategoryAttr";
@Field.many2one
@Field(displayName = "平台后台类目")
@Field.Relation(relationFields = "categoryCode", referenceFields = "code", store = true)
private AriesPlatformCategory platformCategory;
}
在设计器设计左树右表之前,需要在模型 中配置好关联关系 。如下部分代码 配置好类目与父类目的关联关系。
@Field.many2one
@Field.Relation(relationFields = {"parentCateCode"}, referenceFields = {"code"},store = true)
@Field(displayName = "平台父类目")
private AriesPlatformCategory platformCategory;
配置好 类目与类目属性的关联关系。一个类目可以有多个类目属性,一对多one2many
@Field.one2many
@Field(displayName = "类目属性")
@Field.Relation(relationFields = "code", referenceFields = "categoryCode", store = true)
private List<AriesPlatformCategoryAttr> platformCategoryAttrs;
在类目属性模型中,配置好属性与类目的关联关系,一个类目属性只属于一个类目,一个类目可以有多个类目属性。类目属性对类目多对一many2one
@Field.many2one
@Field(displayName = "平台后台类目")
@Field.Relation(relationFields = "categoryCode", referenceFields = "code", store = true)
private AriesPlatformCategory platformCategory;
设计器实例:
1.需要选择 平台类目属性 做为主模型创建树表页面
2.构建关联关系 选择平台后台类目 第一级的筛选条件 上级编码为空 表格关联关系字段 选择 平台类目属性。
3.表格拖拽好需要的属性字段
2: 左树为A模型,右表也为A模型
举例 左A模型 组织结构管理 右A模型 组织结构管理
模型代码实例:
@Model.model(BasicOrg.MODEL_MODEL)
@Model(displayName = "组织结构管理", summary = "组织结构管理", labelFields = {"orgName"})
@Model.Code(sequence = "ORDERLY_SEQ", prefix = "Org", size = 5, initial = 0)
public class BasicOrg extends BizCodeModel implements IDataStatus, ITreeCodeModel {
public static final String MODEL_MODEL = "basic.BasicOrg";
@Field.String
@Field(displayName = "名称")
private String orgName;
@Field.Enum
@Field(displayName = "组织类型", summary = "组织类型")
private OrgTypeEnum deptType;
@Field.Enum
@Field(displayName = "工厂类型", summary = "当组织类型为工厂时可见")
private FactoryTypeEnum factoryType;
@Field.Enum
@Field(displayName = "仓库类型", summary = "当组织类型为仓库时可见")
private WarehouseTypeEnum warehouseType;
@Field.String
@Field(displayName = "负责人", summary = "负责人")
private String principal;
@Field.String
@Field(displayName = "联系号码", summary = "联系号码")
private String phone;
@Field(displayName = "上级组织")
@Field.many2one
@Field.Relation(relationFields = {"parentCode"}, referenceFields = {"code"})
private BasicOrg parent;
@Field.Text
@Field(displayName = "备注")
private String remark;
@Field.Enum
@Field(displayName = "数据状态", required = true, defaultValue = "ENABLED")
private DataStatusEnum dataStatus;
@Field.String
@Field(displayName = "上级组织编码")
private String parentCode;
@Field.String(size = 256)
@Field(displayName = "树编码", required = true)
private String treeCode;
@Field.one2many
@Field.Relation(relationFields = "id", referenceFields = "orgId")
@Field(displayName = "基础-所属组织员工")
private List<BasicEmployee> basicEmployees;
}
配置好自我关联
@Field(displayName = "上级组织")
@Field.many2one
@Field.Relation(relationFields = {"parentCode"}, referenceFields = {"code"})
private BasicOrg parent;
设计器操作:
- 选择好模型 组织结构管理 创建页面 试图类型选择 表格 布局选择树表
2.设置联动关系 模型选择 组织结构管理 模型 ; 第一级的筛选条件 上级编码为空 表格关联关系字段 选择 组织结构管理-上级组织 字段名parent
- 表格拖拽好需要的属性字段
Oinone社区 作者:shao原创文章,如若转载,请注明出处:https://doc.oinone.top/dai-ma-shi-jian/5576.html
访问Oinone官网:https://www.oinone.top获取数式Oinone低代码应用平台体验