use "email" as default for emailDisplay attribute in et2-url-email (like before)

add new attribute value "preference" to use the user preference (like et2-email does)
This commit is contained in:
ralf 2024-01-22 17:11:53 +02:00
parent 866d10e030
commit b492ed5c15
2 changed files with 9 additions and 6 deletions

View File

@ -138,7 +138,7 @@ export async function formatEmailAddress(address : string, emailDisplayFormat? :
const split = splitEmail(address); const split = splitEmail(address);
let content = address; let content = address;
let contact; let contact;
if(!split.name && (contact = await checkContact(address))) if(emailDisplayFormat !== 'email' && !split.name && (contact = await checkContact(address)))
{ {
split.name = contact.n_fn; split.name = contact.n_fn;
} }

View File

@ -22,22 +22,25 @@ export class Et2UrlEmailReadonly extends Et2UrlReadonly
/** /**
* What to display for the selected email addresses * What to display for the selected email addresses
* *
* - email: "test@example.com" (default)
* - full: "Mr Test User <test@example.com> * - full: "Mr Test User <test@example.com>
* - name: "Mr Test User" * - name: "Mr Test User"
* - domain: "Mr Test User (example.com)" * - domain: "Mr Test User (example.com)"
* - email: "test@example.com" * - preference: use the users preference, like et2-email does
* *
* If name is unknown, we'll use the email instead. * If name is unknown, we'll use the email instead.
*/ */
@property({type: String}) @property({type: String})
emailDisplay : "full" | "email" | "name" | "domain"; emailDisplay : "email" | "full" | "name" | "domain" | "preference";
set value(val : string) set value(val : string)
{ {
this._value = val; this._value = val;
const split = splitEmail(this._value); const split = splitEmail(this._value);
super.statustext = split.name ? split.email : ""; super.statustext = split.name ? split.email : "";
formatEmailAddress(val, this.emailDisplay).then((value) => super.value = value); formatEmailAddress(val, !this.emailDisplay ? "email" :
(this.emailDisplay === 'preference' ? null : this.emailDisplay)).then(
(value) => super.value = value);
} }
get value() get value()
@ -52,8 +55,8 @@ export class Et2UrlEmailReadonly extends Et2UrlReadonly
attrs.onclick = () => attrs.onclick = () =>
{ {
let email; let email;
if (IsEmail.EMAIL_PREG.exec(email=this.value) || if (IsEmail.EMAIL_PREG.exec(email=this._value) ||
IsEmail.EMAIL_PREG.exec(email = '"' + this.value + '" <' + this.statustext + '>')) IsEmail.EMAIL_PREG.exec(email = '"' + this._value + '" <' + this.statustext + '>'))
{ {
Et2UrlEmail.action(email); Et2UrlEmail.action(email);
} }