mirror of
https://github.com/venera-app/venera.git
synced 2025-09-27 07:47:24 +00:00
Add callback setting
This commit is contained in:
@@ -6,6 +6,7 @@ import 'dart:convert';
|
||||
import 'dart:math' as math;
|
||||
|
||||
import 'package:flutter/widgets.dart';
|
||||
import 'package:flutter_qjs/flutter_qjs.dart';
|
||||
import 'package:venera/foundation/app.dart';
|
||||
import 'package:venera/foundation/comic_type.dart';
|
||||
import 'package:venera/foundation/history.dart';
|
||||
@@ -203,7 +204,7 @@ class ComicSource {
|
||||
|
||||
final LikeCommentFunc? likeCommentFunc;
|
||||
|
||||
final Map<String, dynamic>? settings;
|
||||
final Map<String, Map<String, dynamic>>? settings;
|
||||
|
||||
final Map<String, Map<String, String>>? translations;
|
||||
|
||||
|
@@ -923,8 +923,30 @@ class ComicSourceParser {
|
||||
};
|
||||
}
|
||||
|
||||
Map<String, dynamic> _parseSettings() {
|
||||
return _getValue("settings") ?? {};
|
||||
Map<String, Map<String, dynamic>> _parseSettings() {
|
||||
var value = _getValue("settings");
|
||||
if (value is Map) {
|
||||
var newMap = <String, Map<String, dynamic>>{};
|
||||
for (var e in value.entries) {
|
||||
if (e.key is! String) {
|
||||
continue;
|
||||
}
|
||||
var v = <String, dynamic>{};
|
||||
for (var e2 in e.value.entries) {
|
||||
if (e2.key is! String) {
|
||||
continue;
|
||||
}
|
||||
var v2 = e2.value;
|
||||
if (v2 is JSInvokable) {
|
||||
v2 = JSAutoFreeFunction(v2);
|
||||
}
|
||||
v[e2.key] = v2;
|
||||
}
|
||||
newMap[e.key] = v;
|
||||
}
|
||||
return newMap;
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
RegExp? _parseIdMatch() {
|
||||
|
@@ -165,7 +165,7 @@ class JsEngine with _JSEngineApi {
|
||||
String settingKey = message["setting_key"];
|
||||
var source = ComicSource.find(key)!;
|
||||
return source.data["settings"]?[settingKey] ??
|
||||
source.settings?[settingKey]['default'] ??
|
||||
source.settings?[settingKey]!['default'] ??
|
||||
(throw "Setting not found: $settingKey");
|
||||
}
|
||||
case "isLogged":
|
||||
@@ -688,3 +688,20 @@ class DocumentWrapper {
|
||||
return elements.length - 1;
|
||||
}
|
||||
}
|
||||
|
||||
class JSAutoFreeFunction {
|
||||
final JSInvokable func;
|
||||
|
||||
/// Automatically free the function when it's not used anymore
|
||||
JSAutoFreeFunction(this.func) {
|
||||
finalizer.attach(this, func);
|
||||
}
|
||||
|
||||
dynamic call(List<dynamic> args) {
|
||||
return func(args);
|
||||
}
|
||||
|
||||
static final finalizer = Finalizer<JSInvokable>((func) {
|
||||
func.free();
|
||||
});
|
||||
}
|
Reference in New Issue
Block a user