memberListStore.tsx 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. import Reflux from 'reflux';
  2. import {User} from 'sentry/types';
  3. type MemberListStoreInterface = {
  4. state: User[];
  5. loaded: boolean;
  6. loadInitialData(items: User[]): void;
  7. isLoaded(): boolean;
  8. getById(id: string): User | undefined;
  9. getByEmail(email: string): User | undefined;
  10. getAll(): User[];
  11. };
  12. const storeConfig: Reflux.StoreDefinition & MemberListStoreInterface = {
  13. // listenables: MemberActions,
  14. loaded: false,
  15. state: [],
  16. init() {
  17. this.state = [];
  18. this.loaded = false;
  19. },
  20. // TODO(dcramer): this should actually come from an action of some sorts
  21. loadInitialData(items: User[]) {
  22. this.state = items;
  23. this.loaded = true;
  24. this.trigger(this.state, 'initial');
  25. },
  26. isLoaded() {
  27. return this.loaded;
  28. },
  29. getById(id) {
  30. if (!this.state) {
  31. return undefined;
  32. }
  33. id = '' + id;
  34. for (let i = 0; i < this.state.length; i++) {
  35. if (this.state[i].id === id) {
  36. return this.state[i];
  37. }
  38. }
  39. return undefined;
  40. },
  41. getByEmail(email) {
  42. if (!this.state) {
  43. return undefined;
  44. }
  45. email = email.toLowerCase();
  46. for (let i = 0; i < this.state.length; i++) {
  47. if (this.state[i].email.toLowerCase() === email) {
  48. return this.state[i];
  49. }
  50. }
  51. return undefined;
  52. },
  53. getAll() {
  54. return this.state;
  55. },
  56. };
  57. const MemberListStore = Reflux.createStore(storeConfig) as Reflux.Store &
  58. MemberListStoreInterface;
  59. export default MemberListStore;