ID:WORK-059Status:donePriority:highComplexity:moderateMilestone:v0.9.0
Metadata Dimensions on StructureEntry
Summary
Add three semantic metadata fields to the StructureEntry interface: metaType, metaRank, and sentimentMap. The identity transform reads these from rune configs and emits data-meta-type, data-meta-rank, and data-meta-sentiment attributes on generated badge elements. This is the foundation that enables themes to style every metadata badge generically with ~18 CSS rules.
Acceptance Criteria
StructureEntryinpackages/transform/src/types.tsgainsmetaType,metaRank, andsentimentMapoptional fields- Identity transform engine emits
data-meta-typewhenmetaTypeis present on a structure entry child - Identity transform engine emits
data-meta-rankwhenmetaRankis present - Identity transform engine resolves sentiment by looking up the current modifier value in
sentimentMap, emittingdata-meta-sentimentwhen a match exists - Existing structure entries without metadata fields continue to work unchanged (backwards compatible)
refrakt inspectoutput shows the new data attributes on badge elements- Unit tests in
packages/transform/test/verify metadata attribute emission for: status with sentiment, category without sentiment, temporal, quantity, tag, and id types
Approach
- Extend
StructureEntryinterface inpackages/transform/src/types.tswith the three optional fields - In
packages/transform/src/engine.ts, in the code path that processes structure entry children, add logic to: readmetaTypeand emitdata-meta-type, readmetaRankand emitdata-meta-rank, look up the current modifier value insentimentMapand emitdata-meta-sentimentif found - The existing
data-{modifier-name}attributes continue to be emitted as before — metadata attributes are additive
References
- SPEC-024 (Metadata System — Extending StructureEntry, Identity Transform)