Hermes 284313f908
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
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

74 lines
2.1 KiB
TypeScript

import type { ExpressionMode } from './modes';
export type SharedExpressionValueType =
| 'string'
| 'number'
| 'integer'
| 'boolean'
| 'object'
| 'array'
| 'null'
| 'unknown';
export interface SharedExpressionSchemaNode {
type?: string | string[];
description?: string;
title?: string;
properties?: Record<string, SharedExpressionSchemaNode>;
items?: SharedExpressionSchemaNode;
required?: string[];
enum?: unknown[];
const?: unknown;
default?: unknown;
anyOf?: SharedExpressionSchemaNode[];
oneOf?: SharedExpressionSchemaNode[];
allOf?: SharedExpressionSchemaNode[];
additionalProperties?: boolean | SharedExpressionSchemaNode;
definitions?: Record<string, SharedExpressionSchemaNode>;
$ref?: string;
}
export interface SharedExpressionContextRoot {
key: string;
label: string;
description?: string;
schema?: SharedExpressionSchemaNode;
allowInModes?: ExpressionMode[];
metadata?: Record<string, string | number | boolean | null | undefined>;
}
export interface SharedExpressionPathOption {
root: string;
path: string;
label: string;
description?: string;
valueType: SharedExpressionValueType;
depth: number;
isLeaf: boolean;
segments: string[];
}
type SerializableContextRoot = Omit<SharedExpressionContextRoot, 'allowInModes'> & {
allowInModes?: ExpressionMode[];
};
const compareByKey = <T extends { key: string }>(a: T, b: T) => a.key.localeCompare(b.key);
const normalizeRoot = (root: SharedExpressionContextRoot): SerializableContextRoot => ({
...root,
allowInModes: root.allowInModes ? [...root.allowInModes] : undefined,
});
export const serializeExpressionContextRoots = (
roots: SharedExpressionContextRoot[],
spacing = 2
): string => {
const normalized = roots.map(normalizeRoot).sort(compareByKey);
return JSON.stringify(normalized, null, spacing);
};
export const deserializeExpressionContextRoots = (serialized: string): SharedExpressionContextRoot[] => {
const parsed = JSON.parse(serialized) as SerializableContextRoot[];
return parsed.map((root) => normalizeRoot(root)).sort(compareByKey);
};