⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 u_bmda.pas

📁 《delphi深度编程及其项目开发》
💻 PAS
字号:
unit U_Bmda;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  ExtCtrls, ComCtrls, Buttons, Db, DBClient, ImgList, Menus, StdCtrls,
  Mask, DBCtrls, Grids, DBGrids;

type
  TfrmBmda = class(TForm)
    Panel1: TPanel;
    TreeView: TTreeView;
    Splitter1: TSplitter;
    StatusBar: TStatusBar;
    pmOperate: TPopupMenu;
    N_insert: TMenuItem;
    N_delete: TMenuItem;
    N_edit: TMenuItem;
    N_cancel: TMenuItem;
    N_save: TMenuItem;
    N7: TMenuItem;
    N_refresh: TMenuItem;
    ImageList1: TImageList;
    DataSource: TDataSource;
    Panel2: TPanel;
    PageControl1: TPageControl;
    TabSheet1: TTabSheet;
    TabSheet2: TTabSheet;
    Panel3: TPanel;
    Label3: TLabel;
    Label1: TLabel;
    Label2: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    Label6: TLabel;
    Label7: TLabel;
    Label8: TLabel;
    DBEdt_Bmbm: TDBEdit;
    DBEdt_Bmmc: TDBEdit;
    DBEdt_Fzrxm: TDBEdit;
    DBEdt_Bmsx: TDBEdit;
    DBEdt_Lxdh: TDBEdit;
    DBEdt_DZ: TDBEdit;
    DBEdt_BZ: TDBEdit;
    DBGrid: TDBGrid;
    ImageList2: TImageList;
    pmOther: TPopupMenu;
    N_Order: TMenuItem;
    N_Print: TMenuItem;
    procedure FormShow(Sender: TObject);
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure N_insertClick(Sender: TObject);
    procedure N_saveClick(Sender: TObject);
    procedure N_refreshClick(Sender: TObject);
    procedure N_editClick(Sender: TObject);
    procedure N_cancelClick(Sender: TObject);
    procedure N_deleteClick(Sender: TObject);
    procedure TreeViewClick(Sender: TObject);
    procedure N_OrderClick(Sender: TObject);
    procedure N_PrintClick(Sender: TObject);
    procedure DBGridTitleClick(Column: TColumn);

  private
    Node_Parent: TTreeNode; //存储父节点
    Node_Child: TTreeNode; //存储当前节点
    b_pd: bool; //用于判断点击的是添加还是编辑
    //在添加、编辑和浏览状态互置按钮的有效性
    procedure button_valid;
    //RefreshTree方法用于将部门档案的部门编码分层次以树型目录的形式显示出来
    procedure refreshTree;
    { Private declarations }
  public

    { Public declarations }
  end;

var
  frmBmda: TfrmBmda;

implementation

uses U_mainform, U_szcx, U_general_print, u_public, WzglDB;

{$R *.DFM}

//在添加、编辑和浏览状态互置组件的有效性
procedure TfrmBmda.button_valid;
begin
  DBEdt_Bmbm.enabled := not DBEdt_Bmbm.enabled;
  DBEdt_Bmmc.enabled := not DBEdt_Bmmc.enabled;
  DBEdt_Fzrxm.enabled := not DBEdt_Fzrxm.enabled;
  DBEdt_Bmsx.enabled := not DBEdt_Bmsx.enabled;
  DBEdt_Lxdh.enabled := not DBEdt_Lxdh.enabled;
  DBEdt_DZ.enabled := not DBEdt_DZ.enabled;
  DBEdt_BZ.enabled := not DBEdt_BZ.enabled;
  n_insert.enabled := not n_insert.enabled;
  n_delete.enabled := not n_delete.enabled;
  n_edit.enabled := not n_edit.enabled;
  n_cancel.enabled := not n_cancel.enabled;
  n_save.enabled := not n_save.enabled;
  n_refresh.enabled := not n_refresh.enabled;
  Treeview.enabled := not Treeview.Enabled;
end;

