onboarding.tsx 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. import {AvatarUser} from './user';
  2. export enum OnboardingTaskKey {
  3. FIRST_PROJECT = 'create_project',
  4. FIRST_EVENT = 'send_first_event',
  5. INVITE_MEMBER = 'invite_member',
  6. SECOND_PLATFORM = 'setup_second_platform',
  7. USER_CONTEXT = 'setup_user_context',
  8. RELEASE_TRACKING = 'setup_release_tracking',
  9. SOURCEMAPS = 'setup_sourcemaps',
  10. USER_REPORTS = 'setup_user_reports',
  11. ISSUE_TRACKER = 'setup_issue_tracker',
  12. ALERT_RULE = 'setup_alert_rules',
  13. FIRST_TRANSACTION = 'setup_transactions',
  14. }
  15. export type OnboardingSupplementComponentProps = {
  16. task: OnboardingTask;
  17. onCompleteTask: () => void;
  18. };
  19. export type OnboardingTaskDescriptor = {
  20. task: OnboardingTaskKey;
  21. title: string;
  22. description: string;
  23. /**
  24. * Can this task be skipped?
  25. */
  26. skippable: boolean;
  27. /**
  28. * A list of require task keys that must have been completed before these
  29. * tasks may be completed.
  30. */
  31. requisites: OnboardingTaskKey[];
  32. /**
  33. * Should the onboarding task currently be displayed
  34. */
  35. display: boolean;
  36. /**
  37. * An extra component that may be rendered within the onboarding task item.
  38. */
  39. SupplementComponent?: React.ComponentType<OnboardingSupplementComponentProps>;
  40. } & (
  41. | {
  42. actionType: 'app' | 'external';
  43. location: string;
  44. }
  45. | {
  46. actionType: 'action';
  47. action: () => void;
  48. }
  49. );
  50. export type OnboardingTaskStatus = {
  51. task: OnboardingTaskKey;
  52. status: 'skipped' | 'pending' | 'complete';
  53. user?: AvatarUser | null;
  54. dateCompleted?: string;
  55. completionSeen?: string;
  56. data?: object;
  57. };
  58. export type OnboardingTask = OnboardingTaskStatus &
  59. OnboardingTaskDescriptor & {
  60. /**
  61. * Onboarding tasks that are currently incomplete and must be completed
  62. * before this task should be completed.
  63. */
  64. requisiteTasks: OnboardingTask[];
  65. };