Skip to content

Instantly share code, notes, and snippets.

@kubk
Last active August 8, 2025 07:14
Show Gist options
  • Save kubk/d9d496271ea76f0da85d67530ed5ef28 to your computer and use it in GitHub Desktop.
Save kubk/d9d496271ea76f0da85d67530ed5ef28 to your computer and use it in GitHub Desktop.
class ListStore<T> {
isLoading = false;
list: T[] = [];
constructor(loadList: () => Promise<T[]>) {
makeAutoObservable(this)
}
loadList() {
this.isLoading = true;
loadList()
.then(action((data) => this.list = data))
.finally(action(() => this.isLoading = false))
}
}
const userListStore = new ListStore(() => api.loadUsers()); // ListStore<User>
const postListStore = new ListStore(() => api.loadPosts()); // ListStore<Post>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment