X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/cc493b89840b48f40c2beaf626994724331aa196..c4c1bd525a660118ecf3b53811cd112a992fdc81:/src/models/user.ts diff --git a/src/models/user.ts b/src/models/user.ts index c2f21e58..87a2e8c1 100644 --- a/src/models/user.ts +++ b/src/models/user.ts @@ -2,7 +2,17 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { Resource, ResourceKind } from '~/models/resource'; +import { Resource, ResourceKind, RESOURCE_UUID_REGEX } from 'models/resource'; + +export type UserPrefs = { + profile?: { + organization?: string, + organization_email?: string, + lab?: string, + website_url?: string, + role?: string + } +}; export interface User { email: string; @@ -10,22 +20,47 @@ export interface User { lastName: string; uuid: string; ownerUuid: string; + username: string; + prefs: UserPrefs; + isAdmin: boolean; + isActive: boolean; } -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 const getUserDisplayName = (user: User, withEmail = false, withUuid = false) => { + const displayName = getUserFullname(user) || user.email || user.username || user.uuid; + let parts: string[] = [displayName]; + if (withEmail && user.email && displayName !== user.email) { + parts.push(`<${user.email}>`); + } + if (withUuid) { + parts.push(`(${user.uuid})`); + } + return parts.join(' '); +}; + +export const getUserDetailsString = (user: User) => { + let parts: string[] = []; + const userCluster = getUserClusterID(user); + user.username.length && parts.push(user.username); + user.email.length && parts.push(`<${user.email}>`); + userCluster && userCluster.length && parts.push(`(${userCluster})`); + return parts.join(' '); }; -export interface UserResource extends Resource { +export const getUserClusterID = (user: User): string | undefined => { + const match = RESOURCE_UUID_REGEX.exec(user.uuid); + const parts = match ? match[0].split('-') : []; + return parts.length === 3 ? parts[0] : undefined; +}; + +export interface UserResource extends Resource, User { kind: ResourceKind.USER; - email: string; - username: string; - firstName: string; - lastName: string; - identityUrl: string; - isAdmin: boolean; - prefs: string; defaultOwnerUuid: string; - isActive: boolean; writableBy: string[]; -} \ No newline at end of file +}