Devbook extensions allow users to add search sources that aren’t supported out-of-the-box by Devbook. It’s like a programmable search engine.
Your extension doesn’t have to implement the search logic or any user interface. You only have to do two things:
- Upload the search data into Devbook's search engine and keep them up-to-date.
- React to user events in the Devbook app.
For uploading extension's search data into Devbook's search engine, use Devbook Extension Admin API.
We're starting with a minimal example and will gradually add more ways how extensions can interact with Devbook.
npm install @devbookhq/extension
or
yarn add @devbookhq/extension
import Devbook, { ExtensionEventHandlers } from '@devbookhq/extension';
// If you want to use our predefined functions to fetch extension data, you have to initialize the Devbook object.
const devbook = new Devbook();
const extensionEventHandlers: ExtensionEventHandlers = {
// Called every time user changes the search query in the Devbook search input.
// An extension is required to implement this function and return an array of search results.
onDidQueryChange: async (data, extensionMode, token) => {
// data - contains information about query.
// extensionMode - whether an extension is running in the 'prod' or 'dev' mode (read more in our documentation).
// token - access token you need if you want to make HTTP request on the Devbook API manually.
// Mock example not fetching any data from the extension data.
const results = [
{
id: '1',
title: 'Hello World!',
body: `The search query was ${data.query}`,
},
];
return { results };
// Fetch your extension data from the https://api.usedevbook.com/:version/extension/:extensionID endpoint.
// You can use our exported predefined functions for that:
// const results = await devbook.search(['testIndex'], data.query);
// return { results };
},
}
export default extensionEventHandlers;
TODO: Add a link to documentation.
Check out the extension examples.