1
0
mirror of https://github.com/immich-app/immich.git synced 2025-01-25 17:15:28 +02:00

fix: replace first and last name with single field (#4915)

This commit is contained in:
Brian Austin 2023-11-11 20:03:32 -05:00 committed by GitHub
parent 413ab2c538
commit 7fca0d8da5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
98 changed files with 567 additions and 1147 deletions

View File

@ -1341,24 +1341,18 @@ export interface CreateUserDto {
* @memberof CreateUserDto * @memberof CreateUserDto
*/ */
'externalPath'?: string | null; 'externalPath'?: string | null;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'firstName': string;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof CreateUserDto * @memberof CreateUserDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -2137,12 +2131,6 @@ export interface LoginResponseDto {
* @memberof LoginResponseDto * @memberof LoginResponseDto
*/ */
'accessToken': string; 'accessToken': string;
/**
*
* @type {string}
* @memberof LoginResponseDto
*/
'firstName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
@ -2154,7 +2142,7 @@ export interface LoginResponseDto {
* @type {string} * @type {string}
* @memberof LoginResponseDto * @memberof LoginResponseDto
*/ */
'lastName': string; 'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -2391,12 +2379,6 @@ export interface PartnerResponseDto {
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'externalPath': string | null; 'externalPath': string | null;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -2415,18 +2397,18 @@ export interface PartnerResponseDto {
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'isAdmin': boolean; 'isAdmin': boolean;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -3431,13 +3413,7 @@ export interface SignUpDto {
* @type {string} * @type {string}
* @memberof SignUpDto * @memberof SignUpDto
*/ */
'firstName': string; 'name': string;
/**
*
* @type {string}
* @memberof SignUpDto
*/
'lastName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4380,12 +4356,6 @@ export interface UpdateUserDto {
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'externalPath'?: string; 'externalPath'?: string;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'firstName'?: string;
/** /**
* *
* @type {string} * @type {string}
@ -4398,18 +4368,18 @@ export interface UpdateUserDto {
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'isAdmin'?: boolean; 'isAdmin'?: boolean;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'lastName'?: string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'name'?: string;
/** /**
* *
* @type {string} * @type {string}
@ -4447,12 +4417,6 @@ export interface UsageByUserDto {
* @memberof UsageByUserDto * @memberof UsageByUserDto
*/ */
'usage': number; 'usage': number;
/**
*
* @type {string}
* @memberof UsageByUserDto
*/
'userFirstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4464,7 +4428,7 @@ export interface UsageByUserDto {
* @type {string} * @type {string}
* @memberof UsageByUserDto * @memberof UsageByUserDto
*/ */
'userLastName': string; 'userName': string;
/** /**
* *
* @type {number} * @type {number}
@ -4484,12 +4448,6 @@ export interface UserDto {
* @memberof UserDto * @memberof UserDto
*/ */
'email': string; 'email': string;
/**
*
* @type {string}
* @memberof UserDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4501,7 +4459,7 @@ export interface UserDto {
* @type {string} * @type {string}
* @memberof UserDto * @memberof UserDto
*/ */
'lastName': string; 'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -4539,12 +4497,6 @@ export interface UserResponseDto {
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'externalPath': string | null; 'externalPath': string | null;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4557,18 +4509,18 @@ export interface UserResponseDto {
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'isAdmin': boolean; 'isAdmin': boolean;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}

View File

@ -51,8 +51,7 @@ immich-admin list-users
{ {
id: 'e65e6f88-2a30-4dbe-8dd9-1885f4889b53', id: 'e65e6f88-2a30-4dbe-8dd9-1885f4889b53',
email: 'immich@example.com.com', email: 'immich@example.com.com',
firstName: 'Immich', name: 'Immich Admin',
lastName: 'Admin',
storageLabel: 'admin', storageLabel: 'admin',
externalPath: null, externalPath: null,
profileImagePath: 'upload/profile/e65e6f88-2a30-4dbe-8dd9-1885f4889b53/e65e6f88-2a30-4dbe-8dd9-1885f4889b53.jpg', profileImagePath: 'upload/profile/e65e6f88-2a30-4dbe-8dd9-1885f4889b53/e65e6f88-2a30-4dbe-8dd9-1885f4889b53.jpg',

View File

@ -114,7 +114,7 @@
"cache_settings_thumbnail_size": "Thumbnail cache size ({} assets)", "cache_settings_thumbnail_size": "Thumbnail cache size ({} assets)",
"cache_settings_title": "Caching Settings", "cache_settings_title": "Caching Settings",
"change_password_form_confirm_password": "Confirm Password", "change_password_form_confirm_password": "Confirm Password",
"change_password_form_description": "Hi {firstName} {lastName},\n\nThis is either the first time you are signing into the system or a request has been made to change your password. Please enter the new password below.", "change_password_form_description": "Hi {name},\n\nThis is either the first time you are signing into the system or a request has been made to change your password. Please enter the new password below.",
"change_password_form_new_password": "New Password", "change_password_form_new_password": "New Password",
"change_password_form_password_mismatch": "Passwords do not match", "change_password_form_password_mismatch": "Passwords do not match",
"change_password_form_reenter_new_password": "Re-enter New Password", "change_password_form_reenter_new_password": "Re-enter New Password",

View File

@ -48,8 +48,7 @@ class Activity {
: ActivityType.like, : ActivityType.like,
user = User( user = User(
email: dto.user.email, email: dto.user.email,
firstName: dto.user.firstName, name: dto.user.name,
lastName: dto.user.lastName,
profileImagePath: dto.user.profileImagePath, profileImagePath: dto.user.profileImagePath,
id: dto.user.id, id: dto.user.id,
// Placeholder values // Placeholder values

View File

@ -61,7 +61,7 @@ class ActivitiesPage extends HookConsumerWidget {
mainAxisSize: leftAlign ? MainAxisSize.min : MainAxisSize.max, mainAxisSize: leftAlign ? MainAxisSize.min : MainAxisSize.max,
children: [ children: [
Text( Text(
"${activity.user.firstName} ${activity.user.lastName}", activity.user.name,
style: textStyle, style: textStyle,
overflow: TextOverflow.ellipsis, overflow: TextOverflow.ellipsis,
), ),

View File

@ -124,7 +124,7 @@ class AlbumOptionsPage extends HookConsumerWidget {
) )
: const SizedBox(), : const SizedBox(),
title: Text( title: Text(
album.owner.value?.firstName ?? "", album.owner.value?.name ?? "",
style: const TextStyle( style: const TextStyle(
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
), ),
@ -155,7 +155,7 @@ class AlbumOptionsPage extends HookConsumerWidget {
radius: 22, radius: 22,
), ),
title: Text( title: Text(
user.firstName, user.name,
style: const TextStyle( style: const TextStyle(
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
), ),

View File

@ -3,8 +3,7 @@ class AuthenticationState {
final String userId; final String userId;
final String userEmail; final String userEmail;
final bool isAuthenticated; final bool isAuthenticated;
final String firstName; final String name;
final String lastName;
final bool isAdmin; final bool isAdmin;
final bool shouldChangePassword; final bool shouldChangePassword;
final String profileImagePath; final String profileImagePath;
@ -13,8 +12,7 @@ class AuthenticationState {
required this.userId, required this.userId,
required this.userEmail, required this.userEmail,
required this.isAuthenticated, required this.isAuthenticated,
required this.firstName, required this.name,
required this.lastName,
required this.isAdmin, required this.isAdmin,
required this.shouldChangePassword, required this.shouldChangePassword,
required this.profileImagePath, required this.profileImagePath,
@ -25,8 +23,7 @@ class AuthenticationState {
String? userId, String? userId,
String? userEmail, String? userEmail,
bool? isAuthenticated, bool? isAuthenticated,
String? firstName, String? name,
String? lastName,
bool? isAdmin, bool? isAdmin,
bool? shouldChangePassword, bool? shouldChangePassword,
String? profileImagePath, String? profileImagePath,
@ -36,8 +33,7 @@ class AuthenticationState {
userId: userId ?? this.userId, userId: userId ?? this.userId,
userEmail: userEmail ?? this.userEmail, userEmail: userEmail ?? this.userEmail,
isAuthenticated: isAuthenticated ?? this.isAuthenticated, isAuthenticated: isAuthenticated ?? this.isAuthenticated,
firstName: firstName ?? this.firstName, name: name ?? this.name,
lastName: lastName ?? this.lastName,
isAdmin: isAdmin ?? this.isAdmin, isAdmin: isAdmin ?? this.isAdmin,
shouldChangePassword: shouldChangePassword ?? this.shouldChangePassword, shouldChangePassword: shouldChangePassword ?? this.shouldChangePassword,
profileImagePath: profileImagePath ?? this.profileImagePath, profileImagePath: profileImagePath ?? this.profileImagePath,
@ -46,7 +42,7 @@ class AuthenticationState {
@override @override
String toString() { String toString() {
return 'AuthenticationState(deviceId: $deviceId, userId: $userId, userEmail: $userEmail, isAuthenticated: $isAuthenticated, firstName: $firstName, lastName: $lastName, isAdmin: $isAdmin, shouldChangePassword: $shouldChangePassword, profileImagePath: $profileImagePath)'; return 'AuthenticationState(deviceId: $deviceId, userId: $userId, userEmail: $userEmail, isAuthenticated: $isAuthenticated, name: $name, isAdmin: $isAdmin, shouldChangePassword: $shouldChangePassword, profileImagePath: $profileImagePath)';
} }
@override @override
@ -58,8 +54,7 @@ class AuthenticationState {
other.userId == userId && other.userId == userId &&
other.userEmail == userEmail && other.userEmail == userEmail &&
other.isAuthenticated == isAuthenticated && other.isAuthenticated == isAuthenticated &&
other.firstName == firstName && other.name == name &&
other.lastName == lastName &&
other.isAdmin == isAdmin && other.isAdmin == isAdmin &&
other.shouldChangePassword == shouldChangePassword && other.shouldChangePassword == shouldChangePassword &&
other.profileImagePath == profileImagePath; other.profileImagePath == profileImagePath;
@ -71,8 +66,7 @@ class AuthenticationState {
userId.hashCode ^ userId.hashCode ^
userEmail.hashCode ^ userEmail.hashCode ^
isAuthenticated.hashCode ^ isAuthenticated.hashCode ^
firstName.hashCode ^ name.hashCode ^
lastName.hashCode ^
isAdmin.hashCode ^ isAdmin.hashCode ^
shouldChangePassword.hashCode ^ shouldChangePassword.hashCode ^
profileImagePath.hashCode; profileImagePath.hashCode;

View File

@ -26,8 +26,7 @@ class AuthenticationNotifier extends StateNotifier<AuthenticationState> {
deviceId: "", deviceId: "",
userId: "", userId: "",
userEmail: "", userEmail: "",
firstName: '', name: '',
lastName: '',
profileImagePath: '', profileImagePath: '',
isAdmin: false, isAdmin: false,
shouldChangePassword: false, shouldChangePassword: false,
@ -117,8 +116,7 @@ class AuthenticationNotifier extends StateNotifier<AuthenticationState> {
deviceId: "", deviceId: "",
userId: "", userId: "",
userEmail: "", userEmail: "",
firstName: '', name: '',
lastName: '',
profileImagePath: '', profileImagePath: '',
isAdmin: false, isAdmin: false,
shouldChangePassword: false, shouldChangePassword: false,
@ -208,8 +206,7 @@ class AuthenticationNotifier extends StateNotifier<AuthenticationState> {
isAuthenticated: true, isAuthenticated: true,
userId: user.id, userId: user.id,
userEmail: user.email, userEmail: user.email,
firstName: user.firstName, name: user.name,
lastName: user.lastName,
profileImagePath: user.profileImagePath, profileImagePath: user.profileImagePath,
isAdmin: user.isAdmin, isAdmin: user.isAdmin,
shouldChangePassword: shouldChangePassword, shouldChangePassword: shouldChangePassword,

View File

@ -46,8 +46,7 @@ class ChangePasswordForm extends HookConsumerWidget {
child: Text( child: Text(
'change_password_form_description'.tr( 'change_password_form_description'.tr(
namedArgs: { namedArgs: {
'firstName': authState.firstName, 'name': authState.name,
'lastName': authState.lastName,
}, },
), ),
style: TextStyle( style: TextStyle(

View File

@ -24,7 +24,7 @@ class PartnerList extends HookConsumerWidget {
contentPadding: const EdgeInsets.symmetric(horizontal: 12.0), contentPadding: const EdgeInsets.symmetric(horizontal: 12.0),
leading: userAvatar(context, p, radius: 30), leading: userAvatar(context, p, radius: 30),
title: Text( title: Text(
"${p.firstName} ${p.lastName}'s photos", "${p.name}'s photos",
style: TextStyle( style: TextStyle(
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
fontSize: 14, fontSize: 14,

View File

@ -25,7 +25,7 @@ class PartnerDetailPage extends HookConsumerWidget {
return Scaffold( return Scaffold(
appBar: AppBar( appBar: AppBar(
title: Text("${partner.firstName} ${partner.lastName}"), title: Text(partner.name),
elevation: 0, elevation: 0,
centerTitle: false, centerTitle: false,
), ),
@ -34,7 +34,7 @@ class PartnerDetailPage extends HookConsumerWidget {
? Padding( ? Padding(
padding: const EdgeInsets.all(16), padding: const EdgeInsets.all(16),
child: Text( child: Text(
"It seems ${partner.firstName} does not have any photos...\n" "It seems ${partner.name} does not have any photos...\n"
"Or your server version does not match the app version."), "Or your server version does not match the app version."),
) )
: ImmichAssetGrid( : ImmichAssetGrid(

View File

@ -41,7 +41,7 @@ class PartnerPage extends HookConsumerWidget {
padding: const EdgeInsets.only(right: 8), padding: const EdgeInsets.only(right: 8),
child: userAvatar(context, u), child: userAvatar(context, u),
), ),
Text("${u.firstName} ${u.lastName}"), Text(u.name),
], ],
), ),
), ),
@ -71,7 +71,7 @@ class PartnerPage extends HookConsumerWidget {
return ConfirmDialog( return ConfirmDialog(
title: "partner_page_stop_sharing_title", title: "partner_page_stop_sharing_title",
content: content:
"partner_page_stop_sharing_content".tr(args: [u.firstName]), "partner_page_stop_sharing_content".tr(args: [u.name]),
onOk: () => ref.read(partnerServiceProvider).removePartner(u), onOk: () => ref.read(partnerServiceProvider).removePartner(u),
); );
}, },

View File

@ -68,11 +68,8 @@ class Album {
} }
final name = <String>[]; final name = <String>[];
if (owner.value?.firstName != null) { if (owner.value?.name != null) {
name.add(owner.value!.firstName); name.add(owner.value!.name);
}
if (owner.value?.lastName != null) {
name.add(owner.value!.lastName);
} }
return name.join(' '); return name.join(' ');

View File

@ -11,8 +11,7 @@ class User {
required this.id, required this.id,
required this.updatedAt, required this.updatedAt,
required this.email, required this.email,
required this.firstName, required this.name,
required this.lastName,
required this.isAdmin, required this.isAdmin,
this.isPartnerSharedBy = false, this.isPartnerSharedBy = false,
this.isPartnerSharedWith = false, this.isPartnerSharedWith = false,
@ -27,8 +26,7 @@ class User {
: id = dto.id, : id = dto.id,
updatedAt = dto.updatedAt, updatedAt = dto.updatedAt,
email = dto.email, email = dto.email,
firstName = dto.firstName, name = dto.name,
lastName = dto.lastName,
isPartnerSharedBy = false, isPartnerSharedBy = false,
isPartnerSharedWith = false, isPartnerSharedWith = false,
profileImagePath = dto.profileImagePath, profileImagePath = dto.profileImagePath,
@ -39,8 +37,7 @@ class User {
: id = dto.id, : id = dto.id,
updatedAt = dto.updatedAt, updatedAt = dto.updatedAt,
email = dto.email, email = dto.email,
firstName = dto.firstName, name = dto.name,
lastName = dto.lastName,
isPartnerSharedBy = false, isPartnerSharedBy = false,
isPartnerSharedWith = false, isPartnerSharedWith = false,
profileImagePath = dto.profileImagePath, profileImagePath = dto.profileImagePath,
@ -52,8 +49,7 @@ class User {
String id; String id;
DateTime updatedAt; DateTime updatedAt;
String email; String email;
String firstName; String name;
String lastName;
bool isPartnerSharedBy; bool isPartnerSharedBy;
bool isPartnerSharedWith; bool isPartnerSharedWith;
bool isAdmin; bool isAdmin;
@ -72,8 +68,7 @@ class User {
return id == other.id && return id == other.id &&
updatedAt.isAtSameMomentAs(other.updatedAt) && updatedAt.isAtSameMomentAs(other.updatedAt) &&
email == other.email && email == other.email &&
firstName == other.firstName && name == other.name &&
lastName == other.lastName &&
isPartnerSharedBy == other.isPartnerSharedBy && isPartnerSharedBy == other.isPartnerSharedBy &&
isPartnerSharedWith == other.isPartnerSharedWith && isPartnerSharedWith == other.isPartnerSharedWith &&
profileImagePath == other.profileImagePath && profileImagePath == other.profileImagePath &&
@ -88,8 +83,7 @@ class User {
id.hashCode ^ id.hashCode ^
updatedAt.hashCode ^ updatedAt.hashCode ^
email.hashCode ^ email.hashCode ^
firstName.hashCode ^ name.hashCode ^
lastName.hashCode ^
isPartnerSharedBy.hashCode ^ isPartnerSharedBy.hashCode ^
isPartnerSharedWith.hashCode ^ isPartnerSharedWith.hashCode ^
profileImagePath.hashCode ^ profileImagePath.hashCode ^

View File

@ -22,53 +22,48 @@ const UserSchema = CollectionSchema(
name: r'email', name: r'email',
type: IsarType.string, type: IsarType.string,
), ),
r'firstName': PropertySchema(
id: 1,
name: r'firstName',
type: IsarType.string,
),
r'id': PropertySchema( r'id': PropertySchema(
id: 2, id: 1,
name: r'id', name: r'id',
type: IsarType.string, type: IsarType.string,
), ),
r'inTimeline': PropertySchema( r'inTimeline': PropertySchema(
id: 3, id: 2,
name: r'inTimeline', name: r'inTimeline',
type: IsarType.bool, type: IsarType.bool,
), ),
r'isAdmin': PropertySchema( r'isAdmin': PropertySchema(
id: 4, id: 3,
name: r'isAdmin', name: r'isAdmin',
type: IsarType.bool, type: IsarType.bool,
), ),
r'isPartnerSharedBy': PropertySchema( r'isPartnerSharedBy': PropertySchema(
id: 5, id: 4,
name: r'isPartnerSharedBy', name: r'isPartnerSharedBy',
type: IsarType.bool, type: IsarType.bool,
), ),
r'isPartnerSharedWith': PropertySchema( r'isPartnerSharedWith': PropertySchema(
id: 6, id: 5,
name: r'isPartnerSharedWith', name: r'isPartnerSharedWith',
type: IsarType.bool, type: IsarType.bool,
), ),
r'lastName': PropertySchema(
id: 7,
name: r'lastName',
type: IsarType.string,
),
r'memoryEnabled': PropertySchema( r'memoryEnabled': PropertySchema(
id: 8, id: 6,
name: r'memoryEnabled', name: r'memoryEnabled',
type: IsarType.bool, type: IsarType.bool,
), ),
r'name': PropertySchema(
id: 7,
name: r'name',
type: IsarType.string,
),
r'profileImagePath': PropertySchema( r'profileImagePath': PropertySchema(
id: 9, id: 8,
name: r'profileImagePath', name: r'profileImagePath',
type: IsarType.string, type: IsarType.string,
), ),
r'updatedAt': PropertySchema( r'updatedAt': PropertySchema(
id: 10, id: 9,
name: r'updatedAt', name: r'updatedAt',
type: IsarType.dateTime, type: IsarType.dateTime,
) )
@ -123,9 +118,8 @@ int _userEstimateSize(
) { ) {
var bytesCount = offsets.last; var bytesCount = offsets.last;
bytesCount += 3 + object.email.length * 3; bytesCount += 3 + object.email.length * 3;
bytesCount += 3 + object.firstName.length * 3;
bytesCount += 3 + object.id.length * 3; bytesCount += 3 + object.id.length * 3;
bytesCount += 3 + object.lastName.length * 3; bytesCount += 3 + object.name.length * 3;
bytesCount += 3 + object.profileImagePath.length * 3; bytesCount += 3 + object.profileImagePath.length * 3;
return bytesCount; return bytesCount;
} }
@ -137,16 +131,15 @@ void _userSerialize(
Map<Type, List<int>> allOffsets, Map<Type, List<int>> allOffsets,
) { ) {
writer.writeString(offsets[0], object.email); writer.writeString(offsets[0], object.email);
writer.writeString(offsets[1], object.firstName); writer.writeString(offsets[1], object.id);
writer.writeString(offsets[2], object.id); writer.writeBool(offsets[2], object.inTimeline);
writer.writeBool(offsets[3], object.inTimeline); writer.writeBool(offsets[3], object.isAdmin);
writer.writeBool(offsets[4], object.isAdmin); writer.writeBool(offsets[4], object.isPartnerSharedBy);
writer.writeBool(offsets[5], object.isPartnerSharedBy); writer.writeBool(offsets[5], object.isPartnerSharedWith);
writer.writeBool(offsets[6], object.isPartnerSharedWith); writer.writeBool(offsets[6], object.memoryEnabled);
writer.writeString(offsets[7], object.lastName); writer.writeString(offsets[7], object.name);
writer.writeBool(offsets[8], object.memoryEnabled); writer.writeString(offsets[8], object.profileImagePath);
writer.writeString(offsets[9], object.profileImagePath); writer.writeDateTime(offsets[9], object.updatedAt);
writer.writeDateTime(offsets[10], object.updatedAt);
} }
User _userDeserialize( User _userDeserialize(
@ -157,16 +150,15 @@ User _userDeserialize(
) { ) {
final object = User( final object = User(
email: reader.readString(offsets[0]), email: reader.readString(offsets[0]),
firstName: reader.readString(offsets[1]), id: reader.readString(offsets[1]),
id: reader.readString(offsets[2]), inTimeline: reader.readBoolOrNull(offsets[2]),
inTimeline: reader.readBoolOrNull(offsets[3]), isAdmin: reader.readBool(offsets[3]),
isAdmin: reader.readBool(offsets[4]), isPartnerSharedBy: reader.readBoolOrNull(offsets[4]) ?? false,
isPartnerSharedBy: reader.readBoolOrNull(offsets[5]) ?? false, isPartnerSharedWith: reader.readBoolOrNull(offsets[5]) ?? false,
isPartnerSharedWith: reader.readBoolOrNull(offsets[6]) ?? false, memoryEnabled: reader.readBoolOrNull(offsets[6]),
lastName: reader.readString(offsets[7]), name: reader.readString(offsets[7]),
memoryEnabled: reader.readBoolOrNull(offsets[8]), profileImagePath: reader.readStringOrNull(offsets[8]) ?? '',
profileImagePath: reader.readStringOrNull(offsets[9]) ?? '', updatedAt: reader.readDateTime(offsets[9]),
updatedAt: reader.readDateTime(offsets[10]),
); );
return object; return object;
} }
@ -183,22 +175,20 @@ P _userDeserializeProp<P>(
case 1: case 1:
return (reader.readString(offset)) as P; return (reader.readString(offset)) as P;
case 2: case 2:
return (reader.readString(offset)) as P;
case 3:
return (reader.readBoolOrNull(offset)) as P; return (reader.readBoolOrNull(offset)) as P;
case 4: case 3:
return (reader.readBool(offset)) as P; return (reader.readBool(offset)) as P;
case 4:
return (reader.readBoolOrNull(offset) ?? false) as P;
case 5: case 5:
return (reader.readBoolOrNull(offset) ?? false) as P; return (reader.readBoolOrNull(offset) ?? false) as P;
case 6: case 6:
return (reader.readBoolOrNull(offset) ?? false) as P; return (reader.readBoolOrNull(offset)) as P;
case 7: case 7:
return (reader.readString(offset)) as P; return (reader.readString(offset)) as P;
case 8: case 8:
return (reader.readBoolOrNull(offset)) as P;
case 9:
return (reader.readStringOrNull(offset) ?? '') as P; return (reader.readStringOrNull(offset) ?? '') as P;
case 10: case 9:
return (reader.readDateTime(offset)) as P; return (reader.readDateTime(offset)) as P;
default: default:
throw IsarError('Unknown property with id $propertyId'); throw IsarError('Unknown property with id $propertyId');
@ -520,136 +510,6 @@ extension UserQueryFilter on QueryBuilder<User, User, QFilterCondition> {
}); });
} }
QueryBuilder<User, User, QAfterFilterCondition> firstNameEqualTo(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameGreaterThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
include: include,
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameLessThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.lessThan(
include: include,
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameBetween(
String lower,
String upper, {
bool includeLower = true,
bool includeUpper = true,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.between(
property: r'firstName',
lower: lower,
includeLower: includeLower,
upper: upper,
includeUpper: includeUpper,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameStartsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.startsWith(
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameEndsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.endsWith(
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameContains(
String value,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.contains(
property: r'firstName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameMatches(
String pattern,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.matches(
property: r'firstName',
wildcard: pattern,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameIsEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'firstName',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> firstNameIsNotEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
property: r'firstName',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> idEqualTo( QueryBuilder<User, User, QAfterFilterCondition> idEqualTo(
String value, { String value, {
bool caseSensitive = true, bool caseSensitive = true,
@ -885,135 +745,6 @@ extension UserQueryFilter on QueryBuilder<User, User, QFilterCondition> {
}); });
} }
QueryBuilder<User, User, QAfterFilterCondition> lastNameEqualTo(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameGreaterThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
include: include,
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameLessThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.lessThan(
include: include,
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameBetween(
String lower,
String upper, {
bool includeLower = true,
bool includeUpper = true,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.between(
property: r'lastName',
lower: lower,
includeLower: includeLower,
upper: upper,
includeUpper: includeUpper,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameStartsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.startsWith(
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameEndsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.endsWith(
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameContains(String value,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.contains(
property: r'lastName',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameMatches(
String pattern,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.matches(
property: r'lastName',
wildcard: pattern,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameIsEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'lastName',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> lastNameIsNotEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
property: r'lastName',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> memoryEnabledIsNull() { QueryBuilder<User, User, QAfterFilterCondition> memoryEnabledIsNull() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(const FilterCondition.isNull( return query.addFilterCondition(const FilterCondition.isNull(
@ -1040,6 +771,134 @@ extension UserQueryFilter on QueryBuilder<User, User, QFilterCondition> {
}); });
} }
QueryBuilder<User, User, QAfterFilterCondition> nameEqualTo(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameGreaterThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
include: include,
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameLessThan(
String value, {
bool include = false,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.lessThan(
include: include,
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameBetween(
String lower,
String upper, {
bool includeLower = true,
bool includeUpper = true,
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.between(
property: r'name',
lower: lower,
includeLower: includeLower,
upper: upper,
includeUpper: includeUpper,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameStartsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.startsWith(
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameEndsWith(
String value, {
bool caseSensitive = true,
}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.endsWith(
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameContains(String value,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.contains(
property: r'name',
value: value,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameMatches(String pattern,
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.matches(
property: r'name',
wildcard: pattern,
caseSensitive: caseSensitive,
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameIsEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.equalTo(
property: r'name',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> nameIsNotEmpty() {
return QueryBuilder.apply(this, (query) {
return query.addFilterCondition(FilterCondition.greaterThan(
property: r'name',
value: '',
));
});
}
QueryBuilder<User, User, QAfterFilterCondition> profileImagePathEqualTo( QueryBuilder<User, User, QAfterFilterCondition> profileImagePathEqualTo(
String value, { String value, {
bool caseSensitive = true, bool caseSensitive = true,
@ -1352,18 +1211,6 @@ extension UserQuerySortBy on QueryBuilder<User, User, QSortBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> sortByFirstName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'firstName', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortByFirstNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'firstName', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortById() { QueryBuilder<User, User, QAfterSortBy> sortById() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'id', Sort.asc); return query.addSortBy(r'id', Sort.asc);
@ -1424,18 +1271,6 @@ extension UserQuerySortBy on QueryBuilder<User, User, QSortBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> sortByLastName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'lastName', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortByLastNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'lastName', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortByMemoryEnabled() { QueryBuilder<User, User, QAfterSortBy> sortByMemoryEnabled() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'memoryEnabled', Sort.asc); return query.addSortBy(r'memoryEnabled', Sort.asc);
@ -1448,6 +1283,18 @@ extension UserQuerySortBy on QueryBuilder<User, User, QSortBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> sortByName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'name', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortByNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'name', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> sortByProfileImagePath() { QueryBuilder<User, User, QAfterSortBy> sortByProfileImagePath() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'profileImagePath', Sort.asc); return query.addSortBy(r'profileImagePath', Sort.asc);
@ -1486,18 +1333,6 @@ extension UserQuerySortThenBy on QueryBuilder<User, User, QSortThenBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> thenByFirstName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'firstName', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenByFirstNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'firstName', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenById() { QueryBuilder<User, User, QAfterSortBy> thenById() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'id', Sort.asc); return query.addSortBy(r'id', Sort.asc);
@ -1570,18 +1405,6 @@ extension UserQuerySortThenBy on QueryBuilder<User, User, QSortThenBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> thenByLastName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'lastName', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenByLastNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'lastName', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenByMemoryEnabled() { QueryBuilder<User, User, QAfterSortBy> thenByMemoryEnabled() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'memoryEnabled', Sort.asc); return query.addSortBy(r'memoryEnabled', Sort.asc);
@ -1594,6 +1417,18 @@ extension UserQuerySortThenBy on QueryBuilder<User, User, QSortThenBy> {
}); });
} }
QueryBuilder<User, User, QAfterSortBy> thenByName() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'name', Sort.asc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenByNameDesc() {
return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'name', Sort.desc);
});
}
QueryBuilder<User, User, QAfterSortBy> thenByProfileImagePath() { QueryBuilder<User, User, QAfterSortBy> thenByProfileImagePath() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addSortBy(r'profileImagePath', Sort.asc); return query.addSortBy(r'profileImagePath', Sort.asc);
@ -1627,13 +1462,6 @@ extension UserQueryWhereDistinct on QueryBuilder<User, User, QDistinct> {
}); });
} }
QueryBuilder<User, User, QDistinct> distinctByFirstName(
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addDistinctBy(r'firstName', caseSensitive: caseSensitive);
});
}
QueryBuilder<User, User, QDistinct> distinctById( QueryBuilder<User, User, QDistinct> distinctById(
{bool caseSensitive = true}) { {bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
@ -1665,19 +1493,19 @@ extension UserQueryWhereDistinct on QueryBuilder<User, User, QDistinct> {
}); });
} }
QueryBuilder<User, User, QDistinct> distinctByLastName(
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addDistinctBy(r'lastName', caseSensitive: caseSensitive);
});
}
QueryBuilder<User, User, QDistinct> distinctByMemoryEnabled() { QueryBuilder<User, User, QDistinct> distinctByMemoryEnabled() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addDistinctBy(r'memoryEnabled'); return query.addDistinctBy(r'memoryEnabled');
}); });
} }
QueryBuilder<User, User, QDistinct> distinctByName(
{bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) {
return query.addDistinctBy(r'name', caseSensitive: caseSensitive);
});
}
QueryBuilder<User, User, QDistinct> distinctByProfileImagePath( QueryBuilder<User, User, QDistinct> distinctByProfileImagePath(
{bool caseSensitive = true}) { {bool caseSensitive = true}) {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
@ -1706,12 +1534,6 @@ extension UserQueryProperty on QueryBuilder<User, User, QQueryProperty> {
}); });
} }
QueryBuilder<User, String, QQueryOperations> firstNameProperty() {
return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'firstName');
});
}
QueryBuilder<User, String, QQueryOperations> idProperty() { QueryBuilder<User, String, QQueryOperations> idProperty() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'id'); return query.addPropertyName(r'id');
@ -1742,18 +1564,18 @@ extension UserQueryProperty on QueryBuilder<User, User, QQueryProperty> {
}); });
} }
QueryBuilder<User, String, QQueryOperations> lastNameProperty() {
return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'lastName');
});
}
QueryBuilder<User, bool?, QQueryOperations> memoryEnabledProperty() { QueryBuilder<User, bool?, QQueryOperations> memoryEnabledProperty() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'memoryEnabled'); return query.addPropertyName(r'memoryEnabled');
}); });
} }
QueryBuilder<User, String, QQueryOperations> nameProperty() {
return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'name');
});
}
QueryBuilder<User, String, QQueryOperations> profileImagePathProperty() { QueryBuilder<User, String, QQueryOperations> profileImagePathProperty() {
return QueryBuilder.apply(this, (query) { return QueryBuilder.apply(this, (query) {
return query.addPropertyName(r'profileImagePath'); return query.addPropertyName(r'profileImagePath');

View File

@ -132,7 +132,7 @@ class AppBarProfileInfoBox extends HookConsumerWidget {
), ),
), ),
title: Text( title: Text(
"${authState.firstName} ${authState.lastName}", authState.name,
style: TextStyle( style: TextStyle(
color: context.primaryColor, color: context.primaryColor,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,

View File

@ -7,8 +7,7 @@ import 'package:immich_mobile/shared/models/user.dart';
Widget userAvatar(BuildContext context, User u, {double? radius}) { Widget userAvatar(BuildContext context, User u, {double? radius}) {
final url = final url =
"${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${u.id}"; "${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${u.id}";
final firstNameFirstLetter = u.firstName.isNotEmpty ? u.firstName[0] : ""; final nameFirstLetter = u.name.isNotEmpty ? u.name[0] : "";
final lastNameFirstLetter = u.lastName.isNotEmpty ? u.lastName[0] : "";
return CircleAvatar( return CircleAvatar(
radius: radius, radius: radius,
backgroundColor: context.primaryColor.withAlpha(50), backgroundColor: context.primaryColor.withAlpha(50),
@ -19,6 +18,6 @@ Widget userAvatar(BuildContext context, User u, {double? radius}) {
), ),
// silence errors if user has no profile image, use initials as fallback // silence errors if user has no profile image, use initials as fallback
onForegroundImageError: (exception, stackTrace) {}, onForegroundImageError: (exception, stackTrace) {},
child: Text((firstNameFirstLetter + lastNameFirstLetter).toUpperCase()), child: Text(nameFirstLetter.toUpperCase()),
); );
} }

View File

@ -43,7 +43,7 @@ class UserCircleAvatar extends ConsumerWidget {
'${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${user.id}?d=${Random().nextInt(1024)}'; '${Store.get(StoreKey.serverEndpoint)}/user/profile-image/${user.id}?d=${Random().nextInt(1024)}';
final textIcon = Text( final textIcon = Text(
user.firstName[0].toUpperCase(), user.name[0].toUpperCase(),
style: TextStyle( style: TextStyle(
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
color: context.isDarkTheme ? Colors.black : Colors.white, color: context.isDarkTheme ? Colors.black : Colors.white,

View File

@ -10,9 +10,8 @@ Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**email** | **String** | | **email** | **String** | |
**externalPath** | **String** | | [optional] **externalPath** | **String** | | [optional]
**firstName** | **String** | |
**lastName** | **String** | |
**memoriesEnabled** | **bool** | | [optional] **memoriesEnabled** | **bool** | | [optional]
**name** | **String** | |
**password** | **String** | | **password** | **String** | |
**storageLabel** | **String** | | [optional] **storageLabel** | **String** | | [optional]

View File

@ -9,9 +9,8 @@ import 'package:openapi/api.dart';
Name | Type | Description | Notes Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**accessToken** | **String** | | **accessToken** | **String** | |
**firstName** | **String** | |
**isAdmin** | **bool** | | **isAdmin** | **bool** | |
**lastName** | **String** | | **name** | **String** | |
**profileImagePath** | **String** | | **profileImagePath** | **String** | |
**shouldChangePassword** | **bool** | | **shouldChangePassword** | **bool** | |
**userEmail** | **String** | | **userEmail** | **String** | |

View File

@ -12,12 +12,11 @@ Name | Type | Description | Notes
**deletedAt** | [**DateTime**](DateTime.md) | | **deletedAt** | [**DateTime**](DateTime.md) | |
**email** | **String** | | **email** | **String** | |
**externalPath** | **String** | | **externalPath** | **String** | |
**firstName** | **String** | |
**id** | **String** | | **id** | **String** | |
**inTimeline** | **bool** | | [optional] **inTimeline** | **bool** | | [optional]
**isAdmin** | **bool** | | **isAdmin** | **bool** | |
**lastName** | **String** | |
**memoriesEnabled** | **bool** | | [optional] **memoriesEnabled** | **bool** | | [optional]
**name** | **String** | |
**oauthId** | **String** | | **oauthId** | **String** | |
**profileImagePath** | **String** | | **profileImagePath** | **String** | |
**shouldChangePassword** | **bool** | | **shouldChangePassword** | **bool** | |

View File

@ -9,8 +9,7 @@ import 'package:openapi/api.dart';
Name | Type | Description | Notes Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**email** | **String** | | **email** | **String** | |
**firstName** | **String** | | **name** | **String** | |
**lastName** | **String** | |
**password** | **String** | | **password** | **String** | |
[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)

View File

@ -10,11 +10,10 @@ Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**email** | **String** | | [optional] **email** | **String** | | [optional]
**externalPath** | **String** | | [optional] **externalPath** | **String** | | [optional]
**firstName** | **String** | | [optional]
**id** | **String** | | **id** | **String** | |
**isAdmin** | **bool** | | [optional] **isAdmin** | **bool** | | [optional]
**lastName** | **String** | | [optional]
**memoriesEnabled** | **bool** | | [optional] **memoriesEnabled** | **bool** | | [optional]
**name** | **String** | | [optional]
**password** | **String** | | [optional] **password** | **String** | | [optional]
**shouldChangePassword** | **bool** | | [optional] **shouldChangePassword** | **bool** | | [optional]
**storageLabel** | **String** | | [optional] **storageLabel** | **String** | | [optional]

View File

@ -10,9 +10,8 @@ Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**photos** | **int** | | **photos** | **int** | |
**usage** | **int** | | **usage** | **int** | |
**userFirstName** | **String** | |
**userId** | **String** | | **userId** | **String** | |
**userLastName** | **String** | | **userName** | **String** | |
**videos** | **int** | | **videos** | **int** | |
[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)

View File

@ -9,9 +9,8 @@ import 'package:openapi/api.dart';
Name | Type | Description | Notes Name | Type | Description | Notes
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
**email** | **String** | | **email** | **String** | |
**firstName** | **String** | |
**id** | **String** | | **id** | **String** | |
**lastName** | **String** | | **name** | **String** | |
**profileImagePath** | **String** | | **profileImagePath** | **String** | |
[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)

View File

@ -12,11 +12,10 @@ Name | Type | Description | Notes
**deletedAt** | [**DateTime**](DateTime.md) | | **deletedAt** | [**DateTime**](DateTime.md) | |
**email** | **String** | | **email** | **String** | |
**externalPath** | **String** | | **externalPath** | **String** | |
**firstName** | **String** | |
**id** | **String** | | **id** | **String** | |
**isAdmin** | **bool** | | **isAdmin** | **bool** | |
**lastName** | **String** | |
**memoriesEnabled** | **bool** | | [optional] **memoriesEnabled** | **bool** | | [optional]
**name** | **String** | |
**oauthId** | **String** | | **oauthId** | **String** | |
**profileImagePath** | **String** | | **profileImagePath** | **String** | |
**shouldChangePassword** | **bool** | | **shouldChangePassword** | **bool** | |

View File

@ -15,9 +15,8 @@ class CreateUserDto {
CreateUserDto({ CreateUserDto({
required this.email, required this.email,
this.externalPath, this.externalPath,
required this.firstName,
required this.lastName,
this.memoriesEnabled, this.memoriesEnabled,
required this.name,
required this.password, required this.password,
this.storageLabel, this.storageLabel,
}); });
@ -26,10 +25,6 @@ class CreateUserDto {
String? externalPath; String? externalPath;
String firstName;
String lastName;
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@ -38,6 +33,8 @@ class CreateUserDto {
/// ///
bool? memoriesEnabled; bool? memoriesEnabled;
String name;
String password; String password;
String? storageLabel; String? storageLabel;
@ -46,9 +43,8 @@ class CreateUserDto {
bool operator ==(Object other) => identical(this, other) || other is CreateUserDto && bool operator ==(Object other) => identical(this, other) || other is CreateUserDto &&
other.email == email && other.email == email &&
other.externalPath == externalPath && other.externalPath == externalPath &&
other.firstName == firstName &&
other.lastName == lastName &&
other.memoriesEnabled == memoriesEnabled && other.memoriesEnabled == memoriesEnabled &&
other.name == name &&
other.password == password && other.password == password &&
other.storageLabel == storageLabel; other.storageLabel == storageLabel;
@ -57,14 +53,13 @@ class CreateUserDto {
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(email.hashCode) + (email.hashCode) +
(externalPath == null ? 0 : externalPath!.hashCode) + (externalPath == null ? 0 : externalPath!.hashCode) +
(firstName.hashCode) +
(lastName.hashCode) +
(memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) + (memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) +
(name.hashCode) +
(password.hashCode) + (password.hashCode) +
(storageLabel == null ? 0 : storageLabel!.hashCode); (storageLabel == null ? 0 : storageLabel!.hashCode);
@override @override
String toString() => 'CreateUserDto[email=$email, externalPath=$externalPath, firstName=$firstName, lastName=$lastName, memoriesEnabled=$memoriesEnabled, password=$password, storageLabel=$storageLabel]'; String toString() => 'CreateUserDto[email=$email, externalPath=$externalPath, memoriesEnabled=$memoriesEnabled, name=$name, password=$password, storageLabel=$storageLabel]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
@ -74,13 +69,12 @@ class CreateUserDto {
} else { } else {
// json[r'externalPath'] = null; // json[r'externalPath'] = null;
} }
json[r'firstName'] = this.firstName;
json[r'lastName'] = this.lastName;
if (this.memoriesEnabled != null) { if (this.memoriesEnabled != null) {
json[r'memoriesEnabled'] = this.memoriesEnabled; json[r'memoriesEnabled'] = this.memoriesEnabled;
} else { } else {
// json[r'memoriesEnabled'] = null; // json[r'memoriesEnabled'] = null;
} }
json[r'name'] = this.name;
json[r'password'] = this.password; json[r'password'] = this.password;
if (this.storageLabel != null) { if (this.storageLabel != null) {
json[r'storageLabel'] = this.storageLabel; json[r'storageLabel'] = this.storageLabel;
@ -100,9 +94,8 @@ class CreateUserDto {
return CreateUserDto( return CreateUserDto(
email: mapValueOfType<String>(json, r'email')!, email: mapValueOfType<String>(json, r'email')!,
externalPath: mapValueOfType<String>(json, r'externalPath'), externalPath: mapValueOfType<String>(json, r'externalPath'),
firstName: mapValueOfType<String>(json, r'firstName')!,
lastName: mapValueOfType<String>(json, r'lastName')!,
memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'), memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'),
name: mapValueOfType<String>(json, r'name')!,
password: mapValueOfType<String>(json, r'password')!, password: mapValueOfType<String>(json, r'password')!,
storageLabel: mapValueOfType<String>(json, r'storageLabel'), storageLabel: mapValueOfType<String>(json, r'storageLabel'),
); );
@ -153,8 +146,7 @@ class CreateUserDto {
/// The list of required keys that must be present in a JSON. /// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{ static const requiredKeys = <String>{
'email', 'email',
'firstName', 'name',
'lastName',
'password', 'password',
}; };
} }

View File

@ -14,9 +14,8 @@ class LoginResponseDto {
/// Returns a new [LoginResponseDto] instance. /// Returns a new [LoginResponseDto] instance.
LoginResponseDto({ LoginResponseDto({
required this.accessToken, required this.accessToken,
required this.firstName,
required this.isAdmin, required this.isAdmin,
required this.lastName, required this.name,
required this.profileImagePath, required this.profileImagePath,
required this.shouldChangePassword, required this.shouldChangePassword,
required this.userEmail, required this.userEmail,
@ -25,11 +24,9 @@ class LoginResponseDto {
String accessToken; String accessToken;
String firstName;
bool isAdmin; bool isAdmin;
String lastName; String name;
String profileImagePath; String profileImagePath;
@ -42,9 +39,8 @@ class LoginResponseDto {
@override @override
bool operator ==(Object other) => identical(this, other) || other is LoginResponseDto && bool operator ==(Object other) => identical(this, other) || other is LoginResponseDto &&
other.accessToken == accessToken && other.accessToken == accessToken &&
other.firstName == firstName &&
other.isAdmin == isAdmin && other.isAdmin == isAdmin &&
other.lastName == lastName && other.name == name &&
other.profileImagePath == profileImagePath && other.profileImagePath == profileImagePath &&
other.shouldChangePassword == shouldChangePassword && other.shouldChangePassword == shouldChangePassword &&
other.userEmail == userEmail && other.userEmail == userEmail &&
@ -54,23 +50,21 @@ class LoginResponseDto {
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(accessToken.hashCode) + (accessToken.hashCode) +
(firstName.hashCode) +
(isAdmin.hashCode) + (isAdmin.hashCode) +
(lastName.hashCode) + (name.hashCode) +
(profileImagePath.hashCode) + (profileImagePath.hashCode) +
(shouldChangePassword.hashCode) + (shouldChangePassword.hashCode) +
(userEmail.hashCode) + (userEmail.hashCode) +
(userId.hashCode); (userId.hashCode);
@override @override
String toString() => 'LoginResponseDto[accessToken=$accessToken, firstName=$firstName, isAdmin=$isAdmin, lastName=$lastName, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, userEmail=$userEmail, userId=$userId]'; String toString() => 'LoginResponseDto[accessToken=$accessToken, isAdmin=$isAdmin, name=$name, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, userEmail=$userEmail, userId=$userId]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'accessToken'] = this.accessToken; json[r'accessToken'] = this.accessToken;
json[r'firstName'] = this.firstName;
json[r'isAdmin'] = this.isAdmin; json[r'isAdmin'] = this.isAdmin;
json[r'lastName'] = this.lastName; json[r'name'] = this.name;
json[r'profileImagePath'] = this.profileImagePath; json[r'profileImagePath'] = this.profileImagePath;
json[r'shouldChangePassword'] = this.shouldChangePassword; json[r'shouldChangePassword'] = this.shouldChangePassword;
json[r'userEmail'] = this.userEmail; json[r'userEmail'] = this.userEmail;
@ -87,9 +81,8 @@ class LoginResponseDto {
return LoginResponseDto( return LoginResponseDto(
accessToken: mapValueOfType<String>(json, r'accessToken')!, accessToken: mapValueOfType<String>(json, r'accessToken')!,
firstName: mapValueOfType<String>(json, r'firstName')!,
isAdmin: mapValueOfType<bool>(json, r'isAdmin')!, isAdmin: mapValueOfType<bool>(json, r'isAdmin')!,
lastName: mapValueOfType<String>(json, r'lastName')!, name: mapValueOfType<String>(json, r'name')!,
profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!, profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!,
shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!, shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!,
userEmail: mapValueOfType<String>(json, r'userEmail')!, userEmail: mapValueOfType<String>(json, r'userEmail')!,
@ -142,9 +135,8 @@ class LoginResponseDto {
/// The list of required keys that must be present in a JSON. /// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{ static const requiredKeys = <String>{
'accessToken', 'accessToken',
'firstName',
'isAdmin', 'isAdmin',
'lastName', 'name',
'profileImagePath', 'profileImagePath',
'shouldChangePassword', 'shouldChangePassword',
'userEmail', 'userEmail',

View File

@ -17,12 +17,11 @@ class PartnerResponseDto {
required this.deletedAt, required this.deletedAt,
required this.email, required this.email,
required this.externalPath, required this.externalPath,
required this.firstName,
required this.id, required this.id,
this.inTimeline, this.inTimeline,
required this.isAdmin, required this.isAdmin,
required this.lastName,
this.memoriesEnabled, this.memoriesEnabled,
required this.name,
required this.oauthId, required this.oauthId,
required this.profileImagePath, required this.profileImagePath,
required this.shouldChangePassword, required this.shouldChangePassword,
@ -38,8 +37,6 @@ class PartnerResponseDto {
String? externalPath; String? externalPath;
String firstName;
String id; String id;
/// ///
@ -52,8 +49,6 @@ class PartnerResponseDto {
bool isAdmin; bool isAdmin;
String lastName;
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@ -62,6 +57,8 @@ class PartnerResponseDto {
/// ///
bool? memoriesEnabled; bool? memoriesEnabled;
String name;
String oauthId; String oauthId;
String profileImagePath; String profileImagePath;
@ -78,12 +75,11 @@ class PartnerResponseDto {
other.deletedAt == deletedAt && other.deletedAt == deletedAt &&
other.email == email && other.email == email &&
other.externalPath == externalPath && other.externalPath == externalPath &&
other.firstName == firstName &&
other.id == id && other.id == id &&
other.inTimeline == inTimeline && other.inTimeline == inTimeline &&
other.isAdmin == isAdmin && other.isAdmin == isAdmin &&
other.lastName == lastName &&
other.memoriesEnabled == memoriesEnabled && other.memoriesEnabled == memoriesEnabled &&
other.name == name &&
other.oauthId == oauthId && other.oauthId == oauthId &&
other.profileImagePath == profileImagePath && other.profileImagePath == profileImagePath &&
other.shouldChangePassword == shouldChangePassword && other.shouldChangePassword == shouldChangePassword &&
@ -97,12 +93,11 @@ class PartnerResponseDto {
(deletedAt == null ? 0 : deletedAt!.hashCode) + (deletedAt == null ? 0 : deletedAt!.hashCode) +
(email.hashCode) + (email.hashCode) +
(externalPath == null ? 0 : externalPath!.hashCode) + (externalPath == null ? 0 : externalPath!.hashCode) +
(firstName.hashCode) +
(id.hashCode) + (id.hashCode) +
(inTimeline == null ? 0 : inTimeline!.hashCode) + (inTimeline == null ? 0 : inTimeline!.hashCode) +
(isAdmin.hashCode) + (isAdmin.hashCode) +
(lastName.hashCode) +
(memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) + (memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) +
(name.hashCode) +
(oauthId.hashCode) + (oauthId.hashCode) +
(profileImagePath.hashCode) + (profileImagePath.hashCode) +
(shouldChangePassword.hashCode) + (shouldChangePassword.hashCode) +
@ -110,7 +105,7 @@ class PartnerResponseDto {
(updatedAt.hashCode); (updatedAt.hashCode);
@override @override
String toString() => 'PartnerResponseDto[createdAt=$createdAt, deletedAt=$deletedAt, email=$email, externalPath=$externalPath, firstName=$firstName, id=$id, inTimeline=$inTimeline, isAdmin=$isAdmin, lastName=$lastName, memoriesEnabled=$memoriesEnabled, oauthId=$oauthId, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel, updatedAt=$updatedAt]'; String toString() => 'PartnerResponseDto[createdAt=$createdAt, deletedAt=$deletedAt, email=$email, externalPath=$externalPath, id=$id, inTimeline=$inTimeline, isAdmin=$isAdmin, memoriesEnabled=$memoriesEnabled, name=$name, oauthId=$oauthId, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel, updatedAt=$updatedAt]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
@ -126,7 +121,6 @@ class PartnerResponseDto {
} else { } else {
// json[r'externalPath'] = null; // json[r'externalPath'] = null;
} }
json[r'firstName'] = this.firstName;
json[r'id'] = this.id; json[r'id'] = this.id;
if (this.inTimeline != null) { if (this.inTimeline != null) {
json[r'inTimeline'] = this.inTimeline; json[r'inTimeline'] = this.inTimeline;
@ -134,12 +128,12 @@ class PartnerResponseDto {
// json[r'inTimeline'] = null; // json[r'inTimeline'] = null;
} }
json[r'isAdmin'] = this.isAdmin; json[r'isAdmin'] = this.isAdmin;
json[r'lastName'] = this.lastName;
if (this.memoriesEnabled != null) { if (this.memoriesEnabled != null) {
json[r'memoriesEnabled'] = this.memoriesEnabled; json[r'memoriesEnabled'] = this.memoriesEnabled;
} else { } else {
// json[r'memoriesEnabled'] = null; // json[r'memoriesEnabled'] = null;
} }
json[r'name'] = this.name;
json[r'oauthId'] = this.oauthId; json[r'oauthId'] = this.oauthId;
json[r'profileImagePath'] = this.profileImagePath; json[r'profileImagePath'] = this.profileImagePath;
json[r'shouldChangePassword'] = this.shouldChangePassword; json[r'shouldChangePassword'] = this.shouldChangePassword;
@ -164,12 +158,11 @@ class PartnerResponseDto {
deletedAt: mapDateTime(json, r'deletedAt', ''), deletedAt: mapDateTime(json, r'deletedAt', ''),
email: mapValueOfType<String>(json, r'email')!, email: mapValueOfType<String>(json, r'email')!,
externalPath: mapValueOfType<String>(json, r'externalPath'), externalPath: mapValueOfType<String>(json, r'externalPath'),
firstName: mapValueOfType<String>(json, r'firstName')!,
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
inTimeline: mapValueOfType<bool>(json, r'inTimeline'), inTimeline: mapValueOfType<bool>(json, r'inTimeline'),
isAdmin: mapValueOfType<bool>(json, r'isAdmin')!, isAdmin: mapValueOfType<bool>(json, r'isAdmin')!,
lastName: mapValueOfType<String>(json, r'lastName')!,
memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'), memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'),
name: mapValueOfType<String>(json, r'name')!,
oauthId: mapValueOfType<String>(json, r'oauthId')!, oauthId: mapValueOfType<String>(json, r'oauthId')!,
profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!, profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!,
shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!, shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!,
@ -226,10 +219,9 @@ class PartnerResponseDto {
'deletedAt', 'deletedAt',
'email', 'email',
'externalPath', 'externalPath',
'firstName',
'id', 'id',
'isAdmin', 'isAdmin',
'lastName', 'name',
'oauthId', 'oauthId',
'profileImagePath', 'profileImagePath',
'shouldChangePassword', 'shouldChangePassword',

View File

@ -14,42 +14,36 @@ class SignUpDto {
/// Returns a new [SignUpDto] instance. /// Returns a new [SignUpDto] instance.
SignUpDto({ SignUpDto({
required this.email, required this.email,
required this.firstName, required this.name,
required this.lastName,
required this.password, required this.password,
}); });
String email; String email;
String firstName; String name;
String lastName;
String password; String password;
@override @override
bool operator ==(Object other) => identical(this, other) || other is SignUpDto && bool operator ==(Object other) => identical(this, other) || other is SignUpDto &&
other.email == email && other.email == email &&
other.firstName == firstName && other.name == name &&
other.lastName == lastName &&
other.password == password; other.password == password;
@override @override
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(email.hashCode) + (email.hashCode) +
(firstName.hashCode) + (name.hashCode) +
(lastName.hashCode) +
(password.hashCode); (password.hashCode);
@override @override
String toString() => 'SignUpDto[email=$email, firstName=$firstName, lastName=$lastName, password=$password]'; String toString() => 'SignUpDto[email=$email, name=$name, password=$password]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'email'] = this.email; json[r'email'] = this.email;
json[r'firstName'] = this.firstName; json[r'name'] = this.name;
json[r'lastName'] = this.lastName;
json[r'password'] = this.password; json[r'password'] = this.password;
return json; return json;
} }
@ -63,8 +57,7 @@ class SignUpDto {
return SignUpDto( return SignUpDto(
email: mapValueOfType<String>(json, r'email')!, email: mapValueOfType<String>(json, r'email')!,
firstName: mapValueOfType<String>(json, r'firstName')!, name: mapValueOfType<String>(json, r'name')!,
lastName: mapValueOfType<String>(json, r'lastName')!,
password: mapValueOfType<String>(json, r'password')!, password: mapValueOfType<String>(json, r'password')!,
); );
} }
@ -114,8 +107,7 @@ class SignUpDto {
/// The list of required keys that must be present in a JSON. /// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{ static const requiredKeys = <String>{
'email', 'email',
'firstName', 'name',
'lastName',
'password', 'password',
}; };
} }

View File

@ -15,11 +15,10 @@ class UpdateUserDto {
UpdateUserDto({ UpdateUserDto({
this.email, this.email,
this.externalPath, this.externalPath,
this.firstName,
required this.id, required this.id,
this.isAdmin, this.isAdmin,
this.lastName,
this.memoriesEnabled, this.memoriesEnabled,
this.name,
this.password, this.password,
this.shouldChangePassword, this.shouldChangePassword,
this.storageLabel, this.storageLabel,
@ -41,14 +40,6 @@ class UpdateUserDto {
/// ///
String? externalPath; String? externalPath;
///
/// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated
/// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note.
///
String? firstName;
String id; String id;
/// ///
@ -65,7 +56,7 @@ class UpdateUserDto {
/// source code must fall back to having a nullable type. /// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note. /// Consider adding a "default:" property in the specification file to hide this note.
/// ///
String? lastName; bool? memoriesEnabled;
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
@ -73,7 +64,7 @@ class UpdateUserDto {
/// source code must fall back to having a nullable type. /// source code must fall back to having a nullable type.
/// Consider adding a "default:" property in the specification file to hide this note. /// Consider adding a "default:" property in the specification file to hide this note.
/// ///
bool? memoriesEnabled; String? name;
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
@ -103,11 +94,10 @@ class UpdateUserDto {
bool operator ==(Object other) => identical(this, other) || other is UpdateUserDto && bool operator ==(Object other) => identical(this, other) || other is UpdateUserDto &&
other.email == email && other.email == email &&
other.externalPath == externalPath && other.externalPath == externalPath &&
other.firstName == firstName &&
other.id == id && other.id == id &&
other.isAdmin == isAdmin && other.isAdmin == isAdmin &&
other.lastName == lastName &&
other.memoriesEnabled == memoriesEnabled && other.memoriesEnabled == memoriesEnabled &&
other.name == name &&
other.password == password && other.password == password &&
other.shouldChangePassword == shouldChangePassword && other.shouldChangePassword == shouldChangePassword &&
other.storageLabel == storageLabel; other.storageLabel == storageLabel;
@ -117,17 +107,16 @@ class UpdateUserDto {
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(email == null ? 0 : email!.hashCode) + (email == null ? 0 : email!.hashCode) +
(externalPath == null ? 0 : externalPath!.hashCode) + (externalPath == null ? 0 : externalPath!.hashCode) +
(firstName == null ? 0 : firstName!.hashCode) +
(id.hashCode) + (id.hashCode) +
(isAdmin == null ? 0 : isAdmin!.hashCode) + (isAdmin == null ? 0 : isAdmin!.hashCode) +
(lastName == null ? 0 : lastName!.hashCode) +
(memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) + (memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) +
(name == null ? 0 : name!.hashCode) +
(password == null ? 0 : password!.hashCode) + (password == null ? 0 : password!.hashCode) +
(shouldChangePassword == null ? 0 : shouldChangePassword!.hashCode) + (shouldChangePassword == null ? 0 : shouldChangePassword!.hashCode) +
(storageLabel == null ? 0 : storageLabel!.hashCode); (storageLabel == null ? 0 : storageLabel!.hashCode);
@override @override
String toString() => 'UpdateUserDto[email=$email, externalPath=$externalPath, firstName=$firstName, id=$id, isAdmin=$isAdmin, lastName=$lastName, memoriesEnabled=$memoriesEnabled, password=$password, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel]'; String toString() => 'UpdateUserDto[email=$email, externalPath=$externalPath, id=$id, isAdmin=$isAdmin, memoriesEnabled=$memoriesEnabled, name=$name, password=$password, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
@ -140,11 +129,6 @@ class UpdateUserDto {
json[r'externalPath'] = this.externalPath; json[r'externalPath'] = this.externalPath;
} else { } else {
// json[r'externalPath'] = null; // json[r'externalPath'] = null;
}
if (this.firstName != null) {
json[r'firstName'] = this.firstName;
} else {
// json[r'firstName'] = null;
} }
json[r'id'] = this.id; json[r'id'] = this.id;
if (this.isAdmin != null) { if (this.isAdmin != null) {
@ -152,16 +136,16 @@ class UpdateUserDto {
} else { } else {
// json[r'isAdmin'] = null; // json[r'isAdmin'] = null;
} }
if (this.lastName != null) {
json[r'lastName'] = this.lastName;
} else {
// json[r'lastName'] = null;
}
if (this.memoriesEnabled != null) { if (this.memoriesEnabled != null) {
json[r'memoriesEnabled'] = this.memoriesEnabled; json[r'memoriesEnabled'] = this.memoriesEnabled;
} else { } else {
// json[r'memoriesEnabled'] = null; // json[r'memoriesEnabled'] = null;
} }
if (this.name != null) {
json[r'name'] = this.name;
} else {
// json[r'name'] = null;
}
if (this.password != null) { if (this.password != null) {
json[r'password'] = this.password; json[r'password'] = this.password;
} else { } else {
@ -190,11 +174,10 @@ class UpdateUserDto {
return UpdateUserDto( return UpdateUserDto(
email: mapValueOfType<String>(json, r'email'), email: mapValueOfType<String>(json, r'email'),
externalPath: mapValueOfType<String>(json, r'externalPath'), externalPath: mapValueOfType<String>(json, r'externalPath'),
firstName: mapValueOfType<String>(json, r'firstName'),
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
isAdmin: mapValueOfType<bool>(json, r'isAdmin'), isAdmin: mapValueOfType<bool>(json, r'isAdmin'),
lastName: mapValueOfType<String>(json, r'lastName'),
memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'), memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'),
name: mapValueOfType<String>(json, r'name'),
password: mapValueOfType<String>(json, r'password'), password: mapValueOfType<String>(json, r'password'),
shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword'), shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword'),
storageLabel: mapValueOfType<String>(json, r'storageLabel'), storageLabel: mapValueOfType<String>(json, r'storageLabel'),

View File

@ -15,9 +15,8 @@ class UsageByUserDto {
UsageByUserDto({ UsageByUserDto({
required this.photos, required this.photos,
required this.usage, required this.usage,
required this.userFirstName,
required this.userId, required this.userId,
required this.userLastName, required this.userName,
required this.videos, required this.videos,
}); });
@ -25,11 +24,9 @@ class UsageByUserDto {
int usage; int usage;
String userFirstName;
String userId; String userId;
String userLastName; String userName;
int videos; int videos;
@ -37,9 +34,8 @@ class UsageByUserDto {
bool operator ==(Object other) => identical(this, other) || other is UsageByUserDto && bool operator ==(Object other) => identical(this, other) || other is UsageByUserDto &&
other.photos == photos && other.photos == photos &&
other.usage == usage && other.usage == usage &&
other.userFirstName == userFirstName &&
other.userId == userId && other.userId == userId &&
other.userLastName == userLastName && other.userName == userName &&
other.videos == videos; other.videos == videos;
@override @override
@ -47,21 +43,19 @@ class UsageByUserDto {
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(photos.hashCode) + (photos.hashCode) +
(usage.hashCode) + (usage.hashCode) +
(userFirstName.hashCode) +
(userId.hashCode) + (userId.hashCode) +
(userLastName.hashCode) + (userName.hashCode) +
(videos.hashCode); (videos.hashCode);
@override @override
String toString() => 'UsageByUserDto[photos=$photos, usage=$usage, userFirstName=$userFirstName, userId=$userId, userLastName=$userLastName, videos=$videos]'; String toString() => 'UsageByUserDto[photos=$photos, usage=$usage, userId=$userId, userName=$userName, videos=$videos]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'photos'] = this.photos; json[r'photos'] = this.photos;
json[r'usage'] = this.usage; json[r'usage'] = this.usage;
json[r'userFirstName'] = this.userFirstName;
json[r'userId'] = this.userId; json[r'userId'] = this.userId;
json[r'userLastName'] = this.userLastName; json[r'userName'] = this.userName;
json[r'videos'] = this.videos; json[r'videos'] = this.videos;
return json; return json;
} }
@ -76,9 +70,8 @@ class UsageByUserDto {
return UsageByUserDto( return UsageByUserDto(
photos: mapValueOfType<int>(json, r'photos')!, photos: mapValueOfType<int>(json, r'photos')!,
usage: mapValueOfType<int>(json, r'usage')!, usage: mapValueOfType<int>(json, r'usage')!,
userFirstName: mapValueOfType<String>(json, r'userFirstName')!,
userId: mapValueOfType<String>(json, r'userId')!, userId: mapValueOfType<String>(json, r'userId')!,
userLastName: mapValueOfType<String>(json, r'userLastName')!, userName: mapValueOfType<String>(json, r'userName')!,
videos: mapValueOfType<int>(json, r'videos')!, videos: mapValueOfType<int>(json, r'videos')!,
); );
} }
@ -129,9 +122,8 @@ class UsageByUserDto {
static const requiredKeys = <String>{ static const requiredKeys = <String>{
'photos', 'photos',
'usage', 'usage',
'userFirstName',
'userId', 'userId',
'userLastName', 'userName',
'videos', 'videos',
}; };
} }

View File

@ -14,48 +14,42 @@ class UserDto {
/// Returns a new [UserDto] instance. /// Returns a new [UserDto] instance.
UserDto({ UserDto({
required this.email, required this.email,
required this.firstName,
required this.id, required this.id,
required this.lastName, required this.name,
required this.profileImagePath, required this.profileImagePath,
}); });
String email; String email;
String firstName;
String id; String id;
String lastName; String name;
String profileImagePath; String profileImagePath;
@override @override
bool operator ==(Object other) => identical(this, other) || other is UserDto && bool operator ==(Object other) => identical(this, other) || other is UserDto &&
other.email == email && other.email == email &&
other.firstName == firstName &&
other.id == id && other.id == id &&
other.lastName == lastName && other.name == name &&
other.profileImagePath == profileImagePath; other.profileImagePath == profileImagePath;
@override @override
int get hashCode => int get hashCode =>
// ignore: unnecessary_parenthesis // ignore: unnecessary_parenthesis
(email.hashCode) + (email.hashCode) +
(firstName.hashCode) +
(id.hashCode) + (id.hashCode) +
(lastName.hashCode) + (name.hashCode) +
(profileImagePath.hashCode); (profileImagePath.hashCode);
@override @override
String toString() => 'UserDto[email=$email, firstName=$firstName, id=$id, lastName=$lastName, profileImagePath=$profileImagePath]'; String toString() => 'UserDto[email=$email, id=$id, name=$name, profileImagePath=$profileImagePath]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
json[r'email'] = this.email; json[r'email'] = this.email;
json[r'firstName'] = this.firstName;
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'lastName'] = this.lastName; json[r'name'] = this.name;
json[r'profileImagePath'] = this.profileImagePath; json[r'profileImagePath'] = this.profileImagePath;
return json; return json;
} }
@ -69,9 +63,8 @@ class UserDto {
return UserDto( return UserDto(
email: mapValueOfType<String>(json, r'email')!, email: mapValueOfType<String>(json, r'email')!,
firstName: mapValueOfType<String>(json, r'firstName')!,
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
lastName: mapValueOfType<String>(json, r'lastName')!, name: mapValueOfType<String>(json, r'name')!,
profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!, profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!,
); );
} }
@ -121,9 +114,8 @@ class UserDto {
/// The list of required keys that must be present in a JSON. /// The list of required keys that must be present in a JSON.
static const requiredKeys = <String>{ static const requiredKeys = <String>{
'email', 'email',
'firstName',
'id', 'id',
'lastName', 'name',
'profileImagePath', 'profileImagePath',
}; };
} }

View File

@ -17,11 +17,10 @@ class UserResponseDto {
required this.deletedAt, required this.deletedAt,
required this.email, required this.email,
required this.externalPath, required this.externalPath,
required this.firstName,
required this.id, required this.id,
required this.isAdmin, required this.isAdmin,
required this.lastName,
this.memoriesEnabled, this.memoriesEnabled,
required this.name,
required this.oauthId, required this.oauthId,
required this.profileImagePath, required this.profileImagePath,
required this.shouldChangePassword, required this.shouldChangePassword,
@ -37,14 +36,10 @@ class UserResponseDto {
String? externalPath; String? externalPath;
String firstName;
String id; String id;
bool isAdmin; bool isAdmin;
String lastName;
/// ///
/// Please note: This property should have been non-nullable! Since the specification file /// Please note: This property should have been non-nullable! Since the specification file
/// does not include a default value (using the "default:" property), however, the generated /// does not include a default value (using the "default:" property), however, the generated
@ -53,6 +48,8 @@ class UserResponseDto {
/// ///
bool? memoriesEnabled; bool? memoriesEnabled;
String name;
String oauthId; String oauthId;
String profileImagePath; String profileImagePath;
@ -69,11 +66,10 @@ class UserResponseDto {
other.deletedAt == deletedAt && other.deletedAt == deletedAt &&
other.email == email && other.email == email &&
other.externalPath == externalPath && other.externalPath == externalPath &&
other.firstName == firstName &&
other.id == id && other.id == id &&
other.isAdmin == isAdmin && other.isAdmin == isAdmin &&
other.lastName == lastName &&
other.memoriesEnabled == memoriesEnabled && other.memoriesEnabled == memoriesEnabled &&
other.name == name &&
other.oauthId == oauthId && other.oauthId == oauthId &&
other.profileImagePath == profileImagePath && other.profileImagePath == profileImagePath &&
other.shouldChangePassword == shouldChangePassword && other.shouldChangePassword == shouldChangePassword &&
@ -87,11 +83,10 @@ class UserResponseDto {
(deletedAt == null ? 0 : deletedAt!.hashCode) + (deletedAt == null ? 0 : deletedAt!.hashCode) +
(email.hashCode) + (email.hashCode) +
(externalPath == null ? 0 : externalPath!.hashCode) + (externalPath == null ? 0 : externalPath!.hashCode) +
(firstName.hashCode) +
(id.hashCode) + (id.hashCode) +
(isAdmin.hashCode) + (isAdmin.hashCode) +
(lastName.hashCode) +
(memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) + (memoriesEnabled == null ? 0 : memoriesEnabled!.hashCode) +
(name.hashCode) +
(oauthId.hashCode) + (oauthId.hashCode) +
(profileImagePath.hashCode) + (profileImagePath.hashCode) +
(shouldChangePassword.hashCode) + (shouldChangePassword.hashCode) +
@ -99,7 +94,7 @@ class UserResponseDto {
(updatedAt.hashCode); (updatedAt.hashCode);
@override @override
String toString() => 'UserResponseDto[createdAt=$createdAt, deletedAt=$deletedAt, email=$email, externalPath=$externalPath, firstName=$firstName, id=$id, isAdmin=$isAdmin, lastName=$lastName, memoriesEnabled=$memoriesEnabled, oauthId=$oauthId, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel, updatedAt=$updatedAt]'; String toString() => 'UserResponseDto[createdAt=$createdAt, deletedAt=$deletedAt, email=$email, externalPath=$externalPath, id=$id, isAdmin=$isAdmin, memoriesEnabled=$memoriesEnabled, name=$name, oauthId=$oauthId, profileImagePath=$profileImagePath, shouldChangePassword=$shouldChangePassword, storageLabel=$storageLabel, updatedAt=$updatedAt]';
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
final json = <String, dynamic>{}; final json = <String, dynamic>{};
@ -115,15 +110,14 @@ class UserResponseDto {
} else { } else {
// json[r'externalPath'] = null; // json[r'externalPath'] = null;
} }
json[r'firstName'] = this.firstName;
json[r'id'] = this.id; json[r'id'] = this.id;
json[r'isAdmin'] = this.isAdmin; json[r'isAdmin'] = this.isAdmin;
json[r'lastName'] = this.lastName;
if (this.memoriesEnabled != null) { if (this.memoriesEnabled != null) {
json[r'memoriesEnabled'] = this.memoriesEnabled; json[r'memoriesEnabled'] = this.memoriesEnabled;
} else { } else {
// json[r'memoriesEnabled'] = null; // json[r'memoriesEnabled'] = null;
} }
json[r'name'] = this.name;
json[r'oauthId'] = this.oauthId; json[r'oauthId'] = this.oauthId;
json[r'profileImagePath'] = this.profileImagePath; json[r'profileImagePath'] = this.profileImagePath;
json[r'shouldChangePassword'] = this.shouldChangePassword; json[r'shouldChangePassword'] = this.shouldChangePassword;
@ -148,11 +142,10 @@ class UserResponseDto {
deletedAt: mapDateTime(json, r'deletedAt', ''), deletedAt: mapDateTime(json, r'deletedAt', ''),
email: mapValueOfType<String>(json, r'email')!, email: mapValueOfType<String>(json, r'email')!,
externalPath: mapValueOfType<String>(json, r'externalPath'), externalPath: mapValueOfType<String>(json, r'externalPath'),
firstName: mapValueOfType<String>(json, r'firstName')!,
id: mapValueOfType<String>(json, r'id')!, id: mapValueOfType<String>(json, r'id')!,
isAdmin: mapValueOfType<bool>(json, r'isAdmin')!, isAdmin: mapValueOfType<bool>(json, r'isAdmin')!,
lastName: mapValueOfType<String>(json, r'lastName')!,
memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'), memoriesEnabled: mapValueOfType<bool>(json, r'memoriesEnabled'),
name: mapValueOfType<String>(json, r'name')!,
oauthId: mapValueOfType<String>(json, r'oauthId')!, oauthId: mapValueOfType<String>(json, r'oauthId')!,
profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!, profileImagePath: mapValueOfType<String>(json, r'profileImagePath')!,
shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!, shouldChangePassword: mapValueOfType<bool>(json, r'shouldChangePassword')!,
@ -209,10 +202,9 @@ class UserResponseDto {
'deletedAt', 'deletedAt',
'email', 'email',
'externalPath', 'externalPath',
'firstName',
'id', 'id',
'isAdmin', 'isAdmin',
'lastName', 'name',
'oauthId', 'oauthId',
'profileImagePath', 'profileImagePath',
'shouldChangePassword', 'shouldChangePassword',

View File

@ -26,21 +26,16 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// String lastName
test('to test the property `lastName`', () async {
// TODO
});
// bool memoriesEnabled // bool memoriesEnabled
test('to test the property `memoriesEnabled`', () async { test('to test the property `memoriesEnabled`', () async {
// TODO // TODO
}); });
// String name
test('to test the property `name`', () async {
// TODO
});
// String password // String password
test('to test the property `password`', () async { test('to test the property `password`', () async {
// TODO // TODO

View File

@ -21,18 +21,13 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// bool isAdmin // bool isAdmin
test('to test the property `isAdmin`', () async { test('to test the property `isAdmin`', () async {
// TODO // TODO
}); });
// String lastName // String name
test('to test the property `lastName`', () async { test('to test the property `name`', () async {
// TODO // TODO
}); });

View File

@ -36,11 +36,6 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// String id // String id
test('to test the property `id`', () async { test('to test the property `id`', () async {
// TODO // TODO
@ -56,13 +51,13 @@ void main() {
// TODO // TODO
}); });
// String lastName // bool memoriesEnabled
test('to test the property `lastName`', () async { test('to test the property `memoriesEnabled`', () async {
// TODO // TODO
}); });
// bool memoriesEnabled // String name
test('to test the property `memoriesEnabled`', () async { test('to test the property `name`', () async {
// TODO // TODO
}); });

View File

@ -21,13 +21,8 @@ void main() {
// TODO // TODO
}); });
// String firstName // String name
test('to test the property `firstName`', () async { test('to test the property `name`', () async {
// TODO
});
// String lastName
test('to test the property `lastName`', () async {
// TODO // TODO
}); });

View File

@ -26,11 +26,6 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// String id // String id
test('to test the property `id`', () async { test('to test the property `id`', () async {
// TODO // TODO
@ -41,13 +36,13 @@ void main() {
// TODO // TODO
}); });
// String lastName // bool memoriesEnabled
test('to test the property `lastName`', () async { test('to test the property `memoriesEnabled`', () async {
// TODO // TODO
}); });
// bool memoriesEnabled // String name
test('to test the property `memoriesEnabled`', () async { test('to test the property `name`', () async {
// TODO // TODO
}); });

View File

@ -26,18 +26,13 @@ void main() {
// TODO // TODO
}); });
// String userFirstName
test('to test the property `userFirstName`', () async {
// TODO
});
// String userId // String userId
test('to test the property `userId`', () async { test('to test the property `userId`', () async {
// TODO // TODO
}); });
// String userLastName // String userName
test('to test the property `userLastName`', () async { test('to test the property `userName`', () async {
// TODO // TODO
}); });

View File

@ -21,18 +21,13 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// String id // String id
test('to test the property `id`', () async { test('to test the property `id`', () async {
// TODO // TODO
}); });
// String lastName // String name
test('to test the property `lastName`', () async { test('to test the property `name`', () async {
// TODO // TODO
}); });

View File

@ -36,11 +36,6 @@ void main() {
// TODO // TODO
}); });
// String firstName
test('to test the property `firstName`', () async {
// TODO
});
// String id // String id
test('to test the property `id`', () async { test('to test the property `id`', () async {
// TODO // TODO
@ -51,13 +46,13 @@ void main() {
// TODO // TODO
}); });
// String lastName // bool memoriesEnabled
test('to test the property `lastName`', () async { test('to test the property `memoriesEnabled`', () async {
// TODO // TODO
}); });
// bool memoriesEnabled // String name
test('to test the property `memoriesEnabled`', () async { test('to test the property `name`', () async {
// TODO // TODO
}); });

View File

@ -62,8 +62,7 @@ void main() {
id: "1", id: "1",
updatedAt: DateTime.now(), updatedAt: DateTime.now(),
email: "a@b.c", email: "a@b.c",
firstName: "first", name: "first last",
lastName: "last",
isAdmin: false, isAdmin: false,
); );
setUpAll(() async { setUpAll(() async {

View File

@ -6844,15 +6844,12 @@
"nullable": true, "nullable": true,
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"lastName": {
"type": "string"
},
"memoriesEnabled": { "memoriesEnabled": {
"type": "boolean" "type": "boolean"
}, },
"name": {
"type": "string"
},
"password": { "password": {
"type": "string" "type": "string"
}, },
@ -6864,8 +6861,7 @@
"required": [ "required": [
"email", "email",
"password", "password",
"firstName", "name"
"lastName"
], ],
"type": "object" "type": "object"
}, },
@ -7463,13 +7459,10 @@
"accessToken": { "accessToken": {
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"isAdmin": { "isAdmin": {
"type": "boolean" "type": "boolean"
}, },
"lastName": { "name": {
"type": "string" "type": "string"
}, },
"profileImagePath": { "profileImagePath": {
@ -7489,8 +7482,7 @@
"accessToken", "accessToken",
"userId", "userId",
"userEmail", "userEmail",
"firstName", "name",
"lastName",
"profileImagePath", "profileImagePath",
"isAdmin", "isAdmin",
"shouldChangePassword" "shouldChangePassword"
@ -7656,9 +7648,6 @@
"nullable": true, "nullable": true,
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"id": { "id": {
"type": "string" "type": "string"
}, },
@ -7668,12 +7657,12 @@
"isAdmin": { "isAdmin": {
"type": "boolean" "type": "boolean"
}, },
"lastName": {
"type": "string"
},
"memoriesEnabled": { "memoriesEnabled": {
"type": "boolean" "type": "boolean"
}, },
"name": {
"type": "string"
},
"oauthId": { "oauthId": {
"type": "string" "type": "string"
}, },
@ -7694,8 +7683,7 @@
}, },
"required": [ "required": [
"id", "id",
"firstName", "name",
"lastName",
"email", "email",
"profileImagePath", "profileImagePath",
"storageLabel", "storageLabel",
@ -8464,14 +8452,10 @@
"example": "testuser@email.com", "example": "testuser@email.com",
"type": "string" "type": "string"
}, },
"firstName": { "name": {
"example": "Admin", "example": "Admin",
"type": "string" "type": "string"
}, },
"lastName": {
"example": "Doe",
"type": "string"
},
"password": { "password": {
"example": "password", "example": "password",
"type": "string" "type": "string"
@ -8480,8 +8464,7 @@
"required": [ "required": [
"email", "email",
"password", "password",
"firstName", "name"
"lastName"
], ],
"type": "object" "type": "object"
}, },
@ -9163,9 +9146,6 @@
"externalPath": { "externalPath": {
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"id": { "id": {
"format": "uuid", "format": "uuid",
"type": "string" "type": "string"
@ -9173,12 +9153,12 @@
"isAdmin": { "isAdmin": {
"type": "boolean" "type": "boolean"
}, },
"lastName": {
"type": "string"
},
"memoriesEnabled": { "memoriesEnabled": {
"type": "boolean" "type": "boolean"
}, },
"name": {
"type": "string"
},
"password": { "password": {
"type": "string" "type": "string"
}, },
@ -9203,13 +9183,10 @@
"format": "int64", "format": "int64",
"type": "integer" "type": "integer"
}, },
"userFirstName": {
"type": "string"
},
"userId": { "userId": {
"type": "string" "type": "string"
}, },
"userLastName": { "userName": {
"type": "string" "type": "string"
}, },
"videos": { "videos": {
@ -9218,8 +9195,7 @@
}, },
"required": [ "required": [
"userId", "userId",
"userFirstName", "userName",
"userLastName",
"photos", "photos",
"videos", "videos",
"usage" "usage"
@ -9231,13 +9207,10 @@
"email": { "email": {
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"id": { "id": {
"type": "string" "type": "string"
}, },
"lastName": { "name": {
"type": "string" "type": "string"
}, },
"profileImagePath": { "profileImagePath": {
@ -9246,8 +9219,7 @@
}, },
"required": [ "required": [
"id", "id",
"firstName", "name",
"lastName",
"email", "email",
"profileImagePath" "profileImagePath"
], ],
@ -9271,21 +9243,18 @@
"nullable": true, "nullable": true,
"type": "string" "type": "string"
}, },
"firstName": {
"type": "string"
},
"id": { "id": {
"type": "string" "type": "string"
}, },
"isAdmin": { "isAdmin": {
"type": "boolean" "type": "boolean"
}, },
"lastName": {
"type": "string"
},
"memoriesEnabled": { "memoriesEnabled": {
"type": "boolean" "type": "boolean"
}, },
"name": {
"type": "string"
},
"oauthId": { "oauthId": {
"type": "string" "type": "string"
}, },
@ -9306,8 +9275,7 @@
}, },
"required": [ "required": [
"id", "id",
"firstName", "name",
"lastName",
"email", "email",
"profileImagePath", "profileImagePath",
"storageLabel", "storageLabel",

View File

@ -16845,11 +16845,6 @@
"luxon": "^3.2.1" "luxon": "^3.2.1"
} }
}, },
"cron-validator": {
"version": "1.3.1",
"resolved": "https://registry.npmjs.org/cron-validator/-/cron-validator-1.3.1.tgz",
"integrity": "sha512-C1HsxuPCY/5opR55G5/WNzyEGDWFVG+6GLrA+fW/sCTcP6A6NTjUP2AK7B8n2PyFs90kDG2qzwm8LMheADku6A=="
},
"cross-spawn": { "cross-spawn": {
"version": "7.0.3", "version": "7.0.3",
"resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",

View File

@ -15,12 +15,12 @@ export class ResetAdminPasswordCommand extends CommandRunner {
async run(): Promise<void> { async run(): Promise<void> {
const ask = (admin: UserResponseDto) => { const ask = (admin: UserResponseDto) => {
const { id, oauthId, email, firstName, lastName } = admin; const { id, oauthId, email, name } = admin;
console.log(`Found Admin: console.log(`Found Admin:
- ID=${id} - ID=${id}
- OAuth ID=${oauthId} - OAuth ID=${oauthId}
- Email=${email} - Email=${email}
- Name=${firstName} ${lastName}`); - Name=${name}`);
return this.inquirer.ask<{ password: string }>('prompt-password', undefined).then(({ password }) => password); return this.inquirer.ask<{ password: string }>('prompt-password', undefined).then(({ password }) => password);
}; };

View File

@ -33,8 +33,7 @@ export class LoginResponseDto {
accessToken!: string; accessToken!: string;
userId!: string; userId!: string;
userEmail!: string; userEmail!: string;
firstName!: string; name!: string;
lastName!: string;
profileImagePath!: string; profileImagePath!: string;
isAdmin!: boolean; isAdmin!: boolean;
shouldChangePassword!: boolean; shouldChangePassword!: boolean;
@ -45,8 +44,7 @@ export function mapLoginResponse(entity: UserEntity, accessToken: string): Login
accessToken: accessToken, accessToken: accessToken,
userId: entity.id, userId: entity.id,
userEmail: entity.email, userEmail: entity.email,
firstName: entity.firstName, name: entity.name,
lastName: entity.lastName,
isAdmin: entity.isAdmin, isAdmin: entity.isAdmin,
profileImagePath: entity.profileImagePath, profileImagePath: entity.profileImagePath,
shouldChangePassword: entity.shouldChangePassword, shouldChangePassword: entity.shouldChangePassword,
@ -62,12 +60,7 @@ export class SignUpDto extends LoginCredentialDto {
@IsString() @IsString()
@IsNotEmpty() @IsNotEmpty()
@ApiProperty({ example: 'Admin' }) @ApiProperty({ example: 'Admin' })
firstName!: string; name!: string;
@IsString()
@IsNotEmpty()
@ApiProperty({ example: 'Doe' })
lastName!: string;
} }
export class ChangePasswordDto { export class ChangePasswordDto {

View File

@ -236,7 +236,7 @@ describe('AuthService', () => {
}); });
describe('adminSignUp', () => { describe('adminSignUp', () => {
const dto: SignUpDto = { email: 'test@immich.com', password: 'password', firstName: 'immich', lastName: 'admin' }; const dto: SignUpDto = { email: 'test@immich.com', password: 'password', name: 'immich admin' };
it('should only allow one admin', async () => { it('should only allow one admin', async () => {
userMock.getAdmin.mockResolvedValue({} as UserEntity); userMock.getAdmin.mockResolvedValue({} as UserEntity);
@ -251,8 +251,7 @@ describe('AuthService', () => {
id: 'admin', id: 'admin',
createdAt: new Date('2021-01-01'), createdAt: new Date('2021-01-01'),
email: 'test@immich.com', email: 'test@immich.com',
firstName: 'immich', name: 'immich admin',
lastName: 'admin',
}); });
expect(userMock.getAdmin).toHaveBeenCalled(); expect(userMock.getAdmin).toHaveBeenCalled();
expect(userMock.create).toHaveBeenCalled(); expect(userMock.create).toHaveBeenCalled();

View File

@ -146,8 +146,7 @@ export class AuthService {
const admin = await this.userCore.createUser({ const admin = await this.userCore.createUser({
isAdmin: true, isAdmin: true,
email: dto.email, email: dto.email,
firstName: dto.firstName, name: dto.name,
lastName: dto.lastName,
password: dto.password, password: dto.password,
storageLabel: 'admin', storageLabel: 'admin',
}); });
@ -273,9 +272,9 @@ export class AuthService {
storageLabel = null; storageLabel = null;
} }
const userName = profile.name ?? `${profile.given_name || ''} ${profile.family_name || ''}`;
user = await this.userCore.createUser({ user = await this.userCore.createUser({
firstName: profile.given_name || '', name: userName,
lastName: profile.family_name || '',
email: profile.email, email: profile.email,
oauthId: profile.sub, oauthId: profile.sub,
storageLabel, storageLabel,

View File

@ -7,10 +7,9 @@ import { PartnerService } from './partner.service';
const responseDto = { const responseDto = {
admin: <PartnerResponseDto>{ admin: <PartnerResponseDto>{
email: 'admin@test.com', email: 'admin@test.com',
firstName: 'admin_first_name', name: 'admin_name',
id: 'admin_id', id: 'admin_id',
isAdmin: true, isAdmin: true,
lastName: 'admin_last_name',
oauthId: '', oauthId: '',
profileImagePath: '', profileImagePath: '',
shouldChangePassword: false, shouldChangePassword: false,
@ -24,10 +23,9 @@ const responseDto = {
}, },
user1: <PartnerResponseDto>{ user1: <PartnerResponseDto>{
email: 'immich@test.com', email: 'immich@test.com',
firstName: 'immich_first_name', name: 'immich_name',
id: 'user-id', id: 'user-id',
isAdmin: false, isAdmin: false,
lastName: 'immich_last_name',
oauthId: '', oauthId: '',
profileImagePath: '', profileImagePath: '',
shouldChangePassword: false, shouldChangePassword: false,

View File

@ -6,8 +6,7 @@ export interface UserListFilter {
export interface UserStatsQueryResponse { export interface UserStatsQueryResponse {
userId: string; userId: string;
userFirstName: string; userName: string;
userLastName: string;
photos: number; photos: number;
videos: number; videos: number;
usage: number; usage: number;

View File

@ -38,9 +38,7 @@ export class UsageByUserDto {
@ApiProperty({ type: 'string' }) @ApiProperty({ type: 'string' })
userId!: string; userId!: string;
@ApiProperty({ type: 'string' }) @ApiProperty({ type: 'string' })
userFirstName!: string; userName!: string;
@ApiProperty({ type: 'string' })
userLastName!: string;
@ApiProperty({ type: 'integer' }) @ApiProperty({ type: 'integer' })
photos!: number; photos!: number;
@ApiProperty({ type: 'integer' }) @ApiProperty({ type: 'integer' })

View File

@ -195,24 +195,21 @@ describe(ServerInfoService.name, () => {
userMock.getUserStats.mockResolvedValue([ userMock.getUserStats.mockResolvedValue([
{ {
userId: 'user1', userId: 'user1',
userFirstName: '1', userName: '1 User',
userLastName: 'User',
photos: 10, photos: 10,
videos: 11, videos: 11,
usage: 12345, usage: 12345,
}, },
{ {
userId: 'user2', userId: 'user2',
userFirstName: '2', userName: '2 User',
userLastName: 'User',
photos: 10, photos: 10,
videos: 20, videos: 20,
usage: 123456, usage: 123456,
}, },
{ {
userId: 'user3', userId: 'user3',
userFirstName: '3', userName: '3 User',
userLastName: 'User',
photos: 100, photos: 100,
videos: 0, videos: 0,
usage: 987654, usage: 987654,
@ -227,25 +224,22 @@ describe(ServerInfoService.name, () => {
{ {
photos: 10, photos: 10,
usage: 12345, usage: 12345,
userFirstName: '1', userName: '1 User',
userId: 'user1', userId: 'user1',
userLastName: 'User',
videos: 11, videos: 11,
}, },
{ {
photos: 10, photos: 10,
usage: 123456, usage: 123456,
userFirstName: '2', userName: '2 User',
userId: 'user2', userId: 'user2',
userLastName: 'User',
videos: 20, videos: 20,
}, },
{ {
photos: 100, photos: 100,
usage: 987654, usage: 987654,
userFirstName: '3', userName: '3 User',
userId: 'user3', userId: 'user3',
userLastName: 'User',
videos: 0, videos: 0,
}, },
], ],

View File

@ -98,8 +98,7 @@ export class ServerInfoService {
for (const user of userStats) { for (const user of userStats) {
const usage = new UsageByUserDto(); const usage = new UsageByUserDto();
usage.userId = user.userId; usage.userId = user.userId;
usage.userFirstName = user.userFirstName; usage.userName = user.userName;
usage.userLastName = user.userLastName;
usage.photos = user.photos; usage.photos = user.photos;
usage.videos = user.videos; usage.videos = user.videos;
usage.usage = user.usage; usage.usage = user.usage;

View File

@ -7,8 +7,7 @@ describe('create user DTO', () => {
const params: Partial<CreateUserDto> = { const params: Partial<CreateUserDto> = {
email: undefined, email: undefined,
password: 'password', password: 'password',
firstName: 'first name', name: 'name',
lastName: 'last name',
}; };
let dto: CreateUserDto = plainToInstance(CreateUserDto, params); let dto: CreateUserDto = plainToInstance(CreateUserDto, params);
let errors = await validate(dto); let errors = await validate(dto);
@ -31,8 +30,7 @@ describe('create user DTO', () => {
const dto = plainToInstance(CreateUserDto, { const dto = plainToInstance(CreateUserDto, {
email: someEmail, email: someEmail,
password: 'some password', password: 'some password',
firstName: 'some first name', name: 'some name',
lastName: 'some last name',
}); });
const errors = await validate(dto); const errors = await validate(dto);
expect(errors).toHaveLength(0); expect(errors).toHaveLength(0);
@ -48,8 +46,7 @@ describe('create admin DTO', () => {
isAdmin: true, isAdmin: true,
email: someEmail, email: someEmail,
password: 'some password', password: 'some password',
firstName: 'some first name', name: 'some name',
lastName: 'some last name',
}); });
const errors = await validate(dto); const errors = await validate(dto);
expect(errors).toHaveLength(0); expect(errors).toHaveLength(0);
@ -64,8 +61,7 @@ describe('create user oauth DTO', () => {
const dto = plainToInstance(CreateUserOAuthDto, { const dto = plainToInstance(CreateUserOAuthDto, {
email: someEmail, email: someEmail,
oauthId: 'some oauth id', oauthId: 'some oauth id',
firstName: 'some first name', name: 'some name',
lastName: 'some last name',
}); });
const errors = await validate(dto); const errors = await validate(dto);
expect(errors).toHaveLength(0); expect(errors).toHaveLength(0);

View File

@ -13,11 +13,7 @@ export class CreateUserDto {
@IsNotEmpty() @IsNotEmpty()
@IsString() @IsString()
firstName!: string; name!: string;
@IsNotEmpty()
@IsString()
lastName!: string;
@Optional({ nullable: true }) @Optional({ nullable: true })
@IsString() @IsString()
@ -45,10 +41,7 @@ export class CreateAdminDto {
password!: string; password!: string;
@IsNotEmpty() @IsNotEmpty()
firstName!: string; name!: string;
@IsNotEmpty()
lastName!: string;
} }
export class CreateUserOAuthDto { export class CreateUserOAuthDto {
@ -59,7 +52,5 @@ export class CreateUserOAuthDto {
@IsNotEmpty() @IsNotEmpty()
oauthId!: string; oauthId!: string;
firstName?: string; name?: string;
lastName?: string;
} }

View File

@ -17,12 +17,7 @@ export class UpdateUserDto {
@Optional() @Optional()
@IsString() @IsString()
@IsNotEmpty() @IsNotEmpty()
firstName?: string; name?: string;
@Optional()
@IsString()
@IsNotEmpty()
lastName?: string;
@Optional() @Optional()
@IsString() @IsString()

View File

@ -2,8 +2,7 @@ import { UserEntity } from '@app/infra/entities';
export class UserDto { export class UserDto {
id!: string; id!: string;
firstName!: string; name!: string;
lastName!: string;
email!: string; email!: string;
profileImagePath!: string; profileImagePath!: string;
} }
@ -24,8 +23,7 @@ export const mapSimpleUser = (entity: UserEntity): UserDto => {
return { return {
id: entity.id, id: entity.id,
email: entity.email, email: entity.email,
firstName: entity.firstName, name: entity.name,
lastName: entity.lastName,
profileImagePath: entity.profileImagePath, profileImagePath: entity.profileImagePath,
}; };
}; };

View File

@ -289,8 +289,7 @@ describe(UserService.name, () => {
await expect( await expect(
sut.create({ sut.create({
email: 'john_smith@email.com', email: 'john_smith@email.com',
firstName: 'John', name: 'John Smith',
lastName: 'Smith',
password: 'password', password: 'password',
}), }),
).rejects.toBeInstanceOf(BadRequestException); ).rejects.toBeInstanceOf(BadRequestException);
@ -303,8 +302,7 @@ describe(UserService.name, () => {
await expect( await expect(
sut.create({ sut.create({
email: userStub.user1.email, email: userStub.user1.email,
firstName: userStub.user1.firstName, name: userStub.user1.name,
lastName: userStub.user1.lastName,
password: 'password', password: 'password',
storageLabel: 'label', storageLabel: 'label',
}), }),
@ -313,8 +311,7 @@ describe(UserService.name, () => {
expect(userMock.getAdmin).toBeCalled(); expect(userMock.getAdmin).toBeCalled();
expect(userMock.create).toBeCalledWith({ expect(userMock.create).toBeCalledWith({
email: userStub.user1.email, email: userStub.user1.email,
firstName: userStub.user1.firstName, name: userStub.user1.name,
lastName: userStub.user1.lastName,
storageLabel: 'label', storageLabel: 'label',
password: expect.anything(), password: expect.anything(),
}); });

View File

@ -16,10 +16,7 @@ export class UserEntity {
id!: string; id!: string;
@Column({ default: '' }) @Column({ default: '' })
firstName!: string; name!: string;
@Column({ default: '' })
lastName!: string;
@Column({ default: false }) @Column({ default: false })
isAdmin!: boolean; isAdmin!: boolean;

View File

@ -0,0 +1,21 @@
import { MigrationInterface, QueryRunner } from "typeorm";
export class AddUsername1699322864544 implements MigrationInterface {
name = 'AddUsername1699322864544'
public async up(queryRunner: QueryRunner): Promise<void> {
await queryRunner.query(`ALTER TABLE "users" ADD "name" character varying NOT NULL DEFAULT ''`);
await queryRunner.query(`UPDATE "users" SET "name" = CONCAT(COALESCE("firstName", ''), ' ', COALESCE("lastName", ''))`);
await queryRunner.query(`ALTER TABLE "users" DROP COLUMN "firstName"`);
await queryRunner.query(`ALTER TABLE "users" DROP COLUMN "lastName"`);
}
public async down(queryRunner: QueryRunner): Promise<void> {
await queryRunner.query(`ALTER TABLE "users" DROP COLUMN "name"`);
await queryRunner.query(`ALTER TABLE "users" ADD "lastName" character varying NOT NULL DEFAULT ''`);
await queryRunner.query(`ALTER TABLE "users" ADD "firstName" character varying NOT NULL DEFAULT ''`);
await queryRunner.query(`UPDATE "users" SET "lastName" = COALESCE("email", '')`);
await queryRunner.query(`UPDATE "users" SET "firstName" = COALESCE("email", '')`);
}
}

View File

@ -80,8 +80,7 @@ export class UserRepository implements IUserRepository {
const stats = await this.userRepository const stats = await this.userRepository
.createQueryBuilder('users') .createQueryBuilder('users')
.select('users.id', 'userId') .select('users.id', 'userId')
.addSelect('users.firstName', 'userFirstName') .addSelect('users.name', 'userName')
.addSelect('users.lastName', 'userLastName')
.addSelect(`COUNT(assets.id) FILTER (WHERE assets.type = 'IMAGE' AND assets.isVisible)`, 'photos') .addSelect(`COUNT(assets.id) FILTER (WHERE assets.type = 'IMAGE' AND assets.isVisible)`, 'photos')
.addSelect(`COUNT(assets.id) FILTER (WHERE assets.type = 'VIDEO' AND assets.isVisible)`, 'videos') .addSelect(`COUNT(assets.id) FILTER (WHERE assets.type = 'VIDEO' AND assets.isVisible)`, 'videos')
.addSelect('COALESCE(SUM(exif.fileSizeInByte), 0)', 'usage') .addSelect('COALESCE(SUM(exif.fileSizeInByte), 0)', 'usage')

View File

@ -350,8 +350,7 @@ describe(`${ActivityController.name} (e2e)`, () => {
const { id: userId } = await api.userApi.create(server, admin.accessToken, { const { id: userId } = await api.userApi.create(server, admin.accessToken, {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}); });
await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] }); await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] });
const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' }); const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' });
@ -371,8 +370,7 @@ describe(`${ActivityController.name} (e2e)`, () => {
const { id: userId } = await api.userApi.create(server, admin.accessToken, { const { id: userId } = await api.userApi.create(server, admin.accessToken, {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}); });
await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] }); await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] });
const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' }); const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' });
@ -393,8 +391,7 @@ describe(`${ActivityController.name} (e2e)`, () => {
const { id: userId } = await api.userApi.create(server, admin.accessToken, { const { id: userId } = await api.userApi.create(server, admin.accessToken, {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}); });
await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] }); await api.albumApi.addUsers(server, admin.accessToken, album.id, { sharedUserIds: [userId] });
const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' }); const nonOwner = await api.authApi.login(server, { email: 'user1@immich.app', password: 'Password123' });

View File

@ -41,14 +41,12 @@ describe(`${AlbumController.name} (e2e)`, () => {
api.userApi.create(server, admin.accessToken, { api.userApi.create(server, admin.accessToken, {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}), }),
api.userApi.create(server, admin.accessToken, { api.userApi.create(server, admin.accessToken, {
email: 'user2@immich.app', email: 'user2@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 2', name: 'User 2',
lastName: 'Test',
}), }),
]); ]);

View File

@ -22,15 +22,13 @@ import request from 'supertest';
const user1Dto = { const user1Dto = {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}; };
const user2Dto = { const user2Dto = {
email: 'user2@immich.app', email: 'user2@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 2', name: 'User 2',
lastName: 'Test',
}; };
const makeUploadDto = (options?: { omit: string }): Record<string, any> => { const makeUploadDto = (options?: { omit: string }): Record<string, any> => {

View File

@ -13,15 +13,13 @@ import {
import { testApp } from '@test/test-utils'; import { testApp } from '@test/test-utils';
import request from 'supertest'; import request from 'supertest';
const firstName = 'Immich'; const name = 'Immich Admin';
const lastName = 'Admin';
const password = 'Password123'; const password = 'Password123';
const email = 'admin@immich.app'; const email = 'admin@immich.app';
const adminSignupResponse = { const adminSignupResponse = {
id: expect.any(String), id: expect.any(String),
firstName: 'Immich', name: 'Immich Admin',
lastName: 'Admin',
email: 'admin@immich.app', email: 'admin@immich.app',
storageLabel: 'admin', storageLabel: 'admin',
externalPath: null, externalPath: null,
@ -64,23 +62,19 @@ describe(`${AuthController.name} (e2e)`, () => {
const invalid = [ const invalid = [
{ {
should: 'require an email address', should: 'require an email address',
data: { firstName, lastName, password }, data: { name, password },
}, },
{ {
should: 'require a password', should: 'require a password',
data: { firstName, lastName, email }, data: { name, email },
}, },
{ {
should: 'require a first name ', should: 'require a name',
data: { lastName, email, password }, data: { email, password },
},
{
should: 'require a last name ',
data: { firstName, email, password },
}, },
{ {
should: 'require a valid email', should: 'require a valid email',
data: { firstName, lastName, email: 'immich', password }, data: { name, email: 'immich', password },
}, },
]; ];

View File

@ -15,15 +15,13 @@ describe(`${LibraryController.name} (e2e)`, () => {
const user1Dto = { const user1Dto = {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}; };
const user2Dto = { const user2Dto = {
email: 'user2@immich.app', email: 'user2@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 2', name: 'User 2',
lastName: 'Test',
}; };
beforeAll(async () => { beforeAll(async () => {

View File

@ -10,15 +10,13 @@ import request from 'supertest';
const user1Dto = { const user1Dto = {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}; };
const user2Dto = { const user2Dto = {
email: 'user2@immich.app', email: 'user2@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 2', name: 'User 2',
lastName: 'Test',
}; };
describe(`${PartnerController.name} (e2e)`, () => { describe(`${PartnerController.name} (e2e)`, () => {

View File

@ -111,7 +111,7 @@ describe(`${ServerInfoController.name} (e2e)`, () => {
it('should only work for admins', async () => { it('should only work for admins', async () => {
const loginDto = { email: 'test@immich.app', password: 'Immich123' }; const loginDto = { email: 'test@immich.app', password: 'Immich123' };
await api.userApi.create(server, accessToken, { ...loginDto, firstName: 'test', lastName: 'test' }); await api.userApi.create(server, accessToken, { ...loginDto, name: 'test' });
const { accessToken: userAccessToken } = await api.authApi.login(server, loginDto); const { accessToken: userAccessToken } = await api.authApi.login(server, loginDto);
const { status, body } = await request(server) const { status, body } = await request(server)
.get('/server-info/statistics') .get('/server-info/statistics')
@ -132,9 +132,8 @@ describe(`${ServerInfoController.name} (e2e)`, () => {
{ {
photos: 0, photos: 0,
usage: 0, usage: 0,
userFirstName: 'Immich', userName: 'Immich Admin',
userId: loginResponse.userId, userId: loginResponse.userId,
userLastName: 'Admin',
videos: 0, videos: 0,
}, },
], ],

View File

@ -11,8 +11,7 @@ import request from 'supertest';
const user1Dto = { const user1Dto = {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}; };
describe(`${PartnerController.name} (e2e)`, () => { describe(`${PartnerController.name} (e2e)`, () => {

View File

@ -64,8 +64,7 @@ describe(`${SystemConfigController.name} (e2e)`, () => {
const credentials = { email: 'user1@immich.app', password: 'Password123' }; const credentials = { email: 'user1@immich.app', password: 'Password123' };
await api.userApi.create(server, admin.accessToken, { await api.userApi.create(server, admin.accessToken, {
...credentials, ...credentials,
firstName: 'User 1', name: 'User 1',
lastName: 'Test',
}); });
const { accessToken } = await api.authApi.login(server, credentials); const { accessToken } = await api.authApi.login(server, credentials);
const { status, body } = await request(server) const { status, body } = await request(server)

View File

@ -59,8 +59,7 @@ describe(`${UserController.name}`, () => {
const user1 = await api.userApi.create(server, accessToken, { const user1 = await api.userApi.create(server, accessToken, {
email: `user1@immich.app`, email: `user1@immich.app`,
password: 'Password123', password: 'Password123',
firstName: `User 1`, name: `User 1`,
lastName: 'Test',
}); });
await api.userApi.delete(server, accessToken, user1.id); await api.userApi.delete(server, accessToken, user1.id);
@ -78,8 +77,7 @@ describe(`${UserController.name}`, () => {
const user1 = await api.userApi.create(server, accessToken, { const user1 = await api.userApi.create(server, accessToken, {
email: `user1@immich.app`, email: `user1@immich.app`,
password: 'Password123', password: 'Password123',
firstName: `User 1`, name: `User 1`,
lastName: 'Test',
}); });
await api.userApi.delete(server, accessToken, user1.id); await api.userApi.delete(server, accessToken, user1.id);
@ -149,8 +147,7 @@ describe(`${UserController.name}`, () => {
isAdmin: true, isAdmin: true,
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'Immich', name: 'Immich',
lastName: 'User',
}) })
.set('Authorization', `Bearer ${accessToken}`); .set('Authorization', `Bearer ${accessToken}`);
expect(body).toMatchObject({ expect(body).toMatchObject({
@ -167,8 +164,7 @@ describe(`${UserController.name}`, () => {
.send({ .send({
email: 'no-memories@immich.app', email: 'no-memories@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'No Memories', name: 'No Memories',
lastName: 'User',
memoriesEnabled: false, memoriesEnabled: false,
}) })
.set('Authorization', `Bearer ${accessToken}`); .set('Authorization', `Bearer ${accessToken}`);
@ -186,8 +182,7 @@ describe(`${UserController.name}`, () => {
beforeEach(async () => { beforeEach(async () => {
userToDelete = await api.userApi.create(server, accessToken, { userToDelete = await api.userApi.create(server, accessToken, {
email: userStub.user1.email, email: userStub.user1.email,
firstName: userStub.user1.firstName, name: userStub.user1.name,
lastName: userStub.user1.lastName,
password: 'superSecurePassword', password: 'superSecurePassword',
}); });
}); });
@ -246,8 +241,7 @@ describe(`${UserController.name}`, () => {
const user = await api.userApi.create(server, accessToken, { const user = await api.userApi.create(server, accessToken, {
email: 'user1@immich.app', email: 'user1@immich.app',
password: 'Password123', password: 'Password123',
firstName: 'Immich', name: 'Immich User',
lastName: 'User',
}); });
const { status, body } = await request(server) const { status, body } = await request(server)
@ -284,15 +278,13 @@ describe(`${UserController.name}`, () => {
const before = await api.userApi.get(server, accessToken, loginResponse.userId); const before = await api.userApi.get(server, accessToken, loginResponse.userId);
const after = await api.userApi.update(server, accessToken, { const after = await api.userApi.update(server, accessToken, {
id: before.id, id: before.id,
firstName: 'First Name', name: 'Name',
lastName: 'Last Name',
}); });
expect(after).toEqual({ expect(after).toEqual({
...before, ...before,
updatedAt: expect.any(String), updatedAt: expect.any(String),
firstName: 'First Name', name: 'Name',
lastName: 'Last Name',
}); });
expect(before.updatedAt).not.toEqual(after.updatedAt); expect(before.updatedAt).not.toEqual(after.updatedAt);
}); });

View File

@ -1,8 +1,7 @@
import { AuthUserDto } from '@app/domain'; import { AuthUserDto } from '@app/domain';
export const adminSignupStub = { export const adminSignupStub = {
firstName: 'Immich', name: 'Immich Admin',
lastName: 'Admin',
email: 'admin@immich.app', email: 'admin@immich.app',
password: 'Password123', password: 'Password123',
}; };
@ -103,9 +102,8 @@ export const loginResponseStub = {
admin: { admin: {
response: { response: {
accessToken: expect.any(String), accessToken: expect.any(String),
firstName: 'Immich', name: 'Immich Admin',
isAdmin: true, isAdmin: true,
lastName: 'Admin',
profileImagePath: '', profileImagePath: '',
shouldChangePassword: true, shouldChangePassword: true,
userEmail: 'admin@immich.app', userEmail: 'admin@immich.app',
@ -117,8 +115,7 @@ export const loginResponseStub = {
accessToken: 'cmFuZG9tLWJ5dGVz', accessToken: 'cmFuZG9tLWJ5dGVz',
userId: 'user-id', userId: 'user-id',
userEmail: 'immich@test.com', userEmail: 'immich@test.com',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
profileImagePath: '', profileImagePath: '',
isAdmin: false, isAdmin: false,
shouldChangePassword: false, shouldChangePassword: false,
@ -133,8 +130,7 @@ export const loginResponseStub = {
accessToken: 'cmFuZG9tLWJ5dGVz', accessToken: 'cmFuZG9tLWJ5dGVz',
userId: 'user-id', userId: 'user-id',
userEmail: 'immich@test.com', userEmail: 'immich@test.com',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
profileImagePath: '', profileImagePath: '',
isAdmin: false, isAdmin: false,
shouldChangePassword: false, shouldChangePassword: false,
@ -149,8 +145,7 @@ export const loginResponseStub = {
accessToken: 'cmFuZG9tLWJ5dGVz', accessToken: 'cmFuZG9tLWJ5dGVz',
userId: 'user-id', userId: 'user-id',
userEmail: 'immich@test.com', userEmail: 'immich@test.com',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
profileImagePath: '', profileImagePath: '',
isAdmin: false, isAdmin: false,
shouldChangePassword: false, shouldChangePassword: false,

View File

@ -5,8 +5,7 @@ export const userStub = {
admin: Object.freeze<UserEntity>({ admin: Object.freeze<UserEntity>({
...authStub.admin, ...authStub.admin,
password: 'admin_password', password: 'admin_password',
firstName: 'admin_first_name', name: 'admin_name',
lastName: 'admin_last_name',
storageLabel: 'admin', storageLabel: 'admin',
externalPath: null, externalPath: null,
oauthId: '', oauthId: '',
@ -22,8 +21,7 @@ export const userStub = {
user1: Object.freeze<UserEntity>({ user1: Object.freeze<UserEntity>({
...authStub.user1, ...authStub.user1,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: null, storageLabel: null,
externalPath: null, externalPath: null,
oauthId: '', oauthId: '',
@ -39,8 +37,7 @@ export const userStub = {
user2: Object.freeze<UserEntity>({ user2: Object.freeze<UserEntity>({
...authStub.user2, ...authStub.user2,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: null, storageLabel: null,
externalPath: null, externalPath: null,
oauthId: '', oauthId: '',
@ -56,8 +53,7 @@ export const userStub = {
storageLabel: Object.freeze<UserEntity>({ storageLabel: Object.freeze<UserEntity>({
...authStub.user1, ...authStub.user1,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: 'label-1', storageLabel: 'label-1',
externalPath: null, externalPath: null,
oauthId: '', oauthId: '',
@ -73,8 +69,7 @@ export const userStub = {
externalPath1: Object.freeze<UserEntity>({ externalPath1: Object.freeze<UserEntity>({
...authStub.user1, ...authStub.user1,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: 'label-1', storageLabel: 'label-1',
externalPath: '/data/user1', externalPath: '/data/user1',
oauthId: '', oauthId: '',
@ -90,8 +85,7 @@ export const userStub = {
externalPath2: Object.freeze<UserEntity>({ externalPath2: Object.freeze<UserEntity>({
...authStub.user1, ...authStub.user1,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: 'label-1', storageLabel: 'label-1',
externalPath: '/data/user2', externalPath: '/data/user2',
oauthId: '', oauthId: '',
@ -107,8 +101,7 @@ export const userStub = {
profilePath: Object.freeze<UserEntity>({ profilePath: Object.freeze<UserEntity>({
...authStub.user1, ...authStub.user1,
password: 'immich_password', password: 'immich_password',
firstName: 'immich_first_name', name: 'immich_name',
lastName: 'immich_last_name',
storageLabel: 'label-1', storageLabel: 'label-1',
externalPath: null, externalPath: null,
oauthId: '', oauthId: '',

View File

@ -1341,24 +1341,18 @@ export interface CreateUserDto {
* @memberof CreateUserDto * @memberof CreateUserDto
*/ */
'externalPath'?: string | null; 'externalPath'?: string | null;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'firstName': string;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof CreateUserDto * @memberof CreateUserDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof CreateUserDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -2137,12 +2131,6 @@ export interface LoginResponseDto {
* @memberof LoginResponseDto * @memberof LoginResponseDto
*/ */
'accessToken': string; 'accessToken': string;
/**
*
* @type {string}
* @memberof LoginResponseDto
*/
'firstName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
@ -2154,7 +2142,7 @@ export interface LoginResponseDto {
* @type {string} * @type {string}
* @memberof LoginResponseDto * @memberof LoginResponseDto
*/ */
'lastName': string; 'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -2391,12 +2379,6 @@ export interface PartnerResponseDto {
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'externalPath': string | null; 'externalPath': string | null;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -2415,18 +2397,18 @@ export interface PartnerResponseDto {
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'isAdmin': boolean; 'isAdmin': boolean;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof PartnerResponseDto * @memberof PartnerResponseDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof PartnerResponseDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -3431,13 +3413,7 @@ export interface SignUpDto {
* @type {string} * @type {string}
* @memberof SignUpDto * @memberof SignUpDto
*/ */
'firstName': string; 'name': string;
/**
*
* @type {string}
* @memberof SignUpDto
*/
'lastName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4380,12 +4356,6 @@ export interface UpdateUserDto {
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'externalPath'?: string; 'externalPath'?: string;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'firstName'?: string;
/** /**
* *
* @type {string} * @type {string}
@ -4398,18 +4368,18 @@ export interface UpdateUserDto {
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'isAdmin'?: boolean; 'isAdmin'?: boolean;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'lastName'?: string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof UpdateUserDto * @memberof UpdateUserDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof UpdateUserDto
*/
'name'?: string;
/** /**
* *
* @type {string} * @type {string}
@ -4447,12 +4417,6 @@ export interface UsageByUserDto {
* @memberof UsageByUserDto * @memberof UsageByUserDto
*/ */
'usage': number; 'usage': number;
/**
*
* @type {string}
* @memberof UsageByUserDto
*/
'userFirstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4464,7 +4428,7 @@ export interface UsageByUserDto {
* @type {string} * @type {string}
* @memberof UsageByUserDto * @memberof UsageByUserDto
*/ */
'userLastName': string; 'userName': string;
/** /**
* *
* @type {number} * @type {number}
@ -4484,12 +4448,6 @@ export interface UserDto {
* @memberof UserDto * @memberof UserDto
*/ */
'email': string; 'email': string;
/**
*
* @type {string}
* @memberof UserDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4501,7 +4459,7 @@ export interface UserDto {
* @type {string} * @type {string}
* @memberof UserDto * @memberof UserDto
*/ */
'lastName': string; 'name': string;
/** /**
* *
* @type {string} * @type {string}
@ -4539,12 +4497,6 @@ export interface UserResponseDto {
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'externalPath': string | null; 'externalPath': string | null;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'firstName': string;
/** /**
* *
* @type {string} * @type {string}
@ -4557,18 +4509,18 @@ export interface UserResponseDto {
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'isAdmin': boolean; 'isAdmin': boolean;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'lastName': string;
/** /**
* *
* @type {boolean} * @type {boolean}
* @memberof UserResponseDto * @memberof UserResponseDto
*/ */
'memoriesEnabled'?: boolean; 'memoriesEnabled'?: boolean;
/**
*
* @type {string}
* @memberof UserResponseDto
*/
'name': string;
/** /**
* *
* @type {string} * @type {string}

View File

@ -27,7 +27,7 @@
<svelte:fragment slot="prompt"> <svelte:fragment slot="prompt">
<div class="flex flex-col gap-4"> <div class="flex flex-col gap-4">
<p> <p>
<b>{user.firstName} {user.lastName}</b>'s account and assets will be permanently deleted after 7 days. <b>{user.name}</b>'s account and assets will be permanently deleted after 7 days.
</p> </p>
<p>Are you sure you want to continue?</p> <p>Are you sure you want to continue?</p>
</div> </div>

View File

@ -16,6 +16,6 @@
<ConfirmDialogue title="Restore User" confirmText="Continue" confirmColor="green" on:confirm={restoreUser} on:cancel> <ConfirmDialogue title="Restore User" confirmText="Continue" confirmColor="green" on:confirm={restoreUser} on:cancel>
<svelte:fragment slot="prompt"> <svelte:fragment slot="prompt">
<p><b>{user.firstName} {user.lastName}</b>'s account will be restored.</p> <p><b>{user.name}</b>'s account will be restored.</p>
</svelte:fragment> </svelte:fragment>
</ConfirmDialogue> </ConfirmDialogue>

View File

@ -96,7 +96,7 @@
<tr <tr
class="flex h-[50px] w-full place-items-center text-center odd:bg-immich-gray even:bg-immich-bg odd:dark:bg-immich-dark-gray/75 even:dark:bg-immich-dark-gray/50" class="flex h-[50px] w-full place-items-center text-center odd:bg-immich-gray even:bg-immich-bg odd:dark:bg-immich-dark-gray/75 even:dark:bg-immich-dark-gray/50"
> >
<td class="w-1/4 text-ellipsis px-2 text-sm">{user.userFirstName} {user.userLastName}</td> <td class="w-1/4 text-ellipsis px-2 text-sm">{user.userName}</td>
<td class="w-1/4 text-ellipsis px-2 text-sm">{user.photos.toLocaleString($locale)}</td> <td class="w-1/4 text-ellipsis px-2 text-sm">{user.photos.toLocaleString($locale)}</td>
<td class="w-1/4 text-ellipsis px-2 text-sm">{user.videos.toLocaleString($locale)}</td> <td class="w-1/4 text-ellipsis px-2 text-sm">{user.videos.toLocaleString($locale)}</td>
<td class="w-1/4 text-ellipsis px-2 text-sm">{asByteUnitString(user.usage, $locale)}</td> <td class="w-1/4 text-ellipsis px-2 text-sm">{asByteUnitString(user.usage, $locale)}</td>

View File

@ -123,8 +123,7 @@
<p>Owned</p> <p>Owned</p>
{:else} {:else}
<p> <p>
Shared by {albumOwner.firstName} Shared by {albumOwner.name}
{albumOwner.lastName}
</p> </p>
{/if} {/if}
{/await} {/await}

View File

@ -56,7 +56,7 @@
<div> <div>
<UserAvatar {user} size="md" /> <UserAvatar {user} size="md" />
</div> </div>
<div class="w-full">{`${user.firstName} ${user.lastName}`}</div> <div class="w-full">{user.name}</div>
<div>Owner</div> <div>Owner</div>
</div> </div>
{#each album.sharedUsers as user (user.id)} {#each album.sharedUsers as user (user.id)}
@ -64,7 +64,7 @@
<div> <div>
<UserAvatar {user} size="md" /> <UserAvatar {user} size="md" />
</div> </div>
<div class="w-full">{`${user.firstName} ${user.lastName}`}</div> <div class="w-full">{user.name}</div>
</div> </div>
{/each} {/each}
</div> </div>

View File

@ -56,7 +56,7 @@
try { try {
await api.albumApi.removeUserFromAlbum({ id: album.id, userId }); await api.albumApi.removeUserFromAlbum({ id: album.id, userId });
dispatch('remove', userId); dispatch('remove', userId);
const message = userId === 'me' ? `Left ${album.albumName}` : `Removed ${selectedRemoveUser.firstName}`; const message = userId === 'me' ? `Left ${album.albumName}` : `Removed ${selectedRemoveUser.name}`;
notificationController.show({ type: NotificationType.Info, message }); notificationController.show({ type: NotificationType.Info, message });
} catch (e) { } catch (e) {
handleError(e, 'Unable to remove user'); handleError(e, 'Unable to remove user');
@ -78,7 +78,7 @@
<div class="flex w-full place-items-center justify-between gap-4 p-5"> <div class="flex w-full place-items-center justify-between gap-4 p-5">
<div class="flex place-items-center gap-4"> <div class="flex place-items-center gap-4">
<UserAvatar user={album.owner} size="md" autoColor /> <UserAvatar user={album.owner} size="md" autoColor />
<p class="text-sm font-medium">{album.owner.firstName} {album.owner.lastName}</p> <p class="text-sm font-medium">{album.owner.name}</p>
</div> </div>
<div id="icon-{album.owner.id}" class="flex place-items-center"> <div id="icon-{album.owner.id}" class="flex place-items-center">
@ -91,7 +91,7 @@
> >
<div class="flex place-items-center gap-4"> <div class="flex place-items-center gap-4">
<UserAvatar {user} size="md" autoColor /> <UserAvatar {user} size="md" autoColor />
<p class="text-sm font-medium">{user.firstName} {user.lastName}</p> <p class="text-sm font-medium">{user.name}</p>
</div> </div>
<div id="icon-{user.id}" class="flex place-items-center"> <div id="icon-{user.id}" class="flex place-items-center">
@ -138,7 +138,7 @@
{#if selectedRemoveUser && selectedRemoveUser?.id !== currentUser?.id} {#if selectedRemoveUser && selectedRemoveUser?.id !== currentUser?.id}
<ConfirmDialogue <ConfirmDialogue
title="Remove User?" title="Remove User?"
prompt="Are you sure you want to remove {selectedRemoveUser.firstName} {selectedRemoveUser.lastName}" prompt="Are you sure you want to remove {selectedRemoveUser.name}"
confirmText="Remove" confirmText="Remove"
on:confirm={handleRemoveUser} on:confirm={handleRemoveUser}
on:cancel={() => (selectedRemoveUser = null)} on:cancel={() => (selectedRemoveUser = null)}

View File

@ -72,7 +72,7 @@
class="flex place-items-center gap-1 rounded-full border border-gray-400 p-1 transition-colors hover:bg-gray-200 dark:hover:bg-gray-700" class="flex place-items-center gap-1 rounded-full border border-gray-400 p-1 transition-colors hover:bg-gray-200 dark:hover:bg-gray-700"
> >
<UserAvatar {user} size="sm" autoColor /> <UserAvatar {user} size="sm" autoColor />
<p class="text-xs font-medium">{user.firstName} {user.lastName}</p> <p class="text-xs font-medium">{user.name}</p>
</button> </button>
{/key} {/key}
{/each} {/each}
@ -99,8 +99,7 @@
<div class="text-left"> <div class="text-left">
<p class="text-immich-fg dark:text-immich-dark-fg"> <p class="text-immich-fg dark:text-immich-dark-fg">
{user.firstName} {user.name}
{user.lastName}
</p> </p>
<p class="text-xs"> <p class="text-xs">
{user.email} {user.email}

View File

@ -221,13 +221,8 @@
<div class="flex p-3 mx-2 mt-3 rounded-full gap-4 items-center text-sm"> <div class="flex p-3 mx-2 mt-3 rounded-full gap-4 items-center text-sm">
<div class="text-red-600"><Icon path={mdiHeart} size={20} /></div> <div class="text-red-600"><Icon path={mdiHeart} size={20} /></div>
<div <div class="w-full" title={`${reaction.user.name} (${reaction.user.email})`}>
class="w-full" {`${reaction.user.name} liked ${assetType ? `this ${getAssetType(assetType).toLowerCase()}` : 'it'}`}
title={`${reaction.user.firstName} ${reaction.user.lastName} (${reaction.user.email})`}
>
{`${reaction.user.firstName} ${reaction.user.lastName} liked ${
assetType ? `this ${getAssetType(assetType).toLowerCase()}` : 'it'
}`}
</div> </div>
{#if assetId === undefined && reaction.assetId} {#if assetId === undefined && reaction.assetId}
<div class="aspect-square w-[75px] h-[75px]"> <div class="aspect-square w-[75px] h-[75px]">

View File

@ -315,8 +315,7 @@
<div class="mb-auto mt-auto"> <div class="mb-auto mt-auto">
<p> <p>
{asset.owner.firstName} {asset.owner.name}
{asset.owner.lastName}
</p> </p>
</div> </div>
</div> </div>

View File

@ -27,15 +27,13 @@
const email = form.get('email'); const email = form.get('email');
const password = form.get('password'); const password = form.get('password');
const firstName = form.get('firstName'); const name = form.get('name');
const lastName = form.get('lastName');
const { status } = await api.authenticationApi.signUpAdmin({ const { status } = await api.authenticationApi.signUpAdmin({
signUpDto: { signUpDto: {
email: String(email), email: String(email),
password: String(password), password: String(password),
firstName: String(firstName), name: String(name),
lastName: String(lastName),
}, },
}); });
@ -83,13 +81,8 @@
</div> </div>
<div class="flex flex-col gap-2"> <div class="flex flex-col gap-2">
<label class="immich-form-label" for="firstName">First Name</label> <label class="immich-form-label" for="name">Name</label>
<input class="immich-form-input" id="firstName" name="firstName" type="text" autocomplete="given-name" required /> <input class="immich-form-input" id="name" name="name" type="text" autocomplete="name" required />
</div>
<div class="flex flex-col gap-2">
<label class="immich-form-label" for="lastName">Last Name</label>
<input class="immich-form-input" id="lastName" name="lastName" type="text" autocomplete="family-name" required />
</div> </div>
{#if error} {#if error}

View File

@ -38,16 +38,14 @@
const email = form.get('email'); const email = form.get('email');
const password = form.get('password'); const password = form.get('password');
const firstName = form.get('firstName'); const name = form.get('name');
const lastName = form.get('lastName');
try { try {
const { status } = await api.userApi.createUser({ const { status } = await api.userApi.createUser({
createUserDto: { createUserDto: {
email: String(email), email: String(email),
password: String(password), password: String(password),
firstName: String(firstName), name: String(name),
lastName: String(lastName),
}, },
}); });
@ -112,13 +110,8 @@
</div> </div>
<div class="m-4 flex flex-col gap-2"> <div class="m-4 flex flex-col gap-2">
<label class="immich-form-label" for="firstName">First Name</label> <label class="immich-form-label" for="name">Name</label>
<input class="immich-form-input" id="firstName" name="firstName" type="text" required /> <input class="immich-form-input" id="name" name="name" type="text" required />
</div>
<div class="m-4 flex flex-col gap-2">
<label class="immich-form-label" for="lastName">Last Name</label>
<input class="immich-form-input" id="lastName" name="lastName" type="text" required />
</div> </div>
{#if error} {#if error}

View File

@ -20,13 +20,12 @@
const editUser = async () => { const editUser = async () => {
try { try {
const { id, email, firstName, lastName, storageLabel, externalPath } = user; const { id, email, name, storageLabel, externalPath } = user;
const { status } = await api.userApi.updateUser({ const { status } = await api.userApi.updateUser({
updateUserDto: { updateUserDto: {
id, id,
email, email,
firstName, name,
lastName,
storageLabel: storageLabel || '', storageLabel: storageLabel || '',
externalPath: externalPath || '', externalPath: externalPath || '',
}, },
@ -84,20 +83,8 @@
</div> </div>
<div class="m-4 flex flex-col gap-2"> <div class="m-4 flex flex-col gap-2">
<label class="immich-form-label" for="firstName">First Name</label> <label class="immich-form-label" for="name">Name</label>
<input <input class="immich-form-input" id="name" name="name" type="text" required bind:value={user.name} />
class="immich-form-input"
id="firstName"
name="firstName"
type="text"
required
bind:value={user.firstName}
/>
</div>
<div class="m-4 flex flex-col gap-2">
<label class="immich-form-label" for="lastName">Last Name</label>
<input class="immich-form-input" id="lastName" name="lastName" type="text" required bind:value={user.lastName} />
</div> </div>
<div class="m-4 flex flex-col gap-2"> <div class="m-4 flex flex-col gap-2">
@ -161,7 +148,7 @@
> >
<svelte:fragment slot="prompt"> <svelte:fragment slot="prompt">
<p> <p>
Are you sure you want to reset <b>{user.firstName} {user.lastName}</b>'s password? Are you sure you want to reset <b>{user.name}</b>'s password?
</p> </p>
</svelte:fragment> </svelte:fragment>
</ConfirmDialogue> </ConfirmDialogue>

View File

@ -26,8 +26,7 @@
<div> <div>
<p class="text-center text-lg font-medium text-immich-primary dark:text-immich-dark-primary"> <p class="text-center text-lg font-medium text-immich-primary dark:text-immich-dark-primary">
{user.firstName} {user.name}
{user.lastName}
</p> </p>
<p class="text-sm text-gray-500 dark:text-immich-dark-fg">{user.email}</p> <p class="text-sm text-gray-500 dark:text-immich-dark-fg">{user.email}</p>
</div> </div>

View File

@ -133,7 +133,7 @@
out:fade={{ delay: 200, duration: 150 }} out:fade={{ delay: 200, duration: 150 }}
class="absolute -bottom-12 right-5 rounded-md border bg-gray-500 p-2 text-[12px] text-gray-100 shadow-md dark:border-immich-dark-gray dark:bg-immich-dark-gray" class="absolute -bottom-12 right-5 rounded-md border bg-gray-500 p-2 text-[12px] text-gray-100 shadow-md dark:border-immich-dark-gray dark:bg-immich-dark-gray"
> >
<p>{user.firstName} {user.lastName}</p> <p>{user.name}</p>
<p>{user.email}</p> <p>{user.email}</p>
</div> </div>
{/if} {/if}

View File

@ -9,8 +9,7 @@
interface User { interface User {
id: string; id: string;
firstName: string; name: string;
lastName: string;
email: string; email: string;
profileImagePath: string; profileImagePath: string;
} }
@ -51,7 +50,7 @@
$: colorClass = colorClasses[autoColor ? getUserColor() : color]; $: colorClass = colorClasses[autoColor ? getUserColor() : color];
$: sizeClass = sizeClasses[size]; $: sizeClass = sizeClasses[size];
$: title = `${user.firstName} ${user.lastName} (${user.email})`; $: title = `${user.name} (${user.email})`;
$: interactiveClass = interactive $: interactiveClass = interactive
? 'border-2 border-immich-primary hover:border-immich-dark-primary dark:hover:border-immich-primary dark:border-immich-dark-primary transition-colors' ? 'border-2 border-immich-primary hover:border-immich-dark-primary dark:hover:border-immich-primary dark:border-immich-dark-primary transition-colors'
: ''; : '';
@ -82,7 +81,7 @@
class:font-medium={!autoColor} class:font-medium={!autoColor}
class:font-semibold={autoColor} class:font-semibold={autoColor}
> >
{((user.firstName[0] || '') + (user.lastName[0] || '')).toUpperCase()} {(user.name[0] || '').toUpperCase()}
</span> </span>
{/if} {/if}
</figure> </figure>

View File

@ -61,8 +61,7 @@
<div class="text-left"> <div class="text-left">
<p class="text-immich-fg dark:text-immich-dark-fg"> <p class="text-immich-fg dark:text-immich-dark-fg">
{user.firstName} {user.name}
{user.lastName}
</p> </p>
<p class="text-xs"> <p class="text-xs">
{user.email} {user.email}

View File

@ -116,8 +116,7 @@
<UserAvatar user={partner.user} size="md" autoColor /> <UserAvatar user={partner.user} size="md" autoColor />
<div class="text-left"> <div class="text-left">
<p class="text-immich-fg dark:text-immich-dark-fg"> <p class="text-immich-fg dark:text-immich-dark-fg">
{partner.user.firstName} {partner.user.name}
{partner.user.lastName}
</p> </p>
<p class="text-xs text-immich-fg/75 dark:text-immich-dark-fg/75"> <p class="text-xs text-immich-fg/75 dark:text-immich-dark-fg/75">
{partner.user.email} {partner.user.email}
@ -139,8 +138,8 @@
<!-- I am sharing my assets with this user --> <!-- I am sharing my assets with this user -->
{#if partner.sharedByMe} {#if partner.sharedByMe}
<hr class="my-4 border border-gray-200 dark:border-gray-700" /> <hr class="my-4 border border-gray-200 dark:border-gray-700" />
<p class="text-xs font-medium my-4">SHARED WITH {partner.user.firstName.toUpperCase()}</p> <p class="text-xs font-medium my-4">SHARED WITH {partner.user.name.toUpperCase()}</p>
<p class="text-md">{partner.user.firstName} can access</p> <p class="text-md">{partner.user.name} can access</p>
<ul class="text-sm"> <ul class="text-sm">
<li class="flex gap-2 place-items-center py-1 mt-2"> <li class="flex gap-2 place-items-center py-1 mt-2">
<Icon path={mdiCheck} /> All your photos and videos except those in Archived and Deleted <Icon path={mdiCheck} /> All your photos and videos except those in Archived and Deleted
@ -154,7 +153,7 @@
<!-- this user is sharing assets with me --> <!-- this user is sharing assets with me -->
{#if partner.sharedWithMe} {#if partner.sharedWithMe}
<hr class="my-4 border border-gray-200 dark:border-gray-700" /> <hr class="my-4 border border-gray-200 dark:border-gray-700" />
<p class="text-xs font-medium my-4">PHOTOS FROM {partner.user.firstName.toUpperCase()}</p> <p class="text-xs font-medium my-4">PHOTOS FROM {partner.user.name.toUpperCase()}</p>
<SettingSwitch <SettingSwitch
title="Show in timeline" title="Show in timeline"
subtitle="Show photos and videos from this user in your timeline" subtitle="Show photos and videos from this user in your timeline"
@ -183,7 +182,7 @@
{#if removePartner} {#if removePartner}
<ConfirmDialogue <ConfirmDialogue
title="Stop sharing your photos?" title="Stop sharing your photos?"
prompt="{removePartner.firstName} will no longer be able to access your photos." prompt="{removePartner.name} will no longer be able to access your photos."
on:cancel={() => (removePartner = null)} on:cancel={() => (removePartner = null)}
on:confirm={() => handleRemovePartner()} on:confirm={() => handleRemovePartner()}
/> />

View File

@ -17,8 +17,7 @@
updateUserDto: { updateUserDto: {
id: user.id, id: user.id,
email: user.email, email: user.email,
firstName: user.firstName, name: user.name,
lastName: user.lastName,
}, },
}); });
@ -47,19 +46,7 @@
<SettingInputField inputType={SettingInputFieldType.EMAIL} label="EMAIL" bind:value={user.email} /> <SettingInputField inputType={SettingInputFieldType.EMAIL} label="EMAIL" bind:value={user.email} />
<SettingInputField <SettingInputField inputType={SettingInputFieldType.TEXT} label="NAME" bind:value={user.name} required={true} />
inputType={SettingInputFieldType.TEXT}
label="FIRST NAME"
bind:value={user.firstName}
required={true}
/>
<SettingInputField
inputType={SettingInputFieldType.TEXT}
label="LAST NAME"
bind:value={user.lastName}
required={true}
/>
<SettingInputField <SettingInputField
inputType={SettingInputFieldType.TEXT} inputType={SettingInputFieldType.TEXT}

View File

@ -39,8 +39,7 @@
<ControlAppBar showBackButton backIcon={mdiArrowLeft} on:close-button-click={() => goto(AppRoute.SHARING)}> <ControlAppBar showBackButton backIcon={mdiArrowLeft} on:close-button-click={() => goto(AppRoute.SHARING)}>
<svelte:fragment slot="leading"> <svelte:fragment slot="leading">
<p class="whitespace-nowrap text-immich-fg dark:text-immich-dark-fg"> <p class="whitespace-nowrap text-immich-fg dark:text-immich-dark-fg">
{data.partner.firstName} {data.partner.name}'s photos
{data.partner.lastName}'s photos
</p> </p>
</svelte:fragment> </svelte:fragment>
</ControlAppBar> </ControlAppBar>

View File

@ -72,8 +72,7 @@
<UserAvatar user={partner} size="lg" autoColor /> <UserAvatar user={partner} size="lg" autoColor />
<div class="text-left"> <div class="text-left">
<p class="text-immich-fg dark:text-immich-dark-fg"> <p class="text-immich-fg dark:text-immich-dark-fg">
{partner.firstName} {partner.name}
{partner.lastName}
</p> </p>
<p class="text-xs text-immich-fg/75 dark:text-immich-dark-fg/75"> <p class="text-xs text-immich-fg/75 dark:text-immich-dark-fg/75">
{partner.email} {partner.email}

View File

@ -168,8 +168,7 @@
> >
<tr class="flex w-full place-items-center"> <tr class="flex w-full place-items-center">
<th class="w-4/12 text-center text-sm font-medium">Email</th> <th class="w-4/12 text-center text-sm font-medium">Email</th>
<th class="w-2/12 text-center text-sm font-medium">First name</th> <th class="w-2/12 text-center text-sm font-medium">Name</th>
<th class="w-2/12 text-center text-sm font-medium">Last name</th>
<th class="w-2/12 text-center text-sm font-medium">Can import</th> <th class="w-2/12 text-center text-sm font-medium">Can import</th>
<th class="w-2/12 text-center text-sm font-medium">Action</th> <th class="w-2/12 text-center text-sm font-medium">Action</th>
</tr> </tr>
@ -187,8 +186,7 @@
}`} }`}
> >
<td class="w-4/12 text-ellipsis break-all px-2 text-sm">{user.email}</td> <td class="w-4/12 text-ellipsis break-all px-2 text-sm">{user.email}</td>
<td class="w-2/12 text-ellipsis break-all px-2 text-sm">{user.firstName}</td> <td class="w-2/12 text-ellipsis break-all px-2 text-sm">{user.name}</td>
<td class="w-2/12 text-ellipsis break-all px-2 text-sm">{user.lastName}</td>
<td class="w-2/12 text-ellipsis break-all px-2 text-sm"> <td class="w-2/12 text-ellipsis break-all px-2 text-sm">
<div class="container mx-auto flex flex-wrap justify-center"> <div class="container mx-auto flex flex-wrap justify-center">
{#if user.externalPath} {#if user.externalPath}
@ -253,7 +251,7 @@
: 'bg-immich-bg dark:bg-immich-dark-gray/50' : 'bg-immich-bg dark:bg-immich-dark-gray/50'
}`} }`}
> >
<td class="w-1/4 text-ellipsis break-words px-2 text-sm">{user.firstName} {user.lastName}</td> <td class="w-1/4 text-ellipsis break-words px-2 text-sm">{user.name}</td>
<td class="w-1/2 text-ellipsis break-all px-2 text-sm">{user.email}</td> <td class="w-1/2 text-ellipsis break-all px-2 text-sm">{user.email}</td>
<td class="w-1/4 text-ellipsis px-2 text-sm"> <td class="w-1/4 text-ellipsis px-2 text-sm">
{#if !isDeleted(user)} {#if !isDeleted(user)}

View File

@ -16,8 +16,7 @@
<FullscreenContainer title={data.meta.title}> <FullscreenContainer title={data.meta.title}>
<p slot="message"> <p slot="message">
Hi {data.user.firstName} Hi {data.user.name} ({data.user.email}),
{data.user.lastName} ({data.user.email}),
<br /> <br />
<br /> <br />
This is either the first time you are signing into the system or a request has been made to change your password. Please This is either the first time you are signing into the system or a request has been made to change your password. Please

View File

@ -5,8 +5,7 @@ import { Sync } from 'factory.ts';
export const userFactory = Sync.makeFactory<UserResponseDto>({ export const userFactory = Sync.makeFactory<UserResponseDto>({
id: Sync.each(() => faker.datatype.uuid()), id: Sync.each(() => faker.datatype.uuid()),
email: Sync.each(() => faker.internet.email()), email: Sync.each(() => faker.internet.email()),
firstName: Sync.each(() => faker.name.firstName()), name: Sync.each(() => faker.name.fullName()),
lastName: Sync.each(() => faker.name.lastName()),
storageLabel: Sync.each(() => faker.random.alphaNumeric()), storageLabel: Sync.each(() => faker.random.alphaNumeric()),
externalPath: Sync.each(() => faker.random.alphaNumeric()), externalPath: Sync.each(() => faker.random.alphaNumeric()),
profileImagePath: '', profileImagePath: '',