Skip to content

Commit

Permalink
Add create update meilisearch data task page
Browse files Browse the repository at this point in the history
  • Loading branch information
lifegpc authored Oct 27, 2024
1 parent 20a115d commit c2d7228
Show file tree
Hide file tree
Showing 8 changed files with 226 additions and 2 deletions.
7 changes: 7 additions & 0 deletions lib/api/client.dart
Original file line number Diff line number Diff line change
Expand Up @@ -342,6 +342,13 @@ abstract class _EHApi {
});
@PUT('/task')
@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({
@Part(name: "cfg") UpdateTagTranslationConfig? cfg,
@Part(name: "type") String t = "update_tag_translation",
Expand Down
53 changes: 53 additions & 0 deletions lib/api/client.g.dart

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions lib/components/task.dart
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,10 @@ class _TaskView extends State<TaskView> {
return Text(i18n.updateTagTranslation,
maxLines: 1, overflow: TextOverflow.ellipsis);
}
if (typ == TaskType.updateMeiliSearchData) {
return Text(i18n.updateMeiliSearchDataTask,
maxLines: 1, overflow: TextOverflow.ellipsis);
}
return Container();
}

Expand Down
136 changes: 136 additions & 0 deletions lib/dialog/new_update_meili_search_data_task_page.dart
Original file line number Diff line number Diff line change
@@ -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))),
],
))));
}
}
4 changes: 3 additions & 1 deletion lib/l10n/app_en.arb
Original file line number Diff line number Diff line change
Expand Up @@ -337,5 +337,7 @@
"search": "Search",
"maxSearchSuggestions": "Maximum results of search suggestions",
"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."
}
4 changes: 3 additions & 1 deletion lib/l10n/app_zh.arb
Original file line number Diff line number Diff line change
Expand Up @@ -337,5 +337,7 @@
"search": "搜索",
"maxSearchSuggestions": "最大搜索建议结果数量",
"ok": "确定",
"changeSettings": "修改设置"
"changeSettings": "修改设置",
"createUpdateMeiliSearchDataTask": "创建同步meilisearch服务器数据任务",
"updateMeiliSearchDataGidHelp": "如果画廊ID非空,只有指定的画廊会同步至meilisearch服务器。"
}
14 changes: 14 additions & 0 deletions lib/main.dart
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import 'dialog/gallery_share_page.dart';
import 'dialog/new_download_task_page.dart';
import 'dialog/new_export_zip_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_user_page.dart';
import 'dialog/task_page.dart';
Expand Down Expand Up @@ -342,6 +343,19 @@ final _router = GoRouter(
path: SearchSettingsPage.routeName,
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: [
_NavigatorObserver(),
Expand Down
6 changes: 6 additions & 0 deletions lib/pages/task_manager.dart
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,10 @@ class _TaskManagerPage extends State<TaskManagerPage>
value: TaskType.import,
child: Text(i18n.createImportTask),
),
PopupMenuItem(
value: TaskType.updateMeiliSearchData,
child: Text(i18n.createUpdateMeiliSearchDataTask),
),
PopupMenuItem(
value: TaskType.updateTagTranslation,
child: Text(i18n.createUpdateTagTranslationTask),
Expand All @@ -235,6 +239,8 @@ class _TaskManagerPage extends State<TaskManagerPage>
context.push("/dialog/new_export_zip_task");
} else if (type == TaskType.import) {
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) {
context.push("/dialog/new_update_tag_translation_task");
}
Expand Down

0 comments on commit c2d7228

Please sign in to comment.