Skip to content

Commit

Permalink
Merge pull request #1908 from ardriveapp/dev
Browse files Browse the repository at this point in the history
PE-7043: Release ArDrive v2.57.0
  • Loading branch information
thiagocarvalhodev authored Oct 29, 2024
2 parents 4b5ee97 + 0417c28 commit 17bbca1
Show file tree
Hide file tree
Showing 68 changed files with 3,142 additions and 1,110 deletions.
8 changes: 8 additions & 0 deletions android/fastlane/metadata/android/en-US/changelogs/159.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
- New feature: Added option to assign an ArNS name during manifest auto-updates in the upload flow.
- New feature: Introduced hide/unhide feature for drives in the sidebar for improved organization.
- Introduced global toggle to show or hide all hidden drives, folders, and files
- Enhanced sidebar persistence during navigation and syncing.
- Improved details panel to retain state when switching views.
- Implemented memory of the last opened drive for quicker access.
- Updated share drive modal with new styles, colors, and copy button with icon.
- Removed feedback survey modal after uploads for a smoother experience.
17 changes: 10 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 Expand Up @@ -367,6 +368,8 @@ class MobileAppBar extends StatelessWidget implements PreferredSizeWidget {
),
),
const Spacer(),
const GlobalHideToggleButton(),
const SizedBox(width: 8),
const SyncButton(),
const SizedBox(
width: 24,
Expand Down
4 changes: 2 additions & 2 deletions lib/authentication/ardrive_auth.dart
Original file line number Diff line number Diff line change
Expand Up @@ -236,12 +236,12 @@ class ArDriveAuthImpl implements ArDriveAuth {
await _secureKeyValueStore.remove('biometricEnabled');
currentUser = null;
await _disconnectFromArConnect();
_userStreamController.add(null);
}

await _userRepository.deleteUser();
await _databaseHelpers.deleteAllTables();
await (await _metadataCache).clear();
(await _metadataCache).clear();
_userStreamController.add(null);
} catch (e, stacktrace) {
logger.e('Failed to logout user', e, stacktrace);
throw AuthenticationFailedException('Failed to logout user');
Expand Down
2 changes: 1 addition & 1 deletion lib/blocs/create_manifest/create_manifest_cubit.dart
Original file line number Diff line number Diff line change
Expand Up @@ -347,7 +347,7 @@ class CreateManifestCubit extends Cubit<CreateManifestState> {
return ARNSUndername(
name: '@',
domain: _selectedAntRecord!.domain,
record: ARNSRecord(
record: const ARNSRecord(
transactionId: 'to_assign',
ttlSeconds: 3600,
),
Expand Down
92 changes: 64 additions & 28 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 @@ -49,10 +49,8 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {

bool _refreshSelectedItem = false;

bool _showHiddenFiles = false;

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

void toggleHiddenFiles() {
_showHiddenFiles = !_showHiddenFiles;
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) {
await _syncCubit.waitCurrentSync();
emit(DriveDetailLoadNotFound());
return;
}

await _folderSubscription?.cancel();

refreshDriveDataTable();
_driveId = driveId;

openFolder(folderId: drive.rootFolderId);
}

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 All @@ -131,6 +146,14 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
),
_profileCubit.stream.startWith(ProfileCheckingAvailability()),
(drive, folderContents, _) async {
if (isClosed) {
return;
}

if (driveId != _driveId) {
return;
}

await _syncCubit.waitCurrentSync();

if (drive == null) {
Expand Down Expand Up @@ -195,6 +218,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 @@ -215,10 +244,10 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
rowsPerPage: availableRowsPerPage.first,
availableRowsPerPage: availableRowsPerPage,
currentFolderContents: currentFolderContents,
isShowingHiddenFiles: _showHiddenFiles,
pathSegments: pathSegments,
driveIsEmpty: folderContents.files.isEmpty &&
folderContents.subfolders.isEmpty,
showSelectedItemDetails: _selectedItem != null,
),
);
} else {
Expand All @@ -241,7 +270,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
multiselect: false,
currentFolderContents: currentFolderContents,
columnVisibility: columnsVisibility,
isShowingHiddenFiles: _showHiddenFiles,
showSelectedItemDetails: _selectedItem != null,
),
);
}
Expand All @@ -264,6 +293,8 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {

logger.e('An error occured mouting the drive explorer', e);
});

await _folderSubscription?.asFuture();
}

List<ArDriveDataTableItem> parseEntitiesToDatatableItem({
Expand Down Expand Up @@ -447,53 +478,58 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
final state = this.state as DriveDetailLoadSuccess;
emit(state.copyWith(
forceRebuildKey: UniqueKey(),
isShowingHiddenFiles: _showHiddenFiles,
));
}
}

