Abbiamo già parlato in uno script precedente della gestione basilare delle notifiche all'interno della Universal Windows Platform. Oggi, invece, affrontiamo un tema più complesso, ovvero come interagire con le notifiche.
Il più semplice livello di interazione è rappresentato dai pulsanti, che permettono, nel caso di una sveglia, ad esempio, di spegnerla oppure di fare lo snooze e riprogrammarla. Per aggiungere i pulsanti è sufficiente aggiungere le Actions al template della notifica toast:
ToastContent toastContent = new ToastContent() { Visual = new ToastVisual() { ... }, Actions = new ToastActionsCustom() { Buttons = { new ToastButton("Snooze", "action=snooze") { ActivationType = ToastActivationType.Foreground }, new ToastButton("Cancel", "action=cancel") { ActivationType = ToastActivationType.Foreground } } }, }; var toast = new ToastNotification(toastContent.GetXml()); ToastNotificationManager.CreateToastNotifier().Show(toast);
L'azione impostata, in questo caso, rimanda all'evento OnActivated della classe App, in cui si potranno recuperare i parametri "snooze" o "cancel" e fare azioni corrispondenti all'evento selezionato, mentre l'applicazione si aprirà nella modalità foreground.
Poiché si sta parlando di una applicazione che simula una sveglia, probabilmente si vuole anche dare all'utente la possibilità di scegliere il prossimo reminder. Per farlo, oltre alla proprietà Buttons è necessario aggiungere la proprietà Inputs, in cui vengono registrate tutte le possibili scelte:
Actions = new ToastActionsCustom() { Buttons = { ... }, Inputs = { new ToastSelectionBox("snoozetiming") { DefaultSelectionBoxItemId = "5", Items = { new ToastSelectionBoxItem("5", "5 minuti"), new ToastSelectionBoxItem("10", "10 minuti"), new ToastSelectionBoxItem("15", "15 minuti") } } } }
E il risultato finale sarà molto simile al seguente:
Come si può notare, è possibile scegliere tramite una combobox il timing preferito e, una volta cliccato sul pulsante, si verrà rimandati di nuovo all'evento OnActivated, dove si potrà recuperare l'item selezionato tramite la proprietà UserInput.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Implementare il throttling in ASP.NET Core
Short-circuiting della Pipeline in ASP.NET Core
Utilizzare Tailwind CSS all'interno di React: installazione
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Copiare automaticamente le secret tra più repository di GitHub
Determinare lo stato di un pod in Kubernetes
Disabilitare automaticamente un workflow di GitHub
Effettuare il binding di date in Blazor
Disabilitare automaticamente un workflow di GitHub (parte 2)
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Verificare la provenienza di un commit tramite le GitHub Actions
Configurare dependabot per aggiornare le dipendenze di terze parti con GitHub Actions
I più letti di oggi
- Vuoi incontrare Bill Gates? Viaggia con ASPItalia.com!
- Customizzare il pager del DataGrid
- Stabilire un collegamento VPN tra una Web App e una Virtual Network
- Documentare ASP.NET Web API con Swagger
- Usare i servizi REST di BING per ottenere informazioni sulla posizione dell'utente
- Visual Studio 2005 CTP May