Skip to main content
Skip table of contents

Story Beat

Features

Story Beat is a built-in mechanism that automatically analyzes user actions at the functional level (rather than at the click level) and helps filter out the noise in a user’s journey.

Story Beat provides insights into the process a user goes through while interacting with an application.

Different options are available depending on the application being monitored. For example, Shopify Pixel can be used to gain insights into the shopping experience, specifically during the cart checkout process.

On a Flow

Germain UX - Story beat.png

Story Beat view - Germain UX

On a Focused Flow

Story Beat on a Focused Flow portlet:

image-20241004-140730.png

Story Beat on Focused Flow - Germain UX

Categories

There are four categories of beats that cover 100% of the session time: browse, trigger, edit, and idle. Within each beat, we provide a detailed breakdown: wait vs. orient vs. act.

CODE
/       Browse        |       Trigger       |        Edit         |        Idle         \
|----- duration ------|----- duration ------|----- duration ------|----- duration ------|
|wait -> orient -> act|wait -> orient -> act|wait -> orient -> act|wait -> orient -> act|
  • Wait: Duration of network activity or rendering that delays user actions.

  • Orient: Time spent by the user preparing to act—for example, visually locating the next button or moving the mouse cursor toward it.

  • Act: Time spent actively engaging, such as reading, scrolling, editing, or idling.

Attributes

Here are the attributes of a Story Beat.

  • Timestamp: The start time of the interval covered by this datapoint.

  • WaitDuration: Duration (in seconds) spent blocked by page activities (e.g., network requests, scripting, rendering).

  • OrientDuration: Duration (in seconds) spent by the user preparing for the next action. Depending on the ActionCategory, this typically includes idle time, scrolling, or moving the mouse.

  • ActionDuration: Duration (in seconds) spent idling, browsing, triggering interactions, or editing inputs, based on the ActionCategory.

  • ActionCategory: Indicates the type of user interaction:

    • edit: User interacted with input controls (e.g., text boxes, checkboxes).

    • trigger: User clicked on a link or button.

    • browse: User primarily moved the mouse or scrolled.

    • idle: No user interaction during the interval.

  • LabelHint: Contextual data bundle aiding backend labeling. All beats include:

    • UiHierarchy: string[] – Indicates the application's current navigation/view at the start of the action interval.

    • ActionTargets: string[] – Specifies elements interacted with, represented as a hierarchy from general to specific (e.g., [appletName, formName, fieldName], [tabName, tableName, buttonLabel]). Each action target includes the tag name of the corresponding HTML element appended in parentheses.

  • Labels (Hierarchical descriptions):

    • Label1: Lowest-level (most granular) description of user activity (e.g., "picking a shoe size").

    • Label2: ...

    • Label3: Mid-level description (e.g., "Comparing details across two products").

    • Label4: ...

    • Label5: Highest-level description (e.g., "Rebuying a larger size of the same shoe just returned").

Pipeline

  • LabelHints are populated client-side using straightforward, application-specific heuristics.

  • Labels (label1-5) are populated on the backend after story beats from all browser tabs are consolidated into a single user-level stream. Labels are populated based on available heuristics and the clarity of contextual clues. Higher-level labels may be backfilled as user intentions become clearer over time.

  • Portlets group adjacent story beats into hierarchical clusters if they share identical label values at each layer (label2, label3, etc.).

Note: Attributes and pipeline population methods vary depending on the technology monitored (e.g., Microsoft, Shopify, Siebel, WordPress).

Service: Analytics

Feature Availability: 8.6.0 or later

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.