Compare commits

..

No commits in common. "23cd60701c12b3df482e06b1960862d6d372d100" and "ce6374d30231661bdff77ea568d040c343f3c2a2" have entirely different histories.

2 changed files with 142 additions and 192 deletions

View file

@ -7,9 +7,10 @@ import 'package:flutter/material.dart';
import 'package:fluxcloud/sftp_worker.dart';
class SftpExplorer extends StatefulWidget {
const SftpExplorer({super.key, required this.sftpWorker});
const SftpExplorer({super.key, required this.sftpWorker, this.path = '/'});
final SftpWorker sftpWorker;
final String path;
@override
State<SftpExplorer> createState() => _SftpExplorerState();
@ -17,8 +18,6 @@ class SftpExplorer extends StatefulWidget {
class _SftpExplorerState extends State<SftpExplorer> {
String path = '/';
bool _isLoading = true;
late List<SftpName> _dirContents;
@ -33,7 +32,7 @@ class _SftpExplorerState extends State<SftpExplorer> {
Future<void> _listDir() async {
setState(() => _isLoading = true);
try {
_dirContents = await widget.sftpWorker.listdir(path);
_dirContents = await widget.sftpWorker.listdir(widget.path);
}
catch (e) {
if (mounted) {
@ -52,20 +51,6 @@ class _SftpExplorerState extends State<SftpExplorer> {
title: Text('Explorer'),
elevation: 2,
actionsPadding: EdgeInsets.only(right: 20),
leading: IconButton(
onPressed: () {
if (path == '/') {
// TODO: figure this out
// Navigator.pop(context);
}
else {
path = path.substring(0, path.length - 1);
path = path.substring(0, path.lastIndexOf('/')+1);
_listDir();
}
},
icon: Icon(Icons.arrow_back)
),
actions: [
if (_progress != null)
Stack(
@ -87,26 +72,7 @@ class _SftpExplorerState extends State<SftpExplorer> {
],
),
floatingActionButton: _buildFABs(context),
body: AnimatedSwitcher(
duration: Duration(milliseconds: 300),
transitionBuilder: (child, animation) {
final curved = CurvedAnimation(
parent: animation,
curve: Curves.fastOutSlowIn
);
return FadeTransition(
opacity: curved,
child: ScaleTransition(
scale: Tween<double>(
begin: 0.92,
end: 1
).animate(curved),
child: child,
),
);
},
child: _isLoading ? Center(child: CircularProgressIndicator()) : ListView.builder(
key: ValueKey(path),
body: _isLoading ? Center(child: CircularProgressIndicator()) : ListView.builder(
itemCount: _dirContents.length,
itemBuilder: (context, index) {
final dirEntry = _dirContents[index];
@ -147,7 +113,7 @@ class _SftpExplorerState extends State<SftpExplorer> {
TextButton(
onPressed: () async {
// try {
// await widget.sftpWorker.rename('${path}${dirEntry.filename}', '${widget.path}${newNameController.text}');
// await widget.sftpWorker.rename('${widget.path}${dirEntry.filename}', '${widget.path}${newNameController.text}');
// _listDir();
// }
// on SftpStatusError catch (e) {
@ -195,10 +161,10 @@ class _SftpExplorerState extends State<SftpExplorer> {
// }
// await widget.sftpWorker.rmdir(path);
// }
// await removeRecursively('${path}${dirEntry.filename}/');
// await removeRecursively('${widget.path}${dirEntry.filename}/');
// }
// else {
// await widget.sftpWorker.remove('${path}${dirEntry.filename}');
// await widget.sftpWorker.remove('${widget.path}${dirEntry.filename}');
// }
// _listDir();
// if (context.mounted) {
@ -217,14 +183,17 @@ class _SftpExplorerState extends State<SftpExplorer> {
),
onTap: () {
if (dirEntry.attr.isDirectory) {
path = '$path${dirEntry.filename}/';
_listDir();
Navigator.push(context, MaterialPageRoute(
builder: (context) => SftpExplorer(
sftpWorker: widget.sftpWorker,
path: '${widget.path}${dirEntry.filename}/',
)
));
}
},
);
},
)
)
);
}
@ -251,18 +220,23 @@ class _SftpExplorerState extends State<SftpExplorer> {
TextButton(onPressed: () => Navigator.pop(context), child: Text('Cancel')),
TextButton(
onPressed: () async {
try {
await widget.sftpWorker.mkdir('${path}${nameController.text}');
_listDir();
}
catch (e) {
if (context.mounted) {
ScaffoldMessenger.of(context).showSnackBar(_buildErrorSnackBar(context, e.toString()));
}
}
if (context.mounted) {
Navigator.pop(context);
}
// try {
// await widget.sftpWorker.mkdir('${widget.path}${nameController.text}');
// _listDir();
// }
// on SftpStatusError catch (e) {
// if (context.mounted) {
// if (e.code == 4) {
// ScaffoldMessenger.of(context).showSnackBar(_buildErrorSnackBar(context, 'Folder Already Exists'));
// }
// else {
// ScaffoldMessenger.of(context).showSnackBar(_buildErrorSnackBar(context, 'Error: ${e.message}'));
// }
// }
// }
// if (context.mounted) {
// Navigator.pop(context);
// }
},
child: Text('Ok')
),
@ -285,7 +259,8 @@ class _SftpExplorerState extends State<SftpExplorer> {
filePaths = files.map((file) => file.path).toList();
}
try {
await for (final progress in widget.sftpWorker.uploadFiles(path, filePaths)) {
await for (final progress in widget.sftpWorker.uploadFiles(widget.path, filePaths)) {
print(progress);
setState(() => _progress = progress);
}
}

View file

@ -8,13 +8,11 @@ import 'package:path/path.dart';
import 'connection.dart';
sealed class SftpCommand {}
class ListDir extends SftpCommand {
final String path;
ListDir(this.path);
}
class UploadFiles extends SftpCommand {
final String path;
final List<String> fileNames;
@ -22,13 +20,6 @@ class UploadFiles extends SftpCommand {
UploadFiles(this.path, this.fileNames);
}
class MkDir extends SftpCommand {
final String path;
MkDir(this.path);
}
class SftpWorker {
final ReceivePort _responses;
@ -88,7 +79,7 @@ class SftpWorker {
static void _sftpCmdHandler(SendPort sendPort, ReceivePort receivePort, SftpClient sftpClient) {
receivePort.listen((message) async {
final (int id, SftpCommand command) = message;
final (int id, dynamic command) = message;
switch (command) {
case ListDir(:final path):
try {
@ -124,14 +115,6 @@ class SftpWorker {
}
sendPort.send((id, 1.0));
}
case MkDir(:final path):
try {
await sftpClient.mkdir(path);
sendPort.send((id, 0));
}
on SftpStatusError catch (e) {
sendPort.send((id, RemoteError(e.message, '')));
}
}
});
}
@ -166,7 +149,7 @@ class SftpWorker {
Future<List<SftpName>> listdir(String path) async {
final completer = Completer.sync();
final completer = Completer<Object>.sync();
final id = _idCounter++;
_activeRequests[id] = completer;
_commands.send((id, ListDir(path)));
@ -182,13 +165,5 @@ class SftpWorker {
return controller.stream;
}
Future<void> mkdir(String path) async {
final completer = Completer.sync();
final id = _idCounter++;
_activeRequests[id] = completer;
_commands.send((id, MkDir(path)));
await completer.future;
}
}