feat: Convert all app files to JS

This commit is contained in:
Faruk AYDIN
2024-01-05 17:44:21 +01:00
parent b95478b635
commit 43dba351c3
1030 changed files with 5114 additions and 6436 deletions

View File

@@ -1,4 +1,4 @@
import defineAction from '../../../../helpers/define-action';
import defineAction from '../../../../helpers/define-action.js';
export default defineAction({
name: 'Create spreadsheet row',
@@ -8,7 +8,7 @@ export default defineAction({
{
label: 'Drive',
key: 'driveId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description:
'The Google Drive where your spreadsheet resides. If nothing is selected, then your personal Google Drive will be used.',
@@ -27,7 +27,7 @@ export default defineAction({
{
label: 'Spreadsheet',
key: 'spreadsheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.driveId'],
description: 'The spreadsheets in your Google Drive.',
@@ -50,7 +50,7 @@ export default defineAction({
{
label: 'Worksheet',
key: 'worksheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.spreadsheetId'],
description: 'The worksheets in your selected spreadsheet.',
@@ -104,7 +104,7 @@ export default defineAction({
const range = sheetName;
const dataValues = Object.entries($.step.parameters)
.filter((entry: [string, string]) => entry[0].startsWith('header-'))
.filter((entry) => entry[0].startsWith('header-'))
.map((value) => value[1]);
const values = [dataValues];

View File

@@ -1,9 +1,4 @@
import defineAction from '../../../../helpers/define-action';
type THeaders = {
__id: string;
header: string;
}[];
import defineAction from '../../../../helpers/define-action.js';
export default defineAction({
name: 'Create spreadsheet',
@@ -14,7 +9,7 @@ export default defineAction({
{
label: 'Title',
key: 'title',
type: 'string' as const,
type: 'string',
required: true,
description: '',
variables: true,
@@ -22,7 +17,7 @@ export default defineAction({
{
label: 'Spreadsheet to copy',
key: 'spreadsheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description: 'Choose a spreadsheet to copy its data.',
variables: true,
@@ -40,7 +35,7 @@ export default defineAction({
{
label: 'Headers',
key: 'headers',
type: 'dynamic' as const,
type: 'dynamic',
required: false,
description:
'These headers are ignored if "Spreadsheet to Copy" is selected.',
@@ -48,7 +43,7 @@ export default defineAction({
{
label: 'Header',
key: 'header',
type: 'string' as const,
type: 'string',
required: true,
variables: true,
},
@@ -69,7 +64,7 @@ export default defineAction({
raw: data,
});
} else {
const headers = $.step.parameters.headers as THeaders;
const headers = $.step.parameters.headers;
const values = headers.map((entry) => entry.header);
const spreadsheetBody = {

View File

@@ -1,14 +1,4 @@
import { IJSONObject } from '@automatisch/types';
import defineAction from '../../../../helpers/define-action';
type THeaders = {
__id: string;
header: string;
}[];
type TBody = {
requests: IJSONObject[];
};
import defineAction from '../../../../helpers/define-action.js';
export default defineAction({
name: 'Create worksheet',
@@ -19,7 +9,7 @@ export default defineAction({
{
label: 'Drive',
key: 'driveId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description:
'The Google Drive where your spreadsheet resides. If nothing is selected, then your personal Google Drive will be used.',
@@ -38,7 +28,7 @@ export default defineAction({
{
label: 'Spreadsheet',
key: 'spreadsheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.driveId'],
variables: true,
@@ -60,7 +50,7 @@ export default defineAction({
{
label: 'Title',
key: 'title',
type: 'string' as const,
type: 'string',
required: true,
description: '',
variables: true,
@@ -68,13 +58,13 @@ export default defineAction({
{
label: 'Headers',
key: 'headers',
type: 'dynamic' as const,
type: 'dynamic',
required: false,
fields: [
{
label: 'Header',
key: 'header',
type: 'string' as const,
type: 'string',
required: true,
variables: true,
},
@@ -83,7 +73,7 @@ export default defineAction({
{
label: 'Overwrite',
key: 'overwrite',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
value: false,
description:
@@ -110,10 +100,10 @@ export default defineAction({
const selectedSheet = sheets.find(
(sheet) => sheet.properties.title === $.step.parameters.title
);
const headers = $.step.parameters.headers as THeaders;
const headers = $.step.parameters.headers;
const values = headers.map((entry) => entry.header);
const body: TBody = {
const body = {
requests: [
{
addSheet: {

View File

@@ -0,0 +1,5 @@
import createSpreadsheet from './create-spreadsheet/index.js';
import createSpreadsheetRow from './create-spreadsheet-row/index.js';
import createWorksheet from './create-worksheet/index.js';
export default [createSpreadsheet, createSpreadsheetRow, createWorksheet];

View File

@@ -1,5 +0,0 @@
import createSpreadsheet from './create-spreadsheet';
import createSpreadsheetRow from './create-spreadsheet-row';
import createWorksheet from './create-worksheet';
export default [createSpreadsheet, createSpreadsheetRow, createWorksheet];

View File

@@ -1,14 +1,13 @@
import { IField, IGlobalVariable } from '@automatisch/types';
import { URLSearchParams } from 'url';
import authScope from '../common/auth-scope';
import authScope from '../common/auth-scope.js';
export default async function generateAuthUrl($: IGlobalVariable) {
export default async function generateAuthUrl($) {
const oauthRedirectUrlField = $.app.auth.fields.find(
(field: IField) => field.key == 'oAuthRedirectUrl'
(field) => field.key == 'oAuthRedirectUrl'
);
const redirectUri = oauthRedirectUrlField.value as string;
const redirectUri = oauthRedirectUrlField.value;
const searchParams = new URLSearchParams({
client_id: $.auth.data.clientId as string,
client_id: $.auth.data.clientId,
redirect_uri: redirectUri,
prompt: 'select_account',
scope: authScope.join(' '),

View File

@@ -1,14 +1,14 @@
import generateAuthUrl from './generate-auth-url';
import verifyCredentials from './verify-credentials';
import refreshToken from './refresh-token';
import isStillVerified from './is-still-verified';
import generateAuthUrl from './generate-auth-url.js';
import verifyCredentials from './verify-credentials.js';
import refreshToken from './refresh-token.js';
import isStillVerified from './is-still-verified.js';
export default {
fields: [
{
key: 'oAuthRedirectUrl',
label: 'OAuth Redirect URL',
type: 'string' as const,
type: 'string',
required: true,
readOnly: true,
value: '{WEB_APP_URL}/app/google-sheets/connections/add',
@@ -20,7 +20,7 @@ export default {
{
key: 'clientId',
label: 'Client ID',
type: 'string' as const,
type: 'string',
required: true,
readOnly: false,
value: null,
@@ -31,7 +31,7 @@ export default {
{
key: 'clientSecret',
label: 'Client Secret',
type: 'string' as const,
type: 'string',
required: true,
readOnly: false,
value: null,

View File

@@ -0,0 +1,8 @@
import getCurrentUser from '../common/get-current-user.js';
const isStillVerified = async ($) => {
const currentUser = await getCurrentUser($);
return !!currentUser.resourceName;
};
export default isStillVerified;

View File

@@ -1,9 +0,0 @@
import { IGlobalVariable } from '@automatisch/types';
import getCurrentUser from '../common/get-current-user';
const isStillVerified = async ($: IGlobalVariable) => {
const currentUser = await getCurrentUser($);
return !!currentUser.resourceName;
};
export default isStillVerified;

View File

@@ -1,13 +1,13 @@
import { URLSearchParams } from 'node:url';
import { IGlobalVariable } from '@automatisch/types';
import authScope from '../common/auth-scope';
const refreshToken = async ($: IGlobalVariable) => {
import authScope from '../common/auth-scope.js';
const refreshToken = async ($) => {
const params = new URLSearchParams({
client_id: $.auth.data.clientId as string,
client_secret: $.auth.data.clientSecret as string,
client_id: $.auth.data.clientId,
client_secret: $.auth.data.clientSecret,
grant_type: 'refresh_token',
refresh_token: $.auth.data.refreshToken as string,
refresh_token: $.auth.data.refreshToken,
});
const { data } = await $.http.post(

View File

@@ -1,25 +1,10 @@
import { IField, IGlobalVariable } from '@automatisch/types';
import getCurrentUser from '../common/get-current-user';
import getCurrentUser from '../common/get-current-user.js';
type TUser = {
displayName: string;
metadata: {
primary: boolean;
};
};
type TEmailAddress = {
value: string;
metadata: {
primary: boolean;
};
};
const verifyCredentials = async ($: IGlobalVariable) => {
const verifyCredentials = async ($) => {
const oauthRedirectUrlField = $.app.auth.fields.find(
(field: IField) => field.key == 'oAuthRedirectUrl'
(field) => field.key == 'oAuthRedirectUrl'
);
const redirectUri = oauthRedirectUrlField.value as string;
const redirectUri = oauthRedirectUrlField.value;
const { data } = await $.http.post(`https://oauth2.googleapis.com/token`, {
client_id: $.auth.data.clientId,
client_secret: $.auth.data.clientSecret,
@@ -36,10 +21,10 @@ const verifyCredentials = async ($: IGlobalVariable) => {
const currentUser = await getCurrentUser($);
const { displayName } = currentUser.names.find(
(name: TUser) => name.metadata.primary
(name) => name.metadata.primary
);
const { value: email } = currentUser.emailAddresses.find(
(emailAddress: TEmailAddress) => emailAddress.metadata.primary
(emailAddress) => emailAddress.metadata.primary
);
await $.auth.set({

View File

@@ -1,6 +1,4 @@
import { TBeforeRequest } from '@automatisch/types';
const addAuthHeader: TBeforeRequest = ($, requestConfig) => {
const addAuthHeader = ($, requestConfig) => {
if ($.auth.data?.accessToken) {
requestConfig.headers.Authorization = `${$.auth.data.tokenType} ${$.auth.data.accessToken}`;
}

View File

@@ -1,4 +1,4 @@
const authScope: string[] = [
const authScope = [
'https://www.googleapis.com/auth/drive',
'https://www.googleapis.com/auth/spreadsheets',
'https://www.googleapis.com/auth/userinfo.email',

View File

@@ -1,6 +1,4 @@
import { IGlobalVariable } from '@automatisch/types';
const getCurrentUser = async ($: IGlobalVariable) => {
const getCurrentUser = async ($) => {
const { data: currentUser } = await $.http.get(
'https://people.googleapis.com/v1/people/me?personFields=names,emailAddresses'
);

View File

@@ -0,0 +1,5 @@
import listDrives from './list-drives/index.js';
import listSpreadsheets from './list-spreadsheets/index.js';
import listWorksheets from './list-worksheets/index.js';
export default [listDrives, listSpreadsheets, listWorksheets];

View File

@@ -1,5 +0,0 @@
import listDrives from './list-drives';
import listSpreadsheets from './list-spreadsheets';
import listWorksheets from './list-worksheets';
export default [listDrives, listSpreadsheets, listWorksheets];

View File

@@ -1,19 +1,15 @@
import { IGlobalVariable, IJSONObject } from '@automatisch/types';
export default {
name: 'List drives',
key: 'listDrives',
async run($: IGlobalVariable) {
const drives: {
data: IJSONObject[];
} = {
async run($) {
const drives = {
data: [{ value: null, name: 'My Google Drive' }],
};
const params = {
pageSize: 100,
pageToken: undefined as unknown as string,
pageToken: undefined,
};
do {

View File

@@ -1,20 +1,16 @@
import { IGlobalVariable, IJSONObject } from '@automatisch/types';
export default {
name: 'List spreadsheets',
key: 'listSpreadsheets',
async run($: IGlobalVariable) {
const spreadsheets: {
data: IJSONObject[];
} = {
async run($) {
const spreadsheets = {
data: [],
};
const params: Record<string, unknown> = {
const params = {
q: `mimeType='application/vnd.google-apps.spreadsheet'`,
pageSize: 100,
pageToken: undefined as unknown as string,
pageToken: undefined,
orderBy: 'createdTime desc',
driveId: $.step.parameters.driveId,
supportsAllDrives: true,

View File

@@ -1,15 +1,11 @@
import { IGlobalVariable, IJSONObject } from '@automatisch/types';
export default {
name: 'List worksheets',
key: 'listWorksheets',
async run($: IGlobalVariable) {
const spreadsheetId = $.step.parameters.spreadsheetId as string;
async run($) {
const spreadsheetId = $.step.parameters.spreadsheetId;
const worksheets: {
data: IJSONObject[];
} = {
const worksheets = {
data: [],
};
@@ -17,8 +13,8 @@ export default {
return worksheets;
}
const params: Record<string, unknown> = {
pageToken: undefined as unknown as string,
const params = {
pageToken: undefined,
};
do {

View File

@@ -0,0 +1,3 @@
import listSheetHeaders from './list-sheet-headers/index.js';
export default [listSheetHeaders];

View File

@@ -1,3 +0,0 @@
import listSheetHeaders from './list-sheet-headers';
export default [listSheetHeaders];

View File

@@ -0,0 +1,59 @@
const hasValue = (value) => value !== null && value !== undefined;
export default {
name: 'List Sheet Headers',
key: 'listSheetHeaders',
async run($) {
if (
!hasValue($.step.parameters.spreadsheetId) ||
!hasValue($.step.parameters.worksheetId)
) {
return;
}
const {
data: { sheets },
} =
(await $.http.get) <
TSheetsResponse >
`/v4/spreadsheets/${$.step.parameters.spreadsheetId}`;
const selectedSheet = sheets.find(
(sheet) => sheet.properties.sheetId === $.step.parameters.worksheetId
);
if (!selectedSheet) return;
const sheetName = selectedSheet.properties.title;
const range = `${sheetName}!1:1`;
const params = {
majorDimension: 'ROWS',
};
const { data } =
(await $.http.get) <
TSheetsValueResponse >
(`/v4/spreadsheets/${$.step.parameters.spreadsheetId}/values/${range}`,
{
params,
});
if (!data.values) {
return;
}
const result = data.values[0].map((item, index) => ({
label: item,
key: `header-${index}`,
type: 'string',
required: false,
value: item,
variables: true,
}));
return result;
},
};

View File

@@ -1,71 +0,0 @@
import { IGlobalVariable } from '@automatisch/types';
type TSheetsResponse = {
sheets: {
properties: {
sheetId: string;
title: string;
};
}[];
};
type TSheetsValueResponse = {
majorDimension: string;
range: string;
values: string[][];
};
const hasValue = (value: any) => value !== null && value !== undefined;
export default {
name: 'List Sheet Headers',
key: 'listSheetHeaders',
async run($: IGlobalVariable) {
if (!hasValue($.step.parameters.spreadsheetId) || !hasValue($.step.parameters.worksheetId)) {
return;
}
const {
data: { sheets },
} = await $.http.get<TSheetsResponse>(
`/v4/spreadsheets/${$.step.parameters.spreadsheetId}`
);
const selectedSheet = sheets.find(
(sheet) => sheet.properties.sheetId === $.step.parameters.worksheetId
);
if (!selectedSheet) return;
const sheetName = selectedSheet.properties.title;
const range = `${sheetName}!1:1`;
const params: Record<string, unknown> = {
majorDimension: 'ROWS',
};
const { data } = await $.http.get<TSheetsValueResponse>(
`/v4/spreadsheets/${$.step.parameters.spreadsheetId}/values/${range}`,
{
params,
}
);
if (!data.values) {
return;
}
const result = data.values[0].map((item: string, index: number) => ({
label: item,
key: `header-${index}`,
type: 'string' as const,
required: false,
value: item,
variables: true,
}));
return result;
},
};

View File

@@ -1,10 +1,10 @@
import defineApp from '../../helpers/define-app';
import addAuthHeader from './common/add-auth-header';
import auth from './auth';
import triggers from './triggers';
import actions from './actions';
import dynamicData from './dynamic-data';
import dynamicFields from './dynamic-fields';
import defineApp from '../../helpers/define-app.js';
import addAuthHeader from './common/add-auth-header.js';
import auth from './auth/index.js';
import triggers from './triggers/index.js';
import actions from './actions/index.js';
import dynamicData from './dynamic-data/index.js';
import dynamicFields from './dynamic-fields/index.js';
export default defineApp({
name: 'Google Sheets',

View File

@@ -0,0 +1,5 @@
import newSpreadsheets from './new-spreadsheets/index.js';
import newWorksheets from './new-worksheets/index.js';
import newSpreadsheetRows from './new-spreadsheet-rows/index.js';
export default [newSpreadsheets, newWorksheets, newSpreadsheetRows];

View File

@@ -1,5 +0,0 @@
import newSpreadsheets from './new-spreadsheets';
import newWorksheets from './new-worksheets';
import newSpreadsheetRows from './new-spreadsheet-rows';
export default [newSpreadsheets, newWorksheets, newSpreadsheetRows];

View File

@@ -1,5 +1,5 @@
import defineTrigger from '../../../../helpers/define-trigger';
import newSpreadsheetRows from './new-spreadsheet-rows';
import defineTrigger from '../../../../helpers/define-trigger.js';
import newSpreadsheetRows from './new-spreadsheet-rows.js';
export default defineTrigger({
name: 'New spreadsheet rows',
@@ -11,7 +11,7 @@ export default defineTrigger({
{
label: 'Drive',
key: 'driveId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description:
'The Google Drive where your spreadsheet resides. If nothing is selected, then your personal Google Drive will be used.',
@@ -30,7 +30,7 @@ export default defineTrigger({
{
label: 'Spreadsheet',
key: 'spreadsheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.driveId'],
description: 'The spreadsheets in your Google Drive.',
@@ -53,7 +53,7 @@ export default defineTrigger({
{
label: 'Worksheet',
key: 'worksheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.spreadsheetId'],
description:

View File

@@ -1,20 +1,10 @@
import { IGlobalVariable } from '@automatisch/types';
type TSheetsResponse = {
sheets: {
properties: {
sheetId: string;
title: string;
};
}[];
};
const newSpreadsheetRows = async ($: IGlobalVariable) => {
const newSpreadsheetRows = async ($) => {
const {
data: { sheets },
} = await $.http.get<TSheetsResponse>(
`/v4/spreadsheets/${$.step.parameters.spreadsheetId}`
);
} =
(await $.http.get) <
TSheetsResponse >
`/v4/spreadsheets/${$.step.parameters.spreadsheetId}`;
const selectedSheet = sheets.find(
(sheet) => sheet.properties.sheetId === $.step.parameters.worksheetId

View File

@@ -1,5 +1,5 @@
import defineTrigger from '../../../../helpers/define-trigger';
import newSpreadsheets from './new-spreadsheets';
import defineTrigger from '../../../../helpers/define-trigger.js';
import newSpreadsheets from './new-spreadsheets.js';
export default defineTrigger({
name: 'New spreadsheets',
@@ -10,7 +10,7 @@ export default defineTrigger({
{
label: 'Drive',
key: 'driveId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description:
'The Google Drive where your spreadsheet resides. If nothing is selected, then your personal Google Drive will be used.',

View File

@@ -1,8 +1,6 @@
import { IGlobalVariable } from '@automatisch/types';
const newSpreadsheets = async ($: IGlobalVariable) => {
const params: Record<string, unknown> = {
pageToken: undefined as unknown as string,
const newSpreadsheets = async ($) => {
const params = {
pageToken: undefined,
orderBy: 'createdTime desc',
q: `mimeType='application/vnd.google-apps.spreadsheet'`,
fields: '*',

View File

@@ -1,5 +1,5 @@
import defineTrigger from '../../../../helpers/define-trigger';
import newWorksheets from './new-worksheets';
import defineTrigger from '../../../../helpers/define-trigger.js';
import newWorksheets from './new-worksheets.js';
export default defineTrigger({
name: 'New worksheets',
@@ -10,7 +10,7 @@ export default defineTrigger({
{
label: 'Drive',
key: 'driveId',
type: 'dropdown' as const,
type: 'dropdown',
required: false,
description:
'The Google Drive where your spreadsheet resides. If nothing is selected, then your personal Google Drive will be used.',
@@ -29,7 +29,7 @@ export default defineTrigger({
{
label: 'Spreadsheet',
key: 'spreadsheetId',
type: 'dropdown' as const,
type: 'dropdown',
required: true,
dependsOn: ['parameters.driveId'],
description: 'The spreadsheets in your Google Drive.',

View File

@@ -1,8 +1,6 @@
import { IGlobalVariable } from '@automatisch/types';
const newWorksheets = async ($: IGlobalVariable) => {
const newWorksheets = async ($) => {
const params = {
pageToken: undefined as unknown as string,
pageToken: undefined,
};
do {