diff --git a/frontend/console/src/features/modules/decls/DeclPanel.tsx b/frontend/console/src/features/modules/decls/DeclPanel.tsx index ab2e07ef53..37c70b342c 100644 --- a/frontend/console/src/features/modules/decls/DeclPanel.tsx +++ b/frontend/console/src/features/modules/decls/DeclPanel.tsx @@ -8,6 +8,8 @@ import { DataPanel } from './DataPanel' import { DatabasePanel } from './DatabasePanel' import { EnumPanel } from './EnumPanel' import { SecretPanel } from './SecretPanel' +import { SubscriptionPanel } from './SubscriptionPanel' +import { TopicPanel } from './TopicPanel' import { TypeAliasPanel } from './TypeAliasPanel' export const DeclPanel = () => { @@ -35,6 +37,10 @@ export const DeclPanel = () => { return case 'secret': return + case 'subscription': + return + case 'topic': + return case 'typeAlias': return case 'verb': diff --git a/frontend/console/src/features/modules/decls/SubscriptionPanel.tsx b/frontend/console/src/features/modules/decls/SubscriptionPanel.tsx new file mode 100644 index 0000000000..ea1ce0b01a --- /dev/null +++ b/frontend/console/src/features/modules/decls/SubscriptionPanel.tsx @@ -0,0 +1,16 @@ +import type { Subscription } from '../../../protos/xyz/block/ftl/v1/schema/schema_pb' +import { PanelHeader } from './PanelHeader' +import { RefLink } from './TypeEl' + +export const SubscriptionPanel = ({ value, moduleName, declName }: { value: Subscription; moduleName: string; declName: string }) => { + return ( +
+ + Subscription: {moduleName}.{declName} + +
+ To Topic: +
+
+ ) +} diff --git a/frontend/console/src/features/modules/decls/TopicPanel.tsx b/frontend/console/src/features/modules/decls/TopicPanel.tsx new file mode 100644 index 0000000000..914cd5a6d5 --- /dev/null +++ b/frontend/console/src/features/modules/decls/TopicPanel.tsx @@ -0,0 +1,16 @@ +import type { Topic } from '../../../protos/xyz/block/ftl/v1/schema/schema_pb' +import { PanelHeader } from './PanelHeader' +import { TypeEl } from './TypeEl' + +export const TopicPanel = ({ value, moduleName, declName }: { value: Topic; moduleName: string; declName: string }) => { + return ( +
+ + Topic: {moduleName}.{declName} + +
+ Event Type: +
+
+ ) +} diff --git a/frontend/console/src/features/modules/decls/TypeEl.tsx b/frontend/console/src/features/modules/decls/TypeEl.tsx index fb1c9acc8d..bb31fcf828 100644 --- a/frontend/console/src/features/modules/decls/TypeEl.tsx +++ b/frontend/console/src/features/modules/decls/TypeEl.tsx @@ -18,6 +18,18 @@ const TypeParams = ({ types }: { types?: (Type | undefined)[] }) => { ) } +export const RefLink = ({ r }: { r?: Ref }) => { + if (!r) { + return + } + return ( + + + + + ) +} + export const TypeEl = ({ t }: { t?: Type }) => { if (!t) { return '' @@ -51,12 +63,7 @@ export const TypeEl = ({ t }: { t?: Type }) => { ) case 'ref': - return ( - - - - - ) + return default: return t.value.case || '' }