HTML - Vorlagen: Unterschied zwischen den Versionen

Aus OrgaMon Wiki
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
Zeile 154: Zeile 154:
=== Kommandos ===
=== Kommandos ===


          if (pos('local', Command) > 0) then
==== local ====
            if (pos(cPageBreakHerePossible, Command) > 0) then
==== pagebreak ====
            if (pos('save&delete', Command) > 0) then
==== save&delete ====
            if (pos('set', Command) > 0) then
==== set ====
            if (pos('load', Command) > 0) then
==== load FROMBLOCK [,ASBLOCK] ====
            if (pos('write', Command) > 0) then
 
            if (pos('save', Command) > 0) then
* Lädt den definierten BLOCK "FROMBLOCK" und fügt ihn an der Insert-Position bei "ASBLOCK" ein.
            if (pos('clear', Command) > 0) then
* Ist "ASBLOCK" nicht definiert, so wird der Block an der Insert-Position "FROMBLOCK" eingefügt.
            if (pos('delete', Command) > 0) then
* Ist "FROMBLOCK" undefiniert wird der Block Namens "ASBLOCK" benutzt, so kann man speziell benannte optionale Blocks definieren, der load gelingt aber dennoch sollte der spezielle Block nicht vorhanden sein
            if (pos('dereference', Command) > 0) then
 
==== write ====
==== save ====
==== clear ====
==== delete ====
==== dereference ====


=== Blocks ===
=== Blocks ===

Version vom 24. Januar 2018, 10:28 Uhr

Alle Dokumente, die der OrgaMon erzeugt sind .html Dateien. Diese werden nicht aus eigener Kraft, sondern grundsätzlich anhand einer .html Vorlage "belichtet". Dabei wird die Vorlage aus dem Verzeichnis ".\HTML Vorlagen" geladen und Platzhalter durch einen echten Inhalt ersetzt. Variable, mehrzeilige Ausgaben werden durch "BLOCKS" gelöst: In der Vorlage markiert man einen Abschnitt als Block der beim Laden entfernt und in einen Zwischenspeicher verlagert wird. "Braucht" die Ausbelichtung diesen Block wird er an einer "insert"-Marke eingefügt und ausbelichtet.

Variable

Je nach Context stellt der OrgaMon verschiedenen Variable zur Verfügung, die im Template verwendet werden können. Im Rahmen der Belichtung werden die Variable ersetzt, und es erscheinen anstelle des Variablennamen echte Inhalte. Es gibt vordefinierte Variablen Listen, die bei den meisten Dokumenten verfübgar sind.

Basis

~Datum~    heutiges Datum

Artikel

~Artikel~                TITEL
~No~                     NUMERO
~Komponist~              e_r_MusikerName(KOMPONIST_R)
~KomponistNachname~      e_r_MusikerNurNachName(KOMPONIST_R)
~Arrangeur~              e_r_MusikerName(ARRANGEUR_R)
~ArrangeurNachname~      e_r_MusikerNurNachName(ARRANGEUR_R)
~Verlag~                 e_r_Verlag(VERLAG_R)
~VerlagNo~               VERLAGNO
~Konto~                  b_r_Konto(SORTIMENT_R)
~Lager~                  e_r_LagerPlatzNameFromLAGER_R(LAGER_R)
~GEMA_WN~                GEMA_WN

Personen

~K#~                  NUMMER
~H#~                  HAUPT_NUMMER
~KontoAR~             KONTO_AR
~KontoER~             KONTO_ER
~Anrede~              ANREDE
~Ansprache~           ANSPRACHE
~Vorname~             VORNAME
~Nachname~            NACHNAME
~Name~                VORNAME ' ' NACHNAME
~Fax~                 PERSON
~Telefon~             e_r_telefon(RID)
~Handy~               HANDY
~eMail~               USER_ID
~Versicherungsnummer~ VERSICHERUNGSNUMMER
~Adressat1~           e_r_Adressat(RID)[0]
~Adressat2~           e_r_Adressat(RID)[1]
~Adressat3~           e_r_Adressat(RID)[2]
~Adressat4~           e_r_Adressat(RID)[3]
~Name1~               NAME1
~Name2~               NAME2
~Strasse~             STRASSE
~Ort~                 e_r_Ort(PRIV_ANSCHRIFT_R)

Mehrseitigkeit

Bei mehrseitigen Dokumenten muss man 4 Typen von Seiten vorbereiten:

  • PAGE_SINGLE: Die "erste" Seite für den Fall, dass alles auf einer Seite Platz hat
  • PAGE_FIRST: Die "erste" Seite für den Fall, dass ein mehrseitiges Dokument ensteht
  • PAGE_NEXT
  • PAGE_LAST

Einseitige Vorlage

<html>
<titel></titel>
Hallo Welt! 

Heute ist der ~DATUM~!
</html>

Blocks

<|-- BEGIN ARTIKEL EVEN -->

~ArtNo~ ~AusgabeArt~~ArtTxt~ ~Menge~  ~Wert~  ~Percent~  ~Anteil~  <|-- END ARTIKEL EVEN --> <|-- BEGIN ARTIKEL ODD --> ~ArtNo~ ~AusgabeArt~~ArtTxt~ ~Menge~  ~Wert~  ~Percent~  ~Anteil~  <|-- END ARTIKEL ODD --> <|-- INSERT ARTIKEL -->

Mehrseitige Vorlage

<html>
<HEAD>
<title></title>
<META HTTP-EQUIV="Pragma" content="no-cache">
<META HTTP-EQUIV="Cache-Control" content="no-cache, must-revalidate">
<META HTTP-EQUIV="Expires" content="0">
<STYLE TYPE="text/css">
<|--
P.breakhere {page-break-before: always}
-->
</STYLE>
</HEAD>
<body bgcolor="#ffffff" text="#000000" link="#cc0000" vlink="#999999" alink="#ffcc00">
<|-- BEGIN PAGE_SINGLE -->
<|-- SET MAXLINES 16 ArtTxt -->



... <|-- END PAGE_SINGLE -->
<|-- BEGIN PAGE_FIRST -->
<|-- SET MAXLINES 18 ArtTxt -->

<|-- END PAGE_FIRST -->

<|-- END PAGE_NEXT -->
<|-- BEGIN PAGE_LAST -->
<|-- SET MAXLINES 18 ArtTxt,MW -->
<|-- END PAGE_LAST -->
<|-- INSERT PAGE -->
</body>
</html>

MAXLINES

COSUMER - Begriff

  • Consumer sind ~Platzhalter~, die im Falle einer Ausbelichtung Platz benötigen
  • "!" sind Nicht-Consumer, die nicht auf eine Seite ausbelichtet werden dürfen

Implementierung

 // konstante Daten, die auf jeder Seite gleich sind
 DatenSammlerGlobal: TStringList; //
 // lokale Block-Daten, die wechseln
 DatenSammlerLokal: TStringList; //

Kommandos

local

pagebreak

save&delete

set

load FROMBLOCK [,ASBLOCK]

  • Lädt den definierten BLOCK "FROMBLOCK" und fügt ihn an der Insert-Position bei "ASBLOCK" ein.
  • Ist "ASBLOCK" nicht definiert, so wird der Block an der Insert-Position "FROMBLOCK" eingefügt.
  • Ist "FROMBLOCK" undefiniert wird der Block Namens "ASBLOCK" benutzt, so kann man speziell benannte optionale Blocks definieren, der load gelingt aber dennoch sollte der spezielle Block nicht vorhanden sein

write

save

clear

delete

dereference

Blocks

 cHTML_BeginBlock = '\<\!-- BEGIN ';
 cHTML_EndBlock = '