refactor: user entity (#16655)

* refactor: user entity

* fix: add users to album & user profile url

* chore: rebase fixes

* generate files

* fix(mobile): timeline not reset on login

* fix: test stub

* refactor: rename user model (#16813)

* refactor: rename user model

* simplify import

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
Co-authored-by: Alex <alex.tran1502@gmail.com>

* chore: generate files

* fix: use getAllAccessible instead of getAll

---------

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
Co-authored-by: Alex <alex.tran1502@gmail.com>
This commit is contained in:
shenlong
2025-03-12 19:26:56 +05:30
committed by GitHub
parent a75718ce99
commit d1c8fe5303
82 changed files with 1039 additions and 947 deletions

View File

@@ -1,41 +1,42 @@
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/domain/models/store.model.dart';
import 'package:immich_mobile/domain/services/store.service.dart';
import 'package:immich_mobile/entities/album.entity.dart';
import 'package:immich_mobile/entities/asset.entity.dart';
import 'package:immich_mobile/interfaces/timeline.interface.dart';
import 'package:immich_mobile/interfaces/user.interface.dart';
import 'package:immich_mobile/providers/app_settings.provider.dart';
import 'package:immich_mobile/providers/infrastructure/store.provider.dart';
import 'package:immich_mobile/repositories/timeline.repository.dart';
import 'package:immich_mobile/repositories/user.repository.dart';
import 'package:immich_mobile/services/app_settings.service.dart';
import 'package:immich_mobile/widgets/asset_grid/asset_grid_data_structure.dart';
final timelineServiceProvider = Provider<TimelineService>((ref) {
return TimelineService(
ref.watch(timelineRepositoryProvider),
ref.watch(userRepositoryProvider),
ref.watch(appSettingsServiceProvider),
ref.watch(storeServiceProvider),
);
});
class TimelineService {
final ITimelineRepository _timelineRepository;
final IUserRepository _userRepository;
final AppSettingsService _appSettingsService;
final StoreService _storeService;
const TimelineService(
this._timelineRepository,
this._userRepository,
this._appSettingsService,
this._storeService,
);
Future<List<int>> getTimelineUserIds() async {
final me = await _userRepository.me();
return _timelineRepository.getTimelineUserIds(me.isarId);
final me = _storeService.get(StoreKey.currentUser);
return _timelineRepository.getTimelineUserIds(me.id);
}
Stream<List<int>> watchTimelineUserIds() async* {
final me = await _userRepository.me();
yield* _timelineRepository.watchTimelineUsers(me.isarId);
final me = _storeService.get(StoreKey.currentUser);
yield* _timelineRepository.watchTimelineUsers(me.id);
}
Stream<RenderList> watchHomeTimeline(int userId) {
@@ -50,15 +51,15 @@ class TimelineService {
}
Stream<RenderList> watchArchiveTimeline() async* {
final user = await _userRepository.me();
final user = _storeService.get(StoreKey.currentUser);
yield* _timelineRepository.watchArchiveTimeline(user.isarId);
yield* _timelineRepository.watchArchiveTimeline(user.id);
}
Stream<RenderList> watchFavoriteTimeline() async* {
final user = await _userRepository.me();
final user = _storeService.get(StoreKey.currentUser);
yield* _timelineRepository.watchFavoriteTimeline(user.isarId);
yield* _timelineRepository.watchFavoriteTimeline(user.id);
}
Stream<RenderList> watchAlbumTimeline(Album album) async* {
@@ -69,9 +70,9 @@ class TimelineService {
}
Stream<RenderList> watchTrashTimeline() async* {
final user = await _userRepository.me();
final user = _storeService.get(StoreKey.currentUser);
yield* _timelineRepository.watchTrashTimeline(user.isarId);
yield* _timelineRepository.watchTrashTimeline(user.id);
}
Stream<RenderList> watchAllVideosTimeline() {
@@ -96,9 +97,9 @@ class TimelineService {
}
Stream<RenderList> watchAssetSelectionTimeline() async* {
final user = await _userRepository.me();
final user = _storeService.get(StoreKey.currentUser);
yield* _timelineRepository.watchAssetSelectionTimeline(user.isarId);
yield* _timelineRepository.watchAssetSelectionTimeline(user.id);
}
GroupAssetsBy _getGroupByOption() {