diff --git a/packages/battery_plus/battery_plus_aurora/.gitignore b/packages/battery_plus/battery_plus_aurora/.gitignore new file mode 100644 index 0000000..96486fd --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/.gitignore @@ -0,0 +1,30 @@ +# Miscellaneous +*.class +*.log +*.pyc +*.swp +.DS_Store +.atom/ +.buildlog/ +.history +.svn/ +migrate_working_dir/ + +# IntelliJ related +*.iml +*.ipr +*.iws +.idea/ + +# The .vscode folder contains launch configuration and tasks you configure in +# VS Code which you may wish to be included in version control, so this line +# is commented out by default. +#.vscode/ + +# Flutter/Dart/Pub related +# Libraries should not include pubspec.lock, per https://dart.dev/guides/libraries/private-files#pubspeclock. +/pubspec.lock +**/doc/api/ +.dart_tool/ +.packages +build/ diff --git a/packages/battery_plus/battery_plus_aurora/README.md b/packages/battery_plus/battery_plus_aurora/README.md new file mode 100644 index 0000000..6cfc057 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/README.md @@ -0,0 +1,39 @@ +# battery_plus_aurora + +The Aurora implementation of [`battery_plus`](https://pub.dev/packages/battery_plus). + +## Usage + +This package is not an _endorsed_ implementation of `battery_plus`. +Therefore, you have to include `battery_plus_aurora` alongside `battery_plus` as dependencies in your `pubspec.yaml` file. + +**pubspec.yaml** + +```yaml +dependencies: + battery_plus: ^4.0.1 + battery_plus_aurora: + path: # path to folder with plugin +``` + +***.dart** + +```dart +// Import package +import 'package:battery_plus/battery_plus.dart'; + +// Instantiate it +var battery = Battery(); + +// Get current battery level +final batteryLevel = await _battery.batteryLevel; +// Get current battery state +final batteryState = await _battery.batteryState; +// Check is enable SaveMode +final isInBatterySaveMode = await _battery.isInBatterySaveMode; + +// Be informed when the state (full, charging, discharging) changes +_battery.onBatteryStateChanged.listen((BatteryState state) { + debugPrint(state.toString()); +}); +``` diff --git a/packages/battery_plus/battery_plus_aurora/analysis_options.yaml b/packages/battery_plus/battery_plus_aurora/analysis_options.yaml new file mode 100644 index 0000000..566c597 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/analysis_options.yaml @@ -0,0 +1,4 @@ +# Copyright (c) 2023. Open Mobile Platform LLC. +# License: Proprietary. + +include: package:flutter_lints/flutter.yaml diff --git a/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.request.xml b/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.request.xml new file mode 100644 index 0000000..5de3ec4 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.request.xml @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + diff --git a/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.signal.xml b/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.signal.xml new file mode 100644 index 0000000..0d85476 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/data/com.nokia.mce.signal.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + + + diff --git a/packages/battery_plus/battery_plus_aurora/data/preview.png b/packages/battery_plus/battery_plus_aurora/data/preview.png new file mode 100644 index 0000000..924f871 Binary files /dev/null and b/packages/battery_plus/battery_plus_aurora/data/preview.png differ diff --git a/packages/battery_plus/battery_plus_aurora/example/.gitignore b/packages/battery_plus/battery_plus_aurora/example/.gitignore new file mode 100644 index 0000000..3db3823 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/.gitignore @@ -0,0 +1,47 @@ +# Miscellaneous +*.class +*.log +*.pyc +*.swp +.DS_Store +.atom/ +.buildlog/ +.history +.svn/ +migrate_working_dir/ + +# IntelliJ related +*.iml +*.ipr +*.iws +.idea/ + +# The .vscode folder contains launch configuration and tasks you configure in +# VS Code which you may wish to be included in version control, so this line +# is commented out by default. +#.vscode/ + +# Flutter/Dart/Pub related +**/doc/api/ +**/ios/Flutter/.last_build_id +.dart_tool/ +.flutter-plugins +.flutter-plugins-dependencies +.packages +.pub-cache/ +.pub/ +/build/ + +# Symbolication related +app.*.symbols + +# Obfuscation related +app.*.map.json + +# Android Studio will place build artifacts here +/android/app/debug +/android/app/profile +/android/app/release + +# Aurora generated +/aurora/flutter diff --git a/packages/battery_plus/battery_plus_aurora/example/README.md b/packages/battery_plus/battery_plus_aurora/example/README.md new file mode 100644 index 0000000..9110259 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/README.md @@ -0,0 +1,21 @@ +# battery_plus_aurora_example + +Demonstrates how to use the battery_plus_aurora plugin. + +## Build + +```shell +# Add an alias if it doesn't already exist +alias flutter-aurora=$HOME/.local/opt/flutter-sdk/bin/flutter +# Get dependencies +flutter-aurora pub get +# Run build +flutter-aurora build aurora --release # [--release|--debug|--profile] +``` + +You can collect, sign, run an example on the device with a script located in the `script/build_example.sh` +More information in `build_example.sh`. + +### Preview example + +![preview.png](../data/preview.png) diff --git a/packages/battery_plus/battery_plus_aurora/example/analysis_options.yaml b/packages/battery_plus/battery_plus_aurora/example/analysis_options.yaml new file mode 100644 index 0000000..566c597 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/analysis_options.yaml @@ -0,0 +1,4 @@ +# Copyright (c) 2023. Open Mobile Platform LLC. +# License: Proprietary. + +include: package:flutter_lints/flutter.yaml diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/.gitignore b/packages/battery_plus/battery_plus_aurora/example/aurora/.gitignore new file mode 100644 index 0000000..d3896c9 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/.gitignore @@ -0,0 +1 @@ +flutter/ephemeral diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/CMakeLists.txt b/packages/battery_plus/battery_plus_aurora/example/aurora/CMakeLists.txt new file mode 100644 index 0000000..048467b --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/CMakeLists.txt @@ -0,0 +1,50 @@ +# Copyright (c) 2023. Open Mobile Platform LLC. +# License: Proprietary. + +cmake_minimum_required(VERSION 3.10) +project(com.example.battery_plus_aurora_example LANGUAGES CXX) + +include(GNUInstallDirs) + +set(BINARY_NAME ${CMAKE_PROJECT_NAME}) +set(FLUTTER_DIR ${CMAKE_CURRENT_SOURCE_DIR}/flutter) + +set(CMAKE_CXX_STANDARD 17) +set(CMAKE_CXX_STANDARD_REQUIRED ON) + +set(CMAKE_CXX_FLAGS "-Wall -Wextra") +set(CMAKE_CXX_FLAGS_RELEASE "-O3") + +set(CMAKE_SKIP_RPATH OFF) +set(CMAKE_INSTALL_RPATH "\$ORIGIN/../share/${BINARY_NAME}/lib") + +find_package(PkgConfig REQUIRED) +pkg_check_modules(FlutterEmbedder REQUIRED IMPORTED_TARGET flutter-embedder) + +add_executable(${BINARY_NAME} main.cpp ${FLUTTER_DIR}/generated_plugin_registrant.cpp) +target_link_libraries(${BINARY_NAME} PRIVATE PkgConfig::FlutterEmbedder) +target_include_directories(${BINARY_NAME} PRIVATE ${FLUTTER_DIR}) + +include(flutter/generated_plugins.cmake) + +set(PACKAGE_INSTALL_DIR ${CMAKE_INSTALL_DATADIR}/${BINARY_NAME}) +set(DESKTOP_INSTALL_DIR ${CMAKE_INSTALL_DATADIR}/applications) +set(ICONS_INSTALL_ROOT_DIR ${CMAKE_INSTALL_DATADIR}/icons/hicolor) + +add_custom_command(TARGET ${BINARY_NAME} POST_BUILD + COMMAND ${CMAKE_COMMAND} -E copy + ${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_LIBDIR}/libflutter-embedder.so + ${PROJECT_BINARY_DIR}/bundle/lib/libflutter-embedder.so) + +install(FILES ${PROJECT_BINARY_DIR}/bundle/icudtl.dat DESTINATION ${PACKAGE_INSTALL_DIR}) +install(DIRECTORY ${PROJECT_BINARY_DIR}/bundle/flutter_assets DESTINATION ${PACKAGE_INSTALL_DIR}) +install(DIRECTORY ${PROJECT_BINARY_DIR}/bundle/lib DESTINATION ${PACKAGE_INSTALL_DIR}) + +install(TARGETS ${BINARY_NAME} RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) +install(FILES desktop/${BINARY_NAME}.desktop DESTINATION ${DESKTOP_INSTALL_DIR}) + +foreach(ICONS_SIZE 86x86 108x108 128x128 172x172) + install(FILES icons/${ICONS_SIZE}.png + RENAME ${BINARY_NAME}.png + DESTINATION ${ICONS_INSTALL_ROOT_DIR}/${ICONS_SIZE}/apps/) +endforeach(ICONS_SIZE) diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/desktop/com.example.battery_plus_aurora_example.desktop b/packages/battery_plus/battery_plus_aurora/example/aurora/desktop/com.example.battery_plus_aurora_example.desktop new file mode 100644 index 0000000..a6aeb93 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/desktop/com.example.battery_plus_aurora_example.desktop @@ -0,0 +1,12 @@ +[Desktop Entry] +Type=Application +Name=battery_plus_aurora_example +Comment=Demonstrates how to use the battery_plus_aurora plugin. +Icon=com.example.battery_plus_aurora_example +Exec=/usr/bin/com.example.battery_plus_aurora_example +X-Nemo-Application-Type=silica-qt5 + +[X-Application] +Permissions= +OrganizationName=com.example +ApplicationName=battery_plus_aurora_example diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/icons/108x108.png b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/108x108.png new file mode 100644 index 0000000..984893d Binary files /dev/null and b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/108x108.png differ diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/icons/128x128.png b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/128x128.png new file mode 100644 index 0000000..2d552ef Binary files /dev/null and b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/128x128.png differ diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/icons/172x172.png b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/172x172.png new file mode 100644 index 0000000..9dc271b Binary files /dev/null and b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/172x172.png differ diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/icons/86x86.png b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/86x86.png new file mode 100644 index 0000000..5923bb1 Binary files /dev/null and b/packages/battery_plus/battery_plus_aurora/example/aurora/icons/86x86.png differ diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/main.cpp b/packages/battery_plus/battery_plus_aurora/example/aurora/main.cpp new file mode 100644 index 0000000..83f2ca8 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/main.cpp @@ -0,0 +1,13 @@ +/* + * Copyright (c) 2023. Open Mobile Platform LLC. + * License: Proprietary. + */ +#include +#include "generated_plugin_registrant.h" + +int main(int argc, char *argv[]) { + Application::Initialize(argc, argv); + RegisterPlugins(); + Application::Launch(); + return 0; +} diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/rpm/com.example.battery_plus_aurora_example.spec b/packages/battery_plus/battery_plus_aurora/example/aurora/rpm/com.example.battery_plus_aurora_example.spec new file mode 100644 index 0000000..a06d8f3 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/rpm/com.example.battery_plus_aurora_example.spec @@ -0,0 +1,31 @@ +%global __provides_exclude_from ^%{_datadir}/%{name}/lib/.*$ +%global __requires_exclude ^lib(dconf|flutter-embedder|maliit-glib|appmanifest-.+|.+_platform_plugin)\\.so.*$ + +Name: com.example.battery_plus_aurora_example +Summary: Demonstrates how to use the battery_plus_aurora plugin. +Version: 0.1.0 +Release: 1 +License: Proprietary +Source0: %{name}-%{version}.tar.zst + +BuildRequires: cmake +BuildRequires: pkgconfig(flutter-embedder) + +%description +%{summary}. + +%prep +%autosetup + +%build +%cmake -DCMAKE_BUILD_TYPE=%{_flutter_build_type} +%make_build + +%install +%make_install + +%files +%{_bindir}/%{name} +%{_datadir}/%{name}/* +%{_datadir}/applications/%{name}.desktop +%{_datadir}/icons/hicolor/*/apps/%{name}.png diff --git a/packages/battery_plus/battery_plus_aurora/example/lib/main.dart b/packages/battery_plus/battery_plus_aurora/example/lib/main.dart new file mode 100644 index 0000000..4d6723f --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/lib/main.dart @@ -0,0 +1,164 @@ +/* + * Copyright (c) 2023. Open Mobile Platform LLC. + * License: Proprietary. + */ +import 'package:flutter/material.dart'; +import 'dart:async'; + +import 'package:battery_plus/battery_plus.dart'; + +void main() { + runApp(const MyApp()); +} + +class MyApp extends StatefulWidget { + const MyApp({super.key}); + + @override + State createState() => _MyAppState(); +} + +class _MyAppState extends State { + final _battery = Battery(); + String? _error; + int? _batteryLevel; + String? _batteryState; + bool? _isInBatterySaveMode; + + @override + void initState() { + super.initState(); + initPlatformState(); + } + + // Platform messages are asynchronous, so we initialize in an async method. + Future initPlatformState() async { + try { + // Get current battery level + final batteryLevel = await _battery.batteryLevel; + // Get current battery state + final batteryState = await _battery.batteryState; + // Check is enable SaveMode + final isInBatterySaveMode = await _battery.isInBatterySaveMode; + + // Be informed when the state (full, charging, discharging) changes + _battery.onBatteryStateChanged.listen((BatteryState state) { + debugPrint(state.toString()); + }); + + setState(() { + _batteryLevel = batteryLevel; + _batteryState = batteryState.name; + _isInBatterySaveMode = isInBatterySaveMode; + }); + } on Exception catch (e) { + setState(() { + _error = e.toString(); + }); + } + } + + @override + Widget build(BuildContext context) { + const textStyleWhite = TextStyle(fontSize: 18, color: Colors.white); + const textStyleTitle = TextStyle(fontSize: 20, color: Colors.black); + const textStylePath = TextStyle(fontSize: 18, color: Colors.black54); + + const spaceMedium = SizedBox(height: 20); + const spaceSmall = SizedBox(height: 10); + + return MaterialApp( + home: Scaffold( + appBar: AppBar( + title: const Text('Example battery_plus'), + ), + body: Stack( + children: [ + // Error message + Visibility( + visible: _error != null, + child: Center( + child: Padding( + padding: const EdgeInsets.all(16), + child: Container( + padding: const EdgeInsets.all(20), + decoration: const BoxDecoration( + color: Colors.redAccent, + borderRadius: BorderRadius.all(Radius.circular(10.0)), + ), + child: Text( + _error ?? '', + style: textStyleWhite, + ), + ), + ), + ), + ), + // List directories path + Visibility( + visible: _error == null, + child: SingleChildScrollView( + child: Padding( + padding: const EdgeInsets.all(16), + child: Center( + child: Column( + children: [ + // Info + Container( + padding: const EdgeInsets.all(20), + decoration: const BoxDecoration( + color: Colors.green, + borderRadius: + BorderRadius.all(Radius.circular(10.0)), + ), + child: const Text( + 'Demo application demonstration implementation of battery_plus', + style: textStyleWhite, + textAlign: TextAlign.center, + ), + ), + const SizedBox(height: 30), + + const Text( + 'Battery Level', + style: textStyleTitle, + ), + spaceSmall, + Text( + "$_batteryLevel%", + style: textStylePath, + ), + + spaceMedium, + const Text( + 'Battery State', + style: textStyleTitle, + ), + spaceSmall, + Text( + _batteryState.toString(), + style: textStylePath, + ), + + spaceMedium, + const Text( + 'Is In Battery SaveMode', + style: textStyleTitle, + ), + spaceSmall, + Text( + _isInBatterySaveMode.toString(), + style: textStylePath, + ), + ], + ), + ), + ), + ), + ), + ], + ), + ), + ); + } +} diff --git a/packages/battery_plus/battery_plus_aurora/example/pubspec.lock b/packages/battery_plus/battery_plus_aurora/example/pubspec.lock new file mode 100644 index 0000000..0c1972b --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/pubspec.lock @@ -0,0 +1,243 @@ +# Generated by pub +# See https://dart.dev/tools/pub/glossary#lockfile +packages: + args: + dependency: transitive + description: + name: args + url: "https://pub.dartlang.org" + source: hosted + version: "2.4.1" + async: + dependency: transitive + description: + name: async + url: "https://pub.dartlang.org" + source: hosted + version: "2.9.0" + battery_plus: + dependency: "direct main" + description: + name: battery_plus + url: "https://pub.dartlang.org" + source: hosted + version: "4.0.1" + battery_plus_aurora: + dependency: "direct main" + description: + path: ".." + relative: true + source: path + version: "0.0.1" + battery_plus_platform_interface: + dependency: transitive + description: + name: battery_plus_platform_interface + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.2" + boolean_selector: + dependency: transitive + description: + name: boolean_selector + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.0" + characters: + dependency: transitive + description: + name: characters + url: "https://pub.dartlang.org" + source: hosted + version: "1.2.1" + clock: + dependency: transitive + description: + name: clock + url: "https://pub.dartlang.org" + source: hosted + version: "1.1.1" + collection: + dependency: transitive + description: + name: collection + url: "https://pub.dartlang.org" + source: hosted + version: "1.16.0" + cupertino_icons: + dependency: "direct main" + description: + name: cupertino_icons + url: "https://pub.dartlang.org" + source: hosted + version: "1.0.5" + dbus: + dependency: transitive + description: + name: dbus + url: "https://pub.dartlang.org" + source: hosted + version: "0.7.8" + fake_async: + dependency: transitive + description: + name: fake_async + url: "https://pub.dartlang.org" + source: hosted + version: "1.3.1" + ffi: + dependency: transitive + description: + name: ffi + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.2" + flutter: + dependency: "direct main" + description: flutter + source: sdk + version: "0.0.0" + flutter_lints: + dependency: "direct dev" + description: + name: flutter_lints + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.1" + flutter_test: + dependency: "direct dev" + description: flutter + source: sdk + version: "0.0.0" + flutter_web_plugins: + dependency: transitive + description: flutter + source: sdk + version: "0.0.0" + js: + dependency: transitive + description: + name: js + url: "https://pub.dartlang.org" + source: hosted + version: "0.6.4" + lints: + dependency: transitive + description: + name: lints + url: "https://pub.dartlang.org" + source: hosted + version: "2.0.1" + matcher: + dependency: transitive + description: + name: matcher + url: "https://pub.dartlang.org" + source: hosted + version: "0.12.12" + material_color_utilities: + dependency: transitive + description: + name: material_color_utilities + url: "https://pub.dartlang.org" + source: hosted + version: "0.1.5" + meta: + dependency: transitive + description: + name: meta + url: "https://pub.dartlang.org" + source: hosted + version: "1.8.0" + path: + dependency: transitive + description: + name: path + url: "https://pub.dartlang.org" + source: hosted + version: "1.8.2" + petitparser: + dependency: transitive + description: + name: petitparser + url: "https://pub.dartlang.org" + source: hosted + version: "5.1.0" + plugin_platform_interface: + dependency: transitive + description: + name: plugin_platform_interface + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.4" + sky_engine: + dependency: transitive + description: flutter + source: sdk + version: "0.0.99" + 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" + 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.1" + test_api: + dependency: transitive + description: + name: test_api + url: "https://pub.dartlang.org" + source: hosted + version: "0.4.12" + upower: + dependency: transitive + description: + name: upower + url: "https://pub.dartlang.org" + source: hosted + version: "0.7.0" + vector_math: + dependency: transitive + description: + name: vector_math + url: "https://pub.dartlang.org" + source: hosted + version: "2.1.2" + xml: + dependency: transitive + description: + name: xml + url: "https://pub.dartlang.org" + source: hosted + version: "6.1.0" +sdks: + dart: ">=2.18.6 <3.0.0" + flutter: ">=3.3.0" diff --git a/packages/battery_plus/battery_plus_aurora/example/pubspec.yaml b/packages/battery_plus/battery_plus_aurora/example/pubspec.yaml new file mode 100644 index 0000000..42def81 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/pubspec.yaml @@ -0,0 +1,26 @@ +# Copyright (c) 2023. Open Mobile Platform LLC. +# License: Proprietary. + +name: battery_plus_aurora_example +description: Demonstrates how to use the battery_plus_aurora plugin. + +publish_to: 'none' + +environment: + sdk: '>=2.18.6 <3.0.0' + +dependencies: + flutter: + sdk: flutter + battery_plus: ^4.0.1 + battery_plus_aurora: + path: ../ + cupertino_icons: ^1.0.2 + +dev_dependencies: + flutter_test: + sdk: flutter + flutter_lints: ^2.0.0 + +flutter: + uses-material-design: true diff --git a/packages/battery_plus/battery_plus_aurora/lib/battery_plus_aurora.dart b/packages/battery_plus/battery_plus_aurora/lib/battery_plus_aurora.dart new file mode 100644 index 0000000..94040d0 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/battery_plus_aurora.dart @@ -0,0 +1,92 @@ +/* + * Copyright (c) 2023. Open Mobile Platform LLC. + * License: Proprietary. + */ +import 'package:battery_plus_aurora/com_nokia_mce_request.dart'; +import 'package:battery_plus_aurora/com_nokia_mce_signal.dart'; +import 'package:dbus/dbus.dart'; +import 'package:battery_plus_platform_interface/battery_plus_platform_interface.dart'; +import 'package:flutter/foundation.dart'; +import 'dart:async' show Stream; +import 'package:async/async.dart' show StreamGroup; + +class BatteryPlusAurora extends BatteryPlatform { + /// Register this dart class as the platform implementation for aurora + static void registerWith() { + if (TargetPlatform.aurora == defaultTargetPlatform) { + BatteryPlatform.instance = BatteryPlusAurora(); + } + } + + /// Returns the current battery level in percent. + @override + Future get batteryLevel async { + final client = DBusClient.system(); + final request = ComNokiaMceRequest(client, 'com.nokia.mce'); + final level = await request.callget_battery_level(); + await client.close(); + return level; + } + + /// Returns true if the device is on battery save mode + @override + Future get isInBatterySaveMode async { + final client = DBusClient.system(); + final request = ComNokiaMceRequest(client, 'com.nokia.mce'); + final state = await request.callget_psm_state(); + await client.close(); + return state; + } + + /// Returns the current battery state in percent. + @override + Future get batteryState async { + final client = DBusClient.system(); + final request = ComNokiaMceRequest(client, 'com.nokia.mce'); + + final level = await request.callget_battery_level(); + final status = await request.callget_charger_state(); + + await client.close(); + + if (level == 100) { + return BatteryState.full; + } else if (status == 'on') { + return BatteryState.charging; + } else { + return BatteryState.discharging; + } + } + + /// Returns a Stream of BatteryState changes. + @override + Stream get onBatteryStateChanged async* { + final client = DBusClient.system(); + final signal = ComNokiaMceSignal(client, 'com.nokia.mce'); + final request = ComNokiaMceRequest(client, 'com.nokia.mce'); + + var steam = StreamGroup.merge([ + signal.battery_status_ind, + signal.charger_state_ind, + ]); + + await for (final event in steam) { + if (event.name == 'battery_status_ind') { + if (event.values.first.toNative() == 'full') { + yield BatteryState.full; + } + } else { + if (event.values.first.toNative() == 'on') { + yield BatteryState.charging; + final level = await request.callget_battery_level(); + if (level == 100) { + yield BatteryState.full; + } + } else { + yield BatteryState.discharging; + } + } + } + await client.close(); + } +} diff --git a/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_request.dart b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_request.dart new file mode 100644 index 0000000..7de2a1d --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_request.dart @@ -0,0 +1,47 @@ +/* + * Copyright (c) 2023. Open Mobile Platform LLC. + * License: Proprietary. + */ +import 'package:dbus/dbus.dart'; + +class ComNokiaMceRequest extends DBusRemoteObject { + ComNokiaMceRequest(DBusClient client, String destination, + {DBusObjectPath path = + const DBusObjectPath.unchecked('/com/nokia/mce/request')}) + : super(client, name: destination, path: path); + + /// Invokes com.nokia.mce.request.get_psm_state() + Future callget_psm_state( + {bool noAutoStart = false, + bool allowInteractiveAuthorization = false}) async { + var result = await callMethod('com.nokia.mce.request', 'get_psm_state', [], + replySignature: DBusSignature('b'), + noAutoStart: noAutoStart, + allowInteractiveAuthorization: allowInteractiveAuthorization); + return result.returnValues[0].asBoolean(); + } + + /// Invokes com.nokia.mce.request.get_battery_level() + Future callget_battery_level( + {bool noAutoStart = false, + bool allowInteractiveAuthorization = false}) async { + var result = await callMethod( + 'com.nokia.mce.request', 'get_battery_level', [], + replySignature: DBusSignature('i'), + noAutoStart: noAutoStart, + allowInteractiveAuthorization: allowInteractiveAuthorization); + return result.returnValues[0].asInt32(); + } + + /// Invokes com.nokia.mce.request.get_charger_state() + Future callget_charger_state( + {bool noAutoStart = false, + bool allowInteractiveAuthorization = false}) async { + var result = await callMethod( + 'com.nokia.mce.request', 'get_charger_state', [], + replySignature: DBusSignature('s'), + noAutoStart: noAutoStart, + allowInteractiveAuthorization: allowInteractiveAuthorization); + return result.returnValues[0].asString(); + } +} diff --git a/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_signal.dart b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_signal.dart new file mode 100644 index 0000000..11d4cab --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_signal.dart @@ -0,0 +1,60 @@ +/* + * Copyright (c) 2023. Open Mobile Platform LLC. + * License: Proprietary. + */ +import 'package:dbus/dbus.dart'; + +/// Signal data for com.nokia.mce.signal.battery_status_ind. +class ComNokiaMceSignalbattery_status_ind extends DBusSignal { + String get battery_status => values[0].asString(); + + ComNokiaMceSignalbattery_status_ind(DBusSignal signal) + : super( + sender: signal.sender, + path: signal.path, + interface: signal.interface, + name: signal.name, + values: signal.values); +} + +/// Signal data for com.nokia.mce.signal.charger_state_ind. +class ComNokiaMceSignalcharger_state_ind extends DBusSignal { + String get charger_state => values[0].asString(); + + ComNokiaMceSignalcharger_state_ind(DBusSignal signal) + : super( + sender: signal.sender, + path: signal.path, + interface: signal.interface, + name: signal.name, + values: signal.values); +} + +class ComNokiaMceSignal extends DBusRemoteObject { + /// Stream of com.nokia.mce.signal.battery_status_ind signals. + late final Stream battery_status_ind; + + /// Stream of com.nokia.mce.signal.charger_state_ind signals. + late final Stream charger_state_ind; + + ComNokiaMceSignal(DBusClient client, String destination, + {DBusObjectPath path = + const DBusObjectPath.unchecked('/com/nokia/mce/signal')}) + : super(client, name: destination, path: path) { + battery_status_ind = DBusRemoteObjectSignalStream( + object: this, + interface: 'com.nokia.mce.signal', + name: 'battery_status_ind', + signature: DBusSignature('s')) + .asBroadcastStream() + .map((signal) => ComNokiaMceSignalbattery_status_ind(signal)); + + charger_state_ind = DBusRemoteObjectSignalStream( + object: this, + interface: 'com.nokia.mce.signal', + name: 'charger_state_ind', + signature: DBusSignature('s')) + .asBroadcastStream() + .map((signal) => ComNokiaMceSignalcharger_state_ind(signal)); + } +} diff --git a/packages/battery_plus/battery_plus_aurora/pubspec.yaml b/packages/battery_plus/battery_plus_aurora/pubspec.yaml new file mode 100644 index 0000000..87fb4e2 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/pubspec.yaml @@ -0,0 +1,29 @@ +# Copyright (c) 2023. Open Mobile Platform LLC. +# License: Proprietary. + +name: battery_plus_aurora +description: The Aurora OS implementation of battery_plus. +version: 0.0.1 + +environment: + sdk: '>=2.18.6 <3.0.0' + flutter: ">=2.5.0" + +dependencies: + flutter: + sdk: flutter + dbus: ^0.7.8 + async: ^2.9.0 + plugin_platform_interface: ^2.0.2 + battery_plus_platform_interface: ^1.2.2 + +dev_dependencies: + flutter_test: + sdk: flutter + flutter_lints: ^2.0.0 + +flutter: + plugin: + platforms: + aurora: + dartPluginClass: BatteryPlusAurora