金蝶云·星空|【客户需求】即时库存按照物料分组树型多级显示

0

本帖最后由 喜喜 于 2019-03-18 09:27 编辑

【需求背景】很多客户用习惯了K3,希望星空的即时库存也能实现按照物料分组左侧来进行树形结构展示。

【说明】系统中即时库存主要涉及的场景为:即时库存查询、即时库存明细查询、单据联查即时库存。
  以下方法:借助基础资料的分组属性实现即时库存明细查询、单据联查即时库存树形结构展示。
  实现效果如下:
  【客户需求】即时库存按照物料分组树型多级显示
  【客户需求】即时库存按照物料分组树型多级显示
步骤:
  1.扩展即时库存,增加基础资料字段(如下图)

  • 字段名:空
  • 可见性:不可见
  • 基础资料类型:数据分组
  • 支持分组:勾选
  • 分组允许维护:不勾选

  【客户需求】即时库存按照物料分组树型多级显示

  2.即时库存编写列表插件,重载实现GetTreeViewData、TreeNodeClick方法。

  • Demo:如下
  1. #region 构造节点
  2. //<summary>
  3. //获取节点(系统会自动往树立添加的)
  4. //</summary>
  5. //<param name="treeNodeArgs"></param>
  6. //<returns></returns>
  7. public override List<TreeNode> GetTreeViewData(TreeNodeArgs treeNodeArgs)
  8. {
  9.         if (string.IsNullOrEmpty(treeNodeArgs.NodeId) || treeNodeArgs.NodeId == "0")
  10.         {
  11.                 string sql = string.Format(" SELECT MG.FID,FNUMBER,FGROUPID,FPARENTID,MGL.FNAME from T_BD_MATERIALGROUP MG INNER JOIN T_BD_MATERIALGROUP_L MGL ON MG.FID = MGL.FID WHERE MGL.FLOCALEID = {0} ",this.View.Context.UserLocale.LCID);
  12.                 DynamicObjectCollection nodeList = DBUtils.ExecuteDynamicObject(this.View.Context,sql);
  13.                 Dictionary<string, TreeNode> _treeNodes = new Dictionary<string, TreeNode>();
  14.                 List<TreeNode> treeNodes = new List<TreeNode>();
  15.                 foreach (DynamicObject node in nodeList)
  16.                 {
  17.                         if (Convert.ToString(node["FPARENTID"]).Equals("0"))
  18.                         {
  19.                                 treeNodes.Add(  new TreeNode()
  20.                                                                 {
  21.                                                                         id = node["FID"].ToString().Trim(),
  22.                                                                         parentid = node["FPARENTID"].ToString().Trim(),
  23.                                                                         xtype = "system",
  24.                                                                         text = node["FNAME"].ToString().Trim(),
  25.                                                                         children = GetSubNode(nodeList, node["FID"].ToString().Trim())
  26.                                                                 }
  27.                                                           );
  28.                         }
  29.                 }  
  30.                 return treeNodes;
  31.         }
  32.         else
  33.         {
  34.                 return null;
  35.         }
  36. }

  37. /// <summary>
  38. /// 节点点击时触发重新查询
  39. /// </summary>
  40. /// <param name="e"></param>
  41. public override void TreeNodeClick(TreeNodeArgs e)
  42. {
  43.         if (this.Model != null)
  44.         {
  45.                 TreeViewFilterParameter treeViewFilter = ((ITreeListModel)this.Model).TreeViewFilterParameter as TreeViewFilterParameter;
  46.                 treeViewFilter.IgnoreSelectedGroupIds = true;     // 忽略系统内置的标准选择节点过滤方法
  47.                 treeViewFilter.FilterString = string.Format(" EXISTS (SELECT 1 FROM T_BD_MATERIALGROUP TG INNER JOIN T_BD_MATERIAL TM ON (TM.FMATERIALGROUP = TG.FID AND TG.FID = {0}) WHERE TM.FMATERIALID = t0.FMATERIALID ) ", Convert.ToInt64(e.NodeId));
  48.                 ((ITreeListView)this.ListView).RefreshList();     // 只刷新列表,不刷新树结构
  49.         }
  50. }

  51. private List<TreeNode> GetSubNode(DynamicObjectCollection nodeList, string parentID)
  52. {
  53.         return nodeList
  54.                 .Where(p => p["FPARENTID"].ToString().Equals(parentID) )
  55.                 .Select(p => new TreeNode()
  56.                 {
  57.                         id = p["FID"].ToString(),
  58.                         parentid = p["FPARENTID"].ToString(),
  59.                         xtype = "leaf",
  60.                         text = p["FNAME"].ToString(),
  61.                 }).ToList();
  62. }
  63. #endregion
复制代码