Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/airtable include fields #1631

Merged
merged 33 commits into from
Jan 29, 2024
Merged
Changes from 1 commit
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
3fb8001
Added support to exclude specific Airtable Field Ids
Dec 30, 2023
6006157
Updated Airtable field exclusion support to use field names instead o…
Dec 30, 2023
beefcf1
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 1, 2024
e88859f
Added support for gpt-4 and gpt-4-32k models
Jan 1, 2024
66701ce
Fixing linting issues using 'yarn lint-fix'
dkindlund Jan 3, 2024
28bfd41
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 3, 2024
e8c8503
Made streaming support a configurable option within the AzureChatOpen…
dkindlund Jan 3, 2024
51a9808
Merge remote-tracking branch 'upstream/main' into chore/Update-AzureO…
dkindlund Jan 4, 2024
e398247
Bumping version
dkindlund Jan 4, 2024
3d2b407
Removed streaming feature since it broke chatflows
dkindlund Jan 4, 2024
e07f27c
Merge branch 'chore/Update-AzureOpenAI-LLM-Types'
dkindlund Jan 4, 2024
27f14ce
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 4, 2024
4d92989
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 5, 2024
c15489c
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 8, 2024
029d5a9
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 9, 2024
b76c3b2
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 20, 2024
dd32a31
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 22, 2024
8ca8e0e
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 25, 2024
6f7b740
Merge branch 'FlowiseAI:main' into main
dkindlund Jan 29, 2024
71f456a
Switched to specifying Airtable fields to include rather than exclude…
Jan 25, 2024
ae64854
Fixing a bunch of build errors
Jan 25, 2024
1a7cb5a
Fixing more build errors
Jan 25, 2024
72ec787
Added more error checking and also fixed yet more build errors
Jan 25, 2024
8ae8481
Clarifying the description for the optional fields param
Jan 26, 2024
456dfab
For some reason, Airtable doesn't like the POST operations, so I need…
dkindlund Jan 26, 2024
3b788e4
When you switch from GET to POST, you're supposed to adjust the Airta…
dkindlund Jan 26, 2024
2237b1a
Fix worked, removing debug logging, and bumped node version.
dkindlund Jan 26, 2024
9b71f68
Support pagination even in loadLimit(), so that if a user wants to lo…
dkindlund Jan 27, 2024
dc39d7e
So Airtable API expects a maxRecords value to be the total set of rec…
Jan 27, 2024
37945fc
The loadAll() function should ignore any maxRecords specified, becaus…
Jan 28, 2024
66eef84
Forgot to make maxRecords optional now
Jan 28, 2024
b960f06
Clarifying that the Limit value is ignored when Return All is set to …
Jan 28, 2024
905c9fc
Reverting version bump
Jan 29, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Updated Airtable field exclusion support to use field names instead o…
…f field ids
  • Loading branch information
Darien Kindlund committed Dec 30, 2023
commit 6006157958f21347c6feff68ca56a313e813712b
22 changes: 11 additions & 11 deletions packages/components/nodes/documentloaders/Airtable/Airtable.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,14 +65,14 @@ class Airtable_DocumentLoaders implements INode {
optional: true
},
{
label: 'Exclude Field Ids',
name: 'excludeFieldIds',
label: 'Exclude Field Names',
name: 'excludeFieldNames',
type: 'string',
placeholder: 'fld1u0qUz0SoOQ9Gg, fldAMOvPfwxr12VrK',
placeholder: 'Name, Assignee',
optional: true,
additionalParams: true,
description:
'Comma-separated list of field ids to exclude'
'Comma-separated list of field names to exclude'
},
{
label: 'Return All',
Expand Down Expand Up @@ -103,7 +103,7 @@ class Airtable_DocumentLoaders implements INode {
const baseId = nodeData.inputs?.baseId as string
const tableId = nodeData.inputs?.tableId as string
const viewId = nodeData.inputs?.viewId as string
const excludeFieldIds = nodeData.inputs?.excludeFieldIds as string
const excludeFieldNames = nodeData.inputs?.excludeFieldNames as string
const returnAll = nodeData.inputs?.returnAll as boolean
const limit = nodeData.inputs?.limit as string
const textSplitter = nodeData.inputs?.textSplitter as TextSplitter
Expand All @@ -116,7 +116,7 @@ class Airtable_DocumentLoaders implements INode {
baseId,
tableId,
viewId,
excludeFieldIds: excludeFieldIds ? excludeFieldIds.split(',').map(id => id.trim()) : [],
excludeFieldNames: excludeFieldNames ? excludeFieldNames.split(',').map(id => id.trim()) : [],
returnAll,
accessToken,
limit: limit ? parseInt(limit, 10) : 100
Expand Down Expand Up @@ -157,7 +157,7 @@ interface AirtableLoaderParams {
tableId: string
accessToken: string
viewId?: string
excludeFieldIds?: string[]
excludeFieldNames?: string[]
limit?: number
returnAll?: boolean
}
Expand All @@ -180,20 +180,20 @@ class AirtableLoader extends BaseDocumentLoader {

public readonly viewId?: string

public readonly excludeFieldIds: string[]
public readonly excludeFieldNames: string[]

public readonly accessToken: string

public readonly limit: number

public readonly returnAll: boolean

constructor({ baseId, tableId, viewId, excludeFieldIds = [], accessToken, limit = 100, returnAll = false }: AirtableLoaderParams) {
constructor({ baseId, tableId, viewId, excludeFieldNames = [], accessToken, limit = 100, returnAll = false }: AirtableLoaderParams) {
super()
this.baseId = baseId
this.tableId = tableId
this.viewId = viewId
this.excludeFieldIds = excludeFieldIds
this.excludeFieldNames = excludeFieldNames
this.accessToken = accessToken
this.limit = limit
this.returnAll = returnAll
Expand Down Expand Up @@ -226,7 +226,7 @@ class AirtableLoader extends BaseDocumentLoader {
const fields = { ...page.fields };

// Exclude any specified fields
this.excludeFieldIds.forEach(id => {
this.excludeFieldNames.forEach(id => {
delete fields[id];
});

Expand Down