bool canNavigateThroughImages() {
final numberOfImages = getAllImagesOfCurrentFolder().length;
bool canNavigateThroughImages(bool showHiddenImages) {
final numberOfImages = getAllImagesOfCurrentFolder(showHiddenImages).length;
return numberOfImages > 1;
}

Future<void> selectNextImage() => _selectImageRelativeToCurrent(1);
Future<void> selectPreviousImage() => _selectImageRelativeToCurrent(-1);
Future<void> selectNextImage(bool showHiddenImages) =>
_selectImageRelativeToCurrent(1, showHiddenImages);
Future<void> selectPreviousImage(bool showHiddenImages) =>
_selectImageRelativeToCurrent(-1, showHiddenImages);

Future<void> _selectImageRelativeToCurrent(int offset) async {
final currentIndex = getIndexForImage(_selectedItem as FileDataTableItem);
Future<void> _selectImageRelativeToCurrent(
int offset, bool showHiddenImages) async {
final currentIndex = getIndexForImage(
_selectedItem as FileDataTableItem,
showHiddenImages,
);
final nextIndex = currentIndex + offset;
final nextImage = getImageForIndex(nextIndex);
final nextImage = getImageForIndex(nextIndex, showHiddenImages);

await selectDataItem(nextImage);
}

FileDataTableItem getImageForIndex(int index) {
final allImagesOfCurrentFolder = getAllImagesOfCurrentFolder();
FileDataTableItem getImageForIndex(int index, bool showHiddenImages) {
final allImagesOfCurrentFolder =
getAllImagesOfCurrentFolder(showHiddenImages);
final cyclicIndex = index % allImagesOfCurrentFolder.length;
final image = allImagesOfCurrentFolder[cyclicIndex];

return image;
}

int getIndexForImage(FileDataTableItem image) {
final allImagesOfCurrentFolder = getAllImagesOfCurrentFolder();
int getIndexForImage(FileDataTableItem image, bool showHiddenImages) {
final allImagesOfCurrentFolder =
getAllImagesOfCurrentFolder(showHiddenImages);
final index = allImagesOfCurrentFolder.indexWhere(
(element) => element.id == image.id,
);

return index;
}

List<FileDataTableItem> getAllImagesOfCurrentFolder() {
List<FileDataTableItem> getAllImagesOfCurrentFolder(bool showHiddenImages) {
if (_allImagesOfCurrentFolder != null) {
return _allImagesOfCurrentFolder!;
}

final state = this.state as DriveDetailLoadSuccess;

final isShowingHiddenFiles = state.isShowingHiddenFiles;

final List<FileDataTableItem> allImagesForFolder =
state.currentFolderContents.whereType<FileDataTableItem>().where(
(element) {
Expand All @@ -502,7 +538,7 @@ class DriveDetailCubit extends Cubit<DriveDetailState> {
);

return supportedImageType &&
(isShowingHiddenFiles ? true : !element.isHidden);
(showHiddenImages ? true : !element.isHidden);
},
).toList();

Expand Down
8 changes: 2 additions & 6 deletions lib/blocs/drive_detail/drive_detail_state.dart
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
final Map<int, bool> columnVisibility;
final Key? forceRebuildKey;

final bool isShowingHiddenFiles;

DriveDetailLoadSuccess({
required this.currentDrive,
required this.hasWritePermissions,
Expand All @@ -61,7 +59,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
required this.currentFolderContents,
required this.columnVisibility,
this.forceRebuildKey,
required this.isShowingHiddenFiles,
required this.pathSegments,
this.selectedPage,
});
Expand All @@ -83,7 +80,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
ArDriveDataTableItem? selectedItem,
List<ArDriveDataTableItem>? currentFolderContents,
Key? forceRebuildKey,
bool? isShowingHiddenFiles,
List<BreadCrumbRowInfo>? pathSegments,
int? selectedPage,
}) =>
Expand All @@ -109,7 +105,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
driveIsEmpty: driveIsEmpty ?? this.driveIsEmpty,
currentFolderContents:
currentFolderContents ?? this.currentFolderContents,
isShowingHiddenFiles: isShowingHiddenFiles ?? this.isShowingHiddenFiles,
pathSegments: pathSegments ?? this.pathSegments,
);

Expand All @@ -119,7 +114,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
hasWritePermissions,
folderInView,
currentFolderContents,
isShowingHiddenFiles,
contentOrderBy,
contentOrderingMode,
showSelectedItemDetails,
Expand All @@ -144,4 +138,6 @@ class DriveDetailLoadSuccess extends DriveDetailState {
/// the user's profile.
class DriveDetailLoadNotFound extends DriveDetailState {}

class DriveDetailLoadEmpty extends DriveDetailState {}

class DriveInitialLoading extends DriveDetailState {}
Loading

0 comments on commit 17bbca1

Please sign in to comment.