using GFramework.Core.Abstractions.Events; namespace GFramework.Core.Abstractions.StateManagement; /// /// 只读状态容器接口,用于暴露应用状态快照和订阅能力。 /// 该抽象适用于 Controller、Query、ViewModel 等只需要观察状态的调用方, /// 使其无需依赖写入能力即可响应复杂状态树的变化。 /// /// 状态树的根状态类型。 public interface IReadonlyStore { /// /// 获取当前状态快照。 /// Store 负责保证返回值与最近一次成功分发后的状态一致。 /// TState State { get; } /// /// 订阅状态变化通知。 /// 仅当 Store 判断状态发生有效变化时,才会调用该监听器。 /// /// 状态变化时的监听器,参数为新的状态快照。 /// 用于取消订阅的句柄。 IUnRegister Subscribe(Action listener); /// /// 订阅状态变化通知,并立即以当前状态调用一次监听器。 /// 该方法适合在 UI 初始化或 ViewModel 首次绑定时建立同步视图。 /// /// 状态变化时的监听器,参数为新的状态快照。 /// 用于取消订阅的句柄。 IUnRegister SubscribeWithInitValue(Action listener); /// /// 取消订阅指定的状态监听器。 /// /// 需要移除的监听器。 void UnSubscribe(Action listener); }