In WinRT abbiamo a disposizione la classe MessageDialog (namespace Windows.UI.Popups) per visualizzare popup modali, in linea con il design e la user experience di Windows 8.
Come le consuete finestre modali, con MessageDialog possiamo informare l'utente con un titolo e un messaggio ma possiamo anche richiedere un'esplicita risposta ad una domanda con un insieme di tre pulsanti.
Nello snippet seguente possiamo vedere il suo semplice utilizzo:
var dialog = new MessageDialog("contenuto", "titolo"); IAsyncOperation<IUICommand> cmd = dialog.ShowAsync();

Come possiamo vedere nell'immagine, nell'utilizzo di base viene mostrato automaticamente un solo pulsante necessario per la scomparsa della finestra modale.
Oltre a questa funzionalità abbiamo la possibilità di mostrare tre pulsanti personalizzati, aggiungendo oggetti UICommand alla collezione Commands.
Negli oggetti UICommand possiamo impostare direttamente nel costruttore l'etichetta e il delegato che viene richiamato alla pressione del pulsante corrispondente, come possiamo vedere nello snippet seguente.
dialog.Options = MessageDialogOptions.AcceptUserInputAfterDelay; dialog.Commands.Add(new UICommand("Si", (args) => { //args è direttamente UICommand })); dialog.Commands.Add(new UICommand("No", (args) => { })); dialog.Commands.Add(new UICommand("Annulla", (args) => { })); dialog.DefaultCommandIndex = 0; dialog.CancelCommandIndex = 2;

Con la proprietà DefaultCommandIndex andiamo ad impostare l'UICommand che viene attivato alla pressione del pulsante Invio, attraverso l'indice relativo alla collezione Commands. In modo analogo la proprietà CancelCommandIndex imposta quello corrispondente alla pressione del pulsante Esc della tastiera.
Una nota sulla proprietà Options: ad essa possiamo assegnare MessageDialogOptions.AcceptUserInputAfterDelay per ritardare l'attivazione dei pulsanti della modale.
La modale si attiva richiamando il metodo ShowAsync, che restituisce un oggetto di tipo IAsyncOperation. Grazie a questo oggetto abbiamo la possibilità di chiudere programmaticamente la MessageDialog richiamando il metodo Cancel.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Scrivere selettori CSS più semplici ed efficienti con :is()
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Ridurre il reflow ottimizzando il CSS
La gestione della riconnessione al server di Blazor in .NET 9
Rendere i propri workflow e le GitHub Action utilizzate più sicure
Creare una libreria CSS universale: Nav menu
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Configurare lo startup di applicazioni server e client con .NET Aspire
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Creare una libreria CSS universale - Rotazione degli elementi
Gestire progetti NPM in .NET Aspire
Creare agenti facilmente con Azure AI Agent Service
I più letti di oggi
- Gestione file Javascript in Blazor con .NET 9
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!