This guide explains how to add support for [Explore]({{<relref"../../features/explore.md">}}) to an existing data source plugin.
This guide assumes that you're already familiar with how to [Build a data source plugin]({{<relref"../../../../../tutorials/build-a-data-source-plugin.md">}}).
By adding support for Explore to your data source, users can make ad-hoc queries without the new of a dashboard. This is useful when users want to troubleshoot or to learn more about the data.
To support Explore, your plugin needs to define a _query editor_ for Explore. Optionally, your plugin can also define a _start page_ for Explore.
## Add a query editor for Explore
The query editor for Explore is similar to the query editor for the data source itself. In fact, you'll probably reuse the same components for both query editors.
1. Create a file `ExploreQueryEditor.tsx` in the `src` directory of your plugin, with the following content:
// Update the query whenever the query field changes.
onChange({...query,queryText:value});
// Run the query on Enter.
if(override&&onRunQuery){
onRunQuery();
}
}
};
return(
<QueryField
portalOrigin="mock-origin"
onChange={onQueryChange}
onRunQuery={props.onRunQuery}
onBlur={props.onBlur}
query={query.queryText||''}
placeholder="Enter a query"
/>
);
};
```
## Add a start page for Explore
By adding an Explore start page for your plugin, you can for example create "cheat sheets" with commonly used queries. When the user clicks on one of the examples, it automatically updates the query editor, and runs the query. It's a great way to increase productivity for your users.
1. Create a file `ExploreStartPage.tsx` in the `src` directory of your plugin, with the following content:
```ts
importReactfrom'react';
import{ExploreStartPageProps}from'@grafana/data';
exportdefault(props:ExploreStartPageProps)=>{
return(
<h2>Mystartpage</h2>
);
};
```
1. Configure the plugin to use the `ExploreStartPage`.
Explore lets you query any data source, regardless of whether it returns metrics or logs. You can change which type of query you want to make, by setting the _Explore mode_.
The query modes that the plugin supports are defined in the [plugin.json]({{< relref "metadata.md" >}}) file.
The query mode is available on the `props` object for both the query editor and the start page. For example, here's how you can change the query editor based on the currently selected mode: