mirror of
https://github.com/apache/superset.git
synced 2026-05-24 01:05:21 +00:00
Previously docusaurus.config.ts had `onBrokenLinks: 'warn'`, so broken
internal links produced advisory warnings during build but didn't gate
merges. Tightening to `throw` surfaces every broken internal route at
build time. Three classes of issue fell out:
1. Stale `/docs/...` and `/docs/6.0.0/...` references in the 6.0.0
versioned snapshot. The user-facing docs section was renamed
`docs` → `user-docs` (routeBasePath) at some point after 6.0.0 was
cut, but the snapshot's links still pointed at the old prefix. The
live site redirects /docs/* → /user-docs/* at runtime, but
Docusaurus's onBrokenLinks checker doesn't honor redirects.
Bulk-rewrote /docs/* → /user-docs/* across the snapshot (and one
/docs/api → /developer-docs/api).
2. Bare-relative MDX links like `[Label](./mcp)` (no .md/.mdx
extension). Docusaurus renders an absolute href in SSR HTML, so
static crawlers see correct links — BUT React Router's `<Link>`
component on the client side resolves the bare path relative to
the current URL on click, so when the page URL has a trailing
slash (e.g. /extensions/overview/), `./mcp` becomes
/extensions/overview/mcp (404). This is exactly the broken-flow a
user reported on /developer-docs/extensions/overview/. Added the
`.md`/`.mdx` extension to all 44 such links across 17 files; this
makes Docusaurus resolve them to the canonical doc URL at the
<Link> level, so SPA navigation works regardless of trailing slash.
3. Miscellaneous content fixes:
- 4 `/configuration/feature-flags` references in 6.0.0 snapshot
pointed at a page that doesn't exist in that version (the
dedicated feature-flags page was added later). Repointed to the
`#feature-flags` anchor inside `configuring-superset.mdx`.
- 3 references to `superset-core/src/superset_core/rest_api/decorators.py`
in extensions docs were rendered as relative URLs, resolving to
/developer-docs/extensions/superset-core/... (404). Converted to
absolute GitHub URLs.
- 1 `/storybook/?path=...` link in extensions/components/index.mdx
pointed at a non-existent route. Repointed to the existing
`/developer-docs/testing/storybook` page that explains how to
run Storybook locally.
- 4 unclosed-paren markdown links in 6.0.0 installation-methods.mdx
(pre-existing source bugs).
Build now passes with `onBrokenLinks: 'throw'`. Note that
`onBrokenAnchors` is still `'warn'` (default); a separate effort
should tighten that and fix the surviving anchor warnings (currently
~60 instances of `/community#superset-community-calendar`).
163 lines
6.7 KiB
Markdown
163 lines
6.7 KiB
Markdown
---
|
|
title: SQL Lab
|
|
sidebar_position: 1
|
|
---
|
|
|
|
<!--
|
|
Licensed to the Apache Software Foundation (ASF) under one
|
|
or more contributor license agreements. See the NOTICE file
|
|
distributed with this work for additional information
|
|
regarding copyright ownership. The ASF licenses this file
|
|
to you under the Apache License, Version 2.0 (the
|
|
"License"); you may not use this file except in compliance
|
|
with the License. You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing,
|
|
software distributed under the License is distributed on an
|
|
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
KIND, either express or implied. See the License for the
|
|
specific language governing permissions and limitations
|
|
under the License.
|
|
-->
|
|
|
|
# SQL Lab Extension Points
|
|
|
|
SQL Lab provides 4 extension points where extensions can contribute custom UI components. Each area serves a specific purpose and supports different types of customizations. These areas will evolve over time as new features are added to SQL Lab.
|
|
|
|
## Layout Overview
|
|
|
|
```
|
|
┌──────────┬─────────────────────────────────────────┬─────────────┐
|
|
│ │ │ │
|
|
│ │ │ │
|
|
│ │ Editor │ │
|
|
│ │ │ │
|
|
│ Left │ │ Right │
|
|
│ Sidebar ├─────────────────────────────────────────┤ Sidebar │
|
|
│ │ │ │
|
|
│ │ Panels │ │
|
|
│ │ │ │
|
|
│ │ │ │
|
|
│ │ │ │
|
|
└──────────┴─────────────────────────────────────────┴─────────────┘
|
|
```
|
|
|
|
| Extension Point | ID | Views | Menus | Description |
|
|
| ----------------- | --------------------- | ----- | ----- | ---------------------------------------------- |
|
|
| **Left Sidebar** | `sqllab.leftSidebar` | — | ✓ | Menu actions for the database explorer |
|
|
| **Editor** | `sqllab.editor` | ✓\* | ✓ | Custom editors + toolbar actions |
|
|
| **Right Sidebar** | `sqllab.rightSidebar` | ✓ | — | Custom panels (AI assistants, query analysis) |
|
|
| **Panels** | `sqllab.panels` | ✓ | ✓ | Custom tabs + toolbar actions (data profiling) |
|
|
|
|
\*Editor views are contributed via [Editor Contributions](./editors.md), not standard view contributions.
|
|
|
|
## Customization Types
|
|
|
|
### Views
|
|
|
|
Extensions can add custom views (React components) to **Right Sidebar** and **Panels**. Views appear as new panels or tabs in their respective areas.
|
|
|
|
### Menus
|
|
|
|
Extensions can add toolbar actions to **Left Sidebar**, **Editor**, and **Panels**. Menu contributions support:
|
|
|
|
```
|
|
┌───────────────────────────────────────────────────────────────┐
|
|
│ [Button] [Button] [•••] │
|
|
├───────────────────────────────────────────────────────────────┤
|
|
│ Area Content │
|
|
└───────────────────────────────────────────────────────────────┘
|
|
```
|
|
|
|
| Action Type | Location | Use Case |
|
|
| --------------------- | ---------------- | ----------------------------------------------------- |
|
|
| **Primary Actions** | Toolbar buttons | Frequently used actions (e.g., run, refresh, add new) |
|
|
| **Secondary Actions** | 3-dot menu (•••) | Less common actions (e.g., export, settings) |
|
|
|
|
### Custom Editors
|
|
|
|
Extensions can replace the default SQL editor with custom implementations (Monaco, CodeMirror, etc.). See [Editor Contributions](./editors.md) for details.
|
|
|
|
## Examples
|
|
|
|
### Adding a Panel
|
|
|
|
This example adds a "Data Profiler" panel to SQL Lab:
|
|
|
|
```typescript
|
|
import React from 'react';
|
|
import { views } from '@apache-superset/core';
|
|
import DataProfilerPanel from './DataProfilerPanel';
|
|
|
|
views.registerView(
|
|
{ id: 'my-extension.data-profiler', name: 'Data Profiler' },
|
|
'sqllab.panels',
|
|
() => <DataProfilerPanel />,
|
|
);
|
|
```
|
|
|
|
### Adding Actions to the Editor
|
|
|
|
This example adds primary, secondary, and context actions to the editor:
|
|
|
|
```typescript
|
|
import { commands, menus, sqlLab } from '@apache-superset/core';
|
|
|
|
commands.registerCommand(
|
|
{ id: 'my-extension.format', title: 'Format Query', icon: 'FormatPainterOutlined' },
|
|
async () => {
|
|
const tab = sqlLab.getCurrentTab();
|
|
if (tab) {
|
|
const editor = await tab.getEditor();
|
|
// Format the SQL query
|
|
}
|
|
},
|
|
);
|
|
|
|
commands.registerCommand(
|
|
{ id: 'my-extension.explain', title: 'Explain Query' },
|
|
async () => {
|
|
const tab = sqlLab.getCurrentTab();
|
|
if (tab) {
|
|
const editor = await tab.getEditor();
|
|
// Show query explanation
|
|
}
|
|
},
|
|
);
|
|
|
|
commands.registerCommand(
|
|
{ id: 'my-extension.copy-as-cte', title: 'Copy as CTE' },
|
|
async () => {
|
|
const tab = sqlLab.getCurrentTab();
|
|
if (tab) {
|
|
const editor = await tab.getEditor();
|
|
// Copy selected text as CTE
|
|
}
|
|
},
|
|
);
|
|
|
|
menus.registerMenuItem(
|
|
{ view: 'builtin.editor', command: 'my-extension.format' },
|
|
'sqllab.editor',
|
|
'primary',
|
|
);
|
|
menus.registerMenuItem(
|
|
{ view: 'builtin.editor', command: 'my-extension.explain' },
|
|
'sqllab.editor',
|
|
'secondary',
|
|
);
|
|
menus.registerMenuItem(
|
|
{ view: 'builtin.editor', command: 'my-extension.copy-as-cte' },
|
|
'sqllab.editor',
|
|
'context',
|
|
);
|
|
```
|
|
|
|
## Next Steps
|
|
|
|
- **[Contribution Types](../contribution-types)** - Learn about other contribution types (commands, menus)
|
|
- **[Development](../development)** - Set up your development environment
|
|
- **[Quick Start](../quick-start)** - Build a complete extension
|