memberListStore.tsx 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import {createStore, StoreDefinition} from 'reflux';
  2. import {User} from 'sentry/types';
  3. interface MemberListStoreDefinition extends StoreDefinition {
  4. getAll(): User[];
  5. getByEmail(email: string): User | undefined;
  6. getById(id: string): User | undefined;
  7. init(): void;
  8. isLoaded(): boolean;
  9. loadInitialData(items: User[]): void;
  10. loaded: boolean;
  11. state: User[];
  12. }
  13. const storeConfig: MemberListStoreDefinition = {
  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 = createStore(storeConfig);
  58. export default MemberListStore;