Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
171 lines
8.0 KiB
JSON
171 lines
8.0 KiB
JSON
[
|
|
{
|
|
"id": "F001",
|
|
"description": "Register a new `transform.compose_text` action in the standard workflow transform catalog.",
|
|
"implemented": true,
|
|
"prdRefs": ["Summary", "Requirements > Functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F002",
|
|
"description": "Place `transform.compose_text` in the Transform category with action metadata that makes it discoverable as a standard reusable transform rather than an AI-specific feature.",
|
|
"implemented": true,
|
|
"prdRefs": ["Problem", "Goals", "Users and Primary Flows"]
|
|
},
|
|
{
|
|
"id": "F003",
|
|
"description": "Define a persisted compose-text step config that stores multiple outputs in one step.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F004",
|
|
"description": "Represent each composed output with a freeform author label, stable reference-safe key, and Alga-owned template document payload.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F005",
|
|
"description": "Generate a unique stable reference-safe key automatically when an output is created from its freeform label.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F006",
|
|
"description": "Preserve stable reference-safe keys across later label edits unless the author explicitly regenerates them.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F007",
|
|
"description": "Validate compose-text outputs so labels are non-empty and unique within a step.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F008",
|
|
"description": "Validate compose-text outputs so stable reference-safe keys are non-empty, unique, and safe for downstream workflow path usage.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Non-functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F009",
|
|
"description": "Define an Alga-owned template document model for markdown-capable text composition that is independent of BlockNote storage formats.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F010",
|
|
"description": "Limit the template document model to markdown-compatible text structures and inline reference nodes rather than arbitrary rich-document concepts.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Non-functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F011",
|
|
"description": "Support simple workflow references as inline template nodes without permitting arbitrary expressions or nested transform definitions inside the composer.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Security / Permissions"]
|
|
},
|
|
{
|
|
"id": "F012",
|
|
"description": "Provide a constrained BlockNote-based editor surface for compose-text authoring that hydrates from the template document model and serializes back to it.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "UX / UI Notes", "Architecture"]
|
|
},
|
|
{
|
|
"id": "F013",
|
|
"description": "Add a custom inline reference placeholder node to the constrained editor so references appear as inline chips instead of raw placeholder strings.",
|
|
"implemented": true,
|
|
"prdRefs": ["UX / UI Notes", "Architecture"]
|
|
},
|
|
{
|
|
"id": "F014",
|
|
"description": "Restrict the compose-text editor to markdown-safe authoring features and remove media, attachments, tables, and other unsupported BlockNote affordances.",
|
|
"implemented": true,
|
|
"prdRefs": ["Non-goals", "UX / UI Notes", "Requirements > Functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F015",
|
|
"description": "Provide dedicated output-list authoring controls for adding, removing, reordering, and selecting multiple composed outputs within one step.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "UX / UI Notes"]
|
|
},
|
|
{
|
|
"id": "F016",
|
|
"description": "Provide authoring controls for editing freeform output labels and surfacing the generated stable reference-safe keys alongside copyable reference paths.",
|
|
"implemented": true,
|
|
"prdRefs": ["UX / UI Notes", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F017",
|
|
"description": "Let authors insert references into compose-text outputs from the existing workflow source/reference browser instead of typing reference paths manually.",
|
|
"implemented": true,
|
|
"prdRefs": ["Users and Primary Flows", "UX / UI Notes", "Architecture"]
|
|
},
|
|
{
|
|
"id": "F018",
|
|
"description": "Surface inline authoring validation for duplicate labels, duplicate stable keys, and invalid or unsupported reference insertions in the compose-text editor.",
|
|
"implemented": true,
|
|
"prdRefs": ["UX / UI Notes", "Requirements > Functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F019",
|
|
"description": "Render the Alga-owned template document model to markdown strings at runtime rather than leaking BlockNote JSON or placeholder syntax into workflow execution.",
|
|
"implemented": true,
|
|
"prdRefs": ["Summary", "Goals", "Requirements > Functional Requirements"]
|
|
},
|
|
{
|
|
"id": "F020",
|
|
"description": "Resolve reference nodes in compose-text outputs against normal workflow runtime context during execution.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Architecture"]
|
|
},
|
|
{
|
|
"id": "F021",
|
|
"description": "Fail compose-text execution explicitly when any referenced value is missing and include enough context to identify the failing output and reference.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Requirements > Functional Requirements", "Acceptance Criteria (Definition of Done)"]
|
|
},
|
|
{
|
|
"id": "F022",
|
|
"description": "Return compose-text results as a plain object of markdown strings keyed by stable reference-safe keys.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F023",
|
|
"description": "Provide a publish-time/runtime output schema strategy for compose-text that accepts markdown-string objects while remaining compatible with action registry validation.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F024",
|
|
"description": "Extend dynamic action output schema resolution so compose-text exposes configured markdown string fields rather than a generic catch-all object.",
|
|
"implemented": true,
|
|
"prdRefs": ["Requirements > Functional Requirements", "Architecture", "Data / API / Integrations"]
|
|
},
|
|
{
|
|
"id": "F025",
|
|
"description": "Extend workflow data-context building and downstream reference browsing so compose-text outputs appear under `vars.<saveAs>.<stableKey>` with the correct field types.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Requirements > Functional Requirements", "Acceptance Criteria (Definition of Done)"]
|
|
},
|
|
{
|
|
"id": "F026",
|
|
"description": "Ensure consuming action fields such as AI prompts and email content can use compose-text outputs through ordinary reference mapping without adding field-specific integration logic.",
|
|
"implemented": true,
|
|
"prdRefs": ["Problem", "Goals", "Acceptance Criteria (Definition of Done)"]
|
|
},
|
|
{
|
|
"id": "F027",
|
|
"description": "Keep compose-text authoring confined to the dedicated transform action editor rather than embedding the composer directly into consuming field editors in this phase.",
|
|
"implemented": true,
|
|
"prdRefs": ["Non-goals", "UX / UI Notes"]
|
|
},
|
|
{
|
|
"id": "F028",
|
|
"description": "Maintain a clean separation where BlockNote is an authoring-only surface and no BlockNote node shapes or storage concepts leak into persisted workflow step config or runtime outputs.",
|
|
"implemented": true,
|
|
"prdRefs": ["Goals", "Requirements > Non-functional Requirements", "Acceptance Criteria (Definition of Done)"]
|
|
}
|
|
]
|