immich/mobile/lib/modules/home/views/home_page.dart

107 lines
3.7 KiB
Dart
Raw Normal View History

2022-02-03 09:06:44 -07:00
import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/modules/home/providers/home_page_render_list_provider.dart';
2022-10-01 01:33:06 -07:00
import 'package:immich_mobile/modules/home/ui/asset_grid/immich_asset_grid.dart';
import 'package:immich_mobile/modules/home/ui/control_bottom_app_bar.dart';
2022-02-03 09:06:44 -07:00
import 'package:immich_mobile/modules/home/ui/immich_sliver_appbar.dart';
import 'package:immich_mobile/modules/home/ui/profile_drawer/profile_drawer.dart';
import 'package:immich_mobile/modules/settings/providers/app_settings.provider.dart';
import 'package:immich_mobile/modules/settings/services/app_settings.service.dart';
import 'package:immich_mobile/shared/providers/asset.provider.dart';
import 'package:immich_mobile/shared/providers/server_info.provider.dart';
import 'package:immich_mobile/shared/providers/websocket.provider.dart';
2022-10-06 13:41:56 -07:00
import 'package:immich_mobile/shared/services/share.service.dart';
import 'package:openapi/api.dart';
2022-02-03 09:06:44 -07:00
class HomePage extends HookConsumerWidget {
const HomePage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context, WidgetRef ref) {
final appSettingService = ref.watch(appSettingsServiceProvider);
var renderList = ref.watch(renderListProvider);
final multiselectEnabled = useState(false);
2022-10-06 13:41:56 -07:00
final selection = useState(<AssetResponseDto>{});
useEffect(
() {
ref.read(websocketProvider.notifier).connect();
ref.read(assetProvider.notifier).getAllAsset();
ref.watch(serverInfoProvider.notifier).getServerVersion();
return null;
},
[],
);
void reloadAllAsset() {
ref.read(assetProvider.notifier).getAllAsset();
}
2022-10-01 01:33:06 -07:00
Widget buildBody() {
2022-10-06 13:41:56 -07:00
void selectionListener(
bool multiselect, Set<AssetResponseDto> selectedAssets) {
multiselectEnabled.value = multiselect;
selection.value = selectedAssets;
2022-04-30 08:55:27 -07:00
}
2022-10-06 13:41:56 -07:00
void onShareAssets() {
ref.watch(shareServiceProvider).shareAssets(selection.value.toList());
2022-10-08 04:08:56 -07:00
multiselectEnabled.value = false;
2022-10-06 13:41:56 -07:00
}
void onDelete() {
ref.watch(assetProvider.notifier).deleteAssets(selection.value);
2022-10-08 04:08:56 -07:00
multiselectEnabled.value = false;
}
2022-02-03 21:18:21 -07:00
return SafeArea(
bottom: !multiselectEnabled.value,
top: !multiselectEnabled.value,
child: Stack(
children: [
CustomScrollView(
slivers: [
2022-10-06 13:41:56 -07:00
multiselectEnabled.value
? const SliverToBoxAdapter(
child: SizedBox(
height: 70,
child: null,
),
)
: ImmichSliverAppBar(
onPopBack: reloadAllAsset,
),
],
),
Padding(
padding: const EdgeInsets.only(top: 60.0, bottom: 0.0),
2022-10-01 01:33:06 -07:00
child: ImmichAssetGrid(
renderList: renderList,
assetsPerRow:
appSettingService.getSetting(AppSettingsEnum.tilesPerRow),
showStorageIndicator: appSettingService
.getSetting(AppSettingsEnum.storageIndicator),
listener: selectionListener,
2022-10-08 04:08:56 -07:00
selectionActive: multiselectEnabled.value,
2022-10-01 01:33:06 -07:00
),
),
if (multiselectEnabled.value) ...[
2022-10-06 13:41:56 -07:00
ControlBottomAppBar(
onShare: onShareAssets,
onDelete: onDelete,
),
],
],
),
);
2022-02-03 09:06:44 -07:00
}
return Scaffold(
drawer: const ProfileDrawer(),
2022-10-01 01:33:06 -07:00
body: buildBody(),
);
}
}