mirror of
https://github.com/xtr-dev/payload-automation.git
synced 2025-12-10 00:43:23 +00:00
Fix TypeScript and ESLint errors, resolve component imports
- Fix TypeScript types in trigger-helpers with proper interfaces - Remove all ESLint no-explicit-any warnings with better typing - Fix component import paths from @/components/* to relative paths - Regenerate import map with correct component references - All compilation and linting errors resolved
This commit is contained in:
@@ -1,5 +1,9 @@
|
|||||||
|
import { default as default_4845c503d8eeb95a2cf39d519276b9b7 } from '../../../../../components/WorkflowExecutionStatus'
|
||||||
|
import { default as default_28774f13376b69227276b43eee64e5a1 } from '../../../../../components/StatusCell'
|
||||||
|
import { default as default_623fcff70b12e3e87839f97bf237499a } from '../../../../../components/ErrorDisplay'
|
||||||
|
|
||||||
export const importMap = {
|
export const importMap = {
|
||||||
|
"../components/WorkflowExecutionStatus#default": default_4845c503d8eeb95a2cf39d519276b9b7,
|
||||||
|
"../components/StatusCell#default": default_28774f13376b69227276b43eee64e5a1,
|
||||||
|
"../components/ErrorDisplay#default": default_623fcff70b12e3e87839f97bf237499a
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -92,7 +92,7 @@ export interface Config {
|
|||||||
'payload-migrations': PayloadMigrationsSelect<false> | PayloadMigrationsSelect<true>;
|
'payload-migrations': PayloadMigrationsSelect<false> | PayloadMigrationsSelect<true>;
|
||||||
};
|
};
|
||||||
db: {
|
db: {
|
||||||
defaultIDType: number;
|
defaultIDType: string;
|
||||||
};
|
};
|
||||||
globals: {};
|
globals: {};
|
||||||
globalsSelect: {};
|
globalsSelect: {};
|
||||||
@@ -136,7 +136,7 @@ export interface UserAuthOperations {
|
|||||||
* via the `definition` "posts".
|
* via the `definition` "posts".
|
||||||
*/
|
*/
|
||||||
export interface Post {
|
export interface Post {
|
||||||
id: number;
|
id: string;
|
||||||
content?: string | null;
|
content?: string | null;
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
@@ -146,7 +146,7 @@ export interface Post {
|
|||||||
* via the `definition` "media".
|
* via the `definition` "media".
|
||||||
*/
|
*/
|
||||||
export interface Media {
|
export interface Media {
|
||||||
id: number;
|
id: string;
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
url?: string | null;
|
url?: string | null;
|
||||||
@@ -164,9 +164,9 @@ export interface Media {
|
|||||||
* via the `definition` "auditLog".
|
* via the `definition` "auditLog".
|
||||||
*/
|
*/
|
||||||
export interface AuditLog {
|
export interface AuditLog {
|
||||||
id: number;
|
id: string;
|
||||||
post?: (number | null) | Post;
|
post?: (string | null) | Post;
|
||||||
user?: (number | null) | User;
|
user?: (string | null) | User;
|
||||||
message?: string | null;
|
message?: string | null;
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
@@ -176,7 +176,7 @@ export interface AuditLog {
|
|||||||
* via the `definition` "users".
|
* via the `definition` "users".
|
||||||
*/
|
*/
|
||||||
export interface User {
|
export interface User {
|
||||||
id: number;
|
id: string;
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
email: string;
|
email: string;
|
||||||
@@ -202,7 +202,7 @@ export interface User {
|
|||||||
* via the `definition` "workflows".
|
* via the `definition` "workflows".
|
||||||
*/
|
*/
|
||||||
export interface Workflow {
|
export interface Workflow {
|
||||||
id: number;
|
id: string;
|
||||||
/**
|
/**
|
||||||
* Human-readable name for the workflow
|
* Human-readable name for the workflow
|
||||||
*/
|
*/
|
||||||
@@ -214,36 +214,45 @@ export interface Workflow {
|
|||||||
triggers?:
|
triggers?:
|
||||||
| {
|
| {
|
||||||
type?: ('collection-trigger' | 'webhook-trigger' | 'global-trigger' | 'cron-trigger') | null;
|
type?: ('collection-trigger' | 'webhook-trigger' | 'global-trigger' | 'cron-trigger') | null;
|
||||||
|
parameters?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
/**
|
/**
|
||||||
* Collection that triggers the workflow
|
* Collection that triggers the workflow
|
||||||
*/
|
*/
|
||||||
collectionSlug?: ('posts' | 'media') | null;
|
__builtin_collectionSlug?: ('posts' | 'media') | null;
|
||||||
/**
|
/**
|
||||||
* Collection operation that triggers the workflow
|
* Collection operation that triggers the workflow
|
||||||
*/
|
*/
|
||||||
operation?: ('create' | 'delete' | 'read' | 'update') | null;
|
__builtin_operation?: ('create' | 'delete' | 'read' | 'update') | null;
|
||||||
/**
|
/**
|
||||||
* URL path for the webhook (e.g., "my-webhook"). Full URL will be /api/workflows/webhook/my-webhook
|
* URL path for the webhook (e.g., "my-webhook"). Full URL will be /api/workflows-webhook/my-webhook
|
||||||
*/
|
*/
|
||||||
webhookPath?: string | null;
|
__builtin_webhookPath?: string | null;
|
||||||
/**
|
/**
|
||||||
* Global that triggers the workflow
|
* Global that triggers the workflow
|
||||||
*/
|
*/
|
||||||
global?: string | null;
|
__builtin_global?: string | null;
|
||||||
/**
|
/**
|
||||||
* Global operation that triggers the workflow
|
* Global operation that triggers the workflow
|
||||||
*/
|
*/
|
||||||
globalOperation?: 'update' | null;
|
__builtin_globalOperation?: 'update' | null;
|
||||||
/**
|
/**
|
||||||
* Cron expression for scheduled execution (e.g., "0 0 * * *" for daily at midnight)
|
* Cron expression for scheduled execution (e.g., "0 0 * * *" for daily at midnight)
|
||||||
*/
|
*/
|
||||||
cronExpression?: string | null;
|
__builtin_cronExpression?: string | null;
|
||||||
/**
|
/**
|
||||||
* Timezone for cron execution (e.g., "America/New_York", "Europe/London"). Defaults to UTC.
|
* Timezone for cron execution (e.g., "America/New_York", "Europe/London"). Defaults to UTC.
|
||||||
*/
|
*/
|
||||||
timezone?: string | null;
|
__builtin_timezone?: string | null;
|
||||||
/**
|
/**
|
||||||
* JSONPath expression that must evaluate to true for this trigger to execute the workflow (e.g., "$.doc.status == 'published'")
|
* JSONPath expression that must evaluate to true for this trigger to execute the workflow (e.g., "$.trigger.doc.status == 'published'")
|
||||||
*/
|
*/
|
||||||
condition?: string | null;
|
condition?: string | null;
|
||||||
id?: string | null;
|
id?: string | null;
|
||||||
@@ -253,7 +262,18 @@ export interface Workflow {
|
|||||||
| {
|
| {
|
||||||
step?: ('http-request-step' | 'create-document') | null;
|
step?: ('http-request-step' | 'create-document') | null;
|
||||||
name?: string | null;
|
name?: string | null;
|
||||||
input?:
|
/**
|
||||||
|
* The URL to make the HTTP request to
|
||||||
|
*/
|
||||||
|
url?: string | null;
|
||||||
|
/**
|
||||||
|
* HTTP method to use
|
||||||
|
*/
|
||||||
|
method?: ('GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH') | null;
|
||||||
|
/**
|
||||||
|
* HTTP headers as JSON object (e.g., {"Content-Type": "application/json"})
|
||||||
|
*/
|
||||||
|
headers?:
|
||||||
| {
|
| {
|
||||||
[k: string]: unknown;
|
[k: string]: unknown;
|
||||||
}
|
}
|
||||||
@@ -262,6 +282,80 @@ export interface Workflow {
|
|||||||
| number
|
| number
|
||||||
| boolean
|
| boolean
|
||||||
| null;
|
| null;
|
||||||
|
/**
|
||||||
|
* Request body data. Use JSONPath to reference values (e.g., {"postId": "$.trigger.doc.id", "title": "$.trigger.doc.title"})
|
||||||
|
*/
|
||||||
|
body?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Request timeout in milliseconds (default: 30000)
|
||||||
|
*/
|
||||||
|
timeout?: number | null;
|
||||||
|
authentication?: {
|
||||||
|
/**
|
||||||
|
* Authentication method
|
||||||
|
*/
|
||||||
|
type?: ('none' | 'bearer' | 'basic' | 'apikey') | null;
|
||||||
|
/**
|
||||||
|
* Bearer token value
|
||||||
|
*/
|
||||||
|
token?: string | null;
|
||||||
|
/**
|
||||||
|
* Basic auth username
|
||||||
|
*/
|
||||||
|
username?: string | null;
|
||||||
|
/**
|
||||||
|
* Basic auth password
|
||||||
|
*/
|
||||||
|
password?: string | null;
|
||||||
|
/**
|
||||||
|
* API key header name (e.g., "X-API-Key")
|
||||||
|
*/
|
||||||
|
headerName?: string | null;
|
||||||
|
/**
|
||||||
|
* API key value
|
||||||
|
*/
|
||||||
|
headerValue?: string | null;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Number of retry attempts on failure (max: 5)
|
||||||
|
*/
|
||||||
|
retries?: number | null;
|
||||||
|
/**
|
||||||
|
* Delay between retries in milliseconds
|
||||||
|
*/
|
||||||
|
retryDelay?: number | null;
|
||||||
|
/**
|
||||||
|
* The collection slug to create a document in
|
||||||
|
*/
|
||||||
|
collectionSlug?: string | null;
|
||||||
|
/**
|
||||||
|
* The document data to create. Use JSONPath to reference trigger data (e.g., {"title": "$.trigger.doc.title", "author": "$.trigger.doc.author"})
|
||||||
|
*/
|
||||||
|
data?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Create as draft (if collection has drafts enabled)
|
||||||
|
*/
|
||||||
|
draft?: boolean | null;
|
||||||
|
/**
|
||||||
|
* Locale for the document (if localization is enabled)
|
||||||
|
*/
|
||||||
|
locale?: string | null;
|
||||||
/**
|
/**
|
||||||
* Step names that must complete before this step can run
|
* Step names that must complete before this step can run
|
||||||
*/
|
*/
|
||||||
@@ -282,11 +376,11 @@ export interface Workflow {
|
|||||||
* via the `definition` "workflow-runs".
|
* via the `definition` "workflow-runs".
|
||||||
*/
|
*/
|
||||||
export interface WorkflowRun {
|
export interface WorkflowRun {
|
||||||
id: number;
|
id: string;
|
||||||
/**
|
/**
|
||||||
* Reference to the workflow that was executed
|
* Reference to the workflow that was executed
|
||||||
*/
|
*/
|
||||||
workflow: number | Workflow;
|
workflow: string | Workflow;
|
||||||
/**
|
/**
|
||||||
* Version of the workflow that was executed
|
* Version of the workflow that was executed
|
||||||
*/
|
*/
|
||||||
@@ -380,7 +474,7 @@ export interface WorkflowRun {
|
|||||||
* via the `definition` "payload-jobs".
|
* via the `definition` "payload-jobs".
|
||||||
*/
|
*/
|
||||||
export interface PayloadJob {
|
export interface PayloadJob {
|
||||||
id: number;
|
id: string;
|
||||||
/**
|
/**
|
||||||
* Input data provided to the job
|
* Input data provided to the job
|
||||||
*/
|
*/
|
||||||
@@ -472,40 +566,40 @@ export interface PayloadJob {
|
|||||||
* via the `definition` "payload-locked-documents".
|
* via the `definition` "payload-locked-documents".
|
||||||
*/
|
*/
|
||||||
export interface PayloadLockedDocument {
|
export interface PayloadLockedDocument {
|
||||||
id: number;
|
id: string;
|
||||||
document?:
|
document?:
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'posts';
|
relationTo: 'posts';
|
||||||
value: number | Post;
|
value: string | Post;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'media';
|
relationTo: 'media';
|
||||||
value: number | Media;
|
value: string | Media;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'auditLog';
|
relationTo: 'auditLog';
|
||||||
value: number | AuditLog;
|
value: string | AuditLog;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'workflows';
|
relationTo: 'workflows';
|
||||||
value: number | Workflow;
|
value: string | Workflow;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'workflow-runs';
|
relationTo: 'workflow-runs';
|
||||||
value: number | WorkflowRun;
|
value: string | WorkflowRun;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'users';
|
relationTo: 'users';
|
||||||
value: number | User;
|
value: string | User;
|
||||||
} | null)
|
} | null)
|
||||||
| ({
|
| ({
|
||||||
relationTo: 'payload-jobs';
|
relationTo: 'payload-jobs';
|
||||||
value: number | PayloadJob;
|
value: string | PayloadJob;
|
||||||
} | null);
|
} | null);
|
||||||
globalSlug?: string | null;
|
globalSlug?: string | null;
|
||||||
user: {
|
user: {
|
||||||
relationTo: 'users';
|
relationTo: 'users';
|
||||||
value: number | User;
|
value: string | User;
|
||||||
};
|
};
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
createdAt: string;
|
createdAt: string;
|
||||||
@@ -515,10 +609,10 @@ export interface PayloadLockedDocument {
|
|||||||
* via the `definition` "payload-preferences".
|
* via the `definition` "payload-preferences".
|
||||||
*/
|
*/
|
||||||
export interface PayloadPreference {
|
export interface PayloadPreference {
|
||||||
id: number;
|
id: string;
|
||||||
user: {
|
user: {
|
||||||
relationTo: 'users';
|
relationTo: 'users';
|
||||||
value: number | User;
|
value: string | User;
|
||||||
};
|
};
|
||||||
key?: string | null;
|
key?: string | null;
|
||||||
value?:
|
value?:
|
||||||
@@ -538,7 +632,7 @@ export interface PayloadPreference {
|
|||||||
* via the `definition` "payload-migrations".
|
* via the `definition` "payload-migrations".
|
||||||
*/
|
*/
|
||||||
export interface PayloadMigration {
|
export interface PayloadMigration {
|
||||||
id: number;
|
id: string;
|
||||||
name?: string | null;
|
name?: string | null;
|
||||||
batch?: number | null;
|
batch?: number | null;
|
||||||
updatedAt: string;
|
updatedAt: string;
|
||||||
@@ -592,13 +686,14 @@ export interface WorkflowsSelect<T extends boolean = true> {
|
|||||||
| T
|
| T
|
||||||
| {
|
| {
|
||||||
type?: T;
|
type?: T;
|
||||||
collectionSlug?: T;
|
parameters?: T;
|
||||||
operation?: T;
|
__builtin_collectionSlug?: T;
|
||||||
webhookPath?: T;
|
__builtin_operation?: T;
|
||||||
global?: T;
|
__builtin_webhookPath?: T;
|
||||||
globalOperation?: T;
|
__builtin_global?: T;
|
||||||
cronExpression?: T;
|
__builtin_globalOperation?: T;
|
||||||
timezone?: T;
|
__builtin_cronExpression?: T;
|
||||||
|
__builtin_timezone?: T;
|
||||||
condition?: T;
|
condition?: T;
|
||||||
id?: T;
|
id?: T;
|
||||||
};
|
};
|
||||||
@@ -607,7 +702,27 @@ export interface WorkflowsSelect<T extends boolean = true> {
|
|||||||
| {
|
| {
|
||||||
step?: T;
|
step?: T;
|
||||||
name?: T;
|
name?: T;
|
||||||
input?: T;
|
url?: T;
|
||||||
|
method?: T;
|
||||||
|
headers?: T;
|
||||||
|
body?: T;
|
||||||
|
timeout?: T;
|
||||||
|
authentication?:
|
||||||
|
| T
|
||||||
|
| {
|
||||||
|
type?: T;
|
||||||
|
token?: T;
|
||||||
|
username?: T;
|
||||||
|
password?: T;
|
||||||
|
headerName?: T;
|
||||||
|
headerValue?: T;
|
||||||
|
};
|
||||||
|
retries?: T;
|
||||||
|
retryDelay?: T;
|
||||||
|
collectionSlug?: T;
|
||||||
|
data?: T;
|
||||||
|
draft?: T;
|
||||||
|
locale?: T;
|
||||||
dependencies?: T;
|
dependencies?: T;
|
||||||
condition?: T;
|
condition?: T;
|
||||||
id?: T;
|
id?: T;
|
||||||
@@ -736,10 +851,118 @@ export interface TaskWorkflowCronExecutor {
|
|||||||
*/
|
*/
|
||||||
export interface TaskHttpRequestStep {
|
export interface TaskHttpRequestStep {
|
||||||
input: {
|
input: {
|
||||||
url?: string | null;
|
/**
|
||||||
|
* The URL to make the HTTP request to
|
||||||
|
*/
|
||||||
|
url: string;
|
||||||
|
/**
|
||||||
|
* HTTP method to use
|
||||||
|
*/
|
||||||
|
method?: ('GET' | 'POST' | 'PUT' | 'DELETE' | 'PATCH') | null;
|
||||||
|
/**
|
||||||
|
* HTTP headers as JSON object (e.g., {"Content-Type": "application/json"})
|
||||||
|
*/
|
||||||
|
headers?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Request body data. Use JSONPath to reference values (e.g., {"postId": "$.trigger.doc.id", "title": "$.trigger.doc.title"})
|
||||||
|
*/
|
||||||
|
body?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Request timeout in milliseconds (default: 30000)
|
||||||
|
*/
|
||||||
|
timeout?: number | null;
|
||||||
|
authentication?: {
|
||||||
|
/**
|
||||||
|
* Authentication method
|
||||||
|
*/
|
||||||
|
type?: ('none' | 'bearer' | 'basic' | 'apikey') | null;
|
||||||
|
/**
|
||||||
|
* Bearer token value
|
||||||
|
*/
|
||||||
|
token?: string | null;
|
||||||
|
/**
|
||||||
|
* Basic auth username
|
||||||
|
*/
|
||||||
|
username?: string | null;
|
||||||
|
/**
|
||||||
|
* Basic auth password
|
||||||
|
*/
|
||||||
|
password?: string | null;
|
||||||
|
/**
|
||||||
|
* API key header name (e.g., "X-API-Key")
|
||||||
|
*/
|
||||||
|
headerName?: string | null;
|
||||||
|
/**
|
||||||
|
* API key value
|
||||||
|
*/
|
||||||
|
headerValue?: string | null;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Number of retry attempts on failure (max: 5)
|
||||||
|
*/
|
||||||
|
retries?: number | null;
|
||||||
|
/**
|
||||||
|
* Delay between retries in milliseconds
|
||||||
|
*/
|
||||||
|
retryDelay?: number | null;
|
||||||
};
|
};
|
||||||
output: {
|
output: {
|
||||||
response?: string | null;
|
/**
|
||||||
|
* HTTP status code
|
||||||
|
*/
|
||||||
|
status?: number | null;
|
||||||
|
/**
|
||||||
|
* HTTP status text
|
||||||
|
*/
|
||||||
|
statusText?: string | null;
|
||||||
|
/**
|
||||||
|
* Response headers
|
||||||
|
*/
|
||||||
|
headers?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Response body
|
||||||
|
*/
|
||||||
|
body?: string | null;
|
||||||
|
/**
|
||||||
|
* Parsed response data (if JSON)
|
||||||
|
*/
|
||||||
|
data?:
|
||||||
|
| {
|
||||||
|
[k: string]: unknown;
|
||||||
|
}
|
||||||
|
| unknown[]
|
||||||
|
| string
|
||||||
|
| number
|
||||||
|
| boolean
|
||||||
|
| null;
|
||||||
|
/**
|
||||||
|
* Request duration in milliseconds
|
||||||
|
*/
|
||||||
|
duration?: number | null;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
@@ -753,7 +976,7 @@ export interface TaskCreateDocument {
|
|||||||
*/
|
*/
|
||||||
collectionSlug: string;
|
collectionSlug: string;
|
||||||
/**
|
/**
|
||||||
* The document data to create
|
* The document data to create. Use JSONPath to reference trigger data (e.g., {"title": "$.trigger.doc.title", "author": "$.trigger.doc.author"})
|
||||||
*/
|
*/
|
||||||
data:
|
data:
|
||||||
| {
|
| {
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ export const createWorkflowCollection: <T extends string>(options: WorkflowsPlug
|
|||||||
type: 'ui',
|
type: 'ui',
|
||||||
admin: {
|
admin: {
|
||||||
components: {
|
components: {
|
||||||
Field: '@/components/WorkflowExecutionStatus'
|
Field: '../components/WorkflowExecutionStatus'
|
||||||
},
|
},
|
||||||
condition: (data) => !!data?.id // Only show for existing workflows
|
condition: (data) => !!data?.id // Only show for existing workflows
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ export const WorkflowRunsCollection: CollectionConfig = {
|
|||||||
admin: {
|
admin: {
|
||||||
description: 'Current execution status',
|
description: 'Current execution status',
|
||||||
components: {
|
components: {
|
||||||
Cell: '@/components/StatusCell'
|
Cell: '../components/StatusCell'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
defaultValue: 'pending',
|
defaultValue: 'pending',
|
||||||
@@ -141,7 +141,7 @@ export const WorkflowRunsCollection: CollectionConfig = {
|
|||||||
description: 'Error message if workflow execution failed',
|
description: 'Error message if workflow execution failed',
|
||||||
condition: (_, siblingData) => siblingData?.status === 'failed',
|
condition: (_, siblingData) => siblingData?.status === 'failed',
|
||||||
components: {
|
components: {
|
||||||
Field: '@/components/ErrorDisplay'
|
Field: '../components/ErrorDisplay'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -166,14 +166,15 @@ export const ErrorDisplay: React.FC<ErrorDisplayProps> = ({
|
|||||||
|
|
||||||
{/* Technical Details Toggle */}
|
{/* Technical Details Toggle */}
|
||||||
<div>
|
<div>
|
||||||
<Button
|
<div style={{ marginBottom: expanded ? '12px' : '0' }}>
|
||||||
onClick={() => setExpanded(!expanded)}
|
<Button
|
||||||
size="small"
|
onClick={() => setExpanded(!expanded)}
|
||||||
buttonStyle="secondary"
|
size="small"
|
||||||
style={{ marginBottom: expanded ? '12px' : '0' }}
|
buttonStyle="secondary"
|
||||||
>
|
>
|
||||||
{expanded ? 'Hide' : 'Show'} Technical Details
|
{expanded ? 'Hide' : 'Show'} Technical Details
|
||||||
</Button>
|
</Button>
|
||||||
|
</div>
|
||||||
|
|
||||||
{expanded && (
|
{expanded && (
|
||||||
<div style={{
|
<div style={{
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
export { TriggerWorkflowButton } from '../components/TriggerWorkflowButton.js'
|
export { TriggerWorkflowButton } from '../components/TriggerWorkflowButton.js'
|
||||||
export { StatusCell } from '../components/StatusCell.js'
|
export { StatusCell } from '../components/StatusCell.js'
|
||||||
// export { ErrorDisplay } from '../components/ErrorDisplay.js' // Temporarily disabled
|
export { ErrorDisplay } from '../components/ErrorDisplay.js'
|
||||||
export { WorkflowExecutionStatus } from '../components/WorkflowExecutionStatus.js'
|
export { WorkflowExecutionStatus } from '../components/WorkflowExecutionStatus.js'
|
||||||
|
|
||||||
// Future client components can be added here:
|
// Future client components can be added here:
|
||||||
|
|||||||
@@ -1,6 +1,22 @@
|
|||||||
import type { Field } from 'payload'
|
import type { Field } from 'payload'
|
||||||
|
|
||||||
import type { CustomTriggerConfig } from '../plugin/config-types.js'
|
import type { CustomTriggerConfig } from '../plugin/config-types.js'
|
||||||
|
|
||||||
|
// Types for better type safety
|
||||||
|
interface FieldWithName {
|
||||||
|
name: string
|
||||||
|
[key: string]: unknown
|
||||||
|
}
|
||||||
|
|
||||||
|
interface HookContext {
|
||||||
|
siblingData: Record<string, unknown>
|
||||||
|
value?: unknown
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ValidationContext {
|
||||||
|
siblingData: Record<string, unknown>
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a virtual field for a trigger parameter that stores its value in the parameters JSON field
|
* Creates a virtual field for a trigger parameter that stores its value in the parameters JSON field
|
||||||
*
|
*
|
||||||
@@ -25,7 +41,7 @@ import type { CustomTriggerConfig } from '../plugin/config-types.js'
|
|||||||
* }
|
* }
|
||||||
* ```
|
* ```
|
||||||
*/
|
*/
|
||||||
export function createTriggerField(field: any, triggerSlug: string): Field {
|
export function createTriggerField(field: FieldWithName, triggerSlug: string): Field {
|
||||||
const originalName = field.name
|
const originalName = field.name
|
||||||
if (!originalName) {
|
if (!originalName) {
|
||||||
throw new Error('Field must have a name property')
|
throw new Error('Field must have a name property')
|
||||||
@@ -34,61 +50,70 @@ export function createTriggerField(field: any, triggerSlug: string): Field {
|
|||||||
// Create a unique field name by prefixing with trigger slug
|
// Create a unique field name by prefixing with trigger slug
|
||||||
const uniqueFieldName = `__trigger_${triggerSlug}_${originalName}`
|
const uniqueFieldName = `__trigger_${triggerSlug}_${originalName}`
|
||||||
|
|
||||||
const resultField: any = {
|
const resultField: Record<string, unknown> = {
|
||||||
...field,
|
...field,
|
||||||
name: uniqueFieldName,
|
|
||||||
virtual: true,
|
|
||||||
admin: {
|
admin: {
|
||||||
...(field.admin || {}),
|
...(field.admin as Record<string, unknown> || {}),
|
||||||
condition: (data: any, siblingData: any) => {
|
condition: (data: unknown, siblingData: Record<string, unknown>) => {
|
||||||
// Only show this field when the trigger type matches
|
// Only show this field when the trigger type matches
|
||||||
const triggerMatches = siblingData?.type === triggerSlug
|
const triggerMatches = siblingData?.type === triggerSlug
|
||||||
|
|
||||||
// If the original field had a condition, combine it with our trigger condition
|
// If the original field had a condition, combine it with our trigger condition
|
||||||
if (field.admin?.condition) {
|
const originalCondition = (field.admin as Record<string, unknown>)?.condition
|
||||||
return triggerMatches && field.admin.condition(data, siblingData)
|
if (originalCondition && typeof originalCondition === 'function') {
|
||||||
|
return triggerMatches && (originalCondition as (data: unknown, siblingData: Record<string, unknown>) => boolean)(data, siblingData)
|
||||||
}
|
}
|
||||||
|
|
||||||
return triggerMatches
|
return triggerMatches
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
hooks: {
|
hooks: {
|
||||||
...(field.hooks || {}),
|
...(field.hooks as Record<string, unknown[]> || {}),
|
||||||
afterRead: [
|
afterRead: [
|
||||||
...(field.hooks?.afterRead || []),
|
...((field.hooks as Record<string, unknown[]>)?.afterRead || []),
|
||||||
({ siblingData }: any) => {
|
({ siblingData }: HookContext) => {
|
||||||
// Read the value from the parameters JSON field
|
// Read the value from the parameters JSON field
|
||||||
return siblingData?.parameters?.[originalName] ?? field.defaultValue
|
const parameters = siblingData?.parameters as Record<string, unknown>
|
||||||
|
return parameters?.[originalName] ?? (field as Record<string, unknown>).defaultValue
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
beforeChange: [
|
beforeChange: [
|
||||||
...(field.hooks?.beforeChange || []),
|
...((field.hooks as Record<string, unknown[]>)?.beforeChange || []),
|
||||||
({ value, siblingData }: any) => {
|
({ siblingData, value }: HookContext) => {
|
||||||
// Store the value in the parameters JSON field
|
// Store the value in the parameters JSON field
|
||||||
if (!siblingData.parameters) {
|
if (!siblingData.parameters) {
|
||||||
siblingData.parameters = {}
|
siblingData.parameters = {}
|
||||||
}
|
}
|
||||||
siblingData.parameters[originalName] = value
|
const parameters = siblingData.parameters as Record<string, unknown>
|
||||||
|
parameters[originalName] = value
|
||||||
return undefined // Virtual field, don't store directly
|
return undefined // Virtual field, don't store directly
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
name: uniqueFieldName,
|
||||||
|
virtual: true,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only add validate if the field supports it (data fields)
|
// Only add validate if the field supports it (data fields)
|
||||||
if (field.validate || field.required) {
|
const hasValidation = (field as Record<string, unknown>).validate || (field as Record<string, unknown>).required
|
||||||
resultField.validate = (value: any, args: any) => {
|
if (hasValidation) {
|
||||||
const paramValue = value ?? args.siblingData?.parameters?.[originalName]
|
resultField.validate = (value: unknown, args: ValidationContext) => {
|
||||||
|
const parameters = args.siblingData?.parameters as Record<string, unknown>
|
||||||
|
const paramValue = value ?? parameters?.[originalName]
|
||||||
|
|
||||||
// Check required validation
|
// Check required validation
|
||||||
if (field.required && args.siblingData?.type === triggerSlug && !paramValue) {
|
const isRequired = (field as Record<string, unknown>).required
|
||||||
const label = field.label || field.admin?.description || originalName
|
if (isRequired && args.siblingData?.type === triggerSlug && !paramValue) {
|
||||||
|
const fieldLabel = (field as Record<string, unknown>).label as string
|
||||||
|
const adminDesc = ((field as Record<string, unknown>).admin as Record<string, unknown>)?.description as string
|
||||||
|
const label = fieldLabel || adminDesc || originalName
|
||||||
return `${label} is required for ${triggerSlug}`
|
return `${label} is required for ${triggerSlug}`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Run original validation if present
|
// Run original validation if present
|
||||||
if (field.validate) {
|
const originalValidate = (field as Record<string, unknown>).validate
|
||||||
return field.validate(paramValue, args)
|
if (originalValidate && typeof originalValidate === 'function') {
|
||||||
|
return (originalValidate as (value: unknown, args: ValidationContext) => boolean | string)(paramValue, args)
|
||||||
}
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
@@ -125,7 +150,7 @@ export function createTriggerField(field: any, triggerSlug: string): Field {
|
|||||||
* ])
|
* ])
|
||||||
* ```
|
* ```
|
||||||
*/
|
*/
|
||||||
export function createTrigger(slug: string, fields: Field[]): CustomTriggerConfig {
|
export function createTrigger(slug: string, fields: FieldWithName[]): CustomTriggerConfig {
|
||||||
return {
|
return {
|
||||||
slug,
|
slug,
|
||||||
inputs: fields.map(field => createTriggerField(field, slug))
|
inputs: fields.map(field => createTriggerField(field, slug))
|
||||||
|
|||||||
Reference in New Issue
Block a user