gtcrais/nativephp-push-notifications-permission-watcher
最新稳定版本:1.0.0
Composer 安装命令:
composer require gtcrais/nativephp-push-notifications-permission-watcher
包简介
NativePHP Mobile plugin which emits an event when the push notifications permission changes
README 文档
README
NativePHP Mobile plugin which emits an event when the push notifications permission changes.
Installation
composer require gtcrais/nativephp-push-notifications-permission-watcher
Usage
PHP (Livewire/Blade)
use GTCrais\Native\Mobile\PushNotificationsPermissionWatcher\Facades\PushNotificationsPermissionWatcher; // Request permission (shows native dialog if not yet determined) PushNotificationsPermissionWatcher::watch(); // Check current permission status without requesting $status = PushNotificationsPermissionWatcher::checkPermission(); // 'granted', 'denied', or 'not_determined' (iOS only)
JavaScript (Vue/React/Inertia)
import { On } from '#nativephp'; import { PushNotificationsPermissionWatcher, PushNotificationsPermissionEvents } from '@gtcrais/nativephp-push-notifications-permission-watcher'; // Listen for the permission result On(PushNotificationsPermissionEvents.PushNotificationsPermissionChanged, ({ status }) => { console.log(status); // 'granted' or 'denied' }); // Trigger the permission dialog await PushNotificationsPermissionWatcher.watch();
Listening for Events
Livewire
use Native\Mobile\Attributes\OnNative; use GTCrais\Native\Mobile\PushNotificationsPermissionWatcher\Events\PushNotificationsPermissionChanged; #[OnNative(PushNotificationsPermissionChanged::class)] public function handlePushNotificationsPermissionChanged(string $status) { // $status is 'granted' or 'denied' }
Laravel Event Listener
use GTCrais\Native\Mobile\PushNotificationsPermissionWatcher\Events\PushNotificationsPermissionChanged; Event::listen(PushNotificationsPermissionChanged::class, function (PushNotificationsPermissionChanged $event) { // $event->status is 'granted' or 'denied' });
Full Code Example
BaseLayout.vue
mounted() { PushNotificationService.registerTokenGeneratedListener(); PushNotificationService.registerPushNotificationsPermissionChangeListener(); }
PushNotificationService.js
import { PushNotifications, On, Events } from '#nativephp'; import { PushNotificationsPermissionWatcher, PushNotificationsPermissionEvents } from '@gtcrais/nativephp-push-notifications-permission-watcher'; import { useAuthStore } from "@/stores/auth-store.js"; import axios from "axios"; import { useAppDataStore } from "@/stores/app-data-store.js"; export default class PushNotificationService { static async enroll() { await PushNotificationsPermissionWatcher.watch(); } static async refreshPermissionStatus() { const status = await PushNotifications.checkPermission(); useAuthStore().setPushNotificationsPermissionStatus(status); } static async getTokenAndStore() { const token = await PushNotifications.getToken(); if (token) { await this.storeToken(token); } } static async storeToken(token) { await axios.post('/push-notifications-token', { token }) .catch((error) => { console.log('[LC]', JSON.stringify(error)); }); } static async deleteToken() { await axios.delete('/push-notifications-token'); } static registerPushNotificationsPermissionChangeListener() { On(PushNotificationsPermissionEvents.PushNotificationsPermissionChanged, async ({ status }) => { setTimeout(async () => { await this.refreshPermissionStatus(); if (this.isGranted) { // Now that the permission is granted, this will just go and fetch // the token, then fire the TokenGenerated event which we listen to await PushNotifications.enroll(); } }, 200); }); } static registerTokenGeneratedListener() { On(Events.PushNotification.TokenGenerated, async ({ token }) => { await this.handleTokenGenerated(token); }); } static async handleTokenGenerated(token) { if (token) { await this.storeToken(token); } } static get permissionStatus() { return useAuthStore().pushNotificationsPermissionStatus; } static get isNotDetermined() { return this.permissionStatus === 'not_determined'; } static get isDetermined() { return !this.isNotDetermined; } static get isDenied() { return this.permissionStatus === 'denied'; } static get isGranted() { return (this.isDetermined && !this.isDenied); } }
auth-store.js
export const useAuthStore = defineStore('auth', { state: () => ({ _pushNotificationsPermissionStatus: null }), getters: { pushNotificationsPermissionStatus: (state) => state._pushNotificationsPermissionStatus, }, actions: { setPushNotificationsPermissionStatus(status) { this._pushNotificationsPermissionStatus = status; } } });
License
MIT
统计信息
- 总下载量: 16
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-13