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);
}