unit frameDnaCodes; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Vcl.ExtCtrls, Vcl.Grids, Vcl.DBGrids, DnaCodeService, Agent, Data.DB, Datasnap.DBClient, UiContext, typinfo, Vcl.Imaging.pngimage; type TfrmDnaCodes = class(TFrame) dbgDnaCodes: TDBGrid; pnlActies: TPanel; btnMaatwerketiket: TButton; btnKlantEtiket: TButton; btnProboxetiket: TButton; pnlZoekKnoppen: TPanel; btnZoeken: TButton; edtDnaCode: TEdit; cdsDnaCodes: TClientDataSet; dsDnaCodes: TDataSource; imgPrinter: TImage; lblDnaCode: TLabel; lblPallet: TLabel; edtPallet: TEdit; lblToelevering: TLabel; edtToelevering: TEdit; lblKlantNummer: TLabel; edtKlantNummer: TEdit; lblOrderNummer: TLabel; edtOrderNummer: TEdit; edtLadeCode: TEdit; lblLadeCode: TLabel; procedure ZoekViaDnaCode(); procedure ZoekViaPallet(); procedure ZoekViaToelevering(); procedure btnZoekenClick(Sender: TObject); procedure btnMaatwerketiketClick(Sender: TObject); procedure btnKlantEtiketClick(Sender: TObject); procedure btnProboxetiketClick(Sender: TObject); procedure edtToeleveringEnter(Sender: TObject); private procedure VulDnaCodeGridMetData(DnaCodes: ArrayOfDnaCodeDnaCode); function BepaalGeselecteerdeDnaCodes: TStringList; function GeefAlleDnaCodesUitGrid: TStringList; procedure ZoekveldenLeegmaken(); procedure DnaCodesZoeken(); public { Public declarations } end; implementation uses Main, System.StrUtils; {$R *.dfm} procedure TfrmDnaCodes.btnMaatwerketiketClick(Sender: TObject); var DnaCodesStringList: TStringList; begin DnaCodesStringList := BepaalGeselecteerdeDnaCodes() //relevante webmethod oproepen end; procedure TfrmDnaCodes.btnProboxetiketClick(Sender: TObject); var DnaCodesStringList: TStringList; fProboxAfdrukkenResponse: ProboxEtiketAfdrukkenResponse; begin DnaCodesStringList := GeefAlleDnaCodesUitGrid(); fProboxAfdrukkenResponse := TAgent.Create(fmMain.UiContext).ProboxEtiketAfdrukken(DnaCodesStringList); try if fProboxAfdrukkenResponse.Header.Status <> '200' then begin ShowMessage(fProboxAfdrukkenResponse.Header.Omschrijving) end else begin ShowMessage('Etiketten afgedrukt') end; finally fProboxAfdrukkenResponse.Free; end; end; procedure TfrmDnaCodes.ZoekViaDnaCode(); var fZoekViaDnaCodeResponse: ZoekViaDnaCodeResponse; DnaCodes: ArrayOfDnaCodeDnaCode; begin fZoekViaDnaCodeResponse := TAgent.Create(fmMain.UiContext).ZoekViaDnaCode(edtDnaCode.Text); try if fZoekViaDnaCodeResponse.Header.Status = '200' then begin SetLength(DnaCodes,1); DnaCodes[0] := fZoekViaDnaCodeResponse.DnaCodes; VulDnaCodeGridMetData(DnaCodes); btnProboxetiket.Visible := false; end else begin ShowMessage(fZoekViaDnaCodeResponse.Header.Omschrijving); end; finally fZoekViaDnaCodeResponse.Free; end; end; procedure TfrmDnaCodes.btnKlantEtiketClick(Sender: TObject); var DnaCodesStringList: TStringList; begin DnaCodesStringList := BepaalGeselecteerdeDnaCodes(); //relevante webmethod oproepen end; procedure TfrmDnaCodes.ZoekViaPallet(); var fZoekViaPalletResponse: ZoekViaPalletCodeResponse; DnaCodes: ArrayOfDnaCodeDnaCode; begin fZoekViaPalletResponse := TAgent.Create(fmMain.UiContext).ZoekViaPalletCode(edtPallet.Text); try if fZoekViaPalletResponse.Header.Status = '200' then begin DnaCodes := fZoekViaPalletResponse.DnaCodes; VulDnaCodeGridMetData(DnaCodes); if StartsText('TBP',edtPallet.Text) then btnProboxetiket.Visible := true; end else begin ShowMessage(fZoekViaPalletResponse.Header.Omschrijving); end; finally fZoekViaPalletResponse.Free; end; end; procedure TfrmDnaCodes.ZoekViaToelevering(); var fZoekViaToeleveringResponse: ZoekViaToeleveringResponse; DnaCodes: ArrayOfDnaCodeDnaCode; begin fZoekViaToeleveringResponse := TAgent.Create(fmMain.UiContext).ZoekViaToelevering(edtToelevering.Text); try if fZoekViaToeleveringResponse.Header.Status = '200' then begin DnaCodes := fZoekViaToeleveringResponse.DnaCodes; VulDnaCodeGridMetData(DnaCodes); btnProboxetiket.Visible := false; end else begin ShowMessage(fZoekViaToeleveringResponse.Header.Omschrijving); end; finally fZoekViaToeleveringResponse.Free; end; end; procedure TfrmDnaCodes.DnaCodesZoeken; begin { edtToelevering.Text := ''; edtPallet.Text := ''; edtDNACode.Text := ''; edtKlantNummer.Text := ''; edtOrderNummer.Text := ''; edtLadeCode.Text := '';} if edtToelevering.Text <> '' then ZoekViaToelevering(); if edtPallet.Text <> '' then ZoekViaPallet(); if edtDNACode.Text <> '' then ZoekViaDNACode(); //if edtKlantNummer.Text <> '' then ZoekViaKlantnummer(); //if edtOrderNummer.Text <> '' then ZoekViaOrderNummer(); //if edtLadeCode.Text <> '' then ZoekViaLadeCode(); end; procedure TfrmDnaCodes.edtToeleveringEnter(Sender: TObject); begin ZoekveldenLeegmaken(); end; procedure TfrmDnaCodes.btnZoekenClick(Sender: TObject); begin DnaCodesZoeken(); end; procedure TfrmDnaCodes.VulDnaCodeGridMetData(DnaCodes: ArrayOfDnaCodeDnaCode); var ii: integer; ScanTijdstipAsString: string; begin cdsDnaCodes.Close; cdsDnaCodes.CreateDataSet; ii := 0; while ii <= length(DnaCodes)-1 do begin if DnaCodes[ii].ScanTijdstip = nil then ScanTijdstipAsString := '' else ScanTijdstipAsString := DateTimeToStr(DnaCodes[ii].ScanTijdstip.AsUTCDateTime); cdsDnaCodes.InsertRecord([DnaCodes[ii].DnaCode, DnaCodes[ii].PalletCode, DnaCodes[ii].Toelevering, GetEnumName(typeInfo(DnaCodeStatus),Ord(DnaCodes[ii].Status)), DnaCodes[ii].BatchId, ScanTijdstipAsString, DnaCodes[ii].InitialenScanner]); ii := ii + 1; end; end; procedure TfrmDnaCodes.ZoekveldenLeegmaken; begin edtToelevering.Text := ''; edtPallet.Text := ''; edtDNACode.Text := ''; edtKlantNummer.Text := ''; edtOrderNummer.Text := ''; edtLadeCode.Text := ''; end; function TfrmDnaCodes.BepaalGeselecteerdeDnaCodes: TStringList; var DnaCodesStringList: TStringList; RijTeller: integer; begin DnaCodesStringList := TStringList.Create(); if dbgDnaCodes.SelectedRows.Count > 0 then begin for rijteller := 0 to dbgDnaCodes.SelectedRows.Count - 1 do begin dbgDnaCodes.DataSource.DataSet.GotoBookmark(Pointer(dbgDnaCodes.SelectedRows.Items[rijteller])); DnaCodesStringList.Add(dbgDnaCodes.DataSource.DataSet.FieldByName('cdsDnaCodesDnaCode').AsString); end; end; result := DnaCodesStringList; end; function TfrmDnaCodes.GeefAlleDnaCodesUitGrid: TStringList; var DnaCodesStringList: TStringList; begin DnaCodesStringList := TStringList.Create(); dbgDnaCodes.DataSource.DataSet.First; while not dbgDnaCodes.DataSource.DataSet.Eof do begin DnaCodesStringList.Add(dbgDnaCodes.DataSource.DataSet.FieldByName('cdsDnaCodesDnaCode').AsString); dbgDnaCodes.DataSource.DataSet.Next; end; result := DnaCodesStringList; end; end.