You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
3.9 KiB
133 lines
3.9 KiB
part of '../neon_files.dart'; |
|
|
|
class FilesChooseCreateDialog extends StatefulWidget { |
|
const FilesChooseCreateDialog({ |
|
required this.bloc, |
|
required this.basePath, |
|
super.key, |
|
}); |
|
|
|
final FilesBloc bloc; |
|
final List<String> basePath; |
|
|
|
@override |
|
State<FilesChooseCreateDialog> createState() => _FilesChooseCreateDialogState(); |
|
} |
|
|
|
class _FilesChooseCreateDialogState extends State<FilesChooseCreateDialog> { |
|
Future<void> uploadFromPick(final FileType type) async { |
|
final result = await FilePicker.platform.pickFiles( |
|
allowMultiple: true, |
|
type: type, |
|
); |
|
if (result != null) { |
|
for (final file in result.files) { |
|
await upload( |
|
file.name, |
|
path: kIsWeb ? null : file.path, |
|
bytes: file.bytes, |
|
); |
|
} |
|
} |
|
} |
|
|
|
Future<void> upload( |
|
final String name, { |
|
final String? path, |
|
final Uint8List? bytes, |
|
}) async { |
|
assert((path == null) != (bytes == null), 'Provide either path or bytes'); |
|
final sizeWarning = widget.bloc.options.uploadSizeWarning.value; |
|
if (path != null && sizeWarning != null) { |
|
final file = File(path); |
|
final stat = file.statSync(); |
|
if (stat.size > sizeWarning) { |
|
if (!(await showConfirmationDialog( |
|
context, |
|
FilesLocalizations.of(context).uploadConfirmSizeWarning( |
|
filesize(sizeWarning), |
|
filesize(stat.size), |
|
), |
|
))) { |
|
return; |
|
} |
|
} |
|
} |
|
|
|
if (path != null) { |
|
widget.bloc.uploadFile([...widget.basePath, name], path); |
|
} else { |
|
widget.bloc.uploadBytes([...widget.basePath, name], bytes!); |
|
} |
|
} |
|
|
|
@override |
|
Widget build(final BuildContext context) => NeonDialog( |
|
children: [ |
|
ListTile( |
|
leading: Icon( |
|
MdiIcons.filePlus, |
|
color: Theme.of(context).colorScheme.primary, |
|
), |
|
title: Text(FilesLocalizations.of(context).uploadFiles), |
|
onTap: () async { |
|
await uploadFromPick(FileType.any); |
|
|
|
if (mounted) { |
|
Navigator.of(context).pop(); |
|
} |
|
}, |
|
), |
|
ListTile( |
|
leading: Icon( |
|
MdiIcons.fileImagePlus, |
|
color: Theme.of(context).colorScheme.primary, |
|
), |
|
title: Text(FilesLocalizations.of(context).uploadImages), |
|
onTap: () async { |
|
await uploadFromPick(FileType.image); |
|
|
|
if (mounted) { |
|
Navigator.of(context).pop(); |
|
} |
|
}, |
|
), |
|
if (NeonPlatform.instance.canUseCamera) ...[ |
|
ListTile( |
|
leading: Icon( |
|
MdiIcons.cameraPlus, |
|
color: Theme.of(context).colorScheme.primary, |
|
), |
|
title: Text(FilesLocalizations.of(context).uploadCamera), |
|
onTap: () async { |
|
Navigator.of(context).pop(); |
|
|
|
final picker = ImagePicker(); |
|
final result = await picker.pickImage(source: ImageSource.camera); |
|
if (result != null) { |
|
await upload(result.name, path: result.path); |
|
} |
|
}, |
|
), |
|
], |
|
ListTile( |
|
leading: Icon( |
|
MdiIcons.folderPlus, |
|
color: Theme.of(context).colorScheme.primary, |
|
), |
|
title: Text(FilesLocalizations.of(context).folderCreate), |
|
onTap: () async { |
|
Navigator.of(context).pop(); |
|
|
|
final result = await showDialog<List<String>>( |
|
context: context, |
|
builder: (final context) => const FilesCreateFolderDialog(), |
|
); |
|
if (result != null) { |
|
widget.bloc.browser.createFolder([...widget.basePath, ...result]); |
|
} |
|
}, |
|
), |
|
], |
|
); |
|
}
|
|
|