* feat(ui): some design mocks * fix(ui): some fixes for stuff * feat(ui): test overview page layout * feat(ui): fix placeholder * feat(ui): answers table modal * feat(tracker): user testing module in tracker * fix(tracker): add "thank you" section, refactor file to make it readable * fix(tracker): naming * fix(tracker): naming * fix(tracker): some refactorings for user testing modd * feat(tracker): export assist vers to window obj, add recorder manager for user testing * feat(tracker): refactor UT file * feat(tracker): add recording delay for UT module * feat(tracker): dnd for UT widget * fix(tracker): changelog for assist * fix(tracker): cover ut with tests * fix(tracker): update package scripts to include testing before releasing packages * fix(UI): fix uxt routes * feat(ui): uxt store * feat(ui): uxt store connection * feat(ui): some api connections for utx * feat(ui): some api connections for utx * feat(ui): some api connections for utx * feat(ui): api connections * feat(ui): api connections * feat(ui): api connections * feat(ui): api connections * feat(ui): utx components for replay * feat(ui): utx components for replay * feat(ui): make events shared * feat(ui): final fixes
84 lines
2.8 KiB
TypeScript
84 lines
2.8 KiB
TypeScript
import React from 'react';
|
|
import DashboardStore from './dashboardStore';
|
|
import MetricStore from './metricStore';
|
|
import UserStore from './userStore';
|
|
import RoleStore from './roleStore';
|
|
import APIClient from 'App/api_client';
|
|
import FunnelStore from './funnelStore';
|
|
import {
|
|
services
|
|
} from 'App/services';
|
|
import SettingsStore from './settingsStore';
|
|
import AuditStore from './auditStore';
|
|
import NotificationStore from './notificationStore';
|
|
import ErrorStore from './errorStore';
|
|
import SessionStore from './sessionStore';
|
|
import NotesStore from './notesStore';
|
|
import BugReportStore from './bugReportStore'
|
|
import RecordingsStore from './recordingsStore'
|
|
import AssistMultiviewStore from './assistMultiviewStore';
|
|
import WeeklyReportStore from './weeklyReportConfigStore'
|
|
import AlertStore from './alertsStore'
|
|
import FeatureFlagsStore from "./featureFlagsStore";
|
|
import UxtestingStore from './uxtestingStore';
|
|
|
|
export class RootStore {
|
|
dashboardStore: DashboardStore;
|
|
metricStore: MetricStore;
|
|
funnelStore: FunnelStore;
|
|
settingsStore: SettingsStore;
|
|
userStore: UserStore;
|
|
roleStore: RoleStore;
|
|
auditStore: AuditStore;
|
|
errorStore: ErrorStore;
|
|
notificationStore: NotificationStore;
|
|
sessionStore: SessionStore;
|
|
notesStore: NotesStore;
|
|
bugReportStore: BugReportStore;
|
|
recordingsStore: RecordingsStore;
|
|
assistMultiviewStore: AssistMultiviewStore;
|
|
weeklyReportStore: WeeklyReportStore
|
|
alertsStore: AlertStore
|
|
featureFlagsStore: FeatureFlagsStore
|
|
uxtestingStore: UxtestingStore
|
|
|
|
constructor() {
|
|
this.dashboardStore = new DashboardStore();
|
|
this.metricStore = new MetricStore();
|
|
this.funnelStore = new FunnelStore();
|
|
this.settingsStore = new SettingsStore();
|
|
this.userStore = new UserStore();
|
|
this.roleStore = new RoleStore();
|
|
this.auditStore = new AuditStore();
|
|
this.errorStore = new ErrorStore();
|
|
this.notificationStore = new NotificationStore();
|
|
this.sessionStore = new SessionStore();
|
|
this.notesStore = new NotesStore();
|
|
this.bugReportStore = new BugReportStore();
|
|
this.recordingsStore = new RecordingsStore();
|
|
this.assistMultiviewStore = new AssistMultiviewStore();
|
|
this.weeklyReportStore = new WeeklyReportStore();
|
|
this.alertsStore = new AlertStore();
|
|
this.featureFlagsStore = new FeatureFlagsStore();
|
|
this.uxtestingStore = new UxtestingStore();
|
|
}
|
|
|
|
initClient() {
|
|
const client = new APIClient();
|
|
services.forEach(service => {
|
|
service.initClient(client);
|
|
})
|
|
}
|
|
}
|
|
|
|
const StoreContext = React.createContext<RootStore>({} as RootStore);
|
|
|
|
export const StoreProvider = ({ children, store }: any) => {
|
|
return <StoreContext.Provider value={store}>{children}</StoreContext.Provider>;
|
|
};
|
|
|
|
export const useStore = () => React.useContext(StoreContext);
|
|
|
|
export const withStore = (Component: any) => (props: any) => {
|
|
return <Component {...props} mstore={useStore()} />;
|
|
};
|