mirror of
https://github.com/lollipopkit/flutter_server_box.git
synced 2025-12-17 07:14:28 +01:00
default: mac window size & opt.: snippet result
This commit is contained in:
@@ -209,7 +209,7 @@ class AppRoute {
|
||||
return AppRoute(AndroidSettingsPage(key: key), 'android_setting');
|
||||
}
|
||||
|
||||
static AppRoute snippetResult({Key? key, required Map<String, String?> results}) {
|
||||
static AppRoute snippetResult({Key? key, required List<SnippetResult?> results}) {
|
||||
return AppRoute(
|
||||
SnippetResultPage(
|
||||
key: key,
|
||||
|
||||
@@ -7,15 +7,15 @@ enum ServerTabMenuType {
|
||||
docker,
|
||||
process,
|
||||
pkg,
|
||||
snippet,
|
||||
//snippet,
|
||||
;
|
||||
|
||||
IconData get icon {
|
||||
switch (this) {
|
||||
case ServerTabMenuType.sftp:
|
||||
return Icons.insert_drive_file;
|
||||
case ServerTabMenuType.snippet:
|
||||
return Icons.code;
|
||||
//case ServerTabMenuType.snippet:
|
||||
//return Icons.code;
|
||||
case ServerTabMenuType.pkg:
|
||||
return Icons.system_security_update;
|
||||
case ServerTabMenuType.docker:
|
||||
@@ -31,8 +31,8 @@ enum ServerTabMenuType {
|
||||
switch (this) {
|
||||
case ServerTabMenuType.sftp:
|
||||
return 'SFTP';
|
||||
case ServerTabMenuType.snippet:
|
||||
return l10n.snippet;
|
||||
//case ServerTabMenuType.snippet:
|
||||
//return l10n.snippet;
|
||||
case ServerTabMenuType.pkg:
|
||||
return l10n.pkg;
|
||||
case ServerTabMenuType.docker:
|
||||
|
||||
@@ -3,6 +3,7 @@ import '../server/system.dart';
|
||||
|
||||
const seperator = 'SrvBoxSep';
|
||||
|
||||
/// The suffix `\t` is for formatting
|
||||
const _cmdDivider = '\necho $seperator\n\t';
|
||||
|
||||
const _serverBoxDir = r'$HOME/.config/server_box';
|
||||
|
||||
@@ -45,3 +45,15 @@ class Snippet implements TagPickable {
|
||||
@override
|
||||
String get tagName => name;
|
||||
}
|
||||
|
||||
class SnippetResult {
|
||||
final String? dest;
|
||||
final String result;
|
||||
final Duration time;
|
||||
|
||||
SnippetResult({
|
||||
required this.dest,
|
||||
required this.result,
|
||||
required this.time,
|
||||
});
|
||||
}
|
||||
|
||||
@@ -362,18 +362,26 @@ class ServerProvider extends ChangeNotifier {
|
||||
_limiter.reset(sid);
|
||||
}
|
||||
|
||||
Future<String?> runSnippets(String id, List<Snippet> snippets) async {
|
||||
Future<SnippetResult?> runSnippets(String id, Snippet snippet) async {
|
||||
final client = _servers[id]?.client;
|
||||
if (client == null) {
|
||||
return null;
|
||||
}
|
||||
return await client.run(snippets.map((e) => e.script).join('&&')).string;
|
||||
final watch = Stopwatch()..start();
|
||||
final result = await client.run(snippet.script).string;
|
||||
final time = watch.elapsed;
|
||||
watch.stop();
|
||||
return SnippetResult(
|
||||
dest: _servers[id]?.spi.name,
|
||||
result: result,
|
||||
time: time,
|
||||
);
|
||||
}
|
||||
|
||||
Future<List<String?>> runSnippetsMulti(
|
||||
Future<List<SnippetResult?>> runSnippetsMulti(
|
||||
List<String> ids,
|
||||
List<Snippet> snippets,
|
||||
Snippet snippet,
|
||||
) async {
|
||||
return await Future.wait(ids.map((id) async => runSnippets(id, snippets)));
|
||||
return await Future.wait(ids.map((id) async => runSnippets(id, snippet)));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -38,5 +38,6 @@ class GithubIds {
|
||||
'a1564471347',
|
||||
'fanzhebufan1',
|
||||
'wcbing',
|
||||
'balh55y',
|
||||
};
|
||||
}
|
||||
|
||||
@@ -134,15 +134,9 @@ class _SnippetListPageState extends State<SnippetListPage> {
|
||||
return;
|
||||
}
|
||||
final ids = servers.map((e) => e.spi.id).toList();
|
||||
final names = servers.map((e) => e.spi.name).toList();
|
||||
final results = await Pros.server.runSnippetsMulti(ids, [snippet]);
|
||||
final results = await Pros.server.runSnippetsMulti(ids, snippet);
|
||||
if (results.isNotEmpty) {
|
||||
// SERVER_NAME: RESULT
|
||||
final result = Map.fromIterables(
|
||||
names,
|
||||
results,
|
||||
);
|
||||
AppRoute.snippetResult(results: result).go(context);
|
||||
AppRoute.snippetResult(results: results).go(context);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,11 +1,13 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:toolbox/core/extension/context/locale.dart';
|
||||
import 'package:toolbox/data/model/server/snippet.dart';
|
||||
import 'package:toolbox/data/res/ui.dart';
|
||||
import 'package:toolbox/view/widget/cardx.dart';
|
||||
import 'package:toolbox/view/widget/custom_appbar.dart';
|
||||
import 'package:toolbox/view/widget/expand_tile.dart';
|
||||
|
||||
class SnippetResultPage extends StatelessWidget {
|
||||
final Map<String, String?> results;
|
||||
final List<SnippetResult?> results;
|
||||
|
||||
const SnippetResultPage({super.key, required this.results});
|
||||
|
||||
@@ -20,28 +22,30 @@ class SnippetResultPage extends StatelessWidget {
|
||||
}
|
||||
|
||||
Widget _buildBody() {
|
||||
return Align(
|
||||
alignment: Alignment.centerLeft,
|
||||
child: ListView.builder(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 17),
|
||||
itemCount: results.length,
|
||||
itemBuilder: (_, index) {
|
||||
final key = results.keys.elementAt(index);
|
||||
final value = results[key];
|
||||
return CardX(
|
||||
ExpandTile(
|
||||
initiallyExpanded: results.length == 1,
|
||||
title: Text(key),
|
||||
children: [
|
||||
Text(
|
||||
value ?? '',
|
||||
return ListView.builder(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 17),
|
||||
itemCount: results.length,
|
||||
itemBuilder: (_, index) {
|
||||
final item = results[index];
|
||||
if (item == null) return UIs.placeholder;
|
||||
return CardX(
|
||||
ExpandTile(
|
||||
initiallyExpanded: results.length == 1,
|
||||
title: Text(item.dest ?? ''),
|
||||
subtitle: Text(item.time.toString(), style: UIs.textGrey),
|
||||
children: [
|
||||
SingleChildScrollView(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 17),
|
||||
scrollDirection: Axis.horizontal,
|
||||
child: Text(
|
||||
item.result,
|
||||
textAlign: TextAlign.start,
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -14,12 +14,10 @@ import 'package:toolbox/data/model/server/dist.dart';
|
||||
import 'package:toolbox/data/res/provider.dart';
|
||||
|
||||
import '../../core/route.dart';
|
||||
import '../../core/utils/misc.dart';
|
||||
import '../../core/utils/server.dart';
|
||||
import '../../data/model/app/menu.dart';
|
||||
import '../../data/model/pkg/upgrade_info.dart';
|
||||
import '../../data/model/server/server_private_info.dart';
|
||||
import '../../data/model/server/snippet.dart';
|
||||
import 'popup_menu.dart';
|
||||
|
||||
class ServerFuncBtnsTopRight extends StatelessWidget {
|
||||
@@ -94,28 +92,29 @@ void _onTapMoreBtns(
|
||||
check: () => _checkClient(context, spi.id),
|
||||
);
|
||||
break;
|
||||
case ServerTabMenuType.snippet:
|
||||
final snippets = await context.showPickDialog<Snippet>(
|
||||
items: Pros.snippet.snippets,
|
||||
name: (e) => e.name,
|
||||
);
|
||||
if (snippets == null) {
|
||||
return;
|
||||
}
|
||||
final result = await Pros.server.runSnippets(spi.id, snippets);
|
||||
if (result != null && result.isNotEmpty) {
|
||||
context.showRoundDialog(
|
||||
title: Text(l10n.result),
|
||||
child: Text(result),
|
||||
actions: [
|
||||
TextButton(
|
||||
onPressed: () => copy2Clipboard(result),
|
||||
child: Text(l10n.copy),
|
||||
)
|
||||
],
|
||||
);
|
||||
}
|
||||
break;
|
||||
// case ServerTabMenuType.snippet:
|
||||
// final snippets = await context.showPickDialog<Snippet>(
|
||||
// items: Pros.snippet.snippets,
|
||||
// name: (e) => e.name,
|
||||
// multi: false
|
||||
// );
|
||||
// if (snippets == null || snippets.isEmpty) {
|
||||
// return;
|
||||
// }
|
||||
// final result = await Pros.server.runSnippets(spi.id, snippets.first);
|
||||
// if (result != null && result.isNotEmpty) {
|
||||
// context.showRoundDialog(
|
||||
// title: Text(l10n.result),
|
||||
// child: Text(result),
|
||||
// actions: [
|
||||
// TextButton(
|
||||
// onPressed: () => copy2Clipboard(result),
|
||||
// child: Text(l10n.copy),
|
||||
// )
|
||||
// ],
|
||||
// );
|
||||
// }
|
||||
// break;
|
||||
case ServerTabMenuType.docker:
|
||||
AppRoute.docker(spi: spi).checkGo(
|
||||
context: context,
|
||||
|
||||
@@ -6,7 +6,8 @@ class MainFlutterWindow: NSWindow {
|
||||
let flutterViewController = FlutterViewController()
|
||||
let windowFrame = self.frame
|
||||
self.contentViewController = flutterViewController
|
||||
self.setFrame(windowFrame, display: true)
|
||||
let newWindowRect = NSRect(x: windowFrame.origin.x, y: windowFrame.origin.y, width: 300, height: 600)
|
||||
self.setFrame(newWindowRect, display: true)
|
||||
|
||||
RegisterGeneratedPlugins(registry: flutterViewController)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user