-
Notifications
You must be signed in to change notification settings - Fork 5
luxTagId v16
Jede LUX-Component (z.B. lux-input, lux-checkbox,...) kann über eine LUX-Tag-Id (Attribut data-luxtagid
) verfügen.
Die LUX-Tag-Ids sollen es den automatischen Tests ermöglichen, im Test die LUX-Components zuverlässig zu identifizieren.
Über das Flag generateLuxTagIds
in der Konfiguration (siehe Config)
wird gesteuert, ob die LUX-Tag-Ids ausgegeben werden. Es kann sinnvoll sein, die LUX-Tag-Ids ausschließlich für
Testumgebungen zu aktivieren.
Damit nicht alle Entwickler zwanghaft allen LUX-Components eine LUX-Tag-Id setzen müssen, wurde die Direktive
LuxTagIdDirective
und LuxCustomTagIdDirective
eingeführt. Die LuxTagIdDirective
-Directive versucht, die LUX-Tag-Ids automatisch zu generieren. Um eine
Eindeutigkeit zu gewährleisten, sammelt die Direktive die LUX-Tag-Ids der Eltern ein und konkateniert diese z.B. mit
dem Label oder Controlbinding. Wenn die Direktive einmal nicht in der Lage ist, eine LUX-Tag-Id zu generieren,
wird eine Warnung in der Console ausgegeben. In diesen Fällen muss der Entwickler die LUX-Tag-Id manuell (z.B
über das Attribut luxTagId
oder mit der LuxCustomTagIdDirective
-Directive) angeben.
Auch die manuell gesetzten LUX-Tag-Ids (Attribut data-luxtagid
) werden nur angezeigt,
wenn das Flag generateLuxTagIds
in der Konfiguration (siehe Config)
aktiviert ist.
Html-Template:
<lux-card luxTitle="Person">
<lux-card-content>
<lux-input-ac luxLabel="Vorname">... </lux-input-ac>
</lux-card-content>
</lux-card>
HTML-Ausgabe:
<lux-card luxTitle="Person" data-luxtagid="lux-card#person">
<lux-card-content>
<lux-input-ac luxLabel="Vorname" data-luxtagid="lux-card#person.vorname"
>...
</lux-input-ac>
</lux-card-content>
</lux-card>
Auch die manuell gesetzten LUX-Tag-Ids (Attribut data-luxtagid
) werden nur angezeigt,
wenn das Flag generateLuxTagIds
in der Konfiguration (siehe Config)
aktiviert ist.
Html-Template
<lux-card luxTitle="Person">
<lux-card-content>
<lux-input-ac luxLabel="Vorname" luxTagId="firstname">... </lux-input-ac>
</lux-card-content>
</lux-card>
HTML-Ausgabe:
<lux-card luxTitle="Person" data-luxtagid="lux-card#person">
<lux-card-content>
<lux-input-ac luxLabel="Vorname" data-luxtagid="lux-card#person.firstname">
</lux-input-ac>
</lux-card-content>
</lux-card>
Html-Template:
<lux-card luxTitle="Person" luxCustomTagId="my-id" luxCustomTagIdSelector="mat-card">
...
</lux-card>
HTML-Ausgabe:
<lux-card luxTitle="Person">
...
<mat-card data-luxtagid="my-id">
...
</mat-card>
</lux-card>
Anmerkung: Das Attribut luxCustomTagIdSelector
muss nicht angegeben werden. Wenn das Attribut fehlt, wird das wird das Element verwendet, an dem es definiert wurde.
In der LUX-Componentskonfiguration wird das Flag generateLuxTagIds
direkt auf true
oder false
gesetzt.
Datei app.module.ts
:
const myConfiguration: LuxComponentsConfigParameters = {
generateLuxTagIds: true,
...
};
In der LUX-Componentskonfiguration wird das gleichnamige Flag generateLuxTagIds
aus der
Umgebung (Ordner src/environments
) referenziert. D.h. wenn beim Bauen das Flag --prod
(siehe Skripte in der Datei package.json
) verwendet wird, dann wird die Datei environment.prod.ts
gezogen,
andernfalls die Datei environment.ts
.
Datei app.module.ts
:
const myConfiguration: LuxComponentsConfigParameters = {
generateLuxTagIds: environment.generateLuxTagIds,
displayLuxConsoleLogs: true,
};
Datei environment.prod.ts
:
export const environment = {
production: true,
generateLuxTagIds: false,
};
Datei environment.ts
:
export const environment = {
production: true,
generateLuxTagIds: true,
};
-
Versionen