TenantAtlas/apps/platform/.pnpm-store/v10/files/d2/d636c44fbc13b5b86351f6750533c3322adea53e8b9abe77adf53825310cb544a06a763e823f327ed07f7f7fa7c56c082274a30a669edbaa02296cd881f656
ahmido 1fec9c6f9d
Some checks failed
Main Confidence / confidence (push) Failing after 45s
feat: compress governance operator outcomes (#253)
## Summary
- introduce surface-aware compressed governance outcomes and reuse the shared truth/explanation seams for operator-first summaries
- apply the compressed outcome hierarchy across baseline, evidence, review, review-pack, canonical review/evidence, and artifact-oriented operation-run surfaces
- expand spec 214 fixtures and Pest coverage, and fix tenant-panel route assertions by generating explicit tenant-panel URLs in the affected Filament tests

## Validation
- `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent`
- focused governance compression suite from `specs/214-governance-outcome-compression/quickstart.md` passed (`68` tests, `445` assertions)
- `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Filament/InventoryItemResourceTest.php tests/Feature/Filament/BackupSetUiEnforcementTest.php tests/Feature/Filament/RestoreRunUiEnforcementTest.php` passed (`18` tests, `81` assertions)

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #253
2026-04-19 12:30:36 +00:00

68 lines
1.9 KiB
Plaintext

import { entityKind } from "../../entity.js";
import { getColumnNameAndConfig } from "../../utils.js";
import { MySqlDateBaseColumn, MySqlDateColumnBaseBuilder } from "./date.common.js";
class MySqlTimestampBuilder extends MySqlDateColumnBaseBuilder {
static [entityKind] = "MySqlTimestampBuilder";
constructor(name, config) {
super(name, "date", "MySqlTimestamp");
this.config.fsp = config?.fsp;
}
/** @internal */
build(table) {
return new MySqlTimestamp(
table,
this.config
);
}
}
class MySqlTimestamp extends MySqlDateBaseColumn {
static [entityKind] = "MySqlTimestamp";
fsp = this.config.fsp;
getSQLType() {
const precision = this.fsp === void 0 ? "" : `(${this.fsp})`;
return `timestamp${precision}`;
}
mapFromDriverValue(value) {
return /* @__PURE__ */ new Date(value + "+0000");
}
mapToDriverValue(value) {
return value.toISOString().slice(0, -1).replace("T", " ");
}
}
class MySqlTimestampStringBuilder extends MySqlDateColumnBaseBuilder {
static [entityKind] = "MySqlTimestampStringBuilder";
constructor(name, config) {
super(name, "string", "MySqlTimestampString");
this.config.fsp = config?.fsp;
}
/** @internal */
build(table) {
return new MySqlTimestampString(
table,
this.config
);
}
}
class MySqlTimestampString extends MySqlDateBaseColumn {
static [entityKind] = "MySqlTimestampString";
fsp = this.config.fsp;
getSQLType() {
const precision = this.fsp === void 0 ? "" : `(${this.fsp})`;
return `timestamp${precision}`;
}
}
function timestamp(a, b = {}) {
const { name, config } = getColumnNameAndConfig(a, b);
if (config?.mode === "string") {
return new MySqlTimestampStringBuilder(name, config);
}
return new MySqlTimestampBuilder(name, config);
}
export {
MySqlTimestamp,
MySqlTimestampBuilder,
MySqlTimestampString,
MySqlTimestampStringBuilder,
timestamp
};
//# sourceMappingURL=timestamp.js.map