name: prowler-tour description: > Keeps product-tour definitions aligned with the UI features they describe. Trigger: When modifying UI components that have associated tours, editing tour definition files, or renaming data-tour-id attributes. license: Apache-2.0 metadata: author: prowler-cloud version: "1.0" scope: [root, ui] auto_invoke: - "Editing a UI file containing data-tour-id attributes" - "Adding, updating, or removing a tour definition (*.tour.ts)" - "Renaming or removing a data-tour-id attribute value" - "Changing button labels or section headings on a tour-covered page" - "Restructuring routes or layouts covered by a tour"
allowed-tools: Read, Glob, Grep
prowler-tour
Report-only. This skill never edits tour files or UI files; it inspects the change, reports drift it finds between tours and the covered UI, and recommends actions for the developer to apply.
Early-exit rule
Run this check first. Most UI edits are not tour-related — exit cheaply.
Glob
ui/lib/tours/*.tour.ts.For each tour, check whether any
coversFilesglob pattern matches any file in the current change.If no tour matches, respond exactly:
No tour affected — skipping alignment check
and exit. Do not proceed to the checklist.
If at least one tour matches, continue to "Drift checklist" for that tour.
Drift checklist
For each affected tour, evaluate every item. Skip items that obviously do not apply, but list explicitly which items were checked.
- Orphan selectors — every step's
target(which composes todata-tour-id="<tour-id>-<step.target>") must resolve to a real element in the codebase. Grepui/for the expected attribute value; report any step whose target is missing. - Renamed selectors — a
data-tour-idattribute was edited in this change. Match it back to any tour step referencing the old value. - Outdated copy — a popover
title/descriptionreferences a button label, heading, or term that no longer exists on the covered page. - Obsolete steps — a step describes a section, panel, or workflow that was removed.
- Missing steps — a new feature was added on the covered surface without a corresponding step (e.g. a new panel, a new primary action, a new wizard stage).
- Reordered flow — the user's path through the feature changed (e.g. query builder moved before scan selection) and the step order no longer reflects it.
Version-bump decision tree
Apply per tour after listing drift:
- NO bump when the change is cosmetic. Examples: fix a typo, soften
copy, rename a
data-tour-idselector while keeping the same step, swap one screenshot for another, tighten wording. - BUMP
versionwhen the user-visible flow changes materially. Examples: a new step was added or removed; the order changed; an anchored target was retargeted to a different panel; the tour now covers a new feature on the surface.
When in doubt, ask: "Would a user who already saw the previous version miss something useful by not seeing this one?" If yes, bump.
Output format
When emitting a report, follow the exact structure in
references/output-format.md. The structure is mandatory because the
report is consumed downstream and tolerates no field reordering.
What this skill MUST NOT do
- Do not edit
*.tour.tsfiles. This skill is report-only. - Do not edit UI files to add or rename
data-tour-idattributes. - Do not invent new tours. Authoring a new tour is a separate, deliberate decision — the developer makes it, not the skill.
- Do not flag drift in tours whose
coversFilesdo not match any file in the current change. Stick to the early-exit rule.
See also
references/output-format.md— exact report template (read when emitting a report).references/tours-architecture.md— code map for the tour abstraction underui/lib/tours/.assets/tour-template.ts— boilerplate for authoring a new*.tour.ts.