unit U_ShaOutList; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxGridCustomTableView, cxGridTableView, cxGridBandedTableView, cxGridDBBandedTableView, cxGridLevel, cxClasses, cxControls, cxGridCustomView, cxGridDBTableView, cxGrid, StdCtrls, ComCtrls, ExtCtrls, ToolWin, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB, DBClient, cxDropDownEdit, cxCheckBox, RM_Common, RM_Class, RM_e_Xls, RM_Dataset, RM_System, RM_GridReport, Menus, cxCalendar, cxButtonEdit, cxTextEdit, cxPC, cxLookAndFeels, cxLookAndFeelPainters, cxNavigator, dxBarBuiltInMenu, dxCore, ActiveX, dxSkinsCore, dxSkinsDefaultPainters, dxSkinscxPCPainter, dxSkinBlack, dxSkinBlue, dxSkinBlueprint, dxSkinCaramel, dxSkinCoffee, dxSkinDarkRoom, dxSkinDarkSide, dxSkinDevExpressDarkStyle, dxSkinDevExpressStyle, dxSkinFoggy, dxSkinGlassOceans, dxSkinHighContrast, dxSkiniMaginary, dxSkinLilian, dxSkinLiquidSky, dxSkinLondonLiquidSky, dxSkinMcSkin, dxSkinMetropolis, dxSkinMetropolisDark, dxSkinMoneyTwins, dxSkinOffice2007Black, dxSkinOffice2007Blue, dxSkinOffice2007Green, dxSkinOffice2007Pink, dxSkinOffice2007Silver, dxSkinOffice2010Black, dxSkinOffice2010Blue, dxSkinOffice2010Silver, dxSkinOffice2013DarkGray, dxSkinOffice2013LightGray, dxSkinOffice2013White, dxSkinPumpkin, dxSkinSeven, dxSkinSevenClassic, dxSkinSharp, dxSkinSharpPlus, dxSkinSilver, dxSkinSpringTime, dxSkinStardust, dxSkinSummer2008, dxSkinTheAsphaltWorld, dxSkinValentine, dxSkinVS2010, dxSkinWhiteprint, dxSkinXmas2008Blue; type TfrmShaOutList = class(TForm) ToolBar1: TToolBar; TBRafresh: TToolButton; TBFind: TToolButton; TBExport: TToolButton; TBClose: TToolButton; Panel1: TPanel; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; DataSource1: TDataSource; cxGridPopupMenu1: TcxGridPopupMenu; Label1: TLabel; Label2: TLabel; BegDate: TDateTimePicker; EndDate: TDateTimePicker; CDS_Main: TClientDataSet; RM1: TRMGridReport; RMDBMain: TRMDBDataSet; RMXLSExport1: TRMXLSExport; RMDBHZ: TRMDBDataSet; CDS_HZ: TClientDataSet; CDS_PRT: TClientDataSet; TBDel: TToolButton; PopupMenu1: TPopupMenu; N1: TMenuItem; N2: TMenuItem; TBAdd: TToolButton; TBEdit: TToolButton; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column2: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column11: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; Label3: TLabel; Label4: TLabel; Label5: TLabel; Label8: TLabel; Label12: TLabel; Label6: TLabel; Y_CodeName: TEdit; FactoryName: TEdit; Y_ID: TEdit; Y_Spec: TEdit; CRType: TComboBox; Y_CF: TEdit; Label11: TLabel; FromFactoryName: TEdit; Label13: TLabel; ToFactoryName: TEdit; v1Column20: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column10: TcxGridDBColumn; cxTabControl1: TcxTabControl; Label14: TLabel; BatchNo: TEdit; ToolButton1: TToolButton; v1ComTaiTou: TcxGridDBColumn; Label15: TLabel; SyrName: TEdit; v1filler: TcxGridDBColumn; v1BCSPName: TcxGridDBColumn; Tv1Column1: TcxGridDBColumn; cxStyleRepository1: TcxStyleRepository; cxStyle1: TcxStyle; Note: TEdit; Label7: TLabel; Tv1Column2: TcxGridDBColumn; CDS_Print: TClientDataSet; Tv1Column3: TcxGridDBColumn; ADOTmp: TADOQuery; procedure FormDestroy(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormCreate(Sender: TObject); procedure TBRafreshClick(Sender: TObject); procedure ConNoMChange(Sender: TObject); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBExportClick(Sender: TObject); procedure TBFindClick(Sender: TObject); procedure SPNameChange(Sender: TObject); procedure Y_IDChange(Sender: TObject); procedure Y_IDKeyPress(Sender: TObject; var Key: Char); procedure N1Click(Sender: TObject); procedure N2Click(Sender: TObject); procedure TBDelClick(Sender: TObject); procedure TBAddClick(Sender: TObject); procedure TBEditClick(Sender: TObject); procedure Y_SpecChange(Sender: TObject); procedure cxTabControl1Change(Sender: TObject); procedure BatchNoKeyPress(Sender: TObject; var Key: Char); procedure NoteKeyPress(Sender: TObject; var Key: Char); procedure ToolButton1Click(Sender: TObject); procedure v1Column9CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure v2Column6CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); procedure Tv1CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); private canshu1, canshu2: string; procedure InitGrid(); { Private declarations } public FFY_ID: string; { Public declarations } end; //var // frmShaOutList: TfrmShaOutList; implementation uses U_DataLink, U_RTFun, U_ShaOutPut, U_Fun; {$R *.dfm} procedure TfrmShaOutList.FormDestroy(Sender: TObject); begin //frmShaOutList:=nil; end; procedure TfrmShaOutList.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmShaOutList.FormCreate(Sender: TObject); begin //cxGrid1.Align:=alClient; canshu1 := Trim(DParameters1); canshu2 := Trim(DParameters2); EndDate.DateTime := SGetServerDate10(ADOQueryTemp); BegDate.DateTime := EndDate.DateTime; end; procedure TfrmShaOutList.InitGrid(); begin try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_Yarn_CR A'); sql.add(' where A.CRTime>=''' + Trim(FormatDateTime('yyyy-MM-dd', BegDate.DateTime)) + ''''); sql.Add(' and A.CRTime<''' + Trim(FormatDateTime('yyyy-MM-dd', enddate.DateTime + 1)) + ''''); sql.Add(' and isnull(CKName,'''')=''纱线'''); SQL.Add(' and CRFlag=''出库'' '); SQL.Add(' order by CRTime desc'); Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmShaOutList.TBRafreshClick(Sender: TObject); begin BegDate.SetFocus; InitGrid(); end; procedure TfrmShaOutList.ConNoMChange(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); end; end; procedure TfrmShaOutList.TBCloseClick(Sender: TObject); begin WriteCxGrid('纱线出库列表121', Tv1, '纱线仓库'); //ReadCxGrid('纱线出库列表121', Tv1, '纱线仓库'); Close; end; procedure TfrmShaOutList.FormShow(Sender: TObject); var fsj: string; begin if Trim(Self.Caption) = '纱线出库管理' then begin end else if Trim(Self.Caption) = '纱线出库查询' then begin TBAdd.Visible := False; TBDel.Visible := False; TBEdit.Visible := False; cxTabControl1.Visible := False; end; ReadCxGrid('纱线出库列表121', Tv1, '纱线仓库'); if Trim(FFY_ID) <> '' then begin TBAdd.Visible := False; TBDel.Visible := False; TBEdit.Visible := False; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where A.KCID=''' + Trim(FFY_ID) + ''''); SQL.Add(' and CRFlag=''出库'' '); SQL.Add(' and isnull(CKName,'''')=''纱线'' '); Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; fsj := 'select distinct(Crtype) name from CK_Yarn_CR where ckname=''纱线'' and crflag=''出库'' '; SInitComBoxBySql(ADOQueryCmd, CRType, False, fsj); InitGrid(); end; procedure TfrmShaOutList.TBExportClick(Sender: TObject); begin if ADOQueryMain.IsEmpty then exit; TcxGridToExcel('纱线出库列表1', cxGrid2); end; procedure TfrmShaOutList.TBFindClick(Sender: TObject); begin if ADOQueryMain.Active then begin SDofilter(ADOQueryMain, SGetFilters(Panel1, 1, 2)); SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); end; end; procedure TfrmShaOutList.SPNameChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmShaOutList.Y_IDChange(Sender: TObject); begin if Length(Trim(Y_ID.Text)) < 4 then begin if Trim(Y_ID.Text) <> '' then Exit; end; TBFind.Click; end; procedure TfrmShaOutList.Y_IDKeyPress(Sender: TObject; var Key: Char); begin if Key = #13 then begin {if Length(Trim(Y_ID.Text))<4 then Exit; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered:=False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_SXPB_CR A'); sql.add(' where Y_ID like :SXID'); Parameters.ParamByName('SXID').Value:='%'+Trim(Y_ID.Text)+'%'; Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain,CDS_Main); SInitCDSData20(ADOQueryMain,CDS_Main); finally ADOQueryMain.EnableControls; end; } end; end; procedure TfrmShaOutList.N1Click(Sender: TObject); begin SelOKNo(CDS_Main, True); end; procedure TfrmShaOutList.N2Click(Sender: TObject); begin SelOKNo(CDS_Main, False); end; procedure TfrmShaOutList.TBDelClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if cxTabControl1.TabIndex <> 0 then Exit; if Trim(CDS_Main.fieldbyname('Y_ID').AsString) <> '' then begin if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移出库' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_Yarn_CR where KCID='); sql.Add('(select Y_ID from CK_Yarn_CR where PYID=''' + Trim(CDS_Main.fieldbyname('Y_ID').AsString) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'')'); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; end; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete CK_Yarn_CR where Y_ID=''' + Trim(CDS_Main.fieldbyname('Y_ID').AsString) + ''''); sql.Add(' Update CK_Yarn_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_Yarn_CR A where A.KCID=CK_Yarn_CR.Y_ID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_Yarn_CR A where A.KCID=CK_Yarn_CR.Y_ID)'); sql.Add(' where Y_ID=''' + Trim(CDS_Main.fieldbyname('KCID').AsString) + ''''); if Trim(CDS_Main.fieldbyname('CRType').AsString) = '平移出库' then begin sql.Add(' delete CK_Yarn_CR where isnull(PYID,''1'')=''' + Trim(CDS_Main.fieldbyname('PYID').AsString) + ''''); sql.Add(' and isnull(PYID,'''')<>'''''); end; ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end; CDS_Main.Delete; end; procedure TfrmShaOutList.TBAddClick(Sender: TObject); begin try frmShaOutPut := TfrmShaOutPut.Create(Application); with frmShaOutPut do begin FBCId := ''; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmShaOutPut.Free; end; end; procedure TfrmShaOutList.TBEditClick(Sender: TObject); begin if CDS_Main.IsEmpty then Exit; if cxTabControl1.TabIndex <> 0 then Exit; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_Yarn_CR where KCID='); sql.Add('(select Y_ID from CK_Yarn_CR where PYID=''' + Trim(CDS_Main.fieldbyname('Y_ID').AsString) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'')'); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能修改!', '提示', 0); Exit; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CW_Money_CR where CWTypeId=''' + Trim(CDS_Main.fieldbyname('Y_ID').AsString) + ''''); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已经生成财务数据不能修改!', '提示', 0); Exit; end; try frmShaOutPut := TfrmShaOutPut.Create(Application); with frmShaOutPut do begin FBCId := Trim(CDS_Main.fieldbyname('Y_ID').AsString); TBDel.Visible := False; TBAdd.Visible := False; if ShowModal = 1 then begin Self.InitGrid(); end; end; finally frmShaOutPut.Free; end; end; procedure TfrmShaOutList.Y_SpecChange(Sender: TObject); begin TBFind.Click; end; procedure TfrmShaOutList.cxTabControl1Change(Sender: TObject); begin InitGrid(); end; procedure TfrmShaOutList.BatchNoKeyPress(Sender: TObject; var Key: Char); begin if Key <> #13 then Exit; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_SXPB_CR A'); sql.add(' where A.BatchNo=''' + Trim(BatchNo.Text) + ''''); sql.Add(' and isnull(CKName,'''')=''纱线'''); SQL.Add(' and CRFlag=''出库'' '); if cxTabControl1.TabIndex = 0 then begin Sql.Add(' and ZFFlag=0 '); end else if cxTabControl1.TabIndex = 1 then begin Sql.Add(' and ZFFlag=1 '); end; Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmShaOutList.NoteKeyPress(Sender: TObject; var Key: Char); begin if Key <> #13 then Exit; try ADOQueryMain.DisableControls; with ADOQueryMain do begin Filtered := False; Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' from CK_Yarn_CR A'); sql.Add('WHERE A.Note LIKE ' + QuotedStr('%' + Trim(Note.Text) + '%')); sql.Add(' and isnull(CKName,'''')=''纱线'''); SQL.Add(' and CRFlag=''出库'' '); Open; //ShowMessage(SQL.Text); end; SCreateCDS20(ADOQueryMain, CDS_Main); SInitCDSData20(ADOQueryMain, CDS_Main); finally ADOQueryMain.EnableControls; end; end; procedure TfrmShaOutList.ToolButton1Click(Sender: TObject); var fPrintFile, Txt, fImagePath, YIDSql: string; Moudle: THandle; Makebar: TMakebar; Mixtext: TMixtext; SelectedCount: Integer; begin if CDS_Main.IsEmpty then Exit; if CDS_Main.Locate('SSel', True, []) = False then begin Application.MessageBox('没有选择数据!', '提示', 0); Exit; end; SelectedCount := 0; YIDSql := ''; CDS_Main.DisableControls; try with CDS_Main do begin First; while not Eof do begin if FieldByName('SSel').AsBoolean then begin if YIDSql <> '' then YIDSql := YIDSql + ',' + QuotedStr(Trim(FieldByName('Y_ID').AsString)) else YIDSql := QuotedStr(Trim(FieldByName('Y_ID').AsString)); Inc(SelectedCount); end; Next; end; end; finally CDS_Main.EnableControls; end; if YIDSql = '' then begin Application.MessageBox('未选择任何数据!', '提示', 0); Exit; end; with ADOQueryCmd do begin Close; SQL.Clear; sql.Add(' select A.* '); sql.Add(' from CK_Yarn_CR A'); sql.Add(' where isnull(CKName,'''')=''纱线'''); SQL.Add(' and CRFlag=''出库'''); SQL.Add(' and A.Y_ID in (' + YIDSql + ')'); SQL.Add(' order by CRTime desc'); Open; end; if ADOQueryCmd.IsEmpty then begin Application.MessageBox('未找到对应的纱线出库数据!', '提示信息', MB_ICONINFORMATION); Exit; end; SCreateCDS20(ADOQueryCmd, CDS_PRT); SInitCDSData20(ADOQueryCmd, CDS_PRT); with ADOQueryTemp do begin Close; SQL.Clear; SQL.Add('UPDATE CK_Yarn_CR set DYFLAG=''已打印'' where Y_ID in (' + YIDSql + ')'); ExecSQL; end; fPrintFile := ExtractFilePath(Application.ExeName) + 'Report\纱线出库报表.rmf'; ExportFtErpFile('纱线出库报表.rmf', ADOQueryCmd); if FileExists(fPrintFile) then begin RM1.LoadFromFile(fPrintFile); RM1.ShowReport; end else begin Application.MessageBox(PChar('未找到报表文件:' + #13#10 + fPrintFile), '提示', MB_ICONWARNING); end; InitGrid(); end; procedure TfrmShaOutList.v1Column9CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); var id: Integer; begin id := TV1.GetColumnByFieldName('PiQty').Index; //;-TV1.GroupedItemCount; // if AViewInfo.GridRecord.Values[tv1.GetColumnByFieldName('PBC').Index] = 1 then // ACanvas.BRUSH.Color := clAqua; if AViewInfo.GridRecord.Values[id] < 0 then begin ACanvas.Font.Color := clRed; end; end; procedure TfrmShaOutList.v2Column6CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); var id: Integer; begin id := TV1.GetColumnByFieldName('Qty').Index; //;-TV1.GroupedItemCount; // if AViewInfo.GridRecord.Values[tv1.GetColumnByFieldName('PBC').Index] = 1 then // ACanvas.BRUSH.Color := clAqua; if AViewInfo.GridRecord.Values[id] < 0 then begin ACanvas.Font.Color := clRed; end; end; procedure TfrmShaOutList.Tv1CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); begin if '已打印' = AViewInfo.GridRecord.Values[Tv1Column3.Index] then ACanvas.Brush.Color := $0080FF80; end; end.