mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-25 12:34:45 -04:00
![renovate[bot]](/assets/img/avatar_default.png)
* Update dependency eslint-plugin-import to v2.25.2 Signed-off-by: Renovate Bot <bot@renovateapp.com> Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de> * Make type imports more explicit Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de> * Enforce use of type imports Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de> Co-authored-by: Renovate Bot <bot@renovateapp.com> Co-authored-by: Tilman Vatteroth <git@tilmanvatteroth.de>
41 lines
1.4 KiB
TypeScript
41 lines
1.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import React from 'react'
|
|
import { Dropdown } from 'react-bootstrap'
|
|
import type { TocAst } from 'markdown-it-toc-done-right'
|
|
import { ForkAwesomeIcon } from '../../common/fork-awesome/fork-awesome-icon'
|
|
import { TableOfContents } from '../../editor-page/table-of-contents/table-of-contents'
|
|
import './markdown-toc-button.scss'
|
|
|
|
export interface MarkdownTocButtonProps {
|
|
tocAst: TocAst
|
|
baseUrl: string
|
|
}
|
|
|
|
/**
|
|
* Renders a button that is hovering over the parent and shows a {@link TableOfContents table of contents list} as overlay if clicked.
|
|
*
|
|
* @param tocAst the {@link TocAst AST} that should be rendered.
|
|
* @param baseUrl the base url that will be used to generate the links
|
|
* @return the created component
|
|
*/
|
|
export const TableOfContentsHoveringButton: React.FC<MarkdownTocButtonProps> = ({ tocAst, baseUrl }) => {
|
|
return (
|
|
<div className={'markdown-toc-sidebar-button'}>
|
|
<Dropdown drop={'up'}>
|
|
<Dropdown.Toggle id='toc-overlay-button' variant={'secondary'} className={'no-arrow'}>
|
|
<ForkAwesomeIcon icon={'list-ol'} />
|
|
</Dropdown.Toggle>
|
|
<Dropdown.Menu>
|
|
<div className={'p-2'}>
|
|
<TableOfContents ast={tocAst} baseUrl={baseUrl} />
|
|
</div>
|
|
</Dropdown.Menu>
|
|
</Dropdown>
|
|
</div>
|
|
)
|
|
}
|