From 89683535516d6f9bdb2a22841693bcbf2f76f9a2 Mon Sep 17 00:00:00 2001 From: Lorenzo Pichilli Date: Tue, 17 May 2022 22:54:43 +0200 Subject: [PATCH 1/9] added initial code generator and example --- analysis_options.yaml | 9 +- ...ter_inappwebview_internal_annotations.dart | 8 + .../lib/src/enum_supported_platforms.dart | 115 +++ .../lib/src/exchangeable_enum.dart | 23 + .../lib/src/exchangeable_object.dart | 15 + .../src/exchangeable_object_constructor.dart | 3 + .../lib/src/exchangeable_object_property.dart | 9 + .../lib/src/supported_platforms.dart | 95 +++ .../pubspec.lock | 383 ++++++++++ .../pubspec.yaml | 10 + dev_packages/generators/build.yaml | 21 + dev_packages/generators/lib/builder.dart | 10 + dev_packages/generators/lib/generators.dart | 1 + .../lib/src/exchangeable_enum_generator.dart | 270 +++++++ .../src/exchangeable_object_generator.dart | 676 ++++++++++++++++++ .../generators/lib/src/model_visitor.dart | 27 + dev_packages/generators/lib/src/util.dart | 91 +++ dev_packages/generators/pubspec.lock | 513 +++++++++++++ dev_packages/generators/pubspec.yaml | 21 + dev_packages/test_gen/analysis_options.yaml | 11 + dev_packages/test_gen/lib/src/main.dart | 6 + .../test_gen/lib/src/test/test_class_2.dart | 10 + dev_packages/test_gen/lib/src/types/main.dart | 2 + .../test_gen/lib/src/types/test_class.dart | 68 ++ .../test_gen/lib/src/types/test_enum.dart | 160 +++++ dev_packages/test_gen/lib/test_gen.dart | 10 + dev_packages/test_gen/pubspec.lock | 422 +++++++++++ dev_packages/test_gen/pubspec.yaml | 20 + lib/src/types/action_mode_menu_item.dart | 134 +--- lib/src/types/action_mode_menu_item.g.dart | 187 +++++ lib/src/types/ajax_request.dart | 81 +-- lib/src/types/ajax_request.g.dart | 164 +++++ lib/src/types/ajax_request_action.dart | 40 +- lib/src/types/ajax_request_action.g.dart | 79 ++ lib/src/types/ajax_request_event.dart | 44 +- lib/src/types/ajax_request_event.g.dart | 60 ++ lib/src/types/ajax_request_event_type.dart | 58 +- lib/src/types/ajax_request_event_type.g.dart | 96 +++ lib/src/types/ajax_request_headers.dart | 21 +- lib/src/types/ajax_request_headers.g.dart | 50 ++ lib/src/types/ajax_request_ready_state.dart | 68 +- lib/src/types/ajax_request_ready_state.g.dart | 97 +++ lib/src/types/attributed_string.dart | 86 +-- lib/src/types/attributed_string.g.dart | 383 ++++++++++ .../attributed_string_text_effect_style.dart | 80 +-- ...attributed_string_text_effect_style.g.dart | 138 ++++ lib/src/types/cache_mode.dart | 122 +--- lib/src/types/cache_mode.g.dart | 178 +++++ .../types/call_async_javascript_result.dart | 24 +- .../types/call_async_javascript_result.g.dart | 46 ++ lib/src/types/client_cert_challenge.dart | 50 +- lib/src/types/client_cert_challenge.g.dart | 75 ++ lib/src/types/main.dart | 324 ++++----- lib/src/types/ssl_certificate.dart | 33 +- lib/src/types/ssl_certificate.g.dart | 105 +++ lib/src/types/ssl_certificate_dname.dart | 56 +- lib/src/types/ssl_certificate_dname.g.dart | 57 ++ lib/src/types/underline_style.dart | 172 +---- lib/src/types/underline_style.g.dart | 237 ++++++ .../types/url_authentication_challenge.dart | 37 +- .../types/url_authentication_challenge.g.dart | 43 ++ lib/src/types/url_protection_space.dart | 156 +--- lib/src/types/url_protection_space.g.dart | 175 +++++ ...rotection_space_authentication_method.dart | 105 +-- ...tection_space_authentication_method.g.dart | 191 +++++ pubspec.yaml | 7 +- 66 files changed, 5816 insertions(+), 1252 deletions(-) create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/flutter_inappwebview_internal_annotations.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/enum_supported_platforms.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_enum.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_constructor.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_property.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/lib/src/supported_platforms.dart create mode 100644 dev_packages/flutter_inappwebview_internal_annotations/pubspec.lock create mode 100755 dev_packages/flutter_inappwebview_internal_annotations/pubspec.yaml create mode 100644 dev_packages/generators/build.yaml create mode 100644 dev_packages/generators/lib/builder.dart create mode 100644 dev_packages/generators/lib/generators.dart create mode 100644 dev_packages/generators/lib/src/exchangeable_enum_generator.dart create mode 100644 dev_packages/generators/lib/src/exchangeable_object_generator.dart create mode 100644 dev_packages/generators/lib/src/model_visitor.dart create mode 100644 dev_packages/generators/lib/src/util.dart create mode 100644 dev_packages/generators/pubspec.lock create mode 100755 dev_packages/generators/pubspec.yaml create mode 100644 dev_packages/test_gen/analysis_options.yaml create mode 100644 dev_packages/test_gen/lib/src/main.dart create mode 100644 dev_packages/test_gen/lib/src/test/test_class_2.dart create mode 100644 dev_packages/test_gen/lib/src/types/main.dart create mode 100644 dev_packages/test_gen/lib/src/types/test_class.dart create mode 100644 dev_packages/test_gen/lib/src/types/test_enum.dart create mode 100644 dev_packages/test_gen/lib/test_gen.dart create mode 100644 dev_packages/test_gen/pubspec.lock create mode 100755 dev_packages/test_gen/pubspec.yaml create mode 100644 lib/src/types/action_mode_menu_item.g.dart create mode 100644 lib/src/types/ajax_request.g.dart create mode 100644 lib/src/types/ajax_request_action.g.dart create mode 100644 lib/src/types/ajax_request_event.g.dart create mode 100644 lib/src/types/ajax_request_event_type.g.dart create mode 100644 lib/src/types/ajax_request_headers.g.dart create mode 100644 lib/src/types/ajax_request_ready_state.g.dart create mode 100644 lib/src/types/attributed_string.g.dart create mode 100644 lib/src/types/attributed_string_text_effect_style.g.dart create mode 100644 lib/src/types/cache_mode.g.dart create mode 100644 lib/src/types/call_async_javascript_result.g.dart create mode 100644 lib/src/types/client_cert_challenge.g.dart create mode 100644 lib/src/types/ssl_certificate.g.dart create mode 100644 lib/src/types/ssl_certificate_dname.g.dart create mode 100644 lib/src/types/underline_style.g.dart create mode 100644 lib/src/types/url_authentication_challenge.g.dart create mode 100644 lib/src/types/url_protection_space.g.dart create mode 100644 lib/src/types/url_protection_space_authentication_method.g.dart diff --git a/analysis_options.yaml b/analysis_options.yaml index a5744c1c..fb01cf49 100644 --- a/analysis_options.yaml +++ b/analysis_options.yaml @@ -1,4 +1,11 @@ -include: package:flutter_lints/flutter.yaml +include: package:lints/recommended.yaml + +linter: + rules: + constant_identifier_names: ignore # Additional information about this file can be found at # https://dart.dev/guides/language/analysis-options +analyzer: + errors: + deprecated_member_use_from_same_package: ignore \ No newline at end of file diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/flutter_inappwebview_internal_annotations.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/flutter_inappwebview_internal_annotations.dart new file mode 100644 index 00000000..a605dda0 --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/flutter_inappwebview_internal_annotations.dart @@ -0,0 +1,8 @@ +library flutter_inappwebview_internal_annotations; + +export 'src/exchangeable_object.dart'; +export 'src/exchangeable_object_constructor.dart'; +export 'src/exchangeable_object_property.dart'; +export 'src/exchangeable_enum.dart'; +export 'src/supported_platforms.dart'; +export 'src/enum_supported_platforms.dart'; \ No newline at end of file diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/enum_supported_platforms.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/enum_supported_platforms.dart new file mode 100644 index 00000000..21f3209b --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/enum_supported_platforms.dart @@ -0,0 +1,115 @@ +import 'supported_platforms.dart'; + +abstract class EnumPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = ""; + final targetPlatformName = ""; +} + +class EnumAndroidPlatform implements EnumPlatform, AndroidPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumAndroidPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = "Android native WebView"; + final targetPlatformName = "android"; +} + +class EnumIOSPlatform implements EnumPlatform, IOSPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumIOSPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = "iOS"; + final targetPlatformName = "iOS"; +} + +class EnumMacOSPlatform implements EnumPlatform, MacOSPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumMacOSPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = "MacOS"; + final targetPlatformName = "macOS"; +} + +class EnumWindowsPlatform implements EnumPlatform, WindowsPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumWindowsPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = "Windows"; + final targetPlatformName = "windows"; +} + +class EnumLinuxPlatform implements EnumPlatform, LinuxPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + + const EnumLinuxPlatform( + {this.available, this.apiName, this.apiUrl, this.note, this.value}); + + final name = "Linux"; + final targetPlatformName = "linux"; +} + +class EnumWebPlatform implements EnumPlatform, WebPlatform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final dynamic value; + final bool requiresSameOrigin; + + const EnumWebPlatform( + {this.available, + this.apiName, + this.apiUrl, + this.note, + this.value, + this.requiresSameOrigin = true}); + + final name = "Web"; + final targetPlatformName = "web"; +} + +class EnumSupportedPlatforms { + final List platforms; + final dynamic defaultValue; + + const EnumSupportedPlatforms({ + required this.platforms, + this.defaultValue, + }); +} \ No newline at end of file diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_enum.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_enum.dart new file mode 100644 index 00000000..b6990249 --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_enum.dart @@ -0,0 +1,23 @@ +class ExchangeableEnum { + final bool valuesProperty; + final bool toValueMethod; + final bool fromValueMethod; + final bool toNativeValueMethod; + final bool fromNativeValueMethod; + final bool toStringMethod; + final bool hashCodeMethod; + final bool equalsOperator; + final bool bitwiseOrOperator; + + const ExchangeableEnum({ + this.valuesProperty = true, + this.toValueMethod = true, + this.fromValueMethod = true, + this.toNativeValueMethod = true, + this.fromNativeValueMethod = true, + this.toStringMethod = true, + this.hashCodeMethod = true, + this.equalsOperator = true, + this.bitwiseOrOperator = false + }); +} \ No newline at end of file diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object.dart new file mode 100644 index 00000000..6e1a9baf --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object.dart @@ -0,0 +1,15 @@ +class ExchangeableObject { + final bool toMapMethod; + final bool toJsonMethod; + final bool fromMapFactory; + final bool nullableFromMapFactory; + final bool toStringMethod; + + const ExchangeableObject({ + this.toMapMethod = true, + this.toJsonMethod = true, + this.fromMapFactory = true, + this.nullableFromMapFactory = true, + this.toStringMethod = true, + }); +} diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_constructor.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_constructor.dart new file mode 100644 index 00000000..13c89ce6 --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_constructor.dart @@ -0,0 +1,3 @@ +class ExchangeableObjectConstructor { + const ExchangeableObjectConstructor(); +} diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_property.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_property.dart new file mode 100644 index 00000000..14fa2eae --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/exchangeable_object_property.dart @@ -0,0 +1,9 @@ +class ExchangeableObjectProperty { + final Function? serializer; + final Function? deserializer; + + const ExchangeableObjectProperty({ + this.serializer, + this.deserializer + }); +} diff --git a/dev_packages/flutter_inappwebview_internal_annotations/lib/src/supported_platforms.dart b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/supported_platforms.dart new file mode 100644 index 00000000..a9d97348 --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/lib/src/supported_platforms.dart @@ -0,0 +1,95 @@ +abstract class Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const Platform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = ""; + final targetPlatformName = ""; +} + +class AndroidPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const AndroidPlatform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = "Android native WebView"; + final targetPlatformName = "android"; +} + +class IOSPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const IOSPlatform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = "iOS"; + final targetPlatformName = "iOS"; +} + +class MacOSPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const MacOSPlatform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = "MacOS"; + final targetPlatformName = "macOS"; +} + +class WindowsPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const WindowsPlatform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = "Windows"; + final targetPlatformName = "windows"; +} + +class LinuxPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + + const LinuxPlatform({this.available, this.apiName, this.apiUrl, this.note}); + + final name = "Linux"; + final targetPlatformName = "linux"; +} + +class WebPlatform implements Platform { + final String? available; + final String? apiName; + final String? apiUrl; + final String? note; + final bool requiresSameOrigin; + + const WebPlatform( + {this.available, + this.apiName, + this.apiUrl, + this.note, + this.requiresSameOrigin = true}); + + final name = "Web"; + final targetPlatformName = "web"; +} + +class SupportedPlatforms { + final List platforms; + + const SupportedPlatforms({required this.platforms}); +} diff --git a/dev_packages/flutter_inappwebview_internal_annotations/pubspec.lock b/dev_packages/flutter_inappwebview_internal_annotations/pubspec.lock new file mode 100644 index 00000000..d1a8e316 --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/pubspec.lock @@ -0,0 +1,383 @@ +# Generated by pub +# See https://dart.dev/tools/pub/glossary#lockfile +packages: + analyzer: + dependency: transitive + description: + name: analyzer + url: "https://pub.dartlang.org" + source: hosted + version: "0.33.6+1" + args: + dependency: transitive + description: + name: args + url: "https://pub.dartlang.org" + source: hosted + version: "1.6.0" + async: + dependency: transitive + description: + name: async + url: "https://pub.dartlang.org" + source: hosted + version: "2.9.0" + boolean_selector: + dependency: transitive + description: + name: boolean_selector + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.5" + charcode: + dependency: transitive + description: + name: charcode + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.1" + clock: + dependency: transitive + description: + name: clock + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.0" + collection: + dependency: transitive + description: + name: collection + url: "https://pub.dartlang.org" + source: hosted + version: "1.15.0" + convert: + dependency: transitive + description: + name: convert + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.1" + crypto: + dependency: transitive + description: + name: crypto + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.5" + csslib: + dependency: transitive + description: + name: csslib + url: "https://pub.dartlang.org" + source: hosted + version: "0.17.1" + file: + dependency: transitive + description: + name: file + url: "https://pub.dartlang.org" + source: hosted + version: "5.2.1" + front_end: + dependency: transitive + description: + name: front_end + url: "https://pub.dartlang.org" + source: hosted + version: "0.1.6+9" + glob: + dependency: transitive + description: + name: glob + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + html: + dependency: transitive + description: + name: html + url: "https://pub.dartlang.org" + source: hosted + version: "0.15.0" + http: + dependency: transitive + description: + name: http + url: "https://pub.dartlang.org" + source: hosted + version: "0.12.2" + http_multi_server: + dependency: transitive + description: + name: http_multi_server + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.0" + http_parser: + dependency: transitive + description: + name: http_parser + url: "https://pub.dartlang.org" + source: hosted + version: "3.1.4" + intl: + dependency: transitive + description: + name: intl + url: "https://pub.dartlang.org" + source: hosted + version: "0.17.0" + io: + dependency: transitive + description: + name: io + url: "https://pub.dartlang.org" + source: hosted + version: "0.3.5" + js: + dependency: transitive + description: + name: js + url: "https://pub.dartlang.org" + source: hosted + version: "0.6.4" + json_rpc_2: + dependency: transitive + description: + name: json_rpc_2 + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.2" + kernel: + dependency: transitive + description: + name: kernel + url: "https://pub.dartlang.org" + source: hosted + version: "0.3.6+9" + logging: + dependency: transitive + description: + name: logging + url: "https://pub.dartlang.org" + source: hosted + version: "0.11.4" + matcher: + dependency: transitive + description: + name: matcher + url: "https://pub.dartlang.org" + source: hosted + version: "0.12.3+1" + meta: + dependency: transitive + description: + name: meta + url: "https://pub.dartlang.org" + source: hosted + version: "1.7.0" + mime: + dependency: transitive + description: + name: mime + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.0" + multi_server_socket: + dependency: transitive + description: + name: multi_server_socket + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.2" + node_interop: + dependency: transitive + description: + name: node_interop + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.1" + node_io: + dependency: transitive + description: + name: node_io + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + node_preamble: + dependency: transitive + description: + name: node_preamble + url: "https://pub.dartlang.org" + source: hosted + version: "1.4.13" + package_config: + dependency: transitive + description: + name: package_config + url: "https://pub.dartlang.org" + source: hosted + version: "1.9.3" + package_resolver: + dependency: transitive + description: + name: package_resolver + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.10" + path: + dependency: transitive + description: + name: path + url: "https://pub.dartlang.org" + source: hosted + version: "1.8.1" + pedantic: + dependency: transitive + description: + name: pedantic + url: "https://pub.dartlang.org" + source: hosted + version: "1.11.1" + plugin: + dependency: transitive + description: + name: plugin + url: "https://pub.dartlang.org" + source: hosted + version: "0.2.0+3" + pool: + dependency: transitive + description: + name: pool + url: "https://pub.dartlang.org" + source: hosted + version: "1.5.0" + pub_semver: + dependency: transitive + description: + name: pub_semver + url: "https://pub.dartlang.org" + source: hosted + version: "1.4.4" + shelf: + dependency: transitive + description: + name: shelf + url: "https://pub.dartlang.org" + source: hosted + version: "0.7.9" + shelf_packages_handler: + dependency: transitive + description: + name: shelf_packages_handler + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.4" + shelf_static: + dependency: transitive + description: + name: shelf_static + url: "https://pub.dartlang.org" + source: hosted + version: "0.2.9+2" + shelf_web_socket: + dependency: transitive + description: + name: shelf_web_socket + url: "https://pub.dartlang.org" + source: hosted + version: "0.2.4+1" + source_map_stack_trace: + dependency: transitive + description: + name: source_map_stack_trace + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.5" + source_maps: + dependency: transitive + description: + name: source_maps + url: "https://pub.dartlang.org" + source: hosted + version: "0.10.10" + source_span: + dependency: transitive + description: + name: source_span + url: "https://pub.dartlang.org" + source: hosted + version: "1.9.0" + stack_trace: + dependency: transitive + description: + name: stack_trace + url: "https://pub.dartlang.org" + source: hosted + version: "1.10.0" + stream_channel: + dependency: transitive + description: + name: stream_channel + url: "https://pub.dartlang.org" + source: hosted + version: "1.7.0" + string_scanner: + dependency: transitive + description: + name: string_scanner + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.1" + term_glyph: + dependency: transitive + description: + name: term_glyph + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + test: + dependency: "direct dev" + description: + name: test + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.4" + typed_data: + dependency: transitive + description: + name: typed_data + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.0" + vm_service_client: + dependency: transitive + description: + name: vm_service_client + url: "https://pub.dartlang.org" + source: hosted + version: "0.2.6+3" + watcher: + dependency: transitive + description: + name: watcher + url: "https://pub.dartlang.org" + source: hosted + version: "0.9.7+15" + web_socket_channel: + dependency: transitive + description: + name: web_socket_channel + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + yaml: + dependency: transitive + description: + name: yaml + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.1" +sdks: + dart: ">=2.16.0-100.0.dev <3.0.0" diff --git a/dev_packages/flutter_inappwebview_internal_annotations/pubspec.yaml b/dev_packages/flutter_inappwebview_internal_annotations/pubspec.yaml new file mode 100755 index 00000000..8ddd6cfc --- /dev/null +++ b/dev_packages/flutter_inappwebview_internal_annotations/pubspec.yaml @@ -0,0 +1,10 @@ +name: flutter_inappwebview_internal_annotations +description: A Flutter plugin that allows you to add an inline webview, to use an headless webview, and to open an in-app browser window. +version: 1.0.0 +homepage: https://github.com/pichillilorenzo/flutter_inappwebview + +environment: + sdk: ">=2.14.0 <3.0.0" + +dev_dependencies: + test: 1.3.4 \ No newline at end of file diff --git a/dev_packages/generators/build.yaml b/dev_packages/generators/build.yaml new file mode 100644 index 00000000..947f4051 --- /dev/null +++ b/dev_packages/generators/build.yaml @@ -0,0 +1,21 @@ +targets: + $default: + builders: + generators|flutter_inappwebview_internal_annotations: + enabled: true + +builders: + generators: + target: ":generators" + # 1 + import: "package:generators/builder.dart" + # 2 + builder_factories: ["generateExchangeableObject", "generateExchangeableEnum"] + # 3 + build_extensions: { ".dart": [".g.dart"] } + auto_apply: dependents + build_to: cache + applies_builders: ["source_gen|combining_builder"] + defaults: + generate_for: + - lib/src/**.dart diff --git a/dev_packages/generators/lib/builder.dart b/dev_packages/generators/lib/builder.dart new file mode 100644 index 00000000..17283b72 --- /dev/null +++ b/dev_packages/generators/lib/builder.dart @@ -0,0 +1,10 @@ +import 'package:build/build.dart'; +import 'package:source_gen/source_gen.dart'; +import 'src/exchangeable_object_generator.dart'; +import 'src/exchangeable_enum_generator.dart'; + +Builder generateExchangeableObject(BuilderOptions options) => + SharedPartBuilder([ExchangeableObjectGenerator()], 'exchangeable_object'); + +Builder generateExchangeableEnum(BuilderOptions options) => + SharedPartBuilder([ExchangeableEnumGenerator()], 'exchangeable_enum'); diff --git a/dev_packages/generators/lib/generators.dart b/dev_packages/generators/lib/generators.dart new file mode 100644 index 00000000..a436ea17 --- /dev/null +++ b/dev_packages/generators/lib/generators.dart @@ -0,0 +1 @@ +library generators; diff --git a/dev_packages/generators/lib/src/exchangeable_enum_generator.dart b/dev_packages/generators/lib/src/exchangeable_enum_generator.dart new file mode 100644 index 00000000..5fdc5af3 --- /dev/null +++ b/dev_packages/generators/lib/src/exchangeable_enum_generator.dart @@ -0,0 +1,270 @@ +import 'package:build/src/builder/build_step.dart'; +import 'package:analyzer/dart/element/element.dart'; +import 'package:analyzer/dart/analysis/results.dart'; +import 'package:source_gen/source_gen.dart'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; +import 'package:analyzer/dart/constant/value.dart'; + +import 'model_visitor.dart'; +import 'util.dart'; + +final _coreCheckerEnumSupportedPlatforms = + const TypeChecker.fromRuntime(EnumSupportedPlatforms); +final _coreCheckerDeprecated = const TypeChecker.fromRuntime(Deprecated); + +class ExchangeableEnumGenerator + extends GeneratorForAnnotation { + @override + String generateForAnnotatedElement( + Element element, ConstantReader annotation, BuildStep buildStep) { + final visitor = ModelVisitor(); + // Visits all the children of element in no particular order. + element.visitChildren(visitor); + + final className = visitor.constructor.returnType.element.name; + // remove "_" to generate the correct class name + final extClassName = className.replaceFirst("_", ""); + + final classBuffer = StringBuffer(); + final classDocs = + visitor.constructor.returnType.element.documentationComment; + if (classDocs != null) { + classBuffer.writeln(classDocs); + } + final classSupportedDocs = Util.getSupportedDocs( + _coreCheckerEnumSupportedPlatforms, + visitor.constructor.returnType.element); + if (classSupportedDocs != null) { + classBuffer.writeln(classSupportedDocs); + } + if (visitor.constructor.returnType.element.hasDeprecated) { + classBuffer.writeln( + "@Deprecated('${_coreCheckerDeprecated.firstAnnotationOfExact(visitor.constructor.returnType.element)?.getField("message")?.toStringValue()}')"); + } + classBuffer.writeln('class $extClassName {'); + + final FieldElement enumValue = visitor.fields.entries + .firstWhere((element) => element.key == "_value") + .value; + final FieldElement enumNativeValue = visitor.fields.entries + .firstWhere((element) => element.key == "_nativeValue", + orElse: () => MapEntry("_nativeValue", enumValue)) + .value; + + classBuffer.writeln("final ${enumValue.type} _value;"); + classBuffer.writeln("final ${enumNativeValue.type} _nativeValue;"); + + classBuffer.writeln( + "const $extClassName._internal(this._value, this._nativeValue);"); + classBuffer.writeln("// ignore: unused_element"); + classBuffer.writeln( + "factory $extClassName._internalMultiPlatform(${enumValue.type} value, Function nativeValue) => $extClassName._internal(value, nativeValue());"); + + for (final entry in visitor.fields.entries) { + final fieldName = entry.key; + final fieldElement = entry.value; + if (fieldName == "_value" || fieldName == "_nativeValue") { + continue; + } + final docs = fieldElement.documentationComment; + if (docs != null) { + classBuffer.writeln(docs); + } + final fieldSupportedDocs = Util.getSupportedDocs( + _coreCheckerEnumSupportedPlatforms, fieldElement); + if (fieldSupportedDocs != null) { + classBuffer.writeln(fieldSupportedDocs); + } + if (fieldName == '_value' || fieldName == '_nativeValue') { + classBuffer.writeln( + "final ${fieldElement.type.toString().replaceFirst("_", "")} $fieldName;"); + } else { + final fieldValue = + fieldElement.computeConstantValue()?.getField("_value"); + final constantValue = fieldValue != null && !fieldValue.isNull + ? fieldValue.toIntValue() ?? "\'${fieldValue.toStringValue()}\'" + : null; + + final fieldAnnotation = _coreCheckerEnumSupportedPlatforms + .firstAnnotationOfExact(fieldElement); + if (fieldAnnotation != null) { + final defaultField = fieldAnnotation.getField('defaultValue')!; + final defaultValue = !defaultField.isNull + ? defaultField.toIntValue() ?? "'${defaultField.toStringValue()}'" + : null; + + var nativeValueBody = "() {"; + nativeValueBody += "switch (defaultTargetPlatform) {"; + final platforms = + fieldAnnotation.getField('platforms')?.toListValue() ?? + []; + var hasWebSupport = false; + var webSupportValue = null; + if (platforms.isNotEmpty) { + for (var platform in platforms) { + final targetPlatformName = + platform.getField("targetPlatformName")!.toStringValue(); + final platformValueField = platform.getField('value'); + final platformValue = + platformValueField != null && !platformValueField.isNull + ? platformValueField.toIntValue() ?? + "'${platformValueField.toStringValue()}'" + : null; + if (targetPlatformName == "web") { + hasWebSupport = true; + webSupportValue = platformValue; + continue; + } + nativeValueBody += "case TargetPlatform.$targetPlatformName:"; + nativeValueBody += "return $platformValue;"; + } + nativeValueBody += "default:"; + nativeValueBody += "break;"; + } + nativeValueBody += "}"; + if (hasWebSupport) { + nativeValueBody += "if (kIsWeb) {"; + nativeValueBody += "return $webSupportValue;"; + nativeValueBody += "}"; + } + nativeValueBody += "return $defaultValue;"; + nativeValueBody += "}"; + + classBuffer.writeln( + "static final $fieldName = $extClassName._internalMultiPlatform($constantValue, $nativeValueBody);"); + } else { + classBuffer.writeln( + "static const $fieldName = $extClassName._internal($constantValue, $constantValue);"); + } + } + } + + if (annotation.read("valuesProperty").boolValue) { + classBuffer.writeln('///Set of all values of [$extClassName].'); + classBuffer.writeln('static final Set<$extClassName> values = ['); + for (final entry in visitor.fields.entries) { + final fieldName = entry.key; + final fieldElement = entry.value; + if (!fieldElement.isPrivate && fieldElement.isStatic) { + classBuffer.writeln('$extClassName.$fieldName,'); + } + } + classBuffer.writeln('].toSet();'); + } + + if (annotation.read("fromValueMethod").boolValue && !visitor.methods.containsKey("fromValue")) { + final hasBitwiseOrOperator = + annotation.read("bitwiseOrOperator").boolValue; + classBuffer.writeln(""" + ///Gets a possible [$extClassName] instance from [${enumValue.type}] value. + static $extClassName? fromValue(${enumValue.type}${!Util.typeIsNullable(enumValue.type) ? '?' : ''} value) { + if (value != null) { + try { + return $extClassName.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return ${!hasBitwiseOrOperator ? 'null' : "$extClassName._internal(value, value)"}; + } + } + return null; + } + """); + } + + if (annotation.read("fromNativeValueMethod").boolValue && !visitor.methods.containsKey("fromNativeValue")) { + final hasBitwiseOrOperator = + annotation.read("bitwiseOrOperator").boolValue; + classBuffer.writeln(""" + ///Gets a possible [$extClassName] instance from a native value. + static $extClassName? fromNativeValue(${enumNativeValue.type}${!Util.typeIsNullable(enumNativeValue.type) ? '?' : ''} value) { + if (value != null) { + try { + return $extClassName.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return ${!hasBitwiseOrOperator ? 'null' : "$extClassName._internal(value, value)"}; + } + } + return null; + } + """); + } + + for (final entry in visitor.methods.entries) { + final methodElement = entry.value; + ParsedLibraryResult parsed = methodElement.session?.getParsedLibraryByElement(methodElement.library) as ParsedLibraryResult; + final methodBody = parsed.getElementDeclaration(methodElement)?.node; + if (methodBody != null) { + final docs = methodElement.documentationComment; + if (docs != null) { + classBuffer.writeln(docs); + } + final fieldSupportedDocs = + Util.getSupportedDocs(_coreCheckerEnumSupportedPlatforms, methodElement); + if (fieldSupportedDocs != null) { + classBuffer.writeln(fieldSupportedDocs); + } + classBuffer.writeln(methodBody); + } + } + + if (annotation.read("toValueMethod").boolValue && !visitor.methods.containsKey("toValue")) { + classBuffer.writeln(""" + ///Gets [${enumValue.type}] value. + ${enumValue.type} toValue() => _value; + """); + } + + if (annotation.read("toNativeValueMethod").boolValue && !visitor.methods.containsKey("toNativeValue")) { + classBuffer.writeln(""" + ///Gets [${enumNativeValue.type}] native value. + ${enumNativeValue.type} toNativeValue() => _nativeValue; + """); + } + + if (annotation.read("hashCodeMethod").boolValue && !visitor.fields.containsKey("hashCode")) { + classBuffer.writeln(""" + @override + int get hashCode => _value.hashCode; + """); + } + + if (annotation.read("equalsOperator").boolValue) { + classBuffer.writeln(""" + @override + bool operator ==(value) => value == _value; + """); + } + + if (annotation.read("bitwiseOrOperator").boolValue) { + classBuffer.writeln( + "$extClassName operator |($extClassName value) => $extClassName._internal(value.toValue() | _value, value.toNativeValue() | _nativeValue);"); + } + + if (annotation.read("toStringMethod").boolValue && !visitor.methods.containsKey("toString")) { + classBuffer.writeln('@override'); + classBuffer.writeln('String toString() {'); + if (enumValue.type.isDartCoreString) { + classBuffer.writeln('return _value;'); + } else { + classBuffer.writeln('switch(_value) {'); + for (final entry in visitor.fields.entries) { + final fieldName = entry.key; + final fieldElement = entry.value; + if (!fieldElement.isPrivate && fieldElement.isStatic) { + final fieldValue = + fieldElement.computeConstantValue()?.getField("_value"); + final constantValue = fieldValue?.toIntValue(); + classBuffer.writeln("case $constantValue: return '$fieldName';"); + } + } + classBuffer.writeln('}'); + classBuffer.writeln('return _value.toString();'); + } + classBuffer.writeln('}'); + } + + classBuffer.writeln('}'); + return classBuffer.toString(); + } +} diff --git a/dev_packages/generators/lib/src/exchangeable_object_generator.dart b/dev_packages/generators/lib/src/exchangeable_object_generator.dart new file mode 100644 index 00000000..5e67f491 --- /dev/null +++ b/dev_packages/generators/lib/src/exchangeable_object_generator.dart @@ -0,0 +1,676 @@ +import 'package:build/src/builder/build_step.dart'; +import 'package:analyzer/dart/element/element.dart'; +import 'package:analyzer/dart/analysis/results.dart'; +import 'package:analyzer/dart/element/type.dart'; +import 'package:source_gen/source_gen.dart'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +import 'model_visitor.dart'; +import 'util.dart'; + +final _coreChecker = const TypeChecker.fromRuntime(ExchangeableObject); +final _coreCheckerObjectConstructor = + const TypeChecker.fromRuntime(ExchangeableObjectConstructor); +final _coreCheckerObjectProperty = + const TypeChecker.fromRuntime(ExchangeableObjectProperty); +final _coreCheckerEnum = const TypeChecker.fromRuntime(ExchangeableEnum); +final _coreCheckerDeprecated = const TypeChecker.fromRuntime(Deprecated); +final _coreCheckerSupportedPlatforms = + const TypeChecker.fromRuntime(SupportedPlatforms); + +class ExchangeableObjectGenerator + extends GeneratorForAnnotation { + @override + String generateForAnnotatedElement( + Element element, ConstantReader annotation, BuildStep buildStep) { + final visitor = ModelVisitor(); + // Visits all the children of element in no particular order. + element.visitChildren(visitor); + + final className = visitor.constructor.returnType.element.name; + final superClass = + visitor.constructor.returnType.superclass?.element.name != 'Object' + ? visitor.constructor.returnType.superclass + : null; + final superClassName = superClass?.element.name.replaceFirst("_", ""); + // remove "_" to generate the correct class name + final extClassName = className.replaceFirst("_", ""); + + final classBuffer = StringBuffer(); + final classDocs = + visitor.constructor.returnType.element.documentationComment; + if (classDocs != null) { + classBuffer.writeln(classDocs); + } + final classSupportedDocs = Util.getSupportedDocs( + _coreCheckerSupportedPlatforms, visitor.constructor.returnType.element); + if (classSupportedDocs != null) { + classBuffer.writeln(classSupportedDocs); + } + if (visitor.constructor.returnType.element.hasDeprecated) { + classBuffer.writeln( + "@Deprecated('${_coreCheckerDeprecated.firstAnnotationOfExact(visitor.constructor.returnType.element)?.getField("message")?.toStringValue()}')"); + } + + classBuffer.write('class $extClassName'); + if (superClass != null) { + classBuffer.writeln(' extends ${superClassName}'); + } + classBuffer.writeln(' {'); + + final deprecatedFields = []; + final constructorFields = []; + final superConstructorFields = []; + for (final entry in visitor.fields.entries) { + final fieldName = entry.key; + final fieldElement = entry.value; + if (!fieldElement.isPrivate) { + final isNullable = Util.typeIsNullable(fieldElement.type); + final constructorParameter = visitor.constructorParameters[fieldName]; + if (constructorParameter != null) { + // remove class reference terminating with "_" + var defaultValueCode = + constructorParameter.defaultValueCode?.replaceFirst("_.", "."); + var constructorField = + '${!isNullable && defaultValueCode == null ? 'required ' : ''}this.$fieldName${defaultValueCode != null ? ' = $defaultValueCode' : ''}'; + if (fieldElement.hasDeprecated) { + deprecatedFields.add(fieldElement); + constructorField = + "@Deprecated('${_coreCheckerDeprecated.firstAnnotationOfExact(fieldElement)?.getField("message")?.toStringValue()}') " + + constructorField; + } + constructorFields.add(constructorField); + } + } + final docs = fieldElement.documentationComment; + if (docs != null) { + classBuffer.writeln(docs); + } + final fieldSupportedDocs = + Util.getSupportedDocs(_coreCheckerSupportedPlatforms, fieldElement); + if (fieldSupportedDocs != null) { + classBuffer.writeln(fieldSupportedDocs); + } + if (fieldElement.hasDeprecated) { + classBuffer.writeln( + "@Deprecated('${_coreCheckerDeprecated.firstAnnotationOfExact(fieldElement)?.getField("message")?.toStringValue()}')"); + } + // remove class reference terminating with "_" + classBuffer + .write("${fieldElement.type.toString().replaceFirst("_", "")} "); + if (!fieldElement.hasInitializer) { + classBuffer.writeln("$fieldName;"); + } else { + ParsedLibraryResult parsed = fieldElement.session + ?.getParsedLibraryByElement(fieldElement.library) + as ParsedLibraryResult; + final fieldBody = parsed.getElementDeclaration(fieldElement)?.node; + classBuffer.writeln("$fieldBody;"); + } + } + + if (superClass != null) { + ConstructorElement superConstructor = superClass.constructors.first; + for (final parameter in superConstructor.parameters) { + final parameterName = parameter.name; + final parameterType = parameter.type; + final isNullable = Util.typeIsNullable(parameter.type); + // remove class reference terminating with "_" + var defaultValueCode = + parameter.defaultValueCode?.replaceFirst("_.", "."); + var constructorField = + '${!isNullable && defaultValueCode == null ? 'required ' : ''}$parameterType $parameterName${defaultValueCode != null ? ' = $defaultValueCode' : ''}'; + if (parameter.hasDeprecated) { + deprecatedFields.add(parameter); + constructorField = + "@Deprecated('${_coreCheckerDeprecated.firstAnnotationOfExact(parameter)?.getField("message")?.toStringValue()}') " + + constructorField; + } + constructorFields.add(constructorField); + superConstructorFields.add("$parameterName: $parameterName"); + } + } + + final hasCustomConstructor = + _coreCheckerObjectConstructor.hasAnnotationOf(visitor.constructor); + final constructorDocs = visitor.constructor.documentationComment; + if (constructorDocs != null) { + classBuffer.writeln(constructorDocs); + } + var constructorSupportedDocs = Util.getSupportedDocs( + _coreCheckerSupportedPlatforms, visitor.constructor); + if (constructorSupportedDocs == null) { + constructorSupportedDocs = Util.getSupportedDocs( + _coreCheckerSupportedPlatforms, + visitor.constructor.returnType.element); + } + if (constructorSupportedDocs != null) { + classBuffer.writeln(constructorSupportedDocs); + } + if (hasCustomConstructor) { + ParsedLibraryResult parsed = visitor.constructor.session + ?.getParsedLibraryByElement(visitor.constructor.library) + as ParsedLibraryResult; + final constructorBody = + parsed.getElementDeclaration(visitor.constructor)?.node; + if (constructorBody != null) { + classBuffer.writeln(constructorBody + .toString() + .replaceAll(className, extClassName) + .replaceAll("@ExchangeableObjectConstructor()", "")); + } + } else if (constructorFields.length > 0) { + classBuffer.writeln('$extClassName({'); + classBuffer.writeln(constructorFields.join(', ')); + } else { + classBuffer.writeln('$extClassName('); + } + + if (!hasCustomConstructor && constructorFields.length > 0) { + classBuffer.write('})'); + } else if (!hasCustomConstructor) { + classBuffer.write(')'); + } + + if (superClass != null) { + classBuffer.write(': super('); + if (superConstructorFields.isNotEmpty) { + classBuffer.write('${superConstructorFields.join(", ")}'); + } + classBuffer.write(')'); + } + + if (!hasCustomConstructor && deprecatedFields.length > 0) { + classBuffer.writeln(' {'); + for (final deprecatedField in deprecatedFields) { + final deprecatedFieldName = deprecatedField.name; + final message = _coreCheckerDeprecated + .firstAnnotationOfExact(deprecatedField)! + .getField("message")! + .toStringValue()!; + final fieldName = message + .replaceFirst("Use ", "") + .replaceFirst(" instead", "") + .trim(); + final fieldElement = visitor.fields[fieldName]!; + final fieldTypeElement = fieldElement.type.element; + final deprecatedFieldTypeElement = deprecatedField.type.element; + + classBuffer.write('$fieldName = $fieldName ?? '); + if (fieldTypeElement != null && deprecatedFieldTypeElement != null) { + final isNullable = Util.typeIsNullable(fieldElement.type); + final deprecatedIsNullable = Util.typeIsNullable(deprecatedField.type); + final hasFromMap = hasFromMapMethod(fieldTypeElement); + final hasFromNativeValue = hasFromNativeValueMethod(fieldTypeElement); + final hasFromValue = hasFromValueMethod(fieldTypeElement); + final deprecatedHasToMap = hasFromMapMethod(deprecatedFieldTypeElement); + final deprecatedHasToNativeValue = hasToNativeValueMethod(deprecatedFieldTypeElement); + final deprecatedHasToValue = hasToValueMethod(deprecatedFieldTypeElement); + if (hasFromMap && deprecatedHasToMap) { + final hasNullableFromMap = hasNullableFromMapFactory(fieldTypeElement); + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + ".fromMap($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toMap())${!isNullable && hasNullableFromMap ? '!' : ''}"); + } else if (hasFromNativeValue && deprecatedHasToNativeValue) { + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + '.fromNativeValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toNativeValue())${!isNullable ? '!' : ''}'); + } else if (hasFromValue && deprecatedHasToValue) { + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + '.fromValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toValue())${!isNullable ? '!' : ''}'); + } else { + classBuffer.write(deprecatedFieldName); + } + } else { + classBuffer.write(deprecatedFieldName); + } + classBuffer.writeln(';'); + } + classBuffer.writeln('}'); + } else if (!hasCustomConstructor) { + classBuffer.writeln(';'); + } + + if (annotation.read("fromMapFactory").boolValue && + !visitor.methods.containsKey("fromMap")) { + classBuffer.writeln( + '///Gets a possible [$extClassName] instance from a [Map] value.'); + final nullable = annotation.read("nullableFromMapFactory").boolValue; + classBuffer + .writeln('static $extClassName${nullable ? '?' : ''} fromMap('); + classBuffer.writeln('Map${nullable ? '?' : ''} map'); + classBuffer.writeln(') {'); + if (nullable) { + classBuffer.writeln('if (map == null) { return null; }'); + } + classBuffer.writeln('final instance = $extClassName('); + final fieldElements = []; + if (superClass != null) { + fieldElements.addAll(superClass.element.fields); + } + fieldElements.addAll(visitor.fields.values); + final nonRequiredFields = []; + final requiredFields = []; + for (final fieldElement in fieldElements) { + final fieldName = fieldElement.name; + if (!fieldElement.isPrivate) { + var value = "map['$fieldName']"; + final deprecationMessage = _coreCheckerDeprecated + .firstAnnotationOfExact(fieldElement) + ?.getField("message") + ?.toStringValue(); + if (deprecationMessage != null) { + final newFieldName = deprecationMessage + .replaceFirst("Use ", "") + .replaceFirst(" instead", "") + .trim(); + value = "map['$newFieldName']"; + } + + final customDeserializer = _coreCheckerObjectProperty + .firstAnnotationOf(fieldElement) + ?.getField("deserializer") + ?.toFunctionValue(); + if (customDeserializer != null) { + final deserializerClassName = customDeserializer.enclosingElement.name; + if (deserializerClassName != null) { + value = "$deserializerClassName.${customDeserializer.name}($value)"; + } else { + value = "${customDeserializer.name}($value)"; + } + } else { + value = getFromMapValue(value, fieldElement.type); + } + final constructorParameter = + visitor.constructorParameters[fieldName]; + final isRequiredParameter = constructorParameter != null && + (constructorParameter.isRequiredNamed || + !Util.typeIsNullable(constructorParameter.type)) && + !constructorParameter.hasDefaultValue; + if (isRequiredParameter) { + requiredFields.add('$fieldName: $value,'); + } else { + nonRequiredFields.add("instance.$fieldName = $value;"); + } + } + } + classBuffer.writeln(requiredFields.join("\n") + ');'); + if (nonRequiredFields.isNotEmpty) { + classBuffer.writeln(nonRequiredFields.join("\n")); + } + classBuffer.writeln('return instance;'); + classBuffer.writeln('}'); + } + + for (final entry in visitor.methods.entries) { + final methodElement = entry.value; + ParsedLibraryResult parsed = methodElement.session + ?.getParsedLibraryByElement(methodElement.library) + as ParsedLibraryResult; + final methodBody = parsed.getElementDeclaration(methodElement)?.node; + if (methodBody != null) { + final docs = methodElement.documentationComment; + if (docs != null) { + classBuffer.writeln(docs); + } + final fieldSupportedDocs = Util.getSupportedDocs( + _coreCheckerSupportedPlatforms, methodElement); + if (fieldSupportedDocs != null) { + classBuffer.writeln(fieldSupportedDocs); + } + classBuffer + .writeln(methodBody.toString().replaceAll(className, extClassName)); + } + } + + if (annotation.read("toMapMethod").boolValue && + !visitor.methods.containsKey("toMap")) { + classBuffer.writeln('///Converts instance to a map.'); + classBuffer.writeln('Map toMap() {'); + classBuffer.writeln('return {'); + final fieldElements = []; + if (superClass != null) { + for (final fieldElement in superClass.element.fields) { + if (!fieldElement.isPrivate && !fieldElement.hasDeprecated) { + fieldElements.add(fieldElement); + } + } + } + for (final entry in visitor.fields.entries) { + final fieldElement = entry.value; + if (!fieldElement.isPrivate && !fieldElement.hasDeprecated) { + fieldElements.add(fieldElement); + } + } + for (final fieldElement in fieldElements) { + if (!fieldElement.isPrivate && !fieldElement.hasDeprecated) { + final fieldName = fieldElement.name; + var mapValue = fieldName; + final customSerializer = _coreCheckerObjectProperty + .firstAnnotationOf(fieldElement) + ?.getField("serializer") + ?.toFunctionValue(); + if (customSerializer != null) { + final serializerClassName = customSerializer.enclosingElement.name; + if (serializerClassName != null) { + mapValue = "$serializerClassName.${customSerializer.name}($mapValue)"; + } else { + mapValue = "${customSerializer.name}($mapValue)"; + } + } else { + mapValue = getToMapValue(fieldName, fieldElement.type); + } + + classBuffer.writeln('"$fieldName": $mapValue,'); + } + } + classBuffer.writeln('};'); + classBuffer.writeln('}'); + } + + if (annotation.read("toJsonMethod").boolValue && + !visitor.methods.containsKey("toJson")) { + classBuffer.writeln('///Converts instance to a map.'); + classBuffer.writeln('Map toJson() {'); + classBuffer.writeln('return toMap();'); + classBuffer.writeln('}'); + } + + if (annotation.read("toStringMethod").boolValue && + !visitor.methods.containsKey("toString")) { + classBuffer.writeln('@override'); + classBuffer.writeln('String toString() {'); + classBuffer.write('return \'$extClassName{'); + final fieldNames = []; + if (superClass != null) { + for (final fieldElement in superClass.element.fields) { + final fieldName = fieldElement.name; + if (!fieldElement.isPrivate && !fieldElement.hasDeprecated) { + fieldNames.add('$fieldName: \$$fieldName'); + } + } + } + for (final entry in visitor.fields.entries) { + final fieldName = entry.key; + final fieldElement = entry.value; + if (!fieldElement.isPrivate && !fieldElement.hasDeprecated) { + fieldNames.add('$fieldName: \$$fieldName'); + } + } + classBuffer.write(fieldNames.join(', ')); + classBuffer.writeln('}\';'); + classBuffer.writeln('}'); + } + + classBuffer.writeln('}'); + return classBuffer.toString(); + } + + String getFromMapValue(String value, DartType elementType) { + final fieldTypeElement = elementType.element; + final isNullable = Util.typeIsNullable(elementType); + if (elementType.getDisplayString(withNullability: false) == "Uri") { + if (!isNullable) { + return "Uri.parse($value)!"; + } else { + return "$value != null ? Uri.parse($value) : null"; + } + } else if (elementType.getDisplayString(withNullability: false) == + "Color") { + if (!isNullable) { + return "UtilColor.fromStringRepresentation($value)!"; + } else { + return "$value != null ? UtilColor.fromStringRepresentation($value) : null"; + } + } else if (elementType.getDisplayString(withNullability: false) == + "DateTime") { + if (!isNullable) { + return "DateTime.fromMillisecondsSinceEpoch($value)!"; + } else { + return "$value != null ? DateTime.fromMillisecondsSinceEpoch($value) : null"; + } + } else if (elementType.isDartCoreList || elementType.isDartCoreSet) { + final genericType = Util.getGenericTypes(elementType).first; + if (!Util.isDartCoreType(genericType)) { + final genericTypeFieldName = 'e'; + return value + + (isNullable ? '?' : '') + + '.forEach(($genericTypeFieldName) => ' + + getFromMapValue('$genericTypeFieldName', genericType) + + ')'; + } else { + return value; + } + } else if (fieldTypeElement != null && hasFromMapMethod(fieldTypeElement)) { + final hasNullableFromMap = hasNullableFromMapFactory(fieldTypeElement); + // remove class reference terminating with "_" + return fieldTypeElement.name!.replaceFirst("_", "") + + ".fromMap($value?.cast())${!isNullable && hasNullableFromMap ? '!' : ''}"; + } else { + final hasFromValue = + fieldTypeElement != null && hasFromValueMethod(fieldTypeElement); + final hasFromNativeValue = fieldTypeElement != null && + hasFromNativeValueMethod(fieldTypeElement); + if (fieldTypeElement != null && (hasFromValue || hasFromNativeValue)) { + if (hasFromNativeValue) { + // remove class reference terminating with "_" + value = fieldTypeElement.name!.replaceFirst("_", "") + + '.fromNativeValue($value)'; + } else { + // remove class reference terminating with "_" + value = fieldTypeElement.name!.replaceFirst("_", "") + + '.fromValue($value)'; + } + if (!isNullable) { + value += '!'; + } + return value; + } + } + + return value; + } + + String getToMapValue(String fieldName, DartType elementType) { + final fieldTypeElement = elementType.element; + final isNullable = Util.typeIsNullable(elementType); + if (elementType.getDisplayString(withNullability: false) == "Uri") { + return fieldName + (isNullable ? '?' : '') + '.toString()'; + } else if (elementType.getDisplayString(withNullability: false) == + "Color") { + return fieldName + (isNullable ? '?' : '') + '.toHex()'; + } else if (elementType.getDisplayString(withNullability: false) == + "DateTime") { + return fieldName + (isNullable ? '?' : '') + '.millisecondsSinceEpoch'; + } else if (elementType.isDartCoreList || elementType.isDartCoreSet) { + final genericType = Util.getGenericTypes(elementType).first; + if (!Util.isDartCoreType(genericType)) { + final genericTypeFieldName = 'e'; + return fieldName + + (isNullable ? '?' : '') + + '.map(($genericTypeFieldName) => ' + + getToMapValue('$genericTypeFieldName', genericType) + + ').toList()'; + } else { + + return fieldName; + } + } else if (fieldTypeElement != null && hasToMapMethod(fieldTypeElement)) { + return fieldName + + (Util.typeIsNullable(elementType) ? '?' : '') + + '.toMap()'; + } else { + final hasToValue = + fieldTypeElement != null && hasToValueMethod(fieldTypeElement); + final hasToNativeValue = + fieldTypeElement != null && hasToNativeValueMethod(fieldTypeElement); + if (fieldTypeElement != null && (hasToValue || hasToNativeValue)) { + if (hasToNativeValue) { + return fieldName + (isNullable ? '?' : '') + '.toNativeValue()'; + } else { + return fieldName + (isNullable ? '?' : '') + '.toValue()'; + } + } + } + + return fieldName; + } + + bool hasToMapMethod(Element element) { + final hasAnnotation = _coreChecker.hasAnnotationOf(element); + final toMapMethod = _coreChecker + .firstAnnotationOfExact(element) + ?.getField('toMapMethod') + ?.toBoolValue() ?? + false; + if (hasAnnotation && toMapMethod) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "toMap") { + return true; + } + } + + return false; + } + + bool hasFromMapMethod(Element element) { + final hasAnnotation = _coreChecker.hasAnnotationOf(element); + final fromMapFactory = _coreChecker + .firstAnnotationOfExact(element) + ?.getField('fromMapFactory') + ?.toBoolValue() ?? + false; + if (hasAnnotation && fromMapFactory) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "fromMap") { + return true; + } + } + + return false; + } + + bool hasNullableFromMapFactory(Element element) { + final hasAnnotation = _coreChecker.hasAnnotationOf(element); + final fromMapFactory = _coreChecker + .firstAnnotationOfExact(element) + ?.getField('fromMapFactory') + ?.toBoolValue() ?? + false; + final nullableFromMapFactory = _coreChecker + .firstAnnotationOfExact(element) + ?.getField('nullableFromMapFactory') + ?.toBoolValue() ?? + false; + if (hasAnnotation && fromMapFactory && nullableFromMapFactory) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "fromMap" && + Util.typeIsNullable(entry.value.returnType)) { + return true; + } + } + + return false; + } + + bool hasFromValueMethod(Element element) { + final hasAnnotation = _coreCheckerEnum.hasAnnotationOf(element); + final fromValueMethod = _coreCheckerEnum + .firstAnnotationOfExact(element) + ?.getField('fromValueMethod') + ?.toBoolValue() ?? + false; + if (hasAnnotation && fromValueMethod) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "fromValue") { + return true; + } + } + + return false; + } + + bool hasFromNativeValueMethod(Element element) { + final hasAnnotation = _coreCheckerEnum.hasAnnotationOf(element); + final fromNativeValueMethod = _coreCheckerEnum + .firstAnnotationOfExact(element) + ?.getField('fromNativeValueMethod') + ?.toBoolValue() ?? + false; + if (hasAnnotation && fromNativeValueMethod) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "fromNativeValue") { + return true; + } + } + + return false; + } + + bool hasToValueMethod(Element element) { + final hasAnnotation = _coreCheckerEnum.hasAnnotationOf(element); + final hasToValueMethod = _coreCheckerEnum + .firstAnnotationOfExact(element) + ?.getField('toValueMethod') + ?.toBoolValue() ?? + false; + if (hasAnnotation && hasToValueMethod) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "toValue") { + return true; + } + } + + return false; + } + + bool hasToNativeValueMethod(Element element) { + final hasAnnotation = _coreCheckerEnum.hasAnnotationOf(element); + final hasToNativeValueMethod = _coreCheckerEnum + .firstAnnotationOfExact(element) + ?.getField('toNativeValueMethod') + ?.toBoolValue() ?? + false; + if (hasAnnotation && hasToNativeValueMethod) { + return true; + } + + final fieldVisitor = ModelVisitor(); + element.visitChildren(fieldVisitor); + for (var entry in fieldVisitor.methods.entries) { + if (entry.key == "toNativeValue") { + return true; + } + } + + return false; + } +} diff --git a/dev_packages/generators/lib/src/model_visitor.dart b/dev_packages/generators/lib/src/model_visitor.dart new file mode 100644 index 00000000..850e84c3 --- /dev/null +++ b/dev_packages/generators/lib/src/model_visitor.dart @@ -0,0 +1,27 @@ +import 'package:analyzer/dart/element/visitor.dart'; +import 'package:analyzer/dart/element/element.dart'; + +class ModelVisitor extends SimpleElementVisitor { + late ConstructorElement constructor; + final constructorParameters = {}; + final fields = {}; + final methods = {}; + + @override + void visitConstructorElement(ConstructorElement element) { + constructor = element; + for (final param in element.parameters) { + constructorParameters.putIfAbsent(param.name, () => param); + } + } + + @override + void visitFieldElement(FieldElement element) { + fields[element.name] = element; + } + + @override + void visitMethodElement(MethodElement element) { + methods[element.name] = element; + } +} diff --git a/dev_packages/generators/lib/src/util.dart b/dev_packages/generators/lib/src/util.dart new file mode 100644 index 00000000..7be8ff41 --- /dev/null +++ b/dev_packages/generators/lib/src/util.dart @@ -0,0 +1,91 @@ +import 'package:analyzer/dart/element/element.dart'; +import 'package:source_gen/source_gen.dart'; +import 'package:analyzer/dart/element/type.dart'; +import 'package:analyzer/dart/element/nullability_suffix.dart'; +import 'package:analyzer/dart/constant/value.dart'; + +abstract class Util { + static bool typeIsNullable(DartType type) { + return type.nullabilitySuffix != NullabilitySuffix.none || + type.toString() == 'dynamic'; + } + + static String? getSupportedDocs(TypeChecker checker, Element element) { + final platformNoteList = []; + final platformSupportedList = []; + final platforms = checker + .firstAnnotationOfExact(element) + ?.getField('platforms') + ?.toListValue() ?? + []; + for (var platform in platforms) { + final platformName = platform.getField("name")!.toStringValue(); + final note = platform.getField("note")?.toStringValue(); + if (note != null) { + platformNoteList.add("///**NOTE for $platformName**: $note"); + } + + final apiName = platform.getField("apiName")?.toStringValue(); + final apiUrl = platform.getField("apiUrl")?.toStringValue(); + final available = platform.getField("available")?.toStringValue(); + final requiresSameOrigin = + platform.getField("requiresSameOrigin")?.toBoolValue() ?? false; + var api = available != null ? "$available+ " : ""; + if (requiresSameOrigin) { + api += "but iframe requires same origin "; + } + if (apiName != null && apiUrl != null) { + api += "([Official API - $apiName]($apiUrl))"; + } else if (apiName != null) { + api += "(Official API - $apiName)"; + } else if (apiUrl != null) { + api += "([Official API]($apiUrl))"; + } + platformSupportedList.add("///- $platformName $api"); + } + if (platformSupportedList.isNotEmpty) { + if (platformNoteList.isNotEmpty) { + return """/// + ${platformNoteList.join("\n///\n")} + /// + ///**Supported Platforms/Implementations**: + ${platformSupportedList.join("\n")}"""; + } else { + return """/// + ///**Supported Platforms/Implementations**: + ${platformSupportedList.join("\n")}"""; + } + } + return null; + } + + static Iterable getGenericTypes(DartType type) { + return type is ParameterizedType ? type.typeArguments : const []; + } + + static bool canHaveGenerics(DartType type) { + final element = type.element; + if (element is ClassElement) { + return element.typeParameters.isNotEmpty; + } + return false; + } + + static bool isDartCoreType(DartType type) { + return type.isDartCoreBool || + type.isDartCoreDouble || + type.isDartCoreEnum || + type.isDartCoreFunction || + type.isDartCoreInt || + type.isDartCoreIterable || + type.isDartCoreList || + type.isDartCoreMap || + type.isDartCoreNull || + type.isDartCoreNum || + type.isDartCoreObject || + type.isDartCoreSet || + type.isDartCoreString || + type.isDartCoreSymbol || + type.isDynamic; + } +} diff --git a/dev_packages/generators/pubspec.lock b/dev_packages/generators/pubspec.lock new file mode 100644 index 00000000..b47fe7bb --- /dev/null +++ b/dev_packages/generators/pubspec.lock @@ -0,0 +1,513 @@ +# Generated by pub +# See https://dart.dev/tools/pub/glossary#lockfile +packages: + _fe_analyzer_shared: + dependency: transitive + description: + name: _fe_analyzer_shared + url: "https://pub.dartlang.org" + source: hosted + version: "39.0.0" + analyzer: + dependency: transitive + description: + name: analyzer + url: "https://pub.dartlang.org" + source: hosted + version: "4.0.0" + args: + dependency: transitive + description: + name: args + url: "https://pub.dartlang.org" + source: hosted + version: "2.3.1" + async: + dependency: transitive + description: + name: async + url: "https://pub.dartlang.org" + source: hosted + version: "2.9.0" + boolean_selector: + dependency: transitive + description: + name: boolean_selector + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + build: + dependency: "direct main" + description: + name: build + url: "https://pub.dartlang.org" + source: hosted + version: "2.3.0" + build_config: + dependency: transitive + description: + name: build_config + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.0" + build_daemon: + dependency: transitive + description: + name: build_daemon + url: "https://pub.dartlang.org" + source: hosted + version: "3.1.0" + build_resolvers: + dependency: transitive + description: + name: build_resolvers + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.8" + build_runner: + dependency: "direct dev" + description: + name: build_runner + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.10" + build_runner_core: + dependency: transitive + description: + name: build_runner_core + url: "https://pub.dartlang.org" + source: hosted + version: "7.2.3" + build_test: + dependency: "direct dev" + description: + name: build_test + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.5" + built_collection: + dependency: transitive + description: + name: built_collection + url: "https://pub.dartlang.org" + source: hosted + version: "5.1.1" + built_value: + dependency: transitive + description: + name: built_value + url: "https://pub.dartlang.org" + source: hosted + version: "8.3.0" + characters: + dependency: transitive + description: + name: characters + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + charcode: + dependency: transitive + description: + name: charcode + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.1" + checked_yaml: + dependency: transitive + description: + name: checked_yaml + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.1" + code_builder: + dependency: transitive + description: + name: code_builder + url: "https://pub.dartlang.org" + source: hosted + version: "4.1.0" + collection: + dependency: transitive + description: + name: collection + url: "https://pub.dartlang.org" + source: hosted + version: "1.15.0" + convert: + dependency: transitive + description: + name: convert + url: "https://pub.dartlang.org" + source: hosted + version: "3.0.1" + coverage: + dependency: transitive + description: + name: coverage + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.1" + crypto: + dependency: transitive + description: + name: crypto + url: "https://pub.dartlang.org" + source: hosted + version: "3.0.2" + csslib: + dependency: transitive + description: + name: csslib + url: "https://pub.dartlang.org" + source: hosted + version: "0.17.1" + dart_style: + dependency: transitive + description: + name: dart_style + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.3" + file: + dependency: transitive + description: + name: file + url: "https://pub.dartlang.org" + source: hosted + version: "6.1.2" + fixnum: + dependency: transitive + description: + name: fixnum + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + flutter: + dependency: "direct main" + description: flutter + source: sdk + version: "0.0.0" + flutter_inappwebview_internal_annotations: + dependency: "direct main" + description: + path: "../flutter_inappwebview_internal_annotations" + relative: true + source: path + version: "1.0.0" + frontend_server_client: + dependency: transitive + description: + name: frontend_server_client + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.2" + glob: + dependency: transitive + description: + name: glob + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.2" + graphs: + dependency: transitive + description: + name: graphs + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + html: + dependency: transitive + description: + name: html + url: "https://pub.dartlang.org" + source: hosted + version: "0.15.0" + http_multi_server: + dependency: transitive + description: + name: http_multi_server + url: "https://pub.dartlang.org" + source: hosted + version: "3.2.0" + http_parser: + dependency: transitive + description: + name: http_parser + url: "https://pub.dartlang.org" + source: hosted + version: "4.0.0" + io: + dependency: transitive + description: + name: io + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.3" + js: + dependency: transitive + description: + name: js + url: "https://pub.dartlang.org" + source: hosted + version: "0.6.4" + json_annotation: + dependency: transitive + description: + name: json_annotation + url: "https://pub.dartlang.org" + source: hosted + version: "4.5.0" + logging: + dependency: transitive + description: + name: logging + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.2" + matcher: + dependency: transitive + description: + name: matcher + url: "https://pub.dartlang.org" + source: hosted + version: "0.12.11" + material_color_utilities: + dependency: transitive + description: + name: material_color_utilities + url: "https://pub.dartlang.org" + source: hosted + version: "0.1.3" + meta: + dependency: transitive + description: + name: meta + url: "https://pub.dartlang.org" + source: hosted + version: "1.7.0" + mime: + dependency: transitive + description: + name: mime + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.2" + node_preamble: + dependency: transitive + description: + name: node_preamble + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.1" + package_config: + dependency: transitive + description: + name: package_config + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.2" + path: + dependency: transitive + description: + name: path + url: "https://pub.dartlang.org" + source: hosted + version: "1.8.1" + pool: + dependency: transitive + description: + name: pool + url: "https://pub.dartlang.org" + source: hosted + version: "1.5.0" + pub_semver: + dependency: transitive + description: + name: pub_semver + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.1" + pubspec_parse: + dependency: transitive + description: + name: pubspec_parse + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + shelf: + dependency: transitive + description: + name: shelf + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.0" + shelf_packages_handler: + dependency: transitive + description: + name: shelf_packages_handler + url: "https://pub.dartlang.org" + source: hosted + version: "3.0.0" + shelf_static: + dependency: transitive + description: + name: shelf_static + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.0" + shelf_web_socket: + dependency: transitive + description: + name: shelf_web_socket + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + sky_engine: + dependency: transitive + description: flutter + source: sdk + version: "0.0.99" + source_gen: + dependency: "direct main" + description: + name: source_gen + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.2" + source_map_stack_trace: + dependency: transitive + description: + name: source_map_stack_trace + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + source_maps: + dependency: transitive + description: + name: source_maps + url: "https://pub.dartlang.org" + source: hosted + version: "0.10.10" + source_span: + dependency: transitive + description: + name: source_span + url: "https://pub.dartlang.org" + source: hosted + version: "1.9.0" + stack_trace: + dependency: transitive + description: + name: stack_trace + url: "https://pub.dartlang.org" + source: hosted + version: "1.10.0" + stream_channel: + dependency: transitive + description: + name: stream_channel + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + stream_transform: + dependency: transitive + description: + name: stream_transform + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.0" + string_scanner: + dependency: transitive + description: + name: string_scanner + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.1" + term_glyph: + dependency: transitive + description: + name: term_glyph + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + test: + dependency: "direct dev" + description: + name: test + url: "https://pub.dartlang.org" + source: hosted + version: "1.21.1" + test_api: + dependency: transitive + description: + name: test_api + url: "https://pub.dartlang.org" + source: hosted + version: "0.4.9" + test_core: + dependency: transitive + description: + name: test_core + url: "https://pub.dartlang.org" + source: hosted + version: "0.4.13" + timing: + dependency: transitive + description: + name: timing + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.0" + typed_data: + dependency: transitive + description: + name: typed_data + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.0" + vector_math: + dependency: transitive + description: + name: vector_math + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.1" + vm_service: + dependency: transitive + description: + name: vm_service + url: "https://pub.dartlang.org" + source: hosted + version: "8.3.0" + watcher: + dependency: transitive + description: + name: watcher + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + web_socket_channel: + dependency: transitive + description: + name: web_socket_channel + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.0" + webkit_inspection_protocol: + dependency: transitive + description: + name: webkit_inspection_protocol + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + yaml: + dependency: transitive + description: + name: yaml + url: "https://pub.dartlang.org" + source: hosted + version: "3.1.1" +sdks: + dart: ">=2.16.0 <3.0.0" + flutter: ">=2.5.0" diff --git a/dev_packages/generators/pubspec.yaml b/dev_packages/generators/pubspec.yaml new file mode 100755 index 00000000..ae78bc72 --- /dev/null +++ b/dev_packages/generators/pubspec.yaml @@ -0,0 +1,21 @@ +name: generators +version: 1.0.0 + +publish_to: none + +environment: + sdk: ">=2.14.0 <3.0.0" + flutter: ">=2.5.0" + +dependencies: + flutter: + sdk: flutter + build: + source_gen: + flutter_inappwebview_internal_annotations: + path: ../flutter_inappwebview_internal_annotations/ + +dev_dependencies: + build_runner: + build_test: + test: ^1.21.1 \ No newline at end of file diff --git a/dev_packages/test_gen/analysis_options.yaml b/dev_packages/test_gen/analysis_options.yaml new file mode 100644 index 00000000..fb01cf49 --- /dev/null +++ b/dev_packages/test_gen/analysis_options.yaml @@ -0,0 +1,11 @@ +include: package:lints/recommended.yaml + +linter: + rules: + constant_identifier_names: ignore + +# Additional information about this file can be found at +# https://dart.dev/guides/language/analysis-options +analyzer: + errors: + deprecated_member_use_from_same_package: ignore \ No newline at end of file diff --git a/dev_packages/test_gen/lib/src/main.dart b/dev_packages/test_gen/lib/src/main.dart new file mode 100644 index 00000000..98e44e7f --- /dev/null +++ b/dev_packages/test_gen/lib/src/main.dart @@ -0,0 +1,6 @@ +import 'package:test_gen/src/types/main.dart'; +import 'package:test_gen/src/types/test_enum.dart'; + +void main() { + TestClass test = TestClass(test1: "test1", test2: TestClass2(test1: ""), actionModeMenuItem: ActionModeMenuItem.MENU_ITEM_NONE); +} \ No newline at end of file diff --git a/dev_packages/test_gen/lib/src/test/test_class_2.dart b/dev_packages/test_gen/lib/src/test/test_class_2.dart new file mode 100644 index 00000000..bdf55255 --- /dev/null +++ b/dev_packages/test_gen/lib/src/test/test_class_2.dart @@ -0,0 +1,10 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'test_class_2.g.dart'; + +@ExchangeableObject() +class TestClass2_ { + String test1; + + TestClass2_({required this.test1}); +} \ No newline at end of file diff --git a/dev_packages/test_gen/lib/src/types/main.dart b/dev_packages/test_gen/lib/src/types/main.dart new file mode 100644 index 00000000..d4476ef7 --- /dev/null +++ b/dev_packages/test_gen/lib/src/types/main.dart @@ -0,0 +1,2 @@ +export 'test_class.dart' show TestClass; +export '../test/test_class_2.dart' show TestClass2; \ No newline at end of file diff --git a/dev_packages/test_gen/lib/src/types/test_class.dart b/dev_packages/test_gen/lib/src/types/test_class.dart new file mode 100644 index 00000000..b0c19e6c --- /dev/null +++ b/dev_packages/test_gen/lib/src/types/test_class.dart @@ -0,0 +1,68 @@ +import 'package:flutter/material.dart'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; +import '../test/test_class_2.dart'; +import 'test_enum.dart'; + +part 'test_class.g.dart'; + +///Custom docs +@ExchangeableObject() +@SupportedPlatforms(platforms: [ + AndroidPlatform( + apiName: "TestClass", + available: "24", + note: "[test1] is always `null`." + ), + IOSPlatform( + apiName: "TestClass", + available: "15.0", + note: "[test2] is always `null`." + ), + WebPlatform(), +]) +class TestClass_ extends TestClass3 { + ///Docs 1 + String test1; + ///Docs 2 + List test2; + + List? colors; + + ///Docs 3 + @SupportedPlatforms(platforms: [ + AndroidPlatform( + apiName: "WebSettings.setDisabledActionModeMenuItems", + apiUrl: "https://developer.android.com/reference/android/webkit/WebSettings#setDisabledActionModeMenuItems(int)", + available: "24" + ) + ]) + List actionModeMenuItem; + + @ExchangeableObjectProperty( + serializer: Util.serializeTest, + deserializer: Util.deserializeTest + ) + int test = 0; + + DateTime? validNotAfterDate; + + TestClass_({required String asd, this.test1 = "asdasd", required this.test2, + this.actionModeMenuItem = const [ActionModeMenuItem_.MENU_ITEM_NONE]}) : super(asd: asd); + +} + +class TestClass3 { + String asd; + + TestClass3({required this.asd}); +} + +class Util { + static String serializeTest(int source) { + return source.toString(); + } + + static int deserializeTest(String source) { + return int.parse(source); + } +} \ No newline at end of file diff --git a/dev_packages/test_gen/lib/src/types/test_enum.dart b/dev_packages/test_gen/lib/src/types/test_enum.dart new file mode 100644 index 00000000..5a4ec50e --- /dev/null +++ b/dev_packages/test_gen/lib/src/types/test_enum.dart @@ -0,0 +1,160 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; +import 'package:flutter/foundation.dart'; + +part 'test_enum.g.dart'; + +typedef myInt = int; + +///Docs +@ExchangeableEnum( + bitwiseOrOperator: true +) +@EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "TestClass", + available: "24", + note: "[test1] is always `null`." + ), + EnumIOSPlatform( + apiName: "TestClass", + available: "15.0", + note: "[test2] is always `null`." + ), + EnumWebPlatform(), +]) +class ActionModeMenuItem_ { + final int _value; + const ActionModeMenuItem_._internal(this._value); + + ///No menu items should be disabled. + static const MENU_ITEM_NONE = const ActionModeMenuItem_._internal(0); + + ///Disable menu item "Share". + static const MENU_ITEM_SHARE = const ActionModeMenuItem_._internal(1); + + ///Disable menu item "Web Search". + static const MENU_ITEM_WEB_SEARCH = const ActionModeMenuItem_._internal(2); + + ///Disable all the action mode menu items for text processing. + @EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "TestClass", + available: "24", + note: "[test1] is always `null`." + ), + EnumIOSPlatform( + apiName: "TestClass", + available: "15.0", + note: "[test2] is always `null`." + ), + EnumWebPlatform(), + ]) + static const MENU_ITEM_PROCESS_TEXT = const ActionModeMenuItem_._internal(4); +} + + +typedef myString = String; + +@ExchangeableEnum() +///Class that represents a type of resource used to ask user's permission. +class PermissionResourceType_ { + final String _value; + final dynamic _nativeValue = null; + const PermissionResourceType_._internal(this._value); + + ///Resource belongs to audio capture device, like microphone. + @EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "PermissionRequest.RESOURCE_AUDIO_CAPTURE", + apiUrl: "https://developer.android.com/reference/android/webkit/PermissionRequest#RESOURCE_AUDIO_CAPTURE", + value: 'android.webkit.resource.AUDIO_CAPTURE' + ), + EnumIOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.microphone", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/microphone", + value: 1 + ), + EnumMacOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.microphone", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/microphone", + value: 1 + ), + ]) + static const MICROPHONE = PermissionResourceType_._internal('MICROPHONE'); + + ///Resource will allow sysex messages to be sent to or received from MIDI devices. + ///These messages are privileged operations, e.g. modifying sound libraries and sampling data, or even updating the MIDI device's firmware. + ///Permission may be requested for this resource in API levels 21 and above, if the Android device has been updated to WebView 45 or above. + @EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "PermissionRequest.RESOURCE_MIDI_SYSEX", + apiUrl: "https://developer.android.com/reference/android/webkit/PermissionRequest#RESOURCE_MIDI_SYSEX", + value: 'android.webkit.resource.RESOURCE_MIDI_SYSEX' + ) + ]) + static const MIDI_SYSEX = PermissionResourceType_._internal('MIDI_SYSEX'); + + ///Resource belongs to protected media identifier. After the user grants this resource, the origin can use EME APIs to generate the license requests. + @EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "PermissionRequest.RESOURCE_PROTECTED_MEDIA_ID", + apiUrl: "https://developer.android.com/reference/android/webkit/PermissionRequest#RESOURCE_PROTECTED_MEDIA_ID", + value: 'android.webkit.resource.PROTECTED_MEDIA_ID' + ) + ]) + static const PROTECTED_MEDIA_ID = PermissionResourceType_._internal('PROTECTED_MEDIA_ID'); + + ///Resource belongs to video capture device, like camera. + @EnumSupportedPlatforms(platforms: [ + EnumAndroidPlatform( + apiName: "PermissionRequest.RESOURCE_VIDEO_CAPTURE", + apiUrl: "https://developer.android.com/reference/android/webkit/PermissionRequest#RESOURCE_VIDEO_CAPTURE", + value: 'android.webkit.resource.VIDEO_CAPTURE' + ), + EnumIOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.camera", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/camera", + value: 0 + ), + EnumMacOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.camera", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/camera", + value: 0 + ), + ]) + static const CAMERA = PermissionResourceType_._internal('CAMERA'); + + ///A media device or devices that can capture audio and video. + @EnumSupportedPlatforms(platforms: [ + EnumIOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.cameraAndMicrophone", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/cameraandmicrophone", + value: 2 + ), + EnumMacOSPlatform( + available: "15.0", + apiName: "WKMediaCaptureType.cameraAndMicrophone", + apiUrl: "https://developer.apple.com/documentation/webkit/wkmediacapturetype/cameraandmicrophone", + value: 2 + ), + ]) + static const CAMERA_AND_MICROPHONE = PermissionResourceType_._internal('CAMERA_AND_MICROPHONE'); + + ///Resource belongs to the device’s orientation and motion. + @EnumSupportedPlatforms(platforms: [ + EnumIOSPlatform( + available: "15.0", + value: 'deviceOrientationAndMotion' + ), + EnumMacOSPlatform( + available: "15.0", + value: 'deviceOrientationAndMotion' + ), + ]) + static const DEVICE_ORIENTATION_AND_MOTION = PermissionResourceType_._internal('DEVICE_ORIENTATION_AND_MOTION'); +} diff --git a/dev_packages/test_gen/lib/test_gen.dart b/dev_packages/test_gen/lib/test_gen.dart new file mode 100644 index 00000000..549b678c --- /dev/null +++ b/dev_packages/test_gen/lib/test_gen.dart @@ -0,0 +1,10 @@ +library test_gen; + +import 'package:test_gen/src/types/test_class.dart'; +import 'package:test_gen/src/test/test_class_2.dart'; +import 'package:test_gen/src/types/test_enum.dart'; + +void main() { + TestClass a = TestClass(test1: "test1", test2: TestClass2(test1: "test2"), actionModeMenuItem: ActionModeMenuItem.MENU_ITEM_NONE); + a.toMap(); +} \ No newline at end of file diff --git a/dev_packages/test_gen/pubspec.lock b/dev_packages/test_gen/pubspec.lock new file mode 100644 index 00000000..7ae39e4f --- /dev/null +++ b/dev_packages/test_gen/pubspec.lock @@ -0,0 +1,422 @@ +# Generated by pub +# See https://dart.dev/tools/pub/glossary#lockfile +packages: + _fe_analyzer_shared: + dependency: transitive + description: + name: _fe_analyzer_shared + url: "https://pub.dartlang.org" + source: hosted + version: "39.0.0" + analyzer: + dependency: transitive + description: + name: analyzer + url: "https://pub.dartlang.org" + source: hosted + version: "4.0.0" + args: + dependency: transitive + description: + name: args + url: "https://pub.dartlang.org" + source: hosted + version: "2.3.1" + async: + dependency: transitive + description: + name: async + url: "https://pub.dartlang.org" + source: hosted + version: "2.9.0" + build: + dependency: transitive + description: + name: build + url: "https://pub.dartlang.org" + source: hosted + version: "2.3.0" + build_config: + dependency: transitive + description: + name: build_config + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.0" + build_daemon: + dependency: transitive + description: + name: build_daemon + url: "https://pub.dartlang.org" + source: hosted + version: "3.1.0" + build_resolvers: + dependency: transitive + description: + name: build_resolvers + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.8" + build_runner: + dependency: "direct dev" + description: + name: build_runner + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.10" + build_runner_core: + dependency: transitive + description: + name: build_runner_core + url: "https://pub.dartlang.org" + source: hosted + version: "7.2.3" + built_collection: + dependency: transitive + description: + name: built_collection + url: "https://pub.dartlang.org" + source: hosted + version: "5.1.1" + built_value: + dependency: transitive + description: + name: built_value + url: "https://pub.dartlang.org" + source: hosted + version: "8.3.0" + characters: + dependency: transitive + description: + name: characters + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + charcode: + dependency: transitive + description: + name: charcode + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.1" + checked_yaml: + dependency: transitive + description: + name: checked_yaml + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.1" + code_builder: + dependency: transitive + description: + name: code_builder + url: "https://pub.dartlang.org" + source: hosted + version: "4.1.0" + collection: + dependency: transitive + description: + name: collection + url: "https://pub.dartlang.org" + source: hosted + version: "1.15.0" + convert: + dependency: transitive + description: + name: convert + url: "https://pub.dartlang.org" + source: hosted + version: "3.0.1" + crypto: + dependency: transitive + description: + name: crypto + url: "https://pub.dartlang.org" + source: hosted + version: "3.0.2" + dart_style: + dependency: transitive + description: + name: dart_style + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.3" + file: + dependency: transitive + description: + name: file + url: "https://pub.dartlang.org" + source: hosted + version: "6.1.2" + fixnum: + dependency: transitive + description: + name: fixnum + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + flutter: + dependency: "direct main" + description: flutter + source: sdk + version: "0.0.0" + flutter_inappwebview_internal_annotations: + dependency: "direct main" + description: + path: "../flutter_inappwebview_internal_annotations" + relative: true + source: path + version: "1.0.0" + frontend_server_client: + dependency: transitive + description: + name: frontend_server_client + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.2" + generators: + dependency: "direct dev" + description: + path: "../generators" + relative: true + source: path + version: "1.0.0" + glob: + dependency: transitive + description: + name: glob + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.2" + graphs: + dependency: transitive + description: + name: graphs + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + http_multi_server: + dependency: transitive + description: + name: http_multi_server + url: "https://pub.dartlang.org" + source: hosted + version: "3.2.0" + http_parser: + dependency: transitive + description: + name: http_parser + url: "https://pub.dartlang.org" + source: hosted + version: "4.0.0" + io: + dependency: transitive + description: + name: io + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.3" + js: + dependency: transitive + description: + name: js + url: "https://pub.dartlang.org" + source: hosted + version: "0.6.4" + json_annotation: + dependency: transitive + description: + name: json_annotation + url: "https://pub.dartlang.org" + source: hosted + version: "4.5.0" + lints: + dependency: "direct dev" + description: + name: lints + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + logging: + dependency: transitive + description: + name: logging + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.2" + matcher: + dependency: transitive + description: + name: matcher + url: "https://pub.dartlang.org" + source: hosted + version: "0.12.11" + material_color_utilities: + dependency: transitive + description: + name: material_color_utilities + url: "https://pub.dartlang.org" + source: hosted + version: "0.1.3" + meta: + dependency: transitive + description: + name: meta + url: "https://pub.dartlang.org" + source: hosted + version: "1.7.0" + mime: + dependency: transitive + description: + name: mime + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.2" + package_config: + dependency: transitive + description: + name: package_config + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.2" + path: + dependency: transitive + description: + name: path + url: "https://pub.dartlang.org" + source: hosted + version: "1.8.1" + pool: + dependency: transitive + description: + name: pool + url: "https://pub.dartlang.org" + source: hosted + version: "1.5.0" + pub_semver: + dependency: transitive + description: + name: pub_semver + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.1" + pubspec_parse: + dependency: transitive + description: + name: pubspec_parse + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + shelf: + dependency: transitive + description: + name: shelf + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.0" + shelf_web_socket: + dependency: transitive + description: + name: shelf_web_socket + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + sky_engine: + dependency: transitive + description: flutter + source: sdk + version: "0.0.99" + source_gen: + dependency: transitive + description: + name: source_gen + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.2" + source_span: + dependency: transitive + description: + name: source_span + url: "https://pub.dartlang.org" + source: hosted + version: "1.9.0" + stack_trace: + dependency: transitive + description: + name: stack_trace + url: "https://pub.dartlang.org" + source: hosted + version: "1.10.0" + stream_channel: + dependency: transitive + description: + name: stream_channel + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + stream_transform: + dependency: transitive + description: + name: stream_transform + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.0" + string_scanner: + dependency: transitive + description: + name: string_scanner + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.1" + term_glyph: + dependency: transitive + description: + name: term_glyph + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.0" + timing: + dependency: transitive + description: + name: timing + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.0" + typed_data: + dependency: transitive + description: + name: typed_data + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.0" + vector_math: + dependency: transitive + description: + name: vector_math + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.1" + watcher: + dependency: transitive + description: + name: watcher + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.1" + web_socket_channel: + dependency: transitive + description: + name: web_socket_channel + url: "https://pub.dartlang.org" + source: hosted + version: "2.2.0" + yaml: + dependency: transitive + description: + name: yaml + url: "https://pub.dartlang.org" + source: hosted + version: "3.1.1" +sdks: + dart: ">=2.16.0 <3.0.0" + flutter: ">=2.5.0" diff --git a/dev_packages/test_gen/pubspec.yaml b/dev_packages/test_gen/pubspec.yaml new file mode 100755 index 00000000..155717eb --- /dev/null +++ b/dev_packages/test_gen/pubspec.yaml @@ -0,0 +1,20 @@ +name: test_gen +version: 1.0.0 + +publish_to: none + +environment: + sdk: ">=2.14.0 <3.0.0" + flutter: ">=2.5.0" + +dependencies: + flutter: + sdk: flutter + flutter_inappwebview_internal_annotations: + path: ../flutter_inappwebview_internal_annotations/ + +dev_dependencies: + build_runner: + generators: + path: ../generators/ + lints: ^1.0.1 \ No newline at end of file diff --git a/lib/src/types/action_mode_menu_item.dart b/lib/src/types/action_mode_menu_item.dart index 7f2ca724..8276c9cd 100644 --- a/lib/src/types/action_mode_menu_item.dart +++ b/lib/src/types/action_mode_menu_item.dart @@ -1,68 +1,27 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'action_mode_menu_item.g.dart'; + ///Class used to disable the action mode menu items. -class ActionModeMenuItem { +@ExchangeableEnum( + bitwiseOrOperator: true +) +class ActionModeMenuItem_ { + // ignore: unused_field final int _value; - - const ActionModeMenuItem._internal(this._value); - - ///Set of all values of [ActionModeMenuItem]. - static final Set values = [ - ActionModeMenuItem.MENU_ITEM_NONE, - ActionModeMenuItem.MENU_ITEM_SHARE, - ActionModeMenuItem.MENU_ITEM_WEB_SEARCH, - ActionModeMenuItem.MENU_ITEM_PROCESS_TEXT, - ].toSet(); - - ///Gets a possible [ActionModeMenuItem] instance from an [int] value. - static ActionModeMenuItem? fromValue(int? value) { - if (value != null) { - try { - return ActionModeMenuItem.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - // maybe coming from a Bitwise OR operator - return ActionModeMenuItem._internal(value); - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "MENU_ITEM_SHARE"; - case 2: - return "MENU_ITEM_WEB_SEARCH"; - case 4: - return "MENU_ITEM_PROCESS_TEXT"; - case 0: - return "MENU_ITEM_NONE"; - } - return _value.toString(); - } + const ActionModeMenuItem_._internal(this._value); ///No menu items should be disabled. - static const MENU_ITEM_NONE = const ActionModeMenuItem._internal(0); + static const MENU_ITEM_NONE = ActionModeMenuItem_._internal(0); ///Disable menu item "Share". - static const MENU_ITEM_SHARE = const ActionModeMenuItem._internal(1); + static const MENU_ITEM_SHARE = ActionModeMenuItem_._internal(1); ///Disable menu item "Web Search". - static const MENU_ITEM_WEB_SEARCH = const ActionModeMenuItem._internal(2); + static const MENU_ITEM_WEB_SEARCH = ActionModeMenuItem_._internal(2); ///Disable all the action mode menu items for text processing. - static const MENU_ITEM_PROCESS_TEXT = const ActionModeMenuItem._internal(4); - - bool operator ==(value) => value == _value; - - ActionModeMenuItem operator |(ActionModeMenuItem value) => - ActionModeMenuItem._internal(value.toValue() | _value); - - @override - int get hashCode => _value.hashCode; + static const MENU_ITEM_PROCESS_TEXT = ActionModeMenuItem_._internal(4); } ///An Android-specific class used to disable the action mode menu items. @@ -71,70 +30,25 @@ class ActionModeMenuItem { /// ///Use [ActionModeMenuItem] instead. @Deprecated("Use ActionModeMenuItem instead") -class AndroidActionModeMenuItem { +@ExchangeableEnum( + bitwiseOrOperator: true +) +class AndroidActionModeMenuItem_ { + // ignore: unused_field final int _value; - - const AndroidActionModeMenuItem._internal(this._value); - - ///Set of all values of [AndroidActionModeMenuItem]. - static final Set values = [ - AndroidActionModeMenuItem.MENU_ITEM_NONE, - AndroidActionModeMenuItem.MENU_ITEM_SHARE, - AndroidActionModeMenuItem.MENU_ITEM_WEB_SEARCH, - AndroidActionModeMenuItem.MENU_ITEM_PROCESS_TEXT, - ].toSet(); - - ///Gets a possible [AndroidActionModeMenuItem] instance from an [int] value. - static AndroidActionModeMenuItem? fromValue(int? value) { - if (value != null) { - try { - return AndroidActionModeMenuItem.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - // maybe coming from a Bitwise OR operator - return AndroidActionModeMenuItem._internal(value); - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "MENU_ITEM_SHARE"; - case 2: - return "MENU_ITEM_WEB_SEARCH"; - case 4: - return "MENU_ITEM_PROCESS_TEXT"; - case 0: - return "MENU_ITEM_NONE"; - } - return _value.toString(); - } + const AndroidActionModeMenuItem_._internal(this._value); ///No menu items should be disabled. - static const MENU_ITEM_NONE = const AndroidActionModeMenuItem._internal(0); + static const MENU_ITEM_NONE = const AndroidActionModeMenuItem_._internal(0); ///Disable menu item "Share". - static const MENU_ITEM_SHARE = const AndroidActionModeMenuItem._internal(1); + static const MENU_ITEM_SHARE = const AndroidActionModeMenuItem_._internal(1); ///Disable menu item "Web Search". static const MENU_ITEM_WEB_SEARCH = - const AndroidActionModeMenuItem._internal(2); + const AndroidActionModeMenuItem_._internal(2); ///Disable all the action mode menu items for text processing. static const MENU_ITEM_PROCESS_TEXT = - const AndroidActionModeMenuItem._internal(4); - - bool operator ==(value) => value == _value; - - AndroidActionModeMenuItem operator |(AndroidActionModeMenuItem value) => - AndroidActionModeMenuItem._internal(value.toValue() | _value); - - @override - int get hashCode => _value.hashCode; + const AndroidActionModeMenuItem_._internal(4); } \ No newline at end of file diff --git a/lib/src/types/action_mode_menu_item.g.dart b/lib/src/types/action_mode_menu_item.g.dart new file mode 100644 index 00000000..d18c6a89 --- /dev/null +++ b/lib/src/types/action_mode_menu_item.g.dart @@ -0,0 +1,187 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'action_mode_menu_item.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used to disable the action mode menu items. +class ActionModeMenuItem { + final int _value; + final int _nativeValue; + const ActionModeMenuItem._internal(this._value, this._nativeValue); +// ignore: unused_element + factory ActionModeMenuItem._internalMultiPlatform( + int value, Function nativeValue) => + ActionModeMenuItem._internal(value, nativeValue()); + + ///No menu items should be disabled. + static const MENU_ITEM_NONE = ActionModeMenuItem._internal(0, 0); + + ///Disable menu item "Share". + static const MENU_ITEM_SHARE = ActionModeMenuItem._internal(1, 1); + + ///Disable menu item "Web Search". + static const MENU_ITEM_WEB_SEARCH = ActionModeMenuItem._internal(2, 2); + + ///Disable all the action mode menu items for text processing. + static const MENU_ITEM_PROCESS_TEXT = ActionModeMenuItem._internal(4, 4); + + ///Set of all values of [ActionModeMenuItem]. + static final Set values = [ + ActionModeMenuItem.MENU_ITEM_NONE, + ActionModeMenuItem.MENU_ITEM_SHARE, + ActionModeMenuItem.MENU_ITEM_WEB_SEARCH, + ActionModeMenuItem.MENU_ITEM_PROCESS_TEXT, + ].toSet(); + + ///Gets a possible [ActionModeMenuItem] instance from [int] value. + static ActionModeMenuItem? fromValue(int? value) { + if (value != null) { + try { + return ActionModeMenuItem.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return ActionModeMenuItem._internal(value, value); + } + } + return null; + } + + ///Gets a possible [ActionModeMenuItem] instance from a native value. + static ActionModeMenuItem? fromNativeValue(int? value) { + if (value != null) { + try { + return ActionModeMenuItem.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return ActionModeMenuItem._internal(value, value); + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + ActionModeMenuItem operator |(ActionModeMenuItem value) => + ActionModeMenuItem._internal( + value.toValue() | _value, value.toNativeValue() | _nativeValue); + @override + String toString() { + switch (_value) { + case 0: + return 'MENU_ITEM_NONE'; + case 1: + return 'MENU_ITEM_SHARE'; + case 2: + return 'MENU_ITEM_WEB_SEARCH'; + case 4: + return 'MENU_ITEM_PROCESS_TEXT'; + } + return _value.toString(); + } +} + +///An Android-specific class used to disable the action mode menu items. +/// +///**NOTE**: available on Android 24+. +/// +///Use [ActionModeMenuItem] instead. +@Deprecated('Use ActionModeMenuItem instead') +class AndroidActionModeMenuItem { + final int _value; + final int _nativeValue; + const AndroidActionModeMenuItem._internal(this._value, this._nativeValue); +// ignore: unused_element + factory AndroidActionModeMenuItem._internalMultiPlatform( + int value, Function nativeValue) => + AndroidActionModeMenuItem._internal(value, nativeValue()); + + ///No menu items should be disabled. + static const MENU_ITEM_NONE = AndroidActionModeMenuItem._internal(0, 0); + + ///Disable menu item "Share". + static const MENU_ITEM_SHARE = AndroidActionModeMenuItem._internal(1, 1); + + ///Disable menu item "Web Search". + static const MENU_ITEM_WEB_SEARCH = AndroidActionModeMenuItem._internal(2, 2); + + ///Disable all the action mode menu items for text processing. + static const MENU_ITEM_PROCESS_TEXT = + AndroidActionModeMenuItem._internal(4, 4); + + ///Set of all values of [AndroidActionModeMenuItem]. + static final Set values = [ + AndroidActionModeMenuItem.MENU_ITEM_NONE, + AndroidActionModeMenuItem.MENU_ITEM_SHARE, + AndroidActionModeMenuItem.MENU_ITEM_WEB_SEARCH, + AndroidActionModeMenuItem.MENU_ITEM_PROCESS_TEXT, + ].toSet(); + + ///Gets a possible [AndroidActionModeMenuItem] instance from [int] value. + static AndroidActionModeMenuItem? fromValue(int? value) { + if (value != null) { + try { + return AndroidActionModeMenuItem.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return AndroidActionModeMenuItem._internal(value, value); + } + } + return null; + } + + ///Gets a possible [AndroidActionModeMenuItem] instance from a native value. + static AndroidActionModeMenuItem? fromNativeValue(int? value) { + if (value != null) { + try { + return AndroidActionModeMenuItem.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return AndroidActionModeMenuItem._internal(value, value); + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + AndroidActionModeMenuItem operator |(AndroidActionModeMenuItem value) => + AndroidActionModeMenuItem._internal( + value.toValue() | _value, value.toNativeValue() | _nativeValue); + @override + String toString() { + switch (_value) { + case 0: + return 'MENU_ITEM_NONE'; + case 1: + return 'MENU_ITEM_SHARE'; + case 2: + return 'MENU_ITEM_WEB_SEARCH'; + case 4: + return 'MENU_ITEM_PROCESS_TEXT'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/ajax_request.dart b/lib/src/types/ajax_request.dart index c3f02fe6..6480f11f 100644 --- a/lib/src/types/ajax_request.dart +++ b/lib/src/types/ajax_request.dart @@ -1,10 +1,15 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request_headers.dart'; import 'ajax_request_ready_state.dart'; import 'ajax_request_event.dart'; import 'ajax_request_action.dart'; +part 'ajax_request.g.dart'; + ///Class that represents a JavaScript [XMLHttpRequest](https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest) object. -class AjaxRequest { +@ExchangeableObject() +class AjaxRequest_ { ///Data passed as a parameter to the `XMLHttpRequest.send()` method. dynamic data; @@ -30,10 +35,10 @@ class AjaxRequest { bool? withCredentials; ///The HTTP request headers. - AjaxRequestHeaders? headers; + AjaxRequestHeaders_? headers; ///The state of the `XMLHttpRequest` request. - AjaxRequestReadyState? readyState; + AjaxRequestReadyState_? readyState; ///The numerical HTTP [status code](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status) of the `XMLHttpRequest`'s response. int? status; @@ -67,12 +72,12 @@ class AjaxRequest { Map? responseHeaders; ///Event type of the `XMLHttpRequest` request. - AjaxRequestEvent? event; + AjaxRequestEvent_? event; ///Indicates the [AjaxRequestAction] that can be used to control the `XMLHttpRequest` request. - AjaxRequestAction? action; + AjaxRequestAction_? action; - AjaxRequest( + AjaxRequest_( {this.data, this.method, this.url, @@ -91,68 +96,6 @@ class AjaxRequest { this.statusText, this.responseHeaders, this.event, - this.action = AjaxRequestAction.PROCEED}); + this.action = AjaxRequestAction_.PROCEED}); - ///Gets a possible [AjaxRequest] instance from a [Map] value. - static AjaxRequest? fromMap(Map? map) { - if (map == null) { - return null; - } - - return AjaxRequest( - data: map["data"], - method: map["method"], - url: map["url"] != null ? Uri.parse(map["url"]) : null, - isAsync: map["isAsync"], - user: map["user"], - password: map["password"], - withCredentials: map["withCredentials"], - headers: - AjaxRequestHeaders.fromMap(map["headers"]?.cast()), - readyState: AjaxRequestReadyState.fromValue(map["readyState"]), - status: map["status"], - responseURL: - map["responseURL"] != null ? Uri.parse(map["responseURL"]) : null, - responseType: map["responseType"], - response: map["response"], - responseText: map["responseText"], - responseXML: map["responseXML"], - statusText: map["statusText"], - responseHeaders: map["responseHeaders"]?.cast(), - event: AjaxRequestEvent.fromMap(map["event"]?.cast())); - } - - ///Converts instance to a map. - Map toMap() { - return { - "data": data, - "method": method, - "url": url?.toString(), - "isAsync": isAsync, - "user": user, - "password": password, - "withCredentials": withCredentials, - "headers": headers?.toMap(), - "readyState": readyState?.toValue(), - "status": status, - "responseURL": responseURL?.toString(), - "responseType": responseType, - "response": response, - "responseText": responseText, - "responseXML": responseXML, - "statusText": statusText, - "responseHeaders": responseHeaders, - "action": action?.toValue() - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/ajax_request.g.dart b/lib/src/types/ajax_request.g.dart new file mode 100644 index 00000000..224c5d37 --- /dev/null +++ b/lib/src/types/ajax_request.g.dart @@ -0,0 +1,164 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents a JavaScript [XMLHttpRequest](https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest) object. +class AjaxRequest { + ///Data passed as a parameter to the `XMLHttpRequest.send()` method. + dynamic data; + + ///The HTTP request method of the `XMLHttpRequest` request. + String? method; + + ///The URL of the `XMLHttpRequest` request. + Uri? url; + + ///An optional Boolean parameter, defaulting to true, indicating whether or not the request is performed asynchronously. + bool? isAsync; + + ///The optional user name to use for authentication purposes; by default, this is the null value. + String? user; + + ///The optional password to use for authentication purposes; by default, this is the null value. + String? password; + + ///The XMLHttpRequest.withCredentials property is a Boolean that indicates whether or not cross-site Access-Control requests + ///should be made using credentials such as cookies, authorization headers or TLS client certificates. + ///Setting withCredentials has no effect on same-site requests. + ///In addition, this flag is also used to indicate when cookies are to be ignored in the response. The default is false. + bool? withCredentials; + + ///The HTTP request headers. + AjaxRequestHeaders? headers; + + ///The state of the `XMLHttpRequest` request. + AjaxRequestReadyState? readyState; + + ///The numerical HTTP [status code](https://developer.mozilla.org/en-US/docs/Web/HTTP/Status) of the `XMLHttpRequest`'s response. + int? status; + + ///The serialized URL of the response or the empty string if the URL is null. + ///If the URL is returned, any URL fragment present in the URL will be stripped away. + ///The value of responseURL will be the final URL obtained after any redirects. + Uri? responseURL; + + ///It is an enumerated string value specifying the type of data contained in the response. + ///It also lets the author change the [response type](https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/responseType). + ///If an empty string is set as the value of responseType, the default value of text is used. + String? responseType; + + ///The response's body content. The content-type depends on the [AjaxRequest.reponseType]. + dynamic response; + + ///The text received from a server following a request being sent. + String? responseText; + + ///The HTML or XML string retrieved by the request or null if the request was unsuccessful, has not yet been sent, or if the data can't be parsed as XML or HTML. + String? responseXML; + + ///A String containing the response's status message as returned by the HTTP server. + ///Unlike [AjaxRequest.status] which indicates a numerical status code, this property contains the text of the response status, such as "OK" or "Not Found". + ///If the request's readyState is in [AjaxRequestReadyState.UNSENT] or [AjaxRequestReadyState.OPENED] state, the value of statusText will be an empty string. + ///If the server response doesn't explicitly specify a status text, statusText will assume the default value "OK". + String? statusText; + + ///All the response headers or returns null if no response has been received. If a network error happened, an empty string is returned. + Map? responseHeaders; + + ///Event type of the `XMLHttpRequest` request. + AjaxRequestEvent? event; + + ///Indicates the [AjaxRequestAction] that can be used to control the `XMLHttpRequest` request. + AjaxRequestAction? action; + AjaxRequest( + {this.data, + this.method, + this.url, + this.isAsync, + this.user, + this.password, + this.withCredentials, + this.headers, + this.readyState, + this.status, + this.responseURL, + this.responseType, + this.response, + this.responseText, + this.responseXML, + this.statusText, + this.responseHeaders, + this.event, + this.action = AjaxRequestAction.PROCEED}); + + ///Gets a possible [AjaxRequest] instance from a [Map] value. + static AjaxRequest? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = AjaxRequest(); + instance.data = map['data']; + instance.method = map['method']; + instance.url = map['url'] != null ? Uri.parse(map['url']) : null; + instance.isAsync = map['isAsync']; + instance.user = map['user']; + instance.password = map['password']; + instance.withCredentials = map['withCredentials']; + instance.headers = + AjaxRequestHeaders.fromMap(map['headers']?.cast()); + instance.readyState = + AjaxRequestReadyState.fromNativeValue(map['readyState']); + instance.status = map['status']; + instance.responseURL = + map['responseURL'] != null ? Uri.parse(map['responseURL']) : null; + instance.responseType = map['responseType']; + instance.response = map['response']; + instance.responseText = map['responseText']; + instance.responseXML = map['responseXML']; + instance.statusText = map['statusText']; + instance.responseHeaders = map['responseHeaders']; + instance.event = + AjaxRequestEvent.fromMap(map['event']?.cast()); + instance.action = AjaxRequestAction.fromNativeValue(map['action']); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "data": data, + "method": method, + "url": url?.toString(), + "isAsync": isAsync, + "user": user, + "password": password, + "withCredentials": withCredentials, + "headers": headers?.toMap(), + "readyState": readyState?.toNativeValue(), + "status": status, + "responseURL": responseURL?.toString(), + "responseType": responseType, + "response": response, + "responseText": responseText, + "responseXML": responseXML, + "statusText": statusText, + "responseHeaders": responseHeaders, + "event": event?.toMap(), + "action": action?.toNativeValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'AjaxRequest{data: $data, method: $method, url: $url, isAsync: $isAsync, user: $user, password: $password, withCredentials: $withCredentials, headers: $headers, readyState: $readyState, status: $status, responseURL: $responseURL, responseType: $responseType, response: $response, responseText: $responseText, responseXML: $responseXML, statusText: $statusText, responseHeaders: $responseHeaders, event: $event, action: $action}'; + } +} diff --git a/lib/src/types/ajax_request_action.dart b/lib/src/types/ajax_request_action.dart index e2fd5d33..ee7b9c84 100644 --- a/lib/src/types/ajax_request_action.dart +++ b/lib/src/types/ajax_request_action.dart @@ -1,39 +1,19 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request.dart'; +part 'ajax_request_action.g.dart'; + ///Class used by [AjaxRequest] class. -class AjaxRequestAction { +@ExchangeableEnum() +class AjaxRequestAction_ { + // ignore: unused_field final int _value; - - const AjaxRequestAction._internal(this._value); - - ///Gets [int] value. - int toValue() => _value; + const AjaxRequestAction_._internal(this._value); ///Aborts the current [AjaxRequest]. - static const ABORT = const AjaxRequestAction._internal(0); + static const ABORT = const AjaxRequestAction_._internal(0); ///Proceeds with the current [AjaxRequest]. - static const PROCEED = const AjaxRequestAction._internal(1); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; - - ///Converts instance to a map. - Map toMap() { - return { - "action": _value, - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } + static const PROCEED = const AjaxRequestAction_._internal(1); } \ No newline at end of file diff --git a/lib/src/types/ajax_request_action.g.dart b/lib/src/types/ajax_request_action.g.dart new file mode 100644 index 00000000..9ee6b7a8 --- /dev/null +++ b/lib/src/types/ajax_request_action.g.dart @@ -0,0 +1,79 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request_action.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used by [AjaxRequest] class. +class AjaxRequestAction { + final int _value; + final int _nativeValue; + const AjaxRequestAction._internal(this._value, this._nativeValue); +// ignore: unused_element + factory AjaxRequestAction._internalMultiPlatform( + int value, Function nativeValue) => + AjaxRequestAction._internal(value, nativeValue()); + + ///Aborts the current [AjaxRequest]. + static const ABORT = AjaxRequestAction._internal(0, 0); + + ///Proceeds with the current [AjaxRequest]. + static const PROCEED = AjaxRequestAction._internal(1, 1); + + ///Set of all values of [AjaxRequestAction]. + static final Set values = [ + AjaxRequestAction.ABORT, + AjaxRequestAction.PROCEED, + ].toSet(); + + ///Gets a possible [AjaxRequestAction] instance from [int] value. + static AjaxRequestAction? fromValue(int? value) { + if (value != null) { + try { + return AjaxRequestAction.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [AjaxRequestAction] instance from a native value. + static AjaxRequestAction? fromNativeValue(int? value) { + if (value != null) { + try { + return AjaxRequestAction.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'ABORT'; + case 1: + return 'PROCEED'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/ajax_request_event.dart b/lib/src/types/ajax_request_event.dart index ac4e060d..90dc139f 100644 --- a/lib/src/types/ajax_request_event.dart +++ b/lib/src/types/ajax_request_event.dart @@ -1,10 +1,15 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request.dart'; import 'ajax_request_event_type.dart'; +part 'ajax_request_event.g.dart'; + ///Class used by [AjaxRequest] class. It represents events measuring progress of an [AjaxRequest]. -class AjaxRequestEvent { +@ExchangeableObject() +class AjaxRequestEvent_ { ///Event type. - AjaxRequestEventType? type; + AjaxRequestEventType_? type; ///Is a Boolean flag indicating if the total work to be done, and the amount of work already done, by the underlying process is calculable. ///In other words, it tells if the progress is measurable or not. @@ -19,38 +24,5 @@ class AjaxRequestEvent { ///When downloading a resource using HTTP, this only represent the content itself, not headers and other overhead. int? total; - AjaxRequestEvent({this.type, this.lengthComputable, this.loaded, this.total}); - - ///Gets a possible [AjaxRequestEvent] instance from a [Map] value. - static AjaxRequestEvent? fromMap(Map? map) { - if (map == null) { - return null; - } - - return AjaxRequestEvent( - type: AjaxRequestEventType.fromValue(map["type"]), - lengthComputable: map["lengthComputable"], - loaded: map["loaded"], - total: map["total"]); - } - - ///Converts instance to a map. - Map toMap() { - return { - "type": type?.toValue(), - "lengthComputable": lengthComputable, - "loaded": loaded, - "total": total, - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } + AjaxRequestEvent_({this.type, this.lengthComputable, this.loaded, this.total}); } \ No newline at end of file diff --git a/lib/src/types/ajax_request_event.g.dart b/lib/src/types/ajax_request_event.g.dart new file mode 100644 index 00000000..c37d23aa --- /dev/null +++ b/lib/src/types/ajax_request_event.g.dart @@ -0,0 +1,60 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request_event.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class used by [AjaxRequest] class. It represents events measuring progress of an [AjaxRequest]. +class AjaxRequestEvent { + ///Event type. + AjaxRequestEventType? type; + + ///Is a Boolean flag indicating if the total work to be done, and the amount of work already done, by the underlying process is calculable. + ///In other words, it tells if the progress is measurable or not. + bool? lengthComputable; + + ///Is an integer representing the amount of work already performed by the underlying process. + ///The ratio of work done can be calculated with the property and [AjaxRequestEvent.total]. + ///When downloading a resource using HTTP, this only represent the part of the content itself, not headers and other overhead. + int? loaded; + + ///Is an integer representing the total amount of work that the underlying process is in the progress of performing. + ///When downloading a resource using HTTP, this only represent the content itself, not headers and other overhead. + int? total; + AjaxRequestEvent({this.type, this.lengthComputable, this.loaded, this.total}); + + ///Gets a possible [AjaxRequestEvent] instance from a [Map] value. + static AjaxRequestEvent? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = AjaxRequestEvent(); + instance.type = AjaxRequestEventType.fromNativeValue(map['type']); + instance.lengthComputable = map['lengthComputable']; + instance.loaded = map['loaded']; + instance.total = map['total']; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "type": type?.toNativeValue(), + "lengthComputable": lengthComputable, + "loaded": loaded, + "total": total, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'AjaxRequestEvent{type: $type, lengthComputable: $lengthComputable, loaded: $loaded, total: $total}'; + } +} diff --git a/lib/src/types/ajax_request_event_type.dart b/lib/src/types/ajax_request_event_type.dart index 817581f6..a6ccb1c5 100644 --- a/lib/src/types/ajax_request_event_type.dart +++ b/lib/src/types/ajax_request_event_type.dart @@ -1,64 +1,34 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request_event.dart'; +part 'ajax_request_event_type.g.dart'; + ///Class used by [AjaxRequestEvent] class. -class AjaxRequestEventType { +@ExchangeableEnum() +class AjaxRequestEventType_ { final String _value; - - const AjaxRequestEventType._internal(this._value); - - ///Set of all values of [AjaxRequestEventType]. - static final Set values = [ - AjaxRequestEventType.LOADSTART, - AjaxRequestEventType.LOAD, - AjaxRequestEventType.LOADEND, - AjaxRequestEventType.PROGRESS, - AjaxRequestEventType.ERROR, - AjaxRequestEventType.ABORT, - AjaxRequestEventType.TIMEOUT, - ].toSet(); - - ///Gets a possible [AjaxRequestEventType] instance from a [String] value. - static AjaxRequestEventType? fromValue(String? value) { - if (value != null) { - try { - return AjaxRequestEventType.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - String toString() => _value; + const AjaxRequestEventType_._internal(this._value); ///The LOADSTART event is fired when a request has started to load data. - static const LOADSTART = const AjaxRequestEventType._internal("loadstart"); + static const LOADSTART = const AjaxRequestEventType_._internal("loadstart"); ///The LOAD event is fired when an `XMLHttpRequest` transaction completes successfully. - static const LOAD = const AjaxRequestEventType._internal("load"); + static const LOAD = const AjaxRequestEventType_._internal("load"); ///The LOADEND event is fired when a request has completed, whether successfully (after [AjaxRequestEventType.LOAD]) or ///unsuccessfully (after [AjaxRequestEventType.ABORT] or [AjaxRequestEventType.ERROR]). - static const LOADEND = const AjaxRequestEventType._internal("loadend"); + static const LOADEND = const AjaxRequestEventType_._internal("loadend"); ///The PROGRESS event is fired periodically when a request receives more data. - static const PROGRESS = const AjaxRequestEventType._internal("progress"); + static const PROGRESS = const AjaxRequestEventType_._internal("progress"); ///The ERROR event is fired when the request encountered an error. - static const ERROR = const AjaxRequestEventType._internal("error"); + static const ERROR = const AjaxRequestEventType_._internal("error"); ///The ABORT event is fired when a request has been aborted. - static const ABORT = const AjaxRequestEventType._internal("abort"); + static const ABORT = const AjaxRequestEventType_._internal("abort"); ///The TIMEOUT event is fired when progression is terminated due to preset time expiring. - static const TIMEOUT = const AjaxRequestEventType._internal("timeout"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const TIMEOUT = const AjaxRequestEventType_._internal("timeout"); } \ No newline at end of file diff --git a/lib/src/types/ajax_request_event_type.g.dart b/lib/src/types/ajax_request_event_type.g.dart new file mode 100644 index 00000000..2397d27e --- /dev/null +++ b/lib/src/types/ajax_request_event_type.g.dart @@ -0,0 +1,96 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request_event_type.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used by [AjaxRequestEvent] class. +class AjaxRequestEventType { + final String _value; + final String _nativeValue; + const AjaxRequestEventType._internal(this._value, this._nativeValue); +// ignore: unused_element + factory AjaxRequestEventType._internalMultiPlatform( + String value, Function nativeValue) => + AjaxRequestEventType._internal(value, nativeValue()); + + ///The LOADSTART event is fired when a request has started to load data. + static const LOADSTART = + AjaxRequestEventType._internal('loadstart', 'loadstart'); + + ///The LOAD event is fired when an `XMLHttpRequest` transaction completes successfully. + static const LOAD = AjaxRequestEventType._internal('load', 'load'); + + ///The LOADEND event is fired when a request has completed, whether successfully (after [AjaxRequestEventType.LOAD]) or + ///unsuccessfully (after [AjaxRequestEventType.ABORT] or [AjaxRequestEventType.ERROR]). + static const LOADEND = AjaxRequestEventType._internal('loadend', 'loadend'); + + ///The PROGRESS event is fired periodically when a request receives more data. + static const PROGRESS = + AjaxRequestEventType._internal('progress', 'progress'); + + ///The ERROR event is fired when the request encountered an error. + static const ERROR = AjaxRequestEventType._internal('error', 'error'); + + ///The ABORT event is fired when a request has been aborted. + static const ABORT = AjaxRequestEventType._internal('abort', 'abort'); + + ///The TIMEOUT event is fired when progression is terminated due to preset time expiring. + static const TIMEOUT = AjaxRequestEventType._internal('timeout', 'timeout'); + + ///Set of all values of [AjaxRequestEventType]. + static final Set values = [ + AjaxRequestEventType.LOADSTART, + AjaxRequestEventType.LOAD, + AjaxRequestEventType.LOADEND, + AjaxRequestEventType.PROGRESS, + AjaxRequestEventType.ERROR, + AjaxRequestEventType.ABORT, + AjaxRequestEventType.TIMEOUT, + ].toSet(); + + ///Gets a possible [AjaxRequestEventType] instance from [String] value. + static AjaxRequestEventType? fromValue(String? value) { + if (value != null) { + try { + return AjaxRequestEventType.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [AjaxRequestEventType] instance from a native value. + static AjaxRequestEventType? fromNativeValue(String? value) { + if (value != null) { + try { + return AjaxRequestEventType.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/ajax_request_headers.dart b/lib/src/types/ajax_request_headers.dart index 89635069..1c37e967 100644 --- a/lib/src/types/ajax_request_headers.dart +++ b/lib/src/types/ajax_request_headers.dart @@ -1,19 +1,25 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request.dart'; +part 'ajax_request_headers.g.dart'; + ///Class that represents the HTTP headers of an [AjaxRequest]. -class AjaxRequestHeaders { +@ExchangeableObject() +class AjaxRequestHeaders_ { Map _headers; Map _newHeaders = {}; - AjaxRequestHeaders(this._headers); + @ExchangeableObjectConstructor() + AjaxRequestHeaders_(this._headers); ///Gets a possible [AjaxRequestHeaders] instance from a [Map] value. - static AjaxRequestHeaders? fromMap(Map? map) { + static AjaxRequestHeaders_? fromMap(Map? map) { if (map == null) { return null; } - return AjaxRequestHeaders(map); + return AjaxRequestHeaders_(map); } ///Gets the HTTP headers of the [AjaxRequest]. @@ -34,13 +40,8 @@ class AjaxRequestHeaders { return _newHeaders; } - ///Converts instance to a map. - Map toJson() { - return toMap(); - } - @override String toString() { - return toMap().toString(); + return 'AjaxRequestHeaders{headers: $_headers, requestHeaders: $_newHeaders}'; } } \ No newline at end of file diff --git a/lib/src/types/ajax_request_headers.g.dart b/lib/src/types/ajax_request_headers.g.dart new file mode 100644 index 00000000..e1e10b1f --- /dev/null +++ b/lib/src/types/ajax_request_headers.g.dart @@ -0,0 +1,50 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request_headers.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents the HTTP headers of an [AjaxRequest]. +class AjaxRequestHeaders { + Map _headers; + Map _newHeaders = {}; + AjaxRequestHeaders(this._headers); + + ///Gets a possible [AjaxRequestHeaders] instance from a [Map] value. + static AjaxRequestHeaders? fromMap(Map? map) { + if (map == null) { + return null; + } + return AjaxRequestHeaders(map); + } + + ///Gets the HTTP headers of the [AjaxRequest]. + Map getHeaders() { + return this._headers; + } + + ///Sets/updates an HTTP header of the [AjaxRequest]. If there is already an existing [header] with the same name, the values are merged into one single request header. + ///For security reasons, some headers can only be controlled by the user agent. + ///These headers include the [forbidden header names](https://developer.mozilla.org/en-US/docs/Glossary/Forbidden_header_name) + ///and [forbidden response header names](https://developer.mozilla.org/en-US/docs/Glossary/Forbidden_response_header_name). + void setRequestHeader(String header, String value) { + _newHeaders[header] = value; + } + + ///Converts instance to a map. + Map toMap() { + return _newHeaders; + } + + @override + String toString() { + return 'AjaxRequestHeaders{headers: $_headers, requestHeaders: $_newHeaders}'; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } +} diff --git a/lib/src/types/ajax_request_ready_state.dart b/lib/src/types/ajax_request_ready_state.dart index 0cbb482a..bc5987b0 100644 --- a/lib/src/types/ajax_request_ready_state.dart +++ b/lib/src/types/ajax_request_ready_state.dart @@ -1,70 +1,28 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ajax_request.dart'; +part 'ajax_request_ready_state.g.dart'; + ///Class used by [AjaxRequest] class. It represents the state of an [AjaxRequest]. -class AjaxRequestReadyState { +@ExchangeableEnum() +class AjaxRequestReadyState_ { + // ignore: unused_field final int _value; - - const AjaxRequestReadyState._internal(this._value); - - ///Set of all values of [AjaxRequestReadyState]. - static final Set values = [ - AjaxRequestReadyState.UNSENT, - AjaxRequestReadyState.OPENED, - AjaxRequestReadyState.HEADERS_RECEIVED, - AjaxRequestReadyState.LOADING, - AjaxRequestReadyState.DONE, - ].toSet(); - - ///Gets a possible [AjaxRequestReadyState] instance from an [int] value. - static AjaxRequestReadyState? fromValue(int? value) { - if (value != null) { - try { - return AjaxRequestReadyState.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "OPENED"; - case 2: - return "HEADERS_RECEIVED"; - case 3: - return "LOADING"; - case 4: - return "DONE"; - case 0: - default: - return "UNSENT"; - } - } + const AjaxRequestReadyState_._internal(this._value); ///Client has been created. `XMLHttpRequest.open()` not called yet. - static const UNSENT = const AjaxRequestReadyState._internal(0); + static const UNSENT = const AjaxRequestReadyState_._internal(0); ///`XMLHttpRequest.open()` has been called. - static const OPENED = const AjaxRequestReadyState._internal(1); + static const OPENED = const AjaxRequestReadyState_._internal(1); ///`XMLHttpRequest.send()` has been called, and [AjaxRequest.headers] and [AjaxRequest.status] are available. - static const HEADERS_RECEIVED = const AjaxRequestReadyState._internal(2); + static const HEADERS_RECEIVED = const AjaxRequestReadyState_._internal(2); ///Downloading; [AjaxRequest.responseText] holds partial data. - static const LOADING = const AjaxRequestReadyState._internal(3); + static const LOADING = const AjaxRequestReadyState_._internal(3); ///The operation is complete. - static const DONE = const AjaxRequestReadyState._internal(4); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const DONE = const AjaxRequestReadyState_._internal(4); } \ No newline at end of file diff --git a/lib/src/types/ajax_request_ready_state.g.dart b/lib/src/types/ajax_request_ready_state.g.dart new file mode 100644 index 00000000..2ccd9eb9 --- /dev/null +++ b/lib/src/types/ajax_request_ready_state.g.dart @@ -0,0 +1,97 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ajax_request_ready_state.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used by [AjaxRequest] class. It represents the state of an [AjaxRequest]. +class AjaxRequestReadyState { + final int _value; + final int _nativeValue; + const AjaxRequestReadyState._internal(this._value, this._nativeValue); +// ignore: unused_element + factory AjaxRequestReadyState._internalMultiPlatform( + int value, Function nativeValue) => + AjaxRequestReadyState._internal(value, nativeValue()); + + ///Client has been created. `XMLHttpRequest.open()` not called yet. + static const UNSENT = AjaxRequestReadyState._internal(0, 0); + + ///`XMLHttpRequest.open()` has been called. + static const OPENED = AjaxRequestReadyState._internal(1, 1); + + ///`XMLHttpRequest.send()` has been called, and [AjaxRequest.headers] and [AjaxRequest.status] are available. + static const HEADERS_RECEIVED = AjaxRequestReadyState._internal(2, 2); + + ///Downloading; [AjaxRequest.responseText] holds partial data. + static const LOADING = AjaxRequestReadyState._internal(3, 3); + + ///The operation is complete. + static const DONE = AjaxRequestReadyState._internal(4, 4); + + ///Set of all values of [AjaxRequestReadyState]. + static final Set values = [ + AjaxRequestReadyState.UNSENT, + AjaxRequestReadyState.OPENED, + AjaxRequestReadyState.HEADERS_RECEIVED, + AjaxRequestReadyState.LOADING, + AjaxRequestReadyState.DONE, + ].toSet(); + + ///Gets a possible [AjaxRequestReadyState] instance from [int] value. + static AjaxRequestReadyState? fromValue(int? value) { + if (value != null) { + try { + return AjaxRequestReadyState.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [AjaxRequestReadyState] instance from a native value. + static AjaxRequestReadyState? fromNativeValue(int? value) { + if (value != null) { + try { + return AjaxRequestReadyState.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'UNSENT'; + case 1: + return 'OPENED'; + case 2: + return 'HEADERS_RECEIVED'; + case 3: + return 'LOADING'; + case 4: + return 'DONE'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/attributed_string.dart b/lib/src/types/attributed_string.dart index 5621d7f6..3861e6a7 100644 --- a/lib/src/types/attributed_string.dart +++ b/lib/src/types/attributed_string.dart @@ -1,13 +1,18 @@ import 'dart:ui'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../pull_to_refresh/main.dart'; import 'underline_style.dart'; import 'attributed_string_text_effect_style.dart'; import '../util.dart'; +part 'attributed_string.g.dart'; + ///Class that represents a string with associated attributes ///used by the [PullToRefreshController] and [PullToRefreshSettings] classes. -class AttributedString { +@ExchangeableObject() +class AttributedString_ { ///The characters for the new object. String string; @@ -69,7 +74,7 @@ class AttributedString { /// ///This value indicates whether the text has a line through it and corresponds to one of the constants described in [UnderlineStyle]. ///The default value for this attribute is [UnderlineStyle.STYLE_NONE]. - UnderlineStyle? strikethroughStyle; + UnderlineStyle_? strikethroughStyle; ///The color of the stroke. /// @@ -92,7 +97,7 @@ class AttributedString { /// ///The value of this attribute is a [AttributedStringTextEffectStyle] object. ///The default value of this property is `null`, indicating no text effect. - AttributedStringTextEffectStyle? textEffect; + AttributedStringTextEffectStyle_? textEffect; ///The color of the underline. /// @@ -104,9 +109,9 @@ class AttributedString { /// ///This value indicates whether the text is underlined and corresponds to one of the constants described in [UnderlineStyle]. ///The default value for this attribute is [UnderlineStyle.STYLE_NONE]. - UnderlineStyle? underlineStyle; + UnderlineStyle_? underlineStyle; - AttributedString({ + AttributedString_({ required this.string, this.backgroundColor, this.baselineOffset, @@ -123,42 +128,14 @@ class AttributedString { this.underlineColor, this.underlineStyle, }); - - Map toMap() { - return { - "string": this.string, - "backgroundColor": this.backgroundColor?.toHex(), - "baselineOffset": this.baselineOffset, - "expansion": this.expansion, - "foregroundColor": this.foregroundColor?.toHex(), - "kern": this.kern, - "ligature": this.ligature, - "obliqueness": this.obliqueness, - "strikethroughColor": this.strikethroughColor?.toHex(), - "strikethroughStyle": this.strikethroughStyle?.toValue(), - "strokeColor": this.strokeColor?.toHex(), - "strokeWidth": this.strokeWidth, - "textEffect": this.textEffect?.toValue(), - "underlineColor": this.underlineColor?.toHex(), - "underlineStyle": this.underlineStyle?.toValue(), - }; - } - - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } ///An iOS-specific class that represents a string with associated attributes ///used by the [PullToRefreshController] and [PullToRefreshOptions] classes. ///Use [AttributedString] instead. @Deprecated("Use AttributedString instead") -class IOSNSAttributedString { +@ExchangeableObject() +class IOSNSAttributedString_ { ///The characters for the new object. String string; @@ -220,7 +197,7 @@ class IOSNSAttributedString { /// ///This value indicates whether the text has a line through it and corresponds to one of the constants described in [IOSNSUnderlineStyle]. ///The default value for this attribute is [IOSNSUnderlineStyle.STYLE_NONE]. - IOSNSUnderlineStyle? strikethroughStyle; + IOSNSUnderlineStyle_? strikethroughStyle; ///The color of the stroke. /// @@ -243,7 +220,7 @@ class IOSNSAttributedString { /// ///The value of this attribute is a [IOSNSAttributedStringTextEffectStyle] object. ///The default value of this property is `null`, indicating no text effect. - IOSNSAttributedStringTextEffectStyle? textEffect; + IOSNSAttributedStringTextEffectStyle_? textEffect; ///The color of the underline. /// @@ -255,9 +232,9 @@ class IOSNSAttributedString { /// ///This value indicates whether the text is underlined and corresponds to one of the constants described in [IOSNSUnderlineStyle]. ///The default value for this attribute is [IOSNSUnderlineStyle.STYLE_NONE]. - IOSNSUnderlineStyle? underlineStyle; + IOSNSUnderlineStyle_? underlineStyle; - IOSNSAttributedString({ + IOSNSAttributedString_({ required this.string, this.backgroundColor, this.baselineOffset, @@ -274,35 +251,4 @@ class IOSNSAttributedString { this.underlineColor, this.underlineStyle, }); - - ///Converts instance to a map. - Map toMap() { - return { - "string": this.string, - "backgroundColor": this.backgroundColor?.toHex(), - "baselineOffset": this.baselineOffset, - "expansion": this.expansion, - "foregroundColor": this.foregroundColor?.toHex(), - "kern": this.kern, - "ligature": this.ligature, - "obliqueness": this.obliqueness, - "strikethroughColor": this.strikethroughColor?.toHex(), - "strikethroughStyle": this.strikethroughStyle?.toValue(), - "strokeColor": this.strokeColor?.toHex(), - "strokeWidth": this.strokeWidth, - "textEffect": this.textEffect?.toValue(), - "underlineColor": this.underlineColor?.toHex(), - "underlineStyle": this.underlineStyle?.toValue(), - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/attributed_string.g.dart b/lib/src/types/attributed_string.g.dart new file mode 100644 index 00000000..9e019ed8 --- /dev/null +++ b/lib/src/types/attributed_string.g.dart @@ -0,0 +1,383 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'attributed_string.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents a string with associated attributes +///used by the [PullToRefreshController] and [PullToRefreshSettings] classes. +class AttributedString { + ///The characters for the new object. + String string; + + ///The color of the background behind the text. + /// + ///The value of this attribute is a [Color] object. + ///Use this attribute to specify the color of the background area behind the text. + ///If you do not specify this attribute, no background color is drawn. + Color? backgroundColor; + + ///The vertical offset for the position of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating the character’s offset from the baseline, in points. + ///The default value is `0`. + double? baselineOffset; + + ///The expansion factor of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating the log of the expansion factor to be applied to glyphs. + ///The default value is `0`, indicating no expansion. + double? expansion; + + ///The color of the text. + /// + ///The value of this attribute is a [Color] object. + ///Use this attribute to specify the color of the text during rendering. + ///If you do not specify this attribute, the text is rendered in black. + Color? foregroundColor; + + ///The kerning of the text. + /// + ///The value of this attribute is a number containing a floating-point value. + ///This value specifies the number of points by which to adjust kern-pair characters. + ///Kerning prevents unwanted space from occurring between specific characters and depends on the font. + ///The value `0` means kerning is disabled. The default value for this attribute is `0`. + double? kern; + + ///The ligature of the text. + /// + ///The value of this attribute is a number containing an integer. + ///Ligatures cause specific character combinations to be rendered using a single custom glyph that corresponds to those characters. + ///The value `0` indicates no ligatures. The value `1` indicates the use of the default ligatures. + ///The value `2` indicates the use of all ligatures. + ///The default value for this attribute is `1`. (Value `2` is unsupported on iOS.) + int? ligature; + + ///The obliqueness of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating skew to be applied to glyphs. + ///The default value is `0`, indicating no skew. + double? obliqueness; + + ///The color of the strikethrough. + /// + ///The value of this attribute is a [Color] object. The default value is `null`, indicating same as foreground color. + Color? strikethroughColor; + + ///The strikethrough style of the text. + /// + ///This value indicates whether the text has a line through it and corresponds to one of the constants described in [UnderlineStyle]. + ///The default value for this attribute is [UnderlineStyle.STYLE_NONE]. + UnderlineStyle? strikethroughStyle; + + ///The color of the stroke. + /// + ///The value of this parameter is a [Color] object. + ///If it is not defined (which is the case by default), it is assumed to be the same as the value of foregroundColor; + ///otherwise, it describes the outline color. + Color? strokeColor; + + ///The width of the stroke. + /// + ///The value of this attribute is a number containing a floating-point value. + ///This value represents the amount to change the stroke width and is specified as a percentage of the font point size. + ///Specify `0` (the default) for no additional changes. + ///Specify positive values to change the stroke width alone. + ///Specify negative values to stroke and fill the text. + ///For example, a typical value for outlined text would be `3.0`. + double? strokeWidth; + + ///The text effect. + /// + ///The value of this attribute is a [AttributedStringTextEffectStyle] object. + ///The default value of this property is `null`, indicating no text effect. + AttributedStringTextEffectStyle? textEffect; + + ///The color of the underline. + /// + ///The value of this attribute is a [Color] object. + ///The default value is `null`, indicating same as foreground color. + Color? underlineColor; + + ///The underline style of the text. + /// + ///This value indicates whether the text is underlined and corresponds to one of the constants described in [UnderlineStyle]. + ///The default value for this attribute is [UnderlineStyle.STYLE_NONE]. + UnderlineStyle? underlineStyle; + AttributedString( + {required this.string, + this.backgroundColor, + this.baselineOffset, + this.expansion, + this.foregroundColor, + this.kern, + this.ligature, + this.obliqueness, + this.strikethroughColor, + this.strikethroughStyle, + this.strokeColor, + this.strokeWidth, + this.textEffect, + this.underlineColor, + this.underlineStyle}); + + ///Gets a possible [AttributedString] instance from a [Map] value. + static AttributedString? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = AttributedString( + string: map['string'], + ); + instance.backgroundColor = map['backgroundColor'] != null + ? UtilColor.fromStringRepresentation(map['backgroundColor']) + : null; + instance.baselineOffset = map['baselineOffset']; + instance.expansion = map['expansion']; + instance.foregroundColor = map['foregroundColor'] != null + ? UtilColor.fromStringRepresentation(map['foregroundColor']) + : null; + instance.kern = map['kern']; + instance.ligature = map['ligature']; + instance.obliqueness = map['obliqueness']; + instance.strikethroughColor = map['strikethroughColor'] != null + ? UtilColor.fromStringRepresentation(map['strikethroughColor']) + : null; + instance.strikethroughStyle = + UnderlineStyle.fromNativeValue(map['strikethroughStyle']); + instance.strokeColor = map['strokeColor'] != null + ? UtilColor.fromStringRepresentation(map['strokeColor']) + : null; + instance.strokeWidth = map['strokeWidth']; + instance.textEffect = + AttributedStringTextEffectStyle.fromNativeValue(map['textEffect']); + instance.underlineColor = map['underlineColor'] != null + ? UtilColor.fromStringRepresentation(map['underlineColor']) + : null; + instance.underlineStyle = + UnderlineStyle.fromNativeValue(map['underlineStyle']); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "string": string, + "backgroundColor": backgroundColor?.toHex(), + "baselineOffset": baselineOffset, + "expansion": expansion, + "foregroundColor": foregroundColor?.toHex(), + "kern": kern, + "ligature": ligature, + "obliqueness": obliqueness, + "strikethroughColor": strikethroughColor?.toHex(), + "strikethroughStyle": strikethroughStyle?.toNativeValue(), + "strokeColor": strokeColor?.toHex(), + "strokeWidth": strokeWidth, + "textEffect": textEffect?.toNativeValue(), + "underlineColor": underlineColor?.toHex(), + "underlineStyle": underlineStyle?.toNativeValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'AttributedString{string: $string, backgroundColor: $backgroundColor, baselineOffset: $baselineOffset, expansion: $expansion, foregroundColor: $foregroundColor, kern: $kern, ligature: $ligature, obliqueness: $obliqueness, strikethroughColor: $strikethroughColor, strikethroughStyle: $strikethroughStyle, strokeColor: $strokeColor, strokeWidth: $strokeWidth, textEffect: $textEffect, underlineColor: $underlineColor, underlineStyle: $underlineStyle}'; + } +} + +///An iOS-specific class that represents a string with associated attributes +///used by the [PullToRefreshController] and [PullToRefreshOptions] classes. +///Use [AttributedString] instead. +@Deprecated('Use AttributedString instead') +class IOSNSAttributedString { + ///The characters for the new object. + String string; + + ///The color of the background behind the text. + /// + ///The value of this attribute is a [Color] object. + ///Use this attribute to specify the color of the background area behind the text. + ///If you do not specify this attribute, no background color is drawn. + Color? backgroundColor; + + ///The vertical offset for the position of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating the character’s offset from the baseline, in points. + ///The default value is `0`. + double? baselineOffset; + + ///The expansion factor of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating the log of the expansion factor to be applied to glyphs. + ///The default value is `0`, indicating no expansion. + double? expansion; + + ///The color of the text. + /// + ///The value of this attribute is a [Color] object. + ///Use this attribute to specify the color of the text during rendering. + ///If you do not specify this attribute, the text is rendered in black. + Color? foregroundColor; + + ///The kerning of the text. + /// + ///The value of this attribute is a number containing a floating-point value. + ///This value specifies the number of points by which to adjust kern-pair characters. + ///Kerning prevents unwanted space from occurring between specific characters and depends on the font. + ///The value `0` means kerning is disabled. The default value for this attribute is `0`. + double? kern; + + ///The ligature of the text. + /// + ///The value of this attribute is a number containing an integer. + ///Ligatures cause specific character combinations to be rendered using a single custom glyph that corresponds to those characters. + ///The value `0` indicates no ligatures. The value `1` indicates the use of the default ligatures. + ///The value `2` indicates the use of all ligatures. + ///The default value for this attribute is `1`. (Value `2` is unsupported on iOS.) + int? ligature; + + ///The obliqueness of the text. + /// + ///The value of this attribute is a number containing a floating point value indicating skew to be applied to glyphs. + ///The default value is `0`, indicating no skew. + double? obliqueness; + + ///The color of the strikethrough. + /// + ///The value of this attribute is a [Color] object. The default value is `null`, indicating same as foreground color. + Color? strikethroughColor; + + ///The strikethrough style of the text. + /// + ///This value indicates whether the text has a line through it and corresponds to one of the constants described in [IOSNSUnderlineStyle]. + ///The default value for this attribute is [IOSNSUnderlineStyle.STYLE_NONE]. + IOSNSUnderlineStyle? strikethroughStyle; + + ///The color of the stroke. + /// + ///The value of this parameter is a [Color] object. + ///If it is not defined (which is the case by default), it is assumed to be the same as the value of foregroundColor; + ///otherwise, it describes the outline color. + Color? strokeColor; + + ///The width of the stroke. + /// + ///The value of this attribute is a number containing a floating-point value. + ///This value represents the amount to change the stroke width and is specified as a percentage of the font point size. + ///Specify `0` (the default) for no additional changes. + ///Specify positive values to change the stroke width alone. + ///Specify negative values to stroke and fill the text. + ///For example, a typical value for outlined text would be `3.0`. + double? strokeWidth; + + ///The text effect. + /// + ///The value of this attribute is a [IOSNSAttributedStringTextEffectStyle] object. + ///The default value of this property is `null`, indicating no text effect. + IOSNSAttributedStringTextEffectStyle? textEffect; + + ///The color of the underline. + /// + ///The value of this attribute is a [Color] object. + ///The default value is `null`, indicating same as foreground color. + Color? underlineColor; + + ///The underline style of the text. + /// + ///This value indicates whether the text is underlined and corresponds to one of the constants described in [IOSNSUnderlineStyle]. + ///The default value for this attribute is [IOSNSUnderlineStyle.STYLE_NONE]. + IOSNSUnderlineStyle? underlineStyle; + IOSNSAttributedString( + {required this.string, + this.backgroundColor, + this.baselineOffset, + this.expansion, + this.foregroundColor, + this.kern, + this.ligature, + this.obliqueness, + this.strikethroughColor, + this.strikethroughStyle, + this.strokeColor, + this.strokeWidth, + this.textEffect, + this.underlineColor, + this.underlineStyle}); + + ///Gets a possible [IOSNSAttributedString] instance from a [Map] value. + static IOSNSAttributedString? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = IOSNSAttributedString( + string: map['string'], + ); + instance.backgroundColor = map['backgroundColor'] != null + ? UtilColor.fromStringRepresentation(map['backgroundColor']) + : null; + instance.baselineOffset = map['baselineOffset']; + instance.expansion = map['expansion']; + instance.foregroundColor = map['foregroundColor'] != null + ? UtilColor.fromStringRepresentation(map['foregroundColor']) + : null; + instance.kern = map['kern']; + instance.ligature = map['ligature']; + instance.obliqueness = map['obliqueness']; + instance.strikethroughColor = map['strikethroughColor'] != null + ? UtilColor.fromStringRepresentation(map['strikethroughColor']) + : null; + instance.strikethroughStyle = + IOSNSUnderlineStyle.fromNativeValue(map['strikethroughStyle']); + instance.strokeColor = map['strokeColor'] != null + ? UtilColor.fromStringRepresentation(map['strokeColor']) + : null; + instance.strokeWidth = map['strokeWidth']; + instance.textEffect = + IOSNSAttributedStringTextEffectStyle.fromNativeValue(map['textEffect']); + instance.underlineColor = map['underlineColor'] != null + ? UtilColor.fromStringRepresentation(map['underlineColor']) + : null; + instance.underlineStyle = + IOSNSUnderlineStyle.fromNativeValue(map['underlineStyle']); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "string": string, + "backgroundColor": backgroundColor?.toHex(), + "baselineOffset": baselineOffset, + "expansion": expansion, + "foregroundColor": foregroundColor?.toHex(), + "kern": kern, + "ligature": ligature, + "obliqueness": obliqueness, + "strikethroughColor": strikethroughColor?.toHex(), + "strikethroughStyle": strikethroughStyle?.toNativeValue(), + "strokeColor": strokeColor?.toHex(), + "strokeWidth": strokeWidth, + "textEffect": textEffect?.toNativeValue(), + "underlineColor": underlineColor?.toHex(), + "underlineStyle": underlineStyle?.toNativeValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'IOSNSAttributedString{string: $string, backgroundColor: $backgroundColor, baselineOffset: $baselineOffset, expansion: $expansion, foregroundColor: $foregroundColor, kern: $kern, ligature: $ligature, obliqueness: $obliqueness, strikethroughColor: $strikethroughColor, strikethroughStyle: $strikethroughStyle, strokeColor: $strokeColor, strokeWidth: $strokeWidth, textEffect: $textEffect, underlineColor: $underlineColor, underlineStyle: $underlineStyle}'; + } +} diff --git a/lib/src/types/attributed_string_text_effect_style.dart b/lib/src/types/attributed_string_text_effect_style.dart index 74f74e83..10277280 100644 --- a/lib/src/types/attributed_string_text_effect_style.dart +++ b/lib/src/types/attributed_string_text_effect_style.dart @@ -1,81 +1,29 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'attributed_string_text_effect_style.g.dart'; + ///Class that represents the supported proxy types. -class AttributedStringTextEffectStyle { +@ExchangeableEnum() +class AttributedStringTextEffectStyle_ { + // ignore: unused_field final String _value; - - const AttributedStringTextEffectStyle._internal(this._value); - - ///Set of all values of [AttributedStringTextEffectStyle]. - static final Set values = [ - AttributedStringTextEffectStyle.LETTERPRESS_STYLE, - ].toSet(); - - ///Gets a possible [AttributedStringTextEffectStyle] instance from a [String] value. - static AttributedStringTextEffectStyle? fromValue(String? value) { - if (value != null) { - try { - return AttributedStringTextEffectStyle.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const AttributedStringTextEffectStyle_._internal(this._value); ///A graphical text effect that gives glyphs the appearance of letterpress printing, which involves pressing the type into the paper. static const LETTERPRESS_STYLE = - const AttributedStringTextEffectStyle._internal("letterpressStyle"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + const AttributedStringTextEffectStyle_._internal("letterpressStyle"); } ///An iOS-specific Class that represents the supported proxy types. ///Use [AttributedStringTextEffectStyle] instead. @Deprecated("Use AttributedStringTextEffectStyle instead") -class IOSNSAttributedStringTextEffectStyle { +@ExchangeableEnum() +class IOSNSAttributedStringTextEffectStyle_ { + // ignore: unused_field final String _value; - - const IOSNSAttributedStringTextEffectStyle._internal(this._value); - - ///Set of all values of [IOSNSAttributedStringTextEffectStyle]. - static final Set values = [ - IOSNSAttributedStringTextEffectStyle.LETTERPRESS_STYLE, - ].toSet(); - - ///Gets a possible [IOSNSAttributedStringTextEffectStyle] instance from a [String] value. - static IOSNSAttributedStringTextEffectStyle? fromValue(String? value) { - if (value != null) { - try { - return IOSNSAttributedStringTextEffectStyle.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const IOSNSAttributedStringTextEffectStyle_._internal(this._value); ///A graphical text effect that gives glyphs the appearance of letterpress printing, which involves pressing the type into the paper. static const LETTERPRESS_STYLE = - const IOSNSAttributedStringTextEffectStyle._internal("letterpressStyle"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + const IOSNSAttributedStringTextEffectStyle_._internal("letterpressStyle"); } \ No newline at end of file diff --git a/lib/src/types/attributed_string_text_effect_style.g.dart b/lib/src/types/attributed_string_text_effect_style.g.dart new file mode 100644 index 00000000..209146bf --- /dev/null +++ b/lib/src/types/attributed_string_text_effect_style.g.dart @@ -0,0 +1,138 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'attributed_string_text_effect_style.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the supported proxy types. +class AttributedStringTextEffectStyle { + final String _value; + final String _nativeValue; + const AttributedStringTextEffectStyle._internal( + this._value, this._nativeValue); +// ignore: unused_element + factory AttributedStringTextEffectStyle._internalMultiPlatform( + String value, Function nativeValue) => + AttributedStringTextEffectStyle._internal(value, nativeValue()); + + ///A graphical text effect that gives glyphs the appearance of letterpress printing, which involves pressing the type into the paper. + static const LETTERPRESS_STYLE = AttributedStringTextEffectStyle._internal( + 'letterpressStyle', 'letterpressStyle'); + + ///Set of all values of [AttributedStringTextEffectStyle]. + static final Set values = [ + AttributedStringTextEffectStyle.LETTERPRESS_STYLE, + ].toSet(); + + ///Gets a possible [AttributedStringTextEffectStyle] instance from [String] value. + static AttributedStringTextEffectStyle? fromValue(String? value) { + if (value != null) { + try { + return AttributedStringTextEffectStyle.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [AttributedStringTextEffectStyle] instance from a native value. + static AttributedStringTextEffectStyle? fromNativeValue(String? value) { + if (value != null) { + try { + return AttributedStringTextEffectStyle.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} + +///An iOS-specific Class that represents the supported proxy types. +///Use [AttributedStringTextEffectStyle] instead. +@Deprecated('Use AttributedStringTextEffectStyle instead') +class IOSNSAttributedStringTextEffectStyle { + final String _value; + final String _nativeValue; + const IOSNSAttributedStringTextEffectStyle._internal( + this._value, this._nativeValue); +// ignore: unused_element + factory IOSNSAttributedStringTextEffectStyle._internalMultiPlatform( + String value, Function nativeValue) => + IOSNSAttributedStringTextEffectStyle._internal(value, nativeValue()); + + ///A graphical text effect that gives glyphs the appearance of letterpress printing, which involves pressing the type into the paper. + static const LETTERPRESS_STYLE = + IOSNSAttributedStringTextEffectStyle._internal( + 'letterpressStyle', 'letterpressStyle'); + + ///Set of all values of [IOSNSAttributedStringTextEffectStyle]. + static final Set values = [ + IOSNSAttributedStringTextEffectStyle.LETTERPRESS_STYLE, + ].toSet(); + + ///Gets a possible [IOSNSAttributedStringTextEffectStyle] instance from [String] value. + static IOSNSAttributedStringTextEffectStyle? fromValue(String? value) { + if (value != null) { + try { + return IOSNSAttributedStringTextEffectStyle.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [IOSNSAttributedStringTextEffectStyle] instance from a native value. + static IOSNSAttributedStringTextEffectStyle? fromNativeValue(String? value) { + if (value != null) { + try { + return IOSNSAttributedStringTextEffectStyle.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/cache_mode.dart b/lib/src/types/cache_mode.dart index b917518a..0b6f6eab 100644 --- a/lib/src/types/cache_mode.dart +++ b/lib/src/types/cache_mode.dart @@ -1,129 +1,47 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'cache_mode.g.dart'; + ///Class used to override the way the cache is used. -class CacheMode { +@ExchangeableEnum() +class CacheMode_ { + // ignore: unused_field final int _value; - - const CacheMode._internal(this._value); - - ///Set of all values of [CacheMode]. - static final Set values = [ - CacheMode.LOAD_DEFAULT, - CacheMode.LOAD_CACHE_ELSE_NETWORK, - CacheMode.LOAD_NO_CACHE, - CacheMode.LOAD_CACHE_ONLY, - ].toSet(); - - ///Gets a possible [CacheMode] instance from an [int] value. - static CacheMode? fromValue(int? value) { - if (value != null) { - try { - return CacheMode.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "LOAD_CACHE_ELSE_NETWORK"; - case 2: - return "LOAD_NO_CACHE"; - case 3: - return "LOAD_CACHE_ONLY"; - case -1: - default: - return "LOAD_DEFAULT"; - } - } + const CacheMode_._internal(this._value); ///Default cache usage mode. If the navigation type doesn't impose any specific behavior, ///use cached resources when they are available and not expired, otherwise load resources from the network. - static const LOAD_DEFAULT = const CacheMode._internal(-1); + static const LOAD_DEFAULT = const CacheMode_._internal(-1); ///Use cached resources when they are available, even if they have expired. Otherwise load resources from the network. - static const LOAD_CACHE_ELSE_NETWORK = const CacheMode._internal(1); + static const LOAD_CACHE_ELSE_NETWORK = const CacheMode_._internal(1); ///Don't use the cache, load from the network. - static const LOAD_NO_CACHE = const CacheMode._internal(2); + static const LOAD_NO_CACHE = const CacheMode_._internal(2); ///Don't use the network, load from the cache. - static const LOAD_CACHE_ONLY = const CacheMode._internal(3); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const LOAD_CACHE_ONLY = const CacheMode_._internal(3); } ///An Android-specific class used to override the way the cache is used. ///Use [CacheMode] instead. @Deprecated("Use CacheMode instead") -class AndroidCacheMode { +@ExchangeableEnum() +class AndroidCacheMode_ { + // ignore: unused_field final int _value; - - const AndroidCacheMode._internal(this._value); - - ///Set of all values of [AndroidCacheMode]. - static final Set values = [ - AndroidCacheMode.LOAD_DEFAULT, - AndroidCacheMode.LOAD_CACHE_ELSE_NETWORK, - AndroidCacheMode.LOAD_NO_CACHE, - AndroidCacheMode.LOAD_CACHE_ONLY, - ].toSet(); - - ///Gets a possible [AndroidCacheMode] instance from an [int] value. - static AndroidCacheMode? fromValue(int? value) { - if (value != null) { - try { - return AndroidCacheMode.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "LOAD_CACHE_ELSE_NETWORK"; - case 2: - return "LOAD_NO_CACHE"; - case 3: - return "LOAD_CACHE_ONLY"; - case -1: - default: - return "LOAD_DEFAULT"; - } - } + const AndroidCacheMode_._internal(this._value); ///Default cache usage mode. If the navigation type doesn't impose any specific behavior, ///use cached resources when they are available and not expired, otherwise load resources from the network. - static const LOAD_DEFAULT = const AndroidCacheMode._internal(-1); + static const LOAD_DEFAULT = const AndroidCacheMode_._internal(-1); ///Use cached resources when they are available, even if they have expired. Otherwise load resources from the network. - static const LOAD_CACHE_ELSE_NETWORK = const AndroidCacheMode._internal(1); + static const LOAD_CACHE_ELSE_NETWORK = const AndroidCacheMode_._internal(1); ///Don't use the cache, load from the network. - static const LOAD_NO_CACHE = const AndroidCacheMode._internal(2); + static const LOAD_NO_CACHE = const AndroidCacheMode_._internal(2); ///Don't use the network, load from the cache. - static const LOAD_CACHE_ONLY = const AndroidCacheMode._internal(3); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const LOAD_CACHE_ONLY = const AndroidCacheMode_._internal(3); } \ No newline at end of file diff --git a/lib/src/types/cache_mode.g.dart b/lib/src/types/cache_mode.g.dart new file mode 100644 index 00000000..41099ee5 --- /dev/null +++ b/lib/src/types/cache_mode.g.dart @@ -0,0 +1,178 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'cache_mode.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used to override the way the cache is used. +class CacheMode { + final int _value; + final int _nativeValue; + const CacheMode._internal(this._value, this._nativeValue); +// ignore: unused_element + factory CacheMode._internalMultiPlatform(int value, Function nativeValue) => + CacheMode._internal(value, nativeValue()); + + ///Default cache usage mode. If the navigation type doesn't impose any specific behavior, + ///use cached resources when they are available and not expired, otherwise load resources from the network. + static const LOAD_DEFAULT = CacheMode._internal(-1, -1); + + ///Use cached resources when they are available, even if they have expired. Otherwise load resources from the network. + static const LOAD_CACHE_ELSE_NETWORK = CacheMode._internal(1, 1); + + ///Don't use the cache, load from the network. + static const LOAD_NO_CACHE = CacheMode._internal(2, 2); + + ///Don't use the network, load from the cache. + static const LOAD_CACHE_ONLY = CacheMode._internal(3, 3); + + ///Set of all values of [CacheMode]. + static final Set values = [ + CacheMode.LOAD_DEFAULT, + CacheMode.LOAD_CACHE_ELSE_NETWORK, + CacheMode.LOAD_NO_CACHE, + CacheMode.LOAD_CACHE_ONLY, + ].toSet(); + + ///Gets a possible [CacheMode] instance from [int] value. + static CacheMode? fromValue(int? value) { + if (value != null) { + try { + return CacheMode.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [CacheMode] instance from a native value. + static CacheMode? fromNativeValue(int? value) { + if (value != null) { + try { + return CacheMode.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case -1: + return 'LOAD_DEFAULT'; + case 1: + return 'LOAD_CACHE_ELSE_NETWORK'; + case 2: + return 'LOAD_NO_CACHE'; + case 3: + return 'LOAD_CACHE_ONLY'; + } + return _value.toString(); + } +} + +///An Android-specific class used to override the way the cache is used. +///Use [CacheMode] instead. +@Deprecated('Use CacheMode instead') +class AndroidCacheMode { + final int _value; + final int _nativeValue; + const AndroidCacheMode._internal(this._value, this._nativeValue); +// ignore: unused_element + factory AndroidCacheMode._internalMultiPlatform( + int value, Function nativeValue) => + AndroidCacheMode._internal(value, nativeValue()); + + ///Default cache usage mode. If the navigation type doesn't impose any specific behavior, + ///use cached resources when they are available and not expired, otherwise load resources from the network. + static const LOAD_DEFAULT = AndroidCacheMode._internal(-1, -1); + + ///Use cached resources when they are available, even if they have expired. Otherwise load resources from the network. + static const LOAD_CACHE_ELSE_NETWORK = AndroidCacheMode._internal(1, 1); + + ///Don't use the cache, load from the network. + static const LOAD_NO_CACHE = AndroidCacheMode._internal(2, 2); + + ///Don't use the network, load from the cache. + static const LOAD_CACHE_ONLY = AndroidCacheMode._internal(3, 3); + + ///Set of all values of [AndroidCacheMode]. + static final Set values = [ + AndroidCacheMode.LOAD_DEFAULT, + AndroidCacheMode.LOAD_CACHE_ELSE_NETWORK, + AndroidCacheMode.LOAD_NO_CACHE, + AndroidCacheMode.LOAD_CACHE_ONLY, + ].toSet(); + + ///Gets a possible [AndroidCacheMode] instance from [int] value. + static AndroidCacheMode? fromValue(int? value) { + if (value != null) { + try { + return AndroidCacheMode.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [AndroidCacheMode] instance from a native value. + static AndroidCacheMode? fromNativeValue(int? value) { + if (value != null) { + try { + return AndroidCacheMode.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case -1: + return 'LOAD_DEFAULT'; + case 1: + return 'LOAD_CACHE_ELSE_NETWORK'; + case 2: + return 'LOAD_NO_CACHE'; + case 3: + return 'LOAD_CACHE_ONLY'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/call_async_javascript_result.dart b/lib/src/types/call_async_javascript_result.dart index d46bedcf..1b8c53b0 100644 --- a/lib/src/types/call_async_javascript_result.dart +++ b/lib/src/types/call_async_javascript_result.dart @@ -1,27 +1,17 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../in_app_webview/in_app_webview_controller.dart'; +part 'call_async_javascript_result.g.dart'; + ///Class that represents either a success or a failure, including an associated value in each case for [InAppWebViewController.callAsyncJavaScript]. -class CallAsyncJavaScriptResult { +@ExchangeableObject() +class CallAsyncJavaScriptResult_ { ///It contains the success value. dynamic value; ///It contains the failure value. String? error; - CallAsyncJavaScriptResult({this.value, this.error}); - - ///Converts instance to a map. - Map toMap() { - return {"value": value, "error": error}; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } + CallAsyncJavaScriptResult_({this.value, this.error}); } \ No newline at end of file diff --git a/lib/src/types/call_async_javascript_result.g.dart b/lib/src/types/call_async_javascript_result.g.dart new file mode 100644 index 00000000..6c1cce43 --- /dev/null +++ b/lib/src/types/call_async_javascript_result.g.dart @@ -0,0 +1,46 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'call_async_javascript_result.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents either a success or a failure, including an associated value in each case for [InAppWebViewController.callAsyncJavaScript]. +class CallAsyncJavaScriptResult { + ///It contains the success value. + dynamic value; + + ///It contains the failure value. + String? error; + CallAsyncJavaScriptResult({this.value, this.error}); + + ///Gets a possible [CallAsyncJavaScriptResult] instance from a [Map] value. + static CallAsyncJavaScriptResult? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = CallAsyncJavaScriptResult(); + instance.value = map['value']; + instance.error = map['error']; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "value": value, + "error": error, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'CallAsyncJavaScriptResult{value: $value, error: $error}'; + } +} diff --git a/lib/src/types/client_cert_challenge.dart b/lib/src/types/client_cert_challenge.dart index 0ade9240..2de0e39c 100644 --- a/lib/src/types/client_cert_challenge.dart +++ b/lib/src/types/client_cert_challenge.dart @@ -1,17 +1,27 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../in_app_webview/webview.dart'; import 'url_authentication_challenge.dart'; import 'url_protection_space.dart'; +part 'client_cert_challenge.g.dart'; + ///Class that represents the challenge of the [WebView.onReceivedClientCertRequest] event. ///It provides all the information about the challenge. -class ClientCertChallenge extends URLAuthenticationChallenge { +@ExchangeableObject() +class ClientCertChallenge_ extends URLAuthenticationChallenge_ { ///Use [principals] instead. @Deprecated('Use principals instead') List? androidPrincipals; ///The acceptable certificate issuers for the certificate matching the private key. - /// - ///**NOTE**: available only on Android. + @SupportedPlatforms(platforms: [ + AndroidPlatform( + apiName: "ClientCertRequest.getPrincipals", + apiUrl: "https://developer.android.com/reference/android/webkit/ClientCertRequest#getPrincipals()", + available: "21" + ) + ]) List? principals; ///Use [keyTypes] instead. @@ -19,36 +29,20 @@ class ClientCertChallenge extends URLAuthenticationChallenge { List? androidKeyTypes; ///Returns the acceptable types of asymmetric keys. - /// - ///**NOTE**: available only on Android. + @SupportedPlatforms(platforms: [ + AndroidPlatform( + apiName: "ClientCertRequest.getKeyTypes", + apiUrl: "https://developer.android.com/reference/android/webkit/ClientCertRequest#getKeyTypes()", + available: "21" + ) + ]) List? keyTypes; - ClientCertChallenge( + ClientCertChallenge_( {required URLProtectionSpace protectionSpace, @Deprecated('Use principals instead') this.androidPrincipals, this.principals, @Deprecated('Use keyTypes instead') this.androidKeyTypes, this.keyTypes}) - : super(protectionSpace: protectionSpace) { - // ignore: deprecated_member_use_from_same_package - this.principals = this.principals ?? this.androidPrincipals; - // ignore: deprecated_member_use_from_same_package - this.keyTypes = this.keyTypes ?? this.androidKeyTypes; - } - - ///Gets a possible [ClientCertChallenge] instance from a [Map] value. - static ClientCertChallenge? fromMap(Map? map) { - if (map == null) { - return null; - } - return ClientCertChallenge( - protectionSpace: URLProtectionSpace.fromMap( - map["protectionSpace"].cast())!, - // ignore: deprecated_member_use_from_same_package - androidPrincipals: map["principals"]?.cast(), - principals: map["principals"]?.cast(), - // ignore: deprecated_member_use_from_same_package - androidKeyTypes: map["keyTypes"]?.cast(), - keyTypes: map["keyTypes"]?.cast()); - } + : super(protectionSpace: protectionSpace); } \ No newline at end of file diff --git a/lib/src/types/client_cert_challenge.g.dart b/lib/src/types/client_cert_challenge.g.dart new file mode 100644 index 00000000..15d39c97 --- /dev/null +++ b/lib/src/types/client_cert_challenge.g.dart @@ -0,0 +1,75 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'client_cert_challenge.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents the challenge of the [WebView.onReceivedClientCertRequest] event. +///It provides all the information about the challenge. +class ClientCertChallenge extends URLAuthenticationChallenge { + ///Use [principals] instead. + @Deprecated('Use principals instead') + List? androidPrincipals; + + ///The acceptable certificate issuers for the certificate matching the private key. + /// + ///**Supported Platforms/Implementations**: + ///- Android native WebView 21+ ([Official API - ClientCertRequest.getPrincipals](https://developer.android.com/reference/android/webkit/ClientCertRequest#getPrincipals())) + List? principals; + + ///Use [keyTypes] instead. + @Deprecated('Use keyTypes instead') + List? androidKeyTypes; + + ///Returns the acceptable types of asymmetric keys. + /// + ///**Supported Platforms/Implementations**: + ///- Android native WebView 21+ ([Official API - ClientCertRequest.getKeyTypes](https://developer.android.com/reference/android/webkit/ClientCertRequest#getKeyTypes())) + List? keyTypes; + ClientCertChallenge( + {@Deprecated('Use principals instead') this.androidPrincipals, + this.principals, + @Deprecated('Use keyTypes instead') this.androidKeyTypes, + this.keyTypes, + dynamic protectionSpace}) + : super(protectionSpace: protectionSpace) { + principals = principals ?? androidPrincipals; + keyTypes = keyTypes ?? androidKeyTypes; + } + + ///Gets a possible [ClientCertChallenge] instance from a [Map] value. + static ClientCertChallenge? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = ClientCertChallenge( + protectionSpace: map['protectionSpace'], + ); + instance.androidPrincipals = map['principals']; + instance.principals = map['principals']; + instance.androidKeyTypes = map['keyTypes']; + instance.keyTypes = map['keyTypes']; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "protectionSpace": protectionSpace, + "principals": principals, + "keyTypes": keyTypes, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'ClientCertChallenge{protectionSpace: $protectionSpace, principals: $principals, keyTypes: $keyTypes}'; + } +} diff --git a/lib/src/types/main.dart b/lib/src/types/main.dart index f984c4f5..1abe6550 100644 --- a/lib/src/types/main.dart +++ b/lib/src/types/main.dart @@ -1,162 +1,162 @@ -export 'action_mode_menu_item.dart'; -export 'ajax_request.dart'; -export 'ajax_request_action.dart'; -export 'ajax_request_event.dart'; -export 'ajax_request_event_type.dart'; -export 'ajax_request_headers.dart'; -export 'ajax_request_ready_state.dart'; -export 'attributed_string.dart'; -export 'attributed_string_text_effect_style.dart'; -export 'cache_mode.dart'; -export 'call_async_javascript_result.dart'; -export 'client_cert_challenge.dart'; -export 'client_cert_response.dart'; -export 'client_cert_response_action.dart'; -export 'compress_format.dart'; -export 'console_message.dart'; -export 'console_message_level.dart'; -export 'content_blocker_action_type.dart'; -export 'content_blocker_trigger_load_type.dart'; -export 'content_blocker_trigger_resource_type.dart'; -export 'content_world.dart'; -export 'cookie.dart'; -export 'create_window_action.dart'; -export 'cross_origin.dart'; -export 'css_link_html_tag_attributes.dart'; -export 'custom_scheme_response.dart'; -export 'custom_tabs_share_state.dart'; -export 'data_detector_types.dart'; -export 'dismiss_button_style.dart'; -export 'download_start_request.dart'; -export 'favicon.dart'; -export 'fetch_request.dart'; -export 'fetch_request_action.dart'; -export 'fetch_request_credential.dart'; -export 'fetch_request_credential_default.dart'; -export 'fetch_request_federated_credential.dart'; -export 'fetch_request_password_credential.dart'; -export 'force_dark.dart'; -export 'form_resubmission_action.dart'; -export 'frame_info.dart'; -export 'geolocation_permission_show_prompt_response.dart'; -export 'http_auth_response.dart'; -export 'http_auth_response_action.dart'; -export 'http_authentication_challenge.dart'; -export 'http_cookie_same_site_policy.dart'; -export 'in_app_webview_hit_test_result.dart'; -export 'in_app_webview_hit_test_result_type.dart'; -export 'in_app_webview_initial_data.dart'; -export 'in_app_webview_rect.dart'; -export 'javascript_handler_callback.dart'; -export 'js_alert_request.dart'; -export 'js_alert_response.dart'; -export 'js_alert_response_action.dart'; -export 'js_before_unload_request.dart'; -export 'js_before_unload_response.dart'; -export 'js_before_unload_response_action.dart'; -export 'js_confirm_request.dart'; -export 'js_confirm_response.dart'; -export 'js_confirm_response_action.dart'; -export 'js_prompt_request.dart'; -export 'js_prompt_response.dart'; -export 'js_prompt_response_action.dart'; -export 'layout_algorithm.dart'; -export 'layout_in_display_cutout_mode.dart'; -export 'loaded_resource.dart'; -export 'login_request.dart'; -export 'media_playback_state.dart'; -export 'meta_tag.dart'; -export 'meta_tag_attribute.dart'; -export 'mixed_content_mode.dart'; -export 'modal_presentation_style.dart'; -export 'modal_transition_style.dart'; -export 'navigation_action.dart'; -export 'navigation_action_policy.dart'; -export 'navigation_response.dart'; -export 'navigation_response_action.dart'; -export 'navigation_type.dart'; -export 'on_post_message_callback.dart'; -export 'over_scroll_mode.dart'; -export 'pdf_configuration.dart'; -export 'permission_request.dart'; -export 'permission_resource_type.dart'; -export 'permission_response.dart'; -export 'permission_response_action.dart'; -export 'pull_to_refresh_size.dart'; -export 'referrer_policy.dart'; -export 'render_process_gone_detail.dart'; -export 'renderer_priority.dart'; -export 'renderer_priority_policy.dart'; -export 'request_focus_node_href_result.dart'; -export 'request_image_ref_result.dart'; -export 'safe_browsing_response.dart'; -export 'safe_browsing_response_action.dart'; -export 'safe_browsing_threat.dart'; -export 'sandbox.dart'; -export 'screenshot_configuration.dart'; -export 'script_html_tag_attributes.dart'; -export 'scrollbar_style.dart'; -export 'scrollview_content_inset_adjustment_behavior.dart'; -export 'scrollview_deceleration_rate.dart'; -export 'security_origin.dart'; -export 'selection_granularity.dart'; -export 'server_trust_auth_response.dart'; -export 'server_trust_auth_response_action.dart'; -export 'server_trust_challenge.dart'; -export 'should_allow_deprecated_tls_action.dart'; -export 'ssl_certificate.dart'; -export 'ssl_certificate_dname.dart'; -export 'ssl_error.dart'; -export 'ssl_error_type.dart'; -export 'trusted_web_activity_default_display_mode.dart'; -export 'trusted_web_activity_display_mode.dart'; -export 'trusted_web_activity_immersive_display_mode.dart'; -export 'trusted_web_activity_screen_orientation.dart'; -export 'underline_style.dart'; -export 'url_authentication_challenge.dart'; -export 'url_credential.dart'; -export 'url_credential_persistence.dart'; -export 'url_protection_space.dart'; -export 'url_protection_space_authentication_method.dart'; -export 'url_protection_space_http_auth_credentials.dart'; -export 'url_protection_space_proxy_type.dart'; -export 'url_request.dart'; -export 'url_request_cache_policy.dart'; -export 'url_request_network_service_type.dart'; -export 'url_response.dart'; -export 'user_preferred_content_mode.dart'; -export 'user_script.dart'; -export 'user_script_injection_time.dart'; -export 'vertical_scrollbar_position.dart'; -export 'web_archive_format.dart'; -export 'web_history.dart'; -export 'web_history_item.dart'; -export 'web_message_callback.dart'; -export 'web_resource_request.dart'; -export 'web_resource_response.dart'; -export 'web_storage_origin.dart'; -export 'web_storage_type.dart'; -export 'website_data_record.dart'; -export 'website_data_type.dart'; -export 'webview_implementation.dart'; -export 'webview_package_info.dart'; -export 'webview_render_process_action.dart'; -export 'window_features.dart'; -export 'web_resource_error.dart'; -export 'web_resource_error_type.dart'; -export 'media_capture_state.dart'; -export 'proxy_rule.dart'; -export 'proxy_scheme_filter.dart'; -export 'force_dark_strategy.dart'; -export 'url_request_attribution.dart'; -export 'web_authentication_session_error.dart'; -export 'print_job_info.dart'; -export 'print_job_state.dart'; -export 'print_job_orientation.dart'; -export 'print_job_rendering_quality.dart'; -export 'print_job_media_size.dart'; -export 'print_job_color_mode.dart'; -export 'print_job_duplex_mode.dart'; -export 'print_job_output_type.dart'; -export 'print_job_resolution.dart'; -export 'print_job_attributes.dart'; \ No newline at end of file +export 'action_mode_menu_item.dart' show ActionModeMenuItem, AndroidActionModeMenuItem; +export 'ajax_request.dart' show AjaxRequest; +export 'ajax_request_action.dart' show AjaxRequestAction; +export 'ajax_request_event.dart' show AjaxRequestEvent; +export 'ajax_request_event_type.dart' show AjaxRequestEventType; +export 'ajax_request_headers.dart' show AjaxRequestHeaders; +export 'ajax_request_ready_state.dart' show AjaxRequestReadyState; +export 'attributed_string.dart' show AttributedString, IOSNSAttributedString; +export 'attributed_string_text_effect_style.dart' show AttributedStringTextEffectStyle, IOSNSAttributedStringTextEffectStyle; +export 'cache_mode.dart' show CacheMode, AndroidCacheMode; +export 'call_async_javascript_result.dart' show CallAsyncJavaScriptResult; +export 'client_cert_challenge.dart' show ClientCertChallenge; +export 'client_cert_response.dart' show ClientCertResponse; +export 'client_cert_response_action.dart' show ClientCertResponseAction; +export 'compress_format.dart' show CompressFormat; +export 'console_message.dart' show ConsoleMessage; +export 'console_message_level.dart' show ConsoleMessageLevel; +export 'content_blocker_action_type.dart' show ContentBlockerActionType; +export 'content_blocker_trigger_load_type.dart' show ContentBlockerTriggerLoadType; +export 'content_blocker_trigger_resource_type.dart' show ContentBlockerTriggerResourceType; +export 'content_world.dart' show ContentWorld; +export 'cookie.dart' show Cookie; +export 'create_window_action.dart' show CreateWindowAction; +export 'cross_origin.dart' show CrossOrigin; +export 'css_link_html_tag_attributes.dart' show CSSLinkHtmlTagAttributes; +export 'custom_scheme_response.dart' show CustomSchemeResponse; +export 'custom_tabs_share_state.dart' show CustomTabsShareState; +export 'data_detector_types.dart' show DataDetectorTypes, IOSWKDataDetectorTypes; +export 'dismiss_button_style.dart' show DismissButtonStyle, IOSSafariDismissButtonStyle; +export 'download_start_request.dart' show DownloadStartRequest; +export 'favicon.dart' show Favicon; +export 'fetch_request.dart' show FetchRequest; +export 'fetch_request_action.dart' show FetchRequestAction; +export 'fetch_request_credential.dart' show FetchRequestCredential; +export 'fetch_request_credential_default.dart' show FetchRequestCredentialDefault; +export 'fetch_request_federated_credential.dart' show FetchRequestFederatedCredential; +export 'fetch_request_password_credential.dart' show FetchRequestPasswordCredential; +export 'force_dark.dart' show ForceDark, AndroidForceDark; +export 'force_dark_strategy.dart' show ForceDarkStrategy; +export 'form_resubmission_action.dart' show FormResubmissionAction; +export 'frame_info.dart' show FrameInfo, IOSWKFrameInfo; +export 'geolocation_permission_show_prompt_response.dart' show GeolocationPermissionShowPromptResponse; +export 'http_auth_response.dart' show HttpAuthResponse; +export 'http_auth_response_action.dart' show HttpAuthResponseAction; +export 'http_authentication_challenge.dart' show HttpAuthenticationChallenge; +export 'http_cookie_same_site_policy.dart' show HTTPCookieSameSitePolicy; +export 'in_app_webview_hit_test_result.dart' show InAppWebViewHitTestResult; +export 'in_app_webview_hit_test_result_type.dart' show InAppWebViewHitTestResultType; +export 'in_app_webview_initial_data.dart' show InAppWebViewInitialData; +export 'in_app_webview_rect.dart' show InAppWebViewRect; +export 'javascript_handler_callback.dart' show JavaScriptHandlerCallback; +export 'js_alert_request.dart' show JsAlertRequest; +export 'js_alert_response.dart' show JsAlertResponse; +export 'js_alert_response_action.dart' show JsAlertResponseAction; +export 'js_before_unload_request.dart' show JsBeforeUnloadRequest; +export 'js_before_unload_response.dart' show JsBeforeUnloadResponse; +export 'js_before_unload_response_action.dart' show JsBeforeUnloadResponseAction; +export 'js_confirm_request.dart' show JsConfirmRequest; +export 'js_confirm_response.dart' show JsConfirmResponse; +export 'js_confirm_response_action.dart' show JsConfirmResponseAction; +export 'js_prompt_request.dart' show JsPromptRequest; +export 'js_prompt_response.dart' show JsPromptResponse; +export 'js_prompt_response_action.dart' show JsPromptResponseAction; +export 'layout_algorithm.dart' show LayoutAlgorithm, AndroidLayoutAlgorithm; +export 'layout_in_display_cutout_mode.dart' show LayoutInDisplayCutoutMode, AndroidLayoutInDisplayCutoutMode; +export 'loaded_resource.dart' show LoadedResource; +export 'login_request.dart' show LoginRequest; +export 'media_capture_state.dart' show MediaCaptureState; +export 'media_playback_state.dart' show MediaPlaybackState; +export 'meta_tag.dart' show MetaTag; +export 'meta_tag_attribute.dart' show MetaTagAttribute; +export 'mixed_content_mode.dart' show MixedContentMode, AndroidMixedContentMode; +export 'modal_presentation_style.dart' show ModalPresentationStyle, IOSUIModalPresentationStyle; +export 'modal_transition_style.dart' show ModalTransitionStyle, IOSUIModalTransitionStyle; +export 'navigation_action.dart' show NavigationAction; +export 'navigation_action_policy.dart' show NavigationActionPolicy; +export 'navigation_response.dart' show NavigationResponse, IOSWKNavigationResponse; +export 'navigation_response_action.dart' show NavigationResponseAction, IOSNavigationResponseAction; +export 'navigation_type.dart' show NavigationType, IOSWKNavigationType; +export 'on_post_message_callback.dart' show OnPostMessageCallback; +export 'over_scroll_mode.dart' show OverScrollMode, AndroidOverScrollMode; +export 'pdf_configuration.dart' show PDFConfiguration, IOSWKPDFConfiguration; +export 'permission_request.dart' show PermissionRequest; +export 'permission_resource_type.dart' show PermissionResourceType; +export 'permission_response.dart' show PermissionResponse, PermissionRequestResponse; +export 'permission_response_action.dart' show PermissionResponseAction, PermissionRequestResponseAction; +export 'print_job_attributes.dart' show PrintJobAttributes; +export 'print_job_color_mode.dart' show PrintJobColorMode; +export 'print_job_duplex_mode.dart' show PrintJobDuplexMode; +export 'print_job_info.dart' show PrintJobInfo; +export 'print_job_media_size.dart' show PrintJobMediaSize; +export 'print_job_orientation.dart' show PrintJobOrientation; +export 'print_job_output_type.dart' show PrintJobOutputType; +export 'print_job_rendering_quality.dart' show PrintJobRenderingQuality; +export 'print_job_resolution.dart' show PrintJobResolution; +export 'print_job_state.dart' show PrintJobState; +export 'proxy_rule.dart' show ProxyRule; +export 'proxy_scheme_filter.dart' show ProxySchemeFilter; +export 'pull_to_refresh_size.dart' show PullToRefreshSize, AndroidPullToRefreshSize; +export 'referrer_policy.dart' show ReferrerPolicy; +export 'render_process_gone_detail.dart' show RenderProcessGoneDetail; +export 'renderer_priority.dart' show RendererPriority; +export 'renderer_priority_policy.dart' show RendererPriorityPolicy; +export 'request_focus_node_href_result.dart' show RequestFocusNodeHrefResult; +export 'request_image_ref_result.dart' show RequestImageRefResult; +export 'safe_browsing_response.dart' show SafeBrowsingResponse; +export 'safe_browsing_response_action.dart' show SafeBrowsingResponseAction; +export 'safe_browsing_threat.dart' show SafeBrowsingThreat; +export 'sandbox.dart' show Sandbox; +export 'screenshot_configuration.dart' show ScreenshotConfiguration; +export 'script_html_tag_attributes.dart' show ScriptHtmlTagAttributes; +export 'scrollbar_style.dart' show ScrollBarStyle, AndroidScrollBarStyle; +export 'scrollview_content_inset_adjustment_behavior.dart' show ScrollViewContentInsetAdjustmentBehavior, IOSUIScrollViewContentInsetAdjustmentBehavior; +export 'scrollview_deceleration_rate.dart' show ScrollViewDecelerationRate, IOSUIScrollViewDecelerationRate; +export 'security_origin.dart' show SecurityOrigin, IOSWKSecurityOrigin; +export 'selection_granularity.dart' show SelectionGranularity, IOSWKSelectionGranularity; +export 'server_trust_auth_response.dart' show ServerTrustAuthResponse; +export 'server_trust_auth_response_action.dart' show ServerTrustAuthResponseAction; +export 'server_trust_challenge.dart' show ServerTrustChallenge; +export 'should_allow_deprecated_tls_action.dart' show ShouldAllowDeprecatedTLSAction, IOSShouldAllowDeprecatedTLSAction; +export 'ssl_certificate.dart' show SslCertificate; +export 'ssl_certificate_dname.dart' show SslCertificateDName; +export 'ssl_error.dart' show SslError; +export 'ssl_error_type.dart' show SslErrorType, AndroidSslError, IOSSslError; +export 'trusted_web_activity_default_display_mode.dart' show TrustedWebActivityDefaultDisplayMode; +export 'trusted_web_activity_display_mode.dart' show TrustedWebActivityDisplayMode; +export 'trusted_web_activity_immersive_display_mode.dart' show TrustedWebActivityImmersiveDisplayMode; +export 'trusted_web_activity_screen_orientation.dart' show TrustedWebActivityScreenOrientation; +export 'underline_style.dart' show UnderlineStyle, IOSNSUnderlineStyle; +export 'url_authentication_challenge.dart' show URLAuthenticationChallenge; +export 'url_credential.dart' show URLCredential; +export 'url_credential_persistence.dart' show URLCredentialPersistence, IOSURLCredentialPersistence; +export 'url_protection_space.dart' show URLProtectionSpace; +export 'url_protection_space_authentication_method.dart' show URLProtectionSpaceAuthenticationMethod, IOSNSURLProtectionSpaceAuthenticationMethod; +export 'url_protection_space_http_auth_credentials.dart' show URLProtectionSpaceHttpAuthCredentials; +export 'url_protection_space_proxy_type.dart' show URLProtectionSpaceProxyType, IOSNSURLProtectionSpaceProxyType; +export 'url_request.dart' show URLRequest; +export 'url_request_attribution.dart' show URLRequestAttribution; +export 'url_request_cache_policy.dart' show URLRequestCachePolicy, IOSURLRequestCachePolicy; +export 'url_request_network_service_type.dart' show URLRequestNetworkServiceType, IOSURLRequestNetworkServiceType; +export 'url_response.dart' show URLResponse, IOSURLResponse; +export 'user_preferred_content_mode.dart' show UserPreferredContentMode; +export 'user_script.dart' show UserScript; +export 'user_script_injection_time.dart' show UserScriptInjectionTime; +export 'vertical_scrollbar_position.dart' show VerticalScrollbarPosition, AndroidVerticalScrollbarPosition; +export 'web_archive_format.dart' show WebArchiveFormat; +export 'web_authentication_session_error.dart' show WebAuthenticationSessionError; +export 'web_history.dart' show WebHistory; +export 'web_history_item.dart' show WebHistoryItem; +export 'web_message_callback.dart' show WebMessageCallback; +export 'web_resource_error.dart' show WebResourceError; +export 'web_resource_error_type.dart' show WebResourceErrorType; +export 'web_resource_request.dart' show WebResourceRequest; +export 'web_resource_response.dart' show WebResourceResponse; +export 'web_storage_origin.dart' show WebStorageOrigin, AndroidWebStorageOrigin; +export 'web_storage_type.dart' show WebStorageType; +export 'website_data_record.dart' show WebsiteDataRecord, IOSWKWebsiteDataRecord; +export 'website_data_type.dart' show WebsiteDataType, IOSWKWebsiteDataType; +export 'webview_implementation.dart' show WebViewImplementation; +export 'webview_package_info.dart' show WebViewPackageInfo, AndroidWebViewPackageInfo; +export 'webview_render_process_action.dart' show WebViewRenderProcessAction; +export 'window_features.dart' show WindowFeatures, IOSWKWindowFeatures; \ No newline at end of file diff --git a/lib/src/types/ssl_certificate.dart b/lib/src/types/ssl_certificate.dart index 69e1a318..7405a690 100644 --- a/lib/src/types/ssl_certificate.dart +++ b/lib/src/types/ssl_certificate.dart @@ -1,17 +1,21 @@ import 'package:flutter/foundation.dart'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; import '../x509_certificate/x509_certificate.dart'; import '../x509_certificate/asn1_distinguished_names.dart'; import 'ssl_certificate_dname.dart'; +part 'ssl_certificate.g.dart'; + ///SSL certificate info (certificate details) class. -class SslCertificate { +@ExchangeableObject() +class SslCertificate_ { ///Name of the entity this certificate is issued by. - SslCertificateDName? issuedBy; + SslCertificateDName_? issuedBy; ///Name of the entity this certificate is issued to. - SslCertificateDName? issuedTo; + SslCertificateDName_? issuedTo; ///Not-after date from the validity period. DateTime? validNotAfterDate; @@ -22,7 +26,7 @@ class SslCertificate { ///The original source certificate, if available. X509Certificate? x509Certificate; - SslCertificate( + SslCertificate_( {this.issuedBy, this.issuedTo, this.validNotAfterDate, @@ -88,25 +92,4 @@ class SslCertificate { x509Certificate: x509Certificate, ); } - - ///Converts instance to a map. - Map toMap() { - return { - "issuedBy": issuedBy?.toMap(), - "issuedTo": issuedTo?.toMap(), - "validNotAfterDate": validNotAfterDate?.millisecondsSinceEpoch, - "validNotBeforeDate": validNotBeforeDate?.millisecondsSinceEpoch, - "x509Certificate": x509Certificate?.toMap(), - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/ssl_certificate.g.dart b/lib/src/types/ssl_certificate.g.dart new file mode 100644 index 00000000..4d62ab25 --- /dev/null +++ b/lib/src/types/ssl_certificate.g.dart @@ -0,0 +1,105 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ssl_certificate.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///SSL certificate info (certificate details) class. +class SslCertificate { + ///Name of the entity this certificate is issued by. + SslCertificateDName? issuedBy; + + ///Name of the entity this certificate is issued to. + SslCertificateDName? issuedTo; + + ///Not-after date from the validity period. + DateTime? validNotAfterDate; + + ///Not-before date from the validity period. + DateTime? validNotBeforeDate; + + ///The original source certificate, if available. + X509Certificate? x509Certificate; + SslCertificate( + {this.issuedBy, + this.issuedTo, + this.validNotAfterDate, + this.validNotBeforeDate, + this.x509Certificate}); + + ///Gets a possible [SslCertificate] instance from a [Map] value. + static SslCertificate? fromMap(Map? map) { + if (map == null) { + return null; + } + X509Certificate? x509Certificate; + try { + x509Certificate = X509Certificate.fromData(data: map["x509Certificate"]); + } catch (e, stacktrace) { + print(e); + print(stacktrace); + } + if (defaultTargetPlatform == TargetPlatform.iOS) { + if (x509Certificate != null) { + return SslCertificate( + issuedBy: SslCertificateDName( + CName: x509Certificate.issuer(dn: ASN1DistinguishedNames.COMMON_NAME) ?? + "", + DName: x509Certificate.issuerDistinguishedName ?? "", + OName: x509Certificate.issuer( + dn: ASN1DistinguishedNames.ORGANIZATION_NAME) ?? + "", + UName: x509Certificate.issuer( + dn: ASN1DistinguishedNames.ORGANIZATIONAL_UNIT_NAME) ?? + ""), + issuedTo: SslCertificateDName( + CName: x509Certificate.subject(dn: ASN1DistinguishedNames.COMMON_NAME) ?? + "", + DName: x509Certificate.subjectDistinguishedName ?? "", + OName: x509Certificate.subject( + dn: ASN1DistinguishedNames.ORGANIZATION_NAME) ?? + "", + UName: x509Certificate.subject( + dn: ASN1DistinguishedNames.ORGANIZATIONAL_UNIT_NAME) ?? + ""), + validNotAfterDate: x509Certificate.notAfter, + validNotBeforeDate: x509Certificate.notBefore, + x509Certificate: x509Certificate); + } + return null; + } + return SslCertificate( + issuedBy: SslCertificateDName.fromMap( + map["issuedBy"]?.cast()), + issuedTo: SslCertificateDName.fromMap( + map["issuedTo"]?.cast()), + validNotAfterDate: + DateTime.fromMillisecondsSinceEpoch(map["validNotAfterDate"]), + validNotBeforeDate: + DateTime.fromMillisecondsSinceEpoch(map["validNotBeforeDate"]), + x509Certificate: x509Certificate); + } + + ///Converts instance to a map. + Map toMap() { + return { + "issuedBy": issuedBy?.toMap(), + "issuedTo": issuedTo?.toMap(), + "validNotAfterDate": validNotAfterDate?.millisecondsSinceEpoch, + "validNotBeforeDate": validNotBeforeDate?.millisecondsSinceEpoch, + "x509Certificate": x509Certificate?.toMap(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'SslCertificate{issuedBy: $issuedBy, issuedTo: $issuedTo, validNotAfterDate: $validNotAfterDate, validNotBeforeDate: $validNotBeforeDate, x509Certificate: $x509Certificate}'; + } +} diff --git a/lib/src/types/ssl_certificate_dname.dart b/lib/src/types/ssl_certificate_dname.dart index 2450a51f..fba647b1 100644 --- a/lib/src/types/ssl_certificate_dname.dart +++ b/lib/src/types/ssl_certificate_dname.dart @@ -1,62 +1,24 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'ssl_certificate.dart'; +part 'ssl_certificate_dname.g.dart'; + ///Distinguished name helper class. Used by [SslCertificate]. -class SslCertificateDName { +@ExchangeableObject() +class SslCertificateDName_ { ///Common-name (CN) component of the name - // ignore: non_constant_identifier_names String? CName; ///Distinguished name (normally includes CN, O, and OU names) - // ignore: non_constant_identifier_names String? DName; ///Organization (O) component of the name - // ignore: non_constant_identifier_names String? OName; ///Organizational Unit (OU) component of the name - // ignore: non_constant_identifier_names String? UName; - SslCertificateDName( - // ignore: non_constant_identifier_names - {this.CName = "", - // ignore: non_constant_identifier_names - this.DName = "", - // ignore: non_constant_identifier_names - this.OName = "", - // ignore: non_constant_identifier_names - this.UName = ""}); - - ///Gets a possible [SslCertificateDName] instance from a [Map] value. - static SslCertificateDName? fromMap(Map? map) { - return map != null - ? SslCertificateDName( - CName: map["CName"] ?? "", - DName: map["DName"] ?? "", - OName: map["OName"] ?? "", - UName: map["UName"] ?? "", - ) - : null; - } - - ///Converts instance to a map. - Map toMap() { - return { - "CName": CName, - "DName": DName, - "OName": OName, - "UName": UName, - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } -} \ No newline at end of file + SslCertificateDName_( + {this.CName = "", this.DName = "", this.OName = "", this.UName = ""}); +} diff --git a/lib/src/types/ssl_certificate_dname.g.dart b/lib/src/types/ssl_certificate_dname.g.dart new file mode 100644 index 00000000..3231eb69 --- /dev/null +++ b/lib/src/types/ssl_certificate_dname.g.dart @@ -0,0 +1,57 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'ssl_certificate_dname.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Distinguished name helper class. Used by [SslCertificate]. +class SslCertificateDName { + ///Common-name (CN) component of the name + String? CName; + + ///Distinguished name (normally includes CN, O, and OU names) + String? DName; + + ///Organization (O) component of the name + String? OName; + + ///Organizational Unit (OU) component of the name + String? UName; + SslCertificateDName( + {this.CName = "", this.DName = "", this.OName = "", this.UName = ""}); + + ///Gets a possible [SslCertificateDName] instance from a [Map] value. + static SslCertificateDName? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = SslCertificateDName(); + instance.CName = map['CName']; + instance.DName = map['DName']; + instance.OName = map['OName']; + instance.UName = map['UName']; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "CName": CName, + "DName": DName, + "OName": OName, + "UName": UName, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'SslCertificateDName{CName: $CName, DName: $DName, OName: $OName, UName: $UName}'; + } +} diff --git a/lib/src/types/underline_style.dart b/lib/src/types/underline_style.dart index 6e74bf24..ad1b4df4 100644 --- a/lib/src/types/underline_style.dart +++ b/lib/src/types/underline_style.dart @@ -1,187 +1,75 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'underline_style.g.dart'; + ///Class that represents the constants for the underline style and strikethrough style attribute keys. -class UnderlineStyle { +@ExchangeableEnum() +class UnderlineStyle_ { + // ignore: unused_field final int _value; - - const UnderlineStyle._internal(this._value); - - ///Set of all values of [UnderlineStyle]. - static final Set values = [ - UnderlineStyle.STYLE_NONE, - UnderlineStyle.SINGLE, - UnderlineStyle.THICK, - UnderlineStyle.DOUBLE, - UnderlineStyle.PATTERN_DOT, - UnderlineStyle.PATTERN_DASH, - UnderlineStyle.PATTERN_DASH_DOT, - UnderlineStyle.PATTERN_DASH_DOT_DOT, - UnderlineStyle.BY_WORD, - ].toSet(); - - ///Gets a possible [UnderlineStyle] instance from an [int] value. - static UnderlineStyle? fromValue(int? value) { - if (value != null) { - try { - return UnderlineStyle.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "SINGLE"; - case 2: - return "THICK"; - case 9: - return "DOUBLE"; - case 256: - return "PATTERN_DOT"; - case 512: - return "PATTERN_DASH"; - case 768: - return "PATTERN_DASH_DOT"; - case 1024: - return "PATTERN_DASH_DOT_DOT"; - case 32768: - return "BY_WORD"; - case 0: - default: - return "STYLE_NONE"; - } - } + const UnderlineStyle_._internal(this._value); ///Do not draw a line. - static const STYLE_NONE = const UnderlineStyle._internal(0); + static const STYLE_NONE = const UnderlineStyle_._internal(0); ///Draw a single line. - static const SINGLE = const UnderlineStyle._internal(1); + static const SINGLE = const UnderlineStyle_._internal(1); ///Draw a thick line. - static const THICK = const UnderlineStyle._internal(2); + static const THICK = const UnderlineStyle_._internal(2); ///Draw a double line. - static const DOUBLE = const UnderlineStyle._internal(9); + static const DOUBLE = const UnderlineStyle_._internal(9); ///Draw a line of dots. - static const PATTERN_DOT = const UnderlineStyle._internal(256); + static const PATTERN_DOT = const UnderlineStyle_._internal(256); ///Draw a line of dashes. - static const PATTERN_DASH = const UnderlineStyle._internal(512); + static const PATTERN_DASH = const UnderlineStyle_._internal(512); ///Draw a line of alternating dashes and dots. - static const PATTERN_DASH_DOT = const UnderlineStyle._internal(768); + static const PATTERN_DASH_DOT = const UnderlineStyle_._internal(768); ///Draw a line of alternating dashes and two dots. - static const PATTERN_DASH_DOT_DOT = const UnderlineStyle._internal(1024); + static const PATTERN_DASH_DOT_DOT = const UnderlineStyle_._internal(1024); ///Draw the line only beneath or through words, not whitespace. - static const BY_WORD = const UnderlineStyle._internal(32768); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const BY_WORD = const UnderlineStyle_._internal(32768); } ///An iOS-specific Class that represents the constants for the underline style and strikethrough style attribute keys. ///Use [UnderlineStyle] instead. @Deprecated("Use UnderlineStyle instead") -class IOSNSUnderlineStyle { +@ExchangeableEnum() +class IOSNSUnderlineStyle_ { + // ignore: unused_field final int _value; - - const IOSNSUnderlineStyle._internal(this._value); - - ///Set of all values of [IOSNSUnderlineStyle]. - static final Set values = [ - IOSNSUnderlineStyle.STYLE_NONE, - IOSNSUnderlineStyle.SINGLE, - IOSNSUnderlineStyle.THICK, - IOSNSUnderlineStyle.DOUBLE, - IOSNSUnderlineStyle.PATTERN_DOT, - IOSNSUnderlineStyle.PATTERN_DASH, - IOSNSUnderlineStyle.PATTERN_DASH_DOT, - IOSNSUnderlineStyle.PATTERN_DASH_DOT_DOT, - IOSNSUnderlineStyle.BY_WORD, - ].toSet(); - - ///Gets a possible [IOSNSUnderlineStyle] instance from an [int] value. - static IOSNSUnderlineStyle? fromValue(int? value) { - if (value != null) { - try { - return IOSNSUnderlineStyle.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 1: - return "SINGLE"; - case 2: - return "THICK"; - case 9: - return "DOUBLE"; - case 256: - return "PATTERN_DOT"; - case 512: - return "PATTERN_DASH"; - case 768: - return "PATTERN_DASH_DOT"; - case 1024: - return "PATTERN_DASH_DOT_DOT"; - case 32768: - return "BY_WORD"; - case 0: - default: - return "STYLE_NONE"; - } - } + const IOSNSUnderlineStyle_._internal(this._value); ///Do not draw a line. - static const STYLE_NONE = const IOSNSUnderlineStyle._internal(0); + static const STYLE_NONE = const IOSNSUnderlineStyle_._internal(0); ///Draw a single line. - static const SINGLE = const IOSNSUnderlineStyle._internal(1); + static const SINGLE = const IOSNSUnderlineStyle_._internal(1); ///Draw a thick line. - static const THICK = const IOSNSUnderlineStyle._internal(2); + static const THICK = const IOSNSUnderlineStyle_._internal(2); ///Draw a double line. - static const DOUBLE = const IOSNSUnderlineStyle._internal(9); + static const DOUBLE = const IOSNSUnderlineStyle_._internal(9); ///Draw a line of dots. - static const PATTERN_DOT = const IOSNSUnderlineStyle._internal(256); + static const PATTERN_DOT = const IOSNSUnderlineStyle_._internal(256); ///Draw a line of dashes. - static const PATTERN_DASH = const IOSNSUnderlineStyle._internal(512); + static const PATTERN_DASH = const IOSNSUnderlineStyle_._internal(512); ///Draw a line of alternating dashes and dots. - static const PATTERN_DASH_DOT = const IOSNSUnderlineStyle._internal(768); + static const PATTERN_DASH_DOT = const IOSNSUnderlineStyle_._internal(768); ///Draw a line of alternating dashes and two dots. - static const PATTERN_DASH_DOT_DOT = const IOSNSUnderlineStyle._internal(1024); + static const PATTERN_DASH_DOT_DOT = const IOSNSUnderlineStyle_._internal(1024); ///Draw the line only beneath or through words, not whitespace. - static const BY_WORD = const IOSNSUnderlineStyle._internal(32768); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const BY_WORD = const IOSNSUnderlineStyle_._internal(32768); } \ No newline at end of file diff --git a/lib/src/types/underline_style.g.dart b/lib/src/types/underline_style.g.dart new file mode 100644 index 00000000..5a38df52 --- /dev/null +++ b/lib/src/types/underline_style.g.dart @@ -0,0 +1,237 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'underline_style.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the constants for the underline style and strikethrough style attribute keys. +class UnderlineStyle { + final int _value; + final int _nativeValue; + const UnderlineStyle._internal(this._value, this._nativeValue); +// ignore: unused_element + factory UnderlineStyle._internalMultiPlatform( + int value, Function nativeValue) => + UnderlineStyle._internal(value, nativeValue()); + + ///Do not draw a line. + static const STYLE_NONE = UnderlineStyle._internal(0, 0); + + ///Draw a single line. + static const SINGLE = UnderlineStyle._internal(1, 1); + + ///Draw a thick line. + static const THICK = UnderlineStyle._internal(2, 2); + + ///Draw a double line. + static const DOUBLE = UnderlineStyle._internal(9, 9); + + ///Draw a line of dots. + static const PATTERN_DOT = UnderlineStyle._internal(256, 256); + + ///Draw a line of dashes. + static const PATTERN_DASH = UnderlineStyle._internal(512, 512); + + ///Draw a line of alternating dashes and dots. + static const PATTERN_DASH_DOT = UnderlineStyle._internal(768, 768); + + ///Draw a line of alternating dashes and two dots. + static const PATTERN_DASH_DOT_DOT = UnderlineStyle._internal(1024, 1024); + + ///Draw the line only beneath or through words, not whitespace. + static const BY_WORD = UnderlineStyle._internal(32768, 32768); + + ///Set of all values of [UnderlineStyle]. + static final Set values = [ + UnderlineStyle.STYLE_NONE, + UnderlineStyle.SINGLE, + UnderlineStyle.THICK, + UnderlineStyle.DOUBLE, + UnderlineStyle.PATTERN_DOT, + UnderlineStyle.PATTERN_DASH, + UnderlineStyle.PATTERN_DASH_DOT, + UnderlineStyle.PATTERN_DASH_DOT_DOT, + UnderlineStyle.BY_WORD, + ].toSet(); + + ///Gets a possible [UnderlineStyle] instance from [int] value. + static UnderlineStyle? fromValue(int? value) { + if (value != null) { + try { + return UnderlineStyle.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [UnderlineStyle] instance from a native value. + static UnderlineStyle? fromNativeValue(int? value) { + if (value != null) { + try { + return UnderlineStyle.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'STYLE_NONE'; + case 1: + return 'SINGLE'; + case 2: + return 'THICK'; + case 9: + return 'DOUBLE'; + case 256: + return 'PATTERN_DOT'; + case 512: + return 'PATTERN_DASH'; + case 768: + return 'PATTERN_DASH_DOT'; + case 1024: + return 'PATTERN_DASH_DOT_DOT'; + case 32768: + return 'BY_WORD'; + } + return _value.toString(); + } +} + +///An iOS-specific Class that represents the constants for the underline style and strikethrough style attribute keys. +///Use [UnderlineStyle] instead. +@Deprecated('Use UnderlineStyle instead') +class IOSNSUnderlineStyle { + final int _value; + final int _nativeValue; + const IOSNSUnderlineStyle._internal(this._value, this._nativeValue); +// ignore: unused_element + factory IOSNSUnderlineStyle._internalMultiPlatform( + int value, Function nativeValue) => + IOSNSUnderlineStyle._internal(value, nativeValue()); + + ///Do not draw a line. + static const STYLE_NONE = IOSNSUnderlineStyle._internal(0, 0); + + ///Draw a single line. + static const SINGLE = IOSNSUnderlineStyle._internal(1, 1); + + ///Draw a thick line. + static const THICK = IOSNSUnderlineStyle._internal(2, 2); + + ///Draw a double line. + static const DOUBLE = IOSNSUnderlineStyle._internal(9, 9); + + ///Draw a line of dots. + static const PATTERN_DOT = IOSNSUnderlineStyle._internal(256, 256); + + ///Draw a line of dashes. + static const PATTERN_DASH = IOSNSUnderlineStyle._internal(512, 512); + + ///Draw a line of alternating dashes and dots. + static const PATTERN_DASH_DOT = IOSNSUnderlineStyle._internal(768, 768); + + ///Draw a line of alternating dashes and two dots. + static const PATTERN_DASH_DOT_DOT = IOSNSUnderlineStyle._internal(1024, 1024); + + ///Draw the line only beneath or through words, not whitespace. + static const BY_WORD = IOSNSUnderlineStyle._internal(32768, 32768); + + ///Set of all values of [IOSNSUnderlineStyle]. + static final Set values = [ + IOSNSUnderlineStyle.STYLE_NONE, + IOSNSUnderlineStyle.SINGLE, + IOSNSUnderlineStyle.THICK, + IOSNSUnderlineStyle.DOUBLE, + IOSNSUnderlineStyle.PATTERN_DOT, + IOSNSUnderlineStyle.PATTERN_DASH, + IOSNSUnderlineStyle.PATTERN_DASH_DOT, + IOSNSUnderlineStyle.PATTERN_DASH_DOT_DOT, + IOSNSUnderlineStyle.BY_WORD, + ].toSet(); + + ///Gets a possible [IOSNSUnderlineStyle] instance from [int] value. + static IOSNSUnderlineStyle? fromValue(int? value) { + if (value != null) { + try { + return IOSNSUnderlineStyle.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [IOSNSUnderlineStyle] instance from a native value. + static IOSNSUnderlineStyle? fromNativeValue(int? value) { + if (value != null) { + try { + return IOSNSUnderlineStyle.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'STYLE_NONE'; + case 1: + return 'SINGLE'; + case 2: + return 'THICK'; + case 9: + return 'DOUBLE'; + case 256: + return 'PATTERN_DOT'; + case 512: + return 'PATTERN_DASH'; + case 768: + return 'PATTERN_DASH_DOT'; + case 1024: + return 'PATTERN_DASH_DOT_DOT'; + case 32768: + return 'BY_WORD'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/url_authentication_challenge.dart b/lib/src/types/url_authentication_challenge.dart index 677968fa..5fd10253 100644 --- a/lib/src/types/url_authentication_challenge.dart +++ b/lib/src/types/url_authentication_challenge.dart @@ -1,40 +1,17 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'url_protection_space.dart'; +part 'url_authentication_challenge.g.dart'; + ///Class that represents a challenge from a server requiring authentication from the client. ///It provides all the information about the challenge. -class URLAuthenticationChallenge { +@ExchangeableObject() +class URLAuthenticationChallenge_ { ///The protection space requiring authentication. URLProtectionSpace protectionSpace; - URLAuthenticationChallenge({ + URLAuthenticationChallenge_({ required this.protectionSpace, }); - - ///Gets a possible [URLAuthenticationChallenge] instance from a [Map] value. - static URLAuthenticationChallenge? fromMap(Map? map) { - if (map == null) { - return null; - } - return URLAuthenticationChallenge( - protectionSpace: URLProtectionSpace.fromMap( - map["protectionSpace"].cast())!, - ); - } - - ///Converts instance to a map. - Map toMap() { - return { - "protectionSpace": protectionSpace.toMap(), - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/url_authentication_challenge.g.dart b/lib/src/types/url_authentication_challenge.g.dart new file mode 100644 index 00000000..6c82b59c --- /dev/null +++ b/lib/src/types/url_authentication_challenge.g.dart @@ -0,0 +1,43 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'url_authentication_challenge.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents a challenge from a server requiring authentication from the client. +///It provides all the information about the challenge. +class URLAuthenticationChallenge { + ///The protection space requiring authentication. + dynamic protectionSpace; + URLAuthenticationChallenge({this.protectionSpace}); + + ///Gets a possible [URLAuthenticationChallenge] instance from a [Map] value. + static URLAuthenticationChallenge? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = URLAuthenticationChallenge( + protectionSpace: map['protectionSpace'], + ); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "protectionSpace": protectionSpace, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'URLAuthenticationChallenge{protectionSpace: $protectionSpace}'; + } +} diff --git a/lib/src/types/url_protection_space.dart b/lib/src/types/url_protection_space.dart index 95a0ed8a..79b1cb4b 100644 --- a/lib/src/types/url_protection_space.dart +++ b/lib/src/types/url_protection_space.dart @@ -1,13 +1,35 @@ import 'dart:typed_data'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../x509_certificate/x509_certificate.dart'; import 'url_protection_space_proxy_type.dart'; import 'url_protection_space_authentication_method.dart'; import 'ssl_error.dart'; import 'ssl_certificate.dart'; +part 'url_protection_space.g.dart'; + +List? _distinguishedNamesDeserializer(dynamic value) { + List? distinguishedNames; + if (value != null) { + distinguishedNames = []; + (value.cast() as List) + .forEach((data) { + try { + distinguishedNames!.add(X509Certificate.fromData(data: data)); + } catch (e, stacktrace) { + print(e); + print(stacktrace); + } + }); + } + return distinguishedNames; +} + ///Class that represents a protection space requiring authentication. -class URLProtectionSpace { +@ExchangeableObject() +class URLProtectionSpace_ { ///The hostname of the server. String host; @@ -23,22 +45,25 @@ class URLProtectionSpace { int? port; ///The SSL certificate used. - SslCertificate? sslCertificate; + SslCertificate_? sslCertificate; ///The SSL Error associated. SslError? sslError; ///Use [authenticationMethod] instead. @Deprecated("Use authenticationMethod instead") - IOSNSURLProtectionSpaceAuthenticationMethod? iosAuthenticationMethod; + IOSNSURLProtectionSpaceAuthenticationMethod_? iosAuthenticationMethod; ///The authentication method used by the receiver. /// ///**NOTE**: available only on iOS. - URLProtectionSpaceAuthenticationMethod? authenticationMethod; + URLProtectionSpaceAuthenticationMethod_? authenticationMethod; ///Use [distinguishedNames] instead. @Deprecated("Use distinguishedNames instead") + @ExchangeableObjectProperty( + deserializer: _distinguishedNamesDeserializer + ) List? iosDistinguishedNames; ///The acceptable certificate-issuing authorities for client certificate authentication. @@ -46,6 +71,9 @@ class URLProtectionSpace { ///The returned issuing authorities are encoded with Distinguished Encoding Rules (DER). /// ///**NOTE**: available only on iOS. + @ExchangeableObjectProperty( + deserializer: _distinguishedNamesDeserializer + ) List? distinguishedNames; ///Use [receivesCredentialSecurely] instead. @@ -78,7 +106,7 @@ class URLProtectionSpace { ///**NOTE**: available only on iOS. URLProtectionSpaceProxyType? proxyType; - URLProtectionSpace( + URLProtectionSpace_( {required this.host, this.protocol, this.realm, @@ -99,121 +127,5 @@ class URLProtectionSpace { this.isProxy, @Deprecated("Use proxyType instead") this.iosProxyType, - this.proxyType}) { - this.authenticationMethod = this.authenticationMethod ?? - URLProtectionSpaceAuthenticationMethod.fromValue( - // ignore: deprecated_member_use_from_same_package - this.iosAuthenticationMethod?.toValue()); - this.distinguishedNames = - // ignore: deprecated_member_use_from_same_package - this.distinguishedNames ?? this.iosDistinguishedNames; - this.receivesCredentialSecurely = - // ignore: deprecated_member_use_from_same_package - this.receivesCredentialSecurely ?? this.iosReceivesCredentialSecurely; - // ignore: deprecated_member_use_from_same_package - this.isProxy = this.isProxy ?? this.iosIsProxy; - this.proxyType = this.proxyType ?? - // ignore: deprecated_member_use_from_same_package - URLProtectionSpaceProxyType.fromValue(this.iosProxyType?.toValue()); - } - - ///Gets a possible [URLProtectionSpace] instance from a [Map] value. - static URLProtectionSpace? fromMap(Map? map) { - if (map == null) { - return null; - } - List? distinguishedNames; - if (map["distinguishedNames"] != null) { - distinguishedNames = []; - (map["distinguishedNames"].cast() as List) - .forEach((data) { - try { - distinguishedNames!.add(X509Certificate.fromData(data: data)); - } catch (e, stacktrace) { - print(e); - print(stacktrace); - } - }); - } - - return URLProtectionSpace( - host: map["host"], - protocol: map["protocol"], - realm: map["realm"], - port: map["port"], - sslCertificate: SslCertificate.fromMap( - map["sslCertificate"]?.cast()), - sslError: SslError.fromMap(map["sslError"]?.cast()), - // ignore: deprecated_member_use_from_same_package - iosAuthenticationMethod: - // ignore: deprecated_member_use_from_same_package - IOSNSURLProtectionSpaceAuthenticationMethod.fromValue( - map["authenticationMethod"]), - authenticationMethod: URLProtectionSpaceAuthenticationMethod.fromValue( - map["authenticationMethod"]), - // ignore: deprecated_member_use_from_same_package - iosDistinguishedNames: distinguishedNames, - distinguishedNames: distinguishedNames, - // ignore: deprecated_member_use_from_same_package - iosReceivesCredentialSecurely: map["receivesCredentialSecurely"], - receivesCredentialSecurely: map["receivesCredentialSecurely"], - // ignore: deprecated_member_use_from_same_package - iosIsProxy: map["isProxy"], - isProxy: map["isProxy"], - // ignore: deprecated_member_use_from_same_package - iosProxyType: - // ignore: deprecated_member_use_from_same_package - IOSNSURLProtectionSpaceProxyType.fromValue(map["proxyType"]), - proxyType: URLProtectionSpaceProxyType.fromValue(map["proxyType"]), - ); - } - - ///Converts instance to a map. - Map toMap() { - return { - "host": host, - "protocol": protocol, - "realm": realm, - "port": port, - "sslCertificate": sslCertificate?.toMap(), - "sslError": sslError?.toMap(), - "iosAuthenticationMethod": - // ignore: deprecated_member_use_from_same_package - authenticationMethod ?? iosAuthenticationMethod, - // ignore: deprecated_member_use_from_same_package - "authenticationMethod": authenticationMethod ?? iosAuthenticationMethod, - // ignore: deprecated_member_use_from_same_package - "iosDistinguishedNames": (distinguishedNames ?? iosDistinguishedNames) - ?.map((e) => e.toMap()) - .toList(), - // ignore: deprecated_member_use_from_same_package - "distinguishedNames": (distinguishedNames ?? iosDistinguishedNames) - ?.map((e) => e.toMap()) - .toList(), - "iosReceivesCredentialSecurely": - // ignore: deprecated_member_use_from_same_package - receivesCredentialSecurely ?? iosReceivesCredentialSecurely, - "receivesCredentialSecurely": - // ignore: deprecated_member_use_from_same_package - receivesCredentialSecurely ?? iosReceivesCredentialSecurely, - // ignore: deprecated_member_use_from_same_package - "iosIsProxy": isProxy ?? iosIsProxy, - // ignore: deprecated_member_use_from_same_package - "isProxy": isProxy ?? iosIsProxy, - // ignore: deprecated_member_use_from_same_package - "iosProxyType": proxyType?.toValue() ?? iosProxyType?.toValue(), - // ignore: deprecated_member_use_from_same_package - "proxyType": proxyType?.toValue() ?? iosProxyType?.toValue(), - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } + this.proxyType}); } \ No newline at end of file diff --git a/lib/src/types/url_protection_space.g.dart b/lib/src/types/url_protection_space.g.dart new file mode 100644 index 00000000..2d8df4e4 --- /dev/null +++ b/lib/src/types/url_protection_space.g.dart @@ -0,0 +1,175 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'url_protection_space.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents a protection space requiring authentication. +class URLProtectionSpace { + ///The hostname of the server. + String host; + + ///The protocol of the server - e.g. "http", "ftp", "https". + String? protocol; + + ///A string indicating a protocol-specific subdivision of a single host. + ///For http and https, this maps to the realm string in http authentication challenges. + ///For many other protocols it is unused. + String? realm; + + ///The port of the server. + int? port; + + ///The SSL certificate used. + SslCertificate? sslCertificate; + + ///The SSL Error associated. + SslError? sslError; + + ///Use [authenticationMethod] instead. + @Deprecated('Use authenticationMethod instead') + IOSNSURLProtectionSpaceAuthenticationMethod? iosAuthenticationMethod; + + ///The authentication method used by the receiver. + /// + ///**NOTE**: available only on iOS. + URLProtectionSpaceAuthenticationMethod? authenticationMethod; + + ///Use [distinguishedNames] instead. + @Deprecated('Use distinguishedNames instead') + List? iosDistinguishedNames; + + ///The acceptable certificate-issuing authorities for client certificate authentication. + ///This value is `null` if the authentication method of the protection space is not client certificate. + ///The returned issuing authorities are encoded with Distinguished Encoding Rules (DER). + /// + ///**NOTE**: available only on iOS. + List? distinguishedNames; + + ///Use [receivesCredentialSecurely] instead. + @Deprecated('Use receivesCredentialSecurely instead') + bool? iosReceivesCredentialSecurely; + + ///A Boolean value that indicates whether the credentials for the protection space can be sent securely. + ///This value is `true` if the credentials for the protection space represented by the receiver can be sent securely, `false` otherwise. + /// + ///**NOTE**: available only on iOS. + bool? receivesCredentialSecurely; + + ///Use [isProxy] instead. + @Deprecated('Use isProxy instead') + bool? iosIsProxy; + + ///Returns a Boolean value that indicates whether the receiver does not descend from `NSObject`. + /// + ///**NOTE**: available only on iOS. + bool? isProxy; + + ///Use [proxyType] instead. + @Deprecated('Use proxyType instead') + IOSNSURLProtectionSpaceProxyType? iosProxyType; + + ///The receiver's proxy type. + ///This value is `null` if the receiver does not represent a proxy protection space. + ///The supported proxy types are listed in [URLProtectionSpaceProxyType.values]. + /// + ///**NOTE**: available only on iOS. + URLProtectionSpaceProxyType? proxyType; + URLProtectionSpace( + {required this.host, + this.protocol, + this.realm, + this.port, + this.sslCertificate, + this.sslError, + @Deprecated('Use authenticationMethod instead') + this.iosAuthenticationMethod, + this.authenticationMethod, + @Deprecated('Use distinguishedNames instead') + this.iosDistinguishedNames, + this.distinguishedNames, + @Deprecated('Use receivesCredentialSecurely instead') + this.iosReceivesCredentialSecurely, + this.receivesCredentialSecurely, + @Deprecated('Use isProxy instead') + this.iosIsProxy, + this.isProxy, + @Deprecated('Use proxyType instead') + this.iosProxyType, + this.proxyType}) { + authenticationMethod = authenticationMethod ?? + URLProtectionSpaceAuthenticationMethod.fromNativeValue( + iosAuthenticationMethod?.toNativeValue()); + distinguishedNames = distinguishedNames ?? iosDistinguishedNames; + receivesCredentialSecurely = + receivesCredentialSecurely ?? iosReceivesCredentialSecurely; + isProxy = isProxy ?? iosIsProxy; + proxyType = proxyType ?? + URLProtectionSpaceProxyType.fromValue(iosProxyType?.toValue()); + } + + ///Gets a possible [URLProtectionSpace] instance from a [Map] value. + static URLProtectionSpace? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = URLProtectionSpace( + host: map['host'], + ); + instance.protocol = map['protocol']; + instance.realm = map['realm']; + instance.port = map['port']; + instance.sslCertificate = + SslCertificate.fromMap(map['sslCertificate']?.cast()); + instance.sslError = + SslError.fromMap(map['sslError']?.cast()); + instance.iosAuthenticationMethod = + IOSNSURLProtectionSpaceAuthenticationMethod.fromNativeValue( + map['authenticationMethod']); + instance.authenticationMethod = + URLProtectionSpaceAuthenticationMethod.fromNativeValue( + map['authenticationMethod']); + instance.iosDistinguishedNames = + _distinguishedNamesDeserializer(map['distinguishedNames']); + instance.distinguishedNames = + _distinguishedNamesDeserializer(map['distinguishedNames']); + instance.iosReceivesCredentialSecurely = map['receivesCredentialSecurely']; + instance.receivesCredentialSecurely = map['receivesCredentialSecurely']; + instance.iosIsProxy = map['isProxy']; + instance.isProxy = map['isProxy']; + instance.iosProxyType = + IOSNSURLProtectionSpaceProxyType.fromValue(map['proxyType']); + instance.proxyType = + URLProtectionSpaceProxyType.fromValue(map['proxyType']); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "host": host, + "protocol": protocol, + "realm": realm, + "port": port, + "sslCertificate": sslCertificate?.toMap(), + "sslError": sslError?.toMap(), + "authenticationMethod": authenticationMethod?.toNativeValue(), + "distinguishedNames": distinguishedNames?.map((e) => e.toMap()).toList(), + "receivesCredentialSecurely": receivesCredentialSecurely, + "isProxy": isProxy, + "proxyType": proxyType?.toValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'URLProtectionSpace{host: $host, protocol: $protocol, realm: $realm, port: $port, sslCertificate: $sslCertificate, sslError: $sslError, authenticationMethod: $authenticationMethod, distinguishedNames: $distinguishedNames, receivesCredentialSecurely: $receivesCredentialSecurely, isProxy: $isProxy, proxyType: $proxyType}'; + } +} diff --git a/lib/src/types/url_protection_space_authentication_method.dart b/lib/src/types/url_protection_space_authentication_method.dart index ecbb1242..680e6f66 100644 --- a/lib/src/types/url_protection_space_authentication_method.dart +++ b/lib/src/types/url_protection_space_authentication_method.dart @@ -1,128 +1,63 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'url_protection_space.dart'; +part 'url_protection_space_authentication_method.g.dart'; + ///Class that represents the constants describing known values of the [URLProtectionSpace.authenticationMethod] property. -class URLProtectionSpaceAuthenticationMethod { +@ExchangeableEnum() +class URLProtectionSpaceAuthenticationMethod_ { + // ignore: unused_field final String _value; - - const URLProtectionSpaceAuthenticationMethod._internal(this._value); - - ///Set of all values of [URLProtectionSpaceAuthenticationMethod]. - static final Set values = [ - URLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE, - URLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_NEGOTIATE, - URLProtectionSpaceAuthenticationMethod.NSURL_AUTHENTICATION_METHOD_NTLM, - URLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_SERVER_TRUST, - ].toSet(); - - ///Gets a possible [URLProtectionSpaceAuthenticationMethod] instance from a [String] value. - static URLProtectionSpaceAuthenticationMethod? fromValue(String? value) { - if (value != null) { - try { - return URLProtectionSpaceAuthenticationMethod.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const URLProtectionSpaceAuthenticationMethod_._internal(this._value); ///Use client certificate authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE = - const URLProtectionSpaceAuthenticationMethod._internal( + const URLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodClientCertificate"); ///Negotiate whether to use Kerberos or NTLM authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_NEGOTIATE = - const URLProtectionSpaceAuthenticationMethod._internal( + const URLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodNegotiate"); ///Use NTLM authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_NTLM = - const URLProtectionSpaceAuthenticationMethod._internal( + const URLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodNTLM"); ///Perform server trust authentication (certificate validation) for this protection space. static const NSURL_AUTHENTICATION_METHOD_SERVER_TRUST = - const URLProtectionSpaceAuthenticationMethod._internal( + const URLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodServerTrust"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; } ///An iOS-specific Class that represents the constants describing known values of the [URLProtectionSpace.authenticationMethod] property. ///Use [URLProtectionSpaceAuthenticationMethod] instead. @Deprecated("Use URLProtectionSpaceAuthenticationMethod instead") -class IOSNSURLProtectionSpaceAuthenticationMethod { +@ExchangeableEnum() +class IOSNSURLProtectionSpaceAuthenticationMethod_ { + // ignore: unused_field final String _value; - - const IOSNSURLProtectionSpaceAuthenticationMethod._internal(this._value); - - ///Set of all values of [IOSNSURLProtectionSpaceAuthenticationMethod]. - static final Set values = [ - IOSNSURLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE, - IOSNSURLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_NEGOTIATE, - IOSNSURLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_NTLM, - IOSNSURLProtectionSpaceAuthenticationMethod - .NSURL_AUTHENTICATION_METHOD_SERVER_TRUST, - ].toSet(); - - ///Gets a possible [IOSNSURLProtectionSpaceAuthenticationMethod] instance from a [String] value. - static IOSNSURLProtectionSpaceAuthenticationMethod? fromValue(String? value) { - if (value != null) { - try { - return IOSNSURLProtectionSpaceAuthenticationMethod.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const IOSNSURLProtectionSpaceAuthenticationMethod_._internal(this._value); ///Use client certificate authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE = - const IOSNSURLProtectionSpaceAuthenticationMethod._internal( + const IOSNSURLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodClientCertificate"); ///Negotiate whether to use Kerberos or NTLM authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_NEGOTIATE = - const IOSNSURLProtectionSpaceAuthenticationMethod._internal( + const IOSNSURLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodNegotiate"); ///Use NTLM authentication for this protection space. static const NSURL_AUTHENTICATION_METHOD_NTLM = - const IOSNSURLProtectionSpaceAuthenticationMethod._internal( + const IOSNSURLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodNTLM"); ///Perform server trust authentication (certificate validation) for this protection space. static const NSURL_AUTHENTICATION_METHOD_SERVER_TRUST = - const IOSNSURLProtectionSpaceAuthenticationMethod._internal( + const IOSNSURLProtectionSpaceAuthenticationMethod_._internal( "NSURLAuthenticationMethodServerTrust"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; } \ No newline at end of file diff --git a/lib/src/types/url_protection_space_authentication_method.g.dart b/lib/src/types/url_protection_space_authentication_method.g.dart new file mode 100644 index 00000000..a8f318ea --- /dev/null +++ b/lib/src/types/url_protection_space_authentication_method.g.dart @@ -0,0 +1,191 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'url_protection_space_authentication_method.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the constants describing known values of the [URLProtectionSpace.authenticationMethod] property. +class URLProtectionSpaceAuthenticationMethod { + final String _value; + final String _nativeValue; + const URLProtectionSpaceAuthenticationMethod._internal( + this._value, this._nativeValue); +// ignore: unused_element + factory URLProtectionSpaceAuthenticationMethod._internalMultiPlatform( + String value, Function nativeValue) => + URLProtectionSpaceAuthenticationMethod._internal(value, nativeValue()); + + ///Use client certificate authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE = + URLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodClientCertificate', + 'NSURLAuthenticationMethodClientCertificate'); + + ///Negotiate whether to use Kerberos or NTLM authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_NEGOTIATE = + URLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodNegotiate', + 'NSURLAuthenticationMethodNegotiate'); + + ///Use NTLM authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_NTLM = + URLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodNTLM', 'NSURLAuthenticationMethodNTLM'); + + ///Perform server trust authentication (certificate validation) for this protection space. + static const NSURL_AUTHENTICATION_METHOD_SERVER_TRUST = + URLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodServerTrust', + 'NSURLAuthenticationMethodServerTrust'); + + ///Set of all values of [URLProtectionSpaceAuthenticationMethod]. + static final Set values = [ + URLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE, + URLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_NEGOTIATE, + URLProtectionSpaceAuthenticationMethod.NSURL_AUTHENTICATION_METHOD_NTLM, + URLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_SERVER_TRUST, + ].toSet(); + + ///Gets a possible [URLProtectionSpaceAuthenticationMethod] instance from [String] value. + static URLProtectionSpaceAuthenticationMethod? fromValue(String? value) { + if (value != null) { + try { + return URLProtectionSpaceAuthenticationMethod.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [URLProtectionSpaceAuthenticationMethod] instance from a native value. + static URLProtectionSpaceAuthenticationMethod? fromNativeValue( + String? value) { + if (value != null) { + try { + return URLProtectionSpaceAuthenticationMethod.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} + +///An iOS-specific Class that represents the constants describing known values of the [URLProtectionSpace.authenticationMethod] property. +///Use [URLProtectionSpaceAuthenticationMethod] instead. +@Deprecated('Use URLProtectionSpaceAuthenticationMethod instead') +class IOSNSURLProtectionSpaceAuthenticationMethod { + final String _value; + final String _nativeValue; + const IOSNSURLProtectionSpaceAuthenticationMethod._internal( + this._value, this._nativeValue); +// ignore: unused_element + factory IOSNSURLProtectionSpaceAuthenticationMethod._internalMultiPlatform( + String value, Function nativeValue) => + IOSNSURLProtectionSpaceAuthenticationMethod._internal( + value, nativeValue()); + + ///Use client certificate authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE = + IOSNSURLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodClientCertificate', + 'NSURLAuthenticationMethodClientCertificate'); + + ///Negotiate whether to use Kerberos or NTLM authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_NEGOTIATE = + IOSNSURLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodNegotiate', + 'NSURLAuthenticationMethodNegotiate'); + + ///Use NTLM authentication for this protection space. + static const NSURL_AUTHENTICATION_METHOD_NTLM = + IOSNSURLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodNTLM', 'NSURLAuthenticationMethodNTLM'); + + ///Perform server trust authentication (certificate validation) for this protection space. + static const NSURL_AUTHENTICATION_METHOD_SERVER_TRUST = + IOSNSURLProtectionSpaceAuthenticationMethod._internal( + 'NSURLAuthenticationMethodServerTrust', + 'NSURLAuthenticationMethodServerTrust'); + + ///Set of all values of [IOSNSURLProtectionSpaceAuthenticationMethod]. + static final Set values = [ + IOSNSURLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_CLIENT_CERTIFICATE, + IOSNSURLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_NEGOTIATE, + IOSNSURLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_NTLM, + IOSNSURLProtectionSpaceAuthenticationMethod + .NSURL_AUTHENTICATION_METHOD_SERVER_TRUST, + ].toSet(); + + ///Gets a possible [IOSNSURLProtectionSpaceAuthenticationMethod] instance from [String] value. + static IOSNSURLProtectionSpaceAuthenticationMethod? fromValue(String? value) { + if (value != null) { + try { + return IOSNSURLProtectionSpaceAuthenticationMethod.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [IOSNSURLProtectionSpaceAuthenticationMethod] instance from a native value. + static IOSNSURLProtectionSpaceAuthenticationMethod? fromNativeValue( + String? value) { + if (value != null) { + try { + return IOSNSURLProtectionSpaceAuthenticationMethod.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/pubspec.yaml b/pubspec.yaml index 657d6702..18d6cb1a 100755 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -13,13 +13,18 @@ dependencies: flutter_web_plugins: sdk: flutter js: ^0.6.3 + flutter_inappwebview_internal_annotations: + path: dev_packages/flutter_inappwebview_internal_annotations dev_dependencies: flutter_test: sdk: flutter flutter_driver: sdk: flutter - pedantic: ^1.11.1 + lints: ^1.0.1 + build_runner: + generators: + path: dev_packages/generators # For information on the generic Dart part of this file, see the # following page: https://www.dartlang.org/tools/pub/pubspec From 015b5f33abaefae0ae8b185faf305af4863c46b1 Mon Sep 17 00:00:00 2001 From: Lorenzo Pichilli Date: Wed, 18 May 2022 03:05:06 +0200 Subject: [PATCH 2/9] Updated generator --- CHANGELOG.md | 5 +- .../src/exchangeable_object_generator.dart | 57 ++-- .../test_gen/lib/src/types/test_class.dart | 123 ++++++++- ios/Classes/Types/URLProtectionSpace.swift | 1 - lib/src/types/client_cert_response.dart | 42 +-- lib/src/types/client_cert_response.g.dart | 77 ++++++ .../types/client_cert_response_action.dart | 25 +- .../types/client_cert_response_action.g.dart | 85 ++++++ lib/src/types/compress_format.dart | 54 +--- lib/src/types/compress_format.g.dart | 107 +++++++ lib/src/types/console_message.dart | 40 +-- lib/src/types/console_message.g.dart | 51 ++++ lib/src/types/console_message_level.dart | 68 +---- lib/src/types/console_message_level.g.dart | 97 +++++++ .../types/content_blocker_action_type.dart | 48 +--- .../types/content_blocker_action_type.g.dart | 81 ++++++ .../content_blocker_trigger_load_type.dart | 45 +-- .../content_blocker_trigger_load_type.g.dart | 75 +++++ ...content_blocker_trigger_resource_type.dart | 66 ++--- ...ntent_blocker_trigger_resource_type.g.dart | 91 ++++++ lib/src/types/content_world.dart | 2 - lib/src/types/cookie.dart | 36 +-- lib/src/types/cookie.g.dart | 106 +++++++ lib/src/types/create_window_action.dart | 150 +++------- lib/src/types/create_window_action.g.dart | 140 ++++++++++ lib/src/types/cross_origin.dart | 45 +-- lib/src/types/cross_origin.g.dart | 76 +++++ lib/src/types/frame_info.dart | 84 +----- lib/src/types/frame_info.g.dart | 103 +++++++ .../types/http_cookie_same_site_policy.dart | 48 +--- .../types/http_cookie_same_site_policy.g.dart | 85 ++++++ lib/src/types/navigation_action.dart | 181 +++++------- lib/src/types/navigation_action.g.dart | 162 +++++++++++ lib/src/types/navigation_type.dart | 142 ++-------- lib/src/types/navigation_type.g.dart | 201 ++++++++++++++ lib/src/types/url_protection_space.dart | 50 ++-- lib/src/types/url_protection_space.g.dart | 52 ++-- lib/src/types/url_request.dart | 259 ++++++----------- lib/src/types/url_request.g.dart | 260 ++++++++++++++++++ lib/src/types/url_request_attribution.dart | 53 +--- lib/src/types/url_request_attribution.g.dart | 85 ++++++ lib/src/types/url_request_cache_policy.dart | 142 ++-------- lib/src/types/url_request_cache_policy.g.dart | 237 ++++++++++++++++ .../url_request_network_service_type.dart | 162 ++--------- .../url_request_network_service_type.g.dart | 242 ++++++++++++++++ lib/src/types/window_features.dart | 94 +------ lib/src/types/window_features.g.dart | 163 +++++++++++ 47 files changed, 3149 insertions(+), 1449 deletions(-) create mode 100644 lib/src/types/client_cert_response.g.dart create mode 100644 lib/src/types/client_cert_response_action.g.dart create mode 100644 lib/src/types/compress_format.g.dart create mode 100644 lib/src/types/console_message.g.dart create mode 100644 lib/src/types/console_message_level.g.dart create mode 100644 lib/src/types/content_blocker_action_type.g.dart create mode 100644 lib/src/types/content_blocker_trigger_load_type.g.dart create mode 100644 lib/src/types/content_blocker_trigger_resource_type.g.dart create mode 100644 lib/src/types/cookie.g.dart create mode 100644 lib/src/types/create_window_action.g.dart create mode 100644 lib/src/types/cross_origin.g.dart create mode 100644 lib/src/types/frame_info.g.dart create mode 100644 lib/src/types/http_cookie_same_site_policy.g.dart create mode 100644 lib/src/types/navigation_action.g.dart create mode 100644 lib/src/types/navigation_type.g.dart create mode 100644 lib/src/types/url_request.g.dart create mode 100644 lib/src/types/url_request_attribution.g.dart create mode 100644 lib/src/types/url_request_cache_policy.g.dart create mode 100644 lib/src/types/url_request_network_service_type.g.dart create mode 100644 lib/src/types/window_features.g.dart diff --git a/CHANGELOG.md b/CHANGELOG.md index 451997e5..bf48d2e3 100755 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,8 +16,9 @@ ### BREAKING CHANGES -- On Android, the `InAppWebView` widget uses hybrid composition by default (`useHybridComposition: true`). -- All properties of `GeolocationPermissionShowPromptResponse` cannot be `null`; +- On Android, the `InAppWebView` widget uses hybrid composition by default (`useHybridComposition: true`) +- All properties of `GeolocationPermissionShowPromptResponse` cannot be `null` +- Removed `URLProtectionSpace.iosIsProxy` property ## 5.4.3+7 diff --git a/dev_packages/generators/lib/src/exchangeable_object_generator.dart b/dev_packages/generators/lib/src/exchangeable_object_generator.dart index 5e67f491..56844ae7 100644 --- a/dev_packages/generators/lib/src/exchangeable_object_generator.dart +++ b/dev_packages/generators/lib/src/exchangeable_object_generator.dart @@ -119,7 +119,7 @@ class ExchangeableObjectGenerator var defaultValueCode = parameter.defaultValueCode?.replaceFirst("_.", "."); var constructorField = - '${!isNullable && defaultValueCode == null ? 'required ' : ''}$parameterType $parameterName${defaultValueCode != null ? ' = $defaultValueCode' : ''}'; + '${!isNullable && defaultValueCode == null ? 'required ' : ''}${parameterType.toString().replaceFirst("_", "")} $parameterName${defaultValueCode != null ? ' = $defaultValueCode' : ''}'; if (parameter.hasDeprecated) { deprecatedFields.add(parameter); constructorField = @@ -157,6 +157,7 @@ class ExchangeableObjectGenerator classBuffer.writeln(constructorBody .toString() .replaceAll(className, extClassName) + .replaceAll("_.", ".") .replaceAll("@ExchangeableObjectConstructor()", "")); } } else if (constructorFields.length > 0) { @@ -192,37 +193,39 @@ class ExchangeableObjectGenerator .replaceFirst("Use ", "") .replaceFirst(" instead", "") .trim(); - final fieldElement = visitor.fields[fieldName]!; - final fieldTypeElement = fieldElement.type.element; - final deprecatedFieldTypeElement = deprecatedField.type.element; + final fieldElement = visitor.fields[fieldName]; + if (fieldElement != null) { + final fieldTypeElement = fieldElement.type.element; + final deprecatedFieldTypeElement = deprecatedField.type.element; - classBuffer.write('$fieldName = $fieldName ?? '); - if (fieldTypeElement != null && deprecatedFieldTypeElement != null) { - final isNullable = Util.typeIsNullable(fieldElement.type); - final deprecatedIsNullable = Util.typeIsNullable(deprecatedField.type); - final hasFromMap = hasFromMapMethod(fieldTypeElement); - final hasFromNativeValue = hasFromNativeValueMethod(fieldTypeElement); - final hasFromValue = hasFromValueMethod(fieldTypeElement); - final deprecatedHasToMap = hasFromMapMethod(deprecatedFieldTypeElement); - final deprecatedHasToNativeValue = hasToNativeValueMethod(deprecatedFieldTypeElement); - final deprecatedHasToValue = hasToValueMethod(deprecatedFieldTypeElement); - if (hasFromMap && deprecatedHasToMap) { - final hasNullableFromMap = hasNullableFromMapFactory(fieldTypeElement); - classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + - ".fromMap($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toMap())${!isNullable && hasNullableFromMap ? '!' : ''}"); - } else if (hasFromNativeValue && deprecatedHasToNativeValue) { - classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + - '.fromNativeValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toNativeValue())${!isNullable ? '!' : ''}'); - } else if (hasFromValue && deprecatedHasToValue) { - classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + - '.fromValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toValue())${!isNullable ? '!' : ''}'); + classBuffer.write('$fieldName = $fieldName ?? '); + if (fieldTypeElement != null && deprecatedFieldTypeElement != null) { + final isNullable = Util.typeIsNullable(fieldElement.type); + final deprecatedIsNullable = Util.typeIsNullable(deprecatedField.type); + final hasFromMap = hasFromMapMethod(fieldTypeElement); + final hasFromNativeValue = hasFromNativeValueMethod(fieldTypeElement); + final hasFromValue = hasFromValueMethod(fieldTypeElement); + final deprecatedHasToMap = hasFromMapMethod(deprecatedFieldTypeElement); + final deprecatedHasToNativeValue = hasToNativeValueMethod(deprecatedFieldTypeElement); + final deprecatedHasToValue = hasToValueMethod(deprecatedFieldTypeElement); + if (hasFromMap && deprecatedHasToMap) { + final hasNullableFromMap = hasNullableFromMapFactory(fieldTypeElement); + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + ".fromMap($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toMap())${!isNullable && hasNullableFromMap ? '!' : ''}"); + } else if (hasFromNativeValue && deprecatedHasToNativeValue) { + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + '.fromNativeValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toNativeValue())${!isNullable ? '!' : ''}'); + } else if (hasFromValue && deprecatedHasToValue) { + classBuffer.write(fieldTypeElement.name!.replaceFirst("_", "") + + '.fromValue($deprecatedFieldName${deprecatedIsNullable ? '?' : ''}.toValue())${!isNullable ? '!' : ''}'); + } else { + classBuffer.write(deprecatedFieldName); + } } else { classBuffer.write(deprecatedFieldName); } - } else { - classBuffer.write(deprecatedFieldName); + classBuffer.writeln(';'); } - classBuffer.writeln(';'); } classBuffer.writeln('}'); } else if (!hasCustomConstructor) { diff --git a/dev_packages/test_gen/lib/src/types/test_class.dart b/dev_packages/test_gen/lib/src/types/test_class.dart index b0c19e6c..9f5556d1 100644 --- a/dev_packages/test_gen/lib/src/types/test_class.dart +++ b/dev_packages/test_gen/lib/src/types/test_class.dart @@ -6,7 +6,7 @@ import 'test_enum.dart'; part 'test_class.g.dart'; ///Custom docs -@ExchangeableObject() +// @ExchangeableObject() @SupportedPlatforms(platforms: [ AndroidPlatform( apiName: "TestClass", @@ -20,7 +20,7 @@ part 'test_class.g.dart'; ), WebPlatform(), ]) -class TestClass_ extends TestClass3 { +class TestClass_ extends TestClass3_ { ///Docs 1 String test1; ///Docs 2 @@ -51,10 +51,125 @@ class TestClass_ extends TestClass3 { } -class TestClass3 { +@ExchangeableObject() +class TestClass3_ { String asd; - TestClass3({required this.asd}); + TestClass3_({required this.asd}); +} + +///Class that represents the navigation request used by the [WebView.onCreateWindow] event. +@ExchangeableObject() +class CreateWindowAction_ extends NavigationAction_ { + ///The window id. Used by [WebView] to create a new WebView. + int windowId; + + ///Use [isDialog] instead. + @Deprecated("Use isDialog instead") + bool? androidIsDialog; + + ///Indicates if the new window should be a dialog, rather than a full-size window. + @SupportedPlatforms( + platforms: [ + AndroidPlatform() + ] + ) + bool? isDialog; + + CreateWindowAction_( + {required this.windowId, + @Deprecated('Use isDialog instead') + this.androidIsDialog, + this.isDialog, + required bool isForMainFrame, + @Deprecated('Use hasGesture instead') + bool? androidHasGesture, + @Deprecated('Use isRedirect instead') + bool? androidIsRedirect, + bool? hasGesture, + bool? isRedirect, + @Deprecated('Use navigationType instead') + // ignore: deprecated_member_use_from_same_package + TestClass3_? iosWKNavigationType, + TestClass3_? navigationType}) : super( + isForMainFrame: isForMainFrame, + hasGesture: hasGesture, + isRedirect: isRedirect, + navigationType: navigationType + ); +} + +///An object that contains information about an action that causes navigation to occur. +@ExchangeableObject() +class NavigationAction_ { + ///Indicates whether the request was made for the main frame. + /// + ///**NOTE for Android**: If the request is associated to the [WebView.onCreateWindow] event, this is always `true`. + ///Also, on Android < 21, this is always `true`. + bool isForMainFrame; + + ///Use [hasGesture] instead. + @Deprecated('Use hasGesture instead') + bool? androidHasGesture; + + ///Gets whether a gesture (such as a click) was associated with the request. + ///For security reasons in certain situations this method may return `false` even though + ///the sequence of events which caused the request to be created was initiated by a user + ///gesture. + @SupportedPlatforms( + platforms: [ + AndroidPlatform( + available: "21", + apiName: "WebResourceRequest.hasGesture", + apiUrl: "https://developer.android.com/reference/android/webkit/WebResourceRequest#hasGesture()", + note: "On Android < 21, this is always `false`" + ) + ] + ) + bool? hasGesture; + + ///Use [isRedirect] instead. + @Deprecated('Use isRedirect instead') + bool? androidIsRedirect; + + ///Gets whether the request was a result of a server-side redirect. + /// + ///**NOTE**: If the request is associated to the [WebView.onCreateWindow] event, this is always `false`. + ///Also, on Android < 21, this is always `false`. + @SupportedPlatforms( + platforms: [ + AndroidPlatform( + available: "21", + apiName: "WebResourceRequest.isRedirect", + apiUrl: "https://developer.android.com/reference/android/webkit/WebResourceRequest#isRedirect()" + ) + ] + ) + bool? isRedirect; + + ///Use [navigationType] instead. + @Deprecated("Use navigationType instead") + TestClass3_? iosWKNavigationType; + + ///The type of action triggering the navigation. + /// + ///**NOTE**: available only on iOS. + TestClass3_? navigationType; + + ///A value indicating whether the web content used a download attribute to indicate that this should be downloaded. + /// + ///**NOTE**: available only on iOS. + bool? shouldPerformDownload; + + NavigationAction_( + {required this.isForMainFrame, + @Deprecated('Use hasGesture instead') this.androidHasGesture, + this.hasGesture, + @Deprecated('Use isRedirect instead') this.androidIsRedirect, + this.isRedirect, + @Deprecated("Use navigationType instead") this.iosWKNavigationType, + this.navigationType, + this.shouldPerformDownload}); } class Util { diff --git a/ios/Classes/Types/URLProtectionSpace.swift b/ios/Classes/Types/URLProtectionSpace.swift index 33c03847..75557e17 100644 --- a/ios/Classes/Types/URLProtectionSpace.swift +++ b/ios/Classes/Types/URLProtectionSpace.swift @@ -57,7 +57,6 @@ extension URLProtectionSpace { "authenticationMethod": authenticationMethod, "distinguishedNames": distinguishedNames, "receivesCredentialSecurely": receivesCredentialSecurely, - "isProxy": isProxy(), "proxyType": proxyType ] } diff --git a/lib/src/types/client_cert_response.dart b/lib/src/types/client_cert_response.dart index 1cee42fa..10c3219f 100644 --- a/lib/src/types/client_cert_response.dart +++ b/lib/src/types/client_cert_response.dart @@ -1,11 +1,15 @@ import 'package:flutter/foundation.dart'; +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; import '../in_app_webview/webview.dart'; import 'client_cert_response_action.dart'; +part 'client_cert_response.g.dart'; + ///Class that represents the response used by the [WebView.onReceivedClientCertRequest] event. -class ClientCertResponse { +@ExchangeableObject() +class ClientCertResponse_ { ///The file path of the certificate to use. String certificatePath; @@ -17,48 +21,28 @@ class ClientCertResponse { String? androidKeyStoreType; ///An Android-specific property used by Java [KeyStore](https://developer.android.com/reference/java/security/KeyStore) class to get the instance. + @SupportedPlatforms(platforms: [ + AndroidPlatform() + ]) String? keyStoreType; ///Indicate the [ClientCertResponseAction] to take in response of the client certificate challenge. - ClientCertResponseAction? action; + ClientCertResponseAction_? action; - ClientCertResponse( + @ExchangeableObjectConstructor() + ClientCertResponse_( {required this.certificatePath, this.certificatePassword = "", @Deprecated('Use keyStoreType instead') this.androidKeyStoreType = "PKCS12", this.keyStoreType = "PKCS12", - this.action = ClientCertResponseAction.CANCEL}) { - if (this.action == ClientCertResponseAction.PROCEED) + this.action = ClientCertResponseAction_.CANCEL}) { + if (this.action == ClientCertResponseAction_.PROCEED) assert(certificatePath.isNotEmpty); - // ignore: deprecated_member_use_from_same_package this.keyStoreType = this.keyStoreType ?? this.androidKeyStoreType; if (!kIsWeb && defaultTargetPlatform == TargetPlatform.android) assert(this.keyStoreType != null); } - - ///Converts instance to a map. - Map toMap() { - return { - "certificatePath": certificatePath, - "certificatePassword": certificatePassword, - // ignore: deprecated_member_use_from_same_package - "androidKeyStoreType": keyStoreType ?? androidKeyStoreType, - // ignore: deprecated_member_use_from_same_package - "keyStoreType": keyStoreType ?? androidKeyStoreType, - "action": action?.toValue() - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/client_cert_response.g.dart b/lib/src/types/client_cert_response.g.dart new file mode 100644 index 00000000..dc1f21f2 --- /dev/null +++ b/lib/src/types/client_cert_response.g.dart @@ -0,0 +1,77 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'client_cert_response.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents the response used by the [WebView.onReceivedClientCertRequest] event. +class ClientCertResponse { + ///The file path of the certificate to use. + String certificatePath; + + ///The certificate password. + String? certificatePassword; + + ///Use [keyStoreType] instead. + @Deprecated('Use keyStoreType instead') + String? androidKeyStoreType; + + ///An Android-specific property used by Java [KeyStore](https://developer.android.com/reference/java/security/KeyStore) class to get the instance. + /// + ///**Supported Platforms/Implementations**: + ///- Android native WebView + String? keyStoreType; + + ///Indicate the [ClientCertResponseAction] to take in response of the client certificate challenge. + ClientCertResponseAction? action; + ClientCertResponse( + {required this.certificatePath, + this.certificatePassword = "", + @Deprecated('Use keyStoreType instead') + this.androidKeyStoreType = "PKCS12", + this.keyStoreType = "PKCS12", + this.action = ClientCertResponseAction.CANCEL}) { + if (this.action == ClientCertResponseAction.PROCEED) + assert(certificatePath.isNotEmpty); + this.keyStoreType = this.keyStoreType ?? this.androidKeyStoreType; + if (!kIsWeb && defaultTargetPlatform == TargetPlatform.android) + assert(this.keyStoreType != null); + } + + ///Gets a possible [ClientCertResponse] instance from a [Map] value. + static ClientCertResponse? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = ClientCertResponse( + certificatePath: map['certificatePath'], + ); + instance.certificatePassword = map['certificatePassword']; + instance.androidKeyStoreType = map['keyStoreType']; + instance.keyStoreType = map['keyStoreType']; + instance.action = ClientCertResponseAction.fromNativeValue(map['action']); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "certificatePath": certificatePath, + "certificatePassword": certificatePassword, + "keyStoreType": keyStoreType, + "action": action?.toNativeValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'ClientCertResponse{certificatePath: $certificatePath, certificatePassword: $certificatePassword, keyStoreType: $keyStoreType, action: $action}'; + } +} diff --git a/lib/src/types/client_cert_response_action.dart b/lib/src/types/client_cert_response_action.dart index 44683331..7d606567 100644 --- a/lib/src/types/client_cert_response_action.dart +++ b/lib/src/types/client_cert_response_action.dart @@ -1,25 +1,22 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'client_cert_response.dart'; +part 'client_cert_response_action.g.dart'; + ///Class used by [ClientCertResponse] class. -class ClientCertResponseAction { +@ExchangeableEnum() +class ClientCertResponseAction_ { + // ignore: unused_field final int _value; - - const ClientCertResponseAction._internal(this._value); - - ///Gets [int] value. - int toValue() => _value; + const ClientCertResponseAction_._internal(this._value); ///Cancel this request. - static const CANCEL = const ClientCertResponseAction._internal(0); + static const CANCEL = const ClientCertResponseAction_._internal(0); ///Proceed with the specified certificate. - static const PROCEED = const ClientCertResponseAction._internal(1); + static const PROCEED = const ClientCertResponseAction_._internal(1); ///Ignore the request for now. - static const IGNORE = const ClientCertResponseAction._internal(2); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const IGNORE = const ClientCertResponseAction_._internal(2); } \ No newline at end of file diff --git a/lib/src/types/client_cert_response_action.g.dart b/lib/src/types/client_cert_response_action.g.dart new file mode 100644 index 00000000..a934d2a1 --- /dev/null +++ b/lib/src/types/client_cert_response_action.g.dart @@ -0,0 +1,85 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'client_cert_response_action.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class used by [ClientCertResponse] class. +class ClientCertResponseAction { + final int _value; + final int _nativeValue; + const ClientCertResponseAction._internal(this._value, this._nativeValue); +// ignore: unused_element + factory ClientCertResponseAction._internalMultiPlatform( + int value, Function nativeValue) => + ClientCertResponseAction._internal(value, nativeValue()); + + ///Cancel this request. + static const CANCEL = ClientCertResponseAction._internal(0, 0); + + ///Proceed with the specified certificate. + static const PROCEED = ClientCertResponseAction._internal(1, 1); + + ///Ignore the request for now. + static const IGNORE = ClientCertResponseAction._internal(2, 2); + + ///Set of all values of [ClientCertResponseAction]. + static final Set values = [ + ClientCertResponseAction.CANCEL, + ClientCertResponseAction.PROCEED, + ClientCertResponseAction.IGNORE, + ].toSet(); + + ///Gets a possible [ClientCertResponseAction] instance from [int] value. + static ClientCertResponseAction? fromValue(int? value) { + if (value != null) { + try { + return ClientCertResponseAction.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [ClientCertResponseAction] instance from a native value. + static ClientCertResponseAction? fromNativeValue(int? value) { + if (value != null) { + try { + return ClientCertResponseAction.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'CANCEL'; + case 1: + return 'PROCEED'; + case 2: + return 'IGNORE'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/compress_format.dart b/lib/src/types/compress_format.dart index ed82b464..da05cb92 100644 --- a/lib/src/types/compress_format.dart +++ b/lib/src/types/compress_format.dart @@ -1,52 +1,29 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'compress_format.g.dart'; + ///Class that represents the known formats a bitmap can be compressed into. -class CompressFormat { +@ExchangeableEnum() +class CompressFormat_ { + // ignore: unused_field final String _value; - - const CompressFormat._internal(this._value); - - ///Set of all values of [CompressFormat]. - static final Set values = [ - CompressFormat.JPEG, - CompressFormat.PNG, - CompressFormat.WEBP, - CompressFormat.WEBP_LOSSY, - CompressFormat.WEBP_LOSSLESS, - ].toSet(); - - ///Gets a possible [CompressFormat] instance from a [String] value. - static CompressFormat? fromValue(String? value) { - if (value != null) { - try { - return CompressFormat.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const CompressFormat_._internal(this._value); ///Compress to the `PNG` format. ///PNG is lossless, so `quality` is ignored. - static const PNG = const CompressFormat._internal("PNG"); + static const PNG = const CompressFormat_._internal("PNG"); ///Compress to the `JPEG` format. ///Quality of `0` means compress for the smallest size. ///`100` means compress for max visual quality. - static const JPEG = const CompressFormat._internal("JPEG"); + static const JPEG = const CompressFormat_._internal("JPEG"); ///Compress to the `WEBP` lossy format. ///Quality of `0` means compress for the smallest size. ///`100` means compress for max visual quality. /// ///**NOTE**: available only on Android. - static const WEBP = const CompressFormat._internal("WEBP"); + static const WEBP = const CompressFormat_._internal("WEBP"); ///Compress to the `WEBP` lossy format. ///Quality of `0` means compress for the smallest size. @@ -55,7 +32,7 @@ class CompressFormat { ///**NOTE**: available only on Android. /// ///**NOTE for Android**: available on Android 30+. - static const WEBP_LOSSY = const CompressFormat._internal("WEBP_LOSSY"); + static const WEBP_LOSSY = const CompressFormat_._internal("WEBP_LOSSY"); ///Compress to the `WEBP` lossless format. ///Quality refers to how much effort to put into compression. @@ -65,10 +42,5 @@ class CompressFormat { ///**NOTE**: available only on Android. /// ///**NOTE for Android**: available on Android 30+. - static const WEBP_LOSSLESS = const CompressFormat._internal("WEBP_LOSSLESS"); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const WEBP_LOSSLESS = const CompressFormat_._internal("WEBP_LOSSLESS"); } \ No newline at end of file diff --git a/lib/src/types/compress_format.g.dart b/lib/src/types/compress_format.g.dart new file mode 100644 index 00000000..ab68248a --- /dev/null +++ b/lib/src/types/compress_format.g.dart @@ -0,0 +1,107 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'compress_format.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the known formats a bitmap can be compressed into. +class CompressFormat { + final String _value; + final String _nativeValue; + const CompressFormat._internal(this._value, this._nativeValue); +// ignore: unused_element + factory CompressFormat._internalMultiPlatform( + String value, Function nativeValue) => + CompressFormat._internal(value, nativeValue()); + + ///Compress to the `PNG` format. + ///PNG is lossless, so `quality` is ignored. + static const PNG = CompressFormat._internal('PNG', 'PNG'); + + ///Compress to the `JPEG` format. + ///Quality of `0` means compress for the smallest size. + ///`100` means compress for max visual quality. + static const JPEG = CompressFormat._internal('JPEG', 'JPEG'); + + ///Compress to the `WEBP` lossy format. + ///Quality of `0` means compress for the smallest size. + ///`100` means compress for max visual quality. + /// + ///**NOTE**: available only on Android. + static const WEBP = CompressFormat._internal('WEBP', 'WEBP'); + + ///Compress to the `WEBP` lossy format. + ///Quality of `0` means compress for the smallest size. + ///`100` means compress for max visual quality. + /// + ///**NOTE**: available only on Android. + /// + ///**NOTE for Android**: available on Android 30+. + static const WEBP_LOSSY = + CompressFormat._internal('WEBP_LOSSY', 'WEBP_LOSSY'); + + ///Compress to the `WEBP` lossless format. + ///Quality refers to how much effort to put into compression. + ///A value of `0` means to compress quickly, resulting in a relatively large file size. + ///`100` means to spend more time compressing, resulting in a smaller file. + /// + ///**NOTE**: available only on Android. + /// + ///**NOTE for Android**: available on Android 30+. + static const WEBP_LOSSLESS = + CompressFormat._internal('WEBP_LOSSLESS', 'WEBP_LOSSLESS'); + + ///Set of all values of [CompressFormat]. + static final Set values = [ + CompressFormat.PNG, + CompressFormat.JPEG, + CompressFormat.WEBP, + CompressFormat.WEBP_LOSSY, + CompressFormat.WEBP_LOSSLESS, + ].toSet(); + + ///Gets a possible [CompressFormat] instance from [String] value. + static CompressFormat? fromValue(String? value) { + if (value != null) { + try { + return CompressFormat.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [CompressFormat] instance from a native value. + static CompressFormat? fromNativeValue(String? value) { + if (value != null) { + try { + return CompressFormat.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/console_message.dart b/lib/src/types/console_message.dart index 403a3c51..33dcbea7 100644 --- a/lib/src/types/console_message.dart +++ b/lib/src/types/console_message.dart @@ -1,45 +1,23 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../in_app_webview/webview.dart'; import 'console_message_level.dart'; +part 'console_message.g.dart'; + ///Class representing a JavaScript console message from WebCore. ///This could be a issued by a call to one of the console logging functions (e.g. console.log('...')) or a JavaScript error on the page. /// ///To receive notifications of these messages, use the [WebView.onConsoleMessage] event. -class ConsoleMessage { +@ExchangeableObject() +class ConsoleMessage_ { ///Console message String message; ///Console messsage level - ConsoleMessageLevel messageLevel; + ConsoleMessageLevel_ messageLevel; - ConsoleMessage( - {this.message = "", this.messageLevel = ConsoleMessageLevel.LOG}); - - ///Gets a possible [ConsoleMessage] instance from a [Map] value. - static ConsoleMessage? fromMap(Map? map) { - if (map == null) { - return null; - } - return ConsoleMessage( - message: map["message"], - messageLevel: ConsoleMessageLevel.fromValue(map["messageLevel"]) ?? - ConsoleMessageLevel.LOG, - ); - } - - ///Converts instance to a map. - Map toMap() { - return {"message": message, "messageLevel": messageLevel.toValue()}; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } + ConsoleMessage_( + {this.message = "", this.messageLevel = ConsoleMessageLevel_.LOG}); } \ No newline at end of file diff --git a/lib/src/types/console_message.g.dart b/lib/src/types/console_message.g.dart new file mode 100644 index 00000000..4573e448 --- /dev/null +++ b/lib/src/types/console_message.g.dart @@ -0,0 +1,51 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'console_message.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class representing a JavaScript console message from WebCore. +///This could be a issued by a call to one of the console logging functions (e.g. console.log('...')) or a JavaScript error on the page. +/// +///To receive notifications of these messages, use the [WebView.onConsoleMessage] event. +class ConsoleMessage { + ///Console message + String message; + + ///Console messsage level + ConsoleMessageLevel messageLevel; + ConsoleMessage( + {this.message = "", this.messageLevel = ConsoleMessageLevel.LOG}); + + ///Gets a possible [ConsoleMessage] instance from a [Map] value. + static ConsoleMessage? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = ConsoleMessage(); + instance.message = map['message']; + instance.messageLevel = + ConsoleMessageLevel.fromNativeValue(map['messageLevel'])!; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "message": message, + "messageLevel": messageLevel.toNativeValue(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'ConsoleMessage{message: $message, messageLevel: $messageLevel}'; + } +} diff --git a/lib/src/types/console_message_level.dart b/lib/src/types/console_message_level.dart index 89219449..96858121 100644 --- a/lib/src/types/console_message_level.dart +++ b/lib/src/types/console_message_level.dart @@ -1,68 +1,26 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + +part 'console_message_level.g.dart'; + ///Class representing the level of a console message. -class ConsoleMessageLevel { +@ExchangeableEnum() +class ConsoleMessageLevel_ { + // ignore: unused_field final int _value; - - const ConsoleMessageLevel._internal(this._value); - - ///Set of all values of [ConsoleMessageLevel]. - static final Set values = [ - ConsoleMessageLevel.TIP, - ConsoleMessageLevel.LOG, - ConsoleMessageLevel.WARNING, - ConsoleMessageLevel.ERROR, - ConsoleMessageLevel.DEBUG, - ].toSet(); - - ///Gets a possible [ConsoleMessageLevel] instance from an [int] value. - static ConsoleMessageLevel? fromValue(int? value) { - if (value != null) { - try { - return ConsoleMessageLevel.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [int] value. - int toValue() => _value; - - @override - String toString() { - switch (_value) { - case 0: - return "TIP"; - case 2: - return "WARNING"; - case 3: - return "ERROR"; - case 4: - return "DEBUG"; - case 1: - default: - return "LOG"; - } - } + const ConsoleMessageLevel_._internal(this._value); ///Console TIP level - static const TIP = const ConsoleMessageLevel._internal(0); + static const TIP = const ConsoleMessageLevel_._internal(0); ///Console LOG level - static const LOG = const ConsoleMessageLevel._internal(1); + static const LOG = const ConsoleMessageLevel_._internal(1); ///Console WARNING level - static const WARNING = const ConsoleMessageLevel._internal(2); + static const WARNING = const ConsoleMessageLevel_._internal(2); ///Console ERROR level - static const ERROR = const ConsoleMessageLevel._internal(3); + static const ERROR = const ConsoleMessageLevel_._internal(3); ///Console DEBUG level - static const DEBUG = const ConsoleMessageLevel._internal(4); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + static const DEBUG = const ConsoleMessageLevel_._internal(4); } \ No newline at end of file diff --git a/lib/src/types/console_message_level.g.dart b/lib/src/types/console_message_level.g.dart new file mode 100644 index 00000000..c221ebae --- /dev/null +++ b/lib/src/types/console_message_level.g.dart @@ -0,0 +1,97 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'console_message_level.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class representing the level of a console message. +class ConsoleMessageLevel { + final int _value; + final int _nativeValue; + const ConsoleMessageLevel._internal(this._value, this._nativeValue); +// ignore: unused_element + factory ConsoleMessageLevel._internalMultiPlatform( + int value, Function nativeValue) => + ConsoleMessageLevel._internal(value, nativeValue()); + + ///Console TIP level + static const TIP = ConsoleMessageLevel._internal(0, 0); + + ///Console LOG level + static const LOG = ConsoleMessageLevel._internal(1, 1); + + ///Console WARNING level + static const WARNING = ConsoleMessageLevel._internal(2, 2); + + ///Console ERROR level + static const ERROR = ConsoleMessageLevel._internal(3, 3); + + ///Console DEBUG level + static const DEBUG = ConsoleMessageLevel._internal(4, 4); + + ///Set of all values of [ConsoleMessageLevel]. + static final Set values = [ + ConsoleMessageLevel.TIP, + ConsoleMessageLevel.LOG, + ConsoleMessageLevel.WARNING, + ConsoleMessageLevel.ERROR, + ConsoleMessageLevel.DEBUG, + ].toSet(); + + ///Gets a possible [ConsoleMessageLevel] instance from [int] value. + static ConsoleMessageLevel? fromValue(int? value) { + if (value != null) { + try { + return ConsoleMessageLevel.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [ConsoleMessageLevel] instance from a native value. + static ConsoleMessageLevel? fromNativeValue(int? value) { + if (value != null) { + try { + return ConsoleMessageLevel.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [int] value. + int toValue() => _value; + + ///Gets [int] native value. + int toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + switch (_value) { + case 0: + return 'TIP'; + case 1: + return 'LOG'; + case 2: + return 'WARNING'; + case 3: + return 'ERROR'; + case 4: + return 'DEBUG'; + } + return _value.toString(); + } +} diff --git a/lib/src/types/content_blocker_action_type.dart b/lib/src/types/content_blocker_action_type.dart index c6530acf..11b7e057 100644 --- a/lib/src/types/content_blocker_action_type.dart +++ b/lib/src/types/content_blocker_action_type.dart @@ -1,52 +1,26 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../content_blocker.dart'; +part 'content_blocker_action_type.g.dart'; + ///Class that represents the kind of action that can be used with a [ContentBlockerTrigger]. -class ContentBlockerActionType { +@ExchangeableEnum() +class ContentBlockerActionType_ { + // ignore: unused_field final String _value; - - const ContentBlockerActionType._internal(this._value); - - ///Set of all values of [ContentBlockerActionType]. - static final Set values = [ - ContentBlockerActionType.BLOCK, - ContentBlockerActionType.CSS_DISPLAY_NONE, - ContentBlockerActionType.MAKE_HTTPS, - ].toSet(); - - ///Gets a possible [ContentBlockerActionType] instance from a [String] value. - static ContentBlockerActionType? fromValue(String? value) { - if (value != null) { - try { - return ContentBlockerActionType.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const ContentBlockerActionType_._internal(this._value); ///Stops loading of the resource. If the resource was cached, the cache is ignored. - static const BLOCK = const ContentBlockerActionType._internal('block'); + static const BLOCK = const ContentBlockerActionType_._internal('block'); ///Hides elements of the page based on a CSS selector. A selector field contains the selector list. Any matching element has its display property set to none, which hides it. /// ///**NOTE**: on Android, JavaScript must be enabled. static const CSS_DISPLAY_NONE = - const ContentBlockerActionType._internal('css-display-none'); + const ContentBlockerActionType_._internal('css-display-none'); ///Changes a URL from http to https. URLs with a specified (nondefault) port and links using other protocols are unaffected. static const MAKE_HTTPS = - const ContentBlockerActionType._internal('make-https'); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + const ContentBlockerActionType_._internal('make-https'); } \ No newline at end of file diff --git a/lib/src/types/content_blocker_action_type.g.dart b/lib/src/types/content_blocker_action_type.g.dart new file mode 100644 index 00000000..45b202ec --- /dev/null +++ b/lib/src/types/content_blocker_action_type.g.dart @@ -0,0 +1,81 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'content_blocker_action_type.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the kind of action that can be used with a [ContentBlockerTrigger]. +class ContentBlockerActionType { + final String _value; + final String _nativeValue; + const ContentBlockerActionType._internal(this._value, this._nativeValue); +// ignore: unused_element + factory ContentBlockerActionType._internalMultiPlatform( + String value, Function nativeValue) => + ContentBlockerActionType._internal(value, nativeValue()); + + ///Stops loading of the resource. If the resource was cached, the cache is ignored. + static const BLOCK = ContentBlockerActionType._internal('block', 'block'); + + ///Hides elements of the page based on a CSS selector. A selector field contains the selector list. Any matching element has its display property set to none, which hides it. + /// + ///**NOTE**: on Android, JavaScript must be enabled. + static const CSS_DISPLAY_NONE = ContentBlockerActionType._internal( + 'css-display-none', 'css-display-none'); + + ///Changes a URL from http to https. URLs with a specified (nondefault) port and links using other protocols are unaffected. + static const MAKE_HTTPS = + ContentBlockerActionType._internal('make-https', 'make-https'); + + ///Set of all values of [ContentBlockerActionType]. + static final Set values = [ + ContentBlockerActionType.BLOCK, + ContentBlockerActionType.CSS_DISPLAY_NONE, + ContentBlockerActionType.MAKE_HTTPS, + ].toSet(); + + ///Gets a possible [ContentBlockerActionType] instance from [String] value. + static ContentBlockerActionType? fromValue(String? value) { + if (value != null) { + try { + return ContentBlockerActionType.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [ContentBlockerActionType] instance from a native value. + static ContentBlockerActionType? fromNativeValue(String? value) { + if (value != null) { + try { + return ContentBlockerActionType.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/content_blocker_trigger_load_type.dart b/lib/src/types/content_blocker_trigger_load_type.dart index 992499b0..0c6c5123 100644 --- a/lib/src/types/content_blocker_trigger_load_type.dart +++ b/lib/src/types/content_blocker_trigger_load_type.dart @@ -1,46 +1,21 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../content_blocker.dart'; +part 'content_blocker_trigger_load_type.g.dart'; + ///Class that represents the possible load type for a [ContentBlockerTrigger]. -class ContentBlockerTriggerLoadType { +@ExchangeableEnum() +class ContentBlockerTriggerLoadType_ { + // ignore: unused_field final String _value; - - const ContentBlockerTriggerLoadType._internal(this._value); - - ///Set of all values of [ContentBlockerTriggerLoadType]. - static final Set values = [ - ContentBlockerTriggerLoadType.FIRST_PARTY, - ContentBlockerTriggerLoadType.THIRD_PARTY, - ].toSet(); - - ///Gets a possible [ContentBlockerTriggerLoadType] instance from a [String] value. - static ContentBlockerTriggerLoadType? fromValue(String? value) { - if (value != null) { - try { - return ContentBlockerTriggerLoadType.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const ContentBlockerTriggerLoadType_._internal(this._value); ///FIRST_PARTY is triggered only if the resource has the same scheme, domain, and port as the main page resource. static const FIRST_PARTY = - const ContentBlockerTriggerLoadType._internal('first-party'); + const ContentBlockerTriggerLoadType_._internal('first-party'); ///THIRD_PARTY is triggered if the resource is not from the same domain as the main page resource. static const THIRD_PARTY = - const ContentBlockerTriggerLoadType._internal('third-party'); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; + const ContentBlockerTriggerLoadType_._internal('third-party'); } \ No newline at end of file diff --git a/lib/src/types/content_blocker_trigger_load_type.g.dart b/lib/src/types/content_blocker_trigger_load_type.g.dart new file mode 100644 index 00000000..8821e70a --- /dev/null +++ b/lib/src/types/content_blocker_trigger_load_type.g.dart @@ -0,0 +1,75 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'content_blocker_trigger_load_type.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the possible load type for a [ContentBlockerTrigger]. +class ContentBlockerTriggerLoadType { + final String _value; + final String _nativeValue; + const ContentBlockerTriggerLoadType._internal(this._value, this._nativeValue); +// ignore: unused_element + factory ContentBlockerTriggerLoadType._internalMultiPlatform( + String value, Function nativeValue) => + ContentBlockerTriggerLoadType._internal(value, nativeValue()); + + ///FIRST_PARTY is triggered only if the resource has the same scheme, domain, and port as the main page resource. + static const FIRST_PARTY = + ContentBlockerTriggerLoadType._internal('first-party', 'first-party'); + + ///THIRD_PARTY is triggered if the resource is not from the same domain as the main page resource. + static const THIRD_PARTY = + ContentBlockerTriggerLoadType._internal('third-party', 'third-party'); + + ///Set of all values of [ContentBlockerTriggerLoadType]. + static final Set values = [ + ContentBlockerTriggerLoadType.FIRST_PARTY, + ContentBlockerTriggerLoadType.THIRD_PARTY, + ].toSet(); + + ///Gets a possible [ContentBlockerTriggerLoadType] instance from [String] value. + static ContentBlockerTriggerLoadType? fromValue(String? value) { + if (value != null) { + try { + return ContentBlockerTriggerLoadType.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [ContentBlockerTriggerLoadType] instance from a native value. + static ContentBlockerTriggerLoadType? fromNativeValue(String? value) { + if (value != null) { + try { + return ContentBlockerTriggerLoadType.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/content_blocker_trigger_resource_type.dart b/lib/src/types/content_blocker_trigger_resource_type.dart index f9945fba..cd232bce 100644 --- a/lib/src/types/content_blocker_trigger_resource_type.dart +++ b/lib/src/types/content_blocker_trigger_resource_type.dart @@ -1,61 +1,31 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../content_blocker.dart'; +part 'content_blocker_trigger_resource_type.g.dart'; + ///Class that represents the possible resource type defined for a [ContentBlockerTrigger]. -class ContentBlockerTriggerResourceType { +@ExchangeableEnum() +class ContentBlockerTriggerResourceType_ { + // ignore: unused_field final String _value; - - const ContentBlockerTriggerResourceType._internal(this._value); - - ///Set of all values of [ContentBlockerTriggerResourceType]. - static final Set values = [ - ContentBlockerTriggerResourceType.DOCUMENT, - ContentBlockerTriggerResourceType.IMAGE, - ContentBlockerTriggerResourceType.STYLE_SHEET, - ContentBlockerTriggerResourceType.SCRIPT, - ContentBlockerTriggerResourceType.FONT, - ContentBlockerTriggerResourceType.MEDIA, - ContentBlockerTriggerResourceType.SVG_DOCUMENT, - ContentBlockerTriggerResourceType.RAW, - ].toSet(); - - ///Gets a possible [ContentBlockerTriggerResourceType] instance from a [String] value. - static ContentBlockerTriggerResourceType? fromValue(String? value) { - if (value != null) { - try { - return ContentBlockerTriggerResourceType.values - .firstWhere((element) => element.toValue() == value); - } catch (e) { - return null; - } - } - return null; - } - - ///Gets [String] value. - String toValue() => _value; - - @override - String toString() => _value; + const ContentBlockerTriggerResourceType_._internal(this._value); static const DOCUMENT = - const ContentBlockerTriggerResourceType._internal('document'); + const ContentBlockerTriggerResourceType_._internal('document'); static const IMAGE = - const ContentBlockerTriggerResourceType._internal('image'); + const ContentBlockerTriggerResourceType_._internal('image'); static const STYLE_SHEET = - const ContentBlockerTriggerResourceType._internal('style-sheet'); + const ContentBlockerTriggerResourceType_._internal('style-sheet'); static const SCRIPT = - const ContentBlockerTriggerResourceType._internal('script'); - static const FONT = const ContentBlockerTriggerResourceType._internal('font'); + const ContentBlockerTriggerResourceType_._internal('script'); + static const FONT = + const ContentBlockerTriggerResourceType_._internal('font'); static const MEDIA = - const ContentBlockerTriggerResourceType._internal('media'); + const ContentBlockerTriggerResourceType_._internal('media'); static const SVG_DOCUMENT = - const ContentBlockerTriggerResourceType._internal('svg-document'); + const ContentBlockerTriggerResourceType_._internal('svg-document'); ///Any untyped load - static const RAW = const ContentBlockerTriggerResourceType._internal('raw'); - - bool operator ==(value) => value == _value; - - @override - int get hashCode => _value.hashCode; -} \ No newline at end of file + static const RAW = const ContentBlockerTriggerResourceType_._internal('raw'); +} diff --git a/lib/src/types/content_blocker_trigger_resource_type.g.dart b/lib/src/types/content_blocker_trigger_resource_type.g.dart new file mode 100644 index 00000000..3dadda51 --- /dev/null +++ b/lib/src/types/content_blocker_trigger_resource_type.g.dart @@ -0,0 +1,91 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'content_blocker_trigger_resource_type.dart'; + +// ************************************************************************** +// ExchangeableEnumGenerator +// ************************************************************************** + +///Class that represents the possible resource type defined for a [ContentBlockerTrigger]. +class ContentBlockerTriggerResourceType { + final String _value; + final String _nativeValue; + const ContentBlockerTriggerResourceType._internal( + this._value, this._nativeValue); +// ignore: unused_element + factory ContentBlockerTriggerResourceType._internalMultiPlatform( + String value, Function nativeValue) => + ContentBlockerTriggerResourceType._internal(value, nativeValue()); + static const DOCUMENT = + ContentBlockerTriggerResourceType._internal('document', 'document'); + static const IMAGE = + ContentBlockerTriggerResourceType._internal('image', 'image'); + static const STYLE_SHEET = + ContentBlockerTriggerResourceType._internal('style-sheet', 'style-sheet'); + static const SCRIPT = + ContentBlockerTriggerResourceType._internal('script', 'script'); + static const FONT = + ContentBlockerTriggerResourceType._internal('font', 'font'); + static const MEDIA = + ContentBlockerTriggerResourceType._internal('media', 'media'); + static const SVG_DOCUMENT = ContentBlockerTriggerResourceType._internal( + 'svg-document', 'svg-document'); + + ///Any untyped load + static const RAW = ContentBlockerTriggerResourceType._internal('raw', 'raw'); + + ///Set of all values of [ContentBlockerTriggerResourceType]. + static final Set values = [ + ContentBlockerTriggerResourceType.DOCUMENT, + ContentBlockerTriggerResourceType.IMAGE, + ContentBlockerTriggerResourceType.STYLE_SHEET, + ContentBlockerTriggerResourceType.SCRIPT, + ContentBlockerTriggerResourceType.FONT, + ContentBlockerTriggerResourceType.MEDIA, + ContentBlockerTriggerResourceType.SVG_DOCUMENT, + ContentBlockerTriggerResourceType.RAW, + ].toSet(); + + ///Gets a possible [ContentBlockerTriggerResourceType] instance from [String] value. + static ContentBlockerTriggerResourceType? fromValue(String? value) { + if (value != null) { + try { + return ContentBlockerTriggerResourceType.values + .firstWhere((element) => element.toValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets a possible [ContentBlockerTriggerResourceType] instance from a native value. + static ContentBlockerTriggerResourceType? fromNativeValue(String? value) { + if (value != null) { + try { + return ContentBlockerTriggerResourceType.values + .firstWhere((element) => element.toNativeValue() == value); + } catch (e) { + return null; + } + } + return null; + } + + ///Gets [String] value. + String toValue() => _value; + + ///Gets [String] native value. + String toNativeValue() => _nativeValue; + + @override + int get hashCode => _value.hashCode; + + @override + bool operator ==(value) => value == _value; + + @override + String toString() { + return _value; + } +} diff --git a/lib/src/types/content_world.dart b/lib/src/types/content_world.dart index 2c86cb38..4607b0fc 100644 --- a/lib/src/types/content_world.dart +++ b/lib/src/types/content_world.dart @@ -24,7 +24,6 @@ class ContentWorld { } ///The default world for clients. - // ignore: non_constant_identifier_names static final ContentWorld DEFAULT_CLIENT = ContentWorld.world(name: "defaultClient"); @@ -32,7 +31,6 @@ class ContentWorld { ///This property contains the content world for scripts that the current webpage executes. ///Be careful when manipulating variables in this content world. ///If you modify a variable with the same name as one the webpage uses, you may unintentionally disrupt the normal operation of that page. - // ignore: non_constant_identifier_names static final ContentWorld PAGE = ContentWorld.world(name: "page"); ///Converts instance to a map. diff --git a/lib/src/types/cookie.dart b/lib/src/types/cookie.dart index 886ee6e7..1e47191c 100644 --- a/lib/src/types/cookie.dart +++ b/lib/src/types/cookie.dart @@ -1,8 +1,13 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../cookie_manager.dart'; import 'http_cookie_same_site_policy.dart'; +part 'cookie.g.dart'; + ///Class that represents a cookie returned by the [CookieManager]. -class Cookie { +@ExchangeableObject() +class Cookie_ { ///The cookie name. String name; @@ -27,7 +32,7 @@ class Cookie { ///The cookie same site policy. /// ///**NOTE**: on Android it will be always `null`. - HTTPCookieSameSitePolicy? sameSite; + HTTPCookieSameSitePolicy_? sameSite; ///Indicates if the cookie is secure or not. /// @@ -44,7 +49,7 @@ class Cookie { ///**NOTE**: on Android it will be always `null`. String? path; - Cookie( + Cookie_( {required this.name, required this.value, this.expiresDate, @@ -54,29 +59,4 @@ class Cookie { this.isSecure, this.isHttpOnly, this.path}); - - ///Converts instance to a map. - Map toMap() { - return { - "name": name, - "value": value, - "expiresDate": expiresDate, - "isSessionOnly": isSessionOnly, - "domain": domain, - "sameSite": sameSite?.toValue(), - "isSecure": isSecure, - "isHttpOnly": isHttpOnly, - "path": path - }; - } - - ///Converts instance to a map. - Map toJson() { - return this.toMap(); - } - - @override - String toString() { - return toMap().toString(); - } } \ No newline at end of file diff --git a/lib/src/types/cookie.g.dart b/lib/src/types/cookie.g.dart new file mode 100644 index 00000000..6994beb3 --- /dev/null +++ b/lib/src/types/cookie.g.dart @@ -0,0 +1,106 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'cookie.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents a cookie returned by the [CookieManager]. +class Cookie { + ///The cookie name. + String name; + + ///The cookie value. + dynamic value; + + ///The cookie expiration date in milliseconds. + /// + ///**NOTE**: on Android it will be always `null`. + int? expiresDate; + + ///Indicates if the cookie is a session only cookie. + /// + ///**NOTE**: on Android it will be always `null`. + bool? isSessionOnly; + + ///The cookie domain. + /// + ///**NOTE**: on Android it will be always `null`. + String? domain; + + ///The cookie same site policy. + /// + ///**NOTE**: on Android it will be always `null`. + HTTPCookieSameSitePolicy? sameSite; + + ///Indicates if the cookie is secure or not. + /// + ///**NOTE**: on Android it will be always `null`. + bool? isSecure; + + ///Indicates if the cookie is a http only cookie. + /// + ///**NOTE**: on Android it will be always `null`. + bool? isHttpOnly; + + ///The cookie path. + /// + ///**NOTE**: on Android it will be always `null`. + String? path; + Cookie( + {required this.name, + this.value, + this.expiresDate, + this.isSessionOnly, + this.domain, + this.sameSite, + this.isSecure, + this.isHttpOnly, + this.path}); + + ///Gets a possible [Cookie] instance from a [Map] value. + static Cookie? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = Cookie( + name: map['name'], + value: map['value'], + ); + instance.expiresDate = map['expiresDate']; + instance.isSessionOnly = map['isSessionOnly']; + instance.domain = map['domain']; + instance.sameSite = + HTTPCookieSameSitePolicy.fromNativeValue(map['sameSite']); + instance.isSecure = map['isSecure']; + instance.isHttpOnly = map['isHttpOnly']; + instance.path = map['path']; + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "name": name, + "value": value, + "expiresDate": expiresDate, + "isSessionOnly": isSessionOnly, + "domain": domain, + "sameSite": sameSite?.toNativeValue(), + "isSecure": isSecure, + "isHttpOnly": isHttpOnly, + "path": path, + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'Cookie{name: $name, value: $value, expiresDate: $expiresDate, isSessionOnly: $isSessionOnly, domain: $domain, sameSite: $sameSite, isSecure: $isSecure, isHttpOnly: $isHttpOnly, path: $path}'; + } +} diff --git a/lib/src/types/create_window_action.dart b/lib/src/types/create_window_action.dart index 11b6e549..33ee7aff 100644 --- a/lib/src/types/create_window_action.dart +++ b/lib/src/types/create_window_action.dart @@ -1,3 +1,5 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import '../in_app_webview/webview.dart'; import 'navigation_action.dart'; import 'window_features.dart'; @@ -5,8 +7,11 @@ import 'url_request.dart'; import 'frame_info.dart'; import 'navigation_type.dart'; +part 'create_window_action.g.dart'; + ///Class that represents the navigation request used by the [WebView.onCreateWindow] event. -class CreateWindowAction extends NavigationAction { +@ExchangeableObject() +class CreateWindowAction_ extends NavigationAction_ { ///The window id. Used by [WebView] to create a new WebView. int windowId; @@ -15,20 +20,29 @@ class CreateWindowAction extends NavigationAction { bool? androidIsDialog; ///Indicates if the new window should be a dialog, rather than a full-size window. - /// - ///**NOTE**: available only on Android. + @SupportedPlatforms( + platforms: [ + AndroidPlatform() + ] + ) bool? isDialog; ///Use [windowFeatures] instead. @Deprecated("Use windowFeatures instead") - IOSWKWindowFeatures? iosWindowFeatures; + IOSWKWindowFeatures_? iosWindowFeatures; ///Window features requested by the webpage. - /// - ///**NOTE**: available only on iOS. - WindowFeatures? windowFeatures; + @SupportedPlatforms( + platforms: [ + IOSPlatform( + apiName: "WKWindowFeatures", + apiUrl: "https://developer.apple.com/documentation/webkit/wkwindowfeatures" + ) + ] + ) + WindowFeatures_? windowFeatures; - CreateWindowAction( + CreateWindowAction_( {required this.windowId, @Deprecated('Use isDialog instead') this.androidIsDialog, @@ -36,7 +50,7 @@ class CreateWindowAction extends NavigationAction { @Deprecated('Use windowFeatures instead') this.iosWindowFeatures, this.windowFeatures, - required URLRequest request, + required URLRequest_ request, required bool isForMainFrame, @Deprecated('Use hasGesture instead') bool? androidHasGesture, @@ -46,113 +60,27 @@ class CreateWindowAction extends NavigationAction { bool? isRedirect, @Deprecated('Use navigationType instead') // ignore: deprecated_member_use_from_same_package - IOSWKNavigationType? iosWKNavigationType, - NavigationType? navigationType, + IOSWKNavigationType_? iosWKNavigationType, + NavigationType_? navigationType, @Deprecated('Use sourceFrame instead') // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo? iosSourceFrame, - FrameInfo? sourceFrame, + IOSWKFrameInfo_? iosSourceFrame, + FrameInfo_? sourceFrame, @Deprecated('Use targetFrame instead') // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo? iosTargetFrame, - FrameInfo? targetFrame}) + IOSWKFrameInfo_? iosTargetFrame, + FrameInfo_? targetFrame}) : super( request: request, isForMainFrame: isForMainFrame, - // ignore: deprecated_member_use_from_same_package - androidHasGesture: hasGesture ?? androidHasGesture, - hasGesture: hasGesture ?? androidHasGesture, - // ignore: deprecated_member_use_from_same_package - androidIsRedirect: isRedirect ?? androidIsRedirect, - isRedirect: isRedirect ?? androidIsRedirect, - // ignore: deprecated_member_use_from_same_package - iosWKNavigationType: - // ignore: deprecated_member_use_from_same_package - IOSWKNavigationType.fromValue(navigationType?.toValue()) ?? - iosWKNavigationType, - navigationType: navigationType ?? - NavigationType.fromValue(iosWKNavigationType?.toValue()), - // ignore: deprecated_member_use_from_same_package - iosSourceFrame: - // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo.fromMap(sourceFrame?.toMap()) ?? iosSourceFrame, - sourceFrame: - sourceFrame ?? FrameInfo.fromMap(iosSourceFrame?.toMap()), - // ignore: deprecated_member_use_from_same_package - iosTargetFrame: - // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo.fromMap(targetFrame?.toMap()) ?? iosTargetFrame, - targetFrame: - targetFrame ?? FrameInfo.fromMap(iosTargetFrame?.toMap())) { - // ignore: deprecated_member_use_from_same_package - this.isDialog = this.isDialog ?? this.androidIsDialog; - this.windowFeatures = this.windowFeatures ?? - // ignore: deprecated_member_use_from_same_package - WindowFeatures.fromMap(this.iosWindowFeatures?.toMap()); - } - - ///Gets a possible [CreateWindowAction] instance from a [Map] value. - static CreateWindowAction? fromMap(Map? map) { - if (map == null) { - return null; - } - return CreateWindowAction( - windowId: map["windowId"], - // ignore: deprecated_member_use_from_same_package - androidIsDialog: map["isDialog"] ?? map["androidIsDialog"], - isDialog: map["isDialog"] ?? map["androidIsDialog"], - // ignore: deprecated_member_use_from_same_package - iosWindowFeatures: IOSWKWindowFeatures.fromMap( - map["windowFeatures"]?.cast()), - windowFeatures: WindowFeatures.fromMap( - map["windowFeatures"]?.cast()), - request: URLRequest.fromMap(map["request"].cast())!, - isForMainFrame: map["isForMainFrame"], - // ignore: deprecated_member_use_from_same_package - androidHasGesture: map["hasGesture"], - hasGesture: map["hasGesture"], - // ignore: deprecated_member_use_from_same_package - androidIsRedirect: map["isRedirect"], - isRedirect: map["isRedirect"], - // ignore: deprecated_member_use_from_same_package - iosWKNavigationType: - // ignore: deprecated_member_use_from_same_package - IOSWKNavigationType.fromValue(map["navigationType"]), - navigationType: NavigationType.fromValue(map["navigationType"]), - // ignore: deprecated_member_use_from_same_package - iosSourceFrame: - // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo.fromMap(map["sourceFrame"]?.cast()), - sourceFrame: - FrameInfo.fromMap(map["sourceFrame"]?.cast()), - // ignore: deprecated_member_use_from_same_package - iosTargetFrame: - // ignore: deprecated_member_use_from_same_package - IOSWKFrameInfo.fromMap(map["targetFrame"]?.cast()), - targetFrame: - FrameInfo.fromMap(map["targetFrame"]?.cast())); - } - - @override - Map toMap() { - var createWindowActionMap = super.toMap(); - createWindowActionMap.addAll({ - "windowId": windowId, - // ignore: deprecated_member_use_from_same_package - "androidIsDialog": isDialog ?? androidIsDialog, - // ignore: deprecated_member_use_from_same_package - "isDialog": isDialog ?? androidIsDialog, - "iosWindowFeatures": - // ignore: deprecated_member_use_from_same_package - windowFeatures?.toMap() ?? iosWindowFeatures?.toMap(), - // ignore: deprecated_member_use_from_same_package - "windowFeatures": windowFeatures?.toMap() ?? iosWindowFeatures?.toMap(), - }); - return createWindowActionMap; - } - - @override - String toString() { - return toMap().toString(); - } + androidHasGesture: androidHasGesture, + hasGesture: hasGesture, + androidIsRedirect: androidIsRedirect, + isRedirect: isRedirect, + iosWKNavigationType: iosWKNavigationType, + navigationType: navigationType, + iosSourceFrame: iosSourceFrame, + sourceFrame: sourceFrame, + iosTargetFrame: iosTargetFrame, + targetFrame: targetFrame); } \ No newline at end of file diff --git a/lib/src/types/create_window_action.g.dart b/lib/src/types/create_window_action.g.dart new file mode 100644 index 00000000..d1a4ecdc --- /dev/null +++ b/lib/src/types/create_window_action.g.dart @@ -0,0 +1,140 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'create_window_action.dart'; + +// ************************************************************************** +// ExchangeableObjectGenerator +// ************************************************************************** + +///Class that represents the navigation request used by the [WebView.onCreateWindow] event. +class CreateWindowAction extends NavigationAction { + ///The window id. Used by [WebView] to create a new WebView. + int windowId; + + ///Use [isDialog] instead. + @Deprecated('Use isDialog instead') + bool? androidIsDialog; + + ///Indicates if the new window should be a dialog, rather than a full-size window. + /// + ///**Supported Platforms/Implementations**: + ///- Android native WebView + bool? isDialog; + + ///Use [windowFeatures] instead. + @Deprecated('Use windowFeatures instead') + IOSWKWindowFeatures? iosWindowFeatures; + + ///Window features requested by the webpage. + /// + ///**Supported Platforms/Implementations**: + ///- iOS ([Official API - WKWindowFeatures](https://developer.apple.com/documentation/webkit/wkwindowfeatures)) + WindowFeatures? windowFeatures; + CreateWindowAction( + {required this.windowId, + @Deprecated('Use isDialog instead') + this.androidIsDialog, + this.isDialog, + @Deprecated('Use windowFeatures instead') + this.iosWindowFeatures, + this.windowFeatures, + required URLRequest request, + required bool isForMainFrame, + @Deprecated('Use hasGesture instead') + bool? androidHasGesture, + bool? hasGesture, + @Deprecated('Use isRedirect instead') + bool? androidIsRedirect, + bool? isRedirect, + @Deprecated('Use navigationType instead') + IOSWKNavigationType? iosWKNavigationType, + NavigationType? navigationType, + @Deprecated('Use sourceFrame instead') + IOSWKFrameInfo? iosSourceFrame, + FrameInfo? sourceFrame, + @Deprecated('Use targetFrame instead') + IOSWKFrameInfo? iosTargetFrame, + FrameInfo? targetFrame, + bool? shouldPerformDownload}) + : super( + request: request, + isForMainFrame: isForMainFrame, + androidHasGesture: androidHasGesture, + hasGesture: hasGesture, + androidIsRedirect: androidIsRedirect, + isRedirect: isRedirect, + iosWKNavigationType: iosWKNavigationType, + navigationType: navigationType, + iosSourceFrame: iosSourceFrame, + sourceFrame: sourceFrame, + iosTargetFrame: iosTargetFrame, + targetFrame: targetFrame, + shouldPerformDownload: shouldPerformDownload) { + isDialog = isDialog ?? androidIsDialog; + windowFeatures = + windowFeatures ?? WindowFeatures.fromMap(iosWindowFeatures?.toMap()); + } + + ///Gets a possible [CreateWindowAction] instance from a [Map] value. + static CreateWindowAction? fromMap(Map? map) { + if (map == null) { + return null; + } + final instance = CreateWindowAction( + request: URLRequest.fromMap(map['request']?.cast())!, + isForMainFrame: map['isForMainFrame'], + windowId: map['windowId'], + ); + instance.androidHasGesture = map['hasGesture']; + instance.hasGesture = map['hasGesture']; + instance.androidIsRedirect = map['isRedirect']; + instance.isRedirect = map['isRedirect']; + instance.iosWKNavigationType = + IOSWKNavigationType.fromNativeValue(map['navigationType']); + instance.navigationType = + NavigationType.fromNativeValue(map['navigationType']); + instance.iosSourceFrame = + IOSWKFrameInfo.fromMap(map['sourceFrame']?.cast()); + instance.sourceFrame = + FrameInfo.fromMap(map['sourceFrame']?.cast()); + instance.iosTargetFrame = + IOSWKFrameInfo.fromMap(map['targetFrame']?.cast()); + instance.targetFrame = + FrameInfo.fromMap(map['targetFrame']?.cast()); + instance.shouldPerformDownload = map['shouldPerformDownload']; + instance.androidIsDialog = map['isDialog']; + instance.isDialog = map['isDialog']; + instance.iosWindowFeatures = IOSWKWindowFeatures.fromMap( + map['windowFeatures']?.cast()); + instance.windowFeatures = + WindowFeatures.fromMap(map['windowFeatures']?.cast()); + return instance; + } + + ///Converts instance to a map. + Map toMap() { + return { + "request": request.toMap(), + "isForMainFrame": isForMainFrame, + "hasGesture": hasGesture, + "isRedirect": isRedirect, + "navigationType": navigationType?.toNativeValue(), + "sourceFrame": sourceFrame?.toMap(), + "targetFrame": targetFrame?.toMap(), + "shouldPerformDownload": shouldPerformDownload, + "windowId": windowId, + "isDialog": isDialog, + "windowFeatures": windowFeatures?.toMap(), + }; + } + + ///Converts instance to a map. + Map toJson() { + return toMap(); + } + + @override + String toString() { + return 'CreateWindowAction{request: $request, isForMainFrame: $isForMainFrame, hasGesture: $hasGesture, isRedirect: $isRedirect, navigationType: $navigationType, sourceFrame: $sourceFrame, targetFrame: $targetFrame, shouldPerformDownload: $shouldPerformDownload, windowId: $windowId, isDialog: $isDialog, windowFeatures: $windowFeatures}'; + } +} diff --git a/lib/src/types/cross_origin.dart b/lib/src/types/cross_origin.dart index a24a3248..b0084dcd 100644 --- a/lib/src/types/cross_origin.dart +++ b/lib/src/types/cross_origin.dart @@ -1,47 +1,22 @@ +import 'package:flutter_inappwebview_internal_annotations/flutter_inappwebview_internal_annotations.dart'; + import 'script_html_tag_attributes.dart'; import 'css_link_html_tag_attributes.dart'; +part 'cross_origin.g.dart'; + ///Class that represents the `crossorigin` content attribute on media elements, which is a CORS settings attribute. ///It could be used with [ScriptHtmlTagAttributes] and [CSSLinkHtmlTagAttributes] ///when fetching a resource `` or a ` \ No newline at end of file diff --git a/ios/Classes/InAppWebView/InAppWebView.swift b/ios/Classes/InAppWebView/InAppWebView.swift index 5425b20f..32c01fd9 100755 --- a/ios/Classes/InAppWebView/InAppWebView.swift +++ b/ios/Classes/InAppWebView/InAppWebView.swift @@ -1527,7 +1527,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, } var result: [String: Any] = [:] - result["history"] = history + result["list"] = history result["currentIndex"] = currentIndex return result; diff --git a/ios/Classes/PluginScriptsJS/InterceptAjaxRequestJS.swift b/ios/Classes/PluginScriptsJS/InterceptAjaxRequestJS.swift index 4ec05183..b5d3a54f 100644 --- a/ios/Classes/PluginScriptsJS/InterceptAjaxRequestJS.swift +++ b/ios/Classes/PluginScriptsJS/InterceptAjaxRequestJS.swift @@ -197,7 +197,7 @@ let INTERCEPT_AJAX_REQUEST_JS_SOURCE = """ }; window.\(JAVASCRIPT_BRIDGE_NAME).callHandler('shouldInterceptAjaxRequest', ajaxRequest).then(function(result) { if (result != null) { - switch (result.action) { + switch (result) { case 0: self.abort(); return; diff --git a/lib/src/in_app_webview/in_app_webview_controller.dart b/lib/src/in_app_webview/in_app_webview_controller.dart index defde8f2..000e3863 100644 --- a/lib/src/in_app_webview/in_app_webview_controller.dart +++ b/lib/src/in_app_webview/in_app_webview_controller.dart @@ -1228,11 +1228,9 @@ class InAppWebViewController { AjaxRequest request = AjaxRequest.fromMap(arguments)!; if (_webview != null && _webview!.onAjaxReadyStateChange != null) - return jsonEncode( - await _webview!.onAjaxReadyStateChange!(this, request)); + return (await _webview!.onAjaxReadyStateChange!(this, request))?.toNativeValue(); else - return jsonEncode( - await _inAppBrowser!.onAjaxReadyStateChange(request)); + return (await _inAppBrowser!.onAjaxReadyStateChange(request))?.toNativeValue(); } return null; case "onAjaxProgress": @@ -1242,10 +1240,9 @@ class InAppWebViewController { AjaxRequest request = AjaxRequest.fromMap(arguments)!; if (_webview != null && _webview!.onAjaxProgress != null) - return jsonEncode( - await _webview!.onAjaxProgress!(this, request)); + return (await _webview!.onAjaxProgress!(this, request))?.toNativeValue(); else - return jsonEncode(await _inAppBrowser!.onAjaxProgress(request)); + return (await _inAppBrowser!.onAjaxProgress(request))?.toNativeValue(); } return null; case "shouldInterceptFetchRequest": diff --git a/lib/src/types/client_cert_challenge.g.dart b/lib/src/types/client_cert_challenge.g.dart index 33fbfe5e..e73d462d 100644 --- a/lib/src/types/client_cert_challenge.g.dart +++ b/lib/src/types/client_cert_challenge.g.dart @@ -47,10 +47,10 @@ class ClientCertChallenge extends URLAuthenticationChallenge { final instance = ClientCertChallenge( protectionSpace: URLProtectionSpace.fromMap( map['protectionSpace']?.cast())!, - androidPrincipals: map['principals'], - principals: map['principals'], - androidKeyTypes: map['keyTypes'], - keyTypes: map['keyTypes'], + androidPrincipals: map['principals']?.cast(), + principals: map['principals']?.cast(), + androidKeyTypes: map['keyTypes']?.cast(), + keyTypes: map['keyTypes']?.cast(), ); return instance; } diff --git a/lib/src/types/meta_tag.g.dart b/lib/src/types/meta_tag.g.dart index 1884e6f1..8ba379c4 100644 --- a/lib/src/types/meta_tag.g.dart +++ b/lib/src/types/meta_tag.g.dart @@ -26,8 +26,10 @@ class MetaTag { final instance = MetaTag( name: map['name'], content: map['content'], - attrs: map['attrs'] - ?.map((e) => MetaTagAttribute.fromMap(e?.cast())!), + attrs: map['attrs'] != null + ? List.from(map['attrs'].map( + (e) => MetaTagAttribute.fromMap(e?.cast())!)) + : null, ); return instance; } diff --git a/lib/src/types/permission_request.g.dart b/lib/src/types/permission_request.g.dart index e2ec7018..f20d606c 100644 --- a/lib/src/types/permission_request.g.dart +++ b/lib/src/types/permission_request.g.dart @@ -31,8 +31,8 @@ class PermissionRequest { origin: Uri.parse(map['origin']), frame: FrameInfo.fromMap(map['frame']?.cast()), ); - instance.resources = - map['resources'].map((e) => PermissionResourceType.fromNativeValue(e)!); + instance.resources = List.from(map['resources'] + .map((e) => PermissionResourceType.fromNativeValue(e)!)); return instance; } diff --git a/lib/src/types/permission_response.g.dart b/lib/src/types/permission_response.g.dart index 0826d978..094d09ec 100644 --- a/lib/src/types/permission_response.g.dart +++ b/lib/src/types/permission_response.g.dart @@ -24,8 +24,8 @@ class PermissionResponse { return null; } final instance = PermissionResponse(); - instance.resources = - map['resources'].map((e) => PermissionResourceType.fromNativeValue(e)!); + instance.resources = List.from(map['resources'] + .map((e) => PermissionResourceType.fromNativeValue(e)!)); instance.action = PermissionResponseAction.fromNativeValue(map['action']); return instance; } @@ -68,7 +68,7 @@ class PermissionRequestResponse { return null; } final instance = PermissionRequestResponse(); - instance.resources = map['resources']; + instance.resources = map['resources'].cast(); instance.action = PermissionRequestResponseAction.fromNativeValue(map['action']); return instance; diff --git a/lib/src/types/url_protection_space_http_auth_credentials.g.dart b/lib/src/types/url_protection_space_http_auth_credentials.g.dart index f00da78c..588dfa00 100644 --- a/lib/src/types/url_protection_space_http_auth_credentials.g.dart +++ b/lib/src/types/url_protection_space_http_auth_credentials.g.dart @@ -26,8 +26,10 @@ class URLProtectionSpaceHttpAuthCredentials { final instance = URLProtectionSpaceHttpAuthCredentials( protectionSpace: URLProtectionSpace.fromMap( map['protectionSpace']?.cast()), - credentials: map['credentials'] - ?.map((e) => URLCredential.fromMap(e?.cast())!), + credentials: map['credentials'] != null + ? List.from(map['credentials'] + .map((e) => URLCredential.fromMap(e?.cast())!)) + : null, ); return instance; } diff --git a/lib/src/types/web_history.g.dart b/lib/src/types/web_history.g.dart index b2ddb8db..67071aeb 100644 --- a/lib/src/types/web_history.g.dart +++ b/lib/src/types/web_history.g.dart @@ -21,8 +21,10 @@ class WebHistory { return null; } final instance = WebHistory( - list: map['list'] - ?.map((e) => WebHistoryItem.fromMap(e?.cast())!), + list: map['list'] != null + ? List.from(map['list'] + .map((e) => WebHistoryItem.fromMap(e?.cast())!)) + : null, currentIndex: map['currentIndex'], ); return instance; diff --git a/lib/src/types/website_data_record.g.dart b/lib/src/types/website_data_record.g.dart index 8ba3a35e..88cc450b 100644 --- a/lib/src/types/website_data_record.g.dart +++ b/lib/src/types/website_data_record.g.dart @@ -22,9 +22,10 @@ class WebsiteDataRecord { } final instance = WebsiteDataRecord( displayName: map['displayName'], - dataTypes: map['dataTypes'] - ?.map((e) => WebsiteDataType.fromNativeValue(e)!) - .toSet(), + dataTypes: map['dataTypes'] != null + ? Set.from( + map['dataTypes'].map((e) => WebsiteDataType.fromNativeValue(e)!)) + : null, ); return instance; } @@ -69,9 +70,10 @@ class IOSWKWebsiteDataRecord { } final instance = IOSWKWebsiteDataRecord( displayName: map['displayName'], - dataTypes: map['dataTypes'] - ?.map((e) => IOSWKWebsiteDataType.fromNativeValue(e)!) - .toSet(), + dataTypes: map['dataTypes'] != null + ? Set.from(map['dataTypes'] + .map((e) => IOSWKWebsiteDataType.fromNativeValue(e)!)) + : null, ); return instance; } diff --git a/test_node_server/index.js b/test_node_server/index.js index 602c7244..559941f9 100755 --- a/test_node_server/index.js +++ b/test_node_server/index.js @@ -10,13 +10,14 @@ // Conversion of client1-crt.pem to certificate.pfx: https://stackoverflow.com/a/38408666/4637638 // - openssl pkcs12 -export -out certificate.pfx -inkey client1-key.pem -in client1-crt.pem -certfile ca-crt.pem // - Overwrite certificate.pfx to example/test_assets/certificate.pfx -const express = require('express') -const https = require('https') -const cors = require('cors') -const auth = require('basic-auth') -const app = express() -const appHttps = express() -const appAuthBasic = express() +const express = require('express'); +const http = require('http'); +const https = require('https'); +const cors = require('cors'); +const auth = require('basic-auth'); +const app = express(); +const appHttps = express(); +const appAuthBasic = express(); const fs = require('fs') const path = require('path') const bodyParser = require('body-parser'); @@ -207,3 +208,21 @@ app.get("/test-download-file", (req, res) => { }) app.listen(8082) + +// Proxy server +http.createServer(function (req, res) { + res.setHeader('Content-type', 'text/html'); + res.write(` + + + + +

