X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/43a384e98b698de75f66dcc5a0241a1246ddd447..2ec7fa451c0970c15c0b0d35fe70e473889f9ea3:/src/models/user.ts diff --git a/src/models/user.ts b/src/models/user.ts index afc4fc7226..2857bce6bf 100644 --- a/src/models/user.ts +++ b/src/models/user.ts @@ -2,7 +2,7 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { Resource, ResourceKind } from '~/models/resource'; +import { Resource, ResourceKind } from 'models/resource'; export type UserPrefs = { profile?: { @@ -24,22 +24,24 @@ export interface User { prefs: UserPrefs; isAdmin: boolean; isActive: boolean; - createdAt: string; } -export const getUserFullname = (user?: User) => { - return user ? `${user.firstName} ${user.lastName}` : ""; +export const getUserFullname = (user: User) => { + return user.firstName && user.lastName + ? `${user.firstName} ${user.lastName}` + : ""; }; -export interface UserResource extends Resource { +export const getUserDisplayName = (user: User, withEmail = false) => { + const displayName = getUserFullname(user) || user.email || user.username || user.uuid; + if (withEmail && user.email && displayName !== user.email) { + return `${displayName} <<${user.email}>>`; + } + return displayName; +}; + +export interface UserResource extends Resource, User { kind: ResourceKind.USER; - email: string; - username: string; - firstName: string; - lastName: string; - isAdmin: boolean; - prefs: UserPrefs; defaultOwnerUuid: string; - isActive: boolean; writableBy: string[]; }