lots of tidying up

This commit is contained in:
TheXamlGuy
2024-01-25 20:33:55 +00:00
parent 5e26e97f6b
commit a322893166
20 changed files with 115 additions and 123 deletions
@@ -10,13 +10,11 @@ public static class IServiceCollectionExtensions
services.AddTransient<IInitializer, WidgetInitializer>(); services.AddTransient<IInitializer, WidgetInitializer>();
services.AddTransient<IFactory<Type, IWidget>, WidgetFactory>(); services.AddTransient<IFactory<Type, IWidget>, WidgetFactory>();
services.AddHandler<WidgetEnumeratorHandler>(); services.AddHandler<WidgetEnumerator>();
services.AddHandler<WidgetAssemblyHandler>(); services.AddHandler<WidgetAssemblyHandler>();
services.AddHandler<WidgetHandler>(); services.AddHandler<WidgetHandler>();
services.AddHandler<WidgetHostHandler>(); services.AddHandler<WidgetHostHandler>();
services.AddTransient<IFactory<IWidgetHost, WidgetContainerViewModel?>, WidgetContainerFactory>();
return services; return services;
} }
+3 -2
View File
@@ -20,6 +20,8 @@ public class WidgetBuilder<TConfiguration>(TConfiguration configuration) :
}) })
.ConfigureServices((context, services) => .ConfigureServices((context, services) =>
{ {
services.AddSingleton<IWidgetHost, WidgetHost>();
services.AddScoped<IServiceFactory>(provider => services.AddScoped<IServiceFactory>(provider =>
new ServiceFactory((type, parameters) => new ServiceFactory((type, parameters) =>
ActivatorUtilities.CreateInstance(provider, type, parameters!))); ActivatorUtilities.CreateInstance(provider, type, parameters!)));
@@ -50,8 +52,7 @@ public class WidgetBuilder<TConfiguration>(TConfiguration configuration) :
public IWidgetHost Build() public IWidgetHost Build()
{ {
IHost host = hostBuilder.Build(); IHost host = hostBuilder.Build();
return (IWidgetHost)ActivatorUtilities.CreateInstance(host.Services, return host.Services.GetRequiredService<IWidgetHost>();
typeof(WidgetHost), host);
} }
public IWidgetBuilder ConfigureServices(Action<IServiceCollection> configureDelegate) public IWidgetBuilder ConfigureServices(Action<IServiceCollection> configureDelegate)
+1 -8
View File
@@ -1,17 +1,10 @@
using Microsoft.Extensions.DependencyInjection; namespace Hyperbar.Widget;
namespace Hyperbar.Widget;
public class WidgetContainerFactory(IServiceFactory factory) : public class WidgetContainerFactory(IServiceFactory factory) :
IFactory<IWidgetHost, WidgetContainerViewModel?> IFactory<IWidgetHost, WidgetContainerViewModel?>
{ {
public WidgetContainerViewModel? Create(IWidgetHost value) public WidgetContainerViewModel? Create(IWidgetHost value)
{
if (value.Services.GetServices<IWidgetViewModel>() is
IEnumerable<IWidgetViewModel> viewModels)
{ {
return factory.Create<WidgetContainerViewModel>(value.Configuration.Id); return factory.Create<WidgetContainerViewModel>(value.Configuration.Id);
} }
return default;
}
} }
@@ -3,6 +3,7 @@ using CommunityToolkit.Mvvm.ComponentModel;
namespace Hyperbar.Widget; namespace Hyperbar.Widget;
[NotificationHandler(nameof(WidgetContainerViewModel))]
public partial class WidgetContainerViewModel(ITemplateFactory templateFactory, public partial class WidgetContainerViewModel(ITemplateFactory templateFactory,
IServiceFactory serviceFactory, IServiceFactory serviceFactory,
IMediator mediator, IMediator mediator,
@@ -4,7 +4,7 @@ using System.Runtime.Loader;
namespace Hyperbar.Widget; namespace Hyperbar.Widget;
public class WidgetEnumeratorHandler(IHostEnvironment hostEnvironment, public class WidgetEnumerator(IHostEnvironment hostEnvironment,
IMediator mediator) : IMediator mediator) :
INotificationHandler<Enumerate<IWidget>> INotificationHandler<Enumerate<IWidget>>
{ {
+5 -6
View File
@@ -1,5 +1,4 @@
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace Hyperbar.Widget; namespace Hyperbar.Widget;
@@ -8,18 +7,18 @@ public class WidgetHost :
IWidgetHost IWidgetHost
{ {
private readonly IConfigurationInitializer<WidgetConfiguration> configurationInitializer; private readonly IConfigurationInitializer<WidgetConfiguration> configurationInitializer;
private readonly IHost host; private readonly IServiceProvider services;
private readonly IEnumerable<IInitializer> initializers; private readonly IEnumerable<IInitializer> initializers;
private readonly IMediator mediator; private readonly IMediator mediator;
private readonly IProxyService<IMediator> proxyMediator; private readonly IProxyService<IMediator> proxyMediator;
public WidgetHost(IHost host, public WidgetHost(IServiceProvider services,
IMediator mediator, IMediator mediator,
IEnumerable<IInitializer> initializers, IEnumerable<IInitializer> initializers,
IProxyService<IMediator> proxyMediator, IProxyService<IMediator> proxyMediator,
IConfigurationInitializer<WidgetConfiguration> configurationInitializer) IConfigurationInitializer<WidgetConfiguration> configurationInitializer)
{ {
this.host = host; this.services = services;
this.mediator = mediator; this.mediator = mediator;
this.initializers = initializers; this.initializers = initializers;
this.proxyMediator = proxyMediator; this.proxyMediator = proxyMediator;
@@ -28,9 +27,9 @@ public class WidgetHost :
mediator.Subscribe(this); mediator.Subscribe(this);
} }
public WidgetConfiguration Configuration => host.Services.GetRequiredService<WidgetConfiguration>(); public WidgetConfiguration Configuration => services.GetRequiredService<WidgetConfiguration>();
public IServiceProvider Services => host.Services; public IServiceProvider Services => services;
public async Task Handle(Changed<WidgetAvailability> notification, public async Task Handle(Changed<WidgetAvailability> notification,
CancellationToken cancellationToken) CancellationToken cancellationToken)
+7 -3
View File
@@ -1,7 +1,8 @@
namespace Hyperbar.Widget; using Microsoft.Extensions.DependencyInjection;
public class WidgetHostHandler(IMediator mediator, namespace Hyperbar.Widget;
IFactory<IWidgetHost, WidgetContainerViewModel?> factory) :
public class WidgetHostHandler(IMediator mediator) :
INotificationHandler<Started<IWidgetHost>>, INotificationHandler<Started<IWidgetHost>>,
INotificationHandler<Stopped<IWidgetHost>> INotificationHandler<Stopped<IWidgetHost>>
{ {
@@ -9,6 +10,8 @@ public class WidgetHostHandler(IMediator mediator,
CancellationToken cancellationToken) CancellationToken cancellationToken)
{ {
if (notification.Value is IWidgetHost host) if (notification.Value is IWidgetHost host)
{
if (host.Services.GetRequiredService<IFactory<IWidgetHost, WidgetContainerViewModel?>>() is { } factory)
{ {
if (factory.Create(host) is WidgetContainerViewModel containerViewModel) if (factory.Create(host) is WidgetContainerViewModel containerViewModel)
{ {
@@ -17,6 +20,7 @@ public class WidgetHostHandler(IMediator mediator,
} }
} }
} }
}
public Task Handle(Stopped<IWidgetHost> notification, public Task Handle(Stopped<IWidgetHost> notification,
CancellationToken cancellationToken) CancellationToken cancellationToken)
+14 -4
View File
@@ -1,11 +1,21 @@
namespace Hyperbar.Widget; using Microsoft.Extensions.DependencyInjection;
public class WidgetViewModelEnumerator : namespace Hyperbar.Widget;
public class WidgetViewModelEnumerator(IWidgetHost host,
IMediator mediator) :
INotificationHandler<Enumerate<IWidgetViewModel>> INotificationHandler<Enumerate<IWidgetViewModel>>
{ {
public Task Handle(Enumerate<IWidgetViewModel> notification, public async Task Handle(Enumerate<IWidgetViewModel> notification,
CancellationToken cancellationToken) CancellationToken cancellationToken)
{ {
throw new NotImplementedException(); if (host.Services.GetServices<IWidgetViewModel>() is IEnumerable<IWidgetViewModel> viewModels)
{
foreach (IWidgetViewModel viewModel in viewModels)
{
await mediator.PublishAsync(new Created<IWidgetViewModel>(viewModel),
nameof(WidgetContainerViewModel), cancellationToken);
}
}
} }
} }
@@ -1,7 +1,5 @@
using CommunityToolkit.Mvvm.ComponentModel; using CommunityToolkit.Mvvm.ComponentModel;
using CommunityToolkit.Mvvm.Input;
using Hyperbar.Widget; using Hyperbar.Widget;
using System.Windows.Input;
namespace Hyperbar.Windows.MediaController; namespace Hyperbar.Windows.MediaController;
@@ -19,9 +17,6 @@ public partial class MediaInformationViewModel(IServiceFactory serviceFactory,
[ObservableProperty] [ObservableProperty]
private string? title; private string? title;
public ICommand Initialize =>
new AsyncRelayCommand(InitializeAsync);
public Task Handle(Changed<MediaInformation> notification, public Task Handle(Changed<MediaInformation> notification,
CancellationToken cancellationToken) CancellationToken cancellationToken)
{ {
@@ -34,6 +29,6 @@ public partial class MediaInformationViewModel(IServiceFactory serviceFactory,
return Task.CompletedTask; return Task.CompletedTask;
} }
public async Task InitializeAsync() => public override async Task InitializeAsync() =>
await Mediator.PublishAsync<Request<MediaInformation>>(); await Mediator.PublishAsync<Request<MediaInformation>>();
} }
+1 -1
View File
@@ -27,8 +27,8 @@ public class PrimaryWidget :
.AddCache<Guid, IWidgetComponentViewModel>() .AddCache<Guid, IWidgetComponentViewModel>()
.AddTransient<IProvider<PrimaryCommandConfiguration, IWidgetComponentViewModel?>, WidgetComponentProvider>() .AddTransient<IProvider<PrimaryCommandConfiguration, IWidgetComponentViewModel?>, WidgetComponentProvider>()
.AddTransient<IFactory<PrimaryCommandConfiguration, IWidgetComponentViewModel?>, WidgetComponentFactory>() .AddTransient<IFactory<PrimaryCommandConfiguration, IWidgetComponentViewModel?>, WidgetComponentFactory>()
.AddTransient<IEnumerator<IWidgetComponentViewModel>, WidgetComponentEnumerationHandler>()
.AddWidgetTemplate<PrimaryWidgetViewModel>() .AddWidgetTemplate<PrimaryWidgetViewModel>()
.AddHandler<WidgetComponentViewModelEnumerator>()
.AddHandler<PrimaryWidgetConfigurationHandler>(); .AddHandler<PrimaryWidgetConfigurationHandler>();
}); });
} }
@@ -6,9 +6,8 @@ namespace Hyperbar.Windows.Primary;
public class PrimaryWidgetViewModel(ITemplateFactory templateFactory, public class PrimaryWidgetViewModel(ITemplateFactory templateFactory,
IServiceFactory serviceFactory, IServiceFactory serviceFactory,
IMediator mediator, IMediator mediator,
IDisposer disposer, IDisposer disposer) :
IEnumerator<IWidgetComponentViewModel> enumerator) : ObservableCollectionViewModel<IWidgetComponentViewModel>(serviceFactory, mediator, disposer),
ObservableCollectionViewModel<IWidgetComponentViewModel>(serviceFactory, mediator, disposer, enumerator),
IWidgetViewModel, IWidgetViewModel,
ITemplatedViewModel ITemplatedViewModel
{ {
@@ -2,12 +2,13 @@
namespace Hyperbar.Windows.Primary; namespace Hyperbar.Windows.Primary;
public class WidgetComponentEnumerationHandler(PrimaryWidgetConfiguration configuration, public class WidgetComponentViewModelEnumerator(PrimaryWidgetConfiguration configuration,
IMediator mediator,
IFactory<PrimaryCommandConfiguration, IWidgetComponentViewModel?> factory, IFactory<PrimaryCommandConfiguration, IWidgetComponentViewModel?> factory,
ICache<(Guid ParentId, Guid Id), PrimaryCommandConfiguration> cache) : ICache<(Guid ParentId, Guid Id), PrimaryCommandConfiguration> cache) :
IEnumerator<IWidgetComponentViewModel> INotificationHandler<Enumerate<IWidgetComponentViewModel>>
{ {
public IEnumerable<IWidgetComponentViewModel?> Get() public async Task Handle(Enumerate<IWidgetComponentViewModel> notification, CancellationToken cancellationToken)
{ {
Stack<(Guid, List<PrimaryCommandConfiguration>)> stack = new(); Stack<(Guid, List<PrimaryCommandConfiguration>)> stack = new();
stack.Push((Guid.Empty, configuration.Commands)); stack.Push((Guid.Empty, configuration.Commands));
@@ -27,7 +28,11 @@ public class WidgetComponentEnumerationHandler(PrimaryWidgetConfiguration config
foreach (PrimaryCommandConfiguration item in configuration.Commands.OrderBy(x => x.Order)) foreach (PrimaryCommandConfiguration item in configuration.Commands.OrderBy(x => x.Order))
{ {
yield return factory.Create(item); if (factory.Create(item) is IWidgetComponentViewModel viewModel)
{
await mediator.PublishAsync(new Created<IWidgetComponentViewModel>(viewModel), nameof(PrimaryWidgetViewModel),
cancellationToken);
}
} }
} }
} }
+13 -7
View File
@@ -6,6 +6,7 @@ using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Configuration.Json; using Microsoft.Extensions.Configuration.Json;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Hosting;
using Microsoft.UI.Dispatching;
using Microsoft.UI.Xaml; using Microsoft.UI.Xaml;
using System; using System;
using System.Reflection; using System.Reflection;
@@ -21,7 +22,6 @@ public partial class App :
protected override async void OnLaunched(LaunchActivatedEventArgs args) protected override async void OnLaunched(LaunchActivatedEventArgs args)
{ {
base.OnLaunched(args); base.OnLaunched(args);
IHost? host = new HostBuilder() IHost? host = new HostBuilder()
.UseContentRoot(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), .UseContentRoot(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData),
Assembly.GetEntryAssembly()?.GetName().Name!), true) Assembly.GetEntryAssembly()?.GetName().Name!), true)
@@ -32,10 +32,10 @@ public partial class App :
.ConfigureServices((context, services) => .ConfigureServices((context, services) =>
{ {
services.AddDefault(); services.AddDefault();
services.AddWidget();
services.AddHostedService<AppService>(); services.AddHostedService<AppService>();
services.AddSingleton<IDispatcher, Dispatcher>(); services.AddSingleton<IDispatcher>(new Dispatcher(DispatcherQueue.GetForCurrentThread()));
services.AddTransient<ITemplateFactory, TemplateFactory>(); services.AddTransient<ITemplateFactory, TemplateFactory>();
services.AddHandler<AppConfigurationChangedHandler>(); services.AddHandler<AppConfigurationChangedHandler>();
@@ -48,20 +48,26 @@ public partial class App :
services.AddSingleton<DesktopBar>(); services.AddSingleton<DesktopBar>();
services.AddContentTemplate<WidgetBarViewModel, WidgetBarView>(); services.AddContentTemplate<WidgetBarViewModel, WidgetBarView>();
services.AddContentTemplate<WidgetContainerViewModel, WidgetContainerView>();
services.AddTransient<IProxyServiceCollection<IWidgetBuilder>>(provider => services.AddTransient<IProxyServiceCollection<IWidgetBuilder>>(provider =>
new ProxyServiceCollection<IWidgetBuilder>(services => new ProxyServiceCollection<IWidgetBuilder>(services =>
{ {
services.AddSingleton<IDispatcher, Dispatcher>(); services.AddSingleton<IDispatcher>(new Dispatcher(DispatcherQueue.GetForCurrentThread()));
services.AddTransient<ITemplateFactory, TemplateFactory>();
services.AddScoped<IVirtualKeyboard, VirtualKeyboard>();
services.AddTransient<IFactory<IWidgetHost, WidgetContainerViewModel?>,
WidgetContainerFactory>();
services.AddTransient<ITemplateFactory, TemplateFactory>();
services.AddScoped<IVirtualKeyboard, VirtualKeyboard>();
services.AddHandler<KeyAcceleratorHandler>(); services.AddHandler<KeyAcceleratorHandler>();
services.AddHandler<StartProcessHandler>(); services.AddHandler<StartProcessHandler>();
services.AddHandler<WidgetViewModelEnumerator>();
services.AddTransient<IWidgetView, WidgetView>(); services.AddTransient<IWidgetView, WidgetView>();
services.AddContentTemplate<WidgetContainerViewModel, WidgetContainerView>();
services.AddContentTemplate<WidgetButtonViewModel, WidgetButtonView>(); services.AddContentTemplate<WidgetButtonViewModel, WidgetButtonView>();
services.AddContentTemplate<WidgetSplitButtonViewModel, WidgetSplitButtonView>(); services.AddContentTemplate<WidgetSplitButtonViewModel, WidgetSplitButtonView>();
})); }));
+3 -6
View File
@@ -3,12 +3,9 @@ using Microsoft.UI.Dispatching;
namespace Hyperbar.Windows; namespace Hyperbar.Windows;
public class Dispatcher : public class Dispatcher(DispatcherQueue dispatcherQueue) :
IDispatcher IDispatcher
{ {
private DispatcherQueue dispatcherQueue; public async Task InvokeAsync(Action action) =>
await dispatcherQueue.EnqueueAsync(action.Invoke);
public Dispatcher() => dispatcherQueue = DispatcherQueue.GetForCurrentThread();
public async Task InvokeAsync(Action action) => await dispatcherQueue.EnqueueAsync(action.Invoke);
} }
@@ -3,6 +3,8 @@
x:Class="Hyperbar.Windows.WidgetContainerView" x:Class="Hyperbar.Windows.WidgetContainerView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:interactions="using:Microsoft.Xaml.Interactions.Core"
xmlns:interactivity="using:Microsoft.Xaml.Interactivity"
xmlns:ui="using:Hyperbar.Windows.UI"> xmlns:ui="using:Hyperbar.Windows.UI">
<Grid> <Grid>
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
@@ -10,7 +12,7 @@
<ColumnDefinition Width="*" /> <ColumnDefinition Width="*" />
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<Rectangle <Rectangle
Width="10" Width="1"
Height="40" Height="40"
Margin="6,2,6,2" Margin="6,2,6,2"
Fill="Red" /> Fill="Red" />
@@ -23,6 +25,11 @@
<StackPanel Orientation="Horizontal" /> <StackPanel Orientation="Horizontal" />
</ItemsPanelTemplate> </ItemsPanelTemplate>
</ItemsControl.ItemsPanel> </ItemsControl.ItemsPanel>
<interactivity:Interaction.Behaviors>
<interactions:EventTriggerBehavior EventName="Loaded">
<interactions:InvokeCommandAction Command="{Binding Initialize}" />
</interactions:EventTriggerBehavior>
</interactivity:Interaction.Behaviors>
</ItemsControl> </ItemsControl>
</Grid> </Grid>
</UserControl> </UserControl>
+10 -1
View File
@@ -3,8 +3,11 @@
x:Class="Hyperbar.Windows.WidgetView" x:Class="Hyperbar.Windows.WidgetView"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:interactions="using:Microsoft.Xaml.Interactions.Core"
xmlns:interactivity="using:Microsoft.Xaml.Interactivity"
xmlns:ui="using:Hyperbar.Windows.UI"> xmlns:ui="using:Hyperbar.Windows.UI">
<ItemsControl ItemTemplateSelector="{Binding Converter={ui:DataTemplateConverter}}" ItemsSource="{Binding}"> <Grid>
<ItemsControl ItemTemplateSelector="{Binding Converter={ui:DataTemplateConverter}}" ItemsSource="{Binding Mode=TwoWay}">
<ItemsControl.ItemsPanel> <ItemsControl.ItemsPanel>
<ItemsPanelTemplate> <ItemsPanelTemplate>
<StackPanel Orientation="Horizontal" Spacing="8" /> <StackPanel Orientation="Horizontal" Spacing="8" />
@@ -15,5 +18,11 @@
<AddDeleteThemeTransition /> <AddDeleteThemeTransition />
</TransitionCollection> </TransitionCollection>
</ItemsControl.ItemContainerTransitions> </ItemsControl.ItemContainerTransitions>
<interactivity:Interaction.Behaviors>
<interactions:EventTriggerBehavior EventName="Loaded">
<interactions:InvokeCommandAction Command="{Binding Initialize}" />
</interactions:EventTriggerBehavior>
</interactivity:Interaction.Behaviors>
</ItemsControl> </ItemsControl>
</Grid>
</UserControl> </UserControl>
@@ -9,16 +9,8 @@ public class ConfigurationInitializer<TConfiguration>(IConfigurationMonitor<TCon
where TConfiguration : where TConfiguration :
class class
{ {
public bool isInitilized;
public async Task InitializeAsync() public async Task InitializeAsync()
{ {
if (isInitilized)
{
return;
}
isInitilized = true;
if (!reader.TryRead(out TConfiguration? _)) if (!reader.TryRead(out TConfiguration? _))
{ {
if (factory.Create() is object defaultConfiguration) if (factory.Create() is object defaultConfiguration)
@@ -1,8 +1,10 @@
using CommunityToolkit.Mvvm.ComponentModel; using CommunityToolkit.Mvvm.ComponentModel;
using CommunityToolkit.Mvvm.Input;
using System.Collections; using System.Collections;
using System.Collections.ObjectModel; using System.Collections.ObjectModel;
using System.Collections.Specialized; using System.Collections.Specialized;
using System.Reactive.Disposables; using System.Reactive.Disposables;
using System.Windows.Input;
namespace Hyperbar; namespace Hyperbar;
@@ -17,8 +19,7 @@ public partial class ObservableCollectionViewModel<TItem> :
where TItem : where TItem :
IDisposable IDisposable
{ {
public ObservableCollection<TItem> collection = []; private readonly ObservableCollection<TItem> collection = new();
private readonly IEnumerator<TItem>? enumerator;
public ObservableCollectionViewModel(IServiceFactory serviceFactory, public ObservableCollectionViewModel(IServiceFactory serviceFactory,
IMediator mediator, IMediator mediator,
@@ -33,33 +34,6 @@ public partial class ObservableCollectionViewModel<TItem> :
collection.CollectionChanged += OnCollectionChanged; collection.CollectionChanged += OnCollectionChanged;
} }
public ObservableCollectionViewModel(IServiceFactory serviceFactory,
IMediator mediator,
IDisposer disposer,
IEnumerator<TItem> enumerator)
{
ServiceFactory = serviceFactory;
Mediator = mediator;
Disposer = disposer;
this.enumerator = enumerator;
mediator.Subscribe(this);
collection.CollectionChanged += OnCollectionChanged;
if (enumerator is not null)
{
foreach (TItem? item in enumerator.Get())
{
if (item is not null)
{
Add(item);
}
}
}
}
public ObservableCollectionViewModel(IServiceFactory serviceFactory, public ObservableCollectionViewModel(IServiceFactory serviceFactory,
IMediator mediator, IMediator mediator,
IDisposer disposer, IDisposer disposer,
@@ -80,6 +54,9 @@ public partial class ObservableCollectionViewModel<TItem> :
public int Count => collection.Count; public int Count => collection.Count;
public ICommand Initialize =>
new AsyncRelayCommand(InitializeAsync);
bool IList.IsFixedSize => false; bool IList.IsFixedSize => false;
bool ICollection<TItem>.IsReadOnly => false; bool ICollection<TItem>.IsReadOnly => false;
@@ -101,10 +78,7 @@ public partial class ObservableCollectionViewModel<TItem> :
public TItem this[int index] public TItem this[int index]
{ {
get => collection[index]; get => collection[index];
set set => SetItem(index, value);
{
SetItem(index, value);
}
} }
object? IList.this[int index] object? IList.this[int index]
@@ -199,7 +173,8 @@ public partial class ObservableCollectionViewModel<TItem> :
void ICollection.CopyTo(Array array, int index) => void ICollection.CopyTo(Array array, int index) =>
collection.CopyTo((TItem[])array, index); collection.CopyTo((TItem[])array, index);
public void Dispose() => Disposer.Dispose(this); public void Dispose() =>
Disposer.Dispose(this);
public System.Collections.Generic.IEnumerator<TItem> GetEnumerator() => public System.Collections.Generic.IEnumerator<TItem> GetEnumerator() =>
collection.GetEnumerator(); collection.GetEnumerator();
@@ -267,6 +242,9 @@ public partial class ObservableCollectionViewModel<TItem> :
IsCompatibleObject(value) ? IsCompatibleObject(value) ?
IndexOf((TItem)value!) : -1; IndexOf((TItem)value!) : -1;
public virtual async Task InitializeAsync() =>
await Mediator.PublishAsync<Enumerate<TItem>>();
public void Insert(int index, TItem item) => public void Insert(int index, TItem item) =>
InsertItem(index, item); InsertItem(index, item);
+1 -3
View File
@@ -2,9 +2,7 @@
namespace Hyperbar; namespace Hyperbar;
public class ObservableViewModel(IServiceFactory serviceFactory, public class ObservableViewModel(IDisposer disposer) :
IMediator mediator,
IDisposer disposer) :
ObservableObject, ObservableObject,
IDisposable IDisposable
{ {