Skip to main content
Glama

mcp-google-sheets

clear-sheet.ts1.92 kB
import { createAction, Property } from '@activepieces/pieces-framework'; import { areSheetIdsValid, googleSheetsCommon } from '../common/common'; import { googleSheetsAuth } from '../..'; import { commonProps } from '../common/props'; export const clearSheetAction = createAction({ auth: googleSheetsAuth, name: 'clear_sheet', description: 'Clears all rows on an existing sheet', displayName: 'Clear Sheet', props: { ...commonProps, is_first_row_headers: Property.Checkbox({ displayName: 'Is First row Headers?', description: 'If the first row is headers', required: true, defaultValue: true, }), headerRow: Property.Number({ displayName: 'Header Row', description: 'Which row contains the headers?', required: true, defaultValue: 1, }), }, async run({ propsValue, auth }) { const { spreadsheetId, sheetId, is_first_row_headers:isFirstRowHeaders, headerRow } = propsValue; if (!areSheetIdsValid(spreadsheetId, sheetId)) { throw new Error('Please select a spreadsheet and sheet first.'); } await googleSheetsCommon.findSheetName( auth.access_token, spreadsheetId as string, sheetId as number ); const rowsToDelete: number[] = []; const values = await googleSheetsCommon.getGoogleSheetRows({ spreadsheetId: spreadsheetId as string, accessToken: auth.access_token, sheetId: sheetId as number, rowIndex_s: 1, rowIndex_e: undefined, headerRow: headerRow, }); for (const key in values) { if (key === '0' && isFirstRowHeaders) { continue; } rowsToDelete.push(parseInt(key) + 1); } const response = await googleSheetsCommon.clearSheet( spreadsheetId as string, sheetId as number, auth.access_token, isFirstRowHeaders ? 1 : 0, rowsToDelete.length ); return response.body; }, });

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/activepieces/activepieces'

If you have feedback or need assistance with the MCP directory API, please join our Discord server