//RefreshTree方法用于将部门档案的部门编码分层次以树型目录的形式显示出来
procedure TfrmBmda.refreshTree;
var
  mynode_1, mynode_2, mynode_3: Ttreenode;
  s_bm_1: string;
  s_mc_1: string;
begin
  statusbar.panels[0].text := '正在进行数据处理...';
  statusbar.refresh;
  treeview.Items.clear;
  //添加根目录名
  mynode_1 := Treeview.Items.Add(Treeview.topitem, '部门档案');
  mynode_1.imageindex := 0;
  mynode_1.stateindex := -1;
  mynode_1.selectedindex := 1;
  //指定部门表记录顺序
  DM.CDS_BMDA.indexfieldnames := '部门编码';
  DM.CDS_BMDA.First;
  while not DM.CDS_BMDA.Eof do
  begin
    s_bm_1 := DM.CDS_BMDA.fieldbyname('部门编码').asstring;
    s_mc_1 := DM.CDS_BMDA.fieldbyname('部门名称').asstring;
    //添加第一级部门名
    if length(trim(s_bm_1)) = 2 then
    begin
      mynode_2 := Treeview.items.addchild(mynode_1, '(' + s_bm_1 + ') ' + s_mc_1);
      mynode_2.imageindex := 0;
      mynode_2.stateindex := -1;
      mynode_2.selectedindex := 1;
    end;
    //添加第二级部门名
    if length(trim(s_bm_1)) = 5 then
    begin
      mynode_3 := Treeview.items.addchild(mynode_2, '(' + s_bm_1 + ') ' + s_mc_1);
      mynode_3.imageindex := 0;
      mynode_3.stateindex := -1;
      mynode_3.selectedindex := 1;
    end;
    DM.CDS_BMDA.next;
  end;
  statusbar.panels[0].text := '';
  statusbar.refresh;
end;

procedure TfrmBmda.FormShow(Sender: TObject);
begin
  with DM do
  begin
    CDS_BMDA.Active := True;
    CDS_BMDA_Index.Active := True;
  end;
  refreshTree; //调用RefreshTree方法将部门档案的部门编码分层次以树型目录的形式显示出来
  Treeview.topitem.Selected := true;
end;

procedure TfrmBmda.FormClose(Sender: TObject; var Action: TCloseAction);
begin
  action := cafree;
  frmBmda := nil;
end;

//添加

procedure TfrmBmda.N_insertClick(Sender: TObject);
var
  gs_global: string; //存储添加的父节点标题;
begin
  b_pd := true;
  Node_Parent := Treeview.selected;
  if Node_Parent.level = 2 then
  begin
    Application.messagebox('最底层不能添加,请在上层添加', '物资管理系统', mb_iconinformation + mb_defbutton1);
    exit;
  end;
  //设置按扭的有效性
  button_valid;
  if Node_Parent.level = 0 then
  begin
    DM.CDS_BMDA.Insert;
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99;1;_';
    pagecontrol1.ActivePageIndex := 0;
    DBEdt_Bmbm.setfocus;
  end;
  if Node_Parent.level = 1 then
  begin
    gs_global := copy(Node_Parent.text, 2, 2);
    DM.CDS_BMDA.insert;
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99-99;1;_';
    pagecontrol1.ActivePageIndex := 0;
    DBEdt_Bmbm.setfocus;
    DBEdt_Bmbm.text := gs_global;
  end;
end;

procedure TfrmBmda.N_editClick(Sender: TObject);
begin
  b_pd := false;
  Node_Child := Treeview.selected;
  if Node_Child.level = 0 then
  begin
    Application.messagebox('最顶层不能编辑,请在下层编辑', '物资管理系统', mb_iconinformation + mb_defbutton1);
    exit;
  end;
  //设置按扭有效性
  button_valid;
  Node_Parent := Node_Child.parent;
  if Node_Parent.level = 0 then
  begin
    DM.CDS_BMDA.edit;
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99;1;_';
    pagecontrol1.ActivePageIndex := 0;
    DBEdt_Bmbm.setfocus;
  end;
  if Node_Parent.level = 1 then
  begin
    DM.CDS_BMDA.edit;
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99-99;1;_';
    pagecontrol1.ActivePageIndex := 0;
    DBEdt_Bmbm.setfocus;
  end;
