--- dao/DelphiScanner/Main.pas 2015/09/03 14:53:37 2700 +++ dao/DelphiScanner/Main.pas 2016/06/27 12:21:43 3056 @@ -1,24 +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, ShellApi, ClipBrd, Buttons, wininet, + IdExplicitTLSClientServerBase, IdFTP, IdException, + ShellApi, ClipBrd, Buttons, wininet, UITypes, PakkeshopLabels, - StBarC, - Math, // DegToRad() bruges i PrintPakkeshopLabel - Utils + Utils, + ParentForm, + LabelPrint, + Configuration, + Vcl.Imaging.pngimage, + Generics.Collections ; type - TMainForm = class(TForm) + TMainForm = class(TForm, IParentForm) StregkodeST: TStaticText; RuteNummerST: TStaticText; BoghandlerNavnST: TStaticText; @@ -26,12 +39,11 @@ XMLDocument1: TXMLDocument; ApplicationEvents1: TApplicationEvents; chkSporgEfterKunde: TCheckBox; - KommentarST: TStaticText; MainMenu1: TMainMenu; N1: TMenuItem; - Pakkernormal1: TMenuItem; - ReturpakkerfraDAO1: TMenuItem; - Returpakkerfraboghandler1: TMenuItem; + menuNatXpress1: TMenuItem; + menuNatxpressReturDAO1: TMenuItem; + menuNatxpressReturfraKunde1: TMenuItem; Hjlp1: TMenuItem; Om1: TMenuItem; Testforbindelsen1: TMenuItem; @@ -44,14 +56,14 @@ radioStorPakke: TRadioButton; radioLillePakke: TRadioButton; N4: TMenuItem; - Storepakker1: TMenuItem; - Smpakker1: TMenuItem; + menuStorePakker: TMenuItem; + menuSmaaPakker: TMenuItem; Panel1: TPanel; Testlyd2: TMenuItem; Button1: TButton; Testlyd1: TMenuItem; ListBox1: TListBox; - Budlevering1: TMenuItem; + menuDaoDirekte1: TMenuItem; BtnDownloadKontrolfil: TButton; IdFTP1: TIdFTP; Image1: TImage; @@ -59,10 +71,10 @@ BtnOpdaterListen: TButton; BtnUploadLogfil: TButton; BtnDownloadRuteskiftFil: TButton; - Pakkeshoplevering1: TMenuItem; + menuPakkeshop1: TMenuItem; PakkeshopText1: TStaticText; btnNulstil: TButton; - Returpakkerfrapakkeshop1: TMenuItem; + menuPakkeshopRetur1: TMenuItem; Altidprintepakkelabel1: TMenuItem; chkAltidPrintLabel: TCheckBox; BtnEKLoverforsel: TButton; @@ -73,8 +85,8 @@ Timer1: TTimer; chkScanTjekkode: TCheckBox; Scanogstjekkoden1: TMenuItem; - Automatisktjekkodestyring1: TMenuItem; - Automatiskvalg1: TMenuItem; + menuAutomatiskTjekkodeStyring: TMenuItem; + menuAutomatiskvalg1: TMenuItem; PanelValgA: TPanel; PanelValg1: TPanel; PanelValg2: TPanel; @@ -92,12 +104,15 @@ PanelManglendePakker5: TPanel; PanelManglendePakker6: TPanel; menuIndlevering: TMenuItem; + chkForstorTilDirekte: TCheckBox; + chkEmballageRepareret: TCheckBox; + KommentarST: TLabel; + + function getProddato() : TDate; function getProddag() : String; function retRutenummer(rutenummer : String) : String; - function GetCurrentPrinterHandle() : THandle; - function SavePChar(p: PChar): PChar; procedure PlaySound(filename : PWideChar); procedure StartScreen(); @@ -113,21 +128,21 @@ procedure radioStorPakkeClick(Sender: TObject); procedure radioLillePakkeClick(Sender: TObject); procedure chkSporgEfterKundeClick(Sender: TObject); - procedure Pakkernormal1Click(Sender: TObject); + procedure menuNatXpress1Click(Sender: TObject); procedure Testforbindelsen1Click(Sender: TObject); procedure Testprinter1Click(Sender: TObject); procedure Om1Click(Sender: TObject); procedure Lukprogrammet1Click(Sender: TObject); procedure Sprgefterboghandlernummer1Click(Sender: TObject); - procedure ReturpakkerfraDAO1Click(Sender: TObject); - procedure Returpakkerfraboghandler1Click(Sender: TObject); - procedure Storepakker1Click(Sender: TObject); - procedure Smpakker1Click(Sender: TObject); + procedure menuNatxpressReturDAO1Click(Sender: TObject); + procedure menuNatxpressReturfraKunde1Click(Sender: TObject); + procedure menuStorePakkerClick(Sender: TObject); + procedure menuSmaaPakkerClick(Sender: TObject); procedure Testlyd1Click(Sender: TObject); procedure Testlyd2Click(Sender: TObject); procedure Button1Click(Sender: TObject); procedure ListBox1DrawItem(Control: TWinControl; Index: Integer; Rect: TRect; State: TOwnerDrawState); - procedure Budlevering1Click(Sender: TObject); + procedure menuDaoDirekte1Click(Sender: TObject); procedure BtnDownloadKontrolfilClick(Sender: TObject); procedure BtnOpdaterListenClick(Sender: TObject); procedure DownloadBladhusRuteskiftfil(); @@ -139,9 +154,9 @@ procedure FormDestroy(Sender: TObject); procedure BtnUploadLogfilClick(Sender: TObject); procedure BtnDownloadRuteskiftFilClick(Sender: TObject); - procedure Pakkeshoplevering1Click(Sender: TObject); + procedure menuPakkeshop1Click(Sender: TObject); procedure btnNulstilClick(Sender: TObject); - procedure Returpakkerfrapakkeshop1Click(Sender: TObject); + procedure menuPakkeshopRetur1Click(Sender: TObject); procedure InitNatxpresslevering(); procedure InitReturFraDao(); procedure InitReturFraKunde(); @@ -158,9 +173,9 @@ procedure Timer1Timer(Sender: TObject); procedure Scanogstjekkoden1Click(Sender: TObject); procedure chkScanTjekkodeClick(Sender: TObject); - procedure Automatisktjekkodestyring1Click(Sender: TObject); + procedure menuAutomatiskTjekkodeStyringClick(Sender: TObject); procedure SendInfoTilServer(Sted, Scanningtype, Infotype, Info : String); - procedure Automatiskvalg1Click(Sender: TObject); + procedure menuAutomatiskvalg1Click(Sender: TObject); procedure PanelValgAClick(Sender: TObject); procedure PanelValg1Click(Sender: TObject); procedure PanelValg2Click(Sender: TObject); @@ -174,11 +189,18 @@ procedure SletLogfiler(Path: string; FileList: TStrings); procedure Manualgenerel1Click(Sender: TObject); procedure TjekkerUrls(); + procedure TjekkerEnkeltUrl(UrlNavn: String; Url: String; var urlFejl: integer); procedure menuIndleveringClick(Sender: TObject); - procedure PrintPakkeshopLabel( PakkeshopLabel : TPakkeshopLabel); - procedure CheckPrintQue(tjektype : string); + + + //Nedarvet fra IParentForm + procedure Msg( msg : string); + procedure LogMessage( msg : string); + procedure SetPrinterstatusText( txt: string; alert: boolean); + function GetFormObject() : TForm; + private @@ -187,17 +209,23 @@ SkrivLog : String; Sted : String; StedNavn : String; - Url, UrlNormal, UrlReturDAO, UrlReturBoghandler, UrlBudlevering, UrlManglendeScanninger, UrlPakkeshoplevering, UrlReturPakkeshop, UrlPakkeshopManglendeScanninger, UrlPakkeshopManglendeReturScanninger,UrlIndleveringsPakke,UrlIndleveringsPakkeManglendeScanninger,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; @@ -206,29 +234,7 @@ 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; @@ -241,12 +247,13 @@ PakkeshopStregkode, PakkeshopTjekkode : String; BoghandlerStregkode, BoghandlerTjekkode : String; TjekUrls : String; + Config : TConfiguration; - Barcode : TStBarcode; + 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(); @@ -256,13 +263,12 @@ procedure SkrivScanningLogFil(var tekst : string); function TjekKoreliste(var RuteNummer, Koreliste : string) : string; procedure VisAlarmSkaerm(strMessage: string); + function InjectURL(Url : String) : String; public { Public declarations } end; - function GetPixelsPerInchX(): Integer; - function GetPixelsPerInchY(): Integer; var MainForm: TMainForm; @@ -278,14 +284,19 @@ {$R *.dfm} +//FormCreate kaldes før InitForm + procedure TMainForm.InitForm(Farve,Titel,Url : String); begin -// 20150309: startr + IdHTTP1.ConnectTimeout := 5000; // Vent max 5 sek på connect + IdHTTP1.ReadTimeout := 10000; // Vent max 10 sek på read + + + + StaticTextManglendePakker.Caption := ''; -// 20150309: slut - Barcode := TStBarcode.Create(MainForm);//Dynamisk oprettelse af Barcode component PanelValg1.Color := clBtnFace; if PanelValg1.Enabled = true then @@ -357,9 +368,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 @@ -393,7 +406,7 @@ PrinterstatusStaticText1.Color := MainForm.Color; end; - if PakkeshopLevering1.Checked or Pakkernormal1.Checked then + if menuPakkeshop1.Checked or menuNatXpress1.Checked then PakkeshopText1.Visible := true else PakkeshopText1.Visible := false; @@ -418,7 +431,7 @@ end; end; - if Automatisktjekkodestyring1.Checked then + if menuAutomatiskTjekkodeStyring.Checked then begin chkScanTjekkode.Enabled := false; Scanogstjekkoden1.Enabled := false; @@ -454,6 +467,7 @@ end; end; + end; procedure TMainForm.Altidprintepakkelabel1Click(Sender: TObject); @@ -475,9 +489,9 @@ StregkodeST.Caption := Stregkode; end; -procedure TMainForm.Automatisktjekkodestyring1Click(Sender: TObject); +procedure TMainForm.menuAutomatiskTjekkodeStyringClick(Sender: TObject); begin - if Automatisktjekkodestyring1.Checked then + if menuAutomatiskTjekkodeStyring.Checked then begin chkScanTjekkode.Enabled := false; Scanogstjekkoden1.Enabled := false; @@ -490,23 +504,35 @@ end; -procedure TMainForm.Automatiskvalg1Click(Sender: TObject); +procedure TMainForm.menuAutomatiskvalg1Click(Sender: TObject); begin // Skal ikke toggle men bare sætte funktionen on // Fravælges ved at vælge en scanningstype - AutomatiskValg1.Checked := true; + menuAutomatiskvalg1.Checked := true; PanelValgA.Color := clGreen; PanelValgA.Font.Color := clWhite; end; +function TMainForm.InjectURL(Url : String) : String; +begin + + Url := Url + '&ver=' + TUtils.URLEncode( TUtils.Sto_GetFmtFileVersion('')); + Url := Url + '&host=' + TUtils.URLEncode( TUtils.GetComputerNameHelper()); + Url := Url + '&user=' + TUtils.URLEncode( TUtils.GetCurrentUserName()); + + Result := Url; +end; + +//InitForm kaldes før FormCreate procedure TMainForm.FormCreate(Sender: TObject); const crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed var - printerInd : integer; gemScanningtype : String; begin + + // Initierer nogle variabler BladhusSted := 00; Application.ShowHint := True; @@ -534,35 +560,69 @@ 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',''); + UrlFindPakketype := ReadString('Settings','UrlFindPakketype','http://omdeling.info/webservices/bogpakkekontrol/FindPakketype.php?stregkode=%s'); + UrlFindPakketype := InjectURL(UrlFindPakketype); + UrlSendPrograminfo := ReadString('Settings','UrlSendPrograminfo','http://omdeling.info/webservices/bogpakkekontrol/SendPrograminfo.php?programnavn=%s&sted=%s&scanningtype=%s&infotype=%s&info=%s'); + UrlSendPrograminfo := InjectURL(UrlSendPrograminfo); + UrlNormal := ReadString('Settings','UrlNormal','http://omdeling.info/webservices/bogpakkekontrol/bogpakkekontrol.php?sted=%s&pakkenummer=%s&boghandlernummer=%s&tjekkode=%s'); + UrlNormal := InjectURL(UrlNormal); + UrlReturDAO := ReadString('Settings','UrlReturDAO','http://omdeling.info/webservices/bogpakkekontrol/bogpakkekontrol.php?sted=%s&pakkenummer=%s&boghandlernummer=%s&returpakketype=%s&pakkestorrelse=%s'); + UrlReturDAO := InjectURL(UrlReturDAO); + UrlReturBoghandler := ReadString('Settings','UrlReturBoghandler','http://omdeling.info/webservices/bogpakkekontrol/bogpakkekontrol.php?sted=%s&pakkenummer=%s&boghandlernummer=%s&returpakketype=%s&pakkestorrelse=%s'); + UrlReturBoghandler := InjectURL(UrlReturBoghandler); + UrlBudlevering := ReadString('Settings','UrlBudlevering','http://omdeling.info/webservices/bogpakkekontrol/bogpakkekontrol.php?sted=%s&pakkenummer=%s&leveringstype=%s&pakkestorrelse=%s'); + UrlBudlevering := InjectURL(UrlBudlevering); + UrlManglendeScanninger := ReadString('Settings','UrlManglendeScanninger','http://omdeling.info/webservices/bogpakkekontrol/bogpakkemanglendescanninger.php?sted=%s&type=%s'); + UrlManglendeScanninger := InjectURL(UrlManglendeScanninger); + UrlEKLoverforsel := ReadString('Settings','UrlEKLoverforsel','http://omdeling.info/webservices/bogpakkekontrol/bogpakkertilekl.php?sted=%s'); + UrlEKLoverforsel := InjectURL(UrlEKLoverforsel); UrlEKLoverforselPakkeshop := ReadString('Settings','UrlEKLoverforselPakkeshop','http://omdeling.info/webservices/pakkeshop/pakkertilekl.php?sted=%s'); + UrlEKLoverforselPakkeshop := InjectURL(UrlEKLoverforselPakkeshop); UrlPakkeshoplevering := ReadString('Settings','UrlPakkeshoplevering','http://omdeling.info/webservices/pakkeshop/pakkekontrol.php?sted=%s&stregkode=%s&tjekkode=%s'); + UrlPakkeshoplevering := InjectURL(UrlPakkeshoplevering); + UrlReturPakkeshop := ReadString('Settings','UrlReturPakkeshop','http://omdeling.info/webservices/pakkeshop/returpakkekontrol.php?sted=%s&stregkode=%s'); + UrlReturPakkeshop := InjectURL(UrlReturPakkeshop); + 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'); + UrlPakkeshopManglendeScanninger := InjectURL(UrlPakkeshopManglendeScanninger); + UrlPakkeshopManglendeReturScanninger := ReadString('Settings','UrlPakkeshopManglendeReturScanninger','http://omdeling.info/webservices/pakkeshop/pakkemanglendereturscanninger.php?sted=%s'); + UrlPakkeshopManglendeReturScanninger := InjectURL(UrlPakkeshopManglendeReturScanninger); UrlIndleveringsPakke := ReadString('Settings','UrlIndleveringsPakke','http://omdeling.info/webservices/pakkeshop/PakkekontrolIndleveringskode.php?sted=%s&pakkekode=%s'); + UrlIndleveringsPakke := InjectURL(UrlIndleveringsPakke); + UrlIndleveringsPakkeManglendeScanninger := ReadString('Settings', 'UrlIndleveringsPakkeManglendeScanninger','http://omdeling.info/webservices/pakkeshop/IndleveringsPakkeManglendeScanninger.php?sted=%s'); + UrlIndleveringsPakkeManglendeScanninger := InjectURL(UrlIndleveringsPakkeManglendeScanninger); + + URLOmdirigerTilPakkeshop := ReadString('Settings', 'URLOmdirigerTilPakkeshop','http://omdeling.info/webservices/pakkeshop/PakkeKontrolOmdirigerTilPakkeshop.php?sted=%s&stregkode=%s'); + URLOmdirigerTilPakkeshop := InjectURL(URLOmdirigerTilPakkeshop); - LabelType := ReadInteger('Settings','LabelType',1); FarveNormal := ReadString('Settings','FarveNormal','D8D8D8'); TitelNormal := ReadString('Settings','TitelNormal','Modtagelse af DAO NAT X-PRESS pakker'); FarveReturDAO := ReadString('Settings','FarveReturDAO','A9F5A9'); @@ -615,81 +675,13 @@ if Scanningtype = 'A' then begin - Automatiskvalg1.Checked := true; + menuAutomatiskvalg1.Checked := true; Scanningtype := '1'; PanelValgA.Color := clGreen; 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 @@ -715,7 +707,7 @@ if ScanTjekkodeAutomatik = '1' then begin - Automatisktjekkodestyring1.Checked := true; + menuAutomatiskTjekkodeStyring.Checked := true; chkScanTjekkode.Enabled := false; Scanogstjekkoden1.Enabled := false; end; @@ -745,6 +737,9 @@ {$IfDef STED_BK} SpecialVersionSted := 'BK'; {$EndIf} +{$IfDef STED_TK} + SpecialVersionSted := 'TK';// BK-Trykkompagniet +{$EndIf} {$IfDef STED_DBK} SpecialVersionSted := 'DBK'; {$EndIf} @@ -755,7 +750,6 @@ 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) @@ -773,16 +767,51 @@ if SpecialVersionSted = 'NS' then begin - SpecialVersionSted := '01'; - SpecialVersionScanningtype := '4'; + //SpecialVersionSted := '01'; // Fra før NS overtog scanning løssalg + //SpecialVersionScanningtype := '4'; + + //FarveNormal := 'A9F5A9'; // her kan vi evt. overrule ini fil + Sted := SpecialVersionSted; + // her skal vi også disable de knapper BK ikke kan bruge + PanelValg2.Enabled := false; + PanelValg2.Font.Color := clInactiveCaption; + PanelValg3.Enabled := false; + PanelValg3.Font.Color := clInactiveCaption; + //PanelValg6.Enabled := false; + //PanelValg6.Font.Color := clInactiveCaption; + + // her skal vi også disable de menupunkter FD ikke kan bruge + menuNatxpressReturDAO1.Enabled := false; + menuNatxpressReturfraKunde1.Enabled := false; + + //Returpakkerfrapakkeshop1.Enabled := false; end; + if SpecialVersionSted = 'FD' then begin - SpecialVersionSted := '03'; - SpecialVersionScanningtype := '4'; + //SpecialVersionSted := '03'; //fra før at FD overtog scanning + //SpecialVersionScanningtype := '4'; + + + //FarveNormal := 'A9F5A9'; // her kan vi evt. overrule ini fil + Sted := SpecialVersionSted; + // her skal vi også disable de knapper BK ikke kan bruge + PanelValg2.Enabled := false; + PanelValg2.Font.Color := clInactiveCaption; + PanelValg3.Enabled := false; + PanelValg3.Font.Color := clInactiveCaption; + //PanelValg6.Enabled := false; + //PanelValg6.Font.Color := clInactiveCaption; + + // her skal vi også disable de menupunkter FD ikke kan bruge + menuNatxpressReturDAO1.Enabled := false; + menuNatxpressReturfraKunde1.Enabled := false; + + //Returpakkerfrapakkeshop1.Enabled := false; + end; - if SpecialVersionSted = 'BK' then + if (SpecialVersionSted = 'BK') OR (SpecialVersionSted = 'TK') then begin //FarveNormal := 'A9F5A9'; // her kan vi evt. overrule ini fil Sted := SpecialVersionSted; @@ -791,12 +820,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; + menuNatxpressReturDAO1.Enabled := false; + menuNatxpressReturfraKunde1.Enabled := false; + + //Returpakkerfrapakkeshop1.Enabled := false; + if SpecialVersionScanningtype = 'A' then begin Scanningtype := '1'; @@ -820,15 +852,14 @@ 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 DBK ikke kan bruge - ReturpakkerfraDAO1.Enabled := false; - Returpakkerfraboghandler1.Enabled := false; + menuNatxpressReturDAO1.Enabled := false; + menuNatxpressReturfraKunde1.Enabled := false; - Pakkeshoplevering1.Enabled := false; - Returpakkerfrapakkeshop1.Enabled := false; + menuPakkeshop1.Enabled := false; + menuPakkeshopRetur1.Enabled := false; if SpecialVersionScanningtype = 'A' then begin @@ -863,18 +894,18 @@ PanelValg7.Font.Color := clInactiveCaption; // her skal vi også disable de menupunkter Bladhusene (01, 02, 03 og 04) ikke kan bruge - Automatiskvalg1.Enabled := false; + menuAutomatiskvalg1.Enabled := false; - Pakkernormal1.Enabled := false; - ReturpakkerfraDAO1.Enabled := false; - Returpakkerfraboghandler1.Enabled := false; - Budlevering1.Enabled := false; - Pakkeshoplevering1.Enabled := false; - Returpakkerfrapakkeshop1.Enabled := false; + menuNatXpress1.Enabled := false; + menuNatxpressReturDAO1.Enabled := false; + menuNatxpressReturfraKunde1.Enabled := false; + menuDaoDirekte1.Enabled := false; + menuPakkeshop1.Enabled := false; + menuPakkeshopRetur1.Enabled := false; if SpecialVersionScanningtype = 'A' then begin Scanningtype := '4'; - Budlevering1.Enabled := true; + menuDaoDirekte1.Enabled := true; PanelValg4.Font.Color := clWindowText; PanelValg4.Enabled := true; end @@ -883,41 +914,41 @@ Scanningtype := SpecialVersionScanningtype; PanelValgA.Enabled := false; PanelValgA.Font.Color := clInactiveCaption; - AutomatiskValg1.Checked := false; + menuAutomatiskvalg1.Checked := false; PanelValgA.Color := clBtnFace; if Scanningtype = '1' then begin - Pakkernormal1.Enabled := true; + menuNatXpress1.Enabled := true; PanelValg1.Enabled := true; PanelValg1.Font.Color := clWindowText; end; if Scanningtype = '2' then begin - ReturpakkerfraDAO1.Enabled := true; + menuNatxpressReturDAO1.Enabled := true; PanelValg2.Enabled := true; PanelValg2.Font.Color := clWindowText; end; if Scanningtype = '3' then begin - Returpakkerfraboghandler1.Enabled := true; + menuNatxpressReturfraKunde1.Enabled := true; PanelValg3.Enabled := true; PanelValg3.Font.Color := clWindowText; end; if Scanningtype = '4' then begin - Budlevering1.Enabled := true; + menuDaoDirekte1.Enabled := true; PanelValg4.Enabled := true; PanelValg4.Font.Color := clWindowText; end; if Scanningtype = '5' then begin - Pakkeshoplevering1.Enabled := true; + menuPakkeshop1.Enabled := true; PanelValg5.Enabled := true; PanelValg5.Font.Color := clWindowText; end; if Scanningtype = '6' then begin - Returpakkerfrapakkeshop1.Enabled := true; + menuPakkeshopRetur1.Enabled := true; PanelValg6.Enabled := true; PanelValg6.Font.Color := clWindowText; end; @@ -998,12 +1029,12 @@ if Pakketype = '1' then begin - Storepakker1.Checked := true; + menuStorePakker.Checked := true; radioStorPakke.Checked := true; end else begin - Smpakker1.Checked := true; + menuSmaaPakker.Checked := true; radioLillePakke.Checked := true; end; @@ -1051,14 +1082,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; @@ -1067,14 +1094,14 @@ // UBD skal p.t. ikke have adgang til flg. funktioner if ( (Sted = '1') or (Sted = '2') or (Sted = '3') or (Sted = '4') ) then begin - ReturpakkerfraDAO1.Visible := false; - Returpakkerfraboghandler1.Visible := false; - Budlevering1.Visible := false; - Storepakker1.Visible := false; - Smpakker1.Visible := false; + menuNatxpressReturDAO1.Visible := false; + menuNatxpressReturfraKunde1.Visible := false; + menuDaoDirekte1.Visible := false; + menuStorePakker.Visible := false; + menuSmaaPakker.Visible := false; Testprinter1.Visible := false; - Pakkeshoplevering1.Visible := false; - Returpakkerfrapakkeshop1.Visible := false; + menuPakkeshop1.Visible := false; + menuPakkeshopRetur1.Visible := false; end; if (BladhusSted > 00) and (BladhusSted < Length(BladhusStedNavn)) then @@ -1182,6 +1209,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 @@ -1192,11 +1222,15 @@ 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 VisAlarmSkaerm( 'Der skal scannes en stregkode...' ); @@ -1246,6 +1280,22 @@ 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 @@ -1443,19 +1493,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 VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); exit; end; - if Automatiskvalg1.Checked and (Length(Stregkode) > 8) then + if (menuAutomatiskvalg1.Checked and (Length(Stregkode) > 8) ) then begin GemStregkode := Stregkode; if Pakketype = 'NatXpress' then @@ -1484,25 +1534,35 @@ InitPakkeshoplevering(); end; end - // Retur kan ikke scannes med 'Automatisk valg' + else if Pakketype = 'PakkeshopRetur' then + begin + if Scanningtype <> '6' then + begin + VisAlarmSkaerm( Stregkode + ' Pakkeshop retur,'#13#10' kan ikke bruges med automatisk valg' ); + + exit; + end; + end + else begin // Her skal komme en alarm og rød skærm - VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); + //VisAlarmSkaerm( Stregkode + ' kan ikke vælges på dette scanningsted' ); + VisAlarmSkaerm( Stregkode + ' kan ikke bruges med automatisk valg' ); exit; end; Stregkode := GemStregkode; end - else if Automatiskvalg1.Checked and (PakkeshopText1.Caption = 'Stregkode') then + else if menuAutomatiskvalg1.Checked and (PakkeshopText1.Caption = 'Stregkode') then begin VisAlarmSkaerm( 'Pakkenummer ikke gyldigt (for kort)' ); exit; end; - if not Automatiskvalg1.Checked then + if not menuAutomatiskvalg1.Checked then begin if ( (Pakkescanningtype <> Scanningtype) and (Scanningtype <> '2') and (Scanningtype <> '3') ) then begin @@ -1515,7 +1575,7 @@ - if (PakkeshopText1.Visible = true) and (PakkeshopText1.Caption = 'Stregkode') and Automatisktjekkodestyring1.Checked then + if (PakkeshopText1.Visible = true) and (PakkeshopText1.Caption = 'Stregkode') and menuAutomatiskTjekkodeStyring.Checked then begin chkScanTjekkode.Checked := false; for i := 0 to length(stregkoderMedTjekkodeArray)-1 do @@ -1528,7 +1588,7 @@ end; end; - if Pakkernormal1.Checked and not Scanogstjekkoden1.Checked then + if menuNatXpress1.Checked and not Scanogstjekkoden1.Checked then begin // Når vi ikke kræver tjekkode er alt ok her BoghandlerStregkode := Stregkode; @@ -1538,7 +1598,7 @@ Stregkode := ''; InitScreen(); end - else if (PakkeshopLevering1.Checked or Pakkernormal1.Checked) and not Scanogstjekkoden1.Checked then + else if (menuPakkeshop1.Checked or menuNatXpress1.Checked) and not Scanogstjekkoden1.Checked then begin // Når vi ikke kræver tjekkode er alt ok her PakkeshopStregkode := Stregkode; @@ -1550,7 +1610,7 @@ Stregkode := ''; InitScreen(); end - else if PakkeshopLevering1.Checked or Pakkernormal1.Checked then + else if menuPakkeshop1.Checked or menuNatXpress1.Checked then if PakkeshopText1.Caption = 'Stregkode' then begin if length(Stregkode) > 5 then @@ -1576,17 +1636,17 @@ PakkeshopTjekkode := Stregkode; BoghandlerTjekkode := Stregkode; PakkeshopText1.Caption := 'Stregkode'; - if (PakkeshopLevering1.Checked) then + if (menuPakkeshop1.Checked) then MainForm.Color := TUtils.HexToTColor(FarvePakkeshoplevering); - if (Pakkernormal1.Checked) then + if (menuNatXpress1.Checked) then MainForm.Color := TUtils.HexToTColor(FarveNormal); btnNulstil.Visible := false; end else begin - if (PakkeshopLevering1.Checked) then + if (menuPakkeshop1.Checked) then VisAlarmSkaerm('Du skal scanne en tjekkode til stregkode ' + PakkeshopStregkode); - if (Pakkernormal1.Checked) then + if (menuNatXpress1.Checked) then VisAlarmSkaerm('Du skal scanne en tjekkode til stregkode ' + BoghandlerStregkode); StregKode := ''; @@ -1598,11 +1658,12 @@ InitScreen(); end; - 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 + if not menuPakkeshop1.Checked and not menuNatXpress1.Checked or (menuPakkeshop1.Checked and (PakkeshopStregkode <> '') and (PakkeshopTjekkode <> '')) or (menuNatXpress1.Checked and (Scanogstjekkoden1.Checked and (BoghandlerStregkode <> '') and (BoghandlerTjekkode <> '') or not Scanogstjekkoden1.Checked)) then begin - if PakkeshopLevering1.Checked and (PakkeshopStregkode <> '') and (PakkeshopTjekkode <> '') then + + if menuPakkeshop1.Checked and (PakkeshopStregkode <> '') and (PakkeshopTjekkode <> '') then StregKode := PakkeshopStregkode; - if Pakkernormal1.Checked and ((BoghandlerStregkode <> '') and (BoghandlerTjekkode <> '') or not Scanogstjekkoden1.Checked) then + if menuNatXpress1.Checked and ((BoghandlerStregkode <> '') and (BoghandlerTjekkode <> '') or not Scanogstjekkoden1.Checked) then StregKode := BoghandlerStregkode; StregkodeST.Caption := StregKode; try @@ -1616,7 +1677,7 @@ exit; end; - if (Pakkernormal1.Checked or Budlevering1.Checked or PakkeshopLevering1.Checked) then + if (menuNatXpress1.Checked or menuDaoDirekte1.Checked or menuPakkeshop1.Checked) then begin PrintLabel(RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, PrintNyLabel); pakkeErScannet := pos('PAKKEN ER SCANNET', BoghandlerNavn); @@ -1637,10 +1698,10 @@ 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 + if ( menuNatXpress1.Checked and (pakkeErScannet = 0) and (pakkeForkertSted = 0) and (tjekkodemangler = 0) and (RuteNummerST.Caption <> 'Ukendt') ) or (Copy(Kommentar,1,2) = 'Ok') then begin MainForm.Color := TUtils.HexToTColor(Farve); - if Storepakker1.Checked then + if menuStorePakker.Checked then begin PlaySound(PWideChar(ScannetOkStorLyd)); end @@ -1650,10 +1711,10 @@ end; btnNulstil.Visible := false; end - else if (Returpakkerfradao1.Checked or Returpakkerfraboghandler1.Checked) then + else if (menuNatxpressReturDAO1.Checked or menuNatxpressReturfraKunde1.Checked) then begin MainForm.Color := TUtils.HexToTColor(Farve); - if Storepakker1.Checked then + if menuStorePakker.Checked then begin PlaySound(PWideChar(ScannetOkStorLyd)); end @@ -1674,12 +1735,13 @@ begin VisAlarmSkaerm(''); end; + if not btnNulstil.Visible then begin - If (Budlevering1.Checked) then + If (menuDaoDirekte1.Checked) then begin - if Storepakker1.Checked then + if menuStorePakker.Checked then begin PlaySound(PWideChar(ScannetOkStorLyd)); end @@ -1723,8 +1785,15 @@ Key := #0; + + + + + end; //End of OnKeyPress + + procedure TMainForm.SendInfoTilServer(Sted, Scanningtype, Infotype, Info : String); const crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed @@ -1766,11 +1835,12 @@ begin - if Budlevering1.Checked or Pakkeshoplevering1.Checked or Returpakkerfrapakkeshop1.Checked or Pakkernormal1.Checked then + if menuDaoDirekte1.Checked or menuPakkeshop1.Checked or menuPakkeshopRetur1.Checked or menuNatXpress1.Checked or menuIndlevering.Checked then begin for i := ListBox2.items.count-1 downto 0 do if pos(StregKode,ListBox2.items[i]) <> 0 then begin + wrkAntalSenere := 0;//initial Value // Ajourføring af tæller for manglende pakker (scanninger) wrkAntal := StaticTextManglendePakker.Caption; @@ -1885,7 +1955,7 @@ PanelManglendePakker6.Visible := false; end; end; -// 20150310: slut + ListBox2.items.delete(i); end; end; @@ -1915,54 +1985,14 @@ begin Altidprintepakkelabel1.Enabled := false; - Pakkernormal1.Visible := false; - ReturpakkerfraDAO1.Visible := false; - Returpakkerfraboghandler1.Visible := false; + menuNatXpress1.Visible := false; + menuNatxpressReturDAO1.Visible := false; + menuNatxpressReturfraKunde1.Visible := false; 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 + + if menuDaoDirekte1.Checked then begin IndlesScanningLogFil(); end; @@ -1986,8 +2016,8 @@ 02 : begin; // BK Testprinter1.Visible := true; - Smpakker1.Enabled := true; - Storepakker1.Enabled := true; + menuSmaaPakker.Enabled := true; + menuStorePakker.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; BtnDownloadKontrolfil.Enabled := false; // kontrolfil bruges ikke her @@ -2024,8 +2054,8 @@ end; 04 : begin; // DBK Testprinter1.Visible := true; - Smpakker1.Enabled := true; - Storepakker1.Enabled := true; + menuSmaaPakker.Enabled := true; + menuStorePakker.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; BtnDownloadKontrolfil.Enabled := false; // kontrolfil bruges ikke her @@ -2058,7 +2088,7 @@ end; - if Pakkernormal1.Checked then + if menuNatXpress1.Checked then begin if (BoghandlerTjekkode = '') then begin @@ -2066,23 +2096,23 @@ end; URLStr := Format(UrlNormal,[Sted, PakkeNr, BoghandlerNummer, BoghandlerTjekkode]); end - else if ReturpakkerfraDAO1.Checked then + else if menuNatxpressReturDAO1.Checked then begin URLStr := Format(UrlReturDAO,[Sted, PakkeNr, BoghandlerNummer, 'DAO', pakkestorrelse]); end - else if Returpakkerfraboghandler1.Checked then + else if menuNatxpressReturfraKunde1.Checked then begin URLStr := Format(UrlReturBoghandler,[Sted, PakkeNr, BoghandlerNummer, 'Boghandler', pakkestorrelse]); end - else if Budlevering1.Checked then + else if menuDaoDirekte1.Checked then begin URLStr := Format(UrlBudlevering,[Sted, PakkeNr, 'bud', pakkestorrelse]); end - else if Pakkeshoplevering1.Checked then + else if menuPakkeshop1.Checked then begin URLStr := Format(UrlPakkeshoplevering,[Sted, PakkeNr, PakkeshopTjekkode]); end - else if Returpakkerfrapakkeshop1.Checked then + else if menuPakkeshopRetur1.Checked then begin URLStr := Format(UrlReturPakkeshop,[Sted, PakkeNr]); end @@ -2094,6 +2124,12 @@ 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); @@ -2115,9 +2151,10 @@ end; end; end; + XMLDocument1.LoadFromXML(WebSvar); try - if Pakkeshoplevering1.Checked or Returpakkerfrapakkeshop1.Checked then + if menuPakkeshop1.Checked or menuPakkeshopRetur1.Checked then begin RuteNummer := XMLDocument1.ChildNodes.FindNode('PakkeKontrol').ChildNodes.FindNode('PakkeshopTurid').Text; Kommentar := XMLDocument1.ChildNodes.FindNode('PakkeKontrol').ChildNodes.FindNode('Stregkodematch').Text; @@ -2125,7 +2162,7 @@ BoghandlerNavn := BoghandlerNavn + ' ' + XMLDocument1.ChildNodes.FindNode('PakkeKontrol').ChildNodes.FindNode('PakkeshopNavn').Text; PrintNyLabel := False; - if Pakkeshoplevering1.Checked then + if menuPakkeshop1.Checked then begin try PrintNyLabelInteger := StrToInt(XMLDocument1.ChildNodes.FindNode('PakkeKontrol').ChildNodes.FindNode('PakkeshopPrintPakkeLabel').Text); @@ -2138,7 +2175,7 @@ end; end; end - else if menuIndlevering.Checked then + else if menuIndlevering.Checked or chkForstorTilDirekte.Checked then begin @@ -2149,9 +2186,11 @@ begin PrintNyLabel := True; //Indleveringskode vil ALTID udskrive label PakkeshopLabel := TPakkeshopLabel.Create( XMLDocument1 ); //Opret struct og parse xml doc - RuteNummer := PakkeshopLabel.Koreliste; + RuteNummer := PakkeshopLabel.Koreliste + ' -> ' + PakkeshopLabel.PakkeshopTurid; + Stregkode := PakkeshopLabel.Stregkode; - PrintPakkeshopLabel( PakkeshopLabel ); + LabelPrint.PrintPakkeshopLabel( PakkeshopLabel ); + chkForstorTilDirekte.Checked := false; end; @@ -2164,7 +2203,7 @@ Kommentar := XMLDocument1.ChildNodes.FindNode('BogpakkeKontrol').ChildNodes.FindNode('Kommentar').Text; BoghandlerNavn := XMLDocument1.ChildNodes.FindNode('BogpakkeKontrol').ChildNodes.FindNode('BoghandlerNavn').Text; Leveringssted := XMLDocument1.ChildNodes.FindNode('BogpakkeKontrol').ChildNodes.FindNode('Leveringssted').Text; - if Budlevering1.Checked then + if menuDaoDirekte1.Checked then begin try SmsKode := XMLDocument1.ChildNodes.FindNode('BogpakkeKontrol').ChildNodes.FindNode('SmsKode').Text; @@ -2199,7 +2238,7 @@ PrintNyLabel := False; end; end - else if (Budlevering1.Checked) and (Leveringssted <> Sted) then + else if (menuDaoDirekte1.Checked) and (Leveringssted <> Sted) then begin if (Leveringssted = 'E') and (Sted = 'DBK') then begin @@ -2228,7 +2267,7 @@ //Label1.Caption := Kommentar; // bruges hvis der skal vises linieskift - det kan man ikke i en staticText BoghandlerNavnST.Caption := StringReplace(BoghandlerNavn, ' & ', ' && ', [rfReplaceAll, rfIgnoreCase]); List1msg := TimeToStr(now) + '; '; - if Pakkeshoplevering1.Checked then + if menuPakkeshop1.Checked then List1msg := List1msg + PakkeshopStregkode + ' ' + PakkeshopTjekkode + '; ' + KommentarST.Caption + '; '; List1Pakkestorrelse := ''; if radioStorPakke.Checked then @@ -2240,21 +2279,21 @@ List1Pakkestorrelse := 'Lille pakke'; end; List1msg := List1msg + BoghandlerNavn + '; '; - if ReturpakkerfraDAO1.Checked then + if menuNatxpressReturDAO1.Checked then begin List1msg := List1msg + RightStr(Kommentar, Length(Kommentar)-8); end; - if Returpakkerfraboghandler1.Checked then + if menuNatxpressReturfraKunde1.Checked then begin List1msg := List1msg + RightStr(Kommentar, Length(Kommentar)-16); end; - if ReturpakkerfraDAO1.Checked or Returpakkerfraboghandler1.Checked then + if menuNatxpressReturDAO1.Checked or menuNatxpressReturfraKunde1.Checked then List1msg := List1msg + '; ' + List1Pakkestorrelse; if length(BoghNr) > 0 then begin List1Msg := List1Msg + '; Indtastet ' + BoghNr; end; - if Budlevering1.Checked then + if menuDaoDirekte1.Checked then begin List1msg := TimeToStr(now) + '; ' + Kommentar + '; ' + BoghandlerNavn; if (radioStorPakke.Checked) then @@ -2266,11 +2305,11 @@ List1msg := List1msg + '; Lille pakke'; end; end; - if Returpakkerfrapakkeshop1.Checked then + if menuPakkeshopRetur1.Checked then begin List1msg := List1msg + Stregkode + ' ' + RightStr(Kommentar, Length(Kommentar)-6); end; - if Pakkernormal1.Checked then + if menuNatXpress1.Checked then begin if (Kommentar = '***** Kommentar *****') // fra test printer funktionen or (BoghandlerNavn = 'Forbindelse ok') // fra test forbindelse funktionen @@ -2283,6 +2322,12 @@ 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); @@ -2304,7 +2349,7 @@ kontrolKoreliste : string; nytRuteNummer, nyFarve : String; begin - if Budlevering1.Checked then + if menuDaoDirekte1.Checked then RuteNummerST.Color := TUtils.HexToTColor(Farve); pakkeErScannet := pos('PAKKEN ER SCANNET', BoghandlerNavn); @@ -2342,7 +2387,7 @@ end; end else - if Budlevering1.Checked then + if menuDaoDirekte1.Checked then begin if (BoghandlerNavn = 'Ukendt pakke') then begin @@ -2411,7 +2456,7 @@ end; - if Budlevering1.Checked then + if menuDaoDirekte1.Checked then begin case BladhusSted of 00 : begin; @@ -2423,7 +2468,7 @@ 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; @@ -2431,13 +2476,13 @@ // 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; @@ -2445,13 +2490,13 @@ // 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 @@ -2460,12 +2505,12 @@ end; // Hvis det er normal bogpakke modtagelse til UBD skal vi p.t. ikke printe - men stopper her - if Pakkernormal1.Checked and ( (Sted = '1') or (Sted = '2') or (Sted = '3') or (Sted = '4') ) then + if menuNatXpress1.Checked and ( (Sted = '1') or (Sted = '2') or (Sted = '3') or (Sted = '4') ) then begin exit; end; - if Budlevering1.Checked or ( Sprgefterboghandlernummer1.Enabled and chkSporgEfterKunde.Checked and ( (RuteNummer = 'Ukendt') or (RuteNummer = 'Ukendt tur') or (RuteNummer = 'Retur ukendt') or (pakkeErScannet > 0) ) and (printNyLabel = false) ) then + if menuDaoDirekte1.Checked or ( Sprgefterboghandlernummer1.Enabled and chkSporgEfterKunde.Checked and ( (RuteNummer = 'Ukendt') or (RuteNummer = 'Ukendt tur') or (RuteNummer = 'Retur ukendt') or (pakkeErScannet > 0) ) and (printNyLabel = false) ) then begin end else @@ -2487,85 +2532,25 @@ 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); begin - Storepakker1.Checked := true; + menuStorePakker.Checked := true; radioStorPakke.Checked := true; end; procedure TMainForm.radioLillePakkeClick(Sender: TObject); begin - Smpakker1.Checked := true; + menuSmaaPakker.Checked := true; radioLillePakke.Checked := true; end; @@ -2608,7 +2593,7 @@ end; end; -procedure TMainForm.Pakkeshoplevering1Click(Sender: TObject); +procedure TMainForm.menuPakkeshop1Click(Sender: TObject); begin Scanningtype := '5'; InitPakkeshoplevering(); @@ -2617,7 +2602,7 @@ procedure TMainForm.NulstilAutomatiskValg(); begin - Automatiskvalg1.Checked := false; + menuAutomatiskvalg1.Checked := false; PanelValgA.Color := clBtnFace; PanelValgA.Font.Color := clWindowText; @@ -2629,7 +2614,7 @@ // her skal vi også disable knappen for 01, 02, 03 og 04 (NS, BK, FD og DBK) PanelValgA.Enabled := false; PanelValgA.Font.Color := clInactiveCaption; - Automatiskvalg1.Enabled := false; + menuAutomatiskvalg1.Enabled := false; end; // 20150317: slut end; @@ -2644,438 +2629,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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 TUtils.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 UrlIndleveringsPakke og UrlIndleveringsPakkeManglendeScanninger - if PanelValg7.Enabled = true then - begin - if TUtils.CheckUrl(UrlIndleveringsPakke) then - begin - logTekst := 'UrlIndleveringsPakke accepteret: ' + UrlIndleveringsPakke; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlIndleveringsPakke svarer ikke: ' + UrlIndleveringsPakke; - 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 UrlPakkeshopManglendeScanninger + if PanelValg5.Enabled = true then + begin + TjekkerEnkeltUrl('UrlPakkeshopManglendeScanninger', UrlPakkeshopManglendeScanninger, urlFejl); + end; - if TUtils.CheckUrl(UrlIndleveringsPakkeManglendeScanninger) then - begin - logTekst := 'UrlIndleveringsPakkeManglendeScanninger accepteret: ' + UrlIndleveringsPakkeManglendeScanninger; - SkrivScanningLogFil(logTekst); - end - else - begin - inc(urlFejl); // Optæller antal fejl - logTekst := 'UrlIndleveringsPakkeManglendeScanninger svarer ikke: ' + UrlIndleveringsPakkeManglendeScanninger; - 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 UrlPakkeshopManglendeReturScanninger + if PanelValg6.Enabled = true then + begin + TjekkerEnkeltUrl('UrlPakkeshopManglendeReturScanninger', UrlPakkeshopManglendeReturScanninger, urlFejl); + end; - // Tjekker UrlEKLoverforsel - if PanelValg1.Enabled = true then - begin - if TUtils.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 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 UrlEKLoverforselPakkeshop - if PanelValg5.Enabled = true then - begin - if TUtils.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 UrlEKLoverforselPakkeshop + if PanelValg5.Enabled = true then + begin + TjekkerEnkeltUrl('UrlEKLoverforselPakkeshop', UrlEKLoverforselPakkeshop, urlFejl); + end; - // Tjekker UrlFindPakketype - if TUtils.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 TUtils.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 UrlFindPakketype + TjekkerEnkeltUrl('UrlFindPakketype', UrlFindPakketype, 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; + // Tjekker UrlSendPrograminfo + TjekkerEnkeltUrl('UrlSendPrograminfo', UrlSendPrograminfo, urlFejl); + + + + logTekst := 'urls er ok'; + ListBox1.Items.Insert(0,TimeToStr(now) + ': ' + logTekst); + SkrivScanningLogFil(logTekst); + + Except + TjekUrls := '-'; // markerer at der var fejl + + end; +end; + +procedure TMainForm.TjekkerEnkeltUrl(UrlNavn: String; Url: String; var urlFejl: integer); +const + crlf = Chr(13) + Chr(10) ; // Carriage return & Linefeed +begin + 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; @@ -3155,18 +2846,8 @@ if Farve <> '' then begin MainForm.Color := TUtils.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 end; - if (Budlevering1.Checked) then + if (menuDaoDirekte1.Checked) then begin InitLillePakke(); end; @@ -3230,7 +2911,7 @@ begin // Skal ikke toggle men bare sætte funktionen on // Fravælges ved at vælge en scanningstype - AutomatiskValg1.Checked := true; + menuAutomatiskvalg1.Checked := true; PanelValgA.Color := clGreen; PanelValgA.Font.Color := clWhite; @@ -3238,7 +2919,7 @@ end; -procedure TMainForm.Pakkernormal1Click(Sender: TObject); +procedure TMainForm.menuNatXpress1Click(Sender: TObject); begin Scanningtype := '1'; NulstilAutomatiskValg(); @@ -3308,7 +2989,7 @@ Falsk := False; - if (Printer.Printers.Count = 0) then + if (LabelPrint.GetPrinterCount() = 0) then begin ShowMessage('Der er ikke installeret en printer på denne PC.'); end @@ -3323,7 +3004,7 @@ DBKbane := '999'; Leveringssted := 'XXX'; PrintLabel(RuteNummer, Kommentar, BoghandlerNavn, Koreliste, SmsKode, DBKbane, Leveringssted, Falsk); - CheckPrintQue('Test'); + LabelPrint.CheckPrintQue('Test', PrinterNavn); end; FocusControl(StregkodeST); end; @@ -3332,7 +3013,7 @@ begin if (TjekPrinter = '1') then begin - CheckPrintQue('Timer'); + LabelPrint.CheckPrintQue('Timer', PrinterNavn); end else begin @@ -3393,6 +3074,7 @@ end; + procedure TMainForm.ListBox1DrawItem(Control: TWinControl; Index: Integer; Rect: TRect; State: TOwnerDrawState); var @@ -3507,14 +3189,14 @@ end; -procedure TMainForm.ReturpakkerfraDAO1Click(Sender: TObject); +procedure TMainForm.menuNatxpressReturDAO1Click(Sender: TObject); begin Scanningtype := '2'; NulstilAutomatiskValg(); InitReturFraDao(); end; -procedure TMainForm.Returpakkerfrapakkeshop1Click(Sender: TObject); +procedure TMainForm.menuPakkeshopRetur1Click(Sender: TObject); begin Scanningtype := '6'; InitReturFraPakkeshop(); @@ -3523,9 +3205,9 @@ procedure TMainForm.InitNatxpresslevering(); begin - AutomatiskTjekkodeStyring1.Enabled := true; + menuAutomatiskTjekkodeStyring.Enabled := true; btnNulstil.Visible := false; - Pakkernormal1.Checked := true; + menuNatXpress1.Checked := true; InitForm(FarveNormal,TitelNormal,UrlNormal); PanelValg1.Color := clGreen; PanelValg1.Font.Color := clWhite; @@ -3537,8 +3219,8 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := true; - Smpakker1.Enabled := false; - Storepakker1.Enabled := false; + menuSmaaPakker.Enabled := false; + menuStorePakker.Enabled := false; radioStorPakke.Enabled := false; radioLillePakke.Enabled := false; ListBox1.Visible := true; @@ -3546,6 +3228,10 @@ BtnEKLoverforsel.Enabled := true; InitLillePakke(); ListBox1.Items.Clear; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + if BladhusSted = 0 then begin IndlesScanningLogFil(); @@ -3555,8 +3241,8 @@ procedure TMainForm.InitReturFraDao(); begin - AutomatiskTjekkodeStyring1.Enabled := false; - ReturpakkerfraDAO1.Checked := true; + menuAutomatiskTjekkodeStyring.Enabled := false; + menuNatxpressReturDAO1.Checked := true; btnNulstil.Visible := false; InitForm(FarveReturDAO,TitelReturDAO,UrlReturDAO); PanelValg2.Color := clGreen; @@ -3569,21 +3255,25 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := false; - Smpakker1.Enabled := true; - Storepakker1.Enabled := true; + menuSmaaPakker.Enabled := true; + menuStorePakker.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; ListBox1.Visible := true; ListBox1.Items.Clear; ListBox2.Items.Clear; BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + InitLillePakke(); end; procedure TMainForm.InitReturFraKunde(); begin - AutomatiskTjekkodeStyring1.Enabled := false; - Returpakkerfraboghandler1.Checked := true; + menuAutomatiskTjekkodeStyring.Enabled := false; + menuNatxpressReturfraKunde1.Checked := true; btnNulstil.Visible := false; InitForm(FarveReturBoghandler,TitelReturBoghandler,UrlReturBoghandler); PanelValg3.Color := clGreen; @@ -3595,21 +3285,25 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := false; - Smpakker1.Enabled := true; - Storepakker1.Enabled := true; + menuSmaaPakker.Enabled := true; + menuStorePakker.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; ListBox1.Visible := true; ListBox1.Items.Clear; ListBox2.Items.Clear; BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + InitLillePakke(); end; procedure TMainForm.InitDirektelevering(); begin - AutomatiskTjekkodeStyring1.Enabled := false; - Budlevering1.Checked := true; + menuAutomatiskTjekkodeStyring.Enabled := false; + menuDaoDirekte1.Checked := true; btnNulstil.Visible := false; InitForm(FarveBudlevering,TitelBudlevering,UrlBudlevering); PanelValg4.Color := clGreen; @@ -3622,8 +3316,8 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := false; - Smpakker1.Enabled := true; - Storepakker1.Enabled := true; + menuSmaaPakker.Enabled := true; + menuStorePakker.Enabled := true; radioStorPakke.Enabled := true; radioLillePakke.Enabled := true; ListBox1.Visible := true; @@ -3634,6 +3328,10 @@ 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(); @@ -3644,8 +3342,8 @@ procedure TMainForm.InitPakkeshoplevering(); begin - AutomatiskTjekkodeStyring1.Enabled := true; - Pakkeshoplevering1.Checked := true; + menuAutomatiskTjekkodeStyring.Enabled := true; + menuPakkeshop1.Checked := true; btnNulstil.Visible := false; InitForm(FarvePakkeshoplevering,TitelPakkeshoplevering,UrlPakkeshoplevering); PanelValg5.Color := clGreen; @@ -3658,8 +3356,8 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := false; - Smpakker1.Enabled := false; - Storepakker1.Enabled := false; + menuSmaaPakker.Enabled := false; + menuStorePakker.Enabled := false; radioStorPakke.Enabled := false; radioLillePakke.Enabled := false; ListBox1.Visible := true; @@ -3669,6 +3367,9 @@ BtnEKLoverforsel.Enabled := true; + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := true; + InitLillePakke(); IndlesScanningLogFil(); if BladhusSted = 0 then @@ -3681,8 +3382,8 @@ procedure TMainForm.InitReturFraPakkeshop(); begin - AutomatiskTjekkodeStyring1.Enabled := false; - Returpakkerfrapakkeshop1.Checked := true; + menuAutomatiskTjekkodeStyring.Enabled := false; + menuPakkeshopRetur1.Checked := true; btnNulstil.Visible := false; InitForm(FarveReturPakkeshop,TitelReturPakkeshop,UrlReturPakkeshop); PanelValg6.Color := clGreen; @@ -3695,8 +3396,8 @@ Sprgefterboghandlernummer1.Checked := false; chkSporgEfterKunde.Checked := false; Sprgefterboghandlernummer1.Enabled := false; - Smpakker1.Enabled := false; - Storepakker1.Enabled := false; + menuSmaaPakker.Enabled := false; + menuStorePakker.Enabled := false; radioStorPakke.Enabled := false; radioLillePakke.Enabled := false; ListBox1.Visible := true; @@ -3704,6 +3405,11 @@ BtnDownloadKontrolfil.Enabled := false; BtnOpdaterListen.Enabled := true; BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + + InitLillePakke(); IndlesScanningLogFil(); if BladhusSted = 0 then @@ -3714,7 +3420,7 @@ IdFTP1.PassiveUseControlHost := true; end; -procedure TMainForm.Returpakkerfraboghandler1Click(Sender: TObject); +procedure TMainForm.menuNatxpressReturfraKunde1Click(Sender: TObject); begin Scanningtype := '3'; NulstilAutomatiskValg(); @@ -3724,7 +3430,7 @@ procedure TMainForm.InitIndleveringskode(); begin menuIndlevering.Checked := true; - AutomatiskTjekkodeStyring1.Enabled := false; + menuAutomatiskTjekkodeStyring.Enabled := false; btnNulstil.Visible := false; InitForm(FarveIndlevering, TitelIndlevering, UrlReturPakkeshop); @@ -3741,8 +3447,8 @@ - Smpakker1.Enabled := false; - Storepakker1.Enabled := false; + menuSmaaPakker.Enabled := false; + menuStorePakker.Enabled := false; radioStorPakke.Enabled := false; radioLillePakke.Enabled := false; ListBox1.Visible := true; @@ -3751,6 +3457,11 @@ BtnDownloadKontrolfil.Enabled := false; BtnOpdaterListen.Enabled := true; BtnEKLoverforsel.Enabled := false; + + chkForstorTilDirekte.Checked := false; + chkForstorTilDirekte.Enabled := false; + + InitLillePakke(); IndlesScanningLogFil(); if BladhusSted = 0 then @@ -3762,12 +3473,12 @@ end; -procedure TMainForm.Storepakker1Click(Sender: TObject); +procedure TMainForm.menuStorePakkerClick(Sender: TObject); begin InitStorPakke(); end; -procedure TMainForm.Smpakker1Click(Sender: TObject); +procedure TMainForm.menuSmaaPakkerClick(Sender: TObject); begin InitLillePakke(); end; @@ -3775,14 +3486,14 @@ procedure TMainForm.InitLillePakke(); begin radioLillePakke.Checked := true; - Smpakker1.Checked := true; + menuSmaaPakker.Checked := true; // Stregkode := ''; end; procedure TMainForm.InitStorPakke(); begin radioStorPakke.Checked := true; - Storepakker1.Checked := true; + menuStorePakker.Checked := true; // 20150310: start // Stregkode := ''; // 20150310: slut @@ -3826,7 +3537,7 @@ exit; end; - if Smpakker1.Checked then + if menuSmaaPakker.Checked then if ScannetOkLyd <> '' then begin PlaySound(PWideChar(ScannetOkLyd)); @@ -3835,7 +3546,7 @@ begin MessageBox(Handle, PWideChar('Lyd fil ikke fundet (ScannetOkLyd)'), 'Information', MB_OK); end; - if Storepakker1.Checked then + if menuStorePakker.Checked then if ScannetOkStorLyd <> '' then begin PlaySound(PWideChar(ScannetOkStorLyd)); @@ -3847,7 +3558,7 @@ end; -procedure TMainForm.Budlevering1Click(Sender: TObject); +procedure TMainForm.menuDaoDirekte1Click(Sender: TObject); begin Scanningtype := '4'; NulstilAutomatiskValg(); @@ -3876,12 +3587,12 @@ 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 @@ -4483,128 +4194,6 @@ end; -// ToDo: PrintPakkeshopLabel() -procedure TMainForm.PrintPakkeshopLabel( PakkeshopLabel : TPakkeshopLabel); -var - XForm, XFormOld: TXForm; //Bruges til rotate X-formation - Angle: integer; - gMode: integer; - Dirigering: string; - -begin - with Printer do - begin - BeginDoc(); - - - Canvas.Font.Size := 16; - Canvas.TextOut(15,10, 'Code: ' + PakkeshopLabel.Tjekkode + ' ' + PakkeshopLabel.Overskrift); - - - - Canvas.TextOut(25, 90, PakkeshopLabel.Navn ); - Canvas.TextOut(25, 135, PakkeshopLabel.Vejnavn ); - Canvas.TextOut(25, 180, PakkeshopLabel.Postnr ); - - - Canvas.Font.Size := 9; - Canvas.TextOut(110, 240, 'Pakkeshop:'); - Canvas.TextOut(110, 270, PakkeshopLabel.PakkeshopNavn); - Canvas.TextOut(110, 300, PakkeshopLabel.PakkeshopAddr); - Canvas.TextOut(110, 330, PakkeshopLabel.PakkeshopPostnr); - - Canvas.TextOut(350, 240, 'Afsender:'); - Canvas.TextOut(350, 270, PakkeshopLabel.AfsenderNavn); - Canvas.TextOut(350, 300, PakkeshopLabel.AfsenderAdresse); - Canvas.TextOut(350, 330, PakkeshopLabel.AfsenderPostnr); - - Dirigering := PakkeshopLabel.PakkeshopSted + ' | ' + PakkeshopLabel.PakkeshopTurid + ' | ' + PakkeshopLabel.PakkeshopNr; - if ( PakkeshopLabel.Koreliste <> '') then - begin - Dirigering := Dirigering + ' > ' + PakkeshopLabel.Koreliste; - end; - - - Canvas.Font.Size := 12; - Canvas.TextOut(15, 370, Dirigering); - - - - - - //Tegn adskillelses linier - Canvas.Pen.Width := 2; - //Øverste linie - Canvas.MoveTo(20,80); - Canvas.LineTo(600,80); - - // Midterste linie - Canvas.MoveTo( 20, 240); - Canvas.LineTo(600, 240); - - //Nederste linie - Canvas.MoveTo( 20, 370); - Canvas.LineTo(600, 370); - - - //Tegn skrå streger over afsender - Canvas.Pen.Width := 1; - Canvas.MoveTo(600, 250); - Canvas.LineTo(350, 360); - Canvas.MoveTo(600, 360); - Canvas.LineTo(350, 250); - - - - - // Resten af rutinen vedr genering og placering af Barcode - - BarCode.BarCodeType := bcCode128; - BarCode.Code128Subset := csCodeC; - BarCode.Code := PakkeshopLabel.Stregkode; - BarCode.Validate(True); - - //Start X-formation - //ShowMessage( Format('%d %d', [PageWidth, PageHeight]) ); - GetWorldTransform(Canvas.Handle, XFormOld); - - Angle := 270; - XForm.eM11 := Cos(DegToRad(Angle)); - XForm.eM12 := Sin(DegToRad(Angle)); - XForm.eM21 := -Sin(DegToRad(Angle)); - XForm.eM22 := Cos(DegToRad(Angle)); - XForm.eDx := 0; - XForm.eDy := 0; - - gMode := SetGraphicsMode(Canvas.Handle, GM_ADVANCED); - SetWorldTransform(Canvas.Handle, XForm); - - // PaintToCanvasSize arbejder i Inches - // Første pos argument bliver nu Y og skal være negativ for at rykke den ned - //Anden pos er X og skal være positiv for at justere ind fra venstre mod højre - - BarCode.PaintToCanvasSize(Printer.Canvas, -1.8, 3.3, 0.4); - - - SetWorldTransform(Canvas.Handle, XFormOld); - SetGraphicsMode(Canvas.Handle, gMode); - - EndDoc(); - end; - - -end; - -function GetPixelsPerInchX(): Integer; -begin - Result := GetDeviceCaps(Printer.Handle, LOGPIXELSX) -end; - -function GetPixelsPerInchY(): Integer; -begin - Result := GetDeviceCaps(Printer.Handle, LOGPIXELSY) -end; - procedure TMainForm.IndlesManglendeScanninger(); var @@ -4615,17 +4204,26 @@ I: Integer; stregkode, modtagernavn, modtageradresse, kommentar : string; pakketype, tjekkodestatus : String; - pakketypeix, antalLiniefelter, antalFelterFundet, linienr : Integer; - pakketyper : TStrings; + antalLiniefelter, antalFelterFundet, linienr : Integer; + //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'); @@ -4640,6 +4238,8 @@ StedKode := Sted; end; + Application.Processmessages; //Ugly Hack to improve User Experience when switching modes + if (Scanningtype = '7') then @@ -4677,6 +4277,9 @@ begin // Her skal vi ikke gøre noget - men vi skal forespørge igen WebSvar := IdHTTP1.Get(URLStr); + + + end; on e:exception do begin @@ -4699,26 +4302,31 @@ 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; @@ -4726,6 +4334,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 @@ -4734,6 +4345,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 @@ -4741,39 +4354,41 @@ 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] := TUtils.split(stregkode, ' ', 2); // Fjerner lige en evt. fremtidig dato fra feltet @@ -4785,6 +4400,8 @@ linienr := linienr + 1; end; end; + + if antalFelterFundet = antalLiniefelter then begin if (ScanningType = '1') then @@ -4800,13 +4417,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 @@ -5248,6 +4874,8 @@ KommentarST.Caption := strMessage; end; + Stregkode := ''; //Nulstil stregkode feltet efter at fejl er vist + end; function TMainForm.getProddato() : TDate; @@ -5307,25 +4935,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 @@ -5340,114 +4949,44 @@ end; +//Nedarvet fra IParentForm +procedure TMainForm.Msg( msg : string); +begin + ShowMessage(msg); +end; +//Nedarvet fra IParentForm +procedure TMainForm.LogMessage( msg : string); +begin + 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; +//Nedarvet fra IParentForm +procedure TMainForm.SetPrinterstatusText( txt: string; alert: boolean); begin -// tjektype = 'Opstart' skal vise alarmlinie, samt opdatere listbox1 -// 'Test' skal vise alarmlinie, samt opdatere listbox1 -// 'Timer' skal kun vise alarmlinie - - 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; +//Nedarvet fra IParentForm +function TMainForm.GetFormObject() : TForm; +begin + Result := self; +end; end.