getGuidesContent.tsx 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635
  1. import {GuidesContent} from 'sentry/components/assistant/types';
  2. import ExternalLink from 'sentry/components/links/externalLink';
  3. import Link from 'sentry/components/links/link';
  4. import {t, tct} from 'sentry/locale';
  5. import ConfigStore from 'sentry/stores/configStore';
  6. export default function getGuidesContent(orgSlug: string | null): GuidesContent {
  7. if (ConfigStore.get('demoMode')) {
  8. if (localStorage.getItem('new-walkthrough') === '1') {
  9. return getDemoModeGuidesV2();
  10. }
  11. return getDemoModeGuides();
  12. }
  13. return [
  14. {
  15. guide: 'issue',
  16. requiredTargets: ['issue_number', 'exception'],
  17. steps: [
  18. {
  19. title: t('Identify Your Issues'),
  20. target: 'issue_number',
  21. description: tct(
  22. `You have Issues. That's fine. Use the Issue number in your commit message,
  23. and we'll automatically resolve the Issue when your code is deployed. [link:Learn more]`,
  24. {link: <ExternalLink href="https://docs.sentry.io/product/releases/" />}
  25. ),
  26. },
  27. {
  28. title: t('Annoy the Right People'),
  29. target: 'owners',
  30. description: tct(
  31. `Notification overload makes it tempting to hurl your phone into the ocean.
  32. Define who is responsible for what, so alerts reach the right people and your
  33. devices stay on dry land. [link:Learn more]`,
  34. {
  35. link: (
  36. <ExternalLink href="https://docs.sentry.io/product/error-monitoring/issue-owners/" />
  37. ),
  38. }
  39. ),
  40. },
  41. {
  42. title: t('Narrow Down Suspects'),
  43. target: 'exception',
  44. description: t(
  45. `We've got stack trace. See the exact sequence of function calls leading to the error
  46. in question, no detective skills necessary.`
  47. ),
  48. },
  49. {
  50. title: t('Retrace Your Steps'),
  51. target: 'breadcrumbs',
  52. description: t(
  53. `Not sure how you got here? Sentry automatically captures breadcrumbs for events in web
  54. frameworks to lead you straight to your error.`
  55. ),
  56. },
  57. ],
  58. },
  59. {
  60. guide: 'issue_stream',
  61. requiredTargets: ['issue_stream'],
  62. steps: [
  63. {
  64. title: t('Issues'),
  65. target: 'issue_stream',
  66. description: tct(
  67. `Sentry automatically groups similar events together into an issue. Similarity is
  68. determined by stack trace and other factors. [link:Learn more].`,
  69. {
  70. link: (
  71. <ExternalLink href="https://docs.sentry.io/platform-redirect/?next=/data-management/event-grouping/" />
  72. ),
  73. }
  74. ),
  75. },
  76. ],
  77. },
  78. {
  79. guide: 'alerts_write_owner',
  80. requiredTargets: ['alerts_write_owner'],
  81. steps: [
  82. {
  83. target: 'alerts_write_owner',
  84. description: tct(
  85. `Today only admins in your organization can create alert rules but we recommend [link:allowing members to create alerts], too.`,
  86. {
  87. link: <Link to={orgSlug ? `/settings/${orgSlug}` : `/settings`} />,
  88. }
  89. ),
  90. nextText: t('Allow'),
  91. hasNextGuide: true,
  92. },
  93. ],
  94. },
  95. {
  96. guide: 'trace_view',
  97. requiredTargets: ['trace_view_guide_row', 'trace_view_guide_row_details'],
  98. steps: [
  99. {
  100. title: t('Event Breakdown'),
  101. target: 'trace_view_guide_breakdown',
  102. description: t(
  103. `The event breakdown shows you the breakdown of event types within a trace.`
  104. ),
  105. },
  106. {
  107. title: t('Transactions'),
  108. target: 'trace_view_guide_row',
  109. description: t(
  110. `You can quickly see all the transactions in a trace alongside the project, transaction duration, and any related errors.`
  111. ),
  112. },
  113. {
  114. title: t('Transactions Details'),
  115. target: 'trace_view_guide_row_details',
  116. description: t('Click on any transaction to see more details.'),
  117. },
  118. ],
  119. },
  120. {
  121. guide: 'span_op_breakdowns_and_tag_explorer',
  122. requiredTargets: ['span_op_breakdowns_filter'],
  123. steps: [
  124. {
  125. title: t('Filter by Span Operation'),
  126. target: 'span_op_breakdowns_filter',
  127. description: t(
  128. 'You can now filter these transaction events based on http, db, browser or resource operation.'
  129. ),
  130. },
  131. {
  132. title: t('Suspect Tags'),
  133. target: 'tag_explorer',
  134. description: tct(
  135. "See which tags often correspond to slower transactions. You'll want to investigate these more. [link:Learn more]",
  136. {
  137. link: (
  138. <ExternalLink href="https://docs.sentry.io/product/performance/transaction-summary/#suspect-tags" />
  139. ),
  140. }
  141. ),
  142. },
  143. ],
  144. },
  145. {
  146. guide: 'project_transaction_threshold',
  147. requiredTargets: ['project_transaction_threshold'],
  148. steps: [
  149. {
  150. title: t('Project Thresholds'),
  151. target: 'project_transaction_threshold',
  152. description: t(
  153. 'Gauge performance using different metrics for each project. Set response time thresholds, per project, for the Apdex and User Misery Scores in each project’s Performance settings.'
  154. ),
  155. },
  156. ],
  157. },
  158. {
  159. guide: 'project_transaction_threshold_override',
  160. requiredTargets: ['project_transaction_threshold_override'],
  161. steps: [
  162. {
  163. title: t('Response Time Thresholds'),
  164. target: 'project_transaction_threshold_override',
  165. description: t(
  166. 'Use this menu to adjust each transaction’s satisfactory response time threshold, which can vary across transactions. These thresholds are used to calculate Apdex and User Misery, metrics that indicate how satisfied and miserable users are, respectively.'
  167. ),
  168. },
  169. ],
  170. },
  171. {
  172. guide: 'semver',
  173. requiredTargets: ['releases_search'],
  174. dateThreshold: new Date('2021-05-01'),
  175. steps: [
  176. {
  177. title: t('Filter by Semver'),
  178. target: 'releases_search',
  179. description: tct(
  180. 'You can now filter releases by semver. For example: release.version:>14.0 [br] [link:View the docs]',
  181. {
  182. br: <br />,
  183. link: (
  184. <ExternalLink href="https://docs.sentry.io/product/releases/usage/sorting-filtering/#filtering-releases" />
  185. ),
  186. }
  187. ),
  188. nextText: t('Leave me alone'),
  189. },
  190. ],
  191. },
  192. {
  193. guide: 'new_page_filters',
  194. requiredTargets: ['new_page_filter_button'],
  195. expectedTargets: ['new_page_filter_pin'],
  196. dateThreshold: new Date('2022-04-05'),
  197. steps: [
  198. {
  199. title: t('Selection filters here now'),
  200. target: 'new_page_filter_button',
  201. description: t(
  202. "Selection filters were at the top of the page. Now they're here. Because this is what's getting filtered. Obvi."
  203. ),
  204. nextText: t('Sounds good'),
  205. },
  206. {
  207. title: t('Pin your filters'),
  208. target: 'new_page_filter_pin',
  209. description: t(
  210. "Want to keep the same filters between searches and sessions? Click this button. Don't want to? Don't click this button."
  211. ),
  212. nextText: t('Got it'),
  213. },
  214. ],
  215. },
  216. {
  217. guide: 'releases_widget',
  218. requiredTargets: ['releases_widget'],
  219. dateThreshold: new Date('2022-06-22'),
  220. steps: [
  221. {
  222. title: t('Releases are here'),
  223. target: 'releases_widget',
  224. description: t(
  225. 'Want to know how your latest release is doing? Monitor release health and crash rates in Dashboards.'
  226. ),
  227. nextText: t('Sounds good'),
  228. },
  229. ],
  230. },
  231. {
  232. guide: 'activate_sampling_rule',
  233. requiredTargets: ['sampling_rule_toggle'],
  234. dateThreshold: new Date('2022-07-05'),
  235. steps: [
  236. {
  237. title: t('Activate your first rule'),
  238. target: 'sampling_rule_toggle',
  239. description: t(
  240. 'Activating a rule will take immediate effect, as well as any changes given to an active rule.'
  241. ),
  242. nextText: t('Activate Rule'),
  243. dismissText: t('Later'),
  244. hasNextGuide: true,
  245. },
  246. ],
  247. },
  248. {
  249. guide: 'create_conditional_rule',
  250. requiredTargets: ['add_conditional_rule'],
  251. dateThreshold: new Date('2022-07-05'),
  252. steps: [
  253. {
  254. title: t('Create a new sample rule'),
  255. target: 'add_conditional_rule',
  256. description: t(
  257. 'Sample transactions under specific conditions, keeping what you need and dropping what you don’t.'
  258. ),
  259. dismissText: t('Enough already'),
  260. },
  261. ],
  262. },
  263. ];
  264. }
  265. function getDemoModeGuides(): GuidesContent {
  266. return [
  267. {
  268. guide: 'sidebar',
  269. requiredTargets: ['projects', 'issues'],
  270. priority: 1, // lower number means higher priority
  271. markOthersAsSeen: true,
  272. steps: [
  273. {
  274. title: t('Projects'),
  275. target: 'projects',
  276. description: t(
  277. `Create a project for any type of application you want to monitor.`
  278. ),
  279. },
  280. {
  281. title: t('Issues'),
  282. target: 'issues',
  283. description: t(
  284. `Here's a list of what's broken with your application. And everything you need to know to fix it.`
  285. ),
  286. },
  287. {
  288. title: t('Performance'),
  289. target: 'performance',
  290. description: t(
  291. `See slow faster. Trace slow-loading pages back to their API calls as well as surface all related errors.`
  292. ),
  293. },
  294. {
  295. title: t('Releases'),
  296. target: 'releases',
  297. description: t(
  298. `Track the health of every release, see differences between releases from crash analytics to adoption rates.`
  299. ),
  300. },
  301. {
  302. title: t('Discover'),
  303. target: 'discover',
  304. description: t(
  305. `Query and unlock insights into the health of your entire system and get answers to critical business questions all in one place.`
  306. ),
  307. nextText: t('Got it'),
  308. },
  309. ],
  310. },
  311. {
  312. guide: 'issue_stream_v2',
  313. requiredTargets: ['issue_stream_title'],
  314. steps: [
  315. {
  316. title: t('Issue'),
  317. target: 'issue_stream_title',
  318. description: t(
  319. `Click here to get a full error report down to the line of code that caused the error.`
  320. ),
  321. },
  322. ],
  323. },
  324. {
  325. guide: 'issue_v2',
  326. requiredTargets: ['issue_details', 'exception'],
  327. steps: [
  328. {
  329. title: t('Details'),
  330. target: 'issue_details',
  331. description: t('See the who, what, and where of every error right at the top'),
  332. },
  333. {
  334. title: t('Exception'),
  335. target: 'exception',
  336. description: t(
  337. `Source code right in the stack trace, so you don’t need to find it yourself.`
  338. ),
  339. },
  340. {
  341. title: t('Tags'),
  342. target: 'tags',
  343. description: t(
  344. `Tags help you quickly access related events and view the tag distribution for a set of events.`
  345. ),
  346. },
  347. {
  348. title: t('Breadcrumbs'),
  349. target: 'breadcrumbs',
  350. description: t(
  351. `Check out the play by play of what your user experienced till they encountered the exception.`
  352. ),
  353. },
  354. {
  355. title: t('Discover'),
  356. target: 'open_in_discover',
  357. description: t(
  358. `Uncover trends with Discover — analyze errors by URL, geography, device, browser, etc.`
  359. ),
  360. },
  361. ],
  362. },
  363. {
  364. guide: 'releases',
  365. requiredTargets: ['release_version'],
  366. steps: [
  367. {
  368. title: t('Release'),
  369. target: 'release_version',
  370. description: t(
  371. `Click here to easily identify new issues, regressions, and track the health of every release.`
  372. ),
  373. },
  374. ],
  375. },
  376. {
  377. guide: 'release_details',
  378. requiredTargets: ['release_chart'],
  379. steps: [
  380. {
  381. title: t('Chart'),
  382. target: 'release_chart',
  383. description: t('Click and drag to zoom in on a specific section of the chart.'),
  384. },
  385. {
  386. title: t('Discover'),
  387. target: 'release_issues_open_in_discover',
  388. description: t('Analyze these errors by URL, geography, device, browser, etc.'),
  389. },
  390. {
  391. title: t('Discover'),
  392. target: 'release_transactions_open_in_discover',
  393. description: t(
  394. `Analyze these performance issues by URL, geography, device, browser, etc.`
  395. ),
  396. },
  397. ],
  398. },
  399. {
  400. guide: 'discover_landing',
  401. requiredTargets: ['discover_landing_header'],
  402. steps: [
  403. {
  404. title: t('Discover'),
  405. target: 'discover_landing_header',
  406. description: t(
  407. `Click into any of the queries below to identify trends in event data.`
  408. ),
  409. },
  410. ],
  411. },
  412. {
  413. guide: 'discover_event_view',
  414. requiredTargets: ['create_alert_from_discover'],
  415. steps: [
  416. {
  417. title: t('Create Alert'),
  418. target: 'create_alert_from_discover',
  419. description: t(
  420. `Create an alert based on this query to get notified when an event exceeds user-defined thresholds.`
  421. ),
  422. },
  423. {
  424. title: t('Columns'),
  425. target: 'columns_header_button',
  426. description: t(
  427. `There's a whole lot more to... _discover_. View all the query conditions.`
  428. ),
  429. },
  430. ],
  431. },
  432. {
  433. guide: 'transaction_details',
  434. requiredTargets: ['span_tree'],
  435. steps: [
  436. {
  437. title: t('Span Tree'),
  438. target: 'span_tree',
  439. description: t(
  440. `Expand the spans to see span details from start date, end date to the operation.`
  441. ),
  442. },
  443. {
  444. title: t('Breadcrumbs'),
  445. target: 'breadcrumbs',
  446. description: t(
  447. `Check out the play by play of what your user experienced till they encountered the performance issue.`
  448. ),
  449. },
  450. ],
  451. },
  452. ];
  453. }
  454. function getDemoModeGuidesV2(): GuidesContent {
  455. return [
  456. {
  457. guide: 'sidebar_v2',
  458. requiredTargets: ['projects'],
  459. priority: 1,
  460. markOthersAsSeen: true,
  461. steps: [
  462. {
  463. title: t('Projects'),
  464. target: 'projects',
  465. description: t(
  466. `Create a project for any type of application you want to monitor.`
  467. ),
  468. },
  469. {
  470. title: t('Issues'),
  471. target: 'issues',
  472. description: t(
  473. `Here's a list of what's broken and slow. Sentry automatically groups similar events together into an issue.`
  474. ),
  475. },
  476. {
  477. title: t('Performance'),
  478. target: 'performance',
  479. description: t(
  480. `Keep a pulse on crash rates, throughput, and latency issues across projects.`
  481. ),
  482. },
  483. {
  484. title: t('Releases'),
  485. target: 'releases',
  486. description: t(
  487. `Track the health of every release, see differences between releases from crash analytics to adoption rates.`
  488. ),
  489. },
  490. {
  491. title: t('Discover'),
  492. target: 'discover',
  493. description: t(
  494. `Query and unlock insights into the health of your entire system and get answers to critical business questions all in one place.`
  495. ),
  496. nextText: t('Got it'),
  497. },
  498. ],
  499. },
  500. {
  501. guide: 'issue_stream_v3',
  502. requiredTargets: ['issue_stream'],
  503. steps: [
  504. {
  505. title: t('Issues'),
  506. target: 'issue_stream',
  507. description: t(
  508. `Sentry automatically groups similar events together into an issue. Similarity is
  509. determined by stack trace and other factors. Click on an issue to learn more`
  510. ),
  511. },
  512. ],
  513. },
  514. {
  515. guide: 'issues_v3',
  516. requiredTargets: ['tags'],
  517. steps: [
  518. {
  519. title: t('Metadata and metrics'),
  520. target: 'tags',
  521. description: t(
  522. `See tags like specific users affected by the event, device, OS, and browser type.
  523. On the right side of the page you can view the number of affected users and exception frequency overtime.`
  524. ),
  525. },
  526. {
  527. title: t('Find your broken code'),
  528. target: 'stack_trace',
  529. description: t(
  530. `View the stack trace to see the exact sequence of function calls leading to the error in question.`
  531. ),
  532. },
  533. {
  534. title: t('Retrace your steps'),
  535. target: 'breadcrumbs',
  536. description: t(
  537. `Sentry automatically captures breadcrumbs for events so you can see the sequence of events so you can see the sequence of events leading up to the error.`
  538. ),
  539. nextText: t('Got it'),
  540. },
  541. ],
  542. },
  543. {
  544. guide: 'releases_v2',
  545. requiredTargets: ['release_projects'],
  546. priority: 1,
  547. steps: [
  548. {
  549. title: t('Compare releases'),
  550. target: 'release_projects',
  551. description: t(
  552. `Click here and select the "react-native" project to see how the release is trending compaed to previous releases.`
  553. ),
  554. },
  555. ],
  556. },
  557. {
  558. guide: 'react-native-release',
  559. requiredTargets: ['release_version'],
  560. steps: [
  561. {
  562. title: t('Release-specfic trends'),
  563. target: 'release_version',
  564. description: t(
  565. `Select the latest release to review new and regressed issues, and business critical metrics like crash rate, user adoption, and session duration.`
  566. ),
  567. },
  568. ],
  569. },
  570. {
  571. guide: 'release-details_v2',
  572. requiredTargets: ['release_states'],
  573. steps: [
  574. {
  575. title: t('New and regresses issues'),
  576. target: 'release_states',
  577. description: t(
  578. `Along with reviewing how your release is trending over time compared to previous releases, you can view new and regressed issues here.`
  579. ),
  580. },
  581. ],
  582. },
  583. {
  584. guide: 'performance',
  585. requiredTargets: ['performance_table'],
  586. steps: [
  587. {
  588. title: t('See slow transactions'),
  589. target: 'performance_table',
  590. description: t(
  591. `Trace slow-loading pages back to their API calls, as well as, related errors and users impacted across projects. Select a transaction to see more details.`
  592. ),
  593. },
  594. ],
  595. },
  596. {
  597. guide: 'transaction_summary',
  598. requiredTargets: ['user_misery', 'transactions_table'],
  599. steps: [
  600. {
  601. title: t('Identify the root cause'),
  602. target: 'user_misery',
  603. description: t(
  604. 'Dive into the details behind a slow transaction. See User Misery, Apdex, and more metrics, along with related events and suspect spans.'
  605. ),
  606. },
  607. {
  608. title: t('Breakdown event spans'),
  609. target: 'transactions_table',
  610. description: t(
  611. 'Select an Event ID from a list of slow transactions to uncover slow spans.'
  612. ),
  613. nextText: t('Got it'),
  614. },
  615. ],
  616. },
  617. {
  618. guide: 'transaction_details_v2',
  619. requiredTargets: ['span_tree'],
  620. steps: [
  621. {
  622. title: t('See slow fast'),
  623. target: 'span_tree',
  624. description: t(
  625. `Expand the spans to see span details from start date, end date to the operation. Below you can view breadcrumbs for a play-by-play of what your users
  626. did before encountering the performance.`
  627. ),
  628. },
  629. ],
  630. },
  631. ];
  632. }