end;

//删除

procedure TfrmBmda.N_deleteClick(Sender: TObject);
var
  mynode: Ttreenode;
begin
  mynode := Treeview.selected;
  //根目录不须删除
  if mynode.level = 0 then
    exit;
  //如果删除的是第二级目录  
  if mynode.level = 2 then
  begin
    if DM.CDS_BMDA.recordcount <> 0 then
    begin
      if Application.messagebox('请确认是否要删除,并且子目录也将被删除', '物资管理系统', mb_iconinformation + mb_yesno) = idyes then
      begin
        DM.CDS_BMDA.Delete;
        DM.CDS_BMDA.applyupdates(0);
        Treeview.Items.delete(mynode);
      end;
    end
    else
    begin
      Application.messagebox('已无记录可删除', '物资管理系统', mb_iconinformation + mb_defbutton1);
      exit;
    end;
    EXIT;
  end;
  //如果删除是第一级目录,还得删除第二级目录
  if mynode.level = 1 then
  begin
    DM.CDS_BMDA.filter := 'substring(部门编码,1,2)=' + '''' + copy(mynode.text, 2, 2) + '''';
    DM.CDS_BMDA.filtered := true;
    DM.CDS_BMDA.first;
    if DM.CDS_BMDA.recordcount <> 0 then
    begin
      if Application.messagebox('请确认是否要删除,并且子目录也将被删除', '物资管理系统', mb_iconinformation + mb_yesno) = idyes then
      begin
        while not DM.CDS_BMDA.eof do
        begin
          DM.CDS_BMDA.Delete;
        end;
        DM.CDS_BMDA.applyupdates(0);
        Treeview.Items.delete(mynode);
      end;
    end
    else
    begin
      Application.messagebox('已无记录可删除', '物资管理系统', mb_iconinformation + mb_defbutton1);
      exit;
    end;
    DM.CDS_BMDA.filtered := false;
  end;
end;


//恢复

procedure TfrmBmda.N_cancelClick(Sender: TObject);
begin
  DM.CDS_BMDA.cancel;
  //设置组件的有效性
  button_valid;
end;


//保存

procedure TfrmBmda.N_saveClick(Sender: TObject);
var
  s_bm, s_mc: string;
begin
  if Node_Parent.level = 0 then
  begin
    if length(trim(DBEdt_Bmbm.text)) <> 2 then
    begin
      Application.messagebox('编码应为两位', '物资管理系统', mb_iconinformation + mb_defbutton1);
      exit;
    end;
  end;
  if Node_Parent.level = 1 then
  begin
    if copy(DBEdt_Bmbm.text, 1, 2) <> copy(Node_Parent.text, 2, 2) then
    begin
      Application.messagebox('前面两位不能变,请确认!', '物资管理系统', mb_iconinformation + mb_defbutton1);
      DBEdt_Bmbm.text := copy(Node_Parent.text, 2, 2);
      exit;
    end;
    if length(trim(DBEdt_Bmbm.text)) <> 5 then
    begin
      Application.messagebox('编码应为五位', '物资管理系统', mb_iconinformation + mb_defbutton1);
      exit;
    end;
  end;
  s_bm := DBEdt_Bmbm.text;
  s_mc := DBEdt_Bmmc.text;
  //查找重复编号
  DM.CDS_BMDA_INDEX.IndexFieldNames := '部门编码';
  DM.CDS_BMDA_INDEX.Refresh;
  if DM.CDS_BMDA.state = dsinsert then
  begin
    if DM.CDS_BMDA_INDEX.FindKey([s_bm]) then
    begin
      application.MessageBox('部门编码已重复', '物资管理系统', mb_iconinformation + mb_defbutton1);
      pagecontrol1.ActivePageIndex := 0;
      DBEdt_Bmbm.SetFocus;
      exit;
    end;
  end;
  //判断是添加数据的保存还是编辑数据保存
  if b_pd = true then
    Treeview.items.addchild(Node_Parent, '(' + s_bm + ') ' + s_mc)
  else
    Node_Child.Text := '(' + s_bm + ') ' + s_mc;
  DM.CDS_BMDA.post;
  DM.CDS_BMDA.applyupdates(0);
  DM.CDS_BMDA.Refresh;
  //设置按扭的有效性
  button_valid;
end;

//刷新

procedure TfrmBmda.N_refreshClick(Sender: TObject);
begin
  refreshTree;
  Treeview.TopItem.selected := true;
end;

//TreeViewClick根据部门编码来定位数据集,从而实现数据的联动
procedure TfrmBmda.TreeViewClick(Sender: TObject);
var
  mynode: Ttreenode;
  s_value_1: string;
begin
  if Treeview.Items.Count = 0 then
    exit;
  mynode := Treeview.selected;
  //如果是在目录树的第一级,代表是第一级部门,它的部门编码只有两位
  if mynode.Level = 1 then
  begin
    //从目录树的节点标题中,提取部门编码
    s_value_1 := copy(mynode.text, 2, 2);
    DM.CDS_BMDA.IndexFieldNames := '部门编码';
    DM.CDS_BMDA.findkey([s_value_1]);
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99;1;_';
  end;
 //如果是在目录树的第二级,代表是第二级部门,它的部门编码有五位
  if mynode.Level = 2 then
  begin
    //从目录树的节点标题中,提取部门编码
    s_value_1 := copy(mynode.text, 2, 5);
    DM.CDS_BMDA.IndexFieldNames := '部门编码';
    DM.CDS_BMDA.FindKey([s_value_1]);
    DM.CDS_BMDA.FieldByName('部门编码').editmask := '99-999;1;_';
  end;
end;

//排序
procedure TfrmBmda.N_OrderClick(Sender: TObject);
var
  vs_value: string;
  vi, i: integer;
begin
  application.createform(TfrmSzcx, frmSzcx);
  frmSzcx.srclist.items.add('部门编码');
  frmSzcx.srclist.items.add('部门名称');
  frmSzcx.srclist.items.add('负责人姓名');
  frmSzcx.srclist.items.add('部门属性');
  frmSzcx.srclist.items.add('联系电话');
  frmSzcx.srclist.items.add('地址');
  try
    frmSzcx.showmodal;
  finally
    if Ordered then
    begin
      vi := frmSzcx.DstList.Items.Count;
      if vi > 0 then
      begin
        vs_value := frmSzcx.dstlist.items[0];
      end;
      for i := 2 to vi do
      begin
        vs_value := vs_value + ';' + frmSzcx.dstlist.items[i - 1];
      end;
      DM.CDS_BMDA.IndexFieldNames := vs_value;
    end;
    frmSzcx.free;
  end;
end;

//打印
procedure TfrmBmda.N_PrintClick(Sender: TObject);
begin
  //打开通用报表窗体
  application.createform(TfrmPrint, frmPrint);
  with frmPrint do
  begin
    //添加打印的字段头
    srclist.items.add('部门编码');
    srclist.items.add('部门名称');
    srclist.items.add('负责人姓名');
    srclist.items.add('部门属性');
    srclist.items.add('联系电话');
    srclist.items.add('地址');
    srclist.items.add('备注');
    //设置表名
    vps_tablename := 'WZ_BMDA';
    //设置过滤条件
    vps_filter := DM.CDS_BMDA.Filter;
    //设置排序索引
    vps_index := DM.CDS_BMDA.IndexFieldNames;
    edtPrintTitle.Text := '部门列表';
    try
      showmodal;
    finally
      free;
    end;
  end;
end;

procedure TfrmBmda.DBGridTitleClick(Column: TColumn);
begin
  //调用u_public单元的DBGridSort按表格的列字段排序
  DBGridSort(dbgrid, column);
end;

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -