diff --git a/packages/battery_plus/battery_plus_aurora/.gitignore b/packages/battery_plus/battery_plus_aurora/.gitignore new file mode 100644 index 0000000..c1631bb --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/.gitignore @@ -0,0 +1,32 @@ +# 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/ +.metadata +run.sh 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..bc0feb3 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/README.md @@ -0,0 +1,38 @@ +# 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. + +```yaml +dependencies: + battery_plus: ^4.0.1 + battery_plus_aurora: + path: # path to folder with plugin +``` + +```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()); +}); +``` + +### Preview example + +![preview.png](data%2Fpreview.png) 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..f9b3034 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/analysis_options.yaml @@ -0,0 +1 @@ +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..66cf84f --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/.gitignore @@ -0,0 +1,45 @@ +# 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 +pubspec.lock 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..cc85198 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/README.md @@ -0,0 +1,17 @@ +# 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 +``` + +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`. 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..f9b3034 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/analysis_options.yaml @@ -0,0 +1 @@ +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..32c841f --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/CMakeLists.txt @@ -0,0 +1,47 @@ +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/flutter/generated_plugin_registrant.cpp b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugin_registrant.cpp new file mode 100644 index 0000000..b315972 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugin_registrant.cpp @@ -0,0 +1,14 @@ +// +// Generated file. Do not edit. +// + +// clang-format off + +#include + +#include "generated_plugin_registrant.h" + +void RegisterPlugins() { + Application::RegisterPlugins({ + }); +} diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugin_registrant.h b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugin_registrant.h new file mode 100644 index 0000000..648dcb3 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugin_registrant.h @@ -0,0 +1,12 @@ +// +// Generated file. Do not edit. +// + +// clang-format off + +#ifndef GENERATED_PLUGIN_REGISTRANT +#define GENERATED_PLUGIN_REGISTRANT + +void RegisterPlugins(); + +#endif /* GENERATED_PLUGIN_REGISTRANT */ diff --git a/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugins.cmake b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugins.cmake new file mode 100644 index 0000000..ae4d0a2 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/flutter/generated_plugins.cmake @@ -0,0 +1,30 @@ +# +# Generated file, do not edit. +# +set(ROOT_PROJECT_BINARY_DIR "${PROJECT_BINARY_DIR}") + +function(add_library TARGET) + _add_library(${TARGET} ${ARGN}) + + if(NOT "${TARGET}" MATCHES "^PkgConfig::.*") + add_custom_command(TARGET ${TARGET} POST_BUILD + COMMAND ${CMAKE_COMMAND} -E copy + "$" + "${ROOT_PROJECT_BINARY_DIR}/bundle/lib/$") + endif(NOT "${TARGET}" MATCHES "^PkgConfig::.*") +endfunction() + +list(APPEND FLUTTER_PLATFORM_PLUGIN_LIST +) + +list(APPEND FLUTTER_FFI_PLUGIN_LIST +) + +foreach(PLUGIN ${FLUTTER_PLATFORM_PLUGIN_LIST}) + add_subdirectory(flutter/ephemeral/.plugin_symlinks/${PLUGIN}/aurora plugins/${PLUGIN}) + target_link_libraries(${BINARY_NAME} PRIVATE ${PLUGIN}_platform_plugin) +endforeach(PLUGIN) + +foreach(FFI_PLUGIN ${FLUTTER_FFI_PLUGIN_LIST}) + add_subdirectory(flutter/ephemeral/.plugin_symlinks/${FFI_PLUGIN}/aurora plugins/${FFI_PLUGIN}) +endforeach(FFI_PLUGIN) 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..2dd2f52 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/aurora/main.cpp @@ -0,0 +1,10 @@ +#include +#include "generated_plugin_registrant.h" + +int main(int argc, char *argv[]) { + Application::Initialize(argc, argv); + Application::SetPixelRatio(1.8); + 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..51ced71 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/lib/main.dart @@ -0,0 +1,160 @@ +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.yaml b/packages/battery_plus/battery_plus_aurora/example/pubspec.yaml new file mode 100644 index 0000000..b270708 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/example/pubspec.yaml @@ -0,0 +1,23 @@ +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..c4617b8 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/battery_plus_aurora.dart @@ -0,0 +1,88 @@ +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..dac1934 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_request.dart @@ -0,0 +1,46 @@ +// This file was generated using the following command and may be overwritten. +// dart-dbus generate-remote-object data/com.nokia.mce.request.xml + +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..1bdce4c --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/lib/com_nokia_mce_signal.dart @@ -0,0 +1,32 @@ +// This file was generated using the following command and may be overwritten. +// dart-dbus generate-remote-object data/com.nokia.mce.signal.xml + +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..3971814 --- /dev/null +++ b/packages/battery_plus/battery_plus_aurora/pubspec.yaml @@ -0,0 +1,27 @@ +name: battery_plus_aurora +description: The Aurora OS implementation of battery_plus. +version: 0.0.1 +homepage: + +environment: + sdk: '>=2.18.6 <3.0.0' + flutter: ">=2.5.0" + +dependencies: + flutter: + sdk: flutter + dbus: ^0.7.8 + async: ^2.11.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