mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 04:48:53 +00:00
70 lines
1.7 KiB
TypeScript
70 lines
1.7 KiB
TypeScript
import { ShadowlessElement } from '@blocksuite/affine/block-std';
|
|
import { WithDisposable } from '@blocksuite/affine/global/lit';
|
|
import type { TestAffineEditorContainer } from '@blocksuite/integration-test';
|
|
import { effect } from '@preact/signals-core';
|
|
import { css, html, nothing } from 'lit';
|
|
import { customElement, property, state } from 'lit/decorators.js';
|
|
|
|
@customElement('custom-frame-panel')
|
|
export class CustomFramePanel extends WithDisposable(ShadowlessElement) {
|
|
static override styles = css`
|
|
.custom-frame-container {
|
|
position: absolute;
|
|
top: 0;
|
|
right: 0;
|
|
border: 1px solid var(--affine-border-color, #e3e2e4);
|
|
background-color: var(--affine-background-primary-color);
|
|
height: 100vh;
|
|
width: 320px;
|
|
box-sizing: border-box;
|
|
padding-top: 16px;
|
|
z-index: 1;
|
|
}
|
|
`;
|
|
|
|
private _renderPanel() {
|
|
return html`<affine-frame-panel
|
|
.host=${this.editor.std.host}
|
|
></affine-frame-panel>`;
|
|
}
|
|
|
|
override connectedCallback(): void {
|
|
super.connectedCallback();
|
|
|
|
this.disposables.add(
|
|
effect(() => {
|
|
const std = this.editor.std;
|
|
if (std) {
|
|
this.editor.updateComplete
|
|
.then(() => this.requestUpdate())
|
|
.catch(console.error);
|
|
}
|
|
})
|
|
);
|
|
}
|
|
|
|
override render() {
|
|
return html`
|
|
${this._show
|
|
? html`<div class="custom-frame-container">${this._renderPanel()}</div>`
|
|
: nothing}
|
|
`;
|
|
}
|
|
|
|
toggleDisplay() {
|
|
this._show = !this._show;
|
|
}
|
|
|
|
@state()
|
|
private accessor _show = false;
|
|
|
|
@property({ attribute: false })
|
|
accessor editor!: TestAffineEditorContainer;
|
|
}
|
|
|
|
declare global {
|
|
interface HTMLElementTagNameMap {
|
|
'custom-frame-panel': CustomFramePanel;
|
|
}
|
|
}
|