Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PE-6752: hide drives #1892

Merged
merged 25 commits into from
Oct 28, 2024
Merged
Show file tree
Hide file tree
Changes from 17 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
71ac336
hide drives + important fixes
thiagocarvalhodev Oct 10, 2024
3a902ac
fix tests
thiagocarvalhodev Oct 14, 2024
e868e51
Update side_bar.dart
thiagocarvalhodev Oct 15, 2024
a92d7a4
manifest preview and download
thiagocarvalhodev Oct 17, 2024
04ea46d
always show shared drives
thiagocarvalhodev Oct 21, 2024
4d44634
chore: remove commented code and prints
thiagocarvalhodev Oct 21, 2024
307d9c1
test(user prefs/hide)
thiagocarvalhodev Oct 22, 2024
630ca0c
fix(user prefs)
thiagocarvalhodev Oct 22, 2024
7dae599
fix hide icon and attach drives
thiagocarvalhodev Oct 22, 2024
fdcd613
Update hide_dialog.dart
thiagocarvalhodev Oct 22, 2024
d3f0cb6
Update drive_explorer_item_tile.dart
thiagocarvalhodev Oct 22, 2024
e5105a0
Update sync_repository.dart
thiagocarvalhodev Oct 22, 2024
9f8b2f0
remove feedback survey modal
thiagocarvalhodev Oct 22, 2024
87ebc4e
fix sync drives with hidden property
thiagocarvalhodev Oct 22, 2024
3b52208
clear all configs when logging out
thiagocarvalhodev Oct 22, 2024
abb5275
Update global_hide_bloc_test.dart
thiagocarvalhodev Oct 22, 2024
d84d6d9
Update user_preferences_repository_test.dart
thiagocarvalhodev Oct 22, 2024
48b6946
refactors(hide drive)
thiagocarvalhodev Oct 22, 2024
b0c7bf4
refactor(hide)
thiagocarvalhodev Oct 22, 2024
836bc7a
Update hide_bloc.dart
thiagocarvalhodev Oct 22, 2024
77ce82e
Update hide_bloc.dart
thiagocarvalhodev Oct 22, 2024
45a6f84
Update app_router_delegate.dart
thiagocarvalhodev Oct 22, 2024
14373a0
fix: missing hide button
thiagocarvalhodev Oct 28, 2024
8acbf55
fix(attach drives): dont ask for attach a drive logging the user out
thiagocarvalhodev Oct 28, 2024
9f47a53
Merge pull request #1904 from ardriveapp/PE-7037-missing-hide-show-hi…
thiagocarvalhodev Oct 28, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 8 additions & 7 deletions lib/app_shell.dart
Original file line number Diff line number Diff line change
Expand Up @@ -84,12 +84,12 @@ class AppShellState extends State<AppShell> {
}
}
},
builder: (context, syncState) => syncState is SyncInProgress
? Stack(
builder: (context, syncState) {
return Stack(children: [
scaffold,
if (syncState is SyncInProgress)
Stack(
children: [
AbsorbPointer(
child: scaffold,
),
SizedBox.expand(
child: Container(
color: Colors.black.withOpacity(0.5),
Expand Down Expand Up @@ -181,8 +181,9 @@ class AppShellState extends State<AppShell> {
),
),
],
)
: scaffold,
),
]);
},
),
);
return ScreenTypeLayout.builder(
Expand Down
37 changes: 32 additions & 5 deletions lib/blocs/drive_detail/drive_detail_cubit.dart
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ import 'package:rxdart/rxdart.dart';
part 'drive_detail_state.dart';

class DriveDetailCubit extends Cubit<DriveDetailState> {
final String driveId;
String _driveId;
final ProfileCubit _profileCubit;
final DriveDao _driveDao;
final ConfigService _configService;
Expand All @@ -52,7 +52,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
bool _showHiddenFiles = false;

DriveDetailCubit({
required this.driveId,
required String driveId,
String? initialFolderId,
required ProfileCubit profileCubit,
required DriveDao driveDao,
Expand All @@ -70,6 +70,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
_breadcrumbBuilder = breadcrumbBuilder,
_syncCubit = syncCubit,
_driveRepository = driveRepository,
_driveId = driveId,
super(DriveDetailLoadInProgress()) {
if (driveId.isEmpty) {
return;
Expand All @@ -95,26 +96,44 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
}
}

void showEmptyDriveDetail() async {
await _syncCubit.waitCurrentSync();

emit(DriveDetailLoadEmpty());
}

Future<void> changeDrive(String driveId) async {
final drive = await _driveDao.driveById(driveId: driveId).getSingleOrNull();

if (drive == null) {
return;
}

_driveId = driveId;

openFolder(folderId: drive.rootFolderId);
}

void toggleHiddenFiles() {
_showHiddenFiles = !_showHiddenFiles;

refreshDriveDataTable();
}

void openFolder({
Future<void> openFolder({
String? folderId,
String? otherDriveId,
String? selectedItemId,
DriveOrder contentOrderBy = DriveOrder.name,
OrderingMode contentOrderingMode = OrderingMode.asc,
}) async {
/// always wait for the current sync to finish before opening a new folder
await _syncCubit.waitCurrentSync();

try {
_selectedItem = null;
_allImagesOfCurrentFolder = null;

String driveId = otherDriveId ?? this.driveId;
String driveId = otherDriveId ?? _driveId;

emit(DriveDetailLoadInProgress());

Expand Down Expand Up @@ -195,6 +214,12 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
isOwner: isDriveOwner(_auth, drive.ownerAddress),
);

if (selectedItemId != null) {
_selectedItem = currentFolderContents.firstWhere(
(element) => element.id == selectedItemId,
);
}

final List<BreadCrumbRowInfo> pathSegments =
await _breadcrumbBuilder.buildForFolder(
folderId: folderContents.folder.id,
Expand All @@ -219,6 +244,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
pathSegments: pathSegments,
driveIsEmpty: folderContents.files.isEmpty &&
folderContents.subfolders.isEmpty,
showSelectedItemDetails: _selectedItem != null,
),
);
} else {
Expand All @@ -242,6 +268,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
currentFolderContents: currentFolderContents,
columnVisibility: columnsVisibility,
isShowingHiddenFiles: _showHiddenFiles,
showSelectedItemDetails: _selectedItem != null,
),
);
}
Expand Down
2 changes: 2 additions & 0 deletions lib/blocs/drive_detail/drive_detail_state.dart
Original file line number Diff line number Diff line change
Expand Up @@ -144,4 +144,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
/// the user's profile.
class DriveDetailLoadNotFound extends DriveDetailState {}

class DriveDetailLoadEmpty extends DriveDetailState {}

class DriveInitialLoading extends DriveDetailState {}
31 changes: 27 additions & 4 deletions lib/blocs/drives/drives_cubit.dart
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import 'package:ardrive/blocs/prompt_to_snapshot/prompt_to_snapshot_bloc.dart';
import 'package:ardrive/blocs/prompt_to_snapshot/prompt_to_snapshot_event.dart';
import 'package:ardrive/core/activity_tracker.dart';
import 'package:ardrive/models/models.dart';
import 'package:ardrive/user/repositories/user_preferences_repository.dart';
import 'package:ardrive/utils/user_utils.dart';
import 'package:ardrive_utils/ardrive_utils.dart';
import 'package:drift/drift.dart';
Expand All @@ -22,6 +23,7 @@ class DrivesCubit extends Cubit<DrivesState> {
final PromptToSnapshotBloc _promptToSnapshotBloc;
final DriveDao _driveDao;
final ArDriveAuth _auth;
final UserPreferencesRepository _userPreferencesRepository;

late StreamSubscription _drivesSubscription;
String? initialSelectedDriveId;
Expand All @@ -32,10 +34,12 @@ class DrivesCubit extends Cubit<DrivesState> {
required PromptToSnapshotBloc promptToSnapshotBloc,
required DriveDao driveDao,
required ActivityTracker activityTracker,
required UserPreferencesRepository userPreferencesRepository,
}) : _profileCubit = profileCubit,
_promptToSnapshotBloc = promptToSnapshotBloc,
_driveDao = driveDao,
_auth = auth,
_userPreferencesRepository = userPreferencesRepository,
super(DrivesLoadInProgress()) {
_auth.onAuthStateChanged().listen((user) {
if (user == null) {
Expand Down Expand Up @@ -66,11 +70,28 @@ class DrivesCubit extends Cubit<DrivesState> {

String? selectedDriveId;

if (state is DrivesLoadSuccess && state.selectedDriveId != null) {
if (state is DrivesLoadSuccess) {
selectedDriveId = state.selectedDriveId;
} else {
selectedDriveId = initialSelectedDriveId ??
(drives.isNotEmpty ? drives.first.id : null);
}

if (selectedDriveId == null) {
if (initialSelectedDriveId != null &&
initialSelectedDriveId!.isNotEmpty) {
selectedDriveId = initialSelectedDriveId;
} else {
final userPreferences = await _userPreferencesRepository.load();

final userHasHiddenDrive = drives.any((d) => d.isHidden);
await _userPreferencesRepository
.saveUserHasHiddenItem(userHasHiddenDrive);

selectedDriveId = userPreferences.lastSelectedDriveId;

if (selectedDriveId == null ||
!drives.any((d) => d.id == selectedDriveId)) {
selectedDriveId = drives.isNotEmpty ? drives.first.id : null;
}
}
}

final walletAddress = profileState is ProfileLoggedIn
Expand Down Expand Up @@ -118,6 +139,8 @@ class DrivesCubit extends Cubit<DrivesState> {
);
_promptToSnapshotBloc.add(const SelectedDrive(driveId: null));
}

_userPreferencesRepository.saveLastSelectedDriveId(driveId);
emit(state);
}

Expand Down
42 changes: 42 additions & 0 deletions lib/blocs/hide/global_hide_bloc.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
import 'package:ardrive/models/daos/drive_dao/drive_dao.dart';
import 'package:ardrive/user/repositories/user_preferences_repository.dart';
import 'package:equatable/equatable.dart';
import 'package:flutter_bloc/flutter_bloc.dart';

part 'global_hide_event.dart';
part 'global_hide_state.dart';

class GlobalHideBloc extends Bloc<GlobalHideEvent, GlobalHideState> {
final UserPreferencesRepository _userPreferencesRepository;
final DriveDao _driveDao;

GlobalHideBloc({
required UserPreferencesRepository userPreferencesRepository,
required DriveDao driveDao,
}) : _userPreferencesRepository = userPreferencesRepository,
_driveDao = driveDao,
super(const GlobalHideInitial(userHasHiddenDrive: false)) {
_userPreferencesRepository.watch().listen((userPreferences) async {
if (userPreferences.showHiddenFiles) {
add(ShowItems(userHasHiddenItems: userPreferences.userHasHiddenDrive));
} else {
add(HideItems(userHasHiddenItems: userPreferences.userHasHiddenDrive));
}
});

_userPreferencesRepository.load();

on<GlobalHideEvent>((event, emit) async {
if (event is ShowItems) {
emit(ShowingHiddenItems(userHasHiddenDrive: event.userHasHiddenItems));
await _userPreferencesRepository.saveShowHiddenFiles(true);
} else if (event is HideItems) {
emit(HiddingItems(userHasHiddenDrive: event.userHasHiddenItems));
await _userPreferencesRepository.saveShowHiddenFiles(false);
} else if (event is RefreshOptions) {
final hasHiddenItems = await _driveDao.userHasHiddenItems();
emit(state.copyWith(userHasHiddenDrive: hasHiddenItems));
}
});
}
}
26 changes: 26 additions & 0 deletions lib/blocs/hide/global_hide_event.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
part of 'global_hide_bloc.dart';

sealed class GlobalHideEvent extends Equatable {
const GlobalHideEvent();

@override
List<Object> get props => [];
}

class HideItems extends GlobalHideEvent {
final bool userHasHiddenItems;

const HideItems({required this.userHasHiddenItems});
}

class ShowItems extends GlobalHideEvent {
final bool userHasHiddenItems;

const ShowItems({required this.userHasHiddenItems});
}

class RefreshOptions extends GlobalHideEvent {
final bool userHasHiddenItems;

const RefreshOptions({required this.userHasHiddenItems});
}
61 changes: 61 additions & 0 deletions lib/blocs/hide/global_hide_state.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
part of 'global_hide_bloc.dart';

sealed class GlobalHideState extends Equatable {
const GlobalHideState({
required this.userHasHiddenDrive,
});

final bool userHasHiddenDrive;

@override
List<Object> get props => [userHasHiddenDrive];

GlobalHideState copyWith({
bool? userHasHiddenDrive,
});
}

final class GlobalHideInitial extends GlobalHideState {
const GlobalHideInitial({
required super.userHasHiddenDrive,
});

@override
GlobalHideState copyWith({
bool? userHasHiddenDrive,
}) {
return GlobalHideInitial(
userHasHiddenDrive: userHasHiddenDrive ?? this.userHasHiddenDrive,
);
}
}

final class ShowingHiddenItems extends GlobalHideState {
const ShowingHiddenItems({
required super.userHasHiddenDrive,
});

@override
GlobalHideState copyWith({
bool? userHasHiddenDrive,
}) {
return ShowingHiddenItems(
userHasHiddenDrive: userHasHiddenDrive ?? this.userHasHiddenDrive,
);
}
}

final class HiddingItems extends GlobalHideState {
const HiddingItems({
required super.userHasHiddenDrive,
});

@override
GlobalHideState copyWith({
bool? userHasHiddenDrive,
}) {
return HiddingItems(
userHasHiddenDrive: userHasHiddenDrive ?? this.userHasHiddenDrive,
);
}
}
Loading
Loading