12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- import {createStore, StoreDefinition} from 'reflux';
- import {FieldObject} from 'sentry/components/forms/types';
- /**
- * Processed form field metadata.
- */
- export type FormSearchField = {
- description: React.ReactNode;
- field: FieldObject;
- route: string;
- title: React.ReactNode;
- };
- interface StoreInterface {
- get(): InternalDefinition['searchMap'];
- reset(): void;
- }
- type InternalDefinition = {
- loadSearchMap: (searchMap: null | FormSearchField[]) => void;
- searchMap: null | FormSearchField[];
- };
- interface ExternalIssuesDefinition
- extends StoreDefinition,
- InternalDefinition,
- StoreInterface {}
- /**
- * Store for "form" searches, but probably will include more
- */
- const storeConfig: ExternalIssuesDefinition = {
- searchMap: null,
- init() {
- // XXX: Do not use `this.listenTo` in this store. We avoid usage of reflux
- // listeners due to their leaky nature in tests.
- this.reset();
- },
- get() {
- return this.searchMap;
- },
- reset() {
- // `null` means it hasn't been loaded yet
- this.searchMap = null;
- },
- /**
- * Adds to search map
- */
- loadSearchMap(searchMap) {
- // Only load once
- if (this.searchMap !== null) {
- return;
- }
- this.searchMap = searchMap;
- this.trigger(this.searchMap);
- },
- };
- const FormSearchStore = createStore(storeConfig);
- export default FormSearchStore;
|