Files
sim/apps/sim/tools/linear/list_comments.ts
Waleed f99518b837 feat(calcom): added calcom (#3070)
* feat(tools): added calcom

* added more triggers, tested

* updated regex in script for release to be more lenient

* fix(tag-dropdown): performance improvements and scroll bug fixes

- Add flatTagIndexMap for O(1) tag lookups (replaces O(n²) findIndex calls)
- Memoize caret position calculation to avoid DOM manipulation on every render
- Use refs for inputValue/cursorPosition to keep handleTagSelect callback stable
- Change itemRefs from index-based to tag-based keys to prevent stale refs
- Fix scroll jump in nested folders by removing scroll reset from registerFolder
- Add onFolderEnter callback for scroll reset when entering folder via keyboard
- Disable keyboard navigation wrap-around at boundaries
- Simplify selection reset to single effect on flatTagList.length change

Also:
- Add safeCompare utility for timing-safe string comparison
- Refactor webhook signature validation to use safeCompare

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* updated types

* fix(calcom): simplify required field constraints for booking attendee

The condition field already restricts these to calcom_create_booking,
so simplified to required: true. Per Cal.com API docs, email is optional
while name and timeZone are required.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* added tests

* updated folder multi select, updated calcom and github tools and docs generator script

* updated drag, updated outputs for tools, regen docs with nested docs script

* updated setup instructions links, destructure trigger outputs, fix text subblock styling

* updated docs gen script

* updated docs script

* updated docs script

* updated script

* remove destructuring of stripe webhook

* expanded wand textarea, updated calcom tools

---------

Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-29 20:37:30 -08:00

128 lines
2.9 KiB
TypeScript

import type { LinearListCommentsParams, LinearListCommentsResponse } from '@/tools/linear/types'
import { COMMENT_OUTPUT_PROPERTIES, PAGE_INFO_OUTPUT } from '@/tools/linear/types'
import type { ToolConfig } from '@/tools/types'
export const linearListCommentsTool: ToolConfig<
LinearListCommentsParams,
LinearListCommentsResponse
> = {
id: 'linear_list_comments',
name: 'Linear List Comments',
description: 'List all comments on an issue in Linear',
version: '1.0.0',
oauth: {
required: true,
provider: 'linear',
},
params: {
issueId: {
type: 'string',
required: true,
visibility: 'user-or-llm',
description: 'Linear issue ID',
},
first: {
type: 'number',
required: false,
visibility: 'user-or-llm',
description: 'Number of comments to return (default: 50)',
},
after: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Cursor for pagination',
},
},
request: {
url: 'https://api.linear.app/graphql',
method: 'POST',
headers: (params) => {
if (!params.accessToken) {
throw new Error('Missing access token for Linear API request')
}
return {
'Content-Type': 'application/json',
Authorization: `Bearer ${params.accessToken}`,
}
},
body: (params) => ({
query: `
query ListComments($issueId: String!, $first: Int, $after: String) {
issue(id: $issueId) {
comments(first: $first, after: $after) {
nodes {
id
body
createdAt
updatedAt
user {
id
name
email
}
}
pageInfo {
hasNextPage
endCursor
}
}
}
}
`,
variables: {
issueId: params.issueId,
first: params.first ? Number(params.first) : 50,
after: params.after,
},
}),
},
transformResponse: async (response) => {
const data = await response.json()
if (data.errors) {
return {
success: false,
error: data.errors[0]?.message || 'Failed to list comments',
output: {},
}
}
if (!data.data?.issue) {
return {
success: false,
error: 'Issue not found',
output: {},
}
}
const result = data.data.issue.comments
return {
success: true,
output: {
comments: result.nodes,
pageInfo: {
hasNextPage: result.pageInfo.hasNextPage,
endCursor: result.pageInfo.endCursor,
},
},
}
},
outputs: {
comments: {
type: 'array',
description: 'Array of comments on the issue',
items: {
type: 'object',
properties: COMMENT_OUTPUT_PROPERTIES,
},
},
pageInfo: PAGE_INFO_OUTPUT,
},
}