unit U_FactoryInput; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxGraphics, cxCustomData, cxStyles, cxTL, cxMaskEdit, DB, ADODB, cxInplaceContainer, cxDBTL, cxControls, cxTLData, ComCtrls, ToolWin, StdCtrls, cxFilter, cxData, cxDataStorage, cxEdit, cxDBData, DBClient, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, ExtCtrls, cxSplitter, cxGridLevel, cxClasses, cxGridCustomView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, RM_Dataset, RM_System, RM_Common, RM_Class, RM_GridReport, IdBaseComponent, IdComponent, IdTCPConnection, IdTCPClient, IdFTP, ShellAPI, IniFiles, cxCheckBox, cxCalendar, cxButtonEdit, cxTextEdit, cxDropDownEdit, BtnEdit, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxSkinsCore, dxSkinsDefaultPainters, dxDateRanges, dxBarBuiltInMenu, U_BaseList; type TfrmFactoryInput = class(TForm) ToolBar1: TToolBar; TBClose: TToolButton; ADOQueryTemp: TADOQuery; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ToolButton3: TToolButton; CDS_LXR: TClientDataSet; DSLXR: TDataSource; ScrollBox1: TScrollBox; Label2: TLabel; Label6: TLabel; Label7: TLabel; Label19: TLabel; CoName: TEdit; CoNote: TMemo; Label1: TLabel; CoAbbrName: TEdit; CoCode: TEdit; GPM_2: TcxGridPopupMenu; Label4: TLabel; CoAddress: TMemo; CoBusinessType: TBtnEditC; Panel2: TPanel; ToolBar2: TToolBar; ToolButton1: TToolButton; ToolButton4: TToolButton; ToolButton5: TToolButton; cxGrid1: TcxGrid; Tv1: TcxGridDBTableView; v3Column3: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; Tv1Column2: TcxGridDBColumn; cxGridDBColumn1: TcxGridDBColumn; Tv1Column3: TcxGridDBColumn; cxGridLevel1: TcxGridLevel; ToolButton2: TToolButton; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure ToolButton4Click(Sender: TObject); procedure ToolButton5Click(Sender: TObject); procedure ToolButton1Click(Sender: TObject); procedure COGdyBtnDnClick(Sender: TObject); procedure COGdyBtnUpClick(Sender: TObject); procedure ToolButton2Click(Sender: TObject); private { Private declarations } procedure InitGrid(); function SaveData(): Boolean; public fkhType: string; { Public declarations } FCOID: string; end; var frmFactoryInput: TfrmFactoryInput; implementation uses U_DataLink, U_RTFun, U_ZDYHelp; {$R *.dfm} procedure TfrmFactoryInput.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; SQL.Clear; sql.Add(' select * from BS_Company where CoType=''��Ӧ��'' and COID=''' + Trim(FCOID) + ''''); Open; end; SCSHData(ADOQueryMain, ScrollBox1, 2); with ADOQueryMain do begin Filtered := False; Close; SQL.Clear; sql.Add(' select * from BS_Company_contact where COID=' + quotedstr(Trim(FCOID))); Open; end; SCreateCDS(ADOQueryMain, CDS_LXR); SInitCDSData(ADOQueryMain, CDS_LXR); finally ADOQueryMain.EnableControls; end; end; procedure TfrmFactoryInput.FormDestroy(Sender: TObject); begin frmFactoryInput := nil; end; procedure TfrmFactoryInput.COGdyBtnDnClick(Sender: TObject); begin TBtnEditC(Sender).Text := ''; TBtnEditC(Sender).TxtCode := ''; end; procedure TfrmFactoryInput.COGdyBtnUpClick(Sender: TObject); var fsj: string; FWZ: Integer; begin fsj := Trim(TEdit(Sender).Hint); FWZ := Pos('/', fsj); try frmZDYHelp := TfrmZDYHelp.Create(Application); with frmZDYHelp do begin flag := Copy(fsj, 1, FWZ - 1); flagname := Copy(fsj, FWZ + 1, Length(fsj) - FWZ); if ShowModal = 1 then begin TEdit(Sender).Text := Trim(ClientDataSet1.fieldbyname('ZDYName').AsString); end; end; finally frmZDYHelp.Free; end; end; procedure TfrmFactoryInput.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmFactoryInput.TBCloseClick(Sender: TObject); begin close; end; procedure TfrmFactoryInput.FormShow(Sender: TObject); begin ReadCxGrid(trim(self.Caption) + 'TV1', Tv1, '��Ӧ�̹���'); InitGrid(); if trim(FCOID) = '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' exec P_BS_Com_Get_No @Str=''G'' '); Open; end; CoCode.Text := trim(ADOQueryTemp.FieldByName('NewCoCode').asstring); end; end; procedure TfrmFactoryInput.TBRafreshClick(Sender: TObject); begin InitGrid(); end; function TfrmFactoryInput.SaveData(): Boolean; var MaxId, MaxSubId, FCoCode, FCCID: string; begin try ADOQueryCmd.Connection.BeginTrans; if Trim(FCOID) = '' then begin if GetLSNo(ADOQueryCmd, MaxId, 'CO', 'BS_Company', 4, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('ȡ����ʧ�ܣ�', '��ʾ', 0); Exit; end; if trim(CoCode.Text) = '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' exec P_BS_Com_Get_No @Str=''G'' '); Open; end; CoCode.Text := trim(ADOQueryTemp.FieldByName('NewCoCode').asstring); end; end else begin MaxId := Trim(FCOID); end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add('select * from BS_Company where COID=''' + Trim(FCOID) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FCOID) = '' then begin Append; FieldByName('FillId').Value := Trim(DCode); FieldByName('Filler').Value := Trim(DName); FieldByName('status').Value := '0'; end else begin Edit; FieldByName('EditId').Value := Trim(DCode); FieldByName('Editer').Value := Trim(DName); FieldByName('Edittime').Value := SGetServerDateTime(ADOQueryTemp); end; FieldByName('COID').Value := Trim(MaxId); RTSetsavedata(ADOQueryCmd, 'BS_Company', ScrollBox1, 2); FieldByName('CoType').Value := '��Ӧ��'; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from BS_Company where CoCode=' + quotedstr(trim(CoCode.Text))); Open; end; if ADOQueryCmd.RecordCount > 1 then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('��Ӧ�̱���ظ�!', '��ʾ', 0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from BS_Company where CoName=' + quotedstr(trim(CoName.Text))); sql.Add(' and CoType=''��Ӧ��'' '); Open; end; if ADOQueryCmd.RecordCount > 1 then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('��Ӧ�������ظ�!', '��ʾ', 0); Exit; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from BS_Company where CoAbbrName=' + quotedstr(trim(CoAbbrName.Text))); sql.Add(' and CoType=''��Ӧ��'' '); Open; end; if ADOQueryCmd.RecordCount > 1 then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('��Ӧ�̼���ظ�!', '��ʾ', 0); Exit; end; ////////////// ��ϵ�� /////////////////// if not CDS_LXR.IsEmpty then begin with CDS_LXR do begin CDS_LXR.First; while not Eof do begin FCCID := Trim(CDS_LXR.fieldbyname('CCID').AsString); if Trim(FCCID) = '' then begin if GetLSNo(ADOQueryCmd, MaxSubId, 'CCS', 'BS_Company_contact', 4, 1) = False then begin ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('ȡϵ�����IDʧ��!', '��ʾ', 0); Exit; end; end else begin MaxSubId := trim(FCCID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from BS_Company_contact where CCID=' + quotedstr(Trim(MaxSubId))); Open; end; with ADOQueryCmd do begin if Trim(FCCID) = '' then begin Append; end else begin Edit; end; FieldByName('CCID').Value := Trim(MaxSubId); FieldByName('COID').Value := Trim(MaxId); RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_LXR, 'BS_Company_contact', 0); Post; end; with CDS_LXR do begin Edit; FieldByName('CCID').Value := Trim(MaxSubId); Post; end; CDS_LXR.Next; end; end; end; ////////////// ��ϵ�� /////////////////// //////////////// �������� //////////////////////// // with ADOQueryCmd do // begin // Close; // sql.Clear; // sql.Add('exec P_Com_Up_Code @COID=' + quotedstr(Trim(MaxId))); // ExecSQL; // end; //////////////// �������� //////////////////////// ADOQueryCmd.Connection.CommitTrans; FCCID := Trim(MaxSubId); Result := True; except Result := false; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('�����쳣!', '��ʾ', 0); end; end; procedure TfrmFactoryInput.ToolButton3Click(Sender: TObject); begin if Trim(CoAbbrName.Text) = '' then begin Application.MessageBox('��Ʋ���Ϊ��!', '��ʾ', 0); Exit; end; if Trim(CoName.Text) = '' then begin Application.MessageBox('���Ʋ���Ϊ��!', '��ʾ', 0); Exit; end; if SaveData() then begin Application.MessageBox('����ɹ�!', '��ʾ', 0); ModalResult := 1; end; end; procedure TfrmFactoryInput.ToolButton4Click(Sender: TObject); var maxno: string; begin if GetLSNo(ADOQueryCmd, maxno, 'CC', 'BS_Company_contact', 4, 1) = False then begin Application.MessageBox('ȡϵ�����IDʧ��!', '��ʾ', 0); Exit; end; if CDS_LXR.IsEmpty then begin with CDS_LXR do begin Append; fieldbyname('CCID').Value := trim(maxno); fieldbyname('IsDefault').Value := true; Post; end; end else begin with CDS_LXR do begin Append; fieldbyname('CCID').Value := trim(maxno); fieldbyname('IsDefault').Value := false; Post; end; end; end; procedure TfrmFactoryInput.ToolButton5Click(Sender: TObject); begin if CDS_LXR.IsEmpty then Exit; if Trim(CDS_LXR.fieldbyname('CCID').AsString) <> '' then begin if Application.MessageBox('ȷ��Ҫɾ��������', '��ʾ', 32 + 4) <> IDYES then Exit; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('delete from BS_Company_contact where CCID=''' + Trim(CDS_LXR.fieldbyname('CCID').AsString) + ''''); ExecSQL; end; end; CDS_LXR.Delete; if CDS_LXR.IsEmpty = false then begin if CDS_LXR.Locate('IsDefault', true, []) = false then begin CDS_LXR.first; CDS_LXR.edit; CDS_LXR.FieldByName('IsDefault').value := true; end; end; end; procedure TfrmFactoryInput.ToolButton1Click(Sender: TObject); var DwFlag: string; begin DwFlag := trim(CDS_LXR.FieldByName('CCID').AsString); if CDS_LXR.Locate('IsDefault', true, []) then begin CDS_LXR.edit; CDS_LXR.FieldByName('IsDefault').value := false; end; if CDS_LXR.Locate('CCID', DwFlag, []) then begin CDS_LXR.edit; CDS_LXR.FieldByName('IsDefault').value := true; end; end; procedure TfrmFactoryInput.ToolButton2Click(Sender: TObject); begin WriteCxGrid(trim(self.Caption) + 'TV1', Tv1, '��Ӧ�̹���'); end; end.