feat(miro): add create board action
This commit is contained in:
94
packages/backend/src/apps/miro/actions/create-board/index.ts
Normal file
94
packages/backend/src/apps/miro/actions/create-board/index.ts
Normal file
@@ -0,0 +1,94 @@
|
|||||||
|
import defineAction from '../../../../helpers/define-action';
|
||||||
|
|
||||||
|
export default defineAction({
|
||||||
|
name: 'Create board',
|
||||||
|
key: 'createBoard',
|
||||||
|
description: 'Creates a new board.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Title',
|
||||||
|
key: 'title',
|
||||||
|
type: 'string' as const,
|
||||||
|
required: true,
|
||||||
|
description: 'Title for the board.',
|
||||||
|
variables: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Description',
|
||||||
|
key: 'description',
|
||||||
|
type: 'string' as const,
|
||||||
|
required: false,
|
||||||
|
description: 'Description of the board.',
|
||||||
|
variables: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Team Access',
|
||||||
|
key: 'teamAccess',
|
||||||
|
type: 'dropdown' as const,
|
||||||
|
required: false,
|
||||||
|
description:
|
||||||
|
'Team access to the board. Can be private, view, comment or edit. Default: private.',
|
||||||
|
variables: true,
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
label: 'Private - nobody in the team can find and access the board',
|
||||||
|
value: 'private',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'View - any team member can find and view the board',
|
||||||
|
value: 'view',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Comment - any team member can find and comment the board',
|
||||||
|
value: 'comment',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Edit - any team member can find and edit the board',
|
||||||
|
value: 'edit',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Access Via Link',
|
||||||
|
key: 'accessViaLink',
|
||||||
|
type: 'dropdown' as const,
|
||||||
|
required: false,
|
||||||
|
description:
|
||||||
|
'Access to the board by link. Can be private, view, comment. Default: private.',
|
||||||
|
variables: true,
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
label: 'Private - only you have access to the board',
|
||||||
|
value: 'private',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'View - can view, no sign-in required',
|
||||||
|
value: 'view',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Comment - can comment, no sign-in required',
|
||||||
|
value: 'comment',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
const body = {
|
||||||
|
name: $.step.parameters.title,
|
||||||
|
description: $.step.parameters.description,
|
||||||
|
policy: {
|
||||||
|
sharingPolicy: {
|
||||||
|
access: $.step.parameters.accessViaLink || 'private',
|
||||||
|
teamAccess: $.step.parameters.teamAccess || 'private',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const { data } = await $.http.post('/v2/boards', body);
|
||||||
|
|
||||||
|
$.setActionItem({
|
||||||
|
raw: data,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
3
packages/backend/src/apps/miro/actions/index.ts
Normal file
3
packages/backend/src/apps/miro/actions/index.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import createBoard from './create-board';
|
||||||
|
|
||||||
|
export default [createBoard];
|
@@ -14,6 +14,7 @@ const refreshToken = async ($: IGlobalVariable) => {
|
|||||||
await $.auth.set({
|
await $.auth.set({
|
||||||
accessToken: data.access_token,
|
accessToken: data.access_token,
|
||||||
expiresIn: data.expires_in,
|
expiresIn: data.expires_in,
|
||||||
|
refreshToken: data.refresh_token,
|
||||||
scope: data.scope,
|
scope: data.scope,
|
||||||
tokenType: data.token_type,
|
tokenType: data.token_type,
|
||||||
});
|
});
|
||||||
|
@@ -1,6 +1,7 @@
|
|||||||
import defineApp from '../../helpers/define-app';
|
import defineApp from '../../helpers/define-app';
|
||||||
import addAuthHeader from './common/add-auth-header';
|
import addAuthHeader from './common/add-auth-header';
|
||||||
import auth from './auth';
|
import auth from './auth';
|
||||||
|
import actions from './actions';
|
||||||
|
|
||||||
export default defineApp({
|
export default defineApp({
|
||||||
name: 'Miro',
|
name: 'Miro',
|
||||||
@@ -13,4 +14,5 @@ export default defineApp({
|
|||||||
supportsConnections: true,
|
supportsConnections: true,
|
||||||
beforeRequest: [addAuthHeader],
|
beforeRequest: [addAuthHeader],
|
||||||
auth,
|
auth,
|
||||||
|
actions,
|
||||||
});
|
});
|
||||||
|
@@ -178,6 +178,15 @@ export default defineConfig({
|
|||||||
{ text: 'Connection', link: '/apps/mattermost/connection' },
|
{ text: 'Connection', link: '/apps/mattermost/connection' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
text: 'Miro',
|
||||||
|
collapsible: true,
|
||||||
|
collapsed: true,
|
||||||
|
items: [
|
||||||
|
{ text: 'Actions', link: '/apps/miro/actions' },
|
||||||
|
{ text: 'Connection', link: '/apps/miro/connection' },
|
||||||
|
],
|
||||||
|
},
|
||||||
{
|
{
|
||||||
text: 'Notion',
|
text: 'Notion',
|
||||||
collapsible: true,
|
collapsible: true,
|
||||||
|
12
packages/docs/pages/apps/miro/actions.md
Normal file
12
packages/docs/pages/apps/miro/actions.md
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
---
|
||||||
|
favicon: /favicons/miro.svg
|
||||||
|
items:
|
||||||
|
- name: Create board
|
||||||
|
desc: Creates a new board.
|
||||||
|
---
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import CustomListing from '../../components/CustomListing.vue'
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<CustomListing />
|
19
packages/docs/pages/apps/miro/connection.md
Normal file
19
packages/docs/pages/apps/miro/connection.md
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
# Miro
|
||||||
|
|
||||||
|
:::info
|
||||||
|
This page explains the steps you need to follow to set up the Miro
|
||||||
|
connection in Automatisch. If any of the steps are outdated, please let us know!
|
||||||
|
:::
|
||||||
|
|
||||||
|
1. Go to [link](https://miro.com/signup/) to create a user account in Miro.
|
||||||
|
2. After signin in, go to [link](https://miro.com/app/dashboard/?createDevTeam=1) to create a developer team.
|
||||||
|
3. In the **Create new team** modal, select the checkbox and then click **Create team** button.
|
||||||
|
4. After that, click **Create new app** in Your app section.
|
||||||
|
5. Fill the field of **App Name**.
|
||||||
|
6. Select the **Expire user authorization token** checkbox and click the **Create app**.
|
||||||
|
7. Copy **OAuth Redirect URL** from Automatisch to the **Redirect URI for OAuth2.0** field.
|
||||||
|
8. Give permissions for **boards**, **identity**, and **team** scopes in Permissions field.
|
||||||
|
9. Copy the **Client ID** value to the `Client ID` field on Automatisch.
|
||||||
|
10. Copy the **Client secret** value to the `Client Secret` field on Automatisch.
|
||||||
|
11. Click **Submit** button on Automatisch.
|
||||||
|
12. Congrats! Start using your new Miro connection within the flows.
|
1
packages/docs/pages/public/favicons/miro.svg
Normal file
1
packages/docs/pages/public/favicons/miro.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg viewBox="0 0 48 48" xmlns="http://www.w3.org/2000/svg" width="2500" height="2500"><path d="M0 0h48v48H0z" fill="#ffd02f"/><path d="M32.708 6.4h-5.124l4.549 7.05-9.617-7.05h-5.124l4.549 9.238L12.324 6.4H7.2l4.474 11.926L7.2 41.6h5.124l9.617-24.955L17.392 41.6h5.124l9.617-27.142-4.549 27.142h5.124L42.4 11.785z" fill="#050038"/></svg>
|
After Width: | Height: | Size: 338 B |
Reference in New Issue
Block a user