--- dao/DelphiScanner/Main.pas 2015/08/23 14:02:55 2657 +++ dao/DelphiScanner/Main.pas 2016/03/15 13:44:38 2977 @@ -1,19 +1,37 @@ unit Main; +// ToDo: flyt PrinterNavn til hhv Configuration lg lad TLabelPrint om al håndtering heraf +// ToDo: flyt flere parametre til TConfiguration + +// ToDo: FormKeyPress() trænger til en seriøs oprydning / refactoring +// ToDo: flyt mere funktionalitet fra interface layer til application layer klasser +// ToDo: vil det give mening at bruge State Pattern ? Så der er en class per scanningstype ? +// ToDo: alternativt kan man bruge en Enum til de forskellige typer +// ToDo: en enklere måde at håndtere capabilities på de forskellige scannings steder + + interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, - Dialogs, StdCtrls, Printers, IdBaseComponent, IdComponent, IdTCPConnection, + Dialogs, StdCtrls, IdBaseComponent, IdComponent, IdTCPConnection, IdTCPClient, IdHTTP, xmldom, XMLIntf, msxmldom, XMLDoc, IniFiles, AppEvnts, Menus, ExtCtrls, ComCtrls, StrUtils, MMSystem, DateUtils, - IdExplicitTLSClientServerBase, IdFTP, pngimage, GIFImg, IdException, - Winspool, Registry, ShellApi, ClipBrd, Buttons, wininet + IdExplicitTLSClientServerBase, IdFTP, IdException, + ShellApi, ClipBrd, Buttons, wininet, + UITypes, + PakkeshopLabels, + Utils, + ParentForm, + LabelPrint, + Configuration, + Vcl.Imaging.pngimage, + Generics.Collections + ; type - TStrArray = array of string; - TMainForm = class(TForm) + TMainForm = class(TForm, IParentForm) StregkodeST: TStaticText; RuteNummerST: TStaticText; BoghandlerNavnST: TStaticText; @@ -47,20 +65,20 @@ Testlyd1: TMenuItem; ListBox1: TListBox; Budlevering1: TMenuItem; - DownloadButton01: TButton; + BtnDownloadKontrolfil: TButton; IdFTP1: TIdFTP; Image1: TImage; ListBox2: TListBox; - OpdaterListenButton01: TButton; - UploadButton01: TButton; - DownloadButton03: TButton; + BtnOpdaterListen: TButton; + BtnUploadLogfil: TButton; + BtnDownloadRuteskiftFil: TButton; Pakkeshoplevering1: TMenuItem; PakkeshopText1: TStaticText; - PakkeshopNulstil: TButton; + btnNulstil: TButton; Returpakkerfrapakkeshop1: TMenuItem; Altidprintepakkelabel1: TMenuItem; chkAltidPrintLabel: TCheckBox; - EKLoverforsel: TButton; + BtnEKLoverforsel: TButton; N5: TMenuItem; Uploadlogfil1: TMenuItem; Manual1: TMenuItem; @@ -86,22 +104,14 @@ PanelManglendePakker4: TPanel; PanelManglendePakker5: TPanel; PanelManglendePakker6: TPanel; + menuIndlevering: TMenuItem; + chkForstorTilDirekte: TCheckBox; + - function Explode(var a: TStrArray; Border, S: string): Integer; - function BarCodeValid (ACode: string): boolean; - function Sto_GetFmtFileVersion(const FileName: String = ''; const Fmt: String = '%d.%d.%d.%d'): String; - function TColorToHex(Color : TColor) : string; - function HexToTColor(sColor : string) : TColor; function getProddato() : TDate; function getProddag() : String; function retRutenummer(rutenummer : String) : String; - function GetCurrentPrinterHandle() : THandle; - function SavePChar(p: PChar): PChar; - function AdobeReaderExists(): Boolean; - function FileTime2DateTime(FileTime: TFileTime): TDateTime; - function split(input: string; schar: Char; s: Integer): string; - function CheckUrl(url:string):boolean; procedure PlaySound(filename : PWideChar); procedure StartScreen(); @@ -132,8 +142,8 @@ procedure Button1Click(Sender: TObject); procedure ListBox1DrawItem(Control: TWinControl; Index: Integer; Rect: TRect; State: TOwnerDrawState); procedure Budlevering1Click(Sender: TObject); - procedure DownloadButton01Click(Sender: TObject); - procedure OpdaterListenButton01Click(Sender: TObject); + procedure BtnDownloadKontrolfilClick(Sender: TObject); + procedure BtnOpdaterListenClick(Sender: TObject); procedure DownloadBladhusRuteskiftfil(); procedure DownloadBladhusKontrolfil(); procedure SendFilTilDAO(fil_type, filnavn_input, filnavn_output: String); @@ -141,10 +151,10 @@ procedure UploadInifilTilDAO(); procedure SletStregkodelinieFraListboks2(StregKode : String); procedure FormDestroy(Sender: TObject); - procedure UploadButton01Click(Sender: TObject); - procedure DownloadButton03Click(Sender: TObject); + procedure BtnUploadLogfilClick(Sender: TObject); + procedure BtnDownloadRuteskiftFilClick(Sender: TObject); procedure Pakkeshoplevering1Click(Sender: TObject); - procedure PakkeshopNulstilClick(Sender: TObject); + procedure btnNulstilClick(Sender: TObject); procedure Returpakkerfrapakkeshop1Click(Sender: TObject); procedure InitNatxpresslevering(); procedure InitReturFraDao(); @@ -156,10 +166,9 @@ procedure Altidprintepakkelabel1Click(Sender: TObject); procedure chkAltidPrintLabelClick(Sender: TObject); - procedure EKLoverforselClick(Sender: TObject); + procedure BtnEKLoverforselClick(Sender: TObject); procedure Uploadlogfil1Click(Sender: TObject); procedure Manual1Click(Sender: TObject); - procedure CheckPrintQue(tjektype : string); procedure Timer1Timer(Sender: TObject); procedure Scanogstjekkoden1Click(Sender: TObject); procedure chkScanTjekkodeClick(Sender: TObject); @@ -179,11 +188,17 @@ procedure SletLogfiler(Path: string; FileList: TStrings); procedure Manualgenerel1Click(Sender: TObject); procedure TjekkerUrls(); -// 20150310: start - procedure RoundCornerOf(Control: TWinControl); + procedure TjekkerEnkeltUrl(UrlNavn: String; Url: String; var urlFejl: integer); + procedure menuIndleveringClick(Sender: TObject); + + + + //Nedarvet fra IParentForm + procedure LogMessage( msg : string); + procedure SetPrinterstatusText( txt: string; alert: boolean); + function GetFormObject() : TForm; -// 20150310: slut private SpecialVersionSted, SpecialVersionScanningtype: String; // Bruges når programmet skal bruges udenfor DAO scanningssteder @@ -191,48 +206,32 @@ SkrivLog : String; Sted : String; StedNavn : String; - Url, UrlNormal, UrlReturDAO, UrlReturBoghandler, UrlBudlevering, UrlManglendeScanninger, UrlPakkeshoplevering, UrlReturPakkeshop, UrlPakkeshopManglendeScanninger, UrlPakkeshopManglendeReturScanninger,UrlEKLoverforsel : String; -// 29150330: start + Url, UrlNormal, UrlReturDAO, UrlReturBoghandler, UrlBudlevering, UrlManglendeScanninger, UrlPakkeshoplevering, + UrlReturPakkeshop, UrlPakkeshopManglendeScanninger, UrlPakkeshopManglendeReturScanninger,UrlIndleveringsPakke, + UrlIndleveringsPakkeManglendeScanninger,UrlEKLoverforsel, URLOmdirigerTilPakkeshop : String; + UrlEKLoverforselPakkeshop : String; -// 20150330: slut + UrlFindPakketype, UrlSendPrograminfo: String; Scanningtype, TestFunktionen, Pakketype, SporgEfterBoghandler : String; ScanTjekkode : String; ScanTjekkodeAutomatik : string; - Farve, FarveNormal, FarveReturDAO, FarveReturBoghandler, FarveBudlevering, FarvePakkeshoplevering, FarveReturPakkeshop, FarveIndlevering : String; - Titel, TitelNormal, TitelReturDAO, TitelReturBoghandler, TitelBudlevering, TitelPakkeshoplevering, TitelReturPakkeshop, TitelIndlevering : String; - LabelType : integer; + + Farve, FarveNormal, FarveReturDAO, FarveReturBoghandler, FarveBudlevering, FarvePakkeshoplevering, FarveReturPakkeshop, + FarveIndlevering : String; + + Titel, TitelNormal, TitelReturDAO, TitelReturBoghandler, TitelBudlevering, TitelPakkeshoplevering, TitelReturPakkeshop, + TitelIndlevering : String; + AlarmLyd : String; ScannetOkLyd : String; ScannetOkStorLyd : String; -// 20150317: start + ScannetOkTilTjekkodeLyd : String; -// 20150317: slut + PrinterNavn : String; TjekPrinter : String; - XPosRute : integer; - YPosRute : integer; - FontSizeRute : integer; - FontSizeRuteLille : integer; - XPosKommentar : integer; - YPosKommentar : integer; - FontSizeKommentar : integer; - XPosBoghandler : integer; - YPosBoghandler : integer; - FontSizeBoghandler : integer; - XPosKoreliste : integer; - YPosKoreliste : integer; - FontSizeKoreliste : integer; - FontSizeKorelisteLille : integer; - XPosSorteringsfelt1 : integer; - YPosSorteringsfelt1 : integer; - FontSizeSorteringsfelt1 : integer; - XPosSorteringsfelt2 : integer; - YPosSorteringsfelt2 : integer; - FontSizeSorteringsfelt2 : integer; - XPosSmskode : integer; - YPosSmskode : integer; - FontSizeSmskode : integer; + Org_RuteNummerST, Org_BoghandlerNavnST, Org_KommentarST : String; BladhusSted : Integer; BladhusStedKode : Array of string; @@ -245,11 +244,13 @@ PakkeshopStregkode, PakkeshopTjekkode : String; BoghandlerStregkode, BoghandlerTjekkode : String; TjekUrls : String; + Config : TConfiguration; - function CheckSumModulo10(const data:string):string; { used for EAN 8/13 } + + LabelPrint: TLabelPrint; procedure PrintLabel(RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted : String; var PrintNyLabel : Boolean; BoghandlerNummer : String = ''); - procedure SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted : String; var PrintNyLabel : Boolean; BoghandlerNummer : string = ''); + procedure HentPakkeInfoFraServer(const Sted, PakkeNr : String; var RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted : String; var PrintNyLabel: Boolean; BoghandlerNummer : String = ''); procedure CheckCode(); procedure IndlesManglendeScanninger(); @@ -258,12 +259,13 @@ procedure IndlesScanningLogFil(); procedure SkrivScanningLogFil(var tekst : string); function TjekKoreliste(var RuteNummer, Koreliste : string) : string; - procedure VisAlarmSkaerm(var List1msg: string); + procedure VisAlarmSkaerm(strMessage: string); public { Public declarations } end; + var MainForm: TMainForm; @@ -277,30 +279,14 @@ implementation {$R *.dfm} -function TMainForm.TColorToHex(Color : TColor) : string; -begin - Result := - IntToHex(GetRValue(Color), 2) + - IntToHex(GetGValue(Color), 2) + - IntToHex(GetBValue(Color), 2) ; -end; - -function TMainForm.HexToTColor(sColor : string) : TColor; -begin - Result := - RGB( - StrToInt('$'+Copy(sColor, 1, 2)), - StrToInt('$'+Copy(sColor, 3, 2)), - StrToInt('$'+Copy(sColor, 5, 2)) - ) ; -end; + +//FormCreate kaldes før InitForm procedure TMainForm.InitForm(Farve,Titel,Url : String); begin -// 20150309: startr StaticTextManglendePakker.Caption := ''; -// 20150309: slut + PanelValg1.Color := clBtnFace; if PanelValg1.Enabled = true then @@ -344,7 +330,7 @@ PanelValg7.Font.Color := clWindowText; end; - OpdaterListenButton01.Enabled := false; + BtnOpdaterListen.Enabled := false; if (BladhusSted > 00) and (BladhusSted < Length(BladhusStedNavn)) then begin @@ -372,9 +358,11 @@ else if (Sted = 'BR') then begin StedNavn := 'Brøndby: '; end else if (Sted = 'BK') then - begin StedNavn := 'Bladkompagniet: '; end + begin StedNavn := 'Bladkompagniet/ISV: '; end + else if (Sted = 'TK') then + begin StedNavn := 'BK/Trykkompagniet: '; end else if (Sted = 'DBK') then - begin StedNavn := 'DBK Køge: '; end + begin StedNavn := 'DBK/Køge: '; end else if (Sted = '1') then begin StedNavn := 'Ålborg: '; end else if (Sted = '2') then @@ -398,7 +386,7 @@ StartScreen(); MainForm.Caption := Titel; - MainForm.Color := HexToTColor(Farve); + MainForm.Color := TUtils.HexToTColor(Farve); MainForm.Farve := Farve; MainForm.Titel := Titel; MainForm.Url := Url; @@ -458,17 +446,18 @@ end else begin - logTekst := 'Speciel version til: '+split(Titel, ':', 2)+' ('+Sted+')'; + logTekst := 'Speciel version til: ' + TUtils.split(Titel, ':', 2) + ' ('+Sted+')'; end; SkrivScanningLogFil(logTekst); end else begin - logTekst := 'Speciel version til: '+split(Titel, ':', 2)+' ('+SpecialVersionSted+')'; + logTekst := 'Speciel version til: ' + TUtils.split(Titel, ':', 2) + ' ('+SpecialVersionSted+')'; SkrivScanningLogFil(logTekst); end; end; + end; procedure TMainForm.Altidprintepakkelabel1Click(Sender: TObject); @@ -507,54 +496,38 @@ procedure TMainForm.Automatiskvalg1Click(Sender: TObject); begin -// 20150317: start -(* - if Automatiskvalg1.Checked then - begin - AutomatiskValg1.Checked := true; - PanelValgA.Color := clGreen; - PanelValgA.Font.Color := clWhite; - end - else - begin - AutomatiskValg1.Checked := false; - PanelValgA.Color := clBtnFace; - PanelValgA.Font.Color := clWindowText; - end; -*) // Skal ikke toggle men bare sætte funktionen on // Fravælges ved at vælge en scanningstype AutomatiskValg1.Checked := true; PanelValgA.Color := clGreen; PanelValgA.Font.Color := clWhite; -// 20150317: slut end; + +//InitForm kaldes før FormCreate procedure TMainForm.FormCreate(Sender: TObject); const crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed var - printerInd : integer; - i : Integer; -// 20150310: start gemScanningtype : String; -// 20150310: slut begin + + // Initierer nogle variabler BladhusSted := 00; Application.ShowHint := True; PrinterstatusStaticText1.Caption := ''; PrinterstatusStaticText1.Color := MainForm.Color; - PakkeshopNulstil.BringToFront; + btnNulstil.BringToFront; - RoundCornerOf(PanelManglendePakker1); - RoundCornerOf(PanelManglendePakker2); - RoundCornerOf(PanelManglendePakker3); - RoundCornerOf(PanelManglendePakker4); - RoundCornerOf(PanelManglendePakker5); - RoundCornerOf(PanelManglendePakker6); + TUtils.RoundCornerOf(PanelManglendePakker1); + TUtils.RoundCornerOf(PanelManglendePakker2); + TUtils.RoundCornerOf(PanelManglendePakker3); + TUtils.RoundCornerOf(PanelManglendePakker4); + TUtils.RoundCornerOf(PanelManglendePakker5); + TUtils.RoundCornerOf(PanelManglendePakker6); // Hvis mappen Docs eksisterer kan vi vælge Manual i menuen Hjælp @@ -568,9 +541,15 @@ MainForm.ClientWidth := 1000; MainForm.ClientHeight := 750; + Config := TConfiguration.Create(); + Config.ReadFromInifile( TIniFile.Create(ChangeFileExt(Application.ExeName,'.ini')) ); //ToDo: clean up duplicate ini ref + Config.Sted := Sted; + // Læser parametre fra ini filen with TIniFile.Create(ChangeFileExt(Application.ExeName,'.ini')) do try + + SkrivLog := ReadString('Settings','SkrivLog','0'); Sted := ReadString('Settings','Sted',''); StedNavn := ReadString('Settings','Stednavn',''); @@ -589,7 +568,15 @@ UrlReturPakkeshop := ReadString('Settings','UrlReturPakkeshop','http://omdeling.info/webservices/pakkeshop/returpakkekontrol.php?sted=%s&stregkode=%s'); UrlPakkeshopManglendeScanninger := ReadString('Settings','UrlPakkeshopManglendeScanninger','http://omdeling.info/webservices/pakkeshop/pakkemanglendescanninger.php?sted=%s'); UrlPakkeshopManglendeReturScanninger := ReadString('Settings','UrlPakkeshopManglendeReturScanninger','http://omdeling.info/webservices/pakkeshop/pakkemanglendereturscanninger.php?sted=%s'); - LabelType := ReadInteger('Settings','LabelType',1); + + + UrlIndleveringsPakke := ReadString('Settings','UrlIndleveringsPakke','http://omdeling.info/webservices/pakkeshop/PakkekontrolIndleveringskode.php?sted=%s&pakkekode=%s'); + UrlIndleveringsPakkeManglendeScanninger := ReadString('Settings', 'UrlIndleveringsPakkeManglendeScanninger','http://omdeling.info/webservices/pakkeshop/IndleveringsPakkeManglendeScanninger.php?sted=%s'); + URLOmdirigerTilPakkeshop := ReadString('Settings', 'URLOmdirigerTilPakkeshop','http://omdeling.info/webservices/pakkeshop/PakkeKontrolOmdirigerTilPakkeshop.php?sted=%s&stregkode=%s'); + + + + FarveNormal := ReadString('Settings','FarveNormal','D8D8D8'); TitelNormal := ReadString('Settings','TitelNormal','Modtagelse af DAO NAT X-PRESS pakker'); FarveReturDAO := ReadString('Settings','FarveReturDAO','A9F5A9'); @@ -626,11 +613,11 @@ if (SkrivLog = '1') then begin - logTekst := 'Program start (Version: ' + Sto_GetFmtFileVersion('','') + ') Dato: ' + FormatDateTime('yyyy-mm-dd hh:nn:ss',now); + logTekst := 'Program start (Version: ' + TUtils.Sto_GetFmtFileVersion('') + ') Dato: ' + FormatDateTime('yyyy-mm-dd hh:nn:ss',now); try SkrivScanningLogFil(logTekst); Uploadlogfil1.Enabled := true; - UploadButton01.Enabled := true; + BtnUploadLogfil.Enabled := true; logTekst := 'Programmet er installeret som: '+ParamStr(0); SkrivScanningLogFil(logTekst); // Oprydning i gamle logfiler @@ -648,75 +635,7 @@ PanelValgA.Font.Color := clWhite; end; - if LabelType = 0 then - begin - XPosRute := ReadInteger('RuteBred','XPos',1); - YPosRute := ReadInteger('RuteBred','YPos',1); - FontSizeRute := ReadInteger('RuteBred','FontSize',72); - FontSizeRuteLille := ReadInteger('RuteBred','FontSizeLille',20); - XPosKommentar := ReadInteger('KommentarBred','XPos',1); - YPosKommentar := ReadInteger('KommentarBred','YPos',250); - FontSizeKommentar := ReadInteger('KommentarBred','FontSize',16); - XPosBoghandler := ReadInteger('BoghandlerBred','XPos',1); - YPosBoghandler := ReadInteger('BoghandlerBred','YPos',400); - FontSizeBoghandler := ReadInteger('BoghandlerBred','FontSize',16); - XPosKoreliste := ReadInteger('KorelisteSmal','XPos',1); - YPosKoreliste := ReadInteger('KorelisteSmal','YPos',100); - FontSizeKoreliste := ReadInteger('KorelisteSmal','FontSize',72); - FontSizeKorelisteLille := ReadInteger('KorelisteSmal','FontSizeLille',20); - XPosSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','XPos',700); - YPosSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','YPos',100); - FontSizeSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','FontSize',16); - XPosSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','XPos',700); - YPosSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','YPos',150); - FontSizeSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','FontSize',16); - XPosSmskode := ReadInteger('SmskodeSmal','XPos',1); - YPosSmskode := ReadInteger('SmskodeSmal','YPos',300); - FontSizeSmskode := ReadInteger('SmskodeSmal','FontSize',32); - end - else - begin - XPosRute := ReadInteger('RuteSmal','XPos',1); - YPosRute := ReadInteger('RuteSmal','YPos',1); - FontSizeRute := ReadInteger('RuteSmal','FontSize',72); - FontSizeRuteLille := ReadInteger('RuteSmal','FontSizeLille',20); - XPosKommentar := ReadInteger('KommentarSmal','XPos',1); - YPosKommentar := ReadInteger('KommentarSmal','YPos',250); - FontSizeKommentar := ReadInteger('KommentarSmal','FontSize',16); - XPosBoghandler := ReadInteger('BoghandlerSmal','XPos',1); - YPosBoghandler := ReadInteger('BoghandlerSmal','YPos',400); - FontSizeBoghandler := ReadInteger('BoghandlerSmal','FontSize',16); - XPosKoreliste := ReadInteger('KorelisteSmal','XPos',1); - YPosKoreliste := ReadInteger('KorelisteSmal','YPos',100); - FontSizeKoreliste := ReadInteger('KorelisteSmal','FontSize',72); - FontSizeKorelisteLille := ReadInteger('KorelisteSmal','FontSizeLille',20); - XPosSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','XPos',700); - YPosSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','YPos',100); - FontSizeSorteringsfelt1 := ReadInteger('Sorteringsfelt1Smal','FontSize',16); - XPosSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','XPos',700); - YPosSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','YPos',150); - FontSizeSorteringsfelt2 := ReadInteger('Sorteringsfelt2Smal','FontSize',16); - XPosSmskode := ReadInteger('SmskodeSmal','XPos',1); - YPosSmskode := ReadInteger('SmskodeSmal','YPos',300); - FontSizeSmskode := ReadInteger('SmskodeSmal','FontSize',32); - if LabelType = 2 then // test på alm. printer kræver at XY-positionerne ganges med 3 - begin - XPosRute := XPosRute * 3; - YPosRute := YPosRute * 3; - XPosKommentar := XPosKommentar * 3; - YPosKommentar := YPosKommentar * 3; - XPosBoghandler := XPosBoghandler * 3; - YPosBoghandler := YPosBoghandler * 3; - XPosKoreliste := XPosKoreliste * 3; - YPosKoreliste := YPosKoreliste * 3; - XPosSorteringsfelt1 := XPosSorteringsfelt1 * 3; - YPosSorteringsfelt1 := YPosSorteringsfelt1 * 3; - XPosSorteringsfelt2 := XPosSorteringsfelt2 * 3; - YPosSorteringsfelt2 := YPosSorteringsfelt2 * 3; - XPosSmskode := XPosSmskode * 3; - YPosSmskode := YPosSmskode * 3; - end; - end; + if SporgEfterBoghandler = '1' then begin @@ -769,6 +688,23 @@ //SpecialVersionSted := 'FD'; // FD - sætter automatisk nedenstående SpecialVersionScanningtype til DIREKTE) // *************************** // +{$IfDef STED_BK} + SpecialVersionSted := 'BK'; +{$EndIf} +{$IfDef STED_TK} + SpecialVersionSted := 'TK';// BK-Trykkompagniet +{$EndIf} +{$IfDef STED_DBK} + SpecialVersionSted := 'DBK'; +{$EndIf} +{$IfDef STED_FD} + SpecialVersionSted := 'FD'; +{$EndIf} +{$IfDef STED_NS} + SpecialVersionSted := 'NS'; +{$EndIf} + + //SpecialVersionSted := '01'; // NS - bruges sammen med nedenstående SpecialVersionScanningtype DIREKTE) //SpecialVersionSted := '02'; // BK - BRUGES IKKE (brug i stedet ovenstående SpecialVersionSted BK) //SpecialVersionSted := '03'; // FD - (bruges sammen med nedenstående SpecialVersionScanningtype DIREKTE) @@ -784,7 +720,6 @@ // Hvis specialversion er valgt (SpecialVersionSted er sat til en værdi ovenfor) // ændrer vi Sted og Scanningtype her: -// 20150313: start if SpecialVersionSted = 'NS' then begin SpecialVersionSted := '01'; @@ -795,9 +730,8 @@ SpecialVersionSted := '03'; SpecialVersionScanningtype := '4'; end; -// 20150313: slut - if SpecialVersionSted = 'BK' then + if (SpecialVersionSted = 'BK') OR (SpecialVersionSted = 'TK') then begin //FarveNormal := 'A9F5A9'; // her kan vi evt. overrule ini fil Sted := SpecialVersionSted; @@ -806,12 +740,15 @@ PanelValg2.Font.Color := clInactiveCaption; PanelValg3.Enabled := false; PanelValg3.Font.Color := clInactiveCaption; - PanelValg6.Enabled := false; - PanelValg6.Font.Color := clInactiveCaption; + //PanelValg6.Enabled := false; + //PanelValg6.Font.Color := clInactiveCaption; + // her skal vi også disable de menupunkter BK ikke kan bruge ReturpakkerfraDAO1.Enabled := false; Returpakkerfraboghandler1.Enabled := false; - Returpakkerfrapakkeshop1.Enabled := false; + + //Returpakkerfrapakkeshop1.Enabled := false; + if SpecialVersionScanningtype = 'A' then begin Scanningtype := '1'; @@ -835,6 +772,8 @@ PanelValg5.Font.Color := clInactiveCaption; PanelValg6.Enabled := false; PanelValg6.Font.Color := clInactiveCaption; + + // her skal vi også disable de menupunkter DBK ikke kan bruge ReturpakkerfraDAO1.Enabled := false; Returpakkerfraboghandler1.Enabled := false; @@ -871,6 +810,8 @@ PanelValg5.Font.Color := clInactiveCaption; PanelValg6.Enabled := false; PanelValg6.Font.Color := clInactiveCaption; + PanelValg7.Enabled := false; + PanelValg7.Font.Color := clInactiveCaption; // her skal vi også disable de menupunkter Bladhusene (01, 02, 03 og 04) ikke kan bruge Automatiskvalg1.Enabled := false; @@ -966,7 +907,7 @@ RutenummerST.Caption := ''; BoghandlerNavnST.Caption := 'Fejl i urls'; KommentarST.Caption := 'Se log vinduet'; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; exit; end; end @@ -1061,14 +1002,10 @@ end; - if (PrinterNavn <> '') then - begin - printerInd := Printer.Printers.IndexOf(printerNavn); - if printerInd >= 0 then - Printer.PrinterIndex := printerInd; - end; - CheckPrintQue('Opstart'); + + LabelPrint := TLabelPrint.Create( self, Config, PrinterNavn ); + LabelPrint.CheckPrintQue('Opstart', PrinterNavn); finally Free; @@ -1135,7 +1072,7 @@ Scanningtype := gemScanningtype; SendInfoTilServer(Sted, Scanningtype, 'Begin', ''); - SendInfoTilServer(Sted, Scanningtype, 'ProgramVersion', Sto_GetFmtFileVersion('','')); + SendInfoTilServer(Sted, Scanningtype, 'ProgramVersion', TUtils.Sto_GetFmtFileVersion('')); end; @@ -1153,7 +1090,6 @@ BoghandlerNavn : String; Koreliste : String; PrintNyLabel : Boolean; - List1msg : String; pakkeErScannet : Integer; pakkeForkertSted : Integer; tjekkodeMangler : Integer; @@ -1193,6 +1129,9 @@ or (NumberString = 'Retur fra kunde') or (NumberString = 'DAO DIREKTE') or (NumberString = 'DAO PAKKESHOP') + or (NumberString = 'DAO PAKKESHOP') + or (LowerCase(NumberString) = 'for stor hjemmelevering' ) + or (LowerCase(NumberString) = 'for stor daodirekte' ) or (NumberString = 'Retur fra pakkeshop') then begin @@ -1203,39 +1142,31 @@ begin ShowMessage('Indsæt et gyldigt pakkenummer - uden linieskift'); end; - end; + end; // Slut ctrl-v if Key = #13 then // Enter begin - if (Length(Trim(Stregkode)) = 0) then + + // Sikre at den er trimmet inden vi går videre - DBK kan finde på at encode et space i enden af deres barcodes + Stregkode := Trim(Stregkode); + + if (Length(Stregkode) = 0) then begin - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'Der skal scannes en stregkode...'; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - RuteNummerST.Caption := ''; - BoghandlerNavnST.Caption := ''; - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; + VisAlarmSkaerm( 'Der skal scannes en stregkode...' ); + exit; end; if StregKode = 'Nulstil' then begin - PakkeshopNulstil.Click(); + btnNulstil.Click(); exit; end; - if PakkeshopNulstil.Visible then + if btnNulstil.Visible then begin - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'HUSK at klikke Nulstil før ny scanning...'; + VisAlarmSkaerm( 'HUSK at klikke Nulstil før ny scanning...' ); - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - KommentarST.Caption := List1msg; - Stregkode := ''; - StregkodeST.Caption := StregKode; exit; end; @@ -1247,7 +1178,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1262,13 +1193,29 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; exit; end; + if (LowerCase(StregKode) = 'for stor hjemmelevering') OR (LowerCase(StregKode) = 'for stor daodirekte') then + begin + if chkForstorTilDirekte.Enabled then + begin + chkForstorTilDirekte.Checked := true; + end + else + begin + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på denne scannings tilstand' ); + end; + Stregkode := ''; + StregkodeST.Caption := StregKode; + exit; + end; + + if StregKode = 'Indtast kundenummer' then begin if chkSporgEfterKunde.Enabled = true then @@ -1284,7 +1231,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1306,7 +1253,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1321,7 +1268,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm(Stregkode + ' kan ikke vælges på dette scanningsted'); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1337,7 +1284,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm(Stregkode + ' kan ikke vælges på dette scanningsted'); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1352,7 +1299,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1367,7 +1314,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1382,7 +1329,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1397,7 +1344,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1412,7 +1359,7 @@ end else begin - VisAlarmSkaerm(List1msg); + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); end; Stregkode := ''; StregkodeST.Caption := StregKode; @@ -1466,31 +1413,19 @@ Pakkescanningtype := Scanningtype; end; - if ( (Pakkescanningtype = '1') and (PanelValg1.Enabled = false) - or (Pakkescanningtype = '2') and (PanelValg2.Enabled = false) - or (Pakkescanningtype = '3') and (PanelValg3.Enabled = false) - or (Pakkescanningtype = '4') and (PanelValg4.Enabled = false) - or (Pakkescanningtype = '5') and (PanelValg5.Enabled = false) - or (Pakkescanningtype = '6') and (PanelValg6.Enabled = false) ) then + if ( ( (Pakkescanningtype = '1') and (PanelValg1.Enabled = false) ) + or ( (Pakkescanningtype = '2') and (PanelValg2.Enabled = false) ) + or ( (Pakkescanningtype = '3') and (PanelValg3.Enabled = false) ) + or ( (Pakkescanningtype = '4') and (PanelValg4.Enabled = false) ) + or ( (Pakkescanningtype = '5') and (PanelValg5.Enabled = false) ) + or ( (Pakkescanningtype = '6') and (PanelValg6.Enabled = false) ) ) then begin // Her skal komme en alarm og rød skærm - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'Pakketype ' + Pakketype + ' kan ikke scannes på dette scanningsted'; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - - RuteNummerST.Caption := ''; - BoghandlerNavnST.Caption := ''; - - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; - - StregKode := ''; - StregkodeST.Caption := StregKode; + VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); exit; end; - if Automatiskvalg1.Checked and (Length(Stregkode) > 8) then + if (Automatiskvalg1.Checked and (Length(Stregkode) > 8) ) then begin GemStregkode := Stregkode; if Pakketype = 'NatXpress' then @@ -1522,20 +1457,10 @@ // Retur kan ikke scannes med 'Automatisk valg' else - begin // Her skal komme en alarm og rød skærm - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'Pakken kan ikke scannes med automatisk valg'; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - - RuteNummerST.Caption := ''; - BoghandlerNavnST.Caption := ''; - - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; - - StregKode := ''; - StregkodeST.Caption := StregKode; + begin + // Her skal komme en alarm og rød skærm + //VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); + VisAlarmSkaerm( Stregkode + ' kan ikke bruges med automatisk valg' ); exit; end; @@ -1543,19 +1468,7 @@ end else if Automatiskvalg1.Checked and (PakkeshopText1.Caption = 'Stregkode') then begin - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'Pakkenummer ikke gyldigt (for kort)'; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - - RuteNummerST.Caption := ''; - BoghandlerNavnST.Caption := ''; - - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; - - StregKode := ''; - StregkodeST.Caption := StregKode; + VisAlarmSkaerm( 'Pakkenummer ikke gyldigt (for kort)' ); exit; end; @@ -1564,18 +1477,9 @@ begin if ( (Pakkescanningtype <> Scanningtype) and (Scanningtype <> '2') and (Scanningtype <> '3') ) then begin - PlaySound(PWideChar(AlarmLyd)); - List1msg := 'Pakke findes som pakketype: ' + Pakketype; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - RuteNummerST.Caption := ''; - BoghandlerNavnST.Caption := ''; + VisAlarmSkaerm( 'Pakke findes som pakketype: ' + Pakketype ); - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; - StregKode := ''; - StregkodeST.Caption := StregKode; exit; end; end; @@ -1601,7 +1505,7 @@ BoghandlerStregkode := Stregkode; BoghandlerTjekkode := ''; PakkeshopText1.Caption := 'Stregkode'; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; Stregkode := ''; InitScreen(); end @@ -1613,7 +1517,7 @@ BoghandlerStregkode := Stregkode; BoghandlerTjekkode := '-1'; PakkeshopText1.Caption := 'Stregkode'; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; Stregkode := ''; InitScreen(); end @@ -1625,19 +1529,13 @@ PakkeshopStregkode := Stregkode; BoghandlerStregkode := Stregkode; PakkeshopText1.Caption := 'Tjekkode'; -// 20150317: start + PlaySound(PWideChar(ScannetOkTilTjekkodeLyd)); -// 20150317: slut + end else begin - List1msg := 'Du skal scanne en stregkode'; - ListBox1.Items.Insert(0,List1Msg); - //logTekst := RightStr(List1Msg, Length(List1Msg)-10); - //SkrivScanningLogFil(logTekst); - PlaySound(PWideChar(AlarmLyd)); - PakkeshopNulstil.Visible := true; - MainForm.Color := clRed; + VisAlarmSkaerm( 'Du skal scanne en stregkode' ); end; Stregkode := ''; InitScreen(); @@ -1650,28 +1548,21 @@ BoghandlerTjekkode := Stregkode; PakkeshopText1.Caption := 'Stregkode'; if (PakkeshopLevering1.Checked) then - MainForm.Color := HexToTColor(FarvePakkeshoplevering); + MainForm.Color := TUtils.HexToTColor(FarvePakkeshoplevering); if (Pakkernormal1.Checked) then - MainForm.Color := HexToTColor(FarveNormal); - PakkeshopNulstil.Visible := false; + MainForm.Color := TUtils.HexToTColor(FarveNormal); + btnNulstil.Visible := false; end else begin if (PakkeshopLevering1.Checked) then - List1msg := 'Du skal scanne en tjekkode til stregkode ' + PakkeshopStregkode; + VisAlarmSkaerm('Du skal scanne en tjekkode til stregkode ' + PakkeshopStregkode); if (Pakkernormal1.Checked) then - List1msg := 'Du skal scanne en tjekkode til stregkode ' + BoghandlerStregkode; - KommentarST.Caption := List1msg; - ListBox1.Items.Insert(0,List1Msg); - //logTekst := RightStr(List1Msg, Length(List1Msg)-10); - //SkrivScanningLogFil(logTekst); - PlaySound(PWideChar(AlarmLyd)); - PakkeshopNulstil.Visible := true; - MainForm.Color := clRed; -// 20150323: start + VisAlarmSkaerm('Du skal scanne en tjekkode til stregkode ' + BoghandlerStregkode); + StregKode := ''; StregkodeST.Caption := StregKode; -// 20150323: slut + exit; end; Stregkode := ''; @@ -1680,6 +1571,7 @@ if not PakkeshopLevering1.Checked and not Pakkernormal1.Checked or (PakkeshopLevering1.Checked and (PakkeshopStregkode <> '') and (PakkeshopTjekkode <> '')) or (Pakkernormal1.Checked and (Scanogstjekkoden1.Checked and (BoghandlerStregkode <> '') and (BoghandlerTjekkode <> '') or not Scanogstjekkoden1.Checked)) then begin + if PakkeshopLevering1.Checked and (PakkeshopStregkode <> '') and (PakkeshopTjekkode <> '') then StregKode := PakkeshopStregkode; if Pakkernormal1.Checked and ((BoghandlerStregkode <> '') and (BoghandlerTjekkode <> '') or not Scanogstjekkoden1.Checked) then @@ -1692,12 +1584,8 @@ // Hvis der var sql fejl i opdateringen skal dette fejlmeldes her if Rutenummer = 'sql fejl' then begin // Her skal komme en alarm og rød skærm - PlaySound(PWideChar(AlarmLyd)); - //List1msg := 'SQL fejl: ' + Kommentar; - //ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - //KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; + VisAlarmSkaerm( 'SQL fejl: ' + Kommentar ); + exit; end; if (Pakkernormal1.Checked or Budlevering1.Checked or PakkeshopLevering1.Checked) then @@ -1717,13 +1605,13 @@ if (pakkeErScannet > 0) or (pakkeForkertSted > 0) or (tjekkodemangler > 0) then begin PlaySound(PWideChar(AlarmLyd)); - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; MainForm.Color := clRed; end; end; if ( Pakkernormal1.Checked and (pakkeErScannet = 0) and (pakkeForkertSted = 0) and (tjekkodemangler = 0) and (RuteNummerST.Caption <> 'Ukendt') ) or (Copy(Kommentar,1,2) = 'Ok') then begin - MainForm.Color := HexToTColor(Farve); + MainForm.Color := TUtils.HexToTColor(Farve); if Storepakker1.Checked then begin PlaySound(PWideChar(ScannetOkStorLyd)); @@ -1732,11 +1620,11 @@ begin PlaySound(PWideChar(ScannetOkLyd)); end; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; end else if (Returpakkerfradao1.Checked or Returpakkerfraboghandler1.Checked) then begin - MainForm.Color := HexToTColor(Farve); + MainForm.Color := TUtils.HexToTColor(Farve); if Storepakker1.Checked then begin PlaySound(PWideChar(ScannetOkStorLyd)); @@ -1745,30 +1633,23 @@ begin PlaySound(PWideChar(ScannetOkLyd)); end; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; end else if Copy(Kommentar,1,8) = 'OPRETTET' then begin - List1msg := 'Pakke ' + PakkeshopStregkode + ' skal gemmes på lager indtil data modtages'; - ListBox1.Items.Insert(0,List1Msg); - MainForm.Color := clRed; - PlaySound(PWideChar(AlarmLyd)); - PakkeshopNulstil.Visible := true; + VisAlarmSkaerm( 'Pakke ' + PakkeshopStregkode + ' skal gemmes på lager indtil data modtages' ); end else if Kommentar = StregKode then // budlevering til 'Ukendt tur' begin end else begin - MainForm.Color := clRed; - PlaySound(PWideChar(AlarmLyd)); - PakkeshopNulstil.Visible := true; + VisAlarmSkaerm(''); end; - if not PakkeshopNulstil.Visible then + + if not btnNulstil.Visible then begin -// 20150310: start -// SletStregkodelinieFraListboks2(StregKode); -// 20150310: slut + If (Budlevering1.Checked) then begin if Storepakker1.Checked then @@ -1782,9 +1663,9 @@ InitLillePakke(); end; end; -// 20150310: start + SletStregkodelinieFraListboks2(StregKode); -// 20150310: slut + PakkeshopStregkode := ''; PakkeshopTjekkode := ''; BoghandlerStregkode := ''; @@ -1815,8 +1696,15 @@ Key := #0; + + + + + end; //End of OnKeyPress + + procedure TMainForm.SendInfoTilServer(Sted, Scanningtype, Infotype, Info : String); const crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed @@ -1858,7 +1746,7 @@ begin - if Budlevering1.Checked or Pakkeshoplevering1.Checked or Returpakkerfrapakkeshop1.Checked or Pakkernormal1.Checked then + if Budlevering1.Checked or Pakkeshoplevering1.Checked or Returpakkerfrapakkeshop1.Checked or Pakkernormal1.Checked or menuIndlevering.Checked then begin for i := ListBox2.items.count-1 downto 0 do if pos(StregKode,ListBox2.items[i]) <> 0 then @@ -1869,11 +1757,11 @@ if (pos('/', wrkAntal) > 0) then // både pakker idag og senere begin wrkAntal := wrkAntal + '/'; // tilføjer '/' sidst i feltet af hensyn til split funktionen - wrkAntalIdag := StrToInt(split(wrkAntal, '/', 2)); + wrkAntalIdag := StrToInt( TUtils.split(wrkAntal, '/', 2)); // ShowMessage(SPLIT('data/another/yet/again/more/','/',3)); // ShowMessage(SPLIT('data/another/','/',3)); // ShowMessage(SPLIT('data/another','/',3)); - wrkAntalSenere := StrToInt(split(wrkAntal, '/', 3)); + wrkAntalSenere := StrToInt( TUtils.split(wrkAntal, '/', 3)); end else // kun idag begin @@ -1977,7 +1865,7 @@ PanelManglendePakker6.Visible := false; end; end; -// 20150310: slut + ListBox2.items.delete(i); end; end; @@ -2004,8 +1892,6 @@ end; procedure TMainForm.InitBladhus(); -var - LogFilnavn : string; begin Altidprintepakkelabel1.Enabled := false; @@ -2015,47 +1901,7 @@ Sprgefterboghandlernummer1.Enabled := false; ListBox1.Visible := true; // TestFunktionen := '1'; -// 20150317: start -(* - if TestFunktionen = '1' then - begin - Testforbindelsen1.Visible := true; - Testprinter1.Visible := true; - Testlyd1.Visible := true; - Testlyd2.Visible := true; - end - else if TestFunktionen = '2' then - begin - Testforbindelsen1.Enabled := false; - Testprinter1.Enabled := false; - Testlyd1.Enabled := false; - Testlyd2.Enabled := false; - end - else - begin - Testforbindelsen1.Visible := false; - Testprinter1.Visible := false; - Testlyd1.Visible := false; - Testlyd2.Visible := false; - end; - Testprinter1.Visible := false; - AlarmLyd := 'Sounds\Alarm.wav'; - if not FileExists(AlarmLyd) then - begin - AlarmLyd := ''; - end; - ScannetOkLyd := 'Sounds\Ok.wav'; - if not FileExists(ScannetOkLyd) then - begin - ScannetOkLyd := ''; - end; - ScannetOkStorLyd := 'Sounds\Ok_stor.wav'; - if not FileExists(ScannetOkStorLyd) then - begin - ScannetOkStorLyd := ''; - end; -*) -// 20150317: slut + if Budlevering1.Checked then begin IndlesScanningLogFil(); @@ -2068,8 +1914,8 @@ 01 : begin; // NS Testprinter1.Visible := true; - DownloadButton01.Enabled := true; - OpdaterListenButton01.Enabled := true; + BtnDownloadKontrolfil.Enabled := true; + BtnOpdaterListen.Enabled := true; IdFTP1.Passive := true; IdFTP1.PassiveUseControlHost := true; BladhusKontrolfil_server := 'franordjyske/RuteKontrol.txt'; @@ -2084,8 +1930,8 @@ Storepakker1.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; - DownloadButton01.Enabled := false; // kontrolfil bruges ikke her - OpdaterListenButton01.Enabled := true; + BtnDownloadKontrolfil.Enabled := false; // kontrolfil bruges ikke her + BtnOpdaterListen.Enabled := true; IdFTP1.Passive := true; IdFTP1.PassiveUseControlHost := true; IndlesManglendeScanninger(); @@ -2095,14 +1941,14 @@ Testprinter1.Visible := true; if (getProddag() = 'lørdag') then begin - DownloadButton03.Visible := false; + BtnDownloadRuteskiftFil.Visible := false; end else begin - DownloadButton03.Visible := false; + BtnDownloadRuteskiftFil.Visible := false; end; - DownloadButton01.Enabled := true; - OpdaterListenButton01.Enabled := true; + BtnDownloadKontrolfil.Enabled := true; + BtnOpdaterListen.Enabled := true; IdFTP1.Passive := true; IdFTP1.PassiveUseControlHost := true; BladhusRuteskiftfil_server := 'frafd/RuteSkift.txt'; @@ -2122,8 +1968,8 @@ Storepakker1.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; - DownloadButton01.Enabled := false; // kontrolfil bruges ikke her - OpdaterListenButton01.Enabled := true; + BtnDownloadKontrolfil.Enabled := false; // kontrolfil bruges ikke her + BtnOpdaterListen.Enabled := true; IdFTP1.Passive := true; IdFTP1.PassiveUseControlHost := true; end; @@ -2139,6 +1985,8 @@ URLStr : String; pakkestorrelse : String; PrintNyLabelInteger : Integer; + + PakkeshopLabel: TPakkeshopLabel; begin if radioStorPakke.Checked then begin @@ -2148,6 +1996,8 @@ begin pakkestorrelse := 'Lille'; end; + + if Pakkernormal1.Checked then begin if (BoghandlerTjekkode = '') then @@ -2176,10 +2026,20 @@ begin URLStr := Format(UrlReturPakkeshop,[Sted, PakkeNr]); end + else if menuIndlevering.Checked then + begin + URLStr := Format(UrlIndleveringsPakke,[Sted, PakkeNr]); + end else begin exit; end; + + if chkForstorTilDirekte.Checked then // Denne skal være efter if/else kæden da den overrider de øvrige URL'er + begin + URLStr := Format(URLOmdirigerTilPakkeshop,[Sted, PakkeNr]); + end; + try //raise EIdConnClosedGracefully.Create('test'); // KUN TIL TEST WebSvar := IdHTTP1.Get(URLStr); @@ -2201,6 +2061,7 @@ end; end; end; + XMLDocument1.LoadFromXML(WebSvar); try if Pakkeshoplevering1.Checked or Returpakkerfrapakkeshop1.Checked then @@ -2222,10 +2083,29 @@ begin PrintNyLabel := True; end; -// 20150310: start end; -// 20150310: slut end + else if menuIndlevering.Checked or chkForstorTilDirekte.Checked then + begin + + + + + Kommentar := XMLDocument1.ChildNodes.FindNode('PakkeKontrol').ChildNodes.FindNode('Stregkodematch').Text; + if (Kommentar = 'Ok') then + begin + PrintNyLabel := True; //Indleveringskode vil ALTID udskrive label + PakkeshopLabel := TPakkeshopLabel.Create( XMLDocument1 ); //Opret struct og parse xml doc + RuteNummer := PakkeshopLabel.Koreliste + ' -> ' + PakkeshopLabel.PakkeshopTurid; + Stregkode := PakkeshopLabel.Stregkode; + + LabelPrint.PrintPakkeshopLabel( PakkeshopLabel ); + chkForstorTilDirekte.Checked := false; + + end; + + + end else begin RuteNummer := XMLDocument1.ChildNodes.FindNode('BogpakkeKontrol').ChildNodes.FindNode('TurId').Text; @@ -2258,6 +2138,8 @@ PrintNyLabel := True; end; end; + + if (BladhusSted > 00) and (BladhusSted < Length(BladhusStedNavn)) then begin if (Leveringssted <> BladhusStedKode[BladhusSted]) and (BladhusStedKode[BladhusSted] <> 'DBK') then @@ -2350,12 +2232,18 @@ List1msg := List1msg + '; ' + Stregkode + ' (' + BoghandlerTjekkode + ')' + '; ' + Kommentar; end; end; + if menuIndlevering.Checked then + begin + List1Msg := Stregkode; + end; + + ListBox1.Items.Insert(0,List1Msg); logTekst := RightStr(List1Msg, Length(List1Msg)-10); SkrivScanningLogFil(logTekst); end; -procedure TMainForm.UploadButton01Click(Sender: TObject); +procedure TMainForm.BtnUploadLogfilClick(Sender: TObject); begin UploadLogfilTilDAO(); UploadInifilTilDAO(); @@ -2372,7 +2260,7 @@ nytRuteNummer, nyFarve : String; begin if Budlevering1.Checked then - RuteNummerST.Color := HexToTColor(Farve); + RuteNummerST.Color := TUtils.HexToTColor(Farve); pakkeErScannet := pos('PAKKEN ER SCANNET', BoghandlerNavn); if pakkeErScannet = 0 then @@ -2417,7 +2305,7 @@ PlaySound(PWideChar(AlarmLyd)); MainForm.Color := clRed; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; end else @@ -2428,7 +2316,7 @@ PrintNyLabel := true; RuteNummerST.Caption := RuteNummer+' -> ny rute: '+nytRuteNummer; nyFarve := Farve; - RuteNummerST.Color := HexToTColor(nyFarve); + RuteNummerST.Color := TUtils.HexToTColor(nyFarve); List1msg := TimeToStr(now) + '; ' + RuteNummer+' -> ny rute: '+nytRuteNummer; RuteNummer := nytRuteNummer; ListBox1.Items.Insert(0,List1Msg); @@ -2444,7 +2332,7 @@ begin PlaySound(PWideChar(AlarmLyd)); MainForm.Color := clRed; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; end; end; @@ -2470,7 +2358,7 @@ begin PlaySound(PWideChar(AlarmLyd)); MainForm.Color := clRed; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; end; end; @@ -2490,35 +2378,35 @@ if PrintNyLabel or (RuteNummer = 'Rutenr') then // 20150304: slut begin - SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); + LabelPrint.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); end; end; 01 : begin; - if PrintNyLabel and ( (kontrolKoreliste <> '') and (kontrolKoreliste <> RuteNummer) ) or (RuteNummer = 'Rutenr') then + if PrintNyLabel or ( (kontrolKoreliste <> '') and (kontrolKoreliste <> RuteNummer) ) or (RuteNummer = 'Rutenr') then // Ovenstående test er lidt speciel fordi der i programmet nogle steder er byttet rundt på rute og køreliste // Meningen er at der kun skal printes hvis der er forskel i kørelisterne eller ruterne - eller vi kommer fra test funktionen (Rutenr = 'Rutenr') begin - SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); + LabelPrint.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); end; end; 02 : begin; if PrintNyLabel or (RuteNummer = 'Rutenr') then // Hvis RuteNummer = 'Rutenr' er vi igang med en printer test begin - SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); + LabelPrint.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); end; end; 03 : begin; - if PrintNyLabel and ( (kontrolKoreliste <> '') and (kontrolKoreliste <> RuteNummer) ) or (RuteNummer = 'Rutenr') then + if PrintNyLabel or ( (kontrolKoreliste <> '') and (kontrolKoreliste <> RuteNummer) ) or (RuteNummer = 'Rutenr') then // Ovenstående test er lidt speciel fordi der i programmet nogle steder er byttet rundt på rute og køreliste // Meningen er at der kun skal printes hvis der er forskel i kørelisterne eller ruterne - eller vi kommer fra test funktionen (Rutenr = 'Rutenr') begin - SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); + LabelPrint.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); end; end; 04 : begin; if PrintNyLabel or (RuteNummer = 'Rutenr') then // Hvis RuteNummer = 'Rutenr' er vi igang med en printer test begin - SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); + LabelPrint.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel, BoghandlerNummer); end; end; else @@ -2554,74 +2442,14 @@ end; logTekst := logTekst + ' for '+BoghandlerNavn; SkrivScanningLogFil(logTekst); - with Printer do - begin - BeginDoc; - Canvas.Font.Size := FontSizeRute; - if (Length(RuteNummer) > 7) then - begin - Canvas.Font.Size := FontSizeRuteLille; - end; - Canvas.TextOut(XPosRute,YPosRute, RuteNummer); - Canvas.Font.Size := FontSizeKommentar; - Kommentar := StringReplace(Kommentar, #$A, ' - ', [rfReplaceAll, rfIgnoreCase]); - if (Kommentar = 'Ok') or (Kommentar = 'ALLEREDE SCANNET') then - begin - Kommentar := ''; - end; - if (BoghandlerNavn = 'PAKKE ER SCANNET') then - begin - BoghandlerNavn := ''; - end; - Canvas.TextOut(XPosKommentar,YPosKommentar, Kommentar); // Kan ikke lave linieskift (se tidligere kommentar om samme) - Canvas.Font.Size := FontSizeBoghandler; - Canvas.TextOut(XPosBoghandler,YPosBoghandler, BoghandlerNavn); - EndDoc; - end; + + LabelPrint.PrintDaodirekteLabel( RuteNummer, Kommentar, BoghandlerNavn) ; + end; end; end; -procedure TMainForm.SendTilPrinter(kontrolKoreliste, RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted : String; var PrintNyLabel : Boolean; BoghandlerNummer : string = ''); -begin - with Printer do - begin - BeginDoc; - Canvas.Font.Size := FontSizeRuteLille; - if (kontrolKoreliste <> '') then - begin - Canvas.TextOut(XPosRute,YPosRute, kontrolKoreliste); - end - else - begin - Canvas.TextOut(XPosRute,YPosRute, RuteNummer); - end; - Canvas.Font.Size := FontSizeKorelisteLille; - Canvas.TextOut(XPosKoreliste,YPosKoreliste, Koreliste); - if (Sted = 'DBK') or (Sted = '04') then - begin - Canvas.Font.Size := FontSizeSorteringsfelt1; - Canvas.TextOut(XPosSorteringsfelt1,YPosSorteringsfelt1, DBKbane); // sorteringsoplysning 1 - Canvas.Font.Size := FontSizeSorteringsfelt1; - Canvas.TextOut(XPosSorteringsfelt2,YPosSorteringsfelt2, Leveringssted); // sorteringsoplysning 2 - end; - Canvas.Font.Size := FontSizeKommentar; - - Kommentar := StringReplace(Kommentar, #$A, ' - ', [rfReplaceAll, rfIgnoreCase]); - Kommentar := StringReplace(Kommentar, 'PAKKE ER SCANNET', '', [rfReplaceAll, rfIgnoreCase]); - - Canvas.TextOut(XPosKommentar,YPosKommentar, Kommentar); // Kan ikke lave linieskift (se tidligere kommentar om samme) - if SmsKode <> '' then - begin - Canvas.Font.Size := FontSizeSmskode; - Canvas.TextOut(XPosKommentar,YPosSmskode, concat('CODE: ', SmsKode)); - end; - Canvas.Font.Size := FontSizeBoghandler; - Canvas.TextOut(XPosBoghandler,YPosBoghandler, BoghandlerNavn); - EndDoc; - end; -end; procedure TMainForm.radioStorPakkeClick(Sender: TObject); @@ -2711,396 +2539,144 @@ //UpdateScreen('', '', 'Tjekker forbindelsen...', '', ''); // virker ikke ShowMessage('Tjekker data forbindelse til serveren.' + crlf + 'Det kan godt tage nogle minutter.' + crlf + 'Resultatet af testen vises i skærmbilledet...'); - // Tjekker urls - logTekst := 'Tjekker urls.'; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - SkrivScanningLogFil(logTekst); + try + // Tjekker urls + logTekst := 'Tjekker urls.'; + ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); + SkrivScanningLogFil(logTekst); - // Tjekker UrlNormal - if PanelValg1.Enabled = true then - begin - if CheckUrl(UrlNormal) then - begin - logTekst := 'UrlNormal accepteret: ' + UrlNormal; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlNormal svarer ikke: ' + UrlNormal; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - TjekUrls := '-'; // markerer at der var fejl - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; - // Tjekker UrlReturDAO - if PanelValg2.Enabled = true then - begin - if CheckUrl(UrlReturDAO) then - begin - logTekst := 'UrlReturDAO accepteret: ' + UrlReturDAO; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlReturDAO svarer ikke: ' + UrlReturDAO; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; - // Tjekker UrlReturBoghandler - if PanelValg3.Enabled = true then - begin - if CheckUrl(UrlReturBoghandler) then - begin - logTekst := 'UrlReturBoghandler accepteret: ' + UrlReturBoghandler; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlReturDAO svarer ikke: ' + UrlReturDAO; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlNormal + if PanelValg1.Enabled = true then + begin + TjekkerEnkeltUrl('UrlNormal', UrlNormal, urlFejl); + end; - // Tjekker UrlBudlevering - if PanelValg4.Enabled = true then - begin - if CheckUrl(UrlBudlevering) then - begin - logTekst := 'UrlBudlevering accepteret: ' + UrlBudlevering; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlBudlevering svarer ikke: ' + UrlBudlevering; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlReturDAO + if PanelValg2.Enabled = true then + begin + TjekkerEnkeltUrl('UrlReturDAO', UrlReturDAO, urlFejl); + end; - // Tjekker UrlPakkeshoplevering - if PanelValg5.Enabled = true then - begin - if CheckUrl(UrlPakkeshoplevering) then - begin - logTekst := 'UrlPakkeshoplevering accepteret: ' + UrlPakkeshoplevering; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlPakkeshoplevering svarer ikke: ' + UrlPakkeshoplevering; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlReturBoghandler + if PanelValg3.Enabled = true then + begin + TjekkerEnkeltUrl('UrlReturBoghandler', UrlReturBoghandler, urlFejl); + end; - // Tjekker UrlReturPakkeshop - if PanelValg6.Enabled = true then - begin - if CheckUrl(UrlReturPakkeshop) then - begin - logTekst := 'UrlReturPakkeshop accepteret: ' + UrlReturPakkeshop; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlReturPakkeshop svarer ikke: ' + UrlReturPakkeshop; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlBudlevering + if PanelValg4.Enabled = true then + begin + TjekkerEnkeltUrl('UrlBudlevering', UrlBudlevering, urlFejl); + end; - // Tjekker UrlManglendeScanninger - if (PanelValg1.Enabled = true) - or (PanelValg4.Enabled = true) then - begin - if CheckUrl(UrlManglendeScanninger) then - begin - logTekst := 'UrlManglendeScanninger accepteret: ' + UrlManglendeScanninger; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlManglendeScanninger svarer ikke: ' + UrlManglendeScanninger; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlPakkeshoplevering + if PanelValg5.Enabled = true then + begin + TjekkerEnkeltUrl('UrlPakkeshoplevering', UrlPakkeshoplevering, urlFejl); + end; - // Tjekker UrlPakkeshopManglendeScanninger - if PanelValg5.Enabled = true then - begin - if CheckUrl(UrlPakkeshopManglendeScanninger) then - begin - logTekst := 'UrlPakkeshopManglendeScanninger accepteret: ' + UrlPakkeshopManglendeScanninger; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlPakkeshopManglendeScanninger svarer ikke: ' + UrlPakkeshopManglendeScanninger; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlReturPakkeshop + if PanelValg6.Enabled = true then + begin + TjekkerEnkeltUrl('UrlReturPakkeshop', UrlReturPakkeshop, urlFejl); + end; - // Tjekker UrlPakkeshopManglendeReturScanninger - if PanelValg6.Enabled = true then - begin - if CheckUrl(UrlPakkeshopManglendeReturScanninger) then - begin - logTekst := 'UrlPakkeshopManglendeReturScanninger accepteret: ' + UrlPakkeshopManglendeReturScanninger; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlPakkeshopManglendeReturScanninger svarer ikke: ' + UrlPakkeshopManglendeReturScanninger; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlManglendeScanninger + if (PanelValg1.Enabled = true) or (PanelValg4.Enabled = true) then + begin + TjekkerEnkeltUrl('UrlManglendeScanninger', UrlManglendeScanninger, urlFejl); + end; - // Tjekker UrlEKLoverforsel - if PanelValg1.Enabled = true then - begin - if CheckUrl(UrlEKLoverforsel) then - begin - logTekst := 'UrlEKLoverforsel accepteret: ' + UrlEKLoverforsel; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlEKLoverforsel svarer ikke: ' + UrlEKLoverforsel; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlPakkeshopManglendeScanninger + if PanelValg5.Enabled = true then + begin + TjekkerEnkeltUrl('UrlPakkeshopManglendeScanninger', UrlPakkeshopManglendeScanninger, urlFejl); + end; + // Tjekker UrlPakkeshopManglendeReturScanninger + if PanelValg6.Enabled = true then + begin + TjekkerEnkeltUrl('UrlPakkeshopManglendeReturScanninger', UrlPakkeshopManglendeReturScanninger, urlFejl); + end; - // Tjekker UrlEKLoverforselPakkeshop - if PanelValg5.Enabled = true then - begin - if CheckUrl(UrlEKLoverforselPakkeshop) then - begin - logTekst := 'UrlEKLoverforselPakkeshop accepteret: ' + UrlEKLoverforselPakkeshop; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlEKLoverforselPakkeshop svarer ikke: ' + UrlEKLoverforselPakkeshop; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - end; + // Tjekker UrlIndleveringsPakke og UrlIndleveringsPakkeManglendeScanninger + if PanelValg7.Enabled = true then + begin + TjekkerEnkeltUrl('UrlIndleveringsPakke', UrlIndleveringsPakke, urlFejl); + TjekkerEnkeltUrl('UrlIndleveringsPakkeManglendeScanninger', UrlIndleveringsPakkeManglendeScanninger, urlFejl); + end; + // Tjekker UrlEKLoverforsel + if PanelValg1.Enabled = true then + begin + TjekkerEnkeltUrl('UrlEKLoverforsel', UrlEKLoverforsel, urlFejl); + end; - // Tjekker UrlFindPakketype - if CheckUrl(UrlFindPakketype) then - begin - logTekst := 'UrlFindPakketype accepteret: ' + UrlFindPakketype; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlFindPakketype svarer ikke: ' + UrlFindPakketype; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; - // Tjekker UrlSendPrograminfo - if CheckUrl(UrlSendPrograminfo) then - begin - logTekst := 'UrlSendPrograminfo accepteret: ' + UrlSendPrograminfo; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlSendPrograminfo svarer ikke: ' + UrlSendPrograminfo; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - if TjekUrls = '1' then - begin - logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; - end; - SkrivScanningLogFil(logTekst); - if TjekUrls = '1' then - begin - ShowMessage(logTekst); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; - exit; - end; - end; + // Tjekker UrlEKLoverforselPakkeshop + if PanelValg5.Enabled = true then + begin + TjekkerEnkeltUrl('UrlEKLoverforselPakkeshop', UrlEKLoverforselPakkeshop, urlFejl); + end; + + + // Tjekker UrlFindPakketype + TjekkerEnkeltUrl('UrlFindPakketype', UrlFindPakketype, urlFejl); + + // Tjekker UrlSendPrograminfo + TjekkerEnkeltUrl('UrlSendPrograminfo', UrlSendPrograminfo, urlFejl); - if urlFejl > 0 then - begin - TjekUrls := '-'; // markerer at der var fejl - end - else - begin - logTekst := 'urls er ok'; - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); - SkrivScanningLogFil(logTekst); - end; + + logTekst := 'urls er ok'; + ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); + SkrivScanningLogFil(logTekst); + + Except + TjekUrls := '-'; // markerer at der var fejl + + end; end; -function TMainForm.FileTime2DateTime(FileTime: TFileTime): TDateTime; -var - LocalFileTime: TFileTime; - SystemTime: TSystemTime; +procedure TMainForm.TjekkerEnkeltUrl(UrlNavn: String; Url: String; var urlFejl: integer); +const + crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed begin - FileTimeToLocalFileTime(FileTime, LocalFileTime) ; - FileTimeToSystemTime(LocalFileTime, SystemTime) ; - Result := SystemTimeToDateTime(SystemTime) ; + if TUtils.CheckUrl(Url) then + + begin + logTekst := UrlNavn + ' accepteret: ' + Url; + SkrivScanningLogFil(logTekst); + end + else + begin + inc(urlFejl); // Optæller antal fejl + logTekst := UrlNavn + ' svarer ikke: ' + Url; + ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); + if TjekUrls = '1' then + begin + logTekst := logTekst + crlf + crlf + 'Programmet afsluttes... '; + end; + + SkrivScanningLogFil(logTekst); + + if TjekUrls = '1' then + begin + ShowMessage(logTekst); + UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut + Application.Terminate; + + raise Exception.Create('UrlFejl'); + + end; + end; + end; + + procedure TMainForm.SletLogfiler(Path: string; FileList: TStrings); var SR: TSearchRec; @@ -3117,9 +2693,10 @@ repeat if (SR.Attr <> faDirectory) then begin + dt := fileDateToDateTime(SR.Time); // finder filens timestamp for seneste ændring CreationTime := SR.FindData.ftCreationTime; // finder filens timestamp for oprettelse - dtCreation := FileTime2DateTime(CreationTime); // finder filens timestamp for oprettelse + dtCreation := TUtils.FileTime2DateTime(CreationTime); // finder filens timestamp for oprettelse // Selvom creation date godt kan være forskellig fra modified date, // skal vi alligevel altid tjekke filens alder ud fra modified date // (ændring den kan ligge både før og efter oprettelse, hvis filerne er flyttet eller ændret manuelt) @@ -3156,11 +2733,11 @@ end; end; -procedure TMainForm.PakkeshopNulstilClick(Sender: TObject); +procedure TMainForm.btnNulstilClick(Sender: TObject); begin PakkeshopStregkode := ''; PakkeshopTjekkode := ''; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; PakkeshopText1.Caption := 'Stregkode'; BoghandlerStregkode := ''; BoghandlerTjekkode := ''; @@ -3178,17 +2755,7 @@ // MainForm.Color := HexToTColor(Farve); if Farve <> '' then begin - MainForm.Color := HexToTColor(Farve); -// 20150312: start -(* - end - else - begin - ShowMessage('Programmet afbrydes...'); - UrlSendPrograminfo := ''; // Her sletter vi lige url, så der ikke forsøges at sende besked ved program slut - Application.Terminate; -*) -// 20150312: slut + MainForm.Color := TUtils.HexToTColor(Farve); end; if (Budlevering1.Checked) then begin @@ -3252,27 +2819,14 @@ procedure TMainForm.PanelValgAClick(Sender: TObject); begin -// 20150311: start -(* - if PanelValgA.Color = clBtnFace then - begin - AutomatiskValg1.Checked := true; - PanelValgA.Color := clGreen; - PanelValgA.Font.Color := clWhite; - end - else - begin - AutomatiskValg1.Checked := false; - PanelValgA.Color := clBtnFace; - PanelValgA.Font.Color := clWindowText; - end; -*) // Skal ikke toggle men bare sætte funktionen on // Fravælges ved at vælge en scanningstype - AutomatiskValg1.Checked := true; - PanelValgA.Color := clGreen; - PanelValgA.Font.Color := clWhite; -// 20150311: slut + AutomatiskValg1.Checked := true; + PanelValgA.Color := clGreen; + PanelValgA.Font.Color := clWhite; + + + end; procedure TMainForm.Pakkernormal1Click(Sender: TObject); @@ -3289,7 +2843,6 @@ BoghandlerNavn : String; Koreliste : String; Falsk : Boolean; - Sand : Boolean; SmsKode : String; DBKbane : String; Leveringssted : String; @@ -3311,12 +2864,12 @@ // Her kommer en alarm og rød skærm PlaySound(PWideChar(AlarmLyd)); MainForm.Color := clRed; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; end else begin Falsk := False; - Sand := True; + HentPakkeInfoFraServer(Sted,'111111111100000', RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, Falsk, ''); UpdateScreen(RuteNummer, Kommentar, BoghandlerNavn, Koreliste, ''); SmsKode := '999999'; @@ -3336,7 +2889,6 @@ BoghandlerNavn : String; Koreliste : String; Falsk : Boolean; - Sand : Boolean; SmsKode : String; DBKbane : String; Leveringssted : String; @@ -3345,9 +2897,9 @@ Kommentar := '***** Kommentar *****'; BoghandlerNavn := 'Modtagernavn'; Falsk := False; - Sand := True; - if (Printer.Printers.Count = 0) then + + if (LabelPrint.GetPrinterCount() = 0) then begin ShowMessage('Der er ikke installeret en printer på denne PC.'); end @@ -3362,7 +2914,7 @@ DBKbane := '999'; Leveringssted := 'XXX'; PrintLabel(RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, Falsk); - CheckPrintQue('Test'); + LabelPrint.CheckPrintQue('Test', PrinterNavn); end; FocusControl(StregkodeST); end; @@ -3371,7 +2923,7 @@ begin if (TjekPrinter = '1') then begin - CheckPrintQue('Timer'); + LabelPrint.CheckPrintQue('Timer', PrinterNavn); end else begin @@ -3380,36 +2932,7 @@ end; end; -{ - VERY fast split function - this function returns part of a string based on - constant defineable delimiters, such as ";". So - SPLIT('this is a test ',' ',3) = 'is' or - SPLIT('data;another;yet;again;more;',';',4) = 'yet' - - Split function shifts index integer by two to - be compatible with commonly used PD split function - gpl 2004 / Juhani Suhonen -} -function TMainForm.split(input: string; schar: Char; s: Integer): string; -var - c: array of Integer; - b, t: Integer; -begin - Dec(s, 2); // for compatibility with very old & slow split function - t := 0; // variable T needs to be initialized... - setlength(c, Length(input)); - for b := 0 to pred(High(c)) do - begin - c[b + 1] := posex(schar, input, succ(c[b])); - // BREAK LOOP if posex looped (position before previous) - // or wanted position reached.. - if (c[b + 1] < c[b]) or (s < t) then break - else - Inc(t); - end; - Result := Copy(input, succ(c[s]), pred(c[s + 1] - c[s])); -end; + procedure TMainForm.Om1Click(Sender: TObject); const @@ -3418,7 +2941,7 @@ tekst, filversion : String; begin - filversion := Sto_GetFmtFileVersion('',''); + filversion := TUtils.Sto_GetFmtFileVersion(''); tekst := 'Program til indscanning af pakker'+crlf+'Version '+filversion+crlf+crlf+'Udviklet af it afdelingen, DAO'; tekst := tekst+crlf+crlf; @@ -3440,12 +2963,12 @@ end else begin - tekst := tekst+crlf+crlf+'Speciel version til: '+split(Titel, ':', 2)+' ('+Sted+')'; + tekst := tekst+crlf+crlf+'Speciel version til: ' + TUtils.split(Titel, ':', 2) + ' ('+Sted+')'; end; end else begin - tekst := tekst+crlf+crlf+'Speciel version til: '+split(Titel, ':', 2)+' ('+SpecialVersionSted+')'; + tekst := tekst+crlf+crlf+'Speciel version til: ' + TUtils.split(Titel, ':', 2) + ' ('+SpecialVersionSted+')'; end; end; @@ -3513,7 +3036,7 @@ if FileExists(fileName) then begin - if AdobeReaderExists then + if TUtils.AdobeReaderExists then begin //ShellExecute(Handle, 'open', 'c:\Windows\notepad.exe', nil, nil, SW_SHOWNORMAL); ShellExecute(Handle,'open',PChar(fileName), nil, nil, SW_SHOWNORMAL); @@ -3537,14 +3060,14 @@ if FileExists(fileName) then begin - if AdobeReaderExists then + if TUtils.AdobeReaderExists then begin //ShellExecute(Handle, 'open', 'c:\Windows\notepad.exe', nil, nil, SW_SHOWNORMAL); ShellExecute(Handle,'open',PChar(fileName), nil, nil, SW_SHOWNORMAL); end else begin - ShowMessage('Acrobat Reader er ikke installeret!'); + ShowMessage('Adobe Reader er ikke installeret!'); end; end else @@ -3553,6 +3076,13 @@ end; end; +procedure TMainForm.menuIndleveringClick(Sender: TObject); +begin + Scanningtype := '7'; + NulstilAutomatiskValg(); + InitIndleveringskode(); +end; + procedure TMainForm.Sprgefterboghandlernummer1Click(Sender: TObject); begin @@ -3585,7 +3115,7 @@ procedure TMainForm.InitNatxpresslevering(); begin AutomatiskTjekkodeStyring1.Enabled := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; Pakkernormal1.Checked := true; InitForm(FarveNormal,TitelNormal,UrlNormal); PanelValg1.Color := clGreen; @@ -3603,10 +3133,14 @@ radioStorPakke.Enabled := false; radioLillePakke.Enabled := false; ListBox1.Visible := true; - OpdaterListenButton01.Enabled := true; - EKLoverforsel.Enabled := true; + BtnOpdaterListen.Enabled := true; + BtnEKLoverforsel.Enabled := true; InitLillePakke(); ListBox1.Items.Clear; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + if BladhusSted = 0 then begin IndlesScanningLogFil(); @@ -3618,7 +3152,7 @@ begin AutomatiskTjekkodeStyring1.Enabled := false; ReturpakkerfraDAO1.Checked := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; InitForm(FarveReturDAO,TitelReturDAO,UrlReturDAO); PanelValg2.Color := clGreen; PanelValg2.Font.Color := clWhite; @@ -3637,7 +3171,11 @@ ListBox1.Visible := true; ListBox1.Items.Clear; ListBox2.Items.Clear; - EKLoverforsel.Enabled := false; + BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + InitLillePakke(); end; @@ -3645,7 +3183,7 @@ begin AutomatiskTjekkodeStyring1.Enabled := false; Returpakkerfraboghandler1.Checked := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; InitForm(FarveReturBoghandler,TitelReturBoghandler,UrlReturBoghandler); PanelValg3.Color := clGreen; PanelValg3.Font.Color := clWhite; @@ -3663,7 +3201,11 @@ ListBox1.Visible := true; ListBox1.Items.Clear; ListBox2.Items.Clear; - EKLoverforsel.Enabled := false; + BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + InitLillePakke(); end; @@ -3671,7 +3213,7 @@ begin AutomatiskTjekkodeStyring1.Enabled := false; Budlevering1.Checked := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; InitForm(FarveBudlevering,TitelBudlevering,UrlBudlevering); PanelValg4.Color := clGreen; PanelValg4.Font.Color := clWhite; @@ -3689,12 +3231,16 @@ radioLillePakke.Enabled := true; ListBox1.Visible := true; ListBox1.Items.Clear; - DownloadButton01.Enabled := false; - OpdaterListenButton01.Enabled := true; - DownloadButton03.Visible := false; - EKLoverforsel.Enabled := false; + BtnDownloadKontrolfil.Enabled := false; + BtnOpdaterListen.Enabled := true; + BtnDownloadRuteskiftFil.Visible := false; + BtnEKLoverforsel.Enabled := false; IdFTP1.Passive := true; IdFTP1.PassiveUseControlHost := true; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := true; + if (BladhusSted = 0) or (BladhusSted = 2) or (BladhusSted = 3) then begin IndlesScanningLogFil(); @@ -3707,7 +3253,7 @@ begin AutomatiskTjekkodeStyring1.Enabled := true; Pakkeshoplevering1.Checked := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; InitForm(FarvePakkeshoplevering,TitelPakkeshoplevering,UrlPakkeshoplevering); PanelValg5.Color := clGreen; PanelValg5.Font.Color := clWhite; @@ -3725,10 +3271,13 @@ radioLillePakke.Enabled := false; ListBox1.Visible := true; ListBox1.Items.Clear; - DownloadButton01.Enabled := false; - OpdaterListenButton01.Enabled := true; + BtnDownloadKontrolfil.Enabled := false; + BtnOpdaterListen.Enabled := true; + + BtnEKLoverforsel.Enabled := true; - EKLoverforsel.Enabled := true; + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := true; InitLillePakke(); IndlesScanningLogFil(); @@ -3744,7 +3293,7 @@ begin AutomatiskTjekkodeStyring1.Enabled := false; Returpakkerfrapakkeshop1.Checked := true; - PakkeshopNulstil.Visible := false; + btnNulstil.Visible := false; InitForm(FarveReturPakkeshop,TitelReturPakkeshop,UrlReturPakkeshop); PanelValg6.Color := clGreen; PanelValg6.Font.Color := clWhite; @@ -3762,9 +3311,14 @@ radioLillePakke.Enabled := false; ListBox1.Visible := true; ListBox1.Items.Clear; - DownloadButton01.Enabled := false; - OpdaterListenButton01.Enabled := true; - EKLoverforsel.Enabled := false; + BtnDownloadKontrolfil.Enabled := false; + BtnOpdaterListen.Enabled := true; + BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + + InitLillePakke(); IndlesScanningLogFil(); if BladhusSted = 0 then @@ -3784,9 +3338,10 @@ procedure TMainForm.InitIndleveringskode(); begin + menuIndlevering.Checked := true; AutomatiskTjekkodeStyring1.Enabled := false; - Returpakkerfrapakkeshop1.Checked := true; - PakkeshopNulstil.Visible := false; + + btnNulstil.Visible := false; InitForm(FarveIndlevering, TitelIndlevering, UrlReturPakkeshop); PanelValg7.Color := clGreen; PanelValg7.Font.Color := clWhite; @@ -3808,9 +3363,14 @@ ListBox1.Visible := true; ListBox1.Items.Clear(); - DownloadButton01.Enabled := false; - OpdaterListenButton01.Enabled := true; - EKLoverforsel.Enabled := false; + BtnDownloadKontrolfil.Enabled := false; + BtnOpdaterListen.Enabled := true; + BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + + InitLillePakke(); IndlesScanningLogFil(); if BladhusSted = 0 then @@ -3848,72 +3408,7 @@ // 20150310: slut end; -/// -/// This function reads the file resource of "FileName" and returns -/// the version number as formatted text. -/// -/// Sto_GetFmtFileVersion() = '4.13.128.0' -/// Sto_GetFmtFileVersion('', '%.2d-%.2d-%.2d') = '04-13-128' -/// -/// If "Fmt" is invalid, the function may raise an -/// EConvertError exception. -/// Full path to exe or dll. If an empty -/// string is passed, the function uses the filename of the -/// running exe or dll. -/// Format string, you can use at most four integer -/// values. -/// Formatted version number of file, '' if no version -/// resource found. -function TMainForm.Sto_GetFmtFileVersion(const FileName: String = ''; - const Fmt: String = '%d.%d.%d.%d'): String; -var - sFileName: String; - iBufferSize: DWORD; - iDummy: DWORD; - pBuffer: Pointer; - pFileInfo: Pointer; - iVer: array[1..4] of Word; - S : String; -begin - // set default value - Result := ''; - // get filename of exe/dll if no filename is specified - sFileName := Trim(FileName); - if (sFileName = '') then - sFileName := GetModuleName(HInstance); - // get size of version info (0 if no version info exists) - iBufferSize := GetFileVersionInfoSize(PChar(sFileName), iDummy); - if (iBufferSize > 0) then - begin - GetMem(pBuffer, iBufferSize); - try - // get fixed file info (language independent) - GetFileVersionInfo(PChar(sFileName), 0, iBufferSize, pBuffer); - VerQueryValue(pBuffer, '\', pFileInfo, iDummy); - // read version blocks - iVer[1] := HiWord(PVSFixedFileInfo(pFileInfo)^.dwFileVersionMS); - iVer[2] := LoWord(PVSFixedFileInfo(pFileInfo)^.dwFileVersionMS); - iVer[3] := HiWord(PVSFixedFileInfo(pFileInfo)^.dwFileVersionLS); - iVer[4] := LoWord(PVSFixedFileInfo(pFileInfo)^.dwFileVersionLS); - finally - FreeMem(pBuffer); - end; - // format result string - Result := Format(Fmt, [iVer[1], iVer[2], iVer[3], iVer[4]]); - // Hvorfor virker ovenstående ikke ??? - S := ''; - Str(iVer[1],Result); - S := S+Result+'.'; - Str(iVer[2],Result); - S := S+Result+'.'; - Str(iVer[3],Result); - S := S+Result+'.'; - Str(iVer[4],Result); - S := S+Result+''; - Result := S; - end; -end; procedure TMainForm.PlaySound(filename : PWideChar); begin @@ -3984,7 +3479,7 @@ CheckCode(); end; -procedure TMainForm.EKLoverforselClick(Sender: TObject); +procedure TMainForm.BtnEKLoverforselClick(Sender: TObject); var WebSvar : String; URLStr : String; @@ -3994,19 +3489,19 @@ status, kommentar : String; begin - EKLoverforsel.Enabled := false; + BtnEKLoverforsel.Enabled := false; ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + 'Overfører de scannede pakker til EKL'); logTekst := 'Overfører de scannede pakker til EKL'; SkrivScanningLogFil(logTekst); StedKode := Sted; URLStr := Format(UrlEKLoverforsel,[StedKode,Sted]); -// 20150330: start + if PanelValg5.Color = clGreen then begin URLStr := Format(UrlEKLoverforselPakkeshop,[StedKode,Sted]); end; -// 20150330: slut + try //raise EIdConnClosedGracefully.Create('test'); // KUN TIL TEST @@ -4057,7 +3552,7 @@ end; end; - EKLoverforsel.Enabled := true; + BtnEKLoverforsel.Enabled := true; ListBox1.SetFocus; // for at flytte fokus væk fra knappen så denne ikke aktiveres ved scanning / indtastning af stregkode @@ -4074,7 +3569,7 @@ BoghandlerNavnST.Caption := 'Prøv venligst igen om lidt...'; end; KommentarST.Caption := Kommentar; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; end; end; @@ -4098,7 +3593,7 @@ else MessageBox(Handle, 'fejl', 'Stregkode', MB_OK); } - Svar := 'Beregnet: '+CheckSumModulo10(LeftStr(Barcode,Length(Barcode)-1))+', Indtastet: '+Barcode; + Svar := 'Beregnet: ' + TUtils.CheckSumModulo10(LeftStr(Barcode,Length(Barcode)-1))+', Indtastet: '+Barcode; MessageBox(Handle, PWideChar(Svar), 'Stregkode', MB_OK); CheckCode(); @@ -4106,45 +3601,6 @@ end; -function TMainForm.BarCodeValid (ACode: string): boolean; -var - I: integer; - SumOdd, SumEven: integer; - ADigit, AChecksumDigit: integer; -begin - SumOdd := 0; - SumEven := 0; - for I := 1 to (Length (ACode) - 1) do begin - ADigit := StrToIntDef (ACode [I], 0); - if (I MOD 2 = 0) then begin - SumEven := SumEven + ADigit; - end else begin - SumOdd := SumOdd + ADigit; - end; {if} - end; {for} - AChecksumDigit := StrToIntDef (ACode [Length (ACode)], 0); - Result := ((SumOdd*3 + SumEven + AChecksumDigit) MOD 10 = 0); -end; {--BarCodeValid--} - -{ used for EAN 8/13 } -function TMainForm.CheckSumModulo10(const data:string):string; - var i,fak,sum : Integer; -begin - sum := 0; - fak := Length(data); - for i:=1 to Length(data) do - begin - if (fak mod 2) = 0 then - sum := sum + (StrToInt(data[i])*1) - else - sum := sum + (StrToInt(data[i])*3); - dec(fak); - end; - if (sum mod 10) = 0 then - result := data+'0' - else - result := data+IntToStr(10-(sum mod 10)); -end; // // Bladhus *** @@ -4622,13 +4078,13 @@ ListBox1.SetFocus; // for at flytte fokus væk fra upload knappen så denne ikke aktiveres ved scanning / indtastning af stregkode end; -procedure TMainForm.DownloadButton01Click(Sender: TObject); +procedure TMainForm.BtnDownloadKontrolfilClick(Sender: TObject); begin DownloadBladhusKontrolfil(); ListBox1.SetFocus; // for at flytte fokus væk fra download knappen så denne ikke aktiveres ved scanning / indtastning af stregkode end; -procedure TMainForm.OpdaterListenButton01Click(Sender: TObject); +procedure TMainForm.BtnOpdaterListenClick(Sender: TObject); const crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed @@ -4637,7 +4093,7 @@ ListBox1.SetFocus; // for at flytte fokus væk fra download knappen så denne ikke aktiveres ved scanning / indtastning af stregkode end; -procedure TMainForm.DownloadButton03Click(Sender: TObject); +procedure TMainForm.BtnDownloadRuteskiftFilClick(Sender: TObject); begin if (getProddag() = 'lørdag') then begin @@ -4646,19 +4102,7 @@ ListBox1.SetFocus; // for at flytte fokus væk fra download knappen så denne ikke aktiveres ved scanning / indtastning af stregkode end; -function TMainForm.Explode(var a: TStrArray; Border, S: string): Integer; -var - S2: string; -begin - Result := 0; - S2 := S + Border; - repeat - SetLength(A, Length(A) + 1); - a[Result] := Copy(S2, 0,Pos(Border, S2) - 1); - Delete(S2, 1,Length(a[Result] + Border)); - Inc(Result); - until S2 = ''; -end; + procedure TMainForm.IndlesManglendeScanninger(); var @@ -4670,16 +4114,25 @@ stregkode, modtagernavn, modtageradresse, kommentar : string; pakketype, tjekkodestatus : String; pakketypeix, antalLiniefelter, antalFelterFundet, linienr : Integer; - pakketyper : TStrings; + //pakketyper : TStrings; + pakketyper : TDictionary; + tmpAntal : Integer; + + + antlin : Integer; antlinIdag, antlinSenere : Integer; - XmlFelter : TStrings; + //XmlFelter : TStrings; + XmlFelter : TDictionary; begin - XmlFelter := TStringList.Create; - pakketyper := TStringList.Create; + + + XmlFelter := TDictionary.Create; + pakketyper := TDictionary.Create; + linienr := 0; ListBox2.Clear; ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + 'Henter oversigt over pakker der endnu ikke er modtaget'); @@ -4694,14 +4147,21 @@ StedKode := Sted; end; + Application.Processmessages; //Ugly Hack to improve User Experience when switching modes + + - if (Scanningtype = '6') then + if (Scanningtype = '7') then + begin + URLStr := Format(UrlIndleveringsPakkeManglendeScanninger, [StedKode]); + end + else if (Scanningtype = '6') then begin - URLStr := Format(UrlPakkeshopManglendeReturScanninger,[StedKode]); + URLStr := Format(UrlPakkeshopManglendeReturScanninger, [StedKode]); end else if (Scanningtype = '5') then begin - URLStr := Format(UrlPakkeshopManglendeScanninger,[StedKode]); + URLStr := Format(UrlPakkeshopManglendeScanninger, [StedKode]); end else if (Scanningtype = '1') then begin @@ -4743,32 +4203,36 @@ antlinIdag := 0; antlinSenere := 0; - antalFelterFundet := 0; for I:= 0 to XMLDocument1.DocumentElement.ChildNodes.Count - 1 do begin Node:= XMLDocument1.DocumentElement.ChildNodes[I]; if Node.NodeType = ntElement then begin if Node.NodeName = 'Stregkode' then begin - antlin := antlin + 1; + Inc(antlin); // 20150306: start if not VarIsNull(Node.NodeValue) then begin if (pos('(', Node.NodeValue) = 0) then begin - antlinIdag := antlinIdag + 1; + Inc(antlinIdag); end else begin - antlinSenere := antlinSenere + 1; + Inc(antlinSenere); end; end; // 20150306: slut end; end; - if (XmlFelter.values[Node.NodeName] <> '') then - XmlFelter.values[Node.NodeName] := IntToStr(StrToInt(XmlFelter.values[Node.NodeName]) + 1) + if ( XmlFelter.ContainsKey(Node.NodeName) ) then + begin + XmlFelter.TryGetValue(Node.NodeName, tmpAntal); + XmlFelter.AddOrSetValue(Node.NodeName, tmpAntal + 1); + end else - XmlFelter.values[Node.NodeName] := '1'; + begin + XmlFelter.Add(Node.NodeName, 1); + end; end; antalLiniefelter := XmlFelter.Count; @@ -4776,6 +4240,9 @@ SetLength(stregkoderMedTjekkodeArray, 0); // reset fra tidligere brug SetLength(stregkoderMedTjekkodeArray, antlin); // sæt antal elementer i array + + Application.Processmessages; //Ugly Hack to improve User Experience when switching modes + logTekst := 'Der er ' + IntToStr(antlin) + ' pakker, der endnu ikke er modtaget'; if (antlinSenere > 0) then begin @@ -4784,6 +4251,8 @@ logTekst := logTekst + '.'; SkrivScanningLogFil(logTekst); + + for I:= 0 to XMLDocument1.DocumentElement.ChildNodes.Count - 1 do begin Node:= XMLDocument1.DocumentElement.ChildNodes[I]; if Node.NodeType = ntElement then begin @@ -4791,42 +4260,44 @@ if not VarIsNull(Node.NodeValue) then stregkode := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; - end; - if Node.NodeName = 'ModtagerNavn' then begin + end + else if Node.NodeName = 'ModtagerNavn' then begin if not VarIsNull(Node.NodeValue) then modtagernavn := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; - end; - if Node.NodeName = 'ModtagerAdresse' then begin + end + else if Node.NodeName = 'ModtagerAdresse' then begin if not VarIsNull(Node.NodeValue) then modtageradresse := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; - end; - if Node.NodeName = 'Kommentar' then begin + end + else if Node.NodeName = 'Kommentar' then begin if not VarIsNull(Node.NodeValue) then kommentar := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; - end; - if Node.NodeName = 'PakkeType' then begin + end + else if Node.NodeName = 'PakkeType' then begin if not VarIsNull(Node.NodeValue) then pakketype := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; - if (pakketyper.values[pakketype] <> '') then - pakketyper.values[pakketype] := IntToStr(StrToInt(pakketyper.values[pakketype]) + 1) + if ( pakketyper.ContainsKey(pakketype) ) then + begin + pakketyper.TryGetValue(pakketype, tmpAntal); + pakketyper.AddOrSetValue(pakketype, tmpAntal + 1); + end else - pakketyper.values[pakketype] := '1'; - end; - if Node.NodeName = 'TjekkodeStatus' then begin + pakketyper.Add(pakketype, 1); + end + else if Node.NodeName = 'TjekkodeStatus' then begin if not VarIsNull(Node.NodeValue) then tjekkodestatus := Node.NodeValue; antalFelterFundet := antalFelterFundet + 1; if (tjekkodestatus = '-1') then begin -// 20150306: start -// stregkoderMedTjekkodeArray[linienr] := stregkode; + if (pos(' ', stregkode) > 0) then begin - stregkoderMedTjekkodeArray[linienr] := split(stregkode, ' ', 2); // Fjerner lige en evt. fremtidig dato fra feltet + stregkoderMedTjekkodeArray[linienr] := TUtils.split(stregkode, ' ', 2); // Fjerner lige en evt. fremtidig dato fra feltet end else begin @@ -4835,6 +4306,8 @@ linienr := linienr + 1; end; end; + + if antalFelterFundet = antalLiniefelter then begin if (ScanningType = '1') then @@ -4850,13 +4323,22 @@ end; end; end; - for pakketypeix := 0 to pakketyper.Count-1 do - begin - ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + ' '+pakketyper[pakketypeix]+' pakke(r) ikke modtaget'); - end; - // Free up the list object + + Application.Processmessages; //Ugly Hack to improve User Experience when switching modes + + + for pakketype in pakketyper.Keys do + begin + pakketyper.TryGetValue(pakketype, tmpAntal); + ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + pakketype + ' ' + IntToStr(tmpAntal) + ' pakke(r) ikke modtaget'); + end; + + // Free up the dictionary object pakketyper.Free; + + + // ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + 'Der er '+IntToStr(antlin)+' pakker, der endnu ikke er modtaget.'); logTekst := 'Der er ' + IntToStr(antlin) + ' pakker, der endnu ikke er modtaget'; if (antlinSenere > 0) then @@ -5013,12 +4495,10 @@ procedure TMainForm.SkrivScanningLogFil(var tekst : string); var SomeTxtFile : TextFile; - buffer : string; - S: string; idag, imorgen : TDateTime; imorgenYmd : string; logFilnavn : string; - error : Integer; + //error : Integer; begin if (SkrivLog = '1') then @@ -5110,10 +4590,10 @@ ReadLn(SomeTxtFile, buffer) ; S := buffer; SetLength(A,0); - Explode(A, ';', S); + TUtils.Explode(A, ';', S); if (length(A) < 2) then begin - Explode(A, ',', S); + TUtils.Explode(A, ',', S); end; if (length(A) > 1) then begin @@ -5187,10 +4667,10 @@ ReadLn(SomeTxtFile, buffer) ; S := buffer; SetLength(A,0); - Explode(A, ';', S); + TUtils.Explode(A, ';', S); if (length(A) < 3) then begin - Explode(A, ',', S); + TUtils.Explode(A, ',', S); end; if (A[0]=imorgenYmd) then begin @@ -5282,18 +4762,24 @@ result := svar; end; -procedure TMainForm.VisAlarmSkaerm(var List1msg: string); +procedure TMainForm.VisAlarmSkaerm(strMessage: string); begin //ShowMessage('Ændring ikke tilladt'); // Her skal komme en 'rød skærm' alarm PlaySound(PWideChar(AlarmLyd)); - List1msg := Stregkode + ' kan ikke vælges på dette scanningsted'; - ListBox1.Items.Insert(0, List1Msg); MainForm.Color := clRed; + + RuteNummerST.Caption := ''; BoghandlerNavnST.Caption := ''; - KommentarST.Caption := List1msg; - PakkeshopNulstil.Visible := true; + btnNulstil.Visible := true; + + if (strMessage <> '') then + begin + ListBox1.Items.Insert(0, strMessage); + KommentarST.Caption := strMessage; + end; + end; function TMainForm.getProddato() : TDate; @@ -5353,25 +4839,6 @@ result := svar; end; -function TMainForm.GetCurrentPrinterHandle: THandle; -var - Device, Driver, Port: array[0..255] of Char; - hDeviceMode: THandle; -begin - Printer.GetPrinter(Device, Driver, Port, hDeviceMode); - if not OpenPrinter(@Device, Result, nil) then - RaiseLastWin32Error; -end; - -function TMainForm.SavePChar(p: PChar): PChar; -const - error: PChar = 'Nil'; -begin - if not Assigned(p) then - Result := error - else - Result := p; -end; procedure TMainForm.Scanogstjekkoden1Click(Sender: TObject); begin @@ -5385,180 +4852,40 @@ end; end; -function TMainForm.AdobeReaderExists: Boolean; -var - AReg: TRegistry; + + +//Nedarvet fra IParentForm +procedure TMainForm.LogMessage( msg : string); begin - result:= false; - AReg := TRegistry.Create; - AReg.RootKey := HKEY_LOCAL_MACHINE; - if AReg.KeyExists('\SOFTWARE\Adobe\Acrobat Reader') then - result:= True; - AReg.Free; + ListBox1.Items.Insert(0, msg); + SkrivScanningLogFil(msg); end; -procedure TMainForm.CheckPrintQue(tjektype : string); -type - TJobs = array [0..1000] of JOB_INFO_1; - PJobs = ^TJobs; -var - hPrinter: THandle; - bytesNeeded, numJobs, i: Cardinal; - pJ: PJobs; - printerTxt, statusTxt, dokumentTxt: String; -begin -// tjektype = 'Opstart' skal vise alarmlinie, samt opdatere listbox1 -// 'Test' skal vise alarmlinie, samt opdatere listbox1 -// 'Timer' skal kun vise alarmlinie +//Nedarvet fra IParentForm +procedure TMainForm.SetPrinterstatusText( txt: string; alert: boolean); +begin - if (PrinterNavn = 'Ingen') and ( (tjektype = 'Opstart') or (tjektype = 'Test') ) then + PrinterstatusStaticText1.Caption := txt; + if (alert) then begin - printerTxt := 'Der er fravalgt printer i dette program'; - ListBox1.Items.Insert(0,printerTxt); - SkrivScanningLogFil(printerTxt); - end - else if (Printer.Printers.Count = 0) and ( (tjektype = 'Opstart') or (tjektype = 'Test') ) then - begin - printerTxt := 'Der er ikke installeret en printer på denne PC'; - ListBox1.Items.Insert(0,printerTxt); - SkrivScanningLogFil(printerTxt); + PrinterstatusStaticText1.Font.Color := clBlack; + PrinterstatusStaticText1.Color := MainForm.Color; + PrinterstatusStaticText1.Transparent := True; end else begin - hPrinter := GetCurrentPrinterHandle; - try - EnumJobs(hPrinter, 0, 1000, 1, nil, 0, bytesNeeded, numJobs); - pJ := AllocMem(bytesNeeded); - if not EnumJobs(hPrinter, 0, 1000, 1, pJ, bytesNeeded, bytesNeeded, numJobs) then - RaiseLastWin32Error; - - if numJobs = 0 then - begin - if (tjektype = 'Test') then - begin - logTekst := printerTxt + ': Ingen dokumenter i kø'; - ListBox1.Items.Insert(0,logTekst); - SkrivScanningLogFil(logTekst); - end; - PrinterstatusStaticText1.Caption := ''; - PrinterstatusStaticText1.Color := MainForm.Color; - end - else // så er der kø til printeren - begin - printerTxt := SavePChar(pJ^[0].pPrinterName); - if (tjektype = 'Opstart') or (tjektype = 'Test') then - begin - logTekst := IntToStr(numJobs) + ' dokument(er) i kø til printer: ' + printerTxt; - ListBox1.Items.Insert(0,logTekst); - SkrivScanningLogFil(logTekst); - end; - for i := 0 to Pred(numJobs) do - begin - printerTxt := SavePChar(pJ^[i].pPrinterName); - statusTxt := 'Ukendt'; - if (IntToStr(pJ^[i].Status) = '0') then - statusTxt := 'Venter...'; - if (IntToStr(pJ^[i].Status) = '4096') then - statusTxt := 'Printer...'; - if (IntToStr(pJ^[i].Status) = '8210') then - statusTxt := 'Printerfejl'; - if (IntToStr(pJ^[i].Status) = '8214') then - statusTxt := 'Sletter print...'; - - dokumentTxt := SavePChar(pJ^[i].pDocument); - if (dokumentTxt = '') then - dokumentTxt := 'Uden navn'; - - if (tjektype = 'Opstart') or (tjektype = 'Test') then - begin - logTekst := Format('Printer %s, Dokument %d: %s, Status (%d): %s', - [printerTxt, i+1, dokumentTxt, pJ^[i].Status, statusTxt]); - ListBox1.Items.Insert(0,logTekst); - SkrivScanningLogFil(logTekst); - end; - - if (i = 0) then - begin - PrinterstatusStaticText1.Caption := printerTxt + ': ' + IntToStr(numJobs) + ' dokument(er) in kø. Dokument status: ' + statusTxt; - PrinterstatusStaticText1.Font.Color := clBlack; - PrinterstatusStaticText1.Color := MainForm.Color; - PrinterstatusStaticText1.Transparent := True; - if (numJobs > 3) then - begin - PrinterstatusStaticText1.Font.Color := clRed; - PrinterstatusStaticText1.Color := clWhite; - PrinterstatusStaticText1.Transparent := true; - end; - end; - - end; - end - finally - ClosePrinter(hPrinter); - end; + PrinterstatusStaticText1.Font.Color := clRed; + PrinterstatusStaticText1.Color := clWhite; + PrinterstatusStaticText1.Transparent := true; end; end; -function TMainForm.CheckUrl(url:string):boolean; -var - hSession, hfile, hRequest: hInternet; - dwindex,dwcodelen :dword; - dwcode:array[1..20] of char; - res : pchar; -begin - if pos('http://',lowercase(url))=0 then - url := 'http://'+url; - Result := false; - hSession := InternetOpen('InetURL:/1.0', - INTERNET_OPEN_TYPE_PRECONFIG, - nil, - nil, - 0); - if assigned(hsession) then - begin - hfile := InternetOpenUrl(hsession, - pchar(url), - nil, - 0, - INTERNET_FLAG_RELOAD, - 0); - dwIndex := 0; - dwCodeLen := 10; - HttpQueryInfo(hfile, - HTTP_QUERY_STATUS_CODE, - @dwcode, - dwcodeLen, - dwIndex); - res := pchar(@dwcode); - result:= (res ='200') or (res ='302'); - if assigned(hfile) then - InternetCloseHandle(hfile); - InternetCloseHandle(hsession); - end; - -end; - -// 20150310: start -procedure TMainForm.RoundCornerOf(Control: TWinControl); -var - R: TRect; - Rgn: HRGN; +//Nedarvet fra IParentForm +function TMainForm.GetFormObject() : TForm; begin - with Control do - begin - R := ClientRect; -// rgn := CreateRoundRectRgn(R.Left, R.Top, R.Right, R.Bottom, 20, 20) ; - rgn := CreateRoundRectRgn(R.Left, R.Top, R.Right, R.Bottom, 25, 25) ; -// rgn := CreateRoundRectRgn(R.Left, R.Top, R.Right, R.Bottom, 30, 30) ; - Perform(EM_GETRECT, 0, lParam(@r)) ; - InflateRect(r, - 4, - 4) ; - Perform(EM_SETRECTNP, 0, lParam(@r)) ; - SetWindowRgn(Handle, rgn, True) ; - Invalidate; - end; + Result := self; end; -// 20150310: slut end.