Proxy Works

+

${req.url}

+

${req.method}

+

${JSON.stringify(req.headers)}

+ + + `); + res.end(); +}).listen(8083); \ No newline at end of file diff --git a/test_node_server/package-lock.json b/test_node_server/package-lock.json index 295ca7b9..feab47d6 100755 --- a/test_node_server/package-lock.json +++ b/test_node_server/package-lock.json @@ -1,8 +1,958 @@ { "name": "node_auth_basic", "version": "1.0.0", - "lockfileVersion": 1, + "lockfileVersion": 2, "requires": true, + "packages": { + "": { + "name": "node_auth_basic", + "version": "1.0.0", + "license": "ISC", + "dependencies": { + "basic-auth": "latest", + "body-parser": "^1.20.0", + "cors": "^2.8.5", + "express": "latest", + "https": "latest", + "multiparty": "^4.2.3" + } + }, + "node_modules/accepts": { + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", + "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", + "dependencies": { + "mime-types": "~2.1.34", + "negotiator": "0.6.3" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/accepts/node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/accepts/node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" + }, + "node_modules/basic-auth": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", + "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", + "dependencies": { + "safe-buffer": "5.1.2" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/body-parser": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz", + "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==", + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.10.3", + "raw-body": "2.5.1", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/call-bind": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", + "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", + "dependencies": { + "function-bind": "^1.1.1", + "get-intrinsic": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/content-disposition": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", + "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", + "dependencies": { + "safe-buffer": "5.2.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/content-disposition/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/content-type": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", + "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", + "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" + }, + "node_modules/cors": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", + "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", + "dependencies": { + "object-assign": "^4", + "vary": "^1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + }, + "node_modules/encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + }, + "node_modules/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/express": { + "version": "4.18.1", + "resolved": "https://registry.npmjs.org/express/-/express-4.18.1.tgz", + "integrity": "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==", + "dependencies": { + "accepts": "~1.3.8", + "array-flatten": "1.1.1", + "body-parser": "1.20.0", + "content-disposition": "0.5.4", + "content-type": "~1.0.4", + "cookie": "0.5.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "2.0.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "1.2.0", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.7", + "qs": "6.10.3", + "range-parser": "~1.2.1", + "safe-buffer": "5.2.1", + "send": "0.18.0", + "serve-static": "1.15.0", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/express/node_modules/body-parser": { + "version": "1.20.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz", + "integrity": "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==", + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.10.3", + "raw-body": "2.5.1", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/express/node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "node_modules/express/node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/qs": { + "version": "6.10.3", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz", + "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==", + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/express/node_modules/raw-body": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", + "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/express/node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" + }, + "node_modules/express/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/express/node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/finalhandler": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", + "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "statuses": "2.0.1", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/finalhandler/node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/finalhandler/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "node_modules/get-intrinsic": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", + "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", + "dependencies": { + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dependencies": { + "function-bind": "^1.1.1" + }, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/https": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https/-/https-1.0.0.tgz", + "integrity": "sha1-PDfHrhqO65ZpBKKtHpdaGUt+06Q=" + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" + }, + "node_modules/methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/mime-db": { + "version": "1.44.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", + "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.27", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", + "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", + "dependencies": { + "mime-db": "1.44.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + }, + "node_modules/multiparty": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/multiparty/-/multiparty-4.2.3.tgz", + "integrity": "sha512-Ak6EUJZuhGS8hJ3c2fY6UW5MbkGUPMBEGd13djUzoY/BHqV/gTuFWtC6IuVA7A2+v3yjBS6c4or50xhzTQZImQ==", + "dependencies": { + "http-errors": "~1.8.1", + "safe-buffer": "5.2.1", + "uid-safe": "2.1.5" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/multiparty/node_modules/depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/multiparty/node_modules/http-errors": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.1.tgz", + "integrity": "sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==", + "dependencies": { + "depd": "~1.1.2", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/multiparty/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/multiparty/node_modules/statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/negotiator": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", + "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", + "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" + }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/qs": { + "version": "6.10.3", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz", + "integrity": "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==", + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/random-bytes": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", + "integrity": "sha512-iv7LhNVO047HzYR3InF6pUcUsPQiHTM1Qal51DcGSuZFBil1aBBWG5eHPNek7bvILMaYJ/8RU1e8w1AMdHmLQQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", + "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" + }, + "node_modules/send": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", + "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", + "dependencies": { + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "2.4.1", + "range-parser": "~1.2.1", + "statuses": "2.0.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/send/node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/send/node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/send/node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "node_modules/send/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" + }, + "node_modules/send/node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/send/node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" + }, + "node_modules/send/node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/send/node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/serve-static": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", + "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", + "dependencies": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.18.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" + }, + "node_modules/side-channel": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", + "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "dependencies": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/uid-safe": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", + "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", + "dependencies": { + "random-bytes": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", + "engines": { + "node": ">= 0.8" + } + } + }, "dependencies": { "accepts": { "version": "1.3.8", From fd17bd4624bc17bed027f192677cf8d624ad554a Mon Sep 17 00:00:00 2001 From: Lorenzo Pichilli Date: Thu, 6 Oct 2022 16:43:19 +0200 Subject: [PATCH 9/9] fixed ios tests --- .../in_app_webview/reload.dart | 4 +++- .../integration_test/webview_flutter_test.dart | 8 ++++---- .../ios/Flutter/flutter_export_environment.sh | 5 +++-- .../FlutterWebViewController.swift | 18 ++++++++++-------- .../InAppWebView/WebViewChannelDelegate.swift | 2 +- ios/Classes/Types/PermissionResponse.swift | 6 +++--- 6 files changed, 24 insertions(+), 19 deletions(-) diff --git a/example/integration_test/in_app_webview/reload.dart b/example/integration_test/in_app_webview/reload.dart index 7029e878..1248ec31 100644 --- a/example/integration_test/in_app_webview/reload.dart +++ b/example/integration_test/in_app_webview/reload.dart @@ -40,7 +40,9 @@ void reload() { controllerCompleter.complete(controller); }, onLoadStop: (controller, url) { - pageLoaded.complete(); + if (!pageLoaded.isCompleted) { + pageLoaded.complete(); + } }, ), ), diff --git a/example/integration_test/webview_flutter_test.dart b/example/integration_test/webview_flutter_test.dart index 1b0e5a52..00016670 100644 --- a/example/integration_test/webview_flutter_test.dart +++ b/example/integration_test/webview_flutter_test.dart @@ -19,13 +19,13 @@ void main() { } WebView.debugLoggingSettings.usePrint = true; - WebView.debugLoggingSettings.maxLogMessageLength = -1; + WebView.debugLoggingSettings.maxLogMessageLength = 7000; InAppBrowser.debugLoggingSettings.usePrint = true; - InAppBrowser.debugLoggingSettings.maxLogMessageLength = -1; + InAppBrowser.debugLoggingSettings.maxLogMessageLength = 7000; ChromeSafariBrowser.debugLoggingSettings.usePrint = true; - ChromeSafariBrowser.debugLoggingSettings.maxLogMessageLength = -1; + ChromeSafariBrowser.debugLoggingSettings.maxLogMessageLength = 7000; WebAuthenticationSession.debugLoggingSettings.usePrint = true; - WebAuthenticationSession.debugLoggingSettings.maxLogMessageLength = -1; + WebAuthenticationSession.debugLoggingSettings.maxLogMessageLength = 7000; in_app_webview_tests.main(); service_worker_controller_tests.main(); diff --git a/example/ios/Flutter/flutter_export_environment.sh b/example/ios/Flutter/flutter_export_environment.sh index fae63896..03bce7c9 100755 --- a/example/ios/Flutter/flutter_export_environment.sh +++ b/example/ios/Flutter/flutter_export_environment.sh @@ -3,11 +3,12 @@ export "FLUTTER_ROOT=/Users/lorenzopichilli/fvm/versions/2.10.4" export "FLUTTER_APPLICATION_PATH=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example" export "COCOAPODS_PARALLEL_CODE_SIGN=true" -export "FLUTTER_TARGET=lib/main.dart" +export "FLUTTER_TARGET=integration_test/webview_flutter_test.dart" export "FLUTTER_BUILD_DIR=build" export "FLUTTER_BUILD_NAME=1.0.0" export "FLUTTER_BUILD_NUMBER=1" +export "DART_DEFINES=RkxVVFRFUl9XRUJfQVVUT19ERVRFQ1Q9dHJ1ZQ==" export "DART_OBFUSCATION=false" export "TRACK_WIDGET_CREATION=true" export "TREE_SHAKE_ICONS=false" -export "PACKAGE_CONFIG=.dart_tool/package_config.json" +export "PACKAGE_CONFIG=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example/.dart_tool/package_config.json" diff --git a/ios/Classes/InAppWebView/FlutterWebViewController.swift b/ios/Classes/InAppWebView/FlutterWebViewController.swift index a8e94268..4fd4b76b 100755 --- a/ios/Classes/InAppWebView/FlutterWebViewController.swift +++ b/ios/Classes/InAppWebView/FlutterWebViewController.swift @@ -95,7 +95,7 @@ public class FlutterWebViewController: NSObject, FlutterPlatformView, Disposable let windowId = params["windowId"] as? Int64 let initialUrlRequest = params["initialUrlRequest"] as? [String: Any?] let initialFile = params["initialFile"] as? String - let initialData = params["initialData"] as? [String: String] + let initialData = params["initialData"] as? [String: String?] if windowId == nil { if #available(iOS 11.0, *) { @@ -131,7 +131,7 @@ public class FlutterWebViewController: NSObject, FlutterPlatformView, Disposable } } - func load(initialUrlRequest: [String:Any?]?, initialFile: String?, initialData: [String: String]?) { + func load(initialUrlRequest: [String:Any?]?, initialFile: String?, initialData: [String: String?]?) { guard let webView = webView() else { return } @@ -144,11 +144,9 @@ public class FlutterWebViewController: NSObject, FlutterPlatformView, Disposable dump(error) } } - else if let initialData = initialData { - let data = initialData["data"]! - let mimeType = initialData["mimeType"]! - let encoding = initialData["encoding"]! - let baseUrl = URL(string: initialData["baseUrl"] ?? "about:blank")! + else if let initialData = initialData, let data = initialData["data"]!, + let mimeType = initialData["mimeType"]!, let encoding = initialData["encoding"]!, + let baseUrl = URL(string: initialData["baseUrl"]! ?? "about:blank") { var allowingReadAccessToURL: URL? = nil if let allowingReadAccessTo = webView.settings?.allowingReadAccessTo, baseUrl.scheme == "file" { allowingReadAccessToURL = URL(string: allowingReadAccessTo) @@ -156,7 +154,11 @@ public class FlutterWebViewController: NSObject, FlutterPlatformView, Disposable allowingReadAccessToURL = nil } } - webView.loadData(data: data, mimeType: mimeType, encoding: encoding, baseUrl: baseUrl, allowingReadAccessTo: allowingReadAccessToURL) + webView.loadData(data: data, + mimeType: mimeType, + encoding: encoding, + baseUrl: baseUrl, + allowingReadAccessTo: allowingReadAccessToURL) } else if let initialUrlRequest = initialUrlRequest { let urlRequest = URLRequest.init(fromPluginMap: initialUrlRequest) diff --git a/ios/Classes/InAppWebView/WebViewChannelDelegate.swift b/ios/Classes/InAppWebView/WebViewChannelDelegate.swift index 551e2b58..c0efe12f 100644 --- a/ios/Classes/InAppWebView/WebViewChannelDelegate.swift +++ b/ios/Classes/InAppWebView/WebViewChannelDelegate.swift @@ -760,7 +760,7 @@ public class WebViewChannelDelegate : ChannelDelegate { "defaultValue": defaultValue, "isMainFrame": isMainFrame ] - channel?.invokeMethod("onJsConfirm", arguments: arguments, callback: callback) + channel?.invokeMethod("onJsPrompt", arguments: arguments, callback: callback) } public class CreateWindowCallback : BaseCallbackResult { diff --git a/ios/Classes/Types/PermissionResponse.swift b/ios/Classes/Types/PermissionResponse.swift index 0032aed6..7971f95e 100644 --- a/ios/Classes/Types/PermissionResponse.swift +++ b/ios/Classes/Types/PermissionResponse.swift @@ -8,10 +8,10 @@ import Foundation public class PermissionResponse : NSObject { - var resources: [String] + var resources: [Any] var action: Int? - public init(resources: [String], action: Int? = nil) { + public init(resources: [Any], action: Int? = nil) { self.resources = resources self.action = action } @@ -20,7 +20,7 @@ public class PermissionResponse : NSObject { guard let map = map else { return nil } - let resources = map["resources"] as! [String] + let resources = map["resources"] as! [Any] let action = map["action"] as? Int return PermissionResponse(resources: resources, action: action) }