Notion Integration
Requirements
Bugsee requires the "Projects and tasks" template to be present in the workspace you want to integrate with. To learn more about that template, please refer to "Getting started with projects and tasks" page in Notion documentation.
During the authentication process you will be asked to grant Bugsee the access to your workspace in Notion. Make sure you select both "Projects" and "Tasks" databases.
Once authenticated, you will need to add the "Description" field to the task template. You can do that by creating the dummy task, opening it and clicking on "Add a property" button below the task fields (not, that this button may be collapsed under the "# more property" toggle).
Authentication
Supported authentication methods
OAuth
Select "OAuth" in the first step of integration wizard. Click "Next".
You will be presented with dialog asking you to authorize Bugsee. Click Select pages to allow Bugsee access your Notion account.
Make sure you select both "Projects" and "Tasks" items in the next step to grant access to them. Click "Allow access" to proceed.
Next you will need to choose the Projects database.
Then you will need to choose the Tasks database.
Configuration
There are no any specific configuration steps for Microsoft Teams. Refer to configuration section for description about generic steps.
Custom recipes
Field types
You can find all the field types and their description in the official Notion developer documentation
Setting assignee
By default Bugsee does not set assignee for the task. You can override this behavior by using the following custom recipe:
function create(context) {
// ...
return {
// ...
custom: {
Assignee: {
type: "people",
people: [
{ id: "<notion-user-unique-id>" }
]
}
}
};
}
Setting custom text field
function create(context) {
// ...
return {
// ...
custom: {
Sprint: {
type: "rich_text",
rich_text: [{ text: { content: "S-11-2" } }]
}
}
};
}
Setting formatted text into description
To apply formatting to the text pushed through the Notion API, it has to be specified in special format
described in the Notion docs. Further, the assembled
sequence should be passed as an override to the description
field in the custom
section.
function create(context) {
// ...
const issue = context.issue;
let description = issue.description || '';
// Add two newlines to separate other data from the description
description += description ? '\n\n' : '';
description += issue.reporter ? `Reported by ${issue.reporter}\n\n` : '';
const formattedDescription = [{ text: { content: description } }]
if (issue.attachments?.length) {
// Bold title
formattedDescription.push({
text: { content: 'Attachments:' },
annotations: { bold: true }
});
formattedDescription.push({ text: { content: `\n` } });
// List of attachments with hyperlinks
issue.attachments.forEach(attachment => {
formattedDescription.push({ text: { content: `- ${attachment.name}: ` } });
formattedDescription.push({ text: {
content: 'Download attachment',
link: { url: attachment.url }
}});
formattedDescription.push({ text: { content: `\n` } });
});
formattedDescription.push({ text: { content: `\n` } });
}
return {
// ...
custom: {
Description: { rich_text: formattedDescription }
}
};
}