La charm dei Settings è un importante punto di integrazione tra il sistema operativo e le Windows Store app perchè permette all'utente di raggiungere le impostazioni di ciascuna app con la stessa modalità, con una user experience omogenea e semplice.
In app WinRT realizzate con PRISM l'integrazione con la charm è già predisposta nella classe MvvmAppBase, la classe base dell'entry point App. In essa, nel metodo di ingresso InitializeFrameAsync ci si registra all'evento CommandsRequested appunto della charm:
SettingsPane.GetForCurrentView().CommandsRequested += OnCommandsRequested;
Il metodo gestore dell'evento fa i controlli del caso e richiama il metodo virtual GetSettingsCommands, metodo che deve restituire la collezione di SettingsCommand che vogliamo mostrare nel panel.
Di questo metodo possiamo fare l'override nella nostra classe App e inserire i SettingsCommand di cui abbiamo bisogno.
protected override IList<SettingsCommand> GetSettingsCommands() { return new List<SettingsCommand>() { new SettingsCommand(Guid.NewGuid().ToString(), "PrivacyPolicy (esempio)", async (c) => await Launcher.LaunchUriAsync(new Uri("https://www.winrtitalia.com"))) }; }
Nello snipped di esempio possiamo vedere un SettingsCommand che naviga ad una pagina di un sito web, come potrebbe essere la pagina che descrive le policy di gestione dei dati personali.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Determinare lo stato di un pod in Kubernetes
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
Effettuare il deploy di immagini solo da container registry approvati in Kubernetes
Potenziare Azure AI Search con la ricerca vettoriale
Configurare dependabot per aggiornare le dipendenze di terze parti con GitHub Actions
Sfruttare lo streaming di una chiamata Http da Blazor
Hosting di componenti WebAssembly in un'applicazione Blazor static
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Esportare ed analizzare le issue di GitHub con la CLI e GraphQL
Utilizzare le Cache API di JavaScript per salvare elementi nella cache del browser
Copiare automaticamente le secret tra più repository di GitHub
Configurare policy CORS in Azure Container Apps
I più letti di oggi
- Cambiare la chiave di partizionamento di Azure Cosmos DB
- ASP.NET 2.0 per tutti
- Definire stili a livello di libreria in Angular
- Utilizzare il trigger SQL con le Azure Function
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- .NET Conference Italia 2023 - Milano e Online
- Come EF 8 ha ottimizzato le query che usano il metodo Contains
- Ottimizzazione dei block template in Angular 17