mirror of
https://github.com/lifegpc/eh_downloader_flutter.git
synced 2026-06-06 05:49:03 +08:00
Add create update meilisearch data task page
This commit is contained in:
@@ -342,6 +342,13 @@ abstract class _EHApi {
|
|||||||
});
|
});
|
||||||
@PUT('/task')
|
@PUT('/task')
|
||||||
@MultiPart()
|
@MultiPart()
|
||||||
|
Future<ApiResult<Task>> createUpdateMeiliSearchDataTask({
|
||||||
|
@Part(name: "gid") int? gid,
|
||||||
|
@Part(name: "type") String t = "update_meili_search_data",
|
||||||
|
@CancelRequest() CancelToken? cancel,
|
||||||
|
});
|
||||||
|
@PUT('/task')
|
||||||
|
@MultiPart()
|
||||||
Future<ApiResult<Task>> createUpdateTagTranslationTask({
|
Future<ApiResult<Task>> createUpdateTagTranslationTask({
|
||||||
@Part(name: "cfg") UpdateTagTranslationConfig? cfg,
|
@Part(name: "cfg") UpdateTagTranslationConfig? cfg,
|
||||||
@Part(name: "type") String t = "update_tag_translation",
|
@Part(name: "type") String t = "update_tag_translation",
|
||||||
|
|||||||
@@ -1911,6 +1911,59 @@ class __EHApi implements _EHApi {
|
|||||||
return _value;
|
return _value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<ApiResult<Task>> createUpdateMeiliSearchDataTask({
|
||||||
|
int? gid,
|
||||||
|
String t = "update_meili_search_data",
|
||||||
|
CancelToken? cancel,
|
||||||
|
}) async {
|
||||||
|
final _extra = <String, dynamic>{};
|
||||||
|
final queryParameters = <String, dynamic>{};
|
||||||
|
queryParameters.removeWhere((k, v) => v == null);
|
||||||
|
final _headers = <String, dynamic>{};
|
||||||
|
final _data = FormData();
|
||||||
|
if (gid != null) {
|
||||||
|
_data.fields.add(MapEntry(
|
||||||
|
'gid',
|
||||||
|
gid.toString(),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
_data.fields.add(MapEntry(
|
||||||
|
'type',
|
||||||
|
t,
|
||||||
|
));
|
||||||
|
final _options = _setStreamType<ApiResult<Task>>(Options(
|
||||||
|
method: 'PUT',
|
||||||
|
headers: _headers,
|
||||||
|
extra: _extra,
|
||||||
|
contentType: 'multipart/form-data',
|
||||||
|
)
|
||||||
|
.compose(
|
||||||
|
_dio.options,
|
||||||
|
'/task',
|
||||||
|
queryParameters: queryParameters,
|
||||||
|
data: _data,
|
||||||
|
cancelToken: cancel,
|
||||||
|
)
|
||||||
|
.copyWith(
|
||||||
|
baseUrl: _combineBaseUrls(
|
||||||
|
_dio.options.baseUrl,
|
||||||
|
baseUrl,
|
||||||
|
)));
|
||||||
|
final _result = await _dio.fetch<Map<String, dynamic>>(_options);
|
||||||
|
late ApiResult<Task> _value;
|
||||||
|
try {
|
||||||
|
_value = ApiResult<Task>.fromJson(
|
||||||
|
_result.data!,
|
||||||
|
(json) => Task.fromJson(json as Map<String, dynamic>),
|
||||||
|
);
|
||||||
|
} on Object catch (e, s) {
|
||||||
|
errorLogger?.logError(e, s, _options);
|
||||||
|
rethrow;
|
||||||
|
}
|
||||||
|
return _value;
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<ApiResult<Task>> createUpdateTagTranslationTask({
|
Future<ApiResult<Task>> createUpdateTagTranslationTask({
|
||||||
UpdateTagTranslationConfig? cfg,
|
UpdateTagTranslationConfig? cfg,
|
||||||
|
|||||||
@@ -106,6 +106,10 @@ class _TaskView extends State<TaskView> {
|
|||||||
return Text(i18n.updateTagTranslation,
|
return Text(i18n.updateTagTranslation,
|
||||||
maxLines: 1, overflow: TextOverflow.ellipsis);
|
maxLines: 1, overflow: TextOverflow.ellipsis);
|
||||||
}
|
}
|
||||||
|
if (typ == TaskType.updateMeiliSearchData) {
|
||||||
|
return Text(i18n.updateMeiliSearchDataTask,
|
||||||
|
maxLines: 1, overflow: TextOverflow.ellipsis);
|
||||||
|
}
|
||||||
return Container();
|
return Container();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
136
lib/dialog/new_update_meili_search_data_task_page.dart
Normal file
136
lib/dialog/new_update_meili_search_data_task_page.dart
Normal file
@@ -0,0 +1,136 @@
|
|||||||
|
import 'package:dio/dio.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
|
||||||
|
import 'package:go_router/go_router.dart';
|
||||||
|
import 'package:logging/logging.dart';
|
||||||
|
import '../components/number_field.dart';
|
||||||
|
import '../globals.dart';
|
||||||
|
|
||||||
|
final _log = Logger("NewUpdateTagTranslationTaskPage");
|
||||||
|
|
||||||
|
class NewUpdateMeiliSearchDataTaskPage extends StatefulWidget {
|
||||||
|
const NewUpdateMeiliSearchDataTaskPage({this.gid, super.key});
|
||||||
|
|
||||||
|
final int? gid;
|
||||||
|
|
||||||
|
static const routeName = "/dialog/new_update_meili_search_data_task";
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<NewUpdateMeiliSearchDataTaskPage> createState() =>
|
||||||
|
_NewUpdateMeiliSearchDataTaskPage();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _NewUpdateMeiliSearchDataTaskPage
|
||||||
|
extends State<NewUpdateMeiliSearchDataTaskPage> {
|
||||||
|
final _formKey = GlobalKey<FormState>();
|
||||||
|
bool _ok = false;
|
||||||
|
bool _isCreating = false;
|
||||||
|
CancelToken? _cancel;
|
||||||
|
int? _gid;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
_gid = widget.gid;
|
||||||
|
super.initState();
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void dispose() {
|
||||||
|
_cancel?.cancel();
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> create() async {
|
||||||
|
try {
|
||||||
|
_cancel = CancelToken();
|
||||||
|
setState(() {
|
||||||
|
_isCreating = true;
|
||||||
|
});
|
||||||
|
(await api.createUpdateMeiliSearchDataTask(gid: _gid, cancel: _cancel))
|
||||||
|
.unwrap();
|
||||||
|
_ok = true;
|
||||||
|
if (!_cancel!.isCancelled) {
|
||||||
|
setState(() {
|
||||||
|
_isCreating = false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
if (!_cancel!.isCancelled) {
|
||||||
|
_log.warning("Failed to create import task:", e);
|
||||||
|
setState(() {
|
||||||
|
_isCreating = false;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Widget _buildWithVecticalPadding(Widget child) {
|
||||||
|
return Container(
|
||||||
|
padding: const EdgeInsets.symmetric(vertical: 8),
|
||||||
|
child: child,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
tryInitApi(context);
|
||||||
|
if (_ok) {
|
||||||
|
WidgetsBinding.instance!.addPostFrameCallback((_) {
|
||||||
|
context.canPop() ? context.pop() : context.go("/task_manager");
|
||||||
|
});
|
||||||
|
_ok = false;
|
||||||
|
}
|
||||||
|
final i18n = AppLocalizations.of(context)!;
|
||||||
|
final maxWidth = MediaQuery.of(context).size.width;
|
||||||
|
return Container(
|
||||||
|
padding: maxWidth < 400
|
||||||
|
? const EdgeInsets.symmetric(vertical: 20, horizontal: 5)
|
||||||
|
: const EdgeInsets.all(20),
|
||||||
|
width: maxWidth < 810 ? null : 800,
|
||||||
|
decoration: BoxDecoration(borderRadius: BorderRadius.circular(10)),
|
||||||
|
child: SingleChildScrollView(
|
||||||
|
child: Form(
|
||||||
|
key: _formKey,
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
Stack(
|
||||||
|
alignment: Alignment.center,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
i18n.createUpdateMeiliSearchDataTask,
|
||||||
|
style: Theme.of(context).textTheme.headlineSmall,
|
||||||
|
),
|
||||||
|
Align(
|
||||||
|
alignment: Alignment.centerRight,
|
||||||
|
child: IconButton(
|
||||||
|
onPressed: () => context.canPop()
|
||||||
|
? context.pop()
|
||||||
|
: context.go("/task_manager"),
|
||||||
|
icon: const Icon(Icons.close),
|
||||||
|
)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
_buildWithVecticalPadding(NumberFormField(
|
||||||
|
min: 0,
|
||||||
|
initialValue: _gid,
|
||||||
|
decoration: InputDecoration(
|
||||||
|
border: const OutlineInputBorder(),
|
||||||
|
labelText: i18n.gid,
|
||||||
|
helperText: i18n.updateMeiliSearchDataGidHelp,
|
||||||
|
helperMaxLines: 3,
|
||||||
|
),
|
||||||
|
onChanged: (gid) {
|
||||||
|
_gid = gid;
|
||||||
|
},
|
||||||
|
)),
|
||||||
|
_buildWithVecticalPadding(ElevatedButton(
|
||||||
|
onPressed: _isCreating
|
||||||
|
? null
|
||||||
|
: () {
|
||||||
|
create();
|
||||||
|
},
|
||||||
|
child: Text(i18n.create))),
|
||||||
|
],
|
||||||
|
))));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -337,5 +337,7 @@
|
|||||||
"search": "Search",
|
"search": "Search",
|
||||||
"maxSearchSuggestions": "Maximum results of search suggestions",
|
"maxSearchSuggestions": "Maximum results of search suggestions",
|
||||||
"ok": "Ok",
|
"ok": "Ok",
|
||||||
"changeSettings": "Change settings"
|
"changeSettings": "Change settings",
|
||||||
|
"createUpdateMeiliSearchDataTask": "Create sync meilisearch server's data task",
|
||||||
|
"updateMeiliSearchDataGidHelp": "If gallery id is not empty, only specified gallery will sync to meilisearch server."
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -337,5 +337,7 @@
|
|||||||
"search": "搜索",
|
"search": "搜索",
|
||||||
"maxSearchSuggestions": "最大搜索建议结果数量",
|
"maxSearchSuggestions": "最大搜索建议结果数量",
|
||||||
"ok": "确定",
|
"ok": "确定",
|
||||||
"changeSettings": "修改设置"
|
"changeSettings": "修改设置",
|
||||||
|
"createUpdateMeiliSearchDataTask": "创建同步meilisearch服务器数据任务",
|
||||||
|
"updateMeiliSearchDataGidHelp": "如果画廊ID非空,只有指定的画廊会同步至meilisearch服务器。"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import 'dialog/gallery_share_page.dart';
|
|||||||
import 'dialog/new_download_task_page.dart';
|
import 'dialog/new_download_task_page.dart';
|
||||||
import 'dialog/new_export_zip_task_page.dart';
|
import 'dialog/new_export_zip_task_page.dart';
|
||||||
import 'dialog/new_import_task_page.dart';
|
import 'dialog/new_import_task_page.dart';
|
||||||
|
import 'dialog/new_update_meili_search_data_task_page.dart';
|
||||||
import 'dialog/new_update_tag_translation_task_page.dart';
|
import 'dialog/new_update_tag_translation_task_page.dart';
|
||||||
import 'dialog/new_user_page.dart';
|
import 'dialog/new_user_page.dart';
|
||||||
import 'dialog/task_page.dart';
|
import 'dialog/task_page.dart';
|
||||||
@@ -342,6 +343,19 @@ final _router = GoRouter(
|
|||||||
path: SearchSettingsPage.routeName,
|
path: SearchSettingsPage.routeName,
|
||||||
builder: (context, state) => SearchSettingsPage(key: state.pageKey),
|
builder: (context, state) => SearchSettingsPage(key: state.pageKey),
|
||||||
),
|
),
|
||||||
|
GoRoute(
|
||||||
|
path: NewUpdateMeiliSearchDataTaskPage.routeName,
|
||||||
|
pageBuilder: (context, state) {
|
||||||
|
int? gid;
|
||||||
|
if (state.uri.queryParameters.containsKey("gid")) {
|
||||||
|
gid = int.tryParse(state.uri.queryParameters["gid"]!);
|
||||||
|
}
|
||||||
|
return DialogPage(
|
||||||
|
key: state.pageKey,
|
||||||
|
builder: (context) {
|
||||||
|
return NewUpdateMeiliSearchDataTaskPage(gid: gid);
|
||||||
|
});
|
||||||
|
}),
|
||||||
],
|
],
|
||||||
observers: [
|
observers: [
|
||||||
_NavigatorObserver(),
|
_NavigatorObserver(),
|
||||||
|
|||||||
@@ -222,6 +222,10 @@ class _TaskManagerPage extends State<TaskManagerPage>
|
|||||||
value: TaskType.import,
|
value: TaskType.import,
|
||||||
child: Text(i18n.createImportTask),
|
child: Text(i18n.createImportTask),
|
||||||
),
|
),
|
||||||
|
PopupMenuItem(
|
||||||
|
value: TaskType.updateMeiliSearchData,
|
||||||
|
child: Text(i18n.createUpdateMeiliSearchDataTask),
|
||||||
|
),
|
||||||
PopupMenuItem(
|
PopupMenuItem(
|
||||||
value: TaskType.updateTagTranslation,
|
value: TaskType.updateTagTranslation,
|
||||||
child: Text(i18n.createUpdateTagTranslationTask),
|
child: Text(i18n.createUpdateTagTranslationTask),
|
||||||
@@ -235,6 +239,8 @@ class _TaskManagerPage extends State<TaskManagerPage>
|
|||||||
context.push("/dialog/new_export_zip_task");
|
context.push("/dialog/new_export_zip_task");
|
||||||
} else if (type == TaskType.import) {
|
} else if (type == TaskType.import) {
|
||||||
context.push("/dialog/new_import_task");
|
context.push("/dialog/new_import_task");
|
||||||
|
} else if (type == TaskType.updateMeiliSearchData) {
|
||||||
|
context.push("/dialog/new_update_meili_search_data_task");
|
||||||
} else if (type == TaskType.updateTagTranslation) {
|
} else if (type == TaskType.updateTagTranslation) {
|
||||||
context.push("/dialog/new_update_tag_translation_task");
|
context.push("/dialog/new_update_tag_translation_task");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user