Custom Charts with Nested Data
The following step-by-step instructions show how to build a custom chart that expects nested data.
This example starts with flat data from the default stream, fetched and prepared using SQL, and reshaped and rendered using JavaScript. Learn more about data preparation and reshaping for custom charts. 
Use Case
Build a custom Sunburst chart to visualize how query execution time is distributed across different organizations and search types. The goal is to understand:
- Which organization generates the most query load
- How that load is split across dashboards, logs, and alerts
- Whether certain usage patterns need optimization or resource allocation
Step 1: Choose the Chart
To build a custom chart, you need to bridge two things:
- What data you already have: This is the structure of your ingested data, which is usually flat.
- What the chart expects: Each chart type needs data in a specific format. Some charts expect flat data, while others require nested data.
Note: Understanding both is important because it helps you write the right SQL query, prepare the data through grouping or aggregation, reshape the results to match the chart’s structure, and map them correctly in the JavaScript code that renders the chart.
Step 1: Understand the Ingested Data
OpenObserve stores ingested data in a flat structure.
Example: In the following dataset, each row represents a single event or query log, with its own timestamp, organization ID, search type, and query duration.
Note: To view the ingested data, go to the Logs page and run the query against the stream for a selected time range.
Step 2: Identify the Expected Data Structure
Before starting, identify what structure the chart expects.
Sunburst chart expects data to be in nested format or parent-child hierarchy. Each parent (organization_id) should contain its children (search_types), each with a value.
Step 3: Fetch and Prepare the Data
In the Add Panel page, under Fields, select the desired stream type and stream name. 
 
 
Write a SQL query in the Query Editor to fetch and prepare the data:
- Filter out incomplete or irrelevant entries.
- Convert duration strings (e.g., 9h 44m 02s) into numeric values (e.g., 35042 seconds).
- Aggregate values for matching categories (e.g., same organization_id and search_type).
- Ensure consistent field names so the reshaping logic works without errors.
SQL Query
Select a time range to fetch the relevant dataset for your chart.

Expected Query Result
Note: OpenObserve stores the result of the query in the data object as an array of an array.
Step 4: Inspect the Queried Data
Inspect the queried dataset before reshaping:
This helps confirm:
- If the field names are correct
- If there is any inconsistencies or formatting issues
- If the data requires any preparation before reshaping
Step 5: Reshape Data Into Nested Structure
In the JavaScript editor, write a script to convert the queried result into a nested array suitable for a Sunburst chart:
Note: In the option object, use the reshaped treeData array as the data field in your chart configuration.
Step 6: Render the Chart
Construct the option object in the JavaScript code to define the reshaped dataset and configure how the chart should appear. 
Note: Further, you can enhance the chart with event handlers and reusable functions.
Step 7: View Results
Click Apply to generate the chart.
If the query and JavaScript logic are correct, the chart appears in the preview area.
 
Understand the Chart
The above Sunburst chart shows a breakdown of total query time across organizations and their search types.
- The inner ring shows the organizations (test, production).
- The outer ring shows search types (logs, alerts, dashboards) under each organization.
- The size of each slice reflects the total duration (in seconds) for that group, larger slices mean more total query time.
- Hover over any slice to see a tooltip showing the exact total duration in seconds.
Use the chart to identify which organizations or search types consume the most query time. Large slices may indicate areas that need performance tuning or more resources.
Troubleshoot
Use the following guidance to identify and fix common issues when working with custom charts:
1. No data found
Cause: The SQL query did not return any results. 
Fix: 
- Confirm the selected time range includes data.
- Check that the stream name and field names are correct.
- Run the query in the Logs view to verify that results are returned.
2. Uncaught ReferenceError: option is not defined
Cause: The chart configuration was not defined correctly.
Fix: 
- Ensure option = {...}is defined at the end of your JavaScript.
- Do not rename the option variable or wrap it in a function or condition.
3. Unsafe code detected: Invalid JavaScript syntax.
Cause: There is a syntax error in your JavaScript.
Fix: 
- Check for missing or extra commas, brackets, or quotation marks.
- Open your browser's developer console to locate the error.
- Use console.log()to test your script step by step.
4. Chart Not Rendering: 
Cause: The query returned data, but the chart did not render.
Fix: 
- Use console.log(data[0])to confirm that the dataset is not empty.
- Make sure the field names in your script match the query output.