REFLEX Angebot/Auftrag Styles Code
Inhaltsverzeichnis
1 Allgemeines
Hier finden Sie den Programm-Code, der in den Standard-Style-Reports für Angebot/Auftrag verwendet wird.
Generell kann man die Syntax in FastReport für mehrere Programmier-Sprachen einstellen, wir verwenden die sog. "Pascal"-Syntax, weil die unserer Meinung nach für Ungeübte am Besten lesbar ist.
- Achtung! Wenn Sie Syntax im Report-Code nachträglich ändern, werden alle Zeilen des Codes gelöscht!!!
2 Code
Der Code ist die Blöcke Kopf, Positionen und Fuss eingeteilt. Technisch gesehen ist das nicht notwendig, die Prozeduren könnten stehen wo sie wollen. Es erhöht aber die Übersichtlichkeit.
Auf den ersten Blick wirkt das erschreckend viel. Allerdings wiederholen sich die Befehle immer wieder, weil es in der Hauptsache darum geht:
- Bereiche (Bänder) oder Felder ein- oder auszublenden
- Felder (Memos, Textfelder) mit Inhalten zu füllen.
Im Code befinden sich Kommentare. Kommentare kann man so festlegen:
- Zeilenweise
- Hier werden die Zeichen
//verwendet. Alles was danach steht, ist Kommentar!
- Blockweise
- Hier werden die Zeichen
(*am Anfang und*)am Ende verwendet. Alles was dazwischen steht, ist Kommentar!
2.1 Kopf
Diese Prozedur wird aufgerufen, bevor der oberste Bereich (also das oberste Band) des Reports gedruckt wird.
Hier werden generelle Einstellungen des Reports gemacht:
- Das Memo-Feld (Text-Feld) für die Anschrift wird gefüllt. Hier werden also die Anschriften-Felder nicht direkt auf dem Report platziert, sondern es gibt ein Memo
memoAnschrift, in das die Zeilen (Lines) angefügt werden. Das hat den Vorteil, dass z.B. das Ansprechpartner-Feld keine Leerzeile verursacht, wenn es gar keinen Ansprechpartner gibt.
- Abhängig von den Auftragskennzeichen werden Bänder ein- oder ausgeblendet.
// Kopf:
procedure MasterDataAnschriftOnBeforePrint(Sender: TfrxComponent);
begin
// Dies ist der erste Bereich des Reports, der gedruckt wird (außer dem PagerHeader des Basis-Reports).
// Hier kann man generelle Einstellungen des Reports vornehmen.
// Anschriftenfeld zusammenstellen:
memoAnschrift.Lines.Clear;
memoAnschrift.Lines.Add( <AuftragsKopf."NameFirma"> );
if <Ansprechpartner."Briefanrede"> > then
memoAnschrift.Lines.Add( <Ansprechpartner."Briefanrede"> );
memoAnschrift.Lines.Add( <AuftragsKopf."Str"> );
memoAnschrift.Lines.Add( <AuftragsKopf."PLZ"> + ' ' + <AuftragsKopf."Ort"> );
memoAnschrift.Lines.Add( UpperCase( <Adresse."Landname"> ) );
Rabatt-Bereich(e) ausschalten, wenn es gar keinen Rabatt gibt:
// Kennzeichen 3 = Rabatt im Fuss Ja/Nein oder kein Rabatt im Auftrag vorhanden:
if ( <AuftragsKopf."KENNZ3"> = 'Nein' )
or ( <AuftrStatistik."AnzahlRabattPos"> = 0 ) then
ChildMaterialRabatt.Visible := False;
Im Style D gibt es auf der ersten und auf der letzten Seite einen Rabatt-Bereich, deshalb lautet der Code hier:
(weil von dem if...then nun mehrere Zeilen betroffen sein sollen, muss man diese Zeilen nun mit begin beginnen mit end; beenden!)
// Kennzeichen 3 = Rabatt im Fuss Ja/Nein oder kein Rabatt im Auftrag vorhanden:
if ( <AuftragsKopf."KENNZ3"> = 'Nein' )
or ( <AuftrStatistik."AnzahlRabattPos"> = 0 ) then
begin
MasterDataKopfRabatt.Visible := False; // Rabatt-Bereich auf der 1. Seite
ChildMaterialRabatt.Visible := False; // Rabatt-Bereich auf der letzten Seite
end;
// Kennzeichen 5 = Kapitelpreise Ja/Nein
if <AuftragsKopf."KENNZ5"> = 'Nein' then
begin
memoKapitelBetrag.Visible := False;
GroupFooterKapitel.Visible := False;
end;
// Kapitel-Summe im Fuss:
if <AuftragsKopf."KENNZ7"> = 'Nein' then
GroupFooterKapitel.Visible := False;
// Bänder nur für ANGEBOT (bzw. ANFRAGE):
if <AuftragsKopf."StatusNr"> in [3,7,103,107] then // ANGEBOT, ANFRAGE, ANGEBOT im Archiv, ANFRAGE im Archiv
begin
// Angebots-Text im Fuß:
ChildAngebotAuftragserteilung.Visible := True;
// Wenn keine Arbeitszeit im Auftrag: Band unterdrücken:
MasterDataArbeitszeitAng.Visible := <AuftragsFuss."SummeArbzeit"> > 0;
end
else
begin
// Wenn kein Angebot, müssen diese Bereiche IMMER ausgeblendet werden:
ChildAngebotAuftragserteilung.Visible := False;
MasterDataArbeitszeitAng.Visible := False;
end;
end;
Diese Prozedur kommt aus dem Basis-Report, das zeigt das Wort _inherited ("geerbt"). Abhängig vom Auftragskennzeichen wird das Logo im Kopf ein- oder ausgeblendet.
procedure pictureBasisKopfLogoOnBeforePrint_inherited(Sender: TfrxComponent);
begin
if <AuftragsKopf."KENNZ1"> = 'Nein' then
pictureBasisKopfLogo.Visible := False;
end;
Da die Seitennummer im Kopf der ersten Seite steht, wird dieser Bereich auf der ersten Seite unterdrückt:
procedure HeaderSeitenNummerOnBeforePrint(Sender: TfrxComponent);
begin
// Seitennummer auf der ersten Seite unterdrücken:
if <Page>=1 then
HeaderSeitenNummer.Visible := False
else
HeaderSeitenNummer.Visible := True;
end;
Das Band mit den Feldern Raum/Stand wird ausgeblendet, wenn die Felder leer sind:
procedure MasterDataVARaumOnBeforePrint(Sender: TfrxComponent);
begin
// Wenn beide Felder leer sind: Ausblenden!
if ( <AuftragsKopf."VA-OrtKurzname"> = ) and ( <AuftragsKopf."VA-Raum"> = ) then
MasterDataVARaum.Visible := False;
end;
Das Band mit dem Standard-Kopftext (aus den Programmparametern ⇒ Formular-Texte) wird ausgeblendet, wenn das Feld leer ist:
procedure MasterDataStandardTextKopfOnBeforePrint(Sender: TfrxComponent);
begin
if <StandardTextKopf."StandardText"> = then
MasterDataStandardTextKopf.Visible:= False
else
MasterDataStandardTextKopf.Visible:= True;
end;
Das Band mit dem Kopftext (aus dem Auftragskopf) wird ausgeblendet, wenn das Feld leer ist:
procedure MasterDataKopftextOnBeforePrint(Sender: TfrxComponent);
begin
if <AuftragsKopf."Kopftext"> = then
MasterDataKopftext.Visible:= False
else
MasterDataKopftext.Visible:= True;
end;
Die Bänder für die Bereiche Miete bzw. Verkauf (aus dem Auftragskopf) werden wechselweise aus-/eingeblendet, abhängig von dem Bereichskennzeichen des Auftrags:
procedure MasterDataKopfMieteOnBeforePrint(Sender: TfrxComponent);
begin
if <AuftragsKopf."Bereich_1Verkauf_2Miete_3Mietverkauf"> <> 2 then
MasterDataKopfMiete.Visible := False
else
begin
MasterDataKopfMiete.Visible := True;
// Bei Miete Datumsfelder im Kopf nur sichtbar, wenn Text drin steht:
if <AuftragsKopf."AufbauText"> = then
begin
AuftragsKopfAufbauDatum.Visible := False;
AuftragsKopfAufbauText.Visible := False;
AuftragsKopfAufbauZeit.Visible := False;
end;
if <AuftragsKopf."AbbauText"> = then
begin
AuftragsKopfAbbauDatum.Visible := False;
AuftragsKopfAbbauText.Visible := False;
AuftragsKopfAbbauZeit.Visible := False;
end;
if <AuftragsKopf."ProbeText"> = then
begin
AuftragsKopfProbeDatum.Visible := False;
AuftragsKopfProbeText.Visible := False;
AuftragsKopfProbeZeit.Visible := False;
end;
end;
end;
procedure MasterDataKopfVerkaufOnBeforePrint(Sender: TfrxComponent);
begin
if <AuftragsKopf."Bereich_1Verkauf_2Miete_3Mietverkauf"> = 2 then
MasterDataKopfVerkauf.Visible := False
else
MasterDataKopfVerkauf.Visible := True;
end;
2.2 Positionen
Wenn der Positions-Textbaustein leer ist oder wenn das Auftragskennzeichen 8 auf "Nein" steht, wird der Textbereich der Auftragsposition ausgeblendet:
// Positionen:
procedure ChildDetailPositionenOnBeforePrint(Sender: TfrxComponent);
begin
if ( <Positionen."TextPosition"> = ) or ( <AuftragsKopf."KENNZ8"> = 'Nein' ) then
ChildDetailPositionen.Visible := False
else
ChildDetailPositionen.Visible := True;
end;
Der Seiten-Kopf (Page-Header) kommt normalerweise auf jeder Seite, also auch auf der ersten. Das ist hier nicht gewünscht, weil im Kopf schon alle relevanten Informationen stehen. Deshalb wird dieses Band auf der 1. Seite ausgeblendet:
procedure MemoTitelHeaderPositionenOnBeforePrint(Sender: TfrxComponent);
begin
// Auf der 1. Seite unterdrücken:
if <Page> = 1 then
HeaderSeitenNummer.Visible := False
else
HeaderSeitenNummer.Visible := True;
end;
Der manuelle Seitenwechsel:
procedure GroupHeaderKapitelOnBeforePrint(Sender: TfrxComponent);
begin
// Dieser Code wird ausgeführt, BEVOR das Positionen-Gruppenkopf-Band (die Kapitel-Überschrift) ausgegeben wird.
// Wenn das Kennzeichen "Seitenwechsel Vorher" gesetzt ist:
if <Positionen."Seitenwechsel_0Nein_1Vorher_2Nachher"> = 1 then
Engine.NewPage; // Neue Seite, Seitenkopf usw. drucken
end;
Zusatztext unterdrücken, wenn keiner angegeben ist:
procedure ChildGroupHeader1OnBeforePrint(Sender: TfrxComponent);
begin
// Unterdrücken, wenn kein Zusatztext vorhanden ist:
if <Positionen."TextPosition"> = then
ChildGroupHeader1.Visible := False
else
ChildGroupHeader1.Visible := True;
end;
Die relative große Prozedur wird vor dem Drucken einer Position aufgerufen. Hier werden z.B. Bereiche ausgeschaltet, abhängig von Auftragskennzeichen.
Damit die Abfragen nicht zu kompliziert werden, werden die Felder am Anfang erst mal alle auf sichtbar gestellt (Visible := True). Abhängig von Kennzeichen, Inhalten usw. werden dann einzelne Felder auf unsichtbar gestellt (Visible := False):
procedure DetailPositionenOnBeforePrint(Sender: TfrxComponent);
begin
// Dieser Code wird ausgeführt, BEVOR das Positionen-Detail-Band
// ausgegeben wird.
// Grundeinstellung: Erst mal alles einschalten, unten u.U. wieder aus:
MemHeaderEinzPreis.Visible := True;
memoHeaderRabattTitel.Visible := True;
memoHeaderGesPreis.Visible := True;
memoPositionenRabattProz.Visible := True;
memoPosEinzelPreis.Visible := True;
memoPosGesBetrag.Visible := True;
// Kennzeichen 4 = Einzelpreise sichtbar Ja/Nein:
if <AuftragsKopf."KENNZ4"> = 'Nein' then
begin
MemHeaderEinzPreis.Visible := False;
memoHeaderRabattTitel.Visible := False;
memoHeaderGesPreis.Visible := False;
end;
// Wenn der Gesamtpreis 0 ist, den Einzelpreis unterdrücken:
// (z.B. bei 100 % Rabatt)
if <Positionen."GesBetrag"> = 0 then
begin
memoPosEinzelPreis.Visible := False;
memoPositionenRabattProz.Visible := False;
end;
// Titel "Rabatt" in Überschrift unterdrücken, wenn keine
// Rabatt-Postion vorhanden ist.
// (Hinweis: Hinter diesem Feld liegt ein leeres Textfeld, das den Rahmen anzeigt, wenn dieses Feld unsichtbar ist!)
if <AuftrStatistik."AnzahlRabattPos"> = 0 then
memoHeaderRabattTitel.Visible := False;
// Kennzeichen 2 = Rabatt Ja/Nein
if <AuftragsKopf."KENNZ2"> = 'Nein' then
begin
memoHeaderRabattTitel.Visible := False;
memoPositionenRabattProz.Visible := False;
end;
// Kapitel-Position ausblenden:
// Kennzeichen "Nur Kapitel" = 'Ja': Positionen unterdrücken:
if ( <Positionen."PosNr"> = 0 )
or ( <AuftragsKopf."KENNZ6"> = 'Ja' ) then
begin
DetailPositionen.Visible := False;
end
else
DetailPositionen.Visible := True;
// Rabatt % unterdrücken, wenn's keinen Rabatt-Betrag gibt:
if <Positionen."RabattBetrag"> = 0 then
memoPositionenRabattProz.Visible := False;
// Einzelpreise sichtbar abhängig vom Kennzeichen 4:
if <AuftragsKopf."KENNZ4"> = 'Nein' then
begin
memoPosEinzelPreis.Visible := False;
memoPositionenRabattProz.Visible := False;
memoPosGesBetrag.Visible := False;
end;
// Bei Mietartikeln den Mietpreisfaktor anzeigen,
// bei Arbeitszeit die Stunden/Tage:
PositionenMietFaktor.Visible := False;
PositionenStundenSoll_BeiArbZeit.Visible := False;
if <Positionen."Artikelart_1MT_2VK_3DL_4AZ"> = 1 then
begin
PositionenMietFaktor.Visible := True;
end;
if <Positionen."Artikelart_1MT_2VK_3DL_4AZ"> = 4 then
begin
PositionenStundenSoll_BeiArbZeit.Visible := True;
end;
// Alternativ-Position kennzeichnen:
// Markierung mit " * " nur bei Alternativ-Position anzeigen
// (und nicht beim Kapitel, das auch das Alternativ-Kennzeichen hat!)
if (<Positionen."Alternativ_0_1"> = 1) and (<Positionen."PosNr"> > 0 ) then
begin
memoPosGesBetrag.Font.Color := clGray; // clWindowFrame;
MemoAlternativStern.Visible := True;
end
else
begin
MemoAlternativStern.Visible := False;
memoPosGesBetrag.Font.Color := clBlack; // clWindowText;
end;
// Wenn das Kennzeichen "Seitenwechsel Vorher" gesetzt ist:
if <Positionen."PosNr"> > 0 then // NICHT bei Kapitel-Position, das wird da schon gemacht!
if <Positionen."Seitenwechsel_0Nein_1Vorher_2Nachher"> = 1 then
Engine.NewPage; // Neue Seite, Seitenkopf usw. drucken
end;
procedure HeaderPositionenOnBeforePrint(Sender: TfrxComponent);
begin
// Auf der 1. Seite unterdrücken:
if <Page> = 1 then
begin
MemoAuftrNrTitelHeaderPositionen.Visible := False;
HeaderSeitenNummer.Visible := False;
HeaderPositionen.Visible := False;
end
else
begin
MemoAuftrNrTitelHeaderPositionen.Visible := True;
HeaderSeitenNummer.Visible := True;
HeaderPositionen.Visible := True;
end;
end;
Diese Prozedur verhindert, dass auf der letzten Seite die Überschrift (Pos., Menge, Bezeichnung usw.) gedruckt wird, obwohl gar keine Position mehr da ist, die letzte Position also schon gedruckt wurde.
Dazu wird die Eigenschaft EOF des Positionen-Datensatzes "DetailPositionen.DataSet" abgefragt. EOF = End of File, eigentlich Ende der Datei, hier ist aber das Ende der Datensätze gemeint.
EOF ergibt True (wahr), wenn das Ende der Datensätze erreicht ist, also keine Positionen mehr kommen.
EOF ergibt False (falsch), wenn noch Positionen kommen.
procedure ChildHeaderPositionenOnBeforePrint(Sender: TfrxComponent);
begin
// Überschriftszeile unterdrücken, wenn keine Positionen mehr kommen:
if DetailPositionen.DataSet.EOF then
ChildHeaderPositionen.Visible := False
else
ChildHeaderPositionen.Visible := True;
end;
2.3 Fuss
Bitte beachten Sie, dass manche Bereiche im Fuss schon ganz oben im Kopfbereich ein- oder ausgeblendet werden.
Diese Prozedur wird vor dem Drucken des Fuss-Bereichs aufgerufen. Hier werden z.B. Bereiche ausgeschaltet, abhängig von Auftragskennzeichen.
Im Fuss kann man den Gesamt-Rabatt auf das Material ausgeben. Da es ein solches Feld in der Datenbank nicht gibt, muss man den %-Wert berechnen und in einer Variablen FussRabattProzent ablegen.
// FUSS:
procedure FussPositionenOnBeforePrint(Sender: TfrxComponent);
begin
// Kennzeichen 2 = Rabatt Ja/Nein
if <AuftragsKopf."KENNZ2"> = 'Nein' then
begin
MemoFooterGespreis.Visible:= False;
end;
// Ohne Mwst.: Mwst-Felder unterdrücken:
if <AuftragsFuss."MwstBetrag"> = 0 then
begin
AuftragsFussMwstBetrag.Visible:= False;
AuftragsFussMwstSatzProzent.Visible:= False;
memoFussGesamtbetragText.Visible:= False;
AuftragsFussGesamtBetragBrutto.Visible:= False;
end;
// Rabatt % berechnen:
if ( <AuftragsFuss."KalkSummeGesamt"> > 0 ) then
Set( 'FussRabattProzent', 100 - ( (<AuftragsFuss."SummeMiete"> + <AuftragsFuss."SummeVerkauf"> ) / <AuftragsFuss."KalkSummeGesamt"> * 100 ) )
else
Set( 'FussRabattProzent',0);
end;
Im Fuss wird angezeigt, dass es im Angebot 'Alternativ-Positionen gibt. Dieser Hinweis soll natürlich nur erscheinen, wenn es im Angebot auch mind. eine Alternativ-Position gibt.
Das Druckprogramm stellt dazu in der Tabelle AuftrStatistik das Feld "AnzahlAlternativPos" zur Verfügung. Dieses Feld enthält die Anzahl der Positionen, die als "Alternativ" gekennzeichnet wurden.
procedure AuftrStatistikAnzahlAlternativPosOnBeforePrint(Sender: TfrxComponent);
begin
// Hinweis aus Alternativ-Positionen:
if <AuftrStatistik."AnzahlAlternativPos"> = 0 then
AuftrStatistikAnzahlAlternativPos.Visible := False
else
AuftrStatistikAnzahlAlternativPos.Visible := True;
end;
Am Ende steht immer dieses, bitte nicht entfernen:
begin end.