flutter_macos_permissions 2.0.4 copy "flutter_macos_permissions: ^2.0.4" to clipboard
flutter_macos_permissions: ^2.0.4 copied to clipboard

A Flutter plugin for requesting camera, microphone, and notification permissions on macOS.

dashstack_poster

flutter macos permissions #

A simple Flutter plugin to request Camera, Microphone, Notification and Location permissions on macOS.

This plugin provides an easy-to-use API using method channels to handle macOS permissions in your Flutter desktop apps.

✨ Features #

πŸŽ₯ Request Camera permission

🎀 Request Microphone permission

πŸ”” Request Notification permission

🌍 Request Location permission

πŸ”Ž Check current permission status

πŸ“ Works with Flutter macOS desktop apps


How to use it ? #

1. Add dependency #

Add this to your package's pubspec.yaml file:

dependencies:
 flutter_macos_permissions: <latest_version>

2. Install it You can install packages from the command line: #

with pub :

$ pub get

with Flutter :

$ flutter pub get

3. Import it #

Now in your Dart code, you can use :

import 'package:flutter_macos_permissions/flutter_macos_permissions.dart';

4.How to Use it ? #

Sample app demonstrates how simple the usage of the library actually is.

Using flutter_macos_permissions in your project easy to intregate.

Build permission with FlutterMacosPermissions #

πŸ”Ή Request permissions #

  • You can request permissions for Camera, Microphone, Notifications and Location :
 String status = "Idle";

  /// Request Permission
  void request(String type) async {
    bool granted = false;
    try {
      switch (type) {
        case 'camera':
          granted = await FlutterMacosPermissions.requestCamera();
          break;
        case 'microphone':
          granted = await FlutterMacosPermissions.requestMicrophone();
          break;
        case 'notification':
          granted = await FlutterMacosPermissions.requestNotification();
          break;
        case 'requestLocation':
          granted = await FlutterMacosPermissions.requestLocation();
          break;
      }
      setState(() {
        status = 'Requested $type β†’ ${granted ? "Granted" : "Denied"}';
      });
    } catch (e) {
      setState(() {
        status = 'Error: $e';
      });
    }
  }

Build UI buttons #

@override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('MacOS Permissions')),
      body: SingleChildScrollView(
        child: Column(
          children: [
            const SizedBox(height: 20),
            /// Status Display
            Container(
              padding: const EdgeInsets.all(16),
              margin: const EdgeInsets.symmetric(horizontal: 20),
              decoration: BoxDecoration(
                color: Colors.transparent,
                borderRadius: BorderRadius.circular(12),
                border: Border.all(
                  color: Colors.grey.shade400,
                  width: 2, // Border width
                ),
              ),
              child: Text(status, style: const TextStyle(fontSize: 16)),
            ),
            const SizedBox(height: 20),
            /// camera permission and status
            permissionCard(
              'Camera',
              Icons.camera_alt,
              () => request('camera'),
              () => checkStatus('cameraStatus'),
            ),

            /// microphone permission and status
            permissionCard(
              'Microphone',
              Icons.mic,
              () => request('microphone'),
              () => checkStatus('microphoneStatus'),
            ),

            /// notification permission and status
            permissionCard(
              'Notifications',
              Icons.notifications,
              () => request('notification'),
              () => checkStatus('notificationStatus'),
            ),

            /// location permission and status
            permissionCard(
              'Location',
              Icons.location_on,
              () => request('requestLocation'),
              () => checkStatus('locationStatus'),
            ),
          ],
        ),
      ),
    );
  }

πŸ“Έ Example #

without Any Permission with Camera Permission with Microphone Permission
idel camera permission microphone permission
with Notification Permission with Location Permission
Notification permission Location permission

πŸ”Ή Check permission status #

  • You can also check the current status without requesting and with requesting.
  • Status will return one of the following: authorized, denied, restricted, notDetermined.
/// Check Permission Status
  void checkStatus(String type) async {
    String status = 'Unknown';
    try {
      switch (type) {
        case 'cameraStatus':
          status = await FlutterMacosPermissions.cameraStatus();
          break;
        case 'microphoneStatus':
          status = await FlutterMacosPermissions.microphoneStatus();
          break;
        case 'notificationStatus':
          status = await FlutterMacosPermissions.notificationStatus();
          break;
        case 'locationStatus':
          status = await FlutterMacosPermissions.locationStatus();
          break;
      }
      setState(() {
        this.status = 'Status $type β†’ $status';
      });
    } catch (e) {
      setState(() => this.status = 'Error: $e');
    }
  }

Build UI buttons #

 @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: const Text('MacOS Permissions')),
      body: SingleChildScrollView(
        child: Column(
          children: [
            const SizedBox(height: 20),
            /// Status Display
            Container(
              padding: const EdgeInsets.all(16),
              margin: const EdgeInsets.symmetric(horizontal: 20),
              decoration: BoxDecoration(
                color: Colors.transparent,
                borderRadius: BorderRadius.circular(12),
                border: Border.all(
                  color: Colors.grey.shade400,
                  width: 2, // Border width
                ),
              ),
              child: Text(status, style: const TextStyle(fontSize: 16)),
            ),
            const SizedBox(height: 20),
            /// camera permission and status
            permissionCard(
              'Camera',
              Icons.camera_alt,
              () => request('camera'),
              () => checkStatus('cameraStatus'),
            ),

            /// microphone permission and status
            permissionCard(
              'Microphone',
              Icons.mic,
              () => request('microphone'),
              () => checkStatus('microphoneStatus'),
            ),

            /// notification permission and status
            permissionCard(
              'Notifications',
              Icons.notifications,
              () => request('notification'),
              () => checkStatus('notificationStatus'),
            ),

            /// location permission and status
            permissionCard(
              'Location',
              Icons.location_on,
              () => request('requestLocation'),
              () => checkStatus('locationStatus'),
            ),
          ],
        ),
      ),
    );
  }

πŸ“Έ Example #

Camera Status Microphone Status
Camera Microphone
Notification Status Location Status
Notification Location

πŸ“‘ Permission Properties #

  • The table below shows the available permissions, their method calls, possible status values, and the System Preferences location that can be opened if the user has denied access.
Permission Request Permission Status Permission Possible Status Values Opens in System Preferences β†’ Privacy & Security
Camera FlutterMacosPermissions.requestCamera() FlutterMacosPermissions.cameraStatus() authorized, denied, restricted, notDetermined Camera
Microphone FlutterMacosPermissions.requestMicrophone() FlutterMacosPermissions.microphoneStatus() authorized, denied, restricted, notDetermined Microphone
Notifications FlutterMacosPermissions.requestNotification() FlutterMacosPermissions.notificationStatus() authorized, denied, notDetermined Notifications
Location FlutterMacosPermissions.requestLocation() FlutterMacosPermissions.locationStatus() authorized, denied, restricted, notDetermined Location Services

Bugs and Feedback #

We welcome and appreciate any suggestions you may have for improvement. For bugs, questions, and discussions please use the GitHub Issues.

Acknowledgments #

It extends Flutter’s foundation to provide a ready-to-use, customizable currency formatter widget.While Flutter and intl provide the base, flutter_macos_permissions simplifies the process by combining widgets and formatting logic into a single package you can drop into any app.

Contribution #

The DashStack team enthusiastically welcomes contributions and project participation! There are a bunch of things you can do if you want to contribute! The Contributor Guide has all the information you need for everything from reporting bugs to contributing new features.

Credits #

flutter_macos_permissions is owned and maintained by the Dashstack Infotech,Surat. Follow us for updates and new releases πŸš€.

4
likes
0
points
96
downloads

Publisher

verified publisherdashstack.tech

Weekly Downloads

A Flutter plugin for requesting camera, microphone, and notification permissions on macOS.

Homepage
Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter, plugin_platform_interface

More

Packages that depend on flutter_macos_permissions

Packages that implement flutter_macos